Commit ac8e67eff09a28d68a4c3733b5dc454988684d21

Authored by Vladyslav
Committed by Igor Kulikov
1 parent 46c78622

Create new input widgets for edit location enity to map (#2138)

... ... @@ -356,6 +356,54 @@
356 356 "dataKeySettingsSchema": "{}\n",
357 357 "defaultConfig": "{\"datasources\":[{\"type\":\"static\",\"name\":\"function\",\"dataKeys\":[{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"Random\",\"color\":\"#2196f3\",\"settings\":{},\"_hash\":0.15479322438769105,\"funcBody\":\"var value = prevValue + Math.random() * 100 - 50;\\nvar multiplier = Math.pow(10, 2 || 0);\\nvar value = Math.round(value * multiplier) / multiplier;\\nif (value < -1000) {\\n\\tvalue = -1000;\\n} else if (value > 1000) {\\n\\tvalue = 1000;\\n}\\nreturn value;\"}]}],\"timewindow\":{\"realtime\":{\"timewindowMs\":60000}},\"showTitle\":true,\"backgroundColor\":\"rgb(255, 255, 255)\",\"color\":\"rgba(0, 0, 0, 0.87)\",\"padding\":\"8px\",\"settings\":{\"deviceSecret\":true,\"showLabel\":true},\"title\":\"Device claiming widget\",\"dropShadow\":true,\"showTitleIcon\":false,\"titleIcon\":\"more_horiz\",\"iconColor\":\"rgba(0, 0, 0, 0.87)\",\"iconSize\":\"24px\",\"titleTooltip\":\"\",\"enableFullscreen\":false,\"enableDataExport\":true,\"widgetStyle\":{},\"titleStyle\":{\"fontSize\":\"16px\",\"fontWeight\":400},\"useDashboardTimewindow\":true,\"displayTimewindow\":true,\"showLegend\":false,\"actions\":{}}"
358 358 }
  359 + },
  360 + {
  361 + "alias": "markers_placement_image_map",
  362 + "name": "Markers Placement - Image Map",
  363 + "descriptor": {
  364 + "type": "latest",
  365 + "sizeX": 8.5,
  366 + "sizeY": 6.5,
  367 + "resources": [],
  368 + "templateHtml": "",
  369 + "templateCss": ".leaflet-zoom-box {\n\tz-index: 9;\n}\n\n.leaflet-pane { z-index: 4; }\n\n.leaflet-tile-pane { z-index: 2; }\n.leaflet-overlay-pane { z-index: 4; }\n.leaflet-shadow-pane { z-index: 5; }\n.leaflet-marker-pane { z-index: 6; }\n.leaflet-tooltip-pane { z-index: 7; }\n.leaflet-popup-pane { z-index: 8; }\n\n.leaflet-map-pane canvas { z-index: 1; }\n.leaflet-map-pane svg { z-index: 2; }\n\n.leaflet-control {\n\tz-index: 9;\n}\n.leaflet-top,\n.leaflet-bottom {\n\tz-index: 11;\n}\n\n.tb-marker-label {\n border: none;\n background: none;\n box-shadow: none;\n}\n\n.tb-marker-label:before {\n border: none;\n background: none;\n}\n",
  370 + "controllerScript": "self.onInit = function() {\n self.ctx.map = new TbMapWidgetV2('image-map', false, self.ctx, null, null, true);\n var createEntityLocation = {\n name: 'action.add',\n show: true,\n onAction: function($event) {\n self.ctx.map.selectEntity($event);\n },\n icon: 'add_location'\n };\n self.ctx.widgetActions = [createEntityLocation];\n}\n\nself.onDataUpdated = function() {\n self.ctx.map.update();\n}\n\nself.onResize = function() {\n self.ctx.map.resize();\n}\n\nself.getSettingsSchema = function() {\n return TbMapWidgetV2.settingsSchema('image-map');\n}\n\nself.getDataKeySettingsSchema = function() {\n return TbMapWidgetV2.dataKeySettingsSchema('image-map');\n}\n\nself.actionSources = function() {\n return TbMapWidgetV2.actionSources();\n}\n\nself.onDestroy = function() {\n}\n",
  371 + "settingsSchema": "{}",
  372 + "dataKeySettingsSchema": "{}\n",
  373 + "defaultConfig": "{\"datasources\":[{\"type\":\"function\",\"name\":\"First point\",\"dataKeys\":[{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"xPos\",\"color\":\"#2196f3\",\"settings\":{},\"_hash\":0.05427416942713381,\"funcBody\":\"var value = prevValue || 0.2;\\nif (time % 5000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"},{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"yPos\",\"color\":\"#4caf50\",\"settings\":{},\"_hash\":0.680594833308841,\"funcBody\":\"var value = prevValue || 0.3;\\nif (time % 5000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"}]},{\"type\":\"function\",\"name\":\"Second point\",\"dataKeys\":[{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"xPos\",\"color\":\"#f44336\",\"settings\":{},\"_hash\":0.05012157428742059,\"funcBody\":\"var value = prevValue || 0.6;\\nif (time % 4000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"},{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"yPos\",\"color\":\"#ffc107\",\"settings\":{},\"_hash\":0.6742359401617628,\"funcBody\":\"var value = prevValue || 0.7;\\nif (time % 4000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"}]}],\"timewindow\":{\"realtime\":{\"timewindowMs\":60000}},\"showTitle\":true,\"backgroundColor\":\"#fff\",\"color\":\"rgba(0, 0, 0, 0.87)\",\"padding\":\"8px\",\"settings\":{\"showLabel\":true,\"label\":\"${entityName}\",\"tooltipPattern\":\"<b>${entityName}</b><br/><br/><b>X Pos:</b> ${xPos:2}<br/><b>Y Pos:</b> ${yPos:2}<br/><br/><link-act name='delete'>Delete</link-act>\",\"markerImageSize\":34,\"useColorFunction\":false,\"markerImages\":[],\"useMarkerImageFunction\":false,\"color\":\"#fe7569\",\"mapImageUrl\":\"\",\"xPosKeyName\":\"xPos\",\"yPosKeyName\":\"yPos\",\"posFunction\":\"return {x: origXPos, y: origYPos};\",\"markerOffsetX\":0.5,\"markerOffsetY\":1,\"showTooltip\":true,\"autocloseTooltip\":true,\"showTooltipAction\":\"click\",\"defaultCenterPosition\":[0,0]},\"title\":\"Markers Placement - Image Map\",\"dropShadow\":true,\"enableFullscreen\":true,\"titleStyle\":{\"fontSize\":\"16px\",\"fontWeight\":400},\"useDashboardTimewindow\":true,\"showLegend\":false,\"widgetStyle\":{},\"actions\":{\"tooltipAction\":[{\"id\":\"c39f512a-21c6-6b06-3aa1-715262c6553d\",\"name\":\"delete\",\"icon\":\"more_horiz\",\"type\":\"custom\",\"customFunction\":\"var $rootScope = widgetContext.$scope.$injector.get('$rootScope');\\nvar entityDatasource = widgetContext.map.subscription.datasources.filter(\\n function(entity) {\\n return entity.entityId === entityId.id\\n });\\n\\nwidgetContext.map.saveMarkerLocation(entityDatasource[0],\\n widgetContext.map.locations[0], {\\n \\\"lat\\\": null,\\n \\\"lng\\\": null\\n }).then(function succes() {\\n $rootScope.$broadcast('widgetForceReInit');\\n });\"}]},\"showTitleIcon\":false,\"titleIcon\":\"more_horiz\",\"iconColor\":\"rgba(0, 0, 0, 0.87)\",\"iconSize\":\"24px\",\"titleTooltip\":\"\",\"displayTimewindow\":true}"
  374 + }
  375 + },
  376 + {
  377 + "alias": "markers_placement_openstreetmap",
  378 + "name": "Markers Placement - OpenStreetMap",
  379 + "descriptor": {
  380 + "type": "latest",
  381 + "sizeX": 8.5,
  382 + "sizeY": 6,
  383 + "resources": [],
  384 + "templateHtml": "",
  385 + "templateCss": ".leaflet-zoom-box {\n\tz-index: 9;\n}\n\n.leaflet-pane { z-index: 4; }\n\n.leaflet-tile-pane { z-index: 2; }\n.leaflet-overlay-pane { z-index: 4; }\n.leaflet-shadow-pane { z-index: 5; }\n.leaflet-marker-pane { z-index: 6; }\n.leaflet-tooltip-pane { z-index: 7; }\n.leaflet-popup-pane { z-index: 8; }\n\n.leaflet-map-pane canvas { z-index: 1; }\n.leaflet-map-pane svg { z-index: 2; }\n\n.leaflet-control {\n\tz-index: 9;\n}\n.leaflet-top,\n.leaflet-bottom {\n\tz-index: 11;\n}\n\n.tb-marker-label {\n border: none;\n background: none;\n box-shadow: none;\n}\n\n.tb-marker-label:before {\n border: none;\n background: none;\n}\n",
  386 + "controllerScript": "self.onInit = function() {\n self.ctx.map = new TbMapWidgetV2('openstreet-map', false, self.ctx, null, null, true);\n var createEntityLocation = {\n name: 'action.add',\n show: true,\n onAction: function($event) {\n self.ctx.map.selectEntity($event);\n },\n icon: 'add_location'\n };\n self.ctx.widgetActions = [createEntityLocation];\n}\n\nself.onDataUpdated = function() {\n self.ctx.map.update();\n}\n\nself.onResize = function() {\n self.ctx.map.resize();\n}\n\nself.getSettingsSchema = function() {\n return TbMapWidgetV2.settingsSchema('openstreet-map');\n}\n\nself.getDataKeySettingsSchema = function() {\n return TbMapWidgetV2.dataKeySettingsSchema('openstreet-map');\n}\n\nself.actionSources = function() {\n return TbMapWidgetV2.actionSources();\n}\n\nself.onDestroy = function() {\n}\n",
  387 + "settingsSchema": "{}",
  388 + "dataKeySettingsSchema": "{}\n",
  389 + "defaultConfig": "{\"datasources\":[{\"type\":\"function\",\"name\":\"First point\",\"dataKeys\":[{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"latitude\",\"color\":\"#2196f3\",\"settings\":{},\"_hash\":0.05427416942713381,\"funcBody\":\"var value = prevValue || 15.833293;\\nif (time % 5000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"},{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"longitude\",\"color\":\"#4caf50\",\"settings\":{},\"_hash\":0.680594833308841,\"funcBody\":\"var value = prevValue || -90.454350;\\nif (time % 5000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"}]},{\"type\":\"function\",\"name\":\"Second point\",\"dataKeys\":[{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"latitude\",\"color\":\"#607d8b\",\"settings\":{},\"_hash\":0.7867521952070078,\"funcBody\":\"var value = prevValue || 14.450463;\\nif (time % 4000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"},{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"longitude\",\"color\":\"#9c27b0\",\"settings\":{},\"_hash\":0.7040053227577256,\"funcBody\":\"var value = prevValue || -84.845334;\\nif (time % 4000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"}]}],\"timewindow\":{\"realtime\":{\"timewindowMs\":60000}},\"showTitle\":true,\"backgroundColor\":\"#fff\",\"color\":\"rgba(0, 0, 0, 0.87)\",\"padding\":\"8px\",\"settings\":{\"fitMapBounds\":true,\"latKeyName\":\"latitude\",\"lngKeyName\":\"longitude\",\"showLabel\":true,\"label\":\"${entityName}\",\"tooltipPattern\":\"<b>${entityName}</b><br/><br/><b>Latitude:</b> ${latitude:7}<br/><b>Longitude:</b> ${longitude:7}<br/><br/><link-act name='delete'>Delete</link-act>\",\"markerImageSize\":34,\"useColorFunction\":false,\"markerImages\":[],\"useMarkerImageFunction\":false,\"color\":\"#fe7569\",\"mapProvider\":\"OpenStreetMap.Mapnik\",\"showTooltip\":true,\"autocloseTooltip\":true,\"defaultCenterPosition\":[0,0],\"customProviderTileUrl\":\"https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png\",\"showTooltipAction\":\"click\",\"polygonKeyName\":\"coordinates\",\"polygonOpacity\":0.5,\"polygonStrokeOpacity\":1,\"polygonStrokeWeight\":1,\"zoomOnClick\":true,\"showCoverageOnHover\":true,\"animate\":true,\"maxClusterRadius\":80,\"removeOutsideVisibleBounds\":true,\"defaultZoomLevel\":5},\"title\":\"Markers Placement - OpenStreetMap\",\"dropShadow\":true,\"enableFullscreen\":true,\"titleStyle\":{\"fontSize\":\"16px\",\"fontWeight\":400},\"useDashboardTimewindow\":true,\"showLegend\":false,\"widgetStyle\":{},\"actions\":{\"tooltipAction\":[{\"id\":\"54c293c4-9ca6-e34f-dc6a-0271944c1c66\",\"name\":\"delete\",\"icon\":\"more_horiz\",\"type\":\"custom\",\"customFunction\":\"var $rootScope = widgetContext.$scope.$injector.get('$rootScope');\\nvar entityDatasource = widgetContext.map.subscription.datasources.filter(\\n function(entity) {\\n return entity.entityId === entityId.id\\n });\\n\\nwidgetContext.map.saveMarkerLocation(entityDatasource[0],\\n widgetContext.map.locations[0], {\\n \\\"lat\\\": null,\\n \\\"lng\\\": null\\n }).then(function succes() {\\n $rootScope.$broadcast('widgetForceReInit');\\n });\"}]},\"showTitleIcon\":false,\"titleIcon\":\"more_horiz\",\"iconColor\":\"rgba(0, 0, 0, 0.87)\",\"iconSize\":\"24px\",\"titleTooltip\":\"\",\"displayTimewindow\":true}"
  390 + }
  391 + },
  392 + {
  393 + "alias": "markers_placement_google_maps",
  394 + "name": "Markers Placement - Google Maps",
  395 + "descriptor": {
  396 + "type": "latest",
  397 + "sizeX": 8.5,
  398 + "sizeY": 6,
  399 + "resources": [],
  400 + "templateHtml": "",
  401 + "templateCss": ".error {\n color: red;\n}\n.tb-labels {\n color: #222;\n font: 12px/1.5 \"Helvetica Neue\", Arial, Helvetica, sans-serif;\n text-align: center;\n width: 200px;\n white-space: nowrap;\n}",
  402 + "controllerScript": "self.onInit = function() {\n self.ctx.map = new TbMapWidgetV2('google-map', false, self.ctx, null, null, true);\n var createEntityLocation = {\n name: 'action.add',\n show: true,\n onAction: function($event) {\n self.ctx.map.selectEntity($event);\n },\n icon: 'add_location'\n };\n self.ctx.widgetActions = [createEntityLocation];\n}\n\nself.onDataUpdated = function() {\n self.ctx.map.update();\n}\n\nself.onResize = function() {\n self.ctx.map.resize();\n}\n\nself.getSettingsSchema = function() {\n return TbMapWidgetV2.settingsSchema('google-map');\n}\n\nself.getDataKeySettingsSchema = function() {\n return TbMapWidgetV2.dataKeySettingsSchema('google-map');\n}\n\nself.actionSources = function() {\n return TbMapWidgetV2.actionSources();\n}\n\nself.onDestroy = function() {\n}\n",
  403 + "settingsSchema": "{}",
  404 + "dataKeySettingsSchema": "{}\n",
  405 + "defaultConfig": "{\"datasources\":[{\"type\":\"function\",\"name\":\"First point\",\"dataKeys\":[{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"latitude\",\"color\":\"#2196f3\",\"settings\":{},\"_hash\":0.05427416942713381,\"funcBody\":\"var value = prevValue || 15.833293;\\nif (time % 5000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"},{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"longitude\",\"color\":\"#4caf50\",\"settings\":{},\"_hash\":0.680594833308841,\"funcBody\":\"var value = prevValue || -90.454350;\\nif (time % 5000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"}]},{\"type\":\"function\",\"name\":\"Second point\",\"dataKeys\":[{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"latitude\",\"color\":\"#f44336\",\"settings\":{},\"_hash\":0.05012157428742059,\"funcBody\":\"var value = prevValue || 14.450463;\\nif (time % 4000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"},{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"longitude\",\"color\":\"#ffc107\",\"settings\":{},\"_hash\":0.6742359401617628,\"funcBody\":\"var value = prevValue || -84.845334;\\nif (time % 4000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"}]}],\"timewindow\":{\"realtime\":{\"timewindowMs\":60000}},\"showTitle\":true,\"backgroundColor\":\"#fff\",\"color\":\"rgba(0, 0, 0, 0.87)\",\"padding\":\"8px\",\"settings\":{\"fitMapBounds\":true,\"latKeyName\":\"latitude\",\"lngKeyName\":\"longitude\",\"showLabel\":true,\"label\":\"${entityName}\",\"tooltipPattern\":\"<b>${entityName}</b><br/><br/><b>Latitude:</b> ${latitude:7}<br/><b>Longitude:</b> ${longitude:7}<br/><br/><link-act name='delete'>Delete</link-act>\",\"markerImageSize\":34,\"gmDefaultMapType\":\"roadmap\",\"gmApiKey\":\"AIzaSyDoEx2kaGz3PxwbI9T7ccTSg5xjdw8Nw8Q\",\"useColorFunction\":false,\"markerImages\":[],\"useMarkerImageFunction\":false,\"colorFunction\":\"\\n\",\"color\":\"#fe7569\",\"showTooltip\":true,\"autocloseTooltip\":true,\"defaultCenterPosition\":[0,0],\"showTooltipAction\":\"click\",\"polygonKeyName\":\"coordinates\",\"polygonOpacity\":0.5,\"polygonStrokeOpacity\":1,\"polygonStrokeWeight\":1,\"zoomOnClick\":true,\"gridSize\":60,\"defaultZoomLevel\":5},\"title\":\"Markers Placement - Google Maps\",\"dropShadow\":true,\"enableFullscreen\":true,\"titleStyle\":{\"fontSize\":\"16px\",\"fontWeight\":400},\"useDashboardTimewindow\":true,\"showLegend\":false,\"widgetStyle\":{},\"actions\":{\"tooltipAction\":[{\"id\":\"8d3c0156-0a14-7a6f-0ddd-0ec16b9ffc91\",\"name\":\"delete\",\"icon\":\"more_horiz\",\"type\":\"custom\",\"customFunction\":\"var $rootScope = widgetContext.$scope.$injector.get('$rootScope');\\nvar entityDatasource = widgetContext.map.subscription.datasources.filter(\\n function(entity) {\\n return entity.entityId === entityId.id\\n });\\n\\nwidgetContext.map.saveMarkerLocation(entityDatasource[0],\\n widgetContext.map.locations[0], {\\n \\\"lat\\\": null,\\n \\\"lng\\\": null\\n }).then(function succes() {\\n $rootScope.$broadcast('widgetForceReInit');\\n });\"}]},\"showTitleIcon\":false,\"titleIcon\":\"more_horiz\",\"iconColor\":\"rgba(0, 0, 0, 0.87)\",\"iconSize\":\"24px\",\"titleTooltip\":\"\",\"displayTimewindow\":true}"
  406 + }
