GeoView : Correction for empty databases.
Since page splitting, some incomplete markers. svn: r11747
This commit is contained in:
parent
f8bd056bb3
commit
3369da1fdf
@ -793,7 +793,7 @@ class GeoView(HtmlView):
|
||||
if page == curpage:
|
||||
self.mapview.write(" %d" % page)
|
||||
else:
|
||||
if ( page < curpage + 10 ) and ( page > curpage - 10 ):
|
||||
if ( page < curpage + 11 ) and ( page > curpage - 11 ):
|
||||
nextfile=GEOVIEW_SUBPATH+"/GeoV-%c-%05d.html" % (ftype,page)
|
||||
self.mapview.write(" <a href='%s' >%d</a>" % (nextfile, page))
|
||||
if curpage != maxpages:
|
||||
@ -1085,7 +1085,7 @@ class GeoView(HtmlView):
|
||||
self.mapview.write("overview: true, scale: true, map_type: true });\n")
|
||||
last = ""
|
||||
indm=0
|
||||
divclose=1
|
||||
divclose=True
|
||||
self.yearinmarker = []
|
||||
InInterval = False
|
||||
self.setattr = True
|
||||
@ -1099,18 +1099,30 @@ class GeoView(HtmlView):
|
||||
InInterval = True
|
||||
if InInterval:
|
||||
if last != mark[0]:
|
||||
self.setattr = True
|
||||
last = mark[0]
|
||||
self.mapview.write("\nvar point = new LatLonPoint(%s,%s);"%(mark[3],mark[4]))
|
||||
self.mapview.write("my_marker = new Marker(point);")
|
||||
self.mapview.write("gmarkers[%d]=my_marker;" % (indm % NB_MARKERS_PER_PAGE))
|
||||
if not divclose:
|
||||
if InInterval:
|
||||
self.mapview.write("</div>\");")
|
||||
divclose = True
|
||||
years = ""
|
||||
if mark[2]:
|
||||
for y in self.yearinmarker:
|
||||
years += "%d " % y
|
||||
years += "end"
|
||||
self.mapview.write("my_marker.setAttribute('year','%s');" % years)
|
||||
self.yearinmarker = []
|
||||
self.mapview.write("mapstraction.addMarker(my_marker);")
|
||||
indm += 1;
|
||||
if ( indm > lastm ):
|
||||
if (indm % NB_MARKERS_PER_PAGE) == 0:
|
||||
InInterval = False
|
||||
last = mark[0]
|
||||
if ( indm >= firstm ) and ( indm <= lastm ):
|
||||
self.mapview.write("\nvar point = new LatLonPoint(%s,%s);"%(mark[3],mark[4]))
|
||||
self.mapview.write("my_marker = new Marker(point);")
|
||||
self.mapview.write("gmarkers[%d]=my_marker;" % (( indm - 1 ) % NB_MARKERS_PER_PAGE))
|
||||
self.mapview.write("my_marker.setLabel(\"%s\");"%mark[0])
|
||||
self.yearinmarker.append(mark[7])
|
||||
divclose=0
|
||||
divclose=False
|
||||
self.mapview.write("my_marker.setInfoBubble(\"<div style='white-space:nowrap;' >")
|
||||
if format == 1:
|
||||
self.mapview.write("%s<br>____________<br><br>%s"%(mark[0],mark[5]))
|
||||
@ -1124,62 +1136,18 @@ class GeoView(HtmlView):
|
||||
self.mapview.write("<br>%s - %s" % (mark[7], mark[5]))
|
||||
if self.isyearnotinmarker(self.yearinmarker,mark[7]):
|
||||
self.yearinmarker.append(mark[7])
|
||||
cent = int(mark[6])
|
||||
if cent:
|
||||
self.centered = True
|
||||
if float(mark[3]) == self.minlat:
|
||||
if signminlat == 1:
|
||||
latit = str(float(mark[3])+self.centerlat)
|
||||
else:
|
||||
latit = str(float(mark[3])-self.centerlat)
|
||||
else:
|
||||
if signminlat == 1:
|
||||
latit = str(float(mark[3])-self.centerlat)
|
||||
else:
|
||||
latit = str(float(mark[3])+self.centerlat)
|
||||
if float(mark[4]) == self.minlon:
|
||||
if signminlon == 1:
|
||||
longt = str(float(mark[4])+self.centerlon)
|
||||
else:
|
||||
longt = str(float(mark[4])-self.centerlon)
|
||||
else:
|
||||
if signminlon == 1:
|
||||
longt = str(float(mark[4])-self.centerlon)
|
||||
else:
|
||||
longt = str(float(mark[4])+self.centerlon)
|
||||
if divclose == 0:
|
||||
if InInterval:
|
||||
self.mapview.write("</div>\");")
|
||||
years = ""
|
||||
if mark[2]:
|
||||
for y in self.yearinmarker:
|
||||
years += "%d " % y
|
||||
years += "end"
|
||||
else:
|
||||
indm += 1
|
||||
if self.setattr:
|
||||
if self.nbmarkers > 0 and InInterval:
|
||||
years = ""
|
||||
if mark[2]:
|
||||
for y in self.yearinmarker:
|
||||
years += "%d " % y
|
||||
years += "end"
|
||||
self.mapview.write("</div>\");")
|
||||
self.mapview.write("my_marker.setAttribute('year','%s');" % years)
|
||||
self.yearinmarker = []
|
||||
self.mapview.write("mapstraction.addMarker(my_marker);")
|
||||
self.setattr = False
|
||||
if self.nbmarkers > 0:
|
||||
if self.setattr:
|
||||
years = ""
|
||||
if mark[2]:
|
||||
for y in self.yearinmarker:
|
||||
years += "%d " % y
|
||||
years += "end"
|
||||
self.mapview.write("my_marker.setAttribute('year','%s');" % years)
|
||||
self.yearinmarker = []
|
||||
years=""
|
||||
self.mapview.write("mapstraction.addMarker(my_marker);")
|
||||
self.setattr = False
|
||||
else:
|
||||
if self.nbmarkers == 0:
|
||||
# We have no valid geographic point to center the map.
|
||||
# So you'll see the street where I live.
|
||||
# I think another place should be better :
|
||||
@ -1188,8 +1156,6 @@ class GeoView(HtmlView):
|
||||
# I think we should put here all gramps developpers.
|
||||
# not only me ...
|
||||
#
|
||||
#longitude = -1.568792
|
||||
#latitude = 47.257971
|
||||
longitude = 0.0
|
||||
latitude = 0.0
|
||||
self.mapview.write("\nvar point = new LatLonPoint(%s,%s);\n"%(latitude,longitude))
|
||||
@ -1202,7 +1168,6 @@ class GeoView(HtmlView):
|
||||
self.mapview.write(_("This is why you see this map."))
|
||||
self.mapview.write("</div>\");\n")
|
||||
self.mapview.write(" mapstraction.addMarker(my_marker);")
|
||||
self.setattr = False
|
||||
self.mapview.write("\n </script>\n")
|
||||
|
||||
def createPersonMarkers(self,db,person,comment):
|
||||
@ -1366,9 +1331,10 @@ class GeoView(HtmlView):
|
||||
self.minyear = int(9999)
|
||||
self.maxyear = int(0)
|
||||
self.center = True
|
||||
person = None
|
||||
if db.active:
|
||||
person = db.active
|
||||
if person:
|
||||
if person is not None:
|
||||
family_list = person.get_family_handle_list()
|
||||
if len(family_list) > 0:
|
||||
fhandle = family_list[0] # first is primary
|
||||
@ -1395,10 +1361,11 @@ class GeoView(HtmlView):
|
||||
self.createPersonMarkers(db,child,comment)
|
||||
if self.center:
|
||||
mess = _("Cannot center the map. No location with coordinates.")
|
||||
self.create_pages(3, _("You have no active person to see this person's family places."),
|
||||
mess)
|
||||
else:
|
||||
mess = ""
|
||||
self.create_pages(3,
|
||||
( _("All %s people's familiy places in the database with coordinates.") %
|
||||
self.create_pages(3, ( _("All %s people's family places in the database with coordinates.") %
|
||||
_nd.display(person) ),
|
||||
mess)
|
||||
|
||||
@ -1417,10 +1384,11 @@ class GeoView(HtmlView):
|
||||
|
||||
latitude = ""
|
||||
longitude = ""
|
||||
person = None
|
||||
if db.active:
|
||||
person = db.active
|
||||
self.center = True
|
||||
if person:
|
||||
if person is not None:
|
||||
# For each event, if we have a place, set a marker.
|
||||
for event_ref in person.get_event_ref_list():
|
||||
if not event_ref:
|
||||
@ -1450,6 +1418,7 @@ class GeoView(HtmlView):
|
||||
self.center = False
|
||||
if self.center:
|
||||
mess = _("Cannot center the map. No location with coordinates.")
|
||||
self.create_pages(4, _("You have no active person to see this person's places."), mess)
|
||||
else:
|
||||
mess = ""
|
||||
self.create_pages(4,( _("All event places for %s.") % _nd.display(person) ), mess)
|
||||
|
Loading…
Reference in New Issue
Block a user