Re-located the _create_place_map() code and updated Mapstraction.css style sheet.

svn: r15567
This commit is contained in:
Rob G. Healey 2010-06-15 00:30:31 +00:00
parent 368ebca243
commit 205a1b703d
2 changed files with 164 additions and 186 deletions

View File

@ -21,48 +21,41 @@
# #
# $Id: Mapstraction.css 15566 2010-06-13 15:10:00Z robhealey1 $ # $Id: Mapstraction.css 15566 2010-06-13 15:10:00Z robhealey1 $
# #
#
Mapstraction
------------------------------------------------- */ ------------------------------------------------- */
.middle {
float: left;
width: 60%;
margin: 0 10px;
padding: 1% 1%;
text-align: justify;
}
.middle ul {
margin-left: 25px;
}
.middle h2 {
color: #3B6EBF;
font-size: 16px;
margin: 10px 0px 10px 0px;
}
div#mapstraction { div#mapstraction {
height: 600px; height: 500px;
width: 500px; width: 100%;
} }
.mapstraction ul, #mapstraction ul {
margin-left: 0px; /* Middle
------------------------------------------------- */
div#middle {
float: center;
height: 400px;
width: 60%;
margin: 10px 0px 10px 0px;
padding: 0% 20% 0% 20%;
text-align: center;
} }
div#googlev3, div#openlayers, div#freeeath, div#yahoo, div#mapquest, div#microsoft { div#middle div#geo-info {
font: bold 6px serif;
}
div#middle a {
color: #000;
background: none;
text-decoration: none;
}
div#middle a:hover {
text-decoration: underline;
}
/* GoogleV3
------------------------------------------------- */
div#googlev3 {
height: 400px; height: 400px;
width: 500px; width: 500px;
} margin-bottom: 6px;
div#clear {
display: block;
clear: both;
width: 100%;
height: 1px;
overflow: hidden;
}
.js_map_provider {
color: #FF4400;
font-weight: bold;
}
#js_code {
height: 300px;
overflow: auto;
border: 1px solid black;
margin-top: 10px;
padding-top: 10px;
} }

View File