359 407 }
360 408 ]
361 409 }
... ...
  1 +/**
  2 + * Copyright © 2016-2019 The Thingsboard Authors
  3 + *
  4 + * Licensed under the Apache License, Version 2.0 (the "License");
  5 + * you may not use this file except in compliance with the License.
  6 + * You may obtain a copy of the License at
  7 + *
  8 + * http://www.apache.org/licenses/LICENSE-2.0
  9 + *
  10 + * Unless required by applicable law or agreed to in writing, software
  11 + * distributed under the License is distributed on an "AS IS" BASIS,
  12 + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13 + * See the License for the specific language governing permissions and
  14 + * limitations under the License.
  15 + */
  16 +.tb-add-entity-panel {
  17 + min-width: 150px;
  18 + max-height: 200px;
  19 + overflow: hidden;
  20 + overflow-y: auto;
  21 + background: #fff;
  22 + border-radius: 4px;
  23 + box-shadow:
  24 + 0 7px 8px -4px rgba(0, 0, 0, .2),
  25 + 0 13px 19px 2px rgba(0, 0, 0, .14),
  26 + 0 5px 24px 4px rgba(0, 0, 0, .12);
  27 +}
... ...
  1 +<!--
  2 +
  3 + Copyright © 2016-2019 The Thingsboard Authors
  4 +
  5 + Licensed under the Apache License, Version 2.0 (the "License");
  6 + you may not use this file except in compliance with the License.
  7 + You may obtain a copy of the License at
  8 +
  9 + http://www.apache.org/licenses/LICENSE-2.0
  10 +
  11 + Unless required by applicable law or agreed to in writing, software
  12 + distributed under the License is distributed on an "AS IS" BASIS,
  13 + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14 + See the License for the specific language governing permissions and
  15 + limitations under the License.
  16 +
  17 +-->
  18 +<md-list ng-cloak>
  19 + <md-list-item ng-repeat="entity in vm.entities" ng-click="vm.selectEntity(entity)">
  20 + <span>{{ entity.entityLabel || entity.name }}</span>
  21 + </md-list-item>
  22 +</md-list>
