diff options
Diffstat (limited to 'src')
l--------- | src/css/font-awesome.css | 1 | ||||
l--------- | src/css/leaflet/MarkerCluster.Default.css | 1 | ||||
l--------- | src/css/leaflet/MarkerCluster.css | 1 | ||||
-rw-r--r-- | src/css/leaflet/extra-markers.css | 236 | ||||
l--------- | src/css/leaflet/leaflet.css | 1 | ||||
-rw-r--r-- | src/css/map.css | 23 | ||||
-rw-r--r-- | src/img/leaflet.extra-markers/markers_default.png | bin | 0 -> 119805 bytes | |||
-rw-r--r-- | src/img/leaflet.extra-markers/markers_default@2x.png | bin | 0 -> 254280 bytes | |||
-rw-r--r-- | src/img/leaflet.extra-markers/markers_shadow.png | bin | 0 -> 535 bytes | |||
-rw-r--r-- | src/img/leaflet.extra-markers/markers_shadow@2x.png | bin | 0 -> 1469 bytes | |||
-rw-r--r-- | src/js/app/boundary.js | 23 | ||||
-rw-r--r-- | src/js/app/mapfactory.js | 28 | ||||
-rw-r--r-- | src/js/app/places.js | 36 | ||||
l--------- | src/js/lib/images | 1 | ||||
-rw-r--r-- | src/js/lib/leaflet.extra-markers.js | 106 | ||||
l--------- | src/js/lib/leaflet.js | 1 | ||||
l--------- | src/js/lib/leaflet.markercluster.js | 1 | ||||
l--------- | src/js/lib/require.js | 1 | ||||
-rw-r--r-- | src/js/lib/require/json.js | 84 | ||||
l--------- | src/js/lib/require/text.js | 1 | ||||
-rw-r--r-- | src/js/slippymap.js | 14 | ||||
-rw-r--r-- | src/js/tours.js | 28 |
22 files changed, 587 insertions, 0 deletions
diff --git a/src/css/font-awesome.css b/src/css/font-awesome.css new file mode 120000 index 0000000..faba91f --- /dev/null +++ b/src/css/font-awesome.css @@ -0,0 +1 @@ +/usr/share/fonts-font-awesome/css/font-awesome.css
\ No newline at end of file diff --git a/src/css/leaflet/MarkerCluster.Default.css b/src/css/leaflet/MarkerCluster.Default.css new file mode 120000 index 0000000..2cf500e --- /dev/null +++ b/src/css/leaflet/MarkerCluster.Default.css @@ -0,0 +1 @@ +/usr/share/javascript/leaflet/MarkerCluster.Default.css
\ No newline at end of file diff --git a/src/css/leaflet/MarkerCluster.css b/src/css/leaflet/MarkerCluster.css new file mode 120000 index 0000000..a791781 --- /dev/null +++ b/src/css/leaflet/MarkerCluster.css @@ -0,0 +1 @@ +/usr/share/javascript/leaflet/MarkerCluster.css
\ No newline at end of file diff --git a/src/css/leaflet/extra-markers.css b/src/css/leaflet/extra-markers.css new file mode 100644 index 0000000..735dd87 --- /dev/null +++ b/src/css/leaflet/extra-markers.css @@ -0,0 +1,236 @@ +/* Marker setup */ +.extra-marker { + background: url("../../img/leaflet.extra-markers/markers_default.png") no-repeat 0 0; + width: 35px; + height: 46px; + position: absolute; + left: 0; + top: 0; + display: block; + text-align: center; +} + +.extra-marker-svg { + background: none; +} + +.extra-marker svg { + position: absolute; + top: 2px; + left: 3px; + width: 30px; + stroke-width:1; +} + +.extra-marker-shadow { + background: url("../../img/leaflet.extra-markers/markers_shadow.png") no-repeat 0 0; + width: 36px; + height: 16px; +} +/* Retina displays */ +@media (min--moz-device-pixel-ratio: 1.5), (-o-min-device-pixel-ratio: 3/2), (-webkit-min-device-pixel-ratio: 1.5), (min-device-pixel-ratio: 1.5), (min-resolution: 1.5dppx) { + .extra-marker { + background-image: url("../../img/leaflet.extra-markers/markers_default@2x.png"); + background-size: 540px 184px; + } + .extra-marker-shadow { + background-image: url("../../img/leaflet.extra-markers/markers_shadow@2x.png"); + background-size: 35px 16px; + } +} +/* Icons */ +.extra-marker i { + color: #fff; + margin-top: 10px; + display: inline-block; + font-size: 14px; +} +/* Semantic UI Fix */ +.extra-marker i.icon { + margin-right: 0; + opacity: 1; +} +/* Sprites setup */ +.extra-marker-circle-red { + background-position: 0 0; +} +.extra-marker-circle-orange-dark { + background-position: -36px 0; +} +.extra-marker-circle-orange { + background-position: -72px 0; +} +.extra-marker-circle-yellow { + background-position: -108px 0; +} +.extra-marker-circle-blue-dark { + background-position: -144px 0; +} +.extra-marker-circle-blue { + background-position: -180px 0; +} +.extra-marker-circle-cyan { + background-position: -216px 0; +} +.extra-marker-circle-purple { + background-position: -252px 0; +} +.extra-marker-circle-violet { + background-position: -288px 0; +} +.extra-marker-circle-pink { + background-position: -324px 0; +} +.extra-marker-circle-green-dark { + background-position: -360px 0; +} +.extra-marker-circle-green { + background-position: -396px 0; +} +.extra-marker-circle-green-light { + background-position: -432px 0; +} +.extra-marker-circle-black { + background-position: -468px 0; +} +.extra-marker-circle-white { + background-position: -504px 0; +} +.extra-marker-square-red { + background-position: 0 -46px; +} +.extra-marker-square-orange-dark { + background-position: -36px -46px; +} +.extra-marker-square-orange { + background-position: -72px -46px; +} +.extra-marker-square-yellow { + background-position: -108px -46px; +} +.extra-marker-square-blue-dark { + background-position: -144px -46px; +} +.extra-marker-square-blue { + background-position: -180px -46px; +} +.extra-marker-square-cyan { + background-position: -216px -46px; +} +.extra-marker-square-purple { + background-position: -252px -46px; +} +.extra-marker-square-violet { + background-position: -288px -46px; +} +.extra-marker-square-pink { + background-position: -324px -46px; +} +.extra-marker-square-green-dark { + background-position: -360px -46px; +} +.extra-marker-square-green { + background-position: -396px -46px; +} +.extra-marker-square-green-light { + background-position: -432px -46px; +} +.extra-marker-square-black { + background-position: -468px -46px; +} +.extra-marker-square-white { + background-position: -504px -46px; +} +.extra-marker-star-red { + background-position: 0 -92px; +} +.extra-marker-star-orange-dark { + background-position: -36px -92px; +} +.extra-marker-star-orange { + background-position: -72px -92px; +} +.extra-marker-star-yellow { + background-position: -108px -92px; +} +.extra-marker-star-blue-dark { + background-position: -144px -92px; +} +.extra-marker-star-blue { + background-position: -180px -92px; +} +.extra-marker-star-cyan { + background-position: -216px -92px; +} +.extra-marker-star-purple { + background-position: -252px -92px; +} +.extra-marker-star-violet { + background-position: -288px -92px; +} +.extra-marker-star-pink { + background-position: -324px -92px; +} +.extra-marker-star-green-dark { + background-position: -360px -92px; +} +.extra-marker-star-green { + background-position: -396px -92px; +} +.extra-marker-star-green-light { + background-position: -432px -92px; +} +.extra-marker-star-black { + background-position: -468px -92px; +} +.extra-marker-star-white { + background-position: -504px -92px; +} +.extra-marker-penta-red { + background-position: 0 -138px; +} +.extra-marker-penta-orange-dark { + background-position: -36px -138px; +} +.extra-marker-penta-orange { + background-position: -72px -138px; +} +.extra-marker-penta-yellow { + background-position: -108px -138px; +} +.extra-marker-penta-blue-dark { + background-position: -144px -138px; +} +.extra-marker-penta-blue { + background-position: -180px -138px; +} +.extra-marker-penta-cyan { + background-position: -216px -138px; +} +.extra-marker-penta-purple { + background-position: -252px -138px; +} +.extra-marker-penta-violet { + background-position: -288px -138px; +} +.extra-marker-penta-pink { + background-position: -324px -138px; +} +.extra-marker-penta-green-dark { + background-position: -360px -138px; +} +.extra-marker-penta-green { + background-position: -396px -138px; +} +.extra-marker-penta-green-light { + background-position: -432px -138px; +} +.extra-marker-penta-black { + background-position: -468px -138px; +} +.extra-marker-penta-white { + background-position: -504px -138px; +} +.extra-marker .fa-number:before { + content: attr(number); +} diff --git a/src/css/leaflet/leaflet.css b/src/css/leaflet/leaflet.css new file mode 120000 index 0000000..40a1f03 --- /dev/null +++ b/src/css/leaflet/leaflet.css @@ -0,0 +1 @@ +/usr/share/javascript/leaflet/leaflet.css
\ No newline at end of file diff --git a/src/css/map.css b/src/css/map.css new file mode 100644 index 0000000..626ff84 --- /dev/null +++ b/src/css/map.css @@ -0,0 +1,23 @@ +.leaflet-control-layers-toggle { + background-image: url(../img/leaflet/layers.png); +} + +.leaflet-retina .leaflet-control-layers-toggle { + background-image: url(../img/leaflet/layers-2x.png); +} + +#content { + position: absolute; + top: 0; + left: 0; + height: 100%; + width: 100%; +} + +.leaflet-control-scale { + text-align: center; +} + +.info { + background-color: white; +} diff --git a/src/img/leaflet.extra-markers/markers_default.png b/src/img/leaflet.extra-markers/markers_default.png Binary files differnew file mode 100644 index 0000000..2c81d15 --- /dev/null +++ b/src/img/leaflet.extra-markers/markers_default.png diff --git a/src/img/leaflet.extra-markers/markers_default@2x.png b/src/img/leaflet.extra-markers/markers_default@2x.png Binary files differnew file mode 100644 index 0000000..35ff61b --- /dev/null +++ b/src/img/leaflet.extra-markers/markers_default@2x.png diff --git a/src/img/leaflet.extra-markers/markers_shadow.png b/src/img/leaflet.extra-markers/markers_shadow.png Binary files differnew file mode 100644 index 0000000..33cf955 --- /dev/null +++ b/src/img/leaflet.extra-markers/markers_shadow.png diff --git a/src/img/leaflet.extra-markers/markers_shadow@2x.png b/src/img/leaflet.extra-markers/markers_shadow@2x.png Binary files differnew file mode 100644 index 0000000..1116503 --- /dev/null +++ b/src/img/leaflet.extra-markers/markers_shadow@2x.png diff --git a/src/js/app/boundary.js b/src/js/app/boundary.js new file mode 100644 index 0000000..f7ebd06 --- /dev/null +++ b/src/js/app/boundary.js @@ -0,0 +1,23 @@ +define(['leaflet'], function(L) { + + var boundaries = L.layerGroup(); + + // GeoJSON feature styling and grouping + function returnMarker(feature, latlng) { + return L.marker(latlng); + }; + + var boundary = L.geoJson([], { + pointToLayer: returnMarker, + style: { + "color": "#ff0080", + "fillOpacity": 0 + } + }); + + return function(data) { + boundary.addData(data); + boundaries.addLayer(boundary); + return boundaries; + }; +}); diff --git a/src/js/app/mapfactory.js b/src/js/app/mapfactory.js new file mode 100644 index 0000000..4802f50 --- /dev/null +++ b/src/js/app/mapfactory.js @@ -0,0 +1,28 @@ +define(['leaflet'], function(L) { + // base config + var attribOSM = '© <a href="https://www.openstreetmap.org/">OpenStreetMap-bidragydere</a>'; + var licenseCcBySa2 = 'under en <a href="https://creativecommons.org/licenses/by-sa/2.0/">Creative Commons Kreditering-DelPåSammeVilkår</a> licens.'; + var licenseODbL ='under licensen <a href="https://opendatacommons.org/licenses/odbl/1.0/">ODbL 1.0</a>'; + var TileLayer = L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', { + attribution: attribOSM + ', kartografi ' + licenseCcBySa2 + ', kortdata ' + licenseODbL + }), + scale = L.control.scale({ + imperial: false + }); + + return function(id, bounds) { + var map = L.map(id, { + layers: [TileLayer] + }) + if (bounds) { + map.fitBounds(L.latLngBounds(bounds)); + } else { + map.fitWorld().zoomIn(); + } + map.attributionControl.setPrefix(false); + + scale.addTo(map); + + return map; + }; +}); diff --git a/src/js/app/places.js b/src/js/app/places.js new file mode 100644 index 0000000..7ae5008 --- /dev/null +++ b/src/js/app/places.js @@ -0,0 +1,36 @@ +define([ + 'leaflet', + 'leaflet.markercluster' +], function(L) { + + // GeoJSON feature grouping + function returnMarker(feature, latlng) { + var marker = new L.CircleMarker(latlng,{ + color: 'none', + fillColor: 'rgba(110, 204, 57, 0.6)', + fillOpacity: '1', + }); + // bindTooltip was introduced in LeafletJS 1.0. + try { + marker.bindTooltip( + feature.properties.name + ); + } catch (e) { + if (console) { + console.warn('tooltip skipped (using an old Leaflet?)'); + } + }; + return marker; + }; + + var place = L.geoJson([], { + pointToLayer: returnMarker + }); + + return function(data) { + place.addData(data); + return L.markerClusterGroup({ + maxClusterRadius: 10 + }).addLayer(place); + }; +}); diff --git a/src/js/lib/images b/src/js/lib/images new file mode 120000 index 0000000..a962773 --- /dev/null +++ b/src/js/lib/images @@ -0,0 +1 @@ +/usr/share/javascript/leaflet/images
\ No newline at end of file diff --git a/src/js/lib/leaflet.extra-markers.js b/src/js/lib/leaflet.extra-markers.js new file mode 100644 index 0000000..30f2b97 --- /dev/null +++ b/src/js/lib/leaflet.extra-markers.js @@ -0,0 +1,106 @@ +(function(window, document, undefined) { + "use strict"; + L.ExtraMarkers = {}; + L.ExtraMarkers.version = "1.0.6"; + L.ExtraMarkers.Icon = L.Icon.extend({ + options: { + iconSize: [ 35, 45 ], + iconAnchor: [ 17, 42 ], + popupAnchor: [ 1, -32 ], + shadowAnchor: [ 10, 12 ], + shadowSize: [ 36, 16 ], + className: "", + prefix: "", + extraClasses: "", + shape: "circle", + icon: "", + innerHTML: "", + markerColor: "red", + svgBorderColor: "#fff", + svgOpacity: 1, + iconColor: "#fff", + number: "", + svg: false + }, + initialize: function(options) { + options = L.Util.setOptions(this, options); + }, + createIcon: function() { + var div = document.createElement("div"), options = this.options; + if (options.icon) { + div.innerHTML = this._createInner(); + } + if (options.innerHTML) { + div.innerHTML = options.innerHTML; + } + if (options.bgPos) { + div.style.backgroundPosition = -options.bgPos.x + "px " + -options.bgPos.y + "px"; + } + if(!options.svg) { + this._setIconStyles(div, options.shape + "-" + options.markerColor); + } else { + this._setIconStyles(div, "svg"); + } + return div; + }, + _createInner: function() { + var iconColorStyle = "", iconNumber = "", options = this.options; + if (options.iconColor) { + iconColorStyle = "style='color: " + options.iconColor + "' "; + } + if (options.number) { + iconNumber = "number='" + options.number + "' "; + } + + if(options.svg) { + var svg = '<svg xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 69.529271 95.44922" style="fill:'+options.markerColor+';stroke:'+options.svgBorderColor+';fill-opacity:'+options.svgOpacity+';" height="100%" width="100%" version="1.1" xmlns:cc="http://creativecommons.org/ns#" xmlns:dc="http://purl.org/dc/elements/1.1/"><g transform="translate(-139.52 -173.21)"><path d="m174.28 173.21c-19.199 0.00035-34.764 15.355-34.764 34.297 0.007 6.7035 1.5591 12.813 5.7461 18.854l0.0234 0.0371 28.979 42.262 28.754-42.107c3.1982-5.8558 5.9163-11.544 6.0275-19.045-0.0001-18.942-15.565-34.298-34.766-34.297z"/></g></svg>'; + + if(options.shape == "square") { + svg = '<svg xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 69.457038 96.523441" style="fill:'+options.markerColor+';stroke:'+options.svgBorderColor+';fill-opacity:'+options.svgOpacity+';" height="100%" width="100%" version="1.1" xmlns:cc="http://creativecommons.org/ns#" xmlns:dc="http://purl.org/dc/elements/1.1/"><g transform="translate(-545.27 -658.39)"><path d="m545.27 658.39v65.301h22.248l12.48 31.223 12.676-31.223h22.053v-65.301h-69.457z"/></g></svg>'; + } + + if(options.shape == "star") { + svg = '<svg style="top:0; fill:'+options.markerColor+';stroke:'+options.svgBorderColor+';fill-opacity:'+options.svgOpacity+';" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns="http://www.w3.org/2000/svg" height="100%" width="100%" version="1.1" xmlns:cc="http://creativecommons.org/ns#" xmlns:dc="http://purl.org/dc/elements/1.1/" viewBox="0 0 77.690999 101.4702"><g transform="translate(-101.15 -162.97)"><g transform="matrix(1 0 0 1.0165 -65.712 -150.28)"><path d="m205.97 308.16-11.561 11.561h-16.346v16.346l-11.197 11.197 11.197 11.197v15.83h15.744l11.615 33.693 11.467-33.568 0.125-0.125h16.346v-16.346l11.197-11.197-11.197-11.197v-15.83h-15.83l-11.561-11.561z"/></g></g></svg>'; + } + + if(options.shape == "penta") { + svg = '<svg style="fill:'+options.markerColor+';stroke:'+options.svgBorderColor+';fill-opacity:'+options.svgOpacity+';" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 71.550368 96.362438" height="100%" width="100%" version="1.1" xmlns:cc="http://creativecommons.org/ns#" xmlns:dc="http://purl.org/dc/elements/1.1/"><g transform="translate(-367.08 -289.9)"><path d="m367.08 322.5 17.236-32.604h36.151l18.164 32.25-35.665 64.112z"/></g></svg>'; + } + + return svg+"<i " + iconNumber + iconColorStyle + "class='" + options.extraClasses + " " + options.prefix + " " + options.icon + "'></i>"; + } + + return "<i " + iconNumber + iconColorStyle + "class='" + options.extraClasses + " " + options.prefix + " " + options.icon + "'></i>"; + }, + _setIconStyles: function(img, name) { + var options = this.options, size = L.point(options[name === "shadow" ? "shadowSize" : "iconSize"]), anchor, leafletName; + if (name === "shadow") { + anchor = L.point(options.shadowAnchor || options.iconAnchor); + leafletName = "shadow"; + } else { + anchor = L.point(options.iconAnchor); + leafletName = "icon"; + } + if (!anchor && size) { + anchor = size.divideBy(2, true); + } + img.className = "leaflet-marker-" + leafletName + " extra-marker extra-marker-" + name + " " + options.className; + if (anchor) { + img.style.marginLeft = -anchor.x + "px"; + img.style.marginTop = -anchor.y + "px"; + } + if (size) { + img.style.width = size.x + "px"; + img.style.height = size.y + "px"; + } + }, + createShadow: function() { + var div = document.createElement("div"); + this._setIconStyles(div, "shadow"); + return div; + } + }); + L.ExtraMarkers.icon = function(options) { + return new L.ExtraMarkers.Icon(options); + }; +})(window, document); diff --git a/src/js/lib/leaflet.js b/src/js/lib/leaflet.js new file mode 120000 index 0000000..f0df49d --- /dev/null +++ b/src/js/lib/leaflet.js @@ -0,0 +1 @@ +/usr/share/javascript/leaflet/leaflet.js
\ No newline at end of file diff --git a/src/js/lib/leaflet.markercluster.js b/src/js/lib/leaflet.markercluster.js new file mode 120000 index 0000000..881bcea --- /dev/null +++ b/src/js/lib/leaflet.markercluster.js @@ -0,0 +1 @@ +/usr/share/javascript/leaflet/leaflet.markercluster.js
\ No newline at end of file diff --git a/src/js/lib/require.js b/src/js/lib/require.js new file mode 120000 index 0000000..a2b8052 --- /dev/null +++ b/src/js/lib/require.js @@ -0,0 +1 @@ +/usr/share/javascript/requirejs/require.js
\ No newline at end of file diff --git a/src/js/lib/require/json.js b/src/js/lib/require/json.js new file mode 100644 index 0000000..40e4da1 --- /dev/null +++ b/src/js/lib/require/json.js @@ -0,0 +1,84 @@ +/** @license + * RequireJS plugin for loading JSON files + * - depends on Text plugin and it was HEAVILY "inspired" by it as well. + * Author: Miller Medeiros + * Version: 0.4.0 (2014/04/10) + * Released under the MIT license + * + * Patched (2013/10/10): + * - supports JS-like comments which are beginning from /* or // + */ +define(['text'], function (text) { + + var CACHE_BUST_QUERY_PARAM = 'bust', + CACHE_BUST_FLAG = '!bust', + jsonParse = (typeof JSON !== 'undefined' && typeof JSON.parse === 'function') ? JSON.parse : function (val) { + return eval('(' + val + ')'); //quick and dirty + }, + PROTECTION_PREFIX = /^\)\]\}',?\n/, + buildMap = {}; + + function cacheBust(url) { + url = url.replace(CACHE_BUST_FLAG, ''); + url += (url.indexOf('?') < 0) ? '?' : '&'; + return url + CACHE_BUST_QUERY_PARAM + '=' + Math.round(2147483647 * Math.random()); + } + + //API + return { + load: function(name, req, onLoad, config) { + // Make sure file part of url ends with .json, add it if not + name = name.replace(new RegExp("^[^?]*"), function(base) { + return base.substr(-5) === ".json" ? base : base + ".json"; + }); + var url = req.toUrl(name); + if (config.isBuild && (config.inlineJSON === false || name.indexOf(CACHE_BUST_QUERY_PARAM + '=') !== -1)) { + //avoid inlining cache busted JSON or if inlineJSON:false + onLoad(null); + } else if (url.indexOf('empty:') === 0) { + //and don't inline files marked as empty: urls + onLoad(null); + } else { + text.get(url, + function (data) { + // Need to check if the JSON data has been formatted for the JSON array security vulnerability + var cleaned_data = ('' + data).replace(PROTECTION_PREFIX, ''); + cleaned_data = cleaned_data.replace(/\/\*.+?\*\/|\/\/[^\n\r]*/g, ''); + var parsed = null; + try { + parsed = jsonParse(cleaned_data); + if (config.isBuild) { + buildMap[name] = parsed; + } + onLoad(parsed); + } catch (e) { + onLoad.error(e); + //onLoad(null); -- should we really call onLoad??? + } + }, + onLoad.error, { + accept: 'application/json' + } + ); + } + }, + + normalize: function (name, normalize) { + // used normalize to avoid caching references to a "cache busted" request + if (name.indexOf(CACHE_BUST_FLAG) !== -1) { + name = cacheBust(name); + } + // resolve any relative paths + return normalize(name); + }, + + // write method based on RequireJS official text plugin by James Burke + // https://github.com/jrburke/requirejs/blob/master/text.js + write: function (pluginName, moduleName, write) { + if (moduleName in buildMap) { + var content = buildMap[moduleName]; + write('define("' + pluginName + '!' + moduleName + '", function () { return ' + (content ? JSON.stringify(content) : content) + '; });\n'); + } + } + }; +}); diff --git a/src/js/lib/require/text.js b/src/js/lib/require/text.js new file mode 120000 index 0000000..2b490b4 --- /dev/null +++ b/src/js/lib/require/text.js @@ -0,0 +1 @@ +/usr/share/javascript/requirejs/text.js
\ No newline at end of file diff --git a/src/js/slippymap.js b/src/js/slippymap.js new file mode 100644 index 0000000..910ee9a --- /dev/null +++ b/src/js/slippymap.js @@ -0,0 +1,14 @@ +// shared code common across pages +requirejs.config({ + baseUrl: 'js/lib', + paths: { + text: 'require/text', + json: 'require/json', + app: '../app', + data: '../../data' + }, + shim: { + 'leaflet.extra-markers': ['leaflet'], + 'leaflet.markercluster': ['leaflet'] + } +}); diff --git a/src/js/tours.js b/src/js/tours.js new file mode 100644 index 0000000..83e1cae --- /dev/null +++ b/src/js/tours.js @@ -0,0 +1,28 @@ +//Load common code that includes config, then load the app logic for this page. +requirejs(['./slippymap'], function(_foo) { + var depth = '../../'; + requirejs.config({ + baseUrl: depth + 'js/lib', + }); + requirejs(['app/mapfactory'], function(mkmap) { + L.Icon.Default.imagePath = depth + 'img/leaflet/'; + var map = mkmap('content', [ + [52.1381, 8.39802], + [52.0400, 8.18859] + ]); + requirejs([ + 'app/boundary', + 'json!data/copenhagen.json' + ], function(boundary, data) { + map.addLayer(boundary(data)); + map.layers.addOverlay(boundary(data), 'Regionsgrænse'); + }); + requirejs([ + 'app/places', + 'json!data/tours.json', + ], function(places, data, hook) { + map.addLayer(places(data)); + hook(map); + }); + }); +}); |