source: trunk/mapbender/http/nav/alkisnav_fkt.php @ 334

Revision 334, 13.6 KB checked in by frank.jaeger, 10 years ago (diff)

Anpassung der Auskunft-Programme an variabel lange gml_id und Datenbanken mit "beendeten" Objekten.

Line 
1<?php
2/* Version vom
3        2013-05-07  Strukturierung des Programms, redundanten Code in Functions zusammen fassen
4        2013-05-14  Hervorhebung aktuelles Objekt, Title auch auf Icon, IE zeigt sonst alt= als Title dar.
5        2013-05-15  Function verlegt
6        2014-02-06  Korrektur zeile_person
7        2014-09-03  PostNAS 0.8: ohne Tab. "alkis_beziehungen", mehr "endet IS NULL", Spalten varchar statt integer
8        2014-09-15  Bei Relationen den Timestamp abschneiden, mehr "endet IS NULL"
9*/
10
11function is_ne_zahl($wert) {
12        // PrÃŒft, ob ein Wert ausschließlich aus den Zahlen 0 bis 9 besteht
13        if (trim($wert, "0..9") == "") {return true;} else {return false;}
14}
15
16function ZerlegungGBKennz($gbkennz) {
17        // Das eingegebene Grundbuch-Kennzeichen auseinander nehmen (gggg-999999z-BVNR)
18        // Return: 9=Fehler, 0=Listen alle Bezirke 1=Such Bezirk-Name
19        //  2=Such Bezirk-Nummer, 3=Such Blatt, 4=Such Buchung BVNR
20        global $zgbbez, $zblatt, $zblattn, $zblattz, $zbvnr;
21        $arr=explode("-", $gbkennz, 3);
22        $zgbbez=trim($arr[0]);
23        $zblatt=trim($arr[1]);
24        $zbvnr=trim($arr[2]);
25        if ($zgbbez == "") { // keine Eingabe
26                return 0; // Amtsgerichte oder Bezirke listen
27        } elseif ( ! is_ne_zahl($zgbbez)) { // Alphabetische Eingabe
28                return 1; // Such Bezirk-NAME
29        } elseif ($zblatt == "") {
30                return 2; // Such Bezirk-NUMMER
31        } else { // Format von BlattNr pruefen
32        //'19'      linksbÃŒndig
33        //'000019 ' gefÃŒllt 6 + blank
34        //'000019A' .. mit Zusatzbuchstabe
35        //'0300001' gefÃŒllt 7, bei Blattart 5000 "fiktives Blatt"
36                $len=strlen($zblatt);
37                if ($len > 0 AND $len < 8) {           
38                        if (trim($zblatt, "0..9 ") == "") { // Normalfall: nur Zahlen (und Blank))
39                                $zblattn= rtrim(ltrim($zblatt, "0"), " ");
40                                $zblattz="";
41                        } else { // Sonderfall: Zusatz-Buchstabe am Ende
42                                $zblattn=substr($zblatt,0,$len-1);
43                                $zblattz=strtoupper(substr($zblatt,$len-1,1));
44                                if ((trim($zblattn, "0..9") == "") and (trim($zblattz, "A..Z") == "")) {
45                                        $zblattn= ltrim($zblattn, "0"); // ohne fuehrende Nullen
46                                } else {
47                                        echo "<p class='err>Format 'Blatt': bis zu 6 Zahlen und ggf. ein Buchstabe</p>";       
48                                        return 9;
49                                }
50                        }
51                        if ($zbvnr == "") {
52                                return 3; // Such BLATT
53                        } elseif (is_ne_zahl($zbvnr)) {         
54                                // $zbvnr=ltrim($zbvnr,"0"); // DB-Format ist integer
55                                // Vorsicht, Wert "0" ist moeglich und gueltig
56                                return 4; // Such Grundstueck
57                        } else {
58                                echo "<p class='err>Die Buchungsstelle (BVNR) '".$zbvnr."' ist nicht numerisch</p>";
59                                return 9;
60                        }
61                } else {
62                        echo "<p class='err>Das Grundbuch-Blatt '".$zblatt."' ist ung&uuml;ltig.</p>";
63                        return 9;
64                }
65        }
66}
67
68function suchfeld($suchstring) {        // Suchstring Ausgeben UND das Eingabeformular damit belegen
69        $out="<a title='Dies als Suchbegriff setzen' href='javascript:formular_belegung(\"".$suchstring."-\")'>".$suchstring."</a>";
70        return $out;
71}
72
73// function Typ "zeile_**"  = Ausgabe eines Knotens
74// - Icon,  ggf. mit Link zur Buchauskunft
75// - Zeile, ggf. mit Link zur weiteren Auflösung untergeordneter Knoten
76// Hierin die Encodierung fÃŒr url und HTML.
77
78function zeile_ag ($ag, $anr, $aktuell) {       // Zeile  A m t s g e r i c h t
79        global $gkz, $gemeinde, $epsg, $auskpath;
80        if ($ag == "") {
81                $agd=$anr; // Ersatz: Nummer statt Name. Besser: Name immer fÃŒllen
82        } else {
83                $agd=htmlentities($ag, ENT_QUOTES, "UTF-8");
84        }
85        if ($aktuell) {$cls=" aktuell";}
86        echo "\n<div class='ga".$cls."' title='Amtsgericht'>";
87                echo "\n\t\t<img class='nwlink' src='ico/Gericht.ico' width='16' height='16' alt='AG' title='Amtsgericht'> ";
88                echo "AG <a href='".$_SERVER['SCRIPT_NAME']."?gkz=".$gkz."&amp;gemeinde=".$gemeinde."&amp;epsg=".$epsg."&amp;ag=".$anr."'>";           
89                echo $agd."</a> (".$anr.")";
90        echo "\n</div>";
91        return;
92}
93
94function zeile_gbbez ($gnam, $zgbbez, $aktuell) {       // Zeile Grundbuch - B e z i r k
95        // Parameter: aktuell = Bool fÃŒr farbliche Markierung der Zeile als aktuell angeklicktes Obj.
96        global $gkz, $gemeinde, $epsg, $person;
97        $gnamd=htmlentities($gnam, ENT_QUOTES, "UTF-8");
98        if ($aktuell) {$cls=" aktuell";}       
99        echo "\n<div class='gk".$cls."' title='GB-Bezirk'>";
100        echo "\n\t\t<img class='nwlink' src='ico/GB-Bezirk.ico' width='16' height='16' alt='Bez.' title='GB-Bezirk'> ";
101        echo "<a href='".$_SERVER['SCRIPT_NAME']."?gkz=".$gkz."&amp;gemeinde=".$gemeinde."&amp;epsg=".$epsg."&amp;gbkennz=".$zgbbez;
102        echo "&amp;gbbeznam=".urlencode($gnam);
103        if ($person != "") { // EigentÃŒmer-Suche
104                echo "&amp;person=".$person."'>";
105                echo "Bezirk ".$gnamd."</a> (".$zgbbez.")";             
106        } else {  // Grundbuch-Suche
107                echo "'>";
108                echo "Bezirk ".$gnamd."</a> (".suchfeld($zgbbez).")";           
109        }
110        echo "\n</div>";
111        return;
112}
113
114function zeile_blatt ($bezirk, $beznam, $blattgml, $blatt, $dienend, $person, $aktuell) {
115        global $gkz, $gemeinde, $epsg, $auskpath;
116        // Zeile Grundbuch - B l a t t
117        $blattd=ltrim($blatt, "0"); // Display-Version ohne fÃŒhrende Nullen
118        if ( $dienend) {$dientxt="dienendes ";}
119        $blattlnk=urlencode($blatt); // trailing Blank
120        if ($beznam != "") {$nam = $beznam." ";}
121        if ($aktuell) {$cls=" aktuell";}       
122
123        echo "\n<div class='gb".$cls."' title='".$dientxt."GB-Blatt'>";
124
125        // Icon / Nachweis
126        if ($blattgml == "") { // Link zum Nachweis nur wenn GML bekannt
127                echo "\n\t<img class='nwlink' src='ico/GBBlatt_link.ico' width='16' height='16' alt='Blatt' title='".$dientxt."GB-Blatt'>";
128        } else {
129                echo "\n\t<a title='Nachweis' href='javascript:imFenster(\"".$auskpath."alkisbestnw.php?gkz=".$gkz."&amp;gmlid=".$blattgml."\")'>";
130                        echo "\n\t\t<img class='nwlink' src='ico/GBBlatt_link.ico' width='16' height='16' alt='Blatt' title='Nachweis'>";
131                echo "\n\t</a> ";
132        }
133
134        // Text, Self-Link
135        echo $nam." <a href='".$_SERVER['SCRIPT_NAME']."?gkz=".$gkz."&amp;gemeinde=".$gemeinde."&amp;epsg=".$epsg;
136        echo "&amp;blattgml=".$blattgml."&amp;gbkennz=".$bezirk."-".$blattlnk;
137
138        echo "&amp;gbbeznam=".urlencode($beznam);
139
140        if ($person != "") {echo "&amp;person=".$person;} // nur fÃŒr EigentÃŒmer-Suche
141        echo "'>Blatt&nbsp;".$blattd."</a>\n</div>";
142        return;
143}
144
145function zeile_buchung($buchunggml, $bvnr, $blattkennz, $dienend, $aktuell) {
146        // Zeile  B u c h u n g s s t e l l e  -  GrundstÃŒck ausgeben
147        global $gkz, $gemeinde, $epsg, $auskpath;
148        if ($bvnr == 0) {
149                $bvnra = "-";
150        } else {
151                $bvnra = str_pad($bvnr, 4, "0", STR_PAD_LEFT); // auf 4 Stellen
152        }
153        if ($diened) {
154                $ti="dienendes&nbsp;";
155                $re="Recht an ";
156        } else {
157                $ti="";
158                $re="";
159        }
160        if ($aktuell) {$cls=" aktuell";}       
161        echo "\n<div class='gs".$cls."' title='".$ti."Grundst&uuml;ck'>";
162        echo "\n\t<img class='nwlink' src='ico/Grundstueck.ico' width='16' height='16' alt='GS'  title='".$ti."Grundst&uuml;ck'> ".$re;
163        if ($blattkennz == "") { // ohne Link
164                echo "Buchung ".$bvnra;
165        } else {
166                $gbkennlnk=urlencode($blattkennz."-".$bvnr); // Trailing Blanks!
167                echo "<a href='".$_SERVER['SCRIPT_NAME']. "?gkz=". $gkz."&amp;gemeinde=".$gemeinde."&amp;epsg=".$epsg."&amp;buchunggml=".$buchunggml;
168                echo "&amp;gbkennz=".$gbkennlnk."'>Buchung ".$bvnra."</a>";
169        }
170        echo "\n</div>";
171        return;
172}
173
174function zeile_gemeinde ($gmdnr, $gmdname, $aktuell) {
175        // Eine Zeile zu Gemeinde ausgeben, SchlÃŒssel und Name wird ÃŒbergeben
176        global $gkz, $gemeinde, $epsg;
177        $stadt=htmlentities($gmdname, ENT_QUOTES, "UTF-8");
178        $bez=urlencode($gmdname);
179        if ($aktuell) {$cls=" aktuell";}
180        echo "\n<div class='gm".$cls."' title='Gemeinde'>";
181                echo "\n\t\t<img class='nwlink' src='ico/Gemeinde.ico' width='16' height='16' alt='Stadt'>";
182                echo " Gem. <a href='".$_SERVER['SCRIPT_NAME']."?gkz=".$gkz."&amp;gemeinde=".$gemeinde."&amp;epsg=".$epsg."&amp;gm=".$gmdnr."&amp;bez=".$bez."'>";             
183                echo  " ".$stadt."</a> (".$gmdnr.")";
184        echo "\n</div>";
185        return;
186}
187
188function zeile_flurstueck ($fs_gml, $fskenn, $x, $y, $gmkg, $flur, $aktuell) {
189        // Zeile mit Icon (Link zum Buch-Nachweis) und Text (Link zum Positionieren)
190        global $gkz, $gemeinde, $epsg, $auskpath, $scalefs;
191
192        if ($aktuell) {$cls=" aktuell";}
193        echo "\n<div class='fs".$cls."'>";
194        echo "\n\t<a title='Nachweis' href='javascript:imFenster(\"".$auskpath."alkisfsnw.php?gkz=".$gkz."&amp;gmlid=".$fs_gml."\")'>";
195                echo "\n\t\t<img class='nwlink' src='ico/Flurstueck_Link.ico' width='16' height='16' alt='FS' title='Nachweis'>";
196        echo "\n\t</a>\n\t";                   
197
198        echo "&nbsp;<a title='Flurst&uuml;ck positionieren 1:".$scalefs."' href='";
199        echo "javascript:";
200                echo "transtitle(\"auf Flurst&uuml;ck positioniert\"); ";
201                echo "parent.parent.parent.mb_repaintScale(\"mapframe1\",".$x.",".$y.",".$scalefs."); ";
202                echo "parent.parent.showHighlight(".$x.",".$y.");' ";
203        echo "onmouseover='parent.parent.showHighlight(".$x.",".$y.")' ";
204        echo "onmouseout='parent.parent.hideHighlight()'>";
205
206        if ($gmkg == "" ) {
207                echo "Flst. "; // Im FS-Teil: Gem+Flur als Knoten darÃŒber ($gmkg und $flur leer)
208        } else {
209                echo $gmkg." "; // Im GB-und Nam-Teil in der Zeile angezeigt
210        }
211        if ($flur != "" ) {echo $flur."-";}
212        echo $fskenn."</a>\n</div>";
213        return;
214}
215
216function zeile_person ($persongml, $nachname, $vorname) {
217        global $gkz, $gemeinde, $epsg, $auskpath;
218        // Zeile  P e r s o n (oder Firma)
219        $nnam=htmlentities($nachname, ENT_QUOTES, "UTF-8");
220        $namlnk=urlencode($nachname);
221        $vnam=htmlentities($vorname, ENT_QUOTES, "UTF-8");
222        // Link zur Auskunft Person ++ Icon differenzieren nach Eigentuemerart?
223
224echo "<div class='pe'>
225        <a title='Nachweis' href='javascript:imFenster(\"".$auskpath."alkisnamstruk.php?gkz=".$gkz."&amp;gemeinde=".$gemeinde."&amp;gmlid=".$persongml."\")'>
226                <img class='nwlink' src='ico/Eigentuemer.ico' width='16' height='16' alt='EIG' title='Nachweis'>
227        </a>           
228        <a title='Person' href='".$_SERVER['SCRIPT_NAME']."?gkz=".$gkz."&amp;gemeinde=".$gemeinde."&amp;epsg=".$epsg."&amp;person=".$persongml."&amp;name=".$namlnk."'>".$nnam.", ".$vnam."</a>
229</div>";
230return;
231}
232
233function GB_Buchung_FS ($linelimit, $blattgbkenn) {
234        // Zu einem Grundbuch-Blatt (identifiziert ÃŒber seine gml_id) suchen der
235        // Buchungen (Gruppenwechsel) und FlurstÃŒcke (Links)
236        global $gemeinde, $blattgml, $epsg, $gfilter, $debug;
237
238        // SQL-Bausteine
239        // vorne gleich
240        $sql1 ="SELECT s1.laufendenummer AS lfd, s1.gml_id AS bsgml, f.gml_id, f.flurnummer, f.zaehler, f.nenner, f.gemeinde, ";
241        if($epsg == "25832") { // Transform nicht notwendig
242                $sql1.="st_x(st_centroid(f.wkb_geometry)) AS x, ";
243                $sql1.="st_y(st_centroid(f.wkb_geometry)) AS y, ";
244        } else { 
245                $sql1.="st_x(st_transform(st_centroid(f.wkb_geometry), ".$epsg.")) AS x, ";
246                $sql1.="st_y(st_transform(st_centroid(f.wkb_geometry), ".$epsg.")) AS y, ";                     
247        }
248        $sql1.="g.gemarkung, g.gemarkungsname FROM ax_buchungsstelle s1 ";
249
250        // zwischen, Variante 1.
251    $sqlz1="JOIN ax_flurstueck f ON f.istgebucht=substring(s1.gml_id,1,16) ";
252
253        // zwischen, Variante 2. Nur an oder "an" und "zu"?
254        $sqlz2 ="JOIN ax_buchungsstelle s2 ON substring(s2.gml_id,1,16)=ANY(s1.an)
255        JOIN ax_flurstueck f ON f.istgebucht=substring(s2.gml_id,1,16) ";
256
257        // hinten gleich
258        $sql2.="JOIN pp_gemarkung g ON f.land=g.land AND f.gemarkungsnummer=g.gemarkung
259        WHERE s1.istbestandteilvon = $1 AND f.endet IS NULL AND s1.endet IS NULL ";
260        switch ($gfilter) {
261                case 1: // Einzelwert
262                        $sql2.="AND g.gemeinde='".$gemeinde."' "; break;
263                case 2: // Liste
264                        $sql2.="AND g.gemeinde in ('".str_replace(",", "','", $gemeinde)."') "; break;
265        }
266
267        // WHERE-Zusatz bei 2
268        $sqlw2=" AND s2.endet IS NULL ";
269
270        $sqlord="ORDER BY cast(s1.laufendenummer AS integer), f.gemarkungsnummer, f.flurnummer, f.zaehler, f.nenner LIMIT $2 ;";
271
272        // d i r e k t e  B u c h u n g e n
273        // Blatt <istBestandteilVon<  Buchungsstelle <istGebucht< FlurstÃŒck
274        $v=array(substr($blattgml,0,16), $linelimit); // Rel. istBestandteilVon nur 16 Stellen
275        $res=pg_prepare("", $sql1.$sqlz1.$sql2.$sqlord);
276        $res=pg_execute("", $v);
277        if (!$res) {
278                echo "\n<p class='err'>Fehler bei Buchung und Flurst&uuml;ck.</p>";
279                if ($debug >= 3) {echo "\n<p class='err'>SQL='".$sql1.$sqlz1.$sql2.$sqlord."'<br>$1 = '".substr($blattgml,0,16)."'</p>";}
280                return;
281        }
282        $zfs1=0;
283        $gwbv="";
284        while($row = pg_fetch_array($res)) {   
285                $bvnr=$row["lfd"];
286                $bsgml=$row["bsgml"]; // Buchungsstelle gml_id
287                if ($gwbv != $bvnr) { // Gruppierung Buchungs-Stelle (BVNR)
288                        $gwbv = $bvnr;
289                        zeile_buchung($bsgml, $bvnr, $blattgbkenn, false, false);
290                }
291                $fs_gml=$row["gml_id"];
292                $gmkg=$row["gemarkungsname"];
293                $flur=$row["flurnummer"];
294                $fskenn=$row["zaehler"];
295                if ($row["nenner"] != "") {$fskenn.="/".$row["nenner"];} // BruchNr
296                $x=$row["x"];
297                $y=$row["y"];
298                zeile_flurstueck ($fs_gml, $fskenn, $x, $y, $gmkg, $flur, false);
299                $zfs1++;
300        }
301        // "nichts gefunden" erst melden, wenn auch Teil 2 (Rechte an) nichts findet
302        if($zfs1 > 1) { // ab 2
303                echo "\n<p class='anz'>".$zfs1." Flurst&uuml;cke zum Grundbuch";
304                if($zfs1 >= $linelimit) {
305                        echo "... und weitere"; //++ BlÀttern einfÃŒhren?
306                }
307                echo "</p>";
308        }
309        if($zfs1 > 0) {echo "<hr>";} // Trennen
310
311        // Rechte "an"  (dienende  Buchungen)
312        $v=array($blattgml, $linelimit);
313        $res=pg_prepare("", $sql1.$sqlz2.$sql2.$sqlw2.$sqlord);
314        $res=pg_execute("", $v);
315        if (!$res) {
316                echo "\n<p class='err'>Fehler bei Recht an Buchung.</p>";
317                #if ($debug >= 3) {echo "\n<p class='dbg'>".$sql1.$sqlz2.$sql2.$sqlw2.$sqlord."</p>";}
318                return;
319        }
320        $zfs2=0;
321        $gwbv="";
322        while($row = pg_fetch_array($res)) {   
323                $bvnr=$row["lfd"];
324                $bsgml=$row["bsgml"]; // Buchungsstelle gml_id
325                if ($gwbv != $bvnr) { // Gruppierung Buchung (BVNR) - dienend
326                        $gwbv = $bvnr;
327                        zeile_buchung($bsgml, $bvnr, $blattgbkenn, true, false);
328                }
329                $fs_gml=$row["gml_id"];
330                $gmkg=$row["gemarkungsname"];
331                $flur=$row["flurnummer"];
332                $fskenn=$row["zaehler"];
333                if ($row["nenner"] != "") {$fskenn.="/".$row["nenner"];} // Bruchnummer
334                zeile_flurstueck ($fs_gml, $fskenn, $row["x"], $row["y"], $gmkg, $flur, false);
335                $zfs2++;
336        }
337        // Foot
338        if($zfs1 + $zfs2 == 0) {
339                echo "\n<p class='anz'>Kein Flurst&uuml;ck im berechtigten Bereich.</p>";
340        } elseif($zfs2 > 1) { // keine Meldung "nichts gefunden - Rechte an" wenn Treffer in Teil 1
341                echo "\n<p class='anz'>".$zfs2." Rechte an Flurst.";
342                if($zfs2 >= $linelimit) {
343                        echo "... und weitere"; // BlÀttern einfÃŒhren?
344                }
345                echo "</p>";
346        }
347        return;
348}
349
350?>
Note: See TracBrowser for help on using the repository browser.