... ...
... ... @@ -29,7 +29,7 @@ export default class TbGoogleMap {
29 29 this.tooltips = [];
30 30 this.defaultMapType = gmDefaultMapType;
31 31 this.defaultCenterPosition = defaultCenterPosition;
32   - this.isMarketCluster = markerClusteringSetting.isMarketCluster;
  32 + this.isMarketCluster = markerClusteringSetting && markerClusteringSetting.isMarketCluster;
33 33
34 34 function clearGlobalId() {
35 35 if (gmGlobals.loadingGmId && gmGlobals.loadingGmId === tbMap.mapId) {
... ... @@ -234,17 +234,19 @@ export default class TbGoogleMap {
234 234 /* eslint-enable no-undef */
235 235
236 236 /* eslint-disable no-undef */
237   - createMarker(location, dsIndex, settings, onClickListener, markerArgs) {
  237 + createMarker(location, dsIndex, settings, onClickListener, markerArgs, onDragendListener) {
238 238 var marker;
239 239 if (settings.showLabel) {
240 240 marker = new MarkerWithLabel({
241 241 position: location,
242 242 labelContent: '<div style="color: '+ settings.labelColor +';"><b>'+settings.labelText+'</b></div>',
243   - labelClass: "tb-labels"
  243 + labelClass: "tb-labels",
  244 + draggable: settings.drraggable,
244 245 });
245 246 } else {
246 247 marker = new google.maps.Marker({
247 248 position: location,
  249 + draggable: settings.drraggable,
248 250 });
249 251 }
250 252 var gMap = this;
... ... @@ -268,6 +270,10 @@ export default class TbGoogleMap {
268 270 marker.addListener('click', onClickListener);
269 271 }
270 272
  273 + if (onDragendListener) {
  274 + marker.addListener('dragend', onDragendListener);
  275 + }
  276 +
271 277 return marker;
272 278 }
273 279
... ... @@ -476,4 +482,8 @@ export default class TbGoogleMap {
476 482 return this.tooltips;
477 483 }
478 484
  485 + getCenter() {
  486 + return this.map.getCenter().toJSON();
  487 + }
  488 +
479 489 }
... ...
... ... @@ -300,12 +300,14 @@ export default class TbImageMap {
300 300 onMarkerIconReady(iconInfo);
301 301 }
302 302
303   - createMarker(position, dsIndex, settings, onClickListener, markerArgs) {
  303 + createMarker(position, dsIndex, settings, onClickListener, markerArgs, onDragendListener) {
304 304 var pos = this.posFunction(position.x, position.y);
305 305 var x = pos.x * this.width;
306 306 var y = pos.y * this.height;
307 307 var location = this.pointToLatLng(x, y);
308   - var marker = L.marker(location, {});//.addTo(this.map);
  308 + var marker = L.marker(location, {
  309 + draggable: settings.drraggable
  310 + });//.addTo(this.map);
309 311 marker.position = position;
310 312 marker.offsetX = settings.markerOffsetX;
311 313 marker.offsetY = settings.markerOffsetY;
... ... @@ -327,10 +329,30 @@ export default class TbImageMap {
327 329 if (onClickListener) {
328 330 marker.on('click', onClickListener);
329 331 }
  332 + if (onDragendListener) {
  333 + marker.on('dragend', ($event) => {
  334 + let newMarkerPosition = this.latLngToPoint(marker.getLatLng());
  335 + marker.position.x = this.constructor.calculateNewPosition(newMarkerPosition.x, this.width);
  336 + marker.position.y = this.constructor.calculateNewPosition(newMarkerPosition.y, this.height);
  337 + this.setMarkerPosition(marker, marker.position);
  338 + onDragendListener($event);
  339 + });
  340 + }
330 341 this.markers.push(marker);
331 342 return marker;
332 343 }
333 344
  345 + static calculateNewPosition(positon, imageSize) {
  346 + let newPosition = positon / imageSize;
  347 + if (newPosition < 0) {
  348 + newPosition = 0;
  349 + } else if (newPosition > 1) {
  350 + newPosition = 1;
  351 + }
  352 + return newPosition;
  353 + }
  354 +
  355 +
334 356 updateMarkers() {
335 357 this.markers.forEach((marker) => {
336 358 this.updateMarkerLocation(marker);
... ... @@ -439,6 +461,10 @@ export default class TbImageMap {
439 461 return this.tooltips;
440 462 }
441 463
  464 + getCenter() {
  465 + return this.map.getCenter();
  466 + }
  467 +
442 468 }
443 469
444 470 class Position {
... ...
... ... @@ -21,10 +21,12 @@ import TbImageMap from './image-map';
21 21 import TbTencentMap from './tencent-map';
22 22
23 23 import {processPattern, arraysEqual, toLabelValueMap, fillPattern, fillPatternWithActions} from './widget-utils';
  24 +import addEntityPanelTemplate from './add-entity-panel.tpl.html';
  25 +import './add-entity-panel.scss';
24 26
25 27 export default class TbMapWidgetV2 {
26 28
27   - constructor(mapProvider, drawRoutes, ctx, useDynamicLocations, $element) {
  29 + constructor(mapProvider, drawRoutes, ctx, useDynamicLocations, $element, isEdit) {
28 30 var tbMap = this;
29 31 this.ctx = ctx;
30 32 this.mapProvider = mapProvider;
... ... @@ -33,6 +35,7 @@ export default class TbMapWidgetV2 {
33 35 }
34 36 this.utils = ctx.$scope.$injector.get('utils');
35 37 this.drawRoutes = drawRoutes;
  38 + this.isEdit = isEdit ? isEdit : false;
36 39 this.markers = [];
37 40 this.polygons = [];
38 41 if (this.drawRoutes) {
... ... @@ -292,6 +295,112 @@ export default class TbMapWidgetV2 {
292 295 }
293 296 }
294 297
  298 + selectEntity($event) {
  299 + var tbMap = this;
  300 +
  301 + function setDefaultPosition(entity) {
  302 + let position = tbMap.map.getCenter();
  303 + if (tbMap.mapProvider === "image-map") {
  304 + position = tbMap.map.latLngToPoint(position);
  305 + position.lat = position.x / tbMap.map.width;
  306 + position.lng = position.y / tbMap.map.height;
  307 + }
  308 +
  309 + tbMap.saveMarkerLocation(
  310 + entity,
  311 + locationsWithoutMarker[entitiesWithoutPosition.indexOf(entity)],
  312 + position
  313 + );
  314 + }
  315 +
  316 + const element = angular.element($event.target);
  317 + const $mdPanel = this.ctx.$scope.$injector.get('$mdPanel');
  318 + const $document = this.ctx.$scope.$injector.get('$document');
  319 + let position = $mdPanel.newPanelPosition()
  320 + .relativeTo(element)
  321 + .addPanelPosition($mdPanel.xPosition.ALIGN_END, $mdPanel.yPosition.BELOW);
  322 +
  323 + let locationsWithoutMarker = this.locations.filter((location) => !location.marker);
  324 + let entitiesWithoutPosition = [];
  325 + for (let i = 0; i < locationsWithoutMarker.length; i++) {
  326 + entitiesWithoutPosition.push(this.subscription.datasources[locationsWithoutMarker[i].dsIndex]);
  327 + }
  328 +
  329 + if(entitiesWithoutPosition.length === 1){
  330 + setDefaultPosition(entitiesWithoutPosition[0]);
  331 + } else {
  332 + let config = {
  333 + attachTo: angular.element($document[0].body),
  334 + controller: addEntityPanelController,
  335 + controllerAs: 'vm',
  336 + templateUrl: addEntityPanelTemplate,
  337 + panelClass: 'tb-add-entity-panel',
  338 + position: position,
  339 + fullscreen: false,
  340 + locals: {
  341 + 'entities': entitiesWithoutPosition,
  342 + 'onClose': setDefaultPosition
  343 + },
  344 + openFrom: $event,
  345 + clickOutsideToClose: true,
  346 + escapeToClose: true,
  347 + focusOnOpen: false
  348 + };
  349 + $mdPanel.open(config);
  350 + }
  351 + }
  352 +
  353 + saveMarkerLocation(datasource, location, coordinate) {
  354 + var tbMap = this;
  355 +
  356 + const types = tbMap.ctx.$scope.$injector.get('types');
  357 + const $q = tbMap.ctx.$scope.$injector.get('$q');
  358 + const attributeService = tbMap.ctx.$scope.$injector.get('attributeService');
  359 +
  360 + let attributesLocation = [];
  361 + let timeseriesLocation = [];
  362 + let promises = [];
  363 +
  364 + let dataKeys = datasource.dataKeys;
  365 + for (let i = 0; i < dataKeys.length; i++) {
  366 + if (dataKeys[i].name === location.settings.latKeyName || dataKeys[i].name === location.settings.lngKeyName) {
  367 + let newLocation = {
  368 + key: dataKeys[i].name,
  369 + value: dataKeys[i].name === location.settings.latKeyName ? coordinate.lat : coordinate.lng
  370 + };
  371 + if (dataKeys[i].type === types.dataKeyType.attribute) {
  372 + attributesLocation.push(newLocation);
  373 + } else if (dataKeys[i].type === types.dataKeyType.timeseries) {
  374 + timeseriesLocation.push(newLocation);
  375 + }
  376 + }
  377 + }
  378 +
  379 + if (attributesLocation.length > 0) {
  380 + promises.push(attributeService.saveEntityAttributes(
  381 + datasource.entityType,
  382 + datasource.entityId,
  383 + types.attributesScope.server.value,
  384 + attributesLocation,
  385 + {
  386 + ignoreLoading: true
  387 + }
  388 + ))
  389 + }
  390 + if (timeseriesLocation.length > 0) {
  391 + promises.push(attributeService.saveEntityTimeseries(
  392 + datasource.entityType,
  393 + datasource.entityId,
  394 + "scope",
  395 + timeseriesLocation,
  396 + {
  397 + ignoreLoading: true
  398 + }
  399 + ))
  400 + }
  401 + return $q.all([promises]);
  402 + }
  403 +
295 404 update() {
296 405 var tbMap = this;
297 406
... ... @@ -411,7 +520,10 @@ export default class TbMapWidgetV2 {
411 520 function (event) {
412 521 tbMap.callbacks.onLocationClick(location);
413 522 locationRowClick(event, location);
414   - }, [location.dsIndex]);
  523 + }, [location.dsIndex],
  524 + function (event) {
  525 + markerDragend(event, location)
  526 + });
415 527 tbMap.markers.push(location.marker);
416 528 changed = true;
417 529 } else {
... ... @@ -424,6 +536,22 @@ export default class TbMapWidgetV2 {
424 536 return changed;
425 537 }
426 538
  539 + function markerDragend($event, location) {
  540 + if (location.settings.drraggable) {
  541 + let position = tbMap.map.getMarkerPosition(location.marker);
  542 + if (tbMap.mapProvider === "image-map") {
  543 + position.lat = position.x;
  544 + position.lng = position.y;
  545 + delete position.x;
  546 + delete position.y;
  547 + } else if (tbMap.mapProvider === "google-map") {
  548 + position = position.toJSON();
  549 + }
  550 +
  551 + tbMap.saveMarkerLocation(tbMap.subscription.datasources[location.dsIndex], location, position);
  552 + }
  553 + }
  554 +
427 555 function locationRowClick($event, location) {
428 556 var descriptors = tbMap.ctx.actionsApi.getActionDescriptors('markerClick');
429 557 if (descriptors.length) {
... ... @@ -567,6 +695,7 @@ export default class TbMapWidgetV2 {
567 695 location.settings.tooltipPattern = tbMap.utils.createLabelFromDatasource(currentDatasource, location.settings.tooltipPattern);
568 696 location.settings.tooltipReplaceInfo = processPattern(location.settings.tooltipPattern, datasources, currentDatasourceIndex);
569 697 }
  698 + location.settings.drraggable = tbMap.isEdit;
570 699 tbMap.locations.push(location);
571 700 updateLocation(location, data, dataMap);
572 701 if (!tbMap.locationSettings.useDefaultCenterPosition) {
... ... @@ -1626,3 +1755,16 @@ const imageMapSettingsSchema =
1626 1755 }
1627 1756 ]
1628 1757 };
  1758 +
  1759 +/*@ngInject*/
  1760 +function addEntityPanelController(mdPanelRef, entities) {
  1761 + var vm = this;
  1762 + vm.entities = entities;
  1763 + vm.selectEntity = selectEntity;
  1764 +
  1765 + function selectEntity(entity) {
  1766 + mdPanelRef.close().then(() => {
  1767 + this.onClose(entity);
  1768 + });
  1769 + }
  1770 +}
... ...
... ... @@ -29,7 +29,7 @@ export default class TbOpenStreetMap {
29 29 this.dontFitMapBounds = dontFitMapBounds;
30 30 this.minZoomLevel = minZoomLevel;
31 31 this.tooltips = [];
32   - this.isMarketCluster = markerClusteringSetting.isMarketCluster;
  32 + this.isMarketCluster = markerClusteringSetting && markerClusteringSetting.isMarketCluster;
33 33
34 34 if (!mapProvider) {
35 35 mapProvider = {
... ... @@ -150,8 +150,10 @@ export default class TbOpenStreetMap {
150 150 onMarkerIconReady(iconInfo);
151 151 }
152 152
153   - createMarker(location, dsIndex, settings, onClickListener, markerArgs) {
154   - var marker = L.marker(location, {});
  153 + createMarker(location, dsIndex, settings, onClickListener, markerArgs, onDragendListener) {
  154 + var marker = L.marker(location, {
  155 + draggable: settings.drraggable
  156 + });
155 157 var opMap = this;
156 158 this.createMarkerIcon(marker, settings, (iconInfo) => {
157 159 marker.setIcon(iconInfo.icon);
... ... @@ -171,6 +173,10 @@ export default class TbOpenStreetMap {
171 173 marker.on('click', onClickListener);
172 174 }
173 175
  176 + if (onDragendListener) {
  177 + marker.on('dragend', onDragendListener);
  178 + }
  179 +
174 180 return marker;
175 181 }
176 182
... ... @@ -326,4 +332,8 @@ export default class TbOpenStreetMap {
326 332 return this.tooltips;
327 333 }
328 334
  335 + getCenter() {
  336 + return this.map.getCenter();
  337 + }
  338 +
329 339 }
... ...
... ... @@ -28,7 +28,7 @@ export default class TbTencentMap {
28 28 this.tooltips = [];
29 29 this.defaultMapType = tmDefaultMapType;
30 30 this.defaultCenterPosition =defaultCenterPosition;
31   - this.isMarketCluster = markerClusteringSetting.isMarketCluster;
  31 + this.isMarketCluster = markerClusteringSetting && markerClusteringSetting.isMarketCluster;
32 32
33 33 function clearGlobalId() {
34 34 if (tmGlobals.loadingTmId && tmGlobals.loadingTmId === tbMap.mapId) {
... ... @@ -239,7 +239,7 @@ export default class TbTencentMap {
239 239 /* eslint-enable no-undef */
240 240
241 241 /* eslint-disable no-undef */
242   - createMarker(location, dsIndex, settings, onClickListener, markerArgs) {
  242 + createMarker(location, dsIndex, settings, onClickListener, markerArgs, onDragendListener) {
243 243 var marker = new qq.maps.Marker({
244 244 position: location
245 245 });
... ... @@ -260,7 +260,8 @@ export default class TbTencentMap {
260 260 visible: true,
261 261 position: location,
262 262 map: tMap.map,
263   - zIndex: 1000
  263 + zIndex: 1000,
  264 + draggable: settings.drraggable
264 265 });
265 266 }
266 267 });
... ... @@ -273,6 +274,10 @@ export default class TbTencentMap {
273 274 qq.maps.event.addListener(marker, 'click', onClickListener);
274 275 }
275 276
  277 + if (onDragendListener) {
  278 + qq.maps.event.addListener(marker, 'dragend', onDragendListener);
  279 + }
  280 +
276 281 return marker;
277 282 }
278 283
... ... @@ -487,4 +492,8 @@ export default class TbTencentMap {
487 492 return this.tooltips;
488 493 }
489 494
  495 + getCenter() {
  496 + return this.map.getCenter();
  497 + }
  498 +
490 499 }
... ...