source: trunk/info/info/alkis/alkisbestnw.php @ 350

Revision 350, 20.0 KB checked in by frank.jaeger, 9 years ago (diff)

ALKIS-Auskunft: Bestandsnachweis verbessert

RevLine 
[330]1<?php
2/*      Modul: alkisbestnw.php
3
4        ALKIS-Buchauskunft, Kommunales Rechenzentrum Minden-Ravensberg/Lippe (Lemgo).
5        Bestandsnachweis fÃŒr ein Grundbuch aus ALKIS PostNAS
6
7        Version:
8        2011-11-17 Parameter der Functions geÀndert
9        2011-11-22 Feldname land in ax_buchungsblattbezirk geÀndert
10        2011-11-30 import_request_variables
11        2012-07-24 Export CSV
12        2013-04-08 deprecated "import_request_variables" ersetzt
13        2014-09-10 PostNAS 0.8: ohne Tab. "alkis_beziehungen", mehr "endet IS NULL", Spalten varchar statt integer
[333]14        2014-09-15 Bei Relationen den Timestamp abschneiden
[339]15        2014-09-30 RÃŒckbau substring(gml_id)
[350]16        2014-12-30 Berechtigte GB nach "an BVNR" dieses Bestandes sortieren
[330]17*/
[132]18session_start();
[330]19$cntget = extract($_GET);
20require_once("alkis_conf_location.php");
21if ($auth == "mapbender") {require_once($mapbender);}
[132]22include("alkisfkt.php");
[330]23if ($id == "j") {$idanzeige=true;} else {$idanzeige=false;}
24$keys = isset($_GET["showkey"]) ? $_GET["showkey"] : "n";
[132]25if ($keys == "j") {$showkey=true;} else {$showkey=false;}
[330]26
27?>
28<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
29<html>
30<head>
31        <meta name="author" content="b600352" >
32        <meta http-equiv="cache-control" content="no-cache">
33        <meta http-equiv="pragma" content="no-cache">
34        <meta http-equiv="expires" content="0">
35        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
36        <title>ALKIS Bestandsnachweis</title>
37        <link rel="stylesheet" type="text/css" href="alkisauszug.css">
38        <link rel="shortcut icon" type="image/x-icon" href="ico/Grundbuch.ico">
39        <script type="text/javascript">
[301]40                function ALKISexport() {
[306]41                        window.open(<?php echo "'alkisexport.php?gkz=".$gkz."&tabtyp=grundbuch&gmlid=".$gmlid."'"; ?>);
[330]42                }
[198]43        </script>
[330]44        <style type='text/css' media='print'>
45                .noprint {visibility: hidden;}
46        </style>
47</head>
48<body>
49<?php
50$con = pg_connect("host=".$dbhost." port=".$dbport." dbname=".$dbname." user=".$dbuser." password=".$dbpass);
51if (!$con) echo "<p class='err'>Fehler beim Verbinden der DB</p>\n";
52
53// G R U N D B U C H
54$sql="SELECT g.gml_id, g.bezirk, g.buchungsblattnummermitbuchstabenerweiterung AS nr, g.blattart,
55b.gml_id, b.bezirk, b.bezeichnung AS beznam, a.gml_id, a.land, a.bezeichnung, a.stelle, a.stellenart
56FROM ax_buchungsblatt g LEFT JOIN ax_buchungsblattbezirk b ON g.land=b.land AND g.bezirk=b.bezirk
57LEFT JOIN ax_dienststelle a ON b.land=a.land AND b.stelle=a.stelle
58WHERE g.gml_id= $1 AND a.stellenart=1000 AND g.endet IS NULL AND a.endet IS NULL;";
59
60$v = array($gmlid);
61$res = pg_prepare("", $sql);
62$res = pg_execute("", $v);
63
64if (!$res) {
65        echo "<p class='err'>Fehler bei Grundbuchdaten.</p>";
66        if ($debug > 2) {echo "<p class='dbg'>SQL=<br>".$sql."<br>$1 = gml_id = '".$gmlid."'</p>";}
67}
68if ($row = pg_fetch_array($res)) {
69        $blattkey=$row["blattart"];
70        $blattart=blattart($blattkey);
71        echo "<p class='gbkennz'>ALKIS Bestand ".$row["bezirk"]." - ".$row["nr"]."&nbsp;</p>\n"; // Balken
72        echo "\n<h2><img src='ico/Grundbuch.ico' width='16' height='16' alt=''> Grundbuch</h2>";
73        echo "\n<table class='outer'>\n<tr>\n\t<td>"; // Kennz. im Rahmen
74                if ($blattkey == 1000) {
75                        echo "\n\t<table class='kennzgb' title='Bestandskennzeichen'>";
76                } else {
77                        echo "\n\t<table class='kennzgbf' title='Bestandskennzeichen'>"; // dotted
78                }
79                        echo "\n\t<tr>";
80                                echo "\n\t\t<td class='head'>".dienststellenart($row["stellenart"])."</td>";
81                                echo "\n\t\t<td class='head'>Bezirk</td>";
82                                echo "\n\t\t<td class='head'>".$blattart."</td>";
83                        echo "\n\t</tr>\n\t<tr>";
84                                echo "\n\t\t<td title='Amtsgerichtsbezirk'>";
85                                if ($showkey) {
86                                        echo "<span class='key'>".$row["stelle"]."</span><br>";
87                                }
88                                echo htmlentities($row["bezeichnung"], ENT_QUOTES, "UTF-8")."</td>";
89                                echo "\n\t\t<td title='Grundbuchbezirk'>";
90                                if ($showkey) {
91                                        echo "<span class='key'>".$row["bezirk"]."</span><br>";
92                                }
93                                echo htmlentities($row["beznam"], ENT_QUOTES, "UTF-8")."</td>";
94                                echo "\n\t\t<td title='Grundbuch-Blatt'><span class='wichtig'>".$row["nr"]."</span></td>";
95                        echo "\n\t</tr>";
96                echo "\n\t</table>";
97
98                echo "\n\n\t</td>\n\t<td>";
99                if ($idanzeige) {linkgml($gkz, $gmlid, "Buchungsblatt", "");}
100        echo "\n\t</td>\n</tr>\n</table>";
101}
102
103if ($blattkey == 5000) { // fikt. Blatt
104        echo "\n<p>Keine Angaben zum Eigentum bei fiktivem Blatt.</p>\n";
[350]105} else {
106        // E I G E N T U E M E R
[330]107        echo "\n<h3><img src='ico/Eigentuemer_2.ico' width='16' height='16' alt=''> Angaben zum Eigentum</h3>\n";
108        $n = eigentuemer($con, $gmlid, true, ""); // MIT Adressen.
109        if ($n == 0) { // keine NamensNr, kein Eigentuemer
110                echo "\n<p class='err'>Keine Namensnummer gefunden.</p>";
111                echo "\n<p>Bezirk: ".$row["bezirk"].", Blatt: ".$row["nr"].", Blattart ".$blattkey." (".$blattart.")</p>";
112                linkgml($gkz, $gmlid, "Buchungsblatt", "");
113        }
114}
115
[350]116// Vorab pruefen, ob der Fall "Rechte an .." vorliegt.
[330]117if ($blattkey == 1000) { // GB-Blatt  <istBestandteilVon<  sh=herrschend  >an>  sd=dienend
118        $sql="SELECT count(sd.laufendenummer) AS anzahl
[339]119        FROM ax_buchungsstelle sh JOIN ax_buchungsstelle sd ON (sd.gml_id=ANY(sh.an) OR sd.gml_id=ANY(sh.zu))
[330]120        WHERE sh.istbestandteilvon= $1 AND sd.endet IS NULL AND sh.endet IS NULL;";
121
[350]122        $v=array($gmlid); // GB-Blatt
[330]123        $res=pg_prepare("", $sql);
124        $res=pg_execute("", $v);
125        if (!$res) echo "<p class='err'>Fehler bei Suche nach Buchungen.</p>\n";
126        $row=pg_fetch_array($res);
127        $anz=$row["anzahl"];
128        //echo "<p>Zeilen : ".$anz." zu Blattart ".$blattkey."</p>";
129} else { // 2000: Katasterblatt, 3000: Pseudoblatt, 5000: Fiktives Blatt
130        $anz=0;
131}
132if ($anz > 0) {
133        echo "\n<hr>\n\n<h3><img src='ico/Flurstueck.ico' width='16' height='16' alt=''> Rechte und Flurst&uuml;cke</h3>";
134        echo "\n<table class='fs'>";
[350]135        echo "\n<tr>"; // zusÀtzliche Kopfzeile
[330]136                echo "\n\t<td>&nbsp;</td>";
137                echo "\n\t<td class='dien' title='herrschendes Grundst&uuml;ck'>herrschende Buchungsart</td>";
138                echo "\n\t<td>&nbsp;</td>";
139                echo "\n\t<td class='dien'>Bezirk</td>";
140                echo "\n\t<td class='dien'>Blatt</td>";
141                echo "\n\t<td class='dien'>BVNR</td>";
142                echo "\n\t<td class='dien' title='dienendes Grundst&uuml;ck'>Buchungsart</td>";
143                echo "\n\t<td>&nbsp;</td>";
144        echo "\n</tr>";
145} else {
146        echo "\n<hr>\n\n<h3><img src='ico/Flurstueck.ico' width='16' height='16' alt=''> Flurst&uuml;cke</h3>";
147        echo "\n<table class='fs'>";
148}
149
[350]150echo "\n<tr>"; // gemeinsame Kopfzeile
[330]151        echo "\n\t<td class='head' title='laufende Nummer Bestandsverzeichnis (BVNR) = Grundst&uuml;ck'><span class='wichtig'>BVNR</span></td>";
152        echo "\n\t<td class='head'>Buchungsart</td>";
153        echo "\n\t<td class='head'>Anteil</td>";
154        echo "\n\t<td class='head'>Gemarkung</td>";
155        echo "\n\t<td class='head'>Flur</td>";
[350]156        echo "\n\t<td class='head fsnr' title='Flurst&uuml;cksnummer (Z&auml;hler / Nenner)'><span class='wichtig'>Flurst.</span></td>";
[330]157        echo "\n\t<td class='head fla'>Fl&auml;che</td>"; // 7
158        echo "\n\t<td class='head nwlink noprint' title='Link: weitere Auskunft'>weit. Auskunft</td>";
159echo "\n</tr>";
160
161// Blatt ->  B u c h u n g s s t e l l e
162// aktuelles ax_buchungsblatt <istBestandteilVon< ax_buchungsstelle
163$sql ="SELECT s.gml_id, s.buchungsart, s.laufendenummer AS lfd, s.beschreibungdesumfangsderbuchung AS udb, s.zaehler, s.nenner, s.nummerimaufteilungsplan AS nrap, s.beschreibungdessondereigentums AS sond, b.bezeichner as bart
[339]164FROM ax_buchungsstelle s LEFT JOIN v_bs_buchungsart b ON s.buchungsart=b.wert
[330]165WHERE s.istbestandteilvon= $1 AND s.endet IS NULL ORDER BY cast(s.laufendenummer AS integer);";
166
[350]167$v=array($gmlid); // Rel. istBestandteilVon
[330]168$res=pg_prepare("", $sql);
169$res=pg_execute("", $v);
170
171if (!$res) {
172        echo "<p class='err'>Fehler bei Buchung.</p>\n";
[339]173        if ($debug > 2) {echo "<p class='dbg'>SQL=<br>".$sql."<br>$1 = gml_id = '". $gmlid."'</p>";}
[330]174}
175$i=0;
176$fscnt=0;
[350]177while($row = pg_fetch_array($res)) { // Loop Buchungsstelle (GrundstÃŒck)
[333]178        $lfdnr=$row["lfd"];
179        $bvnr=str_pad($lfdnr, 4, "0", STR_PAD_LEFT);
180        $gml_bs= $row["gml_id"]; // id der buchungsstelle
181        $ba=$row["bart"]; // Buchungsart aus Schluesseltabelle
[330]182
183        if ($row["zaehler"] == "") {
184                $anteil = "";
185        } else {
186                $anteil = $row["zaehler"]."/".$row["nenner"];
187        }
188        // F l u r s t u e c k s d a t e n  zur direkten Buchungsstelle
189        $j = bnw_fsdaten($con, $lfdnr, $gml_bs, $ba, $anteil, true); // return=Anzahl der FS
190        $fscnt=$fscnt + $j;
191        if ($j == 0) { //  k e i n e  Flurstuecke gefunden (Miteigentumsnteil usw.)
192                // Bei "normalen" Grundstuecken wurden Flurstuecksdaten gefunden und ausgegeben.
193                // Bei Miteigentumsanteil, Erbbaurecht usw. muss nach weiteren Buchungsstellen gesucht werden:
194                //  Buchungsstelle >an/zu> (andere)Buchungsstelle >istBestandTeilVon> "FiktivesBlatt (ohne) Eigentuemer"
195
196                // andere Buchungsstellen
197                //  ax_buchungsstelle >zu> ax_buchungsstelle (des gleichen Blattes)
198                //  ax_buchungsstelle >an> ax_buchungsstelle (anderes Blatt, z.B Erbbaurecht an)
199                //  sh=herrschend          sd=dienend
[350]200                $sql ="SELECT sd.gml_id, sd.buchungsart, sd.laufendenummer AS lfd, sd.beschreibungdesumfangsderbuchung AS udb, sd.nummerimaufteilungsplan AS nrap, sd.beschreibungdessondereigentums AS sond, b.bezeichner AS bart
201        FROM ax_buchungsstelle sh JOIN ax_buchungsstelle sd ON (sd.gml_id=ANY(sh.an) OR sd.gml_id=ANY(sh.zu)) 
202        LEFT JOIN v_bs_buchungsart b ON sd.buchungsart=b.wert
203        WHERE sh.gml_id= $1 AND sh.endet IS NULL AND sd.endet IS NULL ORDER BY sd.laufendenummer;";
[330]204
205                $v=array($gml_bs);
206                $resan=pg_prepare("", $sql);
207                $resan=pg_execute("", $v);
208                if (!$resan) {
209                        echo "<p class='err'>Fehler bei 'andere Buchungsstelle'.</p>\n";
210                        if ($debug > 2) {echo "<p class='dbg'>SQL=<br>".$sql."<br>$1 = gml_id = '".$gmlid."'</p>";}
211                }
212                $a=0; // count
213                $altbvnr=""; // Gruppenwechsel
214                while($rowan = pg_fetch_array($resan)) {
215                        $lfdnran = $rowan["lfd"];               // BVNR an
216                        $gml_bsan= $rowan["gml_id"];    // id der buchungsstelle an
217                        $baan= $rowan["bart"];                  // Buchungsart an, entschluesselt
218
219                        // a n d e r e s   B l a t t  (an dem das aktuelle Blatt Rechte hat)
220                        // dienendes Grundbuch
[350]221                        $sql ="SELECT b.gml_id, b.land, b.bezirk, b.buchungsblattnummermitbuchstabenerweiterung AS blatt, b.blattart, z.bezeichnung AS beznam
222        FROM ax_buchungsblatt b JOIN ax_buchungsstelle s ON b.gml_id=s.istbestandteilvon
223        LEFT JOIN ax_buchungsblattbezirk z ON b.land=z.land AND b.bezirk=z.bezirk
224        WHERE s.gml_id= $1 AND b.endet IS NULL ORDER BY b.land, b.bezirk, b.buchungsblattnummermitbuchstabenerweiterung;";
[330]225                        $v=array($gml_bsan);
226                        $fbres=pg_prepare("", $sql);
227                        $fbres=pg_execute("", $v);
228                        if (!$fbres) {
229                                echo "<p class='err'>Fehler bei fiktivem Blatt.</p>\n";
230                                if ($debug > 2) {echo "<p class='dbg'>SQL=<br>".$sql."<br>$1 = gml_id = '".$gmlid."'</p>";}                     
231                        }
232                        $b=0;
233                        while($fbrow = pg_fetch_array($fbres)) { // genau 1
[333]234                                $fbgml  = $fbrow["gml_id"];
235                                $fbland = $fbrow["land"];
236                                $fbbez  = $fbrow["bezirk"];
[330]237                                $fbblatt = $fbrow["blatt"];
[333]238                                $fbbart = blattart($fbrow["blattart"]);
[330]239                                $beznam = $fbrow["beznam"];
240                                $b++;
241                        }
242                        if ($b != 1) {
243                                echo "<p class='err'>Anzahl fiktive Bl&auml;tter zu anderer Buchungstelle = ".$b."</p>";
244                        }
245
246                        // G r u n d b u c h d a t e n  zur  a n d e r e n  Buchungsstelle
247                        echo "\n<tr>";
248                                echo"\n\t<td>";
249                                        if($bvnr == $altbvnr) { // gleiches Grundstueck
250                                                echo "&nbsp;"; // Anzeige unterdruecken
251                                        } else {
252                                                echo "<a name='bvnr".$lfdnr."'></a>"; // Sprungmarke
253                                                echo "<span class='wichtig'>".$bvnr."</span>"; // Sp.1 Erbbau BVNR
254                                                if ($idanzeige) {linkgml($gkz, $gml_bs, "Buchungsstelle", "ax_buchungsstelle");}
255                                                $altbvnr = $bvnr; // Gruppenwechsel merken
256                                        }
257                                echo "</td>";
258                                echo "\n\t<td class='dien'>"; // Sp.2 Buchung
259                                        if ($showkey) {
260                                                echo "<span class='key'>".$row["buchungsart"]."</span> ";
261                                        }
262                                echo $ba." an</td>";
263                                echo "\n\t<td>".$anteil."</td>"; // Sp.3 Anteil
264                                echo "\n\t<td class='dien'>"; // Sp.4 Gemarkg. hier Bezirk
265                                        if ($showkey) {
266                                                echo "<span class='key'>".$fbbez."</span> ";
267                                        }
268                                        echo $beznam;
269                                echo "</td>"; // Sp.4 hier Bezirk
270                                echo "\n\t<td class='dien'>"; // Sp. 5 Blatt
271                                        echo $fbblatt; // Sp.6 BVNR
272                                        if ($idanzeige) {
273                                                linkgml($gkz, $fbgml, "Buchungsblatt", "");
274                                        }
275                                echo "</td>";
276                                echo "\n\t<td class='dien'>"; // BVNR
277                                        echo str_pad($lfdnran, 4, "0", STR_PAD_LEFT);
278                                        if ($idanzeige) {
279                                                linkgml($gkz, $gml_bsan, "Buchungsstelle", "ax_buchungsstelle");
280                                        }
281
282                                echo "</td>";
283                                echo "\n\t<td class='dien'>"; // Sp.7 Buchungsart
284                                        if ($showkey) {
285                                                echo "<span class='key'>".$rowan["buchungsart"]."</span> ";
286                                        }
287                                        echo $baan." ";
288                                echo "</td>";
289                                echo "\n\t<td>";  // Sp.8 Link ("an" oder "zu" ?)
[350]290                                        echo "<p class='nwlink noprint'>an/zu"; //.$rowan["beziehungsart"] Feld gibt es nicht mehr
[330]291                                        echo " <a href='alkisbestnw.php?gkz=".$gkz."&amp;gmlid=".$fbgml;
292                                                if ($idanzeige) {echo "&amp;id=j";}
293                                                if ($showkey)   {echo "&amp;showkey=j";}
294                                                echo "#bvnr".$lfdnran; // Sprungmarke auf der Seite
295                                                echo "' title='Grundbuchnachweis des dienenden Blattes'>";
296                                                echo $fbbart;
297                                        echo " <img src='ico/GBBlatt_link.ico' width='16' height='16' alt=''></a></p>";
298                                echo "</td>";
299                        echo "\n</tr>";
300
301                        // F l u r s t u e c k s d a t e n  zur  a n d e r e n  Buchungsstelle
[129]302                        // Buchungsart wird nur in erster Zeile ausgegeben, hier leer
[330]303                        $aj = bnw_fsdaten($con, $lfdnran, $gml_bsan, "", $anteil, false); // return=Anz.FS
304                        $fscnt=$fscnt + $aj;
305                        // +++ Gibt es Sondereigentum beim fiktiven Blatt?
306                        if ($rowan["nrap"] != "") {
307                                echo "\n<tr>";
308                                        echo "\n\t<td class='sond' colspan=8>Nr. im Aufteilungsplan: ".$rowan["nrap"]."</td>";
309                                echo "\n</tr>";
310                        }
311                        if ($rowan["sond"] != "") {
312                                echo "\n<tr>";
313                                        echo "\n\t<td class='sond' colspan=8>Verbunden mit dem Sondereigentum an: ".$rowan["sond"]."</td>";
314                                echo "\n</tr>";
315                        }
316                        $a++;
317                }
318                if ($a == 0) {
319                        echo "\n<tr>";
320                                echo "\n\t<td><span class='wichtig'>".$bvnr."</span>";
321                                if ($idanzeige) {
322                                        linkgml($gkz, $gml_bs, "Buchungsstelle", "ax_buchungsstelle");
323                                }
324                                echo "</td>";
325                                echo "\n\t<td colspan=7>";
[333]326                                        echo "<p class='warn'>Flurst&uuml;cke zu ".$bvnr." nicht gefunden.</p>";
[330]327                                echo "</td>";
328                        echo "\n</tr>";
329                }
330        }
331        $i++;
332        if ($row["nrap"] != "") { // Nr im Auft.Plan
333                echo "\n<tr>";
334                        echo "\n\t<td class='nrap' colspan=8>Nummer <span class='wichtig'>".$row["nrap"]."</span> im Aufteilungsplan.</td>";
335                echo "\n</tr>";
336        }
337        if ($row["sond"] != "") { // Sondereigentumsbeschreibung
338                echo "\n<tr>";
339                        echo "\n\t<td class='sond' colspan=8>Verbunden mit dem Sondereigentum an: ".$row["sond"]."</td>";
340                echo "\n</tr>";
341        } // Ende Buchungsstelle/BVNR
342} // Ende Loop
343echo "\n</table>";
344
345if ($i == 0) {
346        echo "\n<p class='err'>Keine Buchung gefunden.</p>\n";
347        linkgml($gkz, $gmlid, "Buchungsblatt", "");
348} else {
349        if ($i > 5 and $fscnt > 5) { // nur wenn nicht auf einen Blick zu erkennen
[333]350                echo "\n<p class='cnt'>".$i." Buchungen mit ".$fscnt." Flurst&uuml;cken</p>\n";
[330]351        }
352}
353
[350]354// B e r e c h t i g t e  Buchungsblaetter  mit Recht an/zu dem aktuellen (fiktiven?) Blatt
[330]355
[350]356// bf                          sf            sb                               bb
[330]357// Blatt   <istBestandteilVon< Stelle  <an<  Stelle      >istBestandteilVon>  Blatt
358// Fiktiv                      Fiktiv  <zu<  Berechtigt                       Berechtigt
[350]359$sql="SELECT sf.laufendenummer AS anlfdnr, bb.gml_id, bb.land, bb.bezirk, bb.buchungsblattnummermitbuchstabenerweiterung AS blatt, bb.blattart,
[330]360sb.gml_id AS gml_s, sb.laufendenummer AS lfdnr, sb.buchungsart, ba.bezeichner AS bart, bz.bezeichnung AS beznam, ag.bezeichnung, ag.stelle, ag.stellenart
[339]361FROM ax_buchungsstelle sf JOIN ax_buchungsstelle sb ON (sf.gml_id=ANY(sb.an) OR sf.gml_id=ANY(sb.zu))
362JOIN ax_buchungsblatt bb ON bb.gml_id=sb.istbestandteilvon
[330]363LEFT JOIN ax_buchungsblattbezirk bz ON bb.land=bz.land AND bb.bezirk=bz.bezirk
364LEFT JOIN ax_dienststelle ag ON bz.land=ag.land AND bz.stelle=ag.stelle
[339]365LEFT JOIN v_bs_buchungsart ba ON sb.buchungsart=ba.wert
[350]366WHERE sf.istbestandteilvon = $1 AND sf.endet IS NULL AND sb.endet IS NULL AND bb.endet IS NULL
367ORDER BY cast(sf.laufendenummer AS integer), bb.land, bb.bezirk, bb.buchungsblattnummermitbuchstabenerweiterung, cast(sb.laufendenummer AS integer);";
368// Änd. 2014-12-30: Sort. wie im ersten Teil
[330]369
[350]370$v = array($gmlid);
[330]371$resb = pg_prepare("", $sql);
372$resb = pg_execute("", $v);
373if (!$resb) {
[350]374        echo "<p class='err'>Fehler bei 'Berechtigte Bl&auml;tter.</p>\n";
[339]375        if ($debug > 2) {echo "<p class='dbg'>SQL=<br>".$sql."<br>$1 = gml_id = '".$gmlid."'</p>";}
[330]376}
[350]377$b=0; // count: Buchungen / BlÀtter
[330]378while($rowb = pg_fetch_array($resb)) {
379        if ($b == 0) { // Ueberschrift und Tabelle nur ausgeben, wenn etwas gefunden wurde
380                echo "\n<h3><img src='ico/Grundbuch_zu.ico' width='16' height='16' alt=''> Berechtigte Grundb&uuml;cher</h3>\n";
381                echo "\n<table class='outer'>";
[350]382                echo "\n<tr>"; // Tab Kopf
383                        echo "\n\t<td class='head' title='lfd. Nr. auf diesem Blatt, wie im Teil Flurst&uuml;cke'>an <span class='wichtig'>BVNR</span></td>"; // wie oben
[330]384                        echo "\n\t<td class='head'>Land</td>";
385                        echo "\n\t<td class='head'>Dienststelle</td>";
386                        echo "\n\t<td class='head'>Bezirk</td>";
[350]387                        echo "\n\t<td class='head'><span class='wichtig'>Blatt</span></td>";
388                        echo "\n\t<td class='head'>BVNR</td>";
389                        echo "\n\t<td class='head'>Buchungsart</td>";
[330]390                        echo "\n\t<td class='head nwlink noprint'>Weitere Auskunft</td>";
391                echo "\n</tr>";
392        }
[350]393
394        $anlfdnr=$rowb["anlfdnr"]; // an BVNR
395        $anlfdnr0=str_pad($anlfdnr, 4, "0", STR_PAD_LEFT); // mit fÃŒhr.0
396        $gml_b=$rowb["gml_id"]; // id des ber. Blattes
397        $gml_s=$rowb["gml_s"]; // id der ber. B-Stelle
[330]398        $blart=$rowb["blattart"];
399        $buch=$rowb["buchungsart"]; // Buchungsart Stelle berechtigt
[350]400        $bart=$rowb["bart"]; // BA entschl.
401        $lfdnr=$rowb["lfdnr"]; // BVNR ber.
[330]402        $bvnr=str_pad($lfdnr, 4, "0", STR_PAD_LEFT);
403
404        echo "\n<tr>";
[350]405                // Teil berechtigte GrundbÃŒcher ist sortiert wie oberer Teil "FlurstÃŒcke"
406                echo "\n\t<td><span class='wichtig'>".$anlfdnr0."</span>";
407                // Link "nach oben" - bringt das Nutzen? Nur bei ganz langen BestÀnden.
408/*                      echo "\n\t\t<p class='noprint'>&nbsp;";
409                        echo "\n\t\t\t<a href='alkisbestnw.php?gkz=".$gkz."&amp;gmlid=".$gmlid."#bvnr".$anlfdnr;
410                                if ($idanzeige) {echo "&amp;id=j";}
411                                if ($showkey)   {echo "&amp;showkey=j";}
412                                echo "' title='Sprung nach oben zum Grundst&uuml;ck'>hoch</a>";
413                        echo "\n\t\t</p>";
414        ++ <p> auflösen, sonst 2 Zeilen im <td> ++
415*/
416                echo "</td>";
[330]417                echo "\n\t<td>".$rowb["land"]."</td>";
418                echo "\n\t<td>"; // Amtsgericht
419                        echo dienststellenart($rowb["stellenart"])." ";
420                        if ($showkey) {
421                                echo "<span class='key'>".$rowb["stelle"]."</span> ";
422                        }
423                        echo $rowb["bezeichnung"];
424                echo "</td>";
425                echo "\n\t<td>";
426                        if ($showkey) {
427                                echo "<span class='key'>".$rowb["bezirk"]."</span> ";
428                        }
429                        echo $rowb["beznam"];
430                echo "</td>";
431                echo "\n\t<td><span class='wichtig'>".$rowb["blatt"]."</span>";
432                        if ($idanzeige) {linkgml($gkz, $gml_b, "Buchungsblatt", "");}
433                echo "</td>";
434                echo "\n\t<td>".$bvnr;
435                        if ($idanzeige) {linkgml($gkz, $gml_s, "Buchungsstelle", "ax_buchungssstelle");}
436                echo "</td>";
437                echo "\n\t<td>";
438                        if ($showkey) {
439                                echo "<span class='key'>".$buch."</span> ";
440                        }
441                        echo $bart;
442                echo "</td>";
443                echo "\n\t<td>";
[350]444                        echo "\n\t\t<p class='nwlink noprint'>";
[330]445                        echo "\n\t\t\t<a href='alkisbestnw.php?gkz=".$gkz."&amp;gmlid=".$gml_b."#bvnr".$lfdnr;
446                                if ($idanzeige) {echo "&amp;id=j";}
447                                if ($showkey)   {echo "&amp;showkey=j";}
448                                echo "' title='Nachweis des berechtigten Blattes an ".$blattart."'>"; // oder "zu" statt "an"
449                                echo blattart($blart);
450                                echo " \n\t\t\t<img src='ico/GBBlatt_link.ico' width='16' height='16' alt=''></a>";
451                        echo "\n\t\t</p>";
452                echo "</td>";
453        echo "\n</tr>";
454        $b++;
455}
456if ($b == 0) {
457        if ($blattkey > 2000 ) { // Warnung nicht bei Grundbuchblatt 1000 und Katasterblatt 2000
458                echo "<p class='err'>Keine berechtigten Bl&auml;tter zu ".$blattart." (".$blattkey.") gefunden.</p>";
459        }
460} else {
461        echo "\n</table>";
[350]462        if ($i > 1) {
463                echo "\n<p class='cnt'>Rechte anderer Buchungsstellen an ".$b." der ".$i." Buchungen</p>\n";
464        }
[330]465}
466?>
467
468<form action=''>
469        <div class='buttonbereich noprint'>
[198]470        <hr>
[315]471                <a title="zur&uuml;ck" href='javascript:history.back()'><img src="ico/zurueck.ico" width="16" height="16" alt="zur&uuml;ck"></a>&nbsp;
472                <a title="Drucken" href='javascript:window.print()'><img src="ico/print.ico" width="16" height="16" alt="Drucken"></a>&nbsp;
473                <a title="Export als CSV" href='javascript:ALKISexport()'><img src="ico/download_gb.ico" width="32" height="16" alt="Export"></a>&nbsp;
[330]474        </div>
475</form>
476
477<?php footer($gmlid, $_SERVER['PHP_SELF']."?", ""); ?>
478
479</body>
[26]480</html>
Note: See TracBrowser for help on using the repository browser.