Mapstraction.css: Fixed a problem where it was not allowing PlacePage Place Maps to not be shown. NarrativeWeb: More tweaks to FamilyMap and PlacePage Maps.

svn: r15652
This commit is contained in:
Rob G. Healey 2010-07-27 08:33:06 +00:00
parent a5d38c55d6
commit 621869d911
2 changed files with 124 additions and 104 deletions

View File

@ -25,35 +25,12 @@
Body element Body element
------------------------------------------------- */ ------------------------------------------------- */
body#FamilyMap { body#FamilyMap {
background-color: #000; background-color: #FFF;
color: #000; color: #000;
margin: 0 auto; margin: 0 auto;
width: 100%; width: 1060px;
padding: 0px 4px 0px 4px; padding: 0px 4px 0px 4px;
} }
div#largeYmap {
width: 800px;
margin: 0% 2% 0% 2%;
}
div#smallYmap {
width: 800px;
margin: 0% 7% 0% 7%;
}
/* References
------------------------------------------------- */
body#FamilyMap div#References {
background-color: #FFF;
}
body#FamilyMap div#References ol {
list-style-type: decimal;
}
body#FamilyMap div#References ol li ol {
list-style-type: lower-alpha;
}
body#FamilyMap div#References ol li a {
text-decoration: none;
}
/* Mapstraction /* Mapstraction
------------------------------------------------- */ ------------------------------------------------- */
@ -80,22 +57,45 @@ div#geo-info {
/* GoogleV3 /* GoogleV3
------------------------------------------------- */ ------------------------------------------------- */
div#googlev3 { div#googlev3 {
height: 500px;
width: 600px;
border: solid 1px #000; border: solid 1px #000;
} }
/* ************************************************************************************** /* **************************************************************************************
middlesection MiddleSection
------------------------------------------------- */ ------------------------------------------------- */
div#middlesection {
float: center;
overflow-y: hidden;
}
/* Y Map Sizes
------------------------------------------------- */
div#largeYMap {
width: 1400px;
margin: 1%;
}
div#middleYMap {
width: 1000px;
margin: 2%;
}
div#smallYMap {
width: 800px;
margin: 0% 8% 0% 9%;
}
/* X Map Sizes
------------------------------------------------- */
div#largeXMap {
height: 1400px;
}
div#middleXMap {
height: 1200px;
}
div#smallXMap { div#smallXMap {
height: 800px; height: 800px;
float: center;
margin: 0% 0% 7% 0%;
}
div#largeXMap {
width: 1400px;
float: center;
margin: 0% 0% 2% 0%;
} }
/* Family GoogleV3 /* Family GoogleV3

View File

@ -110,27 +110,6 @@ from PlaceUtils import conv_lat_lon
#------------------------------------------------------------------------ #------------------------------------------------------------------------
# constants # constants
#------------------------------------------------------------------------ #------------------------------------------------------------------------
# javascript header for family map and place page map
javascript_header = """
var map;
var latlon;
function initialize() {
// create map object
map = new mxn.Mapstraction('familygooglev3', 'googlev3');
// add map controls to image
map.addControls({
pan: true,
zoom: 'large',
scale: true,
disableDoubleClickZoom: true,
keyboardShortcuts: true,
scrollwheel: false,
map_type: true
});"""
# Translatable strings for variables within this plugin # Translatable strings for variables within this plugin
# gettext carries a huge footprint with it. # gettext carries a huge footprint with it.
AHEAD = _("Attributes") AHEAD = _("Attributes")
@ -640,15 +619,17 @@ class BasePage(object):
found = any(p[2] == placetitle for p in place_lat_long) found = any(p[2] == placetitle for p in place_lat_long)
if not found: if not found:
if ( place.lat and place.long ): if (place.lat and place.long):
latitude, longitude = conv_lat_lon( place.lat, latitude, longitude = conv_lat_lon( place.lat,
place.long, place.long,
"D.D8") "D.D8")
date = event.get_date_object() # 0 = latitude, 1 = longitude, 2 = place title, 3 = handle,
place_lat_long.append([latitude, longitude, # 4 = event date
placetitle, place.handle, date]) place_lat_long.append([ latitude, longitude,
placetitle, place.handle,
event.get_date_object() ])
def _get_event_place(self, person): def _get_event_place(self, person):
""" """
@ -660,6 +641,7 @@ class BasePage(object):
return return
db = self.report.database db = self.report.database
# check to see if this person is in the report database?
if check_person_database(person): if check_person_database(person):
event_ref_list = person.get_event_ref_list() event_ref_list = person.get_event_ref_list()
for event_ref in event_ref_list: for event_ref in event_ref_list:
@ -2528,29 +2510,46 @@ class PlacePage(BasePage):
with Html("script", type = "text/javascript") as jsc: with Html("script", type = "text/javascript") as jsc:
middle += jsc middle += jsc
jsc += javascript_header
jsc += """ jsc += """
latlon = new mxn.LatLonPoint(%s, %s);""" % (latitude, longitude) var map;
var latlon;
function initialize() {
// create mxn object
map = new mxn.Mapstraction('googlev3','googlev3');
// add map controls to image
map.addControls({
pan: true,
zoom: 'large',
scale: true,
disableDoubleClickZoom: true,
keyboardShortcuts: true,
scrollwheel: false,
map_type: true
});
latlon = new mxn.LatLonPoint(%s, %s);""" % (latitude, longitude)
jsc += """ jsc += """
// put map on page // put map on page
map.setCenterAndZoom(latlon, 10); map.setCenterAndZoom(latlon, 10);
var marker; var marker;
// set marker at latitude/ longitude // set marker at latitude/ longitude
marker = new mxn.Marker(latlon); marker = new mxn.Marker(latlon);
// add marker InfoBubble() using place name // add marker InfoBubble() using place name
marker.setInfoBubble('<div id = "geo-info" >%s</div>'); """ % self.page_title marker.setInfoBubble('<div id = "geo-info" >%s</div>'); """ % self.page_title
jsc += """ jsc += """
// add marker to map
// add marker to map map.addMarker(marker, true);
map.addMarker(marker, true); }"""
}""" # there is no need to add an ending "</script>",
# there is no need to add an ending "</script>", # as it will be added automatically!
# as it will be added automatically!
# googlev3 division # googlev3 division
middle += Html("div", id = "googlev3", inline = True) middle += Html("div", id = "googlev3", inline = True)
@ -3906,8 +3905,8 @@ class IndividualPage(BasePage):
if not place_lat_long: if not place_lat_long:
return return
MinX = MaxX = "0.00000000" MinX = MaxX = "0.00000001"
MinY = MaxY = "0.00000000" MinY = MaxY = "0.00000001"
number_markers = len(place_lat_long) number_markers = len(place_lat_long)
if number_markers > 3: if number_markers > 3:
@ -3948,10 +3947,12 @@ class IndividualPage(BasePage):
head += Html("script", src = url, inline = True) head += Html("script", src = url, inline = True)
# set map dimensions based on span of Y Coordinates # set map dimensions based on span of Y Coordinates
if (-20 <= spanY > -1) or (20 <= spanY > 1): if (-10 <= spanY > -1) or (10 <= spanY > 1):
map_size = "smallYmap" map_size = "smallYMap"
elif (-40 <= spanY > -11) or (40 <= spanY > 11):
map_size = "middleYMap"
else: else:
map_size = "largeYmap" map_size = "largeYMap"
# begin familymap division # begin familymap division
with Html("div", class_ = "content", id = map_size) as mapbody: with Html("div", class_ = "content", id = map_size) as mapbody:
@ -3966,13 +3967,15 @@ class IndividualPage(BasePage):
"on the place&#8217;s name will take you to that place&#8217;s page.") "on the place&#8217;s name will take you to that place&#8217;s page.")
mapbody += Html("p", msg, id = "description") mapbody += Html("p", msg, id = "description")
if (-20 <= spanX > -1) or (20 <= spanX > 1): if (-10 <= spanX > -1) or (10 <= spanX > 1):
middlesection = "smallXMap" map_size = "smallXMap"
elif (-40 <= spanX > -11) or (40 <= spanX > 11):
map_size = "middleXMap"
else: else:
middlesection = "largeXMap" map_size = "largeXMap"
# begin middle section division # begin middle section division
with Html("div", id = middlesection) as middlesection: with Html("div", id = map_size) as middlesection:
mapbody += middlesection mapbody += middlesection
# begin inline javascript code # begin inline javascript code
@ -3980,16 +3983,34 @@ class IndividualPage(BasePage):
with Html("script", type = "text/javascript") as jsc: with Html("script", type = "text/javascript") as jsc:
middlesection += jsc middlesection += jsc
jsc += javascript_header jsc += """
var map;
var latlon;
function initialize() {
// create map object
map = new mxn.Mapstraction('familygooglev3', 'googlev3');
// add map controls to image
map.addControls({
pan: true,
zoom: 'large',
scale: true,
disableDoubleClickZoom: true,
keyboardShortcuts: true,
scrollwheel: false,
map_type: true
});"""
index = 0 index = 0
for (lat, long, p, h, d) in place_lat_long: for (lat, long, p, h, d) in place_lat_long:
j = index + 1 j = index + 1
jsc += """ add_markers(%d, %s, %s, "%s");""" % ( j, lat, long, p ) jsc += """ add_markers(%d, %s, %s, "%s");""" % ( j, lat, long, p )
index += 1 index += 1
jsc += """ jsc += """
}""" }"""
if (-20 <= spanY > -1) or (20 <= spanY > 1): if (-20 <= spanY > -1) or (20 <= spanY > 1):
pass pass
@ -3997,43 +4018,42 @@ class IndividualPage(BasePage):
else: else:
# set southWest and northEast boundaries as spanY is greater than 20 # set southWest and northEast boundaries as spanY is greater than 20
jsc += """ jsc += """
// boundary southWest equals bottom left GPS Coordinates // boundary southWest equals bottom left GPS Coordinates
var southWest = new mxn.LatLonPoint(%s, %s);""" % (MinX, MinY) var southWest = new mxn.LatLonPoint(%s, %s);""" % (MinX, MinY)
jsc += """ jsc += """
// boundary northEast equals top right GPS Coordinates // boundary northEast equals top right GPS Coordinates
var northEast = new mxn.LatLonPoint(%s, %s);""" % (MaxX, MaxY) var northEast = new mxn.LatLonPoint(%s, %s);""" % (MaxX, MaxY)
jsc += """ jsc += """
var bounds = new google.maps.LatLngBounds(southWest, northEast); var bounds = new google.maps.LatLngBounds(southWest, northEast);
map.fitBounds(bounds);""" map.fitBounds(bounds);"""
# include add_markers function # include add_markers function
jsc += """ jsc += """
function add_markers(num, latitude, longitude, title) { function add_markers(num, latitude, longitude, title) {
latlon = new mxn.LatLonPoint(latitude, longitude); latlon = new mxn.LatLonPoint(latitude, longitude);
var marker = new mxn.Marker(latlon); var marker = new mxn.Marker(latlon);
marker.setInfoBubble(title); marker.setInfoBubble(title);
map.addMarker(marker, true);""" map.addMarker(marker, true);"""
if (-20 <= spanY > -1) or (20 <= spanY > 1): if (-20 <= spanY > -1) or (20 <= spanY > 1):
jsc += """ var zoomlevel = 6;""" jsc += """
var zoomlevel = 6;"""
else: else:
jsc += """ var zoomlevel = 8;""" jsc += """
var zoomlevel = 8;"""
jsc += """ jsc += """
map.setCenterAndZoom(latlon, zoomlevel); map.setCenterAndZoom(latlon, zoomlevel);
}""" }"""
# there is no need to add an ending "</script>", # there is no need to add an ending "</script>",
# as it will be added automatically! # as it will be added automatically!
# familygooglev3 division # here is where the map is held in the CSS
middlesection += Html("div", id = "familygooglev3", inline = True) middlesection += Html("div", id = "familygooglev3", inline = True)
# add fullclear for proper styling
middlesection += fullclear
# add references division and title # add references division and title
with Html("div", class_ = "subsection", id = "References") as section: with Html("div", class_ = "subsection", id = "References") as section:
body += section body += section