westdc-zf1/htdocs/js/timemap.2.0.1/examples/google_events.html

120 lines
4.8 KiB
HTML
Raw Normal View History

2011-11-08 09:02:14 +00:00
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8"/>
<title>Google Events Example</title>
<script src="http://maps.google.com/maps?file=api&v=2&key=ABQIAAAASI0kCI-azC8RgbOZzWc3VRRarOQe_TKf_51Omf6UUSOFm7EABRRhO0PO4nBAO9FCmVDuowVwROLo3w"
type="text/javascript"></script>
<script type="text/javascript" src="../lib/jquery-1.6.2.min.js"></script>
<script type="text/javascript" src="../lib/mxn/mxn.js?(google)"></script>
<script type="text/javascript" src="http://static.simile.mit.edu/timeline/api/timeline-api.js"></script>
<script src="../src/timemap.js" type="text/javascript"></script>
<script src="../src/loaders/json.js" type="text/javascript"></script>
<script type="text/javascript">
$(function() {
TimeMap.init({
mapId: "map", // Id of map div element (required)
timelineId: "timeline", // Id of timeline div element (required)
options: {
eventIconPath: "../images/"
},
datasets: [
{
title: "Developer Community Calendar",
theme: "green",
type: "jsonp", // Data to be loaded in JSON from a remote URL
options: {
url: "http://www.google.com/calendar/feeds/" +
"dev-community-calendar@google.com/public/full?futureevents=true" +
"&orderby=starttime&sortorder=ascending&singleevents=true" +
"&alt=json-in-script&callback=?",
preloadFunction: preloadGCal,
transformFunction: transformGCal
}
},
{
title: "Developer Calendar",
theme: "blue",
type: "jsonp", // Data to be loaded in JSON from a remote URL
options: {
url: "http://www.google.com/calendar/feeds/" +
"developer-calendar@google.com/public/full?futureevents=true" +
"&orderby=starttime&sortorder=ascending&singleevents=true" +
"&alt=json-in-script&callback=?",
preloadFunction: preloadGCal,
transformFunction: transformGCal
}
}
]
});
});
// Preload function for the calendar events feed
// The preloadFunction should leave you with an array of
// elements, stripping off outer envelopes, etc.
function preloadGCal(result) {
var entries = (result.feed.entry);
var events = [];
// delete events without geotags
for (var x=0; x<entries.length; x++) {
entry = entries[x];
var location = entry['gd$where'][0].valueString;
var pattern = new RegExp(/@\s*([\-0-9.]+)\s*,\s*([\-0-9.]+)\s*/);
var matches = pattern.exec(location);
if (matches != null) events.push(entry);
}
return events;
}
// Transform function for a single calendar entry
// The transformFunction should transform a single element from
// your JSON format to the format required by loadItem().
function transformGCal(entry) {
var newData = {};
newData["title"] = entry.title.$t;
newData["options"] = {};
// html for info window
if (entry.content.$t.length > 120)
var content = entry.content.$t.substring(0,120) + '...';
else var content = entry.content.$t;
newData["options"]["infoHtml"] = '<p class="content"><strong>' + entry.title.$t
+ '</strong></p><p class="content">' + content + ' ' +
'<a href="' + entry.link[0].href + '" target=_blank>more &gt;&gt;</a></p>';
newData["start"] = entry['gd$when'][0].startTime;
// get geolocation
var location = entry['gd$where'][0].valueString;
var pattern = new RegExp(/@\s*([\-0-9.]+)\s*,\s*([\-0-9.]+)\s*/);
var matches = pattern.exec(location);
if (matches != null) {
var lat = parseFloat(matches[1]);
var lon = parseFloat(matches[2]);
newData["point"] = {
"lat" : lat,
"lon" : lon
};
}
return newData;
}
</script>
<link href="examples.css" type="text/css" rel="stylesheet"/>
</head>
<body>
<div id="help">
<h1>Two JSON Datasets</h1>
In this example, we're loading two JSON datasets from public Google Calendar feeds. <em>Note: this relied on a lat/lon string in the gd$where attribute - looks like the person managing the calendars stopped adding that. :(<em>
</div>
<div id="timemap">
<div id="timelinecontainer">
<div id="timeline"></div>
</div>
<div id="mapcontainer">
<div id="map"></div>
</div>
</div>
</body>
</html>