@ -337,6 +337,122 @@ class BasePage(object):
# options for PlaceMaps for PlacePages # options for PlaceMaps for PlacePages
self.placemaps = report.options["placemaps"] self.placemaps = report.options["placemaps"]
def _create_place_map(self, placedetail, head, latitude, longitude, place_title):
"""
will create the place map
@param: placedetail -- Html instance page
@param: latitude -- GPS Latitude from place
@param: Longitude -- GPS Longitude from place
"""
# add Mapstraction CSS
fname = "/".join(["styles", "mapstraction.css"])
url = self.report.build_url_fname(fname, None, self.up)
head += Html("link", href = url, type = "text/css", media = "screen",
rel = "stylesheet", indent = False)
# add googlev3 specific javascript code
head += Html("script", type = "text/javascript",
src = "http://maps.google.com/maps/api/js?sensor=false", inline = True)
# add openlayers specific javascript code
head += Html("script", src = "http://openlayers.org/api/OpenLayers.js", inline = True)
# add mapstraction javascript code
fname = "/".join(["mapstraction", "mxn.js"])
url = self.report.build_url_fname(fname, None, self.up)
url += "?(googlev3,openlayers)"
head += Html("script", src = url, inline = True)
# Place Map division
with Html("div", id = "mapstraction") as mapstraction:
placedetail += mapstraction
# section title
mapstraction += Html("h4", _("Place Map"), inline = True)
# begin middle division
with Html("div", id = "middle") as middle:
mapstraction += middle
# begin inline javascript code
# because jsc is a string, it does NOT have to properly indented
with Html("script", type = "text/javascript") as jsc:
middle += jsc
jsc += """
//<![CDATA[
var map;
var pprovider = 'googlev3';
var latlon;
var icon = 'mainmap';
function initialize() {
// create mxn object
map = new mxn.Mapstraction('googlev3','googlev3');
// add map controls to image
map.addControls({
pan: true,
zoom: 'large',
scale: true,
map_type: true
});
latlon = new mxn.LatLonPoint(%s, %s);""" % (latitude, longitude)
jsc += """
// put map on page
map.setCenterAndZoom(latlon, 9);
//add a marker
add_marker();
}
function add_marker() {
var marker;
marker = new mxn.Marker(latlon);
// openlayers mapstraction problem here : drift if anchor.
if ( provider == 'googlev3' ) {
marker.setIcon('../../../images/gramps-geo-' +icon+ '.png',
[22,22],
[0,22]);
} else {
marker.setIcon('../../../images/gramps-geo-' +icon+ '.png',
[22,22]);
};
map.addMarker(marker,true);
}
function changeprovider() {
if ( pprovider == 'googlev3') {
provider = 'openlayers';
icon = 'mainmap';
} else {
provider = 'googlev3';
icon = 'altmap';
};
mao.swap(provider, provider);
add_marker();
}
//]]>"""
# there is no need to add an ending "</script>" as it will be added automatically!
middle += Html("div", id = "googlev3", inline = True)
middle += Html("div", id = "openlayers", inline = True)
middle += Html("a", _("change provider"), attr = 'onclick = "changeprovider();"',
href = "#", inline = True)
# return placedetail division back to its callers
return placedetail, head
def complete_people(self, tcell, first_person, handle_list): def complete_people(self, tcell, first_person, handle_list):
""" """
completes the person column for classes EventListPage and EventPage completes the person column for classes EventListPage and EventPage
@ -2347,115 +2463,6 @@ class PlacePage(BasePage):
self.page_title = ReportUtils.place_name(db, place_handle) self.page_title = ReportUtils.place_name(db, place_handle)
placepage, head, body = self.write_header(_("Places")) placepage, head, body = self.write_header(_("Places"))
# determine if we will be creating Place Maps or not?
if self.placemaps:
if place.lat and place.long:
place_title = ReportUtils.place_name(db, place_handle)
head += Html("script", type = "text/javascript",
src = "http://maps.google.com/maps/api/js?sensor=false", inline = True)
head += Html("script", src = "http://openlayers.org/api/OpenLayers.js",
inline = True)
head += Html("script", src = "../../../mapstraction/mxn.js?(googlev3,openlayers)",
inline = True)
inline_script = """
<style type = "text/css">
div#maps {
height: 500px;
}
div#googlev3 {
height: 400px;
width: 500px;
display: none;
border: solid 2px #000;
}
div#openlayers {
height: 400px;
width: 500px;
border: solid 2px #000;
}
div#geo-info {
font: normal .6em sans;
}
</style>
<script type="text/javascript">
//<![CDATA[
var map;
var hybrid = 'y';
var provider = 'openlayers';
var latlon;
var marker;
var icon = 'mainmap';
function initialize() {
// create mxn object
map = new mxn.Mapstraction('openlayers','openlayers');
map.addControls({pan: true, zoom: 'large', scale: true});
latlon = new mxn.LatLonPoint(%s, %s); """ % (place.lat, place.long)
inline_script += """
// put map on page
map.setCenterAndZoom(latlon, 9);
//add a marker
add_marker();
}
function add_marker() {
marker = new mxn.Marker(latlon);
marker.setLabel('The Label');
marker.setInfoBubble('<div id="geo-info" >%s</div>'); """ % place_title
inline_script += """
// openlayers mapstraction problem here : drift if anchor.
if ( provider == 'googlev3' ) {
marker.setIcon('../../../images/gramps-geo-' +icon+ '.png',
[22,22],
[0,22]);
} else {
marker.setIcon('../../../images/gramps-geo-' +icon+ '.png',
[22,22]);
};
map.addMarker(marker,true);
}
function changetohybrid() {
if ( hybrid == 'y' ) {
hybrid = 'n'
map.setMapType(mxn.Mapstraction.HYBRID);
} else {
hybrid = 'y'
map.setMapType(mxn.Mapstraction.ROAD);
};
}
function changeprovider(){
if ( provider == 'googlev3') {
provider = 'openlayers';
icon = 'mainmap';
} else {
provider = 'googlev3';
icon = 'altmap';
};
map.swap(provider,provider);
add_marker();
}
//]]>
</script> """
head += inline_script
# add javascript function to body element
body.attr = 'onload = "initialize();"'
# begin PlaceDetail Division # begin PlaceDetail Division
with Html("div", class_ = "content", id = "PlaceDetail") as placedetail: with Html("div", class_ = "content", id = "PlaceDetail") as placedetail:
body += placedetail body += placedetail
@ -2495,7 +2502,13 @@ class PlacePage(BasePage):
placedetail += urllinks placedetail += urllinks
# add place map here # add place map here
_create_place_map(placedetail, place.lat, place.long) if self.placemaps:
if place.lat and place.long:
self._create_place_map(placedetail, head, place.lat, place.long, self.page_title)
# add javascript function call to body element
body.attr = 'onload = "initialize();"'
# source references # source references
srcrefs = self.display_ind_sources(place) srcrefs = self.display_ind_sources(place)
@ -5323,7 +5336,7 @@ class NavWebReport(Report):
def copy_narrated_files(self): def copy_narrated_files(self):
""" """
Copy all of the CSS and image files for Narrated Web Copy all of the CSS, image, and javascript files for Narrated Web
""" """
# copy behaviour style sheet # copy behaviour style sheet
@ -5335,7 +5348,7 @@ class NavWebReport(Report):
fname = os.path.join(const.DATA_DIR, self.css) fname = os.path.join(const.DATA_DIR, self.css)
self.copy_file(fname, _NARRATIVESCREEN, "styles") self.copy_file(fname, _NARRATIVESCREEN, "styles")
# copy Navigation Menu Layout if Blue or Visually is being used # copy Navigation Menu Layout style sheet if Blue or Visually is being used
if self.css == "Web_Basic-Blue.css" or "Web_Visually.css": if self.css == "Web_Basic-Blue.css" or "Web_Visually.css":
if self.navigation == "Horizontal": if self.navigation == "Horizontal":
fname = os.path.join(const.DATA_DIR, "Web_Navigation-Horizontal.css") fname = os.path.join(const.DATA_DIR, "Web_Navigation-Horizontal.css")
@ -5343,6 +5356,11 @@ class NavWebReport(Report):
fname = os.path.join(const.DATA_DIR, "Web_Navigation-Vertical.css") fname = os.path.join(const.DATA_DIR, "Web_Navigation-Vertical.css")
self.copy_file(fname, "Web_Navigation-Menus.css", "styles") self.copy_file(fname, "Web_Navigation-Menus.css", "styles")
# copy Mapstraction style sheet if using Place Maps
if self.placemaps:
fname = os.path.join(const.DATA_DIR, "Mapstraction.css")
self.copy_file(fname, "mapstraction.css", "styles")
# copy printer style sheet # copy printer style sheet
fname = os.path.join(const.DATA_DIR, "Web_Print-Default.css") fname = os.path.join(const.DATA_DIR, "Web_Print-Default.css")
self.copy_file(fname, _NARRATIVEPRINT, "styles") self.copy_file(fname, _NARRATIVEPRINT, "styles")
@ -6585,36 +6603,3 @@ def build_event_data(db, ind_list):
# return event_handle_list and event types to its caller # return event_handle_list and event types to its caller
return event_handle_list, event_types return event_handle_list, event_types
def _create_place_map(placedetail, latitude, longitude):
"""
will create the place map
@param: placedetail -- Html instance page
@param: latitude -- GPS Latitude from place
@param: Longitude -- GPS Longitude from place
"""
# if there is no latitude and longitude, return placedetail
if not latitude and not longitude:
return
# Place Map division
with Html("div", id = "maps") as placemap:
placedetail += placemap
# section title
placemap += Html("h4", _("Place Map"), inline = True)
placemap += Html("div", id = "googlev3", inline = True)
placemap += Html("div", id = "openlayers", inline = True)
placemap += Html("a", _("change provider"), attr = 'onclick = "changeprovider();"',
href = "#", inline = True)
placemap += Html("a", _("change to hybrid"), attr = 'onclick = "changetohybrid();"',
href = "#", inline = True)
# return placedetail division back to its callers
return placedetail