2014-12-26 03:05:07 +00:00
|
|
|
(function(fp, $, ng, fm, ol, undefined) {
|
|
|
|
|
|
|
|
fp.app.directive("fpMap", [ "fpMap", function(fpMap) {
|
|
|
|
return {
|
|
|
|
restrict: 'EA',
|
|
|
|
link: function(scope, element, attrs) {
|
|
|
|
fpMap.initMap(element, attrs.id, attrs.fpPadId);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
} ]);
|
|
|
|
|
2016-09-28 12:10:08 +00:00
|
|
|
fp.app.factory("fpMap", function(fpUtils, fpSocket, fpMapMessages, fpDialogs, fpMapMarkers, fpMapPopups, $templateCache, $compile, fpMapLines, fpMapTypes, fpMapViews, $rootScope, fpMapPad, fpMapToolbox, $timeout, fpMapLegend, fpMapSearch, fpMapGpx) {
|
2014-12-26 03:05:07 +00:00
|
|
|
var maps = { };
|
|
|
|
|
|
|
|
var ret = { };
|
|
|
|
|
|
|
|
ret.getMap = function(id) {
|
|
|
|
return maps[id];
|
|
|
|
};
|
|
|
|
|
|
|
|
ret.initMap = function(el, id, padId) {
|
|
|
|
return maps[id] = new Map(el, id, padId);
|
|
|
|
};
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
|
|
|
|
function Map(replaceEl, id, padId) {
|
|
|
|
var map = this;
|
|
|
|
|
|
|
|
map.mapEvents = $rootScope.$new(true); /* Event types: clickMarker, clickLine, click, move, moveEnd, mouseMove */
|
2014-12-30 22:59:04 +00:00
|
|
|
map.socket = fpSocket(padId);
|
2014-12-26 03:05:07 +00:00
|
|
|
map.socket.id = id; // To be in scope for template
|
|
|
|
|
|
|
|
map.markersById = { };
|
|
|
|
map.linesById = { };
|
|
|
|
|
2016-10-02 18:03:24 +00:00
|
|
|
var el = $($templateCache.get("map/map.html"));
|
2014-12-26 03:05:07 +00:00
|
|
|
replaceEl.replaceWith(el);
|
|
|
|
$compile(el)(map.socket);
|
|
|
|
|
2015-01-18 16:55:43 +00:00
|
|
|
map.map = new FacilMap.Map(el[0], {
|
2016-10-03 12:49:58 +00:00
|
|
|
attributionIcon: new ol.Icon("assets/img/logo.png", new ol.Size(191, 176), new ol.Pixel(-37, -131))
|
2015-01-18 16:55:43 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
$(map.map.attributionIcon.imageDiv).css({ overflow: "hidden", height: "131px" });
|
2014-12-26 03:05:07 +00:00
|
|
|
|
|
|
|
// Map ID is not set yet as scope is not digested. So styles might change.
|
|
|
|
$timeout(map.map.updateSize.bind(map.map));
|
|
|
|
|
|
|
|
map.map.addLayer(new fm.Layer.OSM.MapSurfer.Road(ol.i18n("MapSurfer Road"), { permalinkName : "MSfR" }));
|
2015-12-18 23:57:33 +00:00
|
|
|
map.map.addLayer(new fm.Layer.OSM.Mapnik(ol.i18n("Mapnik"), { permalinkName : "Mpnk" }));
|
2014-12-26 03:05:07 +00:00
|
|
|
map.map.addLayer(new fm.Layer.OSM.CycleMap(ol.i18n("OpenCycleMap"), { permalinkName : "OCyc" }));
|
|
|
|
map.map.addLayer(new fm.Layer.OSM.HikeAndBike(ol.i18n("Hike & Bike Map"), { permalinkName : "HiBi" }));
|
|
|
|
map.map.addLayer(new fm.Layer.OSM.OpenPTMap(ol.i18n("Public transportation"), { permalinkName : "OPTM", visibility : false }));
|
|
|
|
map.map.addLayer(new fm.Layer.other.Relief(ol.i18n("Relief"), { visibility: false, permalinkName : "Rlie" }));
|
|
|
|
|
2015-01-03 14:51:11 +00:00
|
|
|
map.layerLines = new FacilMap.Layer.Vector("Lines", { displayInLayerSwitcher: false, visibility: true });
|
2014-12-26 03:05:07 +00:00
|
|
|
map.map.addLayer(map.layerLines);
|
|
|
|
|
2014-12-30 15:14:13 +00:00
|
|
|
var label;
|
2014-12-26 03:05:07 +00:00
|
|
|
map.featureHandler = new OpenLayers.Handler.Feature(null, map.layerLines, {
|
2014-12-30 14:56:16 +00:00
|
|
|
"over" : function(obj) {
|
2014-12-26 03:05:07 +00:00
|
|
|
$(map.map.div).addClass("fp-overFeature");
|
2014-12-30 14:56:16 +00:00
|
|
|
|
2014-12-30 15:14:13 +00:00
|
|
|
if(label)
|
|
|
|
label.close();
|
|
|
|
|
|
|
|
if(obj.fpMarker && obj.fpMarker.name)
|
|
|
|
label = map.showLabel(obj.fpMarker.name, obj.fpMarker, { x: 10, y: 0 });
|
2014-12-31 02:25:21 +00:00
|
|
|
else if(obj.fpLine && obj.fpLine.name) {
|
|
|
|
var e = map.featureHandler.evt;
|
|
|
|
label = map.showLabel(obj.fpLine.name, map.xyToPos({ x: e.offsetX == null ? e.layerX : e.offsetX, y: e.offsetY == null ? e.layerY : e.offsetY }), { x: 15, y: 0 }, true);
|
|
|
|
}
|
2014-12-26 03:05:07 +00:00
|
|
|
},
|
2014-12-30 14:56:16 +00:00
|
|
|
"out" : function(obj) {
|
2014-12-26 03:05:07 +00:00
|
|
|
$(map.map.div).removeClass("fp-overFeature");
|
2014-12-30 14:56:16 +00:00
|
|
|
|
2014-12-30 15:14:13 +00:00
|
|
|
if(label) {
|
|
|
|
label.close();
|
|
|
|
label = null;
|
2014-12-30 14:56:16 +00:00
|
|
|
}
|
2014-12-26 03:05:07 +00:00
|
|
|
},
|
|
|
|
"click" : function(obj) {
|
2014-12-31 02:24:47 +00:00
|
|
|
obj.fpOnClick(map.xyToPos(map.featureHandler.up), map.featureHandler.evt);
|
2014-12-26 03:05:07 +00:00
|
|
|
}
|
|
|
|
}, { map: map.map });
|
|
|
|
map.featureHandler.activate();
|
|
|
|
|
2015-01-03 14:51:11 +00:00
|
|
|
var dragIcon = fpUtils.createMarkerIcon("ffd700");
|
|
|
|
map.dragControl = new FacilMap.Control.DragLine(map.layerLines, dragIcon);
|
|
|
|
map.map.addControl(map.dragControl);
|
|
|
|
|
2014-12-26 03:05:07 +00:00
|
|
|
map.map.events.register("click", map.map, function(e) {
|
|
|
|
map.mapEvents.$emit("click", map.xyToPos(e.xy));
|
|
|
|
});
|
|
|
|
|
|
|
|
map.map.events.register("move", this, function() {
|
|
|
|
setTimeout(function() { map.mapEvents.$emit("move"); }, 0);
|
|
|
|
});
|
|
|
|
|
|
|
|
map.map.events.register("moveend", this, function() {
|
|
|
|
var x = map.map.getExtent().clone().transform(map.map.getProjectionObject(), fpUtils.proj());
|
|
|
|
setTimeout(function() {
|
|
|
|
map.mapEvents.$emit("moveEnd", { top: x.top, left: x.left, bottom: x.bottom, right: x.right, zoom: map.map.getZoom() });
|
|
|
|
}, 0);
|
|
|
|
});
|
|
|
|
|
|
|
|
map.map.events.register("mousemove", this, function(e) {
|
|
|
|
map.mapEvents.$emit("mouseMove", map.xyToPos(e.xy));
|
|
|
|
});
|
|
|
|
|
|
|
|
function _wrapFeatureFunc(superFunc) {
|
|
|
|
return function(feature) {
|
|
|
|
if(this.filterFunc(feature))
|
|
|
|
return superFunc.apply(this, arguments);
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
map.getCurrentView = function() {
|
|
|
|
var ret = map.map.getExtent().clone().transform(map.map.getProjectionObject(), fpUtils.proj());
|
|
|
|
|
|
|
|
ret.baseLayer = map.map.baseLayer.permalinkName;
|
|
|
|
ret.layers = [ ];
|
|
|
|
|
|
|
|
for(var i=0; i<map.map.layers.length; i++) {
|
|
|
|
if(!map.map.layers[i].isBaseLayer && map.map.layers[i].displayInLayerSwitcher && map.map.layers[i].visibility)
|
|
|
|
ret.layers.push(map.map.layers[i].permalinkName || map.map.layers[i].name);
|
|
|
|
}
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
};
|
|
|
|
|
|
|
|
map.displayView = function(view) {
|
|
|
|
if(view == null) {
|
|
|
|
map.map.zoomToMaxExtent();
|
|
|
|
} else {
|
|
|
|
var bbox = OpenLayers.Bounds.prototype.clone.apply(view).transform(fpUtils.proj(), map.map.getProjectionObject());
|
|
|
|
map.map.zoomToExtent(bbox);
|
|
|
|
|
|
|
|
var matching_layers = map.map.getLayersBy("permalinkName", view.baseLayer);
|
|
|
|
if(matching_layers.length == 0)
|
|
|
|
matching_layers = map.map.getLayersBy("name", view.baseLayer);
|
|
|
|
if(matching_layers.length > 0)
|
|
|
|
map.map.setBaseLayer(matching_layers[0]);
|
|
|
|
|
|
|
|
for(var i=0; i<map.map.layers.length; i++) {
|
|
|
|
if(!map.map.layers[i].isBaseLayer && map.map.layers[i].displayInLayerSwitcher)
|
|
|
|
map.map.layers[i].setVisibility(view.layers.indexOf(map.map.layers[i].permalinkName) != -1 || view.layers.indexOf(map.map.layers[i].name) != -1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
map.addMarker = function(marker) {
|
|
|
|
map.deleteMarker(marker);
|
|
|
|
|
2015-01-03 14:51:11 +00:00
|
|
|
var feature = fm.Util.createIconVector(fm.Util.toMapProjection(new ol.LonLat(marker.lon, marker.lat), map.map), fpUtils.createMarkerIcon(marker.colour));
|
2014-12-26 03:05:07 +00:00
|
|
|
feature.fpMarker = marker;
|
2014-12-31 02:24:47 +00:00
|
|
|
feature.fpOnClick = function(pos, evt) {
|
|
|
|
map.mapEvents.$emit("clickMarker", marker, evt);
|
2014-12-26 03:05:07 +00:00
|
|
|
};
|
|
|
|
map.layerLines.addFeatures([ feature ]);
|
|
|
|
map.markersById[marker.id] = feature;
|
|
|
|
};
|
|
|
|
|
|
|
|
map.deleteMarker = function(marker) {
|
|
|
|
var markerObj = map.markersById[marker.id];
|
|
|
|
if(!markerObj)
|
|
|
|
return;
|
|
|
|
|
|
|
|
delete map.markersById[marker.id];
|
|
|
|
map.layerLines.removeFeatures([ markerObj ]);
|
|
|
|
};
|
|
|
|
|
|
|
|
map.addLine = function(line) {
|
|
|
|
map.deleteLine(line);
|
|
|
|
|
2016-09-28 11:32:22 +00:00
|
|
|
if(!line.trackPoints || line.trackPoints.length < 2)
|
2014-12-26 03:05:07 +00:00
|
|
|
return;
|
|
|
|
|
2016-09-28 11:32:22 +00:00
|
|
|
var trackPoints = [ ];
|
|
|
|
for(var i=0; i<line.trackPoints.length; i++) {
|
|
|
|
if(line.trackPoints[i] != null)
|
|
|
|
trackPoints.push(new OpenLayers.Geometry.Point(line.trackPoints[i].lon, line.trackPoints[i].lat));
|
2014-12-26 03:05:07 +00:00
|
|
|
}
|
|
|
|
|
2016-09-28 11:32:22 +00:00
|
|
|
if(trackPoints.length < 2)
|
2014-12-26 03:05:07 +00:00
|
|
|
return;
|
|
|
|
|
|
|
|
var style = {
|
|
|
|
strokeColor : '#'+line.colour,
|
|
|
|
strokeWidth : line.width,
|
|
|
|
strokeOpacity : 0.7
|
|
|
|
};
|
|
|
|
|
2016-09-28 11:32:22 +00:00
|
|
|
var feature = new OpenLayers.Feature.Vector(new OpenLayers.Geometry.LineString(trackPoints).transform(fpUtils.proj(), map.map.getProjectionObject()), null, style);
|
2014-12-30 14:56:16 +00:00
|
|
|
feature.fpLine = line;
|
2014-12-31 02:24:47 +00:00
|
|
|
feature.fpOnClick = function(clickPos, evt) {
|
|
|
|
map.mapEvents.$emit("clickLine", line, clickPos, evt);
|
2014-12-26 03:05:07 +00:00
|
|
|
};
|
|
|
|
map.layerLines.addFeatures([ feature ]);
|
|
|
|
map.linesById[line.id] = feature;
|
|
|
|
};
|
|
|
|
|
|
|
|
map.deleteLine = function(line) {
|
|
|
|
var lineObj = map.linesById[line.id];
|
|
|
|
if(!lineObj)
|
|
|
|
return;
|
|
|
|
|
|
|
|
delete map.linesById[line.id];
|
|
|
|
map.layerLines.removeFeatures([lineObj]);
|
|
|
|
};
|
|
|
|
|
|
|
|
map.addClickListener = function(listener) {
|
|
|
|
map.featureHandler.deactivate(); // Disable clicking on markers and lines
|
|
|
|
$(map.map.div).addClass("fp-clickHandler");
|
|
|
|
|
|
|
|
var unregister;
|
|
|
|
|
|
|
|
var ret = {
|
|
|
|
cancel: function() {
|
|
|
|
unregister();
|
|
|
|
$(map.map.div).removeClass("fp-clickHandler");
|
|
|
|
map.featureHandler.activate();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
setTimeout(function() {
|
|
|
|
unregister = map.mapEvents.$on("click", function(e, pos) {
|
|
|
|
ret.cancel();
|
|
|
|
listener(pos);
|
|
|
|
});
|
|
|
|
}, 0);
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
};
|
|
|
|
|
|
|
|
map.xyToPos = function(xy) {
|
|
|
|
return map.map.getLonLatFromViewPortPx(xy).clone().transform(map.map.getProjectionObject(), fpUtils.proj());
|
|
|
|
};
|
|
|
|
|
|
|
|
map.posToXy = function(pos) {
|
|
|
|
var lonlat = new OpenLayers.LonLat(pos.lon, pos.lat).transform(fpUtils.proj(), map.map.getProjectionObject());
|
|
|
|
return map.map.getViewPortPxFromLonLat(lonlat);
|
|
|
|
};
|
|
|
|
|
|
|
|
map.getLayerInfo = function() {
|
2016-10-04 12:43:57 +00:00
|
|
|
var ret = { base: [ ], overlay: [ ] };
|
2014-12-26 03:05:07 +00:00
|
|
|
map.map.layers.forEach(function(it) {
|
|
|
|
if(!it.displayInLayerSwitcher)
|
|
|
|
return;
|
2016-10-04 12:43:57 +00:00
|
|
|
(it.isBaseLayer ? ret.base : ret.overlay).push({ visibility: it.getVisibility(), name: it.name, permalinkName: it.permalinkName });
|
2014-12-26 03:05:07 +00:00
|
|
|
});
|
|
|
|
return ret;
|
|
|
|
};
|
|
|
|
|
|
|
|
map.showLayer = function(permalinkName, show) {
|
|
|
|
var layers = map.map.getLayersBy("permalinkName", permalinkName);
|
|
|
|
if(layers.length == 0)
|
|
|
|
return;
|
|
|
|
|
2015-06-11 22:23:58 +00:00
|
|
|
if(layers[0].isBaseLayer)
|
2014-12-26 03:05:07 +00:00
|
|
|
map.map.setBaseLayer(layers[0]);
|
|
|
|
else
|
|
|
|
layers[0].setVisibility(show);
|
|
|
|
};
|
|
|
|
|
|
|
|
map.makeLineMovable = function(origLine) {
|
|
|
|
map.featureHandler.deactivate();
|
|
|
|
|
|
|
|
var line = $.extend(true, { }, origLine);
|
2016-09-28 11:32:22 +00:00
|
|
|
line.trackPoints = line.routePoints;
|
2015-01-03 14:51:11 +00:00
|
|
|
var markers = [ ];
|
2016-09-28 11:32:22 +00:00
|
|
|
for(var i=0; i<line.routePoints.length; i++)
|
|
|
|
markers.push(fm.Util.createIconVector(fm.Util.toMapProjection(new ol.LonLat(line.routePoints[i].lon, line.routePoints[i].lat), map.map), dragIcon));
|
2015-01-03 14:51:11 +00:00
|
|
|
map.layerLines.addFeatures(markers);
|
2014-12-26 03:05:07 +00:00
|
|
|
map.addLine(line);
|
|
|
|
|
2015-01-03 14:51:11 +00:00
|
|
|
var dragExcludeBkp = map.layerLines._excludeFeature;
|
|
|
|
map.layerLines._excludeFeature = function(feature) {
|
|
|
|
return dragExcludeBkp.apply(this, arguments) || (!feature.fmStartLonLat && feature != map.linesById[line.id] && markers.indexOf(feature) == -1);
|
|
|
|
};
|
2014-12-26 03:05:07 +00:00
|
|
|
|
2015-01-03 14:51:11 +00:00
|
|
|
map.dragControl.onDblClick = function(feature) {
|
|
|
|
var idx = markers.indexOf(feature);
|
|
|
|
if(idx != -1) {
|
2016-09-28 11:32:22 +00:00
|
|
|
line.routePoints.splice(idx, 1);
|
2014-12-26 03:05:07 +00:00
|
|
|
map.addLine(line);
|
2015-01-03 14:51:11 +00:00
|
|
|
|
|
|
|
markers.splice(idx, 1);
|
|
|
|
map.layerLines.removeFeatures([ feature ]);
|
|
|
|
feature.destroy();
|
2014-12-26 03:05:07 +00:00
|
|
|
}
|
2015-01-03 14:51:11 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
map.dragControl.onDrag = function(feature) {
|
|
|
|
var idx = markers.indexOf(feature);
|
|
|
|
if(idx != -1) { // Existing marker was dragged
|
|
|
|
var lonlat = fm.Util.fromMapProjection(new ol.LonLat(feature.geometry.x, feature.geometry.y), map.map);
|
2016-09-28 11:32:22 +00:00
|
|
|
line.routePoints[idx] = { lat: lonlat.lat, lon: lonlat.lon };
|
2015-01-03 14:51:11 +00:00
|
|
|
map.addLine(line);
|
|
|
|
}
|
|
|
|
else if(feature.fmStartLonLat) { // New marker
|
|
|
|
var index = fm.Util.lonLatIndexOnLine(feature.fmStartLonLat, feature.fmLine.geometry);
|
|
|
|
if(index != null) {
|
2016-09-28 11:32:22 +00:00
|
|
|
var newIndex = line.routePoints.length;
|
2015-01-03 14:51:11 +00:00
|
|
|
var indexes = [ ];
|
|
|
|
for(var i=0; i<newIndex; i++) {
|
2016-09-28 11:32:22 +00:00
|
|
|
indexes.push(fm.Util.lonLatIndexOnLine(fm.Util.toMapProjection(new OpenLayers.LonLat(line.routePoints[i].lon, line.routePoints[i].lat), map.map), feature.fmLine.geometry));
|
|
|
|
if(index < fm.Util.lonLatIndexOnLine(fm.Util.toMapProjection(new OpenLayers.LonLat(line.routePoints[i].lon, line.routePoints[i].lat), map.map), feature.fmLine.geometry))
|
2015-01-03 14:51:11 +00:00
|
|
|
newIndex = i;
|
|
|
|
}
|
|
|
|
|
|
|
|
var lonlat = fm.Util.fromMapProjection(feature.fmStartLonLat, map.map);
|
2016-09-28 11:32:22 +00:00
|
|
|
line.routePoints.splice(newIndex, 0, { lat: lonlat.lat, lon: lonlat.lon });
|
2015-01-03 14:51:11 +00:00
|
|
|
markers.splice(newIndex, 0, feature);
|
|
|
|
map.addLine(line);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
console.warn("Index = null", feature.fmStartLonLat);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
map.dragControl.onComplete = function(feature) {
|
|
|
|
if(feature.fmStartLonLat)
|
|
|
|
delete feature.fmStartLonLat;
|
|
|
|
};
|
|
|
|
|
|
|
|
map.dragControl.activate();
|
2014-12-26 03:05:07 +00:00
|
|
|
|
|
|
|
return {
|
|
|
|
done : function() {
|
|
|
|
end();
|
2016-09-28 11:32:22 +00:00
|
|
|
return line.routePoints;
|
2014-12-26 03:05:07 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2015-01-03 14:51:11 +00:00
|
|
|
function end() {
|
|
|
|
if(markers.indexOf(map.dragControl.feature) != -1)
|
|
|
|
map.dragControl._simulateOverFeature(null);
|
|
|
|
|
|
|
|
map.layerLines.removeFeatures(markers);
|
2014-12-26 03:05:07 +00:00
|
|
|
for(var i=0; i<markers.length; i++)
|
2015-01-03 14:51:11 +00:00
|
|
|
markers[i].destroy();
|
2014-12-26 03:05:07 +00:00
|
|
|
|
2015-01-03 14:51:11 +00:00
|
|
|
map.layerLines._excludeFeature = dragExcludeBkp;
|
|
|
|
map.dragControl.deactivate();
|
2014-12-26 03:05:07 +00:00
|
|
|
map.featureHandler.activate();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
map.loadStart = function() {
|
|
|
|
map.map.getControlsByClass("FacilMap.Control.Loading")[0].loadStart();
|
|
|
|
};
|
|
|
|
|
|
|
|
map.loadEnd = function() {
|
|
|
|
map.map.getControlsByClass("FacilMap.Control.Loading")[0].loadEnd();
|
|
|
|
};
|
|
|
|
|
2014-12-30 14:56:16 +00:00
|
|
|
map.showLabel = function(label, pos, offset, updateOnMove) {
|
|
|
|
var xy = map.posToXy(pos);
|
|
|
|
var el = $("<div/>").addClass("fp-map-label").text(label).css({ top: (xy.y+offset.y)+"px", left: (xy.x+offset.x)+"px" }).appendTo(map.map.div);
|
|
|
|
|
|
|
|
var updatePosition = function(e) {
|
2014-12-31 02:25:21 +00:00
|
|
|
el.css({ top: ((e.offsetY == null ? e.layerY : e.offsetY)+offset.y)+"px", left: ((e.offsetX == null ? e.layerX : e.offsetX)+offset.x)+"px" });
|
2014-12-30 14:56:16 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
if(updateOnMove)
|
|
|
|
map.map.events.register("mousemove", null, updatePosition);
|
|
|
|
|
|
|
|
return {
|
|
|
|
close: function() {
|
|
|
|
el.remove();
|
|
|
|
if(updateOnMove)
|
|
|
|
map.map.events.unregister("mousemove", null, updatePosition);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2014-12-26 03:05:07 +00:00
|
|
|
map.messages = fpMapMessages(map);
|
|
|
|
map.popups = fpMapPopups(map);
|
|
|
|
map.markersUi = fpMapMarkers(map);
|
|
|
|
map.linesUi = fpMapLines(map);
|
|
|
|
map.viewsUi = fpMapViews(map);
|
|
|
|
map.typesUi = fpMapTypes(map);
|
|
|
|
map.padUi = fpMapPad(map);
|
2016-09-28 12:10:08 +00:00
|
|
|
map.gpxUi = fpMapGpx(map);
|
2016-10-04 12:43:57 +00:00
|
|
|
map.toolboxUi = fpMapToolbox(map);
|
2014-12-26 03:05:07 +00:00
|
|
|
|
2014-12-27 02:47:21 +00:00
|
|
|
fpMapLegend(map);
|
2014-12-27 16:16:54 +00:00
|
|
|
fpMapSearch(map);
|
2014-12-26 03:05:07 +00:00
|
|
|
|
2014-12-30 22:59:04 +00:00
|
|
|
map.socket.$on("loadStart", function() {
|
|
|
|
map.loadStart();
|
|
|
|
});
|
|
|
|
|
|
|
|
map.socket.$on("loadEnd", function() {
|
|
|
|
map.loadEnd();
|
|
|
|
});
|
|
|
|
|
|
|
|
var loadedWatcher = map.socket.$watch("loaded", function(loaded) {
|
|
|
|
if(loaded) {
|
|
|
|
setTimeout(function() {
|
|
|
|
map.displayView(map.socket.padData.defaultView);
|
|
|
|
}, 0);
|
|
|
|
loadedWatcher();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
map.socket.on("marker", function(data) {
|
|
|
|
map.addMarker(data);
|
|
|
|
});
|
|
|
|
|
|
|
|
map.socket.on("deleteMarker", function(data) {
|
|
|
|
map.deleteMarker(data);
|
|
|
|
});
|
|
|
|
|
|
|
|
map.socket.on("line", function(data) {
|
2016-09-28 11:32:22 +00:00
|
|
|
setTimeout(function() { // trackPoints needs to be copied over
|
2014-12-30 22:59:04 +00:00
|
|
|
map.addLine(map.socket.lines[data.id]);
|
|
|
|
}, 0);
|
|
|
|
});
|
|
|
|
|
|
|
|
map.socket.on("deleteLine", function(data) {
|
|
|
|
map.deleteLine(data);
|
|
|
|
});
|
|
|
|
|
|
|
|
map.socket.on("linePoints", function(data) {
|
|
|
|
setTimeout(function() {
|
|
|
|
map.addLine(map.socket.lines[data.id]);
|
|
|
|
}, 0);
|
|
|
|
});
|
|
|
|
|
|
|
|
var errorMessage = null;
|
|
|
|
map.socket.$watch("disconnected", function(disconnected) {
|
|
|
|
if(disconnected && !errorMessage)
|
|
|
|
errorMessage = map.messages.showMessage("error", "The connection to the server was lost.");
|
|
|
|
else if(!disconnected && errorMessage) {
|
|
|
|
errorMessage.close();
|
|
|
|
errorMessage = null;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
map.mapEvents.$on("moveEnd", function(e, bbox) {
|
|
|
|
map.socket.updateBbox(bbox);
|
|
|
|
});
|
2014-12-26 03:05:07 +00:00
|
|
|
}
|
2016-03-04 19:18:01 +00:00
|
|
|
});
|
2014-12-26 03:05:07 +00:00
|
|
|
|
|
|
|
})(FacilPad, jQuery, angular, FacilMap, OpenLayers);
|