const phpvms= (function() { const draw_base_map = (opts) => { opts = _.defaults(opts, { render_elem: 'map', zoom: 12, layers: [], set_marker: false, }); /*var openaip_airspace_labels = new L.TileLayer.WMS( "http://{s}.tile.maps.openaip.net/geowebcache/service/wms", { maxZoom: 14, minZoom: 12, layers: 'openaip_approved_airspaces_labels', tileSize: 1024, detectRetina: true, subdomains: '12', format: 'image/png', transparent: true }); openaip_airspace_labels.addTo(map);*/ const opencyclemap_phys_osm = new L.TileLayer( 'http://{s}.tile.thunderforest.com/landscape/{z}/{x}/{y}.png?apikey=f09a38fa87514de4890fc96e7fe8ecb1', { maxZoom: 14, minZoom: 4, format: 'image/png', transparent: true }); const openaip_cached_basemap = new L.TileLayer("http://{s}.tile.maps.openaip.net/geowebcache/service/tms/1.0.0/openaip_basemap@EPSG%3A900913@png/{z}/{x}/{y}.png", { maxZoom: 14, minZoom: 4, tms: true, detectRetina: true, subdomains: '12', format: 'image/png', transparent: true }); const openaip_basemap_phys_osm = L.featureGroup([opencyclemap_phys_osm, openaip_cached_basemap]); let map = L.map('map', { layers: [openaip_basemap_phys_osm], zoom: opts.zoom, scrollWheelZoom: false, }); const attrib = L.control.attribution({position: 'bottomleft'}); attrib.addAttribution("Thunderforest"); attrib.addAttribution("openAIP"); attrib.addAttribution("OpenStreetMap contributors"); attrib.addAttribution("OpenWeatherMap"); attrib.addTo(map); return map; }; return { /** * * @param opts */ render_route_map: (opts) => { opts = _.defaults(opts, { features: null, // [ {name, lat, lon}, {name, lat, lon} ]; center: [], render_elem: 'map', overlay_elem: '', zoom: 5, geodesic: true, layers: [], set_marker: false, }); console.log(opts.features); let map = draw_base_map(opts); if(opts.geodesic) { let geodesicLayer = L.geodesic([], { weight: 7, opacity: 0.5, color: '#ff33ee', steps: 50, wrap: false, }).addTo(map); geodesicLayer.geoJson(opts.features) map.fitBounds(geodesicLayer.getBounds()); } else { let route = L.geoJSON(opts.features, { "color": "#ff7800", "weight": 5, "opacity": 0.65 }); route.addTo(map); map.fitBounds(route.getBounds()); } }, /** * Render a map with the airspace, etc around a given set of coords * e.g, the airport map * @param opts */ render_airspace_map: (opts) => { opts = _.defaults(opts, { render_elem: 'map', overlay_elem: '', lat: 0, lon: 0, zoom: 12, layers: [], set_marker: false, }); let map = draw_base_map(opts); const coords = [opts.lat, opts.lon]; console.log('Applying coords', coords); map.setView(coords, opts.zoom); if (opts.set_marker === true) { L.marker(coords).addTo(map); } return map; } } })();