2016-07-06 22:52:31 +02:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
angular.module('ffhb')
|
2016-07-09 10:15:03 +02:00
|
|
|
.controller('NodeCtrl',function($stateParams,$scope,store,config,leafletData){
|
2016-07-06 22:52:31 +02:00
|
|
|
$scope.nodeid = $stateParams.nodeid;
|
|
|
|
$scope.node = {};
|
2016-07-09 10:15:03 +02:00
|
|
|
angular.extend($scope, {
|
|
|
|
center: config.map.view,
|
|
|
|
markers: {node:{
|
|
|
|
lat: config.map.view.lat,
|
|
|
|
lng: config.map.view.lng,
|
|
|
|
focus: true,
|
|
|
|
title: 'Marker',
|
|
|
|
draggable: true,
|
|
|
|
label: {
|
|
|
|
message: 'Node:'+$stateParams.nodeid,
|
|
|
|
options: {
|
|
|
|
noHide: true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}},
|
|
|
|
events:{}
|
|
|
|
});
|
2016-07-06 22:52:31 +02:00
|
|
|
store.getGeojson.then(function(data){
|
2016-07-09 10:15:03 +02:00
|
|
|
leafletData.getMap().then(function(map) {
|
|
|
|
L.geoJson(data,config.map.geojson).addTo(map);
|
|
|
|
});
|
2016-07-06 22:52:31 +02:00
|
|
|
});
|
|
|
|
function render(prom){
|
|
|
|
prom.then(function(data){
|
|
|
|
$scope.node = data.merged[$stateParams.nodeid];
|
|
|
|
});
|
|
|
|
}
|
|
|
|
render(store.getData);
|
|
|
|
$scope.$on('store', function(ev, prom) {
|
|
|
|
render(prom);
|
|
|
|
});
|
|
|
|
|
2016-07-09 10:15:03 +02:00
|
|
|
$scope.$on('leafletDirectiveMarker.dragend', function(event, args){
|
|
|
|
if($scope.node !== undefined && $scope.node.nodeinfo !== undefined && $scope.node.nodeinfo.location !== undefined){
|
|
|
|
$scope.node.nodeinfo.location.latitude = args.model.lat;
|
|
|
|
$scope.node.nodeinfo.location.latitude = args.model.lng;
|
|
|
|
store.saveNode($stateParams.nodeid);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
var setToGps = function(position){
|
|
|
|
var pos = [position.coords.latitude,position.coords.longitude];
|
|
|
|
console.log('gps',pos);
|
|
|
|
if($scope.node !== undefined && $scope.node.nodeinfo !== undefined && $scope.node.nodeinfo.location !== undefined){
|
|
|
|
$scope.node.nodeinfo.location.latitude = position.coords.latitude;
|
|
|
|
$scope.node.nodeinfo.location.longitude = position.coords.longitude;
|
|
|
|
leafletData.getMap().then(function(map) {
|
|
|
|
map.setView(pos);
|
|
|
|
});
|
|
|
|
store.saveNode($stateParams.nodeid);
|
|
|
|
}
|
|
|
|
};
|
2016-07-06 22:52:31 +02:00
|
|
|
$scope.gps = function() {
|
2016-07-09 10:15:03 +02:00
|
|
|
if (navigator.geolocation) {
|
|
|
|
navigator.geolocation.getCurrentPosition(setToGps);
|
|
|
|
}else{
|
|
|
|
window.alert('No Permission for location');
|
|
|
|
}
|
2016-07-06 22:52:31 +02:00
|
|
|
};
|
|
|
|
$scope.save = function() {
|
|
|
|
store.saveNode($stateParams.nodeid);
|
|
|
|
};
|
|
|
|
});
|