bump to Leaflet 1.94, replace draw with geoman, and add rotation (#249)
* Handle drawing double click better * bump to 1.9.4, add geoman and rotation remove Draw (use geoman instead)
This commit is contained in:
parent
ee40ae2a69
commit
c740dfa783
@ -1,5 +1,11 @@
|
|||||||
### Change Log for Node-RED Worldmap
|
### Change Log for Node-RED Worldmap
|
||||||
|
|
||||||
|
- v3.0.0 - Bump to Leaflet 1.9.4
|
||||||
|
Move to geoman for drawing shapes.
|
||||||
|
Allow command.rotation to set rotation of map.
|
||||||
|
Allow editing of multipoint geojson tracks.
|
||||||
|
|
||||||
|
- v2.43.1 - Tweak drawing layer double click
|
||||||
- v2.43.0 - Revert leaflet update as it broke Draw
|
- v2.43.0 - Revert leaflet update as it broke Draw
|
||||||
- v2.42.3 - More KML and GEOJson drag drop fixes
|
- v2.42.3 - More KML and GEOJson drag drop fixes
|
||||||
- v2.42.1 - Remove extraneous debug logging, fix KMZ icons
|
- v2.42.1 - Remove extraneous debug logging, fix KMZ icons
|
||||||
|
@ -13,6 +13,11 @@ Feel free to [![](https://img.shields.io/static/v1?label=Sponsor&message=%E2%9D%
|
|||||||
|
|
||||||
### Updates
|
### Updates
|
||||||
|
|
||||||
|
- v3.0.0 - Bump to Leaflet 1.9.4
|
||||||
|
Move to geoman for drawing shapes.
|
||||||
|
Allow command.rotation to set rotation of map.
|
||||||
|
Allow editing of multipoint geojson tracks.
|
||||||
|
- v2.43.1 - Tweak drawing layer double click
|
||||||
- v2.43.0 - Revert leaflet update as it broke Draw
|
- v2.43.0 - Revert leaflet update as it broke Draw
|
||||||
- v2.42.3 - More KML and GEOJson drag drop fixes
|
- v2.42.3 - More KML and GEOJson drag drop fixes
|
||||||
- v2.42.1 - Remove extraneous debug logging, fix KMZ icons
|
- v2.42.1 - Remove extraneous debug logging, fix KMZ icons
|
||||||
@ -413,6 +418,7 @@ Optional properties include
|
|||||||
|
|
||||||
- **lat** - move map to specified latitude.
|
- **lat** - move map to specified latitude.
|
||||||
- **lon** - move map to specified longitude.
|
- **lon** - move map to specified longitude.
|
||||||
|
- **rotation** - rotate the base map to the specified compass angle.
|
||||||
- **zoom** - move map to specified zoom level (1 - world, 13 to 20 max zoom depending on map).
|
- **zoom** - move map to specified zoom level (1 - world, 13 to 20 max zoom depending on map).
|
||||||
- **bounds** - if set to an array `[ [ lat(S), lon(W) ], [lat(N), lon(E)] ]` - sets the overall map bounds.
|
- **bounds** - if set to an array `[ [ lat(S), lon(W) ], [lat(N), lon(E)] ]` - sets the overall map bounds.
|
||||||
- **layer** - set map to specified base layer name - `{"command":{"layer":"Esri"}}`
|
- **layer** - set map to specified base layer name - `{"command":{"layer":"Esri"}}`
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "node-red-contrib-web-worldmap",
|
"name": "node-red-contrib-web-worldmap",
|
||||||
"version": "2.43.0",
|
"version": "3.0.0",
|
||||||
"description": "A Node-RED node to provide a web page of a world map for plotting things on.",
|
"description": "A Node-RED node to provide a web page of a world map for plotting things on.",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@turf/bezier-spline": "~6.5.0",
|
"@turf/bezier-spline": "~6.5.0",
|
||||||
@ -28,7 +28,7 @@
|
|||||||
"tak"
|
"tak"
|
||||||
],
|
],
|
||||||
"node-red": {
|
"node-red": {
|
||||||
"version": ">=1.0.0",
|
"version": ">=2.0.0",
|
||||||
"nodes": {
|
"nodes": {
|
||||||
"worldmap": "worldmap.js"
|
"worldmap": "worldmap.js"
|
||||||
}
|
}
|
||||||
@ -42,6 +42,6 @@
|
|||||||
"@HiroyasuNishiyama"
|
"@HiroyasuNishiyama"
|
||||||
],
|
],
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=10"
|
"node": ">=16"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -380,8 +380,8 @@ If <i>Web Path</i> is left empty, then by default <code>⌘⇧m</code> - <code>c
|
|||||||
showruler: {value:"false"},
|
showruler: {value:"false"},
|
||||||
allowFileDrop: {value:"false"},
|
allowFileDrop: {value:"false"},
|
||||||
path: {value:"/worldmap"},
|
path: {value:"/worldmap"},
|
||||||
overlist: {value:"DR,CO,RA,DN,HM"},
|
overlist: {value:"DR,CO,RA,DN"},
|
||||||
maplist: {value:"OSMG,OSMC,EsriC,EsriS,EsriT,EsriDG,UKOS"},
|
maplist: {value:"OSMG,OSMC,EsriC,EsriS,UKOS"},
|
||||||
mapname: {value:""},
|
mapname: {value:""},
|
||||||
mapurl: {value:""},
|
mapurl: {value:""},
|
||||||
mapopt: {value:"", validate:function(v) {try{ v.length===0 || JSON.parse(v); return true;} catch(e) {return false;}}},
|
mapopt: {value:"", validate:function(v) {try{ v.length===0 || JSON.parse(v); return true;} catch(e) {return false;}}},
|
||||||
|
@ -40,8 +40,8 @@ module.exports = function(RED) {
|
|||||||
node.mapurl = n.mapurl || "";
|
node.mapurl = n.mapurl || "";
|
||||||
node.mapopt = n.mapopt || "";
|
node.mapopt = n.mapopt || "";
|
||||||
node.mapwms = n.mapwms || false;
|
node.mapwms = n.mapwms || false;
|
||||||
if (n.maplist === undefined) { node.maplist = "OSMG,OSMC,EsriC,EsriS,EsriT,EsriDG,UKOS,SW"; }
|
if (n.maplist === undefined) { node.maplist = "OSMG,OSMC,EsriC,EsriS,UKOS"; }
|
||||||
if (n.overlist === undefined) { node.overlist = "DR,CO,RA,DN,HM"; }
|
if (n.overlist === undefined) { node.overlist = "DR,CO,RA,DN"; }
|
||||||
try { node.mapopt2 = JSON.parse(node.mapopt); }
|
try { node.mapopt2 = JSON.parse(node.mapopt); }
|
||||||
catch(e) { node.mapopt2 = null; }
|
catch(e) { node.mapopt2 = null; }
|
||||||
|
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
<!DOCTYPE HTML>
|
<!DOCTYPE HTML>
|
||||||
<!--
|
<!--
|
||||||
|
Copyright 2022, 2023 David Conway-Jones.
|
||||||
Copyright 2015, 2021 IBM Corp.
|
Copyright 2015, 2021 IBM Corp.
|
||||||
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
@ -31,7 +32,7 @@
|
|||||||
<link rel="stylesheet" type="text/css" href="leaflet/leaflet-vector-markers.css">
|
<link rel="stylesheet" type="text/css" href="leaflet/leaflet-vector-markers.css">
|
||||||
<link rel="stylesheet" type="text/css" href="leaflet/MarkerCluster.css">
|
<link rel="stylesheet" type="text/css" href="leaflet/MarkerCluster.css">
|
||||||
<link rel="stylesheet" type="text/css" href="leaflet/MarkerCluster.Default.css">
|
<link rel="stylesheet" type="text/css" href="leaflet/MarkerCluster.Default.css">
|
||||||
<link rel="stylesheet" type="text/css" href="leaflet/leaflet.draw.css">
|
<link rel="stylesheet" type="text/css" href="leaflet/leaflet-geoman.css">
|
||||||
<link rel="stylesheet" type="text/css" href="leaflet/leaflet-ruler.css">
|
<link rel="stylesheet" type="text/css" href="leaflet/leaflet-ruler.css">
|
||||||
<link rel="stylesheet" type="text/css" href="leaflet/easy-button.css">
|
<link rel="stylesheet" type="text/css" href="leaflet/easy-button.css">
|
||||||
<link rel="stylesheet" type="text/css" href="leaflet/leaflet.fullscreen.css">
|
<link rel="stylesheet" type="text/css" href="leaflet/leaflet.fullscreen.css">
|
||||||
@ -50,7 +51,7 @@
|
|||||||
<script src="leaflet/leaflet.markercluster.freezable.js"></script>
|
<script src="leaflet/leaflet.markercluster.freezable.js"></script>
|
||||||
<script src="leaflet/leaflet.active-layers.min.js"></script>
|
<script src="leaflet/leaflet.active-layers.min.js"></script>
|
||||||
<script src="leaflet/leaflet.select-layers.min.js"></script>
|
<script src="leaflet/leaflet.select-layers.min.js"></script>
|
||||||
<script src="leaflet/leaflet.draw.js"></script>
|
<script src="leaflet/leaflet-geoman.min.js"></script>
|
||||||
<script src="leaflet/leaflet-ruler.js"></script>
|
<script src="leaflet/leaflet-ruler.js"></script>
|
||||||
<script src="leaflet/easy-button.js"></script>
|
<script src="leaflet/easy-button.js"></script>
|
||||||
<script src="leaflet/Leaflet.fullscreen.min.js"></script>
|
<script src="leaflet/Leaflet.fullscreen.min.js"></script>
|
||||||
@ -70,6 +71,7 @@
|
|||||||
<script src="leaflet/leaflet-omnivore.min.js"></script>
|
<script src="leaflet/leaflet-omnivore.min.js"></script>
|
||||||
<script src="leaflet/togeojson.umd.js"></script>
|
<script src="leaflet/togeojson.umd.js"></script>
|
||||||
<script src="leaflet/leaflet-kmz.js"></script>
|
<script src="leaflet/leaflet-kmz.js"></script>
|
||||||
|
<script src="leaflet/leaflet-rotate.js"></script>
|
||||||
<script src="leaflet/leaflet.mousecoordinate.js"></script>
|
<script src="leaflet/leaflet.mousecoordinate.js"></script>
|
||||||
<script src="leaflet/leaflet.latlng-graticule.js"></script>
|
<script src="leaflet/leaflet.latlng-graticule.js"></script>
|
||||||
<script src="leaflet/VectorTileLayer.umd.min.js"></script>
|
<script src="leaflet/VectorTileLayer.umd.min.js"></script>
|
||||||
@ -79,7 +81,6 @@
|
|||||||
<script src="leaflet/L.TileLayer.PixelFilter.js"></script>
|
<script src="leaflet/L.TileLayer.PixelFilter.js"></script>
|
||||||
<script src="leaflet/jszip.min.js"></script>
|
<script src="leaflet/jszip.min.js"></script>
|
||||||
<script src="leaflet/dialog-polyfill.js"></script>
|
<script src="leaflet/dialog-polyfill.js"></script>
|
||||||
|
|
||||||
<script src="images/emoji.js"></script>
|
<script src="images/emoji.js"></script>
|
||||||
</head>
|
</head>
|
||||||
|
|
||||||
|
Binary file not shown.
Before Width: | Height: | Size: 2.5 KiB After Width: | Height: | Size: 2.4 KiB |
283
worldmap/leaflet/leaflet-geoman.css
Normal file
283
worldmap/leaflet/leaflet-geoman.css
Normal file
@ -0,0 +1,283 @@
|
|||||||
|
.marker-icon,
|
||||||
|
.marker-icon:focus {
|
||||||
|
background-color: #ffffff;
|
||||||
|
border: 1px solid #3388ff;
|
||||||
|
border-radius: 50%;
|
||||||
|
margin: -8px 0 0 -8px !important;
|
||||||
|
width: 14px !important;
|
||||||
|
height: 14px !important;
|
||||||
|
outline: 0;
|
||||||
|
transition: opacity ease 0.3s;
|
||||||
|
}
|
||||||
|
|
||||||
|
.marker-icon-middle,
|
||||||
|
.marker-icon-middle:focus {
|
||||||
|
opacity: 0.7;
|
||||||
|
margin: -6px 0 0 -6px !important;
|
||||||
|
width: 10px !important;
|
||||||
|
height: 10px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-pm-draggable {
|
||||||
|
cursor: move !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.cursor-marker {
|
||||||
|
cursor: crosshair;
|
||||||
|
pointer-events: none;
|
||||||
|
opacity: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.cursor-marker.visible {
|
||||||
|
opacity: 1 !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-pm-invalid {
|
||||||
|
stroke: red;
|
||||||
|
transition: fill ease 0s, stroke ease 0s;
|
||||||
|
}
|
||||||
|
|
||||||
|
.rect-style-marker,
|
||||||
|
.rect-start-marker {
|
||||||
|
opacity: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.rect-style-marker.visible,
|
||||||
|
.rect-start-marker.visible {
|
||||||
|
opacity: 1 !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.vertexmarker-disabled {
|
||||||
|
opacity: 0.7;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pm-text-marker {
|
||||||
|
width: 0;
|
||||||
|
height: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pm-textarea {
|
||||||
|
background-color: #fff;
|
||||||
|
color: #000;
|
||||||
|
resize: none;
|
||||||
|
border: none;
|
||||||
|
outline: 0;
|
||||||
|
cursor: pointer;
|
||||||
|
border-radius: 3px;
|
||||||
|
padding-left: 7px;
|
||||||
|
padding-bottom: 0;
|
||||||
|
padding-top: 4px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-pm-draggable .pm-textarea {
|
||||||
|
cursor: move;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pm-textarea:focus,
|
||||||
|
.pm-textarea:focus-within,
|
||||||
|
.pm-textarea:focus-visible,
|
||||||
|
.pm-textarea:active {
|
||||||
|
border: 2px solid #000;
|
||||||
|
outline: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pm-textarea.pm-disabled {
|
||||||
|
border: none;
|
||||||
|
user-select: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pm-textarea.pm-hasfocus {
|
||||||
|
cursor: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-pm-toolbar {
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-pm-toolbar .leaflet-buttons-control-button {
|
||||||
|
padding: 5px;
|
||||||
|
box-sizing: border-box;
|
||||||
|
position: relative;
|
||||||
|
z-index: 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-pm-toolbar
|
||||||
|
.leaflet-pm-actions-container
|
||||||
|
a.leaflet-pm-action:first-child:not(.pos-right),
|
||||||
|
.leaflet-pm-toolbar
|
||||||
|
.leaflet-pm-actions-container
|
||||||
|
a.leaflet-pm-action:last-child.pos-right {
|
||||||
|
border-radius: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-pm-toolbar .button-container a.leaflet-buttons-control-button {
|
||||||
|
border-radius: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-pm-toolbar
|
||||||
|
.button-container:last-child
|
||||||
|
a.leaflet-buttons-control-button {
|
||||||
|
border-radius: 0 0 2px 2px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-pm-toolbar
|
||||||
|
.button-container:first-child
|
||||||
|
a.leaflet-buttons-control-button {
|
||||||
|
border-radius: 2px 2px 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-pm-toolbar
|
||||||
|
.button-container:last-child
|
||||||
|
a.leaflet-buttons-control-button {
|
||||||
|
border-bottom: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-pm-toolbar .control-fa-icon {
|
||||||
|
font-size: 19px;
|
||||||
|
line-height: 24px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-pm-toolbar .control-icon {
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
box-sizing: border-box;
|
||||||
|
background-size: contain;
|
||||||
|
background-repeat: no-repeat;
|
||||||
|
background-position: center center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-pm-toolbar .leaflet-pm-icon-marker {
|
||||||
|
background-image: url();
|
||||||
|
}
|
||||||
|
.leaflet-pm-toolbar .leaflet-pm-icon-polygon {
|
||||||
|
background-image: url();
|
||||||
|
}
|
||||||
|
.leaflet-pm-toolbar .leaflet-pm-icon-polyline {
|
||||||
|
background-image: url();
|
||||||
|
}
|
||||||
|
.leaflet-pm-toolbar .leaflet-pm-icon-circle {
|
||||||
|
background-image: url();
|
||||||
|
}
|
||||||
|
.leaflet-pm-toolbar .leaflet-pm-icon-circle-marker {
|
||||||
|
background-image: url();
|
||||||
|
}
|
||||||
|
.leaflet-pm-toolbar .leaflet-pm-icon-rectangle {
|
||||||
|
background-image: url();
|
||||||
|
}
|
||||||
|
.leaflet-pm-toolbar .leaflet-pm-icon-delete {
|
||||||
|
background-image: url();
|
||||||
|
}
|
||||||
|
.leaflet-pm-toolbar .leaflet-pm-icon-edit {
|
||||||
|
background-image: url();
|
||||||
|
}
|
||||||
|
.leaflet-pm-toolbar .leaflet-pm-icon-drag {
|
||||||
|
background-image: url();
|
||||||
|
}
|
||||||
|
.leaflet-pm-toolbar .leaflet-pm-icon-cut {
|
||||||
|
background-image: url();
|
||||||
|
}
|
||||||
|
.leaflet-pm-toolbar .leaflet-pm-icon-snapping {
|
||||||
|
background-image: url();
|
||||||
|
}
|
||||||
|
.leaflet-pm-toolbar .leaflet-pm-icon-rotate {
|
||||||
|
background-image: url();
|
||||||
|
}
|
||||||
|
.leaflet-pm-toolbar .leaflet-pm-icon-text {
|
||||||
|
background-image: url();
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-buttons-control-button:hover,
|
||||||
|
.leaflet-buttons-control-button:focus {
|
||||||
|
cursor: pointer;
|
||||||
|
background-color: #f4f4f4;
|
||||||
|
}
|
||||||
|
.active > .leaflet-buttons-control-button {
|
||||||
|
box-shadow: inset 0 -1px 5px 2px rgba(81, 77, 77, 0.31);
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-buttons-control-text-hide {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.button-container {
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
|
||||||
|
.button-container .leaflet-pm-actions-container {
|
||||||
|
z-index: 2;
|
||||||
|
position: absolute;
|
||||||
|
top: 0;
|
||||||
|
left: 100%;
|
||||||
|
display: none;
|
||||||
|
white-space: nowrap;
|
||||||
|
direction: ltr;
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-right
|
||||||
|
.leaflet-pm-toolbar
|
||||||
|
.button-container
|
||||||
|
.leaflet-pm-actions-container {
|
||||||
|
right: 100%;
|
||||||
|
left: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.button-container.active .leaflet-pm-actions-container {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
|
||||||
|
.button-container
|
||||||
|
.leaflet-pm-actions-container:not(.pos-right)
|
||||||
|
a.leaflet-pm-action:last-child {
|
||||||
|
border-radius: 0 3px 3px 0;
|
||||||
|
border-right: 0;
|
||||||
|
}
|
||||||
|
.button-container
|
||||||
|
.leaflet-pm-actions-container.pos-right
|
||||||
|
a.leaflet-pm-action:first-child {
|
||||||
|
border-radius: 3px 0 0 3px;
|
||||||
|
}
|
||||||
|
.button-container
|
||||||
|
.leaflet-pm-actions-container.pos-right
|
||||||
|
a.leaflet-pm-action:last-child {
|
||||||
|
border-right: 0;
|
||||||
|
}
|
||||||
|
.button-container .leaflet-pm-actions-container .leaflet-pm-action {
|
||||||
|
padding: 0 10px;
|
||||||
|
background-color: #666;
|
||||||
|
color: #fff;
|
||||||
|
display: inline-block;
|
||||||
|
width: auto;
|
||||||
|
border-right: 1px solid #eee;
|
||||||
|
user-select: none;
|
||||||
|
border-bottom: none;
|
||||||
|
height: 29px;
|
||||||
|
line-height: 29px;
|
||||||
|
}
|
||||||
|
.leaflet-pm-toolbar
|
||||||
|
.button-container:first-child.pos-right.active
|
||||||
|
a.leaflet-buttons-control-button {
|
||||||
|
border-top-left-radius: 0;
|
||||||
|
}
|
||||||
|
.leaflet-pm-toolbar
|
||||||
|
.button-container:first-child.active:not(.pos-right)
|
||||||
|
a.leaflet-buttons-control-button {
|
||||||
|
border-top-right-radius: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.button-container .leaflet-pm-actions-container .leaflet-pm-action:hover,
|
||||||
|
.button-container .leaflet-pm-actions-container .leaflet-pm-action:focus {
|
||||||
|
cursor: pointer;
|
||||||
|
background-color: #777;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* That the active control is always over the other controls */
|
||||||
|
.leaflet-pm-toolbar.activeChild {
|
||||||
|
z-index: 801;
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-buttons-control-button.pm-disabled {
|
||||||
|
background-color: #f4f4f4;
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-buttons-control-button.pm-disabled > .control-icon {
|
||||||
|
filter: opacity(0.6);
|
||||||
|
}
|
1
worldmap/leaflet/leaflet-geoman.min.js
vendored
Normal file
1
worldmap/leaflet/leaflet-geoman.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
2
worldmap/leaflet/leaflet-rotate.js
Normal file
2
worldmap/leaflet/leaflet-rotate.js
Normal file
File diff suppressed because one or more lines are too long
@ -45,7 +45,10 @@
|
|||||||
}
|
}
|
||||||
/* .leaflet-container svg: reset svg max-width decleration shipped in Joomla! (joomla.org) 3.x */
|
/* .leaflet-container svg: reset svg max-width decleration shipped in Joomla! (joomla.org) 3.x */
|
||||||
/* .leaflet-container img: map is broken in FF if you have max-width: 100% on tiles */
|
/* .leaflet-container img: map is broken in FF if you have max-width: 100% on tiles */
|
||||||
.leaflet-container .leaflet-overlay-pane svg,
|
.leaflet-container .leaflet-overlay-pane svg {
|
||||||
|
max-width: none !important;
|
||||||
|
max-height: none !important;
|
||||||
|
}
|
||||||
.leaflet-container .leaflet-marker-pane img,
|
.leaflet-container .leaflet-marker-pane img,
|
||||||
.leaflet-container .leaflet-shadow-pane img,
|
.leaflet-container .leaflet-shadow-pane img,
|
||||||
.leaflet-container .leaflet-tile-pane img,
|
.leaflet-container .leaflet-tile-pane img,
|
||||||
@ -53,6 +56,13 @@
|
|||||||
.leaflet-container .leaflet-tile {
|
.leaflet-container .leaflet-tile {
|
||||||
max-width: none !important;
|
max-width: none !important;
|
||||||
max-height: none !important;
|
max-height: none !important;
|
||||||
|
width: auto;
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-container img.leaflet-tile {
|
||||||
|
/* See: https://bugs.chromium.org/p/chromium/issues/detail?id=600120 */
|
||||||
|
mix-blend-mode: plus-lighter;
|
||||||
}
|
}
|
||||||
|
|
||||||
.leaflet-container.leaflet-touch-zoom {
|
.leaflet-container.leaflet-touch-zoom {
|
||||||
@ -166,9 +176,6 @@
|
|||||||
|
|
||||||
/* zoom and fade animations */
|
/* zoom and fade animations */
|
||||||
|
|
||||||
.leaflet-fade-anim .leaflet-tile {
|
|
||||||
/* will-change: opacity; */
|
|
||||||
}
|
|
||||||
.leaflet-fade-anim .leaflet-popup {
|
.leaflet-fade-anim .leaflet-popup {
|
||||||
opacity: 0;
|
opacity: 0;
|
||||||
-webkit-transition: opacity 0.2s linear;
|
-webkit-transition: opacity 0.2s linear;
|
||||||
@ -183,9 +190,10 @@
|
|||||||
-ms-transform-origin: 0 0;
|
-ms-transform-origin: 0 0;
|
||||||
transform-origin: 0 0;
|
transform-origin: 0 0;
|
||||||
}
|
}
|
||||||
.leaflet-zoom-anim .leaflet-zoom-animated {
|
svg.leaflet-zoom-animated {
|
||||||
/* will-change: transform; */
|
will-change: transform;
|
||||||
}
|
}
|
||||||
|
|
||||||
.leaflet-zoom-anim .leaflet-zoom-animated {
|
.leaflet-zoom-anim .leaflet-zoom-animated {
|
||||||
-webkit-transition: -webkit-transform 0.25s cubic-bezier(0,0,0.25,1);
|
-webkit-transition: -webkit-transform 0.25s cubic-bezier(0,0,0.25,1);
|
||||||
-moz-transition: -moz-transform 0.25s cubic-bezier(0,0,0.25,1);
|
-moz-transition: -moz-transform 0.25s cubic-bezier(0,0,0.25,1);
|
||||||
@ -251,14 +259,11 @@ svg.leaflet-image-layer.leaflet-interactive path {
|
|||||||
|
|
||||||
.leaflet-container {
|
.leaflet-container {
|
||||||
background: #ddd;
|
background: #ddd;
|
||||||
outline: 0;
|
outline-offset: 1px;
|
||||||
}
|
}
|
||||||
.leaflet-container a {
|
.leaflet-container a {
|
||||||
color: #0078A8;
|
color: #0078A8;
|
||||||
}
|
}
|
||||||
.leaflet-container a.leaflet-active {
|
|
||||||
outline: 2px solid orange;
|
|
||||||
}
|
|
||||||
.leaflet-zoom-box {
|
.leaflet-zoom-box {
|
||||||
border: 2px dotted #38f;
|
border: 2px dotted #38f;
|
||||||
background: rgba(255,255,255,0.5);
|
background: rgba(255,255,255,0.5);
|
||||||
@ -267,7 +272,10 @@ svg.leaflet-image-layer.leaflet-interactive path {
|
|||||||
|
|
||||||
/* general typography */
|
/* general typography */
|
||||||
.leaflet-container {
|
.leaflet-container {
|
||||||
font: 12px/1.5 "Helvetica Neue", Arial, Helvetica, sans-serif;
|
font-family: "Helvetica Neue", Arial, Helvetica, sans-serif;
|
||||||
|
font-size: 12px;
|
||||||
|
font-size: 0.75rem;
|
||||||
|
line-height: 1.5;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -277,8 +285,7 @@ svg.leaflet-image-layer.leaflet-interactive path {
|
|||||||
box-shadow: 0 1px 5px rgba(0,0,0,0.65);
|
box-shadow: 0 1px 5px rgba(0,0,0,0.65);
|
||||||
border-radius: 4px;
|
border-radius: 4px;
|
||||||
}
|
}
|
||||||
.leaflet-bar a,
|
.leaflet-bar a {
|
||||||
.leaflet-bar a:hover {
|
|
||||||
background-color: #fff;
|
background-color: #fff;
|
||||||
border-bottom: 1px solid #ccc;
|
border-bottom: 1px solid #ccc;
|
||||||
width: 26px;
|
width: 26px;
|
||||||
@ -295,7 +302,8 @@ svg.leaflet-image-layer.leaflet-interactive path {
|
|||||||
background-repeat: no-repeat;
|
background-repeat: no-repeat;
|
||||||
display: block;
|
display: block;
|
||||||
}
|
}
|
||||||
.leaflet-bar a:hover {
|
.leaflet-bar a:hover,
|
||||||
|
.leaflet-bar a:focus {
|
||||||
background-color: #f4f4f4;
|
background-color: #f4f4f4;
|
||||||
}
|
}
|
||||||
.leaflet-bar a:first-child {
|
.leaflet-bar a:first-child {
|
||||||
@ -385,6 +393,8 @@ svg.leaflet-image-layer.leaflet-interactive path {
|
|||||||
}
|
}
|
||||||
.leaflet-control-layers label {
|
.leaflet-control-layers label {
|
||||||
display: block;
|
display: block;
|
||||||
|
font-size: 13px;
|
||||||
|
font-size: 1.08333em;
|
||||||
}
|
}
|
||||||
.leaflet-control-layers-separator {
|
.leaflet-control-layers-separator {
|
||||||
height: 0;
|
height: 0;
|
||||||
@ -393,7 +403,7 @@ svg.leaflet-image-layer.leaflet-interactive path {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Default icon URLs */
|
/* Default icon URLs */
|
||||||
.leaflet-default-icon-path {
|
.leaflet-default-icon-path { /* used only in path-guessing heuristic, see L.Icon.Default */
|
||||||
background-image: url(images/marker-icon.png);
|
background-image: url(images/marker-icon.png);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -402,23 +412,27 @@ svg.leaflet-image-layer.leaflet-interactive path {
|
|||||||
|
|
||||||
.leaflet-container .leaflet-control-attribution {
|
.leaflet-container .leaflet-control-attribution {
|
||||||
background: #fff;
|
background: #fff;
|
||||||
background: rgba(255, 255, 255, 0.7);
|
background: rgba(255, 255, 255, 0.8);
|
||||||
margin: 0;
|
margin: 0;
|
||||||
}
|
}
|
||||||
.leaflet-control-attribution,
|
.leaflet-control-attribution,
|
||||||
.leaflet-control-scale-line {
|
.leaflet-control-scale-line {
|
||||||
padding: 0 5px;
|
padding: 0 5px;
|
||||||
color: #333;
|
color: #333;
|
||||||
|
line-height: 1.4;
|
||||||
}
|
}
|
||||||
.leaflet-control-attribution a {
|
.leaflet-control-attribution a {
|
||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
}
|
}
|
||||||
.leaflet-control-attribution a:hover {
|
.leaflet-control-attribution a:hover,
|
||||||
|
.leaflet-control-attribution a:focus {
|
||||||
text-decoration: underline;
|
text-decoration: underline;
|
||||||
}
|
}
|
||||||
.leaflet-container .leaflet-control-attribution,
|
.leaflet-attribution-flag {
|
||||||
.leaflet-container .leaflet-control-scale {
|
display: inline !important;
|
||||||
font-size: 11px;
|
vertical-align: baseline !important;
|
||||||
|
width: 1em;
|
||||||
|
height: 0.6669em;
|
||||||
}
|
}
|
||||||
.leaflet-left .leaflet-control-scale {
|
.leaflet-left .leaflet-control-scale {
|
||||||
margin-left: 5px;
|
margin-left: 5px;
|
||||||
@ -431,14 +445,11 @@ svg.leaflet-image-layer.leaflet-interactive path {
|
|||||||
border-top: none;
|
border-top: none;
|
||||||
line-height: 1.1;
|
line-height: 1.1;
|
||||||
padding: 2px 5px 1px;
|
padding: 2px 5px 1px;
|
||||||
font-size: 11px;
|
|
||||||
white-space: nowrap;
|
white-space: nowrap;
|
||||||
overflow: hidden;
|
|
||||||
-moz-box-sizing: border-box;
|
-moz-box-sizing: border-box;
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
|
background: rgba(255, 255, 255, 0.8);
|
||||||
background: #fff;
|
text-shadow: 1px 1px #fff;
|
||||||
background: rgba(255, 255, 255, 0.5);
|
|
||||||
}
|
}
|
||||||
.leaflet-control-scale-line:not(:first-child) {
|
.leaflet-control-scale-line:not(:first-child) {
|
||||||
border-top: 2px solid #777;
|
border-top: 2px solid #777;
|
||||||
@ -474,17 +485,22 @@ svg.leaflet-image-layer.leaflet-interactive path {
|
|||||||
border-radius: 12px;
|
border-radius: 12px;
|
||||||
}
|
}
|
||||||
.leaflet-popup-content {
|
.leaflet-popup-content {
|
||||||
margin: 13px 19px;
|
margin: 13px 24px 13px 20px;
|
||||||
line-height: 1.4;
|
line-height: 1.3;
|
||||||
|
font-size: 13px;
|
||||||
|
font-size: 1.08333em;
|
||||||
|
min-height: 1px;
|
||||||
}
|
}
|
||||||
.leaflet-popup-content p {
|
.leaflet-popup-content p {
|
||||||
margin: 18px 0;
|
margin: 17px 0;
|
||||||
|
margin: 1.3em 0;
|
||||||
}
|
}
|
||||||
.leaflet-popup-tip-container {
|
.leaflet-popup-tip-container {
|
||||||
width: 40px;
|
width: 40px;
|
||||||
height: 20px;
|
height: 20px;
|
||||||
position: absolute;
|
position: absolute;
|
||||||
left: 50%;
|
left: 50%;
|
||||||
|
margin-top: -1px;
|
||||||
margin-left: -20px;
|
margin-left: -20px;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
pointer-events: none;
|
pointer-events: none;
|
||||||
@ -495,6 +511,7 @@ svg.leaflet-image-layer.leaflet-interactive path {
|
|||||||
padding: 1px;
|
padding: 1px;
|
||||||
|
|
||||||
margin: -10px auto 0;
|
margin: -10px auto 0;
|
||||||
|
pointer-events: auto;
|
||||||
|
|
||||||
-webkit-transform: rotate(45deg);
|
-webkit-transform: rotate(45deg);
|
||||||
-moz-transform: rotate(45deg);
|
-moz-transform: rotate(45deg);
|
||||||
@ -511,24 +528,21 @@ svg.leaflet-image-layer.leaflet-interactive path {
|
|||||||
position: absolute;
|
position: absolute;
|
||||||
top: 0;
|
top: 0;
|
||||||
right: 0;
|
right: 0;
|
||||||
padding: 4px 4px 0 0;
|
|
||||||
border: none;
|
border: none;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
width: 18px;
|
width: 24px;
|
||||||
height: 14px;
|
height: 24px;
|
||||||
font: 16px/14px Tahoma, Verdana, sans-serif;
|
font: 16px/24px Tahoma, Verdana, sans-serif;
|
||||||
color: #c3c3c3;
|
color: #757575;
|
||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
font-weight: bold;
|
|
||||||
background: transparent;
|
background: transparent;
|
||||||
}
|
}
|
||||||
.leaflet-container a.leaflet-popup-close-button:hover {
|
.leaflet-container a.leaflet-popup-close-button:hover,
|
||||||
color: #999;
|
.leaflet-container a.leaflet-popup-close-button:focus {
|
||||||
|
color: #585858;
|
||||||
}
|
}
|
||||||
.leaflet-popup-scrolled {
|
.leaflet-popup-scrolled {
|
||||||
overflow: auto;
|
overflow: auto;
|
||||||
border-bottom: 1px solid #ddd;
|
|
||||||
border-top: 1px solid #ddd;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.leaflet-oldie .leaflet-popup-content-wrapper {
|
.leaflet-oldie .leaflet-popup-content-wrapper {
|
||||||
@ -541,9 +555,6 @@ svg.leaflet-image-layer.leaflet-interactive path {
|
|||||||
-ms-filter: "progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";
|
-ms-filter: "progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";
|
||||||
filter: progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678);
|
filter: progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678);
|
||||||
}
|
}
|
||||||
.leaflet-oldie .leaflet-popup-tip-container {
|
|
||||||
margin-top: -1px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.leaflet-oldie .leaflet-control-zoom,
|
.leaflet-oldie .leaflet-control-zoom,
|
||||||
.leaflet-oldie .leaflet-control-layers,
|
.leaflet-oldie .leaflet-control-layers,
|
||||||
@ -560,13 +571,6 @@ svg.leaflet-image-layer.leaflet-interactive path {
|
|||||||
border: 1px solid #666;
|
border: 1px solid #666;
|
||||||
}
|
}
|
||||||
|
|
||||||
.leaflet-popup-content-wrapper {
|
|
||||||
border-radius: 6px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.leaflet-popup-content {
|
|
||||||
margin: 6px 8px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Tooltip */
|
/* Tooltip */
|
||||||
/* Base styles for the element that has a tooltip */
|
/* Base styles for the element that has a tooltip */
|
||||||
@ -585,7 +589,7 @@ svg.leaflet-image-layer.leaflet-interactive path {
|
|||||||
pointer-events: none;
|
pointer-events: none;
|
||||||
box-shadow: 0 1px 3px rgba(0,0,0,0.4);
|
box-shadow: 0 1px 3px rgba(0,0,0,0.4);
|
||||||
}
|
}
|
||||||
.leaflet-tooltip.leaflet-clickable {
|
.leaflet-tooltip.leaflet-interactive {
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
pointer-events: auto;
|
pointer-events: auto;
|
||||||
}
|
}
|
||||||
@ -645,3 +649,13 @@ svg.leaflet-image-layer.leaflet-interactive path {
|
|||||||
margin-left: -12px;
|
margin-left: -12px;
|
||||||
border-right-color: #fff;
|
border-right-color: #fff;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Printing */
|
||||||
|
|
||||||
|
@media print {
|
||||||
|
/* Prevent printers from removing background-images of controls. */
|
||||||
|
.leaflet-control {
|
||||||
|
-webkit-print-color-adjust: exact;
|
||||||
|
print-color-adjust: exact;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
10
worldmap/leaflet/leaflet.draw.css
vendored
10
worldmap/leaflet/leaflet.draw.css
vendored
@ -1,10 +0,0 @@
|
|||||||
.leaflet-draw-section{position:relative}.leaflet-draw-toolbar{margin-top:12px}.leaflet-draw-toolbar-top{margin-top:0}.leaflet-draw-toolbar-notop a:first-child{border-top-right-radius:0}.leaflet-draw-toolbar-nobottom a:last-child{border-bottom-right-radius:0}.leaflet-draw-toolbar a{background-image:url('images/spritesheet.png');background-image:linear-gradient(transparent,transparent),url('images/spritesheet.svg');background-repeat:no-repeat;background-size:300px 30px;background-clip:padding-box}.leaflet-retina .leaflet-draw-toolbar a{background-image:url('images/spritesheet-2x.png');background-image:linear-gradient(transparent,transparent),url('images/spritesheet.svg')}
|
|
||||||
.leaflet-draw a{display:block;text-align:center;text-decoration:none}.leaflet-draw a .sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.leaflet-draw-actions{display:none;list-style:none;margin:0;padding:0;position:absolute;left:26px;top:0;white-space:nowrap}.leaflet-touch .leaflet-draw-actions{left:32px}.leaflet-right .leaflet-draw-actions{right:26px;left:auto}.leaflet-touch .leaflet-right .leaflet-draw-actions{right:32px;left:auto}.leaflet-draw-actions li{display:inline-block}
|
|
||||||
.leaflet-draw-actions li:first-child a{border-left:0}.leaflet-draw-actions li:last-child a{-webkit-border-radius:0 4px 4px 0;border-radius:0 4px 4px 0}.leaflet-right .leaflet-draw-actions li:last-child a{-webkit-border-radius:0;border-radius:0}.leaflet-right .leaflet-draw-actions li:first-child a{-webkit-border-radius:4px 0 0 4px;border-radius:4px 0 0 4px}.leaflet-draw-actions a{background-color:#919187;border-left:1px solid #AAA;color:#FFF;font:11px/19px "Helvetica Neue",Arial,Helvetica,sans-serif;line-height:28px;text-decoration:none;padding-left:10px;padding-right:10px;height:28px}
|
|
||||||
.leaflet-touch .leaflet-draw-actions a{font-size:12px;line-height:30px;height:30px}.leaflet-draw-actions-bottom{margin-top:0}.leaflet-draw-actions-top{margin-top:1px}.leaflet-draw-actions-top a,.leaflet-draw-actions-bottom a{height:27px;line-height:27px}.leaflet-draw-actions a:hover{background-color:#a0a098}.leaflet-draw-actions-top.leaflet-draw-actions-bottom a{height:26px;line-height:26px}.leaflet-draw-toolbar .leaflet-draw-draw-polyline{background-position:-2px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-draw-polyline{background-position:0 -1px}
|
|
||||||
.leaflet-draw-toolbar .leaflet-draw-draw-polygon{background-position:-31px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-draw-polygon{background-position:-29px -1px}.leaflet-draw-toolbar .leaflet-draw-draw-rectangle{background-position:-62px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-draw-rectangle{background-position:-60px -1px}.leaflet-draw-toolbar .leaflet-draw-draw-circle{background-position:-92px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-draw-circle{background-position:-90px -1px}
|
|
||||||
.leaflet-draw-toolbar .leaflet-draw-draw-marker{background-position:-122px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-draw-marker{background-position:-120px -1px}.leaflet-draw-toolbar .leaflet-draw-draw-circlemarker{background-position:-273px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-draw-circlemarker{background-position:-271px -1px}.leaflet-draw-toolbar .leaflet-draw-edit-edit{background-position:-152px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-edit-edit{background-position:-150px -1px}
|
|
||||||
.leaflet-draw-toolbar .leaflet-draw-edit-remove{background-position:-182px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-edit-remove{background-position:-180px -1px}.leaflet-draw-toolbar .leaflet-draw-edit-edit.leaflet-disabled{background-position:-212px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-edit-edit.leaflet-disabled{background-position:-210px -1px}.leaflet-draw-toolbar .leaflet-draw-edit-remove.leaflet-disabled{background-position:-242px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-edit-remove.leaflet-disabled{background-position:-240px -2px}
|
|
||||||
.leaflet-mouse-marker{background-color:#fff;cursor:crosshair}.leaflet-draw-tooltip{background:#363636;background:rgba(0,0,0,0.5);border:1px solid transparent;-webkit-border-radius:4px;border-radius:4px;color:#fff;font:12px/18px "Helvetica Neue",Arial,Helvetica,sans-serif;margin-left:20px;margin-top:-21px;padding:4px 8px;position:absolute;visibility:hidden;white-space:nowrap;z-index:6}.leaflet-draw-tooltip:before{border-right:6px solid black;border-right-color:rgba(0,0,0,0.5);border-top:6px solid transparent;border-bottom:6px solid transparent;content:"";position:absolute;top:7px;left:-7px}
|
|
||||||
.leaflet-error-draw-tooltip{background-color:#f2dede;border:1px solid #e6b6bd;color:#b94a48}.leaflet-error-draw-tooltip:before{border-right-color:#e6b6bd}.leaflet-draw-tooltip-single{margin-top:-12px}.leaflet-draw-tooltip-subtext{color:#f8d5e4}.leaflet-draw-guide-dash{font-size:1%;opacity:.6;position:absolute;width:5px;height:5px}.leaflet-edit-marker-selected{background-color:rgba(254,87,161,0.1);border:4px dashed rgba(254,87,161,0.6);-webkit-border-radius:4px;border-radius:4px;box-sizing:content-box}
|
|
||||||
.leaflet-edit-move{cursor:move}.leaflet-edit-resize{cursor:pointer}.leaflet-oldie .leaflet-draw-toolbar{border:1px solid #999}
|
|
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
@ -28,7 +28,7 @@ var heat;
|
|||||||
var minimap;
|
var minimap;
|
||||||
var sidebyside;
|
var sidebyside;
|
||||||
var layercontrol;
|
var layercontrol;
|
||||||
var drawControl;
|
// var drawControl;
|
||||||
var drawingColour = "#910000";
|
var drawingColour = "#910000";
|
||||||
var sendDrawing;
|
var sendDrawing;
|
||||||
var colorControl;
|
var colorControl;
|
||||||
@ -54,6 +54,8 @@ var iconSz = {
|
|||||||
"Command": 44
|
"Command": 44
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// L.PM.setOptIn(true);
|
||||||
|
|
||||||
// Create the socket
|
// Create the socket
|
||||||
var connect = function() {
|
var connect = function() {
|
||||||
// var transports = ["websocket", "xhr-streaming", "xhr-polling"],
|
// var transports = ["websocket", "xhr-streaming", "xhr-polling"],
|
||||||
@ -79,7 +81,7 @@ var connect = function() {
|
|||||||
if (data.hasOwnProperty("type") && data.hasOwnProperty("data") && data.type === "Buffer") { data = data.data.toString(); }
|
if (data.hasOwnProperty("type") && data.hasOwnProperty("data") && data.type === "Buffer") { data = data.data.toString(); }
|
||||||
handleData(data);
|
handleData(data);
|
||||||
}
|
}
|
||||||
catch (e) { if (data) { console.log("BAD DATA",data); } }
|
catch (e) { if (data) { console.log("BAD DATA",data); console.log(e) } }
|
||||||
// console.log("DATA",typeof data,data);
|
// console.log("DATA",typeof data,data);
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
@ -189,7 +191,14 @@ if (inIframe === true) {
|
|||||||
// }
|
// }
|
||||||
|
|
||||||
// Create the Initial Map object.
|
// Create the Initial Map object.
|
||||||
map = new L.map('map',{zoomSnap: 0.1}).setView(startpos, startzoom);
|
map = new L.map('map',{
|
||||||
|
zoomSnap: 0.1,
|
||||||
|
rotate: true,
|
||||||
|
rotateControl: {
|
||||||
|
closeOnZeroBearing: true,
|
||||||
|
position: 'topleft'
|
||||||
|
},
|
||||||
|
bearing: 0}).setView(startpos, startzoom);
|
||||||
map.whenReady(function() {
|
map.whenReady(function() {
|
||||||
connect();
|
connect();
|
||||||
});
|
});
|
||||||
@ -301,6 +310,7 @@ function onLocationFound(e) {
|
|||||||
var self = {name:followMode.name || "self", lat:e.latlng.lat, lon:e.latlng.lng, hdg:e.heading, speed:(e.speed*3.6 ?? undefined), layer:followMode.layer, icon:followMode.icon, iconColor:followMode.iconColor ?? "#910000" };
|
var self = {name:followMode.name || "self", lat:e.latlng.lat, lon:e.latlng.lng, hdg:e.heading, speed:(e.speed*3.6 ?? undefined), layer:followMode.layer, icon:followMode.icon, iconColor:followMode.iconColor ?? "#910000" };
|
||||||
setMarker(self);
|
setMarker(self);
|
||||||
}
|
}
|
||||||
|
if (e.heading !== null) { map.setBearing(e.heading); }
|
||||||
if (followMode.accuracy) {
|
if (followMode.accuracy) {
|
||||||
errRing = L.circle(e.latlng, e.accuracy, {color:followMode.color ?? "#00ffff", weight:3, opacity:0.6, fill:false, clickable:false});
|
errRing = L.circle(e.latlng, e.accuracy, {color:followMode.color ?? "#00ffff", weight:3, opacity:0.6, fill:false, clickable:false});
|
||||||
errRing.addTo(map);
|
errRing.addTo(map);
|
||||||
@ -696,8 +706,8 @@ map.on('overlayadd', function(e) {
|
|||||||
}
|
}
|
||||||
if (e.name == "drawing") {
|
if (e.name == "drawing") {
|
||||||
overlays["drawing"].bringToFront();
|
overlays["drawing"].bringToFront();
|
||||||
|
map.pm.toggleControls();
|
||||||
map.addControl(colorControl);
|
map.addControl(colorControl);
|
||||||
map.addControl(drawControl);
|
|
||||||
}
|
}
|
||||||
ws.send(JSON.stringify({action:"addlayer", name:e.name}));
|
ws.send(JSON.stringify({action:"addlayer", name:e.name}));
|
||||||
});
|
});
|
||||||
@ -710,7 +720,7 @@ map.on('overlayremove', function(e) {
|
|||||||
layers["_daynight"].clearLayers();
|
layers["_daynight"].clearLayers();
|
||||||
}
|
}
|
||||||
if (e.name == "drawing") {
|
if (e.name == "drawing") {
|
||||||
map.removeControl(drawControl);
|
map.pm.toggleControls()
|
||||||
map.removeControl(colorControl);
|
map.removeControl(colorControl);
|
||||||
}
|
}
|
||||||
ws.send(JSON.stringify({action:"dellayer", name:e.name}));
|
ws.send(JSON.stringify({action:"dellayer", name:e.name}));
|
||||||
@ -793,7 +803,6 @@ const colorKeywordToRGB = (colorKeyword) => {
|
|||||||
document.body.appendChild(el);
|
document.body.appendChild(el);
|
||||||
let rgbValue = window.getComputedStyle(el).color;
|
let rgbValue = window.getComputedStyle(el).color;
|
||||||
document.body.removeChild(el);
|
document.body.removeChild(el);
|
||||||
console.log(rgbValue);
|
|
||||||
return rgba2hex(rgbValue);
|
return rgba2hex(rgbValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1077,46 +1086,37 @@ var addOverlays = function(overlist) {
|
|||||||
|
|
||||||
layers["_drawing"] = new L.FeatureGroup();
|
layers["_drawing"] = new L.FeatureGroup();
|
||||||
overlays["drawing"] = layers["_drawing"];
|
overlays["drawing"] = layers["_drawing"];
|
||||||
map.options.drawControlTooltips = false;
|
|
||||||
var drawCount = 0;
|
var drawCount = 0;
|
||||||
drawControl = new L.Control.Draw({
|
map.pm.addControls({
|
||||||
draw: {
|
position: 'topleft',
|
||||||
polyline: { shapeOptions: { clickable:true } },
|
drawMarker: false,
|
||||||
marker: false,
|
drawCircleMarker: false,
|
||||||
//circle: false,
|
drawText: false,
|
||||||
circle: { shapeOptions: { clickable:true } },
|
editControls: false
|
||||||
circlemarker: false,
|
|
||||||
rectangle: { shapeOptions: { clickable:true } },
|
|
||||||
polygon: { shapeOptions: { clickable:true } }
|
|
||||||
}
|
|
||||||
//edit: none
|
|
||||||
// {
|
|
||||||
// featureGroup: layers["_drawing"],
|
|
||||||
// remove: true,
|
|
||||||
// edit: true
|
|
||||||
// }
|
|
||||||
});
|
});
|
||||||
|
map.pm.toggleControls();
|
||||||
|
|
||||||
var changeDrawColour = function(col) {
|
var changeDrawColour = function(col) {
|
||||||
drawingColour = col;
|
drawingColour = col;
|
||||||
// console.log("COLOR",col)
|
map.pm.setPathOptions({
|
||||||
drawControl.setDrawingOptions({
|
color: drawingColour,
|
||||||
polyline: { shapeOptions: { color:drawingColour } },
|
fillColor: drawingColour,
|
||||||
circle: { shapeOptions: { color:drawingColour } },
|
fillOpacity: 0.4
|
||||||
rectangle: { shapeOptions: { color:drawingColour } },
|
|
||||||
polygon: { shapeOptions: { color:drawingColour } }
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
var shape;
|
var shape;
|
||||||
map.on('draw:created', function (e) {
|
map.on("pm:create", (e) => {
|
||||||
var name = e.layerType + drawCount;
|
var name = e.shape + drawCount;
|
||||||
drawCount = drawCount + 1;
|
drawCount = drawCount + 1;
|
||||||
|
|
||||||
e.layer.on('contextmenu', function(e) {
|
e.layer.on('contextmenu', function(e) {
|
||||||
L.DomEvent.stopPropagation(e);
|
L.DomEvent.stopPropagation(e);
|
||||||
var rmen = L.popup({offset:[0,-12]}).setLatLng(e.latlng);
|
var rmen = L.popup({offset:[0,-12]}).setLatLng(e.latlng);
|
||||||
rmen.setContent("<input type='text' autofocus value='"+e.target.name+"' id='dinput' placeholder='name (,icon, layer)'/><br/><button onclick='editPoly(\""+e.target.name+"\",true);'>Edit points</button><button onclick='delMarker(\""+e.target.name+"\",true);'>Delete</button><button onclick='sendDrawing();'>OK</button>");
|
rmen.setContent("<input type='text' value='"+e.target.name+"' id='dinput' placeholder='name (,icon, layer)'/><br/><button onclick='editPoly(\""+e.target.name+"\");'>Edit points</button><button onclick='editPoly(\""+e.target.name+"\",\"drag\");'>Drag</button><button onclick='editPoly(\""+e.target.name+"\",\"rot\");'>Rotate</button><button onclick='delMarker(\""+e.target.name+"\",true);'>Delete</button><button onclick='sendDrawing();'>OK</button>");
|
||||||
map.openPopup(rmen);
|
map.openPopup(rmen);
|
||||||
});
|
});
|
||||||
|
e.layer.bindPopup(name);
|
||||||
|
|
||||||
var la, lo, cent;
|
var la, lo, cent;
|
||||||
if (e.layer.hasOwnProperty("_latlng")) {
|
if (e.layer.hasOwnProperty("_latlng")) {
|
||||||
@ -1127,7 +1127,7 @@ var addOverlays = function(overlist) {
|
|||||||
else {
|
else {
|
||||||
cent = e.layer.getBounds().getCenter();
|
cent = e.layer.getBounds().getCenter();
|
||||||
}
|
}
|
||||||
var m = {action:"draw", name:name, type:e.layerType, layer:"_drawing", options:e.layer.options, radius:e.layer._mRadius, lat:la, lon:lo};
|
var m = {action:"draw", name:name, type:e.shape, layer:"_drawing", options:e.layer.options, radius:e.layer._mRadius, lat:la, lon:lo};
|
||||||
if (e.layer.hasOwnProperty("_latlngs")) {
|
if (e.layer.hasOwnProperty("_latlngs")) {
|
||||||
if (e.layer.options.fill === false) { m.line = e.layer._latlngs; }
|
if (e.layer.options.fill === false) { m.line = e.layer._latlngs; }
|
||||||
else { m.area = e.layer._latlngs[0]; }
|
else { m.area = e.layer._latlngs[0]; }
|
||||||
@ -1139,9 +1139,9 @@ var addOverlays = function(overlist) {
|
|||||||
polygons[name].name = name;
|
polygons[name].name = name;
|
||||||
layers["_drawing"].addLayer(shape.layer);
|
layers["_drawing"].addLayer(shape.layer);
|
||||||
|
|
||||||
var rightmenuMarker = L.popup({offset:[0,-12]}).setContent("<input type='text' autofocus value='"+name+"' id='dinput' placeholder='name (,icon, layer)'/><br/><button onclick='editPoly(\""+name+"\",true);'>Edit points</button><button onclick='delMarker(\""+name+"\",true);'>Delete</button><button onclick='sendDrawing(\""+name+"\");'>OK</button>");
|
var rightmenuMarker = L.popup({offset:[0,-12]}).setContent("<input type='text' autofocus value='"+name+"' id='dinput' placeholder='name (,icon, layer)'/><br/><button onclick='editPoly(\""+name+"\");'>Edit points</button><button onclick='editPoly(\""+name+"\",\"drag\");'>Drag</button><button onclick='editPoly(\""+name+"\",\"rot\");'>Rotate</button><button onclick='delMarker(\""+name+"\",true);'>Delete</button><button onclick='sendDrawing(\""+name+"\");'>OK</button>");
|
||||||
if (e.layer.options.fill === false && navigator.onLine) {
|
if (e.layer.options.fill === false && navigator.onLine) {
|
||||||
rightmenuMarker = L.popup({offset:[0,-12]}).setContent("<input type='text' autofocus value='"+name+"' id='dinput' placeholder='name (,icon, layer)'/><br/><button onclick='editPoly(\""+name+"\",true);'>Edit points</button><button onclick='delMarker(\""+name+"\",true);'>Delete</button><button onclick='sendRoute(\""+name+"\");'>Route</button><button onclick='sendDrawing(\""+name+"\");'>OK</button>");
|
rightmenuMarker = L.popup({offset:[0,-12]}).setContent("<input type='text' autofocus value='"+name+"' id='dinput' placeholder='name (,icon, layer)'/><br/><button onclick='editPoly(\""+name+"\");'>Edit points</button><button onclick='editPoly(\""+name+"\",\"drag\");'>Drag</button><button onclick='editPoly(\""+name+"\",\"rot\");'>Rotate</button><button onclick='delMarker(\""+name+"\",true);'>Delete</button><button onclick='sendRoute(\""+name+"\");'>Route</button><button onclick='sendDrawing(\""+name+"\");'>OK</button>");
|
||||||
}
|
}
|
||||||
rightmenuMarker.setLatLng(cent);
|
rightmenuMarker.setLatLng(cent);
|
||||||
setTimeout(function() {map.openPopup(rightmenuMarker)},25);
|
setTimeout(function() {map.openPopup(rightmenuMarker)},25);
|
||||||
@ -1151,6 +1151,7 @@ var addOverlays = function(overlist) {
|
|||||||
var thing = document.getElementById('dinput').value;
|
var thing = document.getElementById('dinput').value;
|
||||||
map.closePopup();
|
map.closePopup();
|
||||||
shape.m.name = thing;
|
shape.m.name = thing;
|
||||||
|
shape.layer.bindPopup(thing);
|
||||||
delMarker(n,true);
|
delMarker(n,true);
|
||||||
|
|
||||||
polygons[thing] = shape.layer;
|
polygons[thing] = shape.layer;
|
||||||
@ -1378,7 +1379,7 @@ helpText += '<p><i class="fa fa-globe fa-lg fa-fw"></i> <b>Heatmap all layers</b
|
|||||||
helpText += 'all layers whether hidden or not will contribute to the heatmap.';
|
helpText += 'all layers whether hidden or not will contribute to the heatmap.';
|
||||||
helpText += 'The default is that only visible layers add to the heatmap.</p>';
|
helpText += 'The default is that only visible layers add to the heatmap.</p>';
|
||||||
|
|
||||||
// Delete a marker (and notify websocket)
|
// Delete a marker or shape (and notify websocket)
|
||||||
var delMarker = function(dname,note) {
|
var delMarker = function(dname,note) {
|
||||||
if (note) { map.closePopup(); }
|
if (note) { map.closePopup(); }
|
||||||
if (typeof polygons[dname] != "undefined") {
|
if (typeof polygons[dname] != "undefined") {
|
||||||
@ -1402,16 +1403,15 @@ var delMarker = function(dname,note) {
|
|||||||
if (note) { ws.send(JSON.stringify({action:"delete", name:dname, deleted:true})); }
|
if (note) { ws.send(JSON.stringify({action:"delete", name:dname, deleted:true})); }
|
||||||
}
|
}
|
||||||
|
|
||||||
var editPoly = function(pname) {
|
var editPoly = function(pname,fun) {
|
||||||
map.closePopup();
|
map.closePopup();
|
||||||
editFeatureGroup = L.featureGroup();
|
if (fun === "rot") { polygons[pname].pm.enableRotate(); }
|
||||||
editToolbar = new L.EditToolbar({ featureGroup:editFeatureGroup });
|
else if (fun === "drag") { polygons[pname].pm.enableLayerDrag(); }
|
||||||
editHandler = editToolbar.getModeHandlers()[0].handler;
|
else { polygons[pname].pm.enable(); }
|
||||||
editHandler._map = map;
|
|
||||||
polygons[pname].on("dblclick", function(e) {
|
polygons[pname].on("dblclick", function(e) {
|
||||||
editHandler.disable();
|
if (fun === "rot") { polygons[pname].pm.disableRotate(); }
|
||||||
editFeatureGroup.removeLayer(polygons[pname]);
|
else if (fun === "drag") { polygons[pname].pm.disableLayerDrag(); }
|
||||||
polygons[pname].off("dblclick");
|
else { polygons[pname].pm.disable(); }
|
||||||
L.DomEvent.stopPropagation(e);
|
L.DomEvent.stopPropagation(e);
|
||||||
var la, lo;
|
var la, lo;
|
||||||
if (e.target.hasOwnProperty("_latlng")) {
|
if (e.target.hasOwnProperty("_latlng")) {
|
||||||
@ -1425,10 +1425,9 @@ var editPoly = function(pname) {
|
|||||||
}
|
}
|
||||||
ws.send(JSON.stringify(m));
|
ws.send(JSON.stringify(m));
|
||||||
})
|
})
|
||||||
editFeatureGroup.addLayer(polygons[pname]);
|
|
||||||
editHandler.enable();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
var rangerings = function(latlng, options) {
|
var rangerings = function(latlng, options) {
|
||||||
options = L.extend({
|
options = L.extend({
|
||||||
ranges: [250,500,750,1000],
|
ranges: [250,500,750,1000],
|
||||||
@ -1463,7 +1462,7 @@ function setMarker(data) {
|
|||||||
rightcontext = "<button id='delbutton' onclick='delMarker(\""+data.name+"\",true);'>Delete</button>";
|
rightcontext = "<button id='delbutton' onclick='delMarker(\""+data.name+"\",true);'>Delete</button>";
|
||||||
//}
|
//}
|
||||||
if (data.editable) {
|
if (data.editable) {
|
||||||
rightcontext = "<button onclick='editPoly(\""+data.name+"\",true);'>Edit</button><button onclick='delMarker(\""+data.name+"\",true);'>Delete</button>";
|
rightcontext = "<button onclick='editPoly(\""+data.name+"\");'>Edit</button><button onclick='delMarker(\""+data.name+"\",true);'>Delete</button>";
|
||||||
}
|
}
|
||||||
if ((data.contextmenu !== undefined) && (typeof data.contextmenu === "string")) {
|
if ((data.contextmenu !== undefined) && (typeof data.contextmenu === "string")) {
|
||||||
rightcontext = data.contextmenu.replace(/\$name/g,'"'+data.name+'"');
|
rightcontext = data.contextmenu.replace(/\$name/g,'"'+data.name+'"');
|
||||||
@ -2812,7 +2811,7 @@ function doCommand(cmd) {
|
|||||||
else { lockit = false; doLock(false); }
|
else { lockit = false; doLock(false); }
|
||||||
document.getElementById("lockit").checked = lockit;
|
document.getElementById("lockit").checked = lockit;
|
||||||
}
|
}
|
||||||
// move to a new position
|
// Move to a new position
|
||||||
var clat = map.getCenter().lat;
|
var clat = map.getCenter().lat;
|
||||||
var clon = map.getCenter().lng;
|
var clon = map.getCenter().lng;
|
||||||
var czoom = map.getZoom();
|
var czoom = map.getZoom();
|
||||||
@ -2821,6 +2820,9 @@ function doCommand(cmd) {
|
|||||||
if (cmd.hasOwnProperty("zoom")) { czoom = cmd.zoom; }
|
if (cmd.hasOwnProperty("zoom")) { czoom = cmd.zoom; }
|
||||||
map.setView([clat,clon],czoom);
|
map.setView([clat,clon],czoom);
|
||||||
|
|
||||||
|
// Set rotation of map
|
||||||
|
if (cmd.hasOwnProperty("rotation") && !isNaN(cmd.rotation)) { map.setBearing(-cmd.rotation); }
|
||||||
|
|
||||||
if (cmd.hasOwnProperty("cluster")) {
|
if (cmd.hasOwnProperty("cluster")) {
|
||||||
clusterAt = cmd.cluster;
|
clusterAt = cmd.cluster;
|
||||||
document.getElementById("setclus").value = cmd.cluster;
|
document.getElementById("setclus").value = cmd.cluster;
|
||||||
@ -2866,7 +2868,6 @@ function doCommand(cmd) {
|
|||||||
|
|
||||||
// handle any incoming GEOJSON directly - may style badly
|
// handle any incoming GEOJSON directly - may style badly
|
||||||
function doGeojson(n,g,l,o) {
|
function doGeojson(n,g,l,o) {
|
||||||
// console.log("GEOJSON",n,g,l,o) // name,geojson,layer,options
|
|
||||||
var lay = l ?? g.name ?? "unknown";
|
var lay = l ?? g.name ?? "unknown";
|
||||||
// if (!basemaps[lay]) {
|
// if (!basemaps[lay]) {
|
||||||
var opt = { style: function(feature) {
|
var opt = { style: function(feature) {
|
||||||
@ -2961,10 +2962,12 @@ function doGeojson(n,g,l,o) {
|
|||||||
delete tx["marker-color"];
|
delete tx["marker-color"];
|
||||||
delete tx["marker-size"];
|
delete tx["marker-size"];
|
||||||
delete tx["coordinateProperties"];
|
delete tx["coordinateProperties"];
|
||||||
delete tx["_gpxType"]
|
delete tx["_gpxType"];
|
||||||
|
var n = tx["name"];
|
||||||
|
delete tx["name"];
|
||||||
tx = JSON.stringify(tx,null,' ');
|
tx = JSON.stringify(tx,null,' ');
|
||||||
if ( tx !== "{}") {
|
if ( tx !== "{}") {
|
||||||
l.bindPopup('<pre style="overflow-x: scroll">'+tx.replace(/[\{\}"]/g,'')+'</pre>');
|
l.bindPopup('<b>'+n+'</b><pre style="overflow-x:scroll">'+tx.replace(/[\{\}"]/g,'')+'</pre>');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (o && o.hasOwnProperty("clickable") && o.clickable === true) {
|
if (o && o.hasOwnProperty("clickable") && o.clickable === true) {
|
||||||
@ -2972,6 +2975,16 @@ function doGeojson(n,g,l,o) {
|
|||||||
ws.send(JSON.stringify({action:"clickgeo",name:n,type:f.type,properties:f.properties,geometry:f.geometry}));
|
ws.send(JSON.stringify({action:"clickgeo",name:n,type:f.type,properties:f.properties,geometry:f.geometry}));
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
if (f.geometry.type === "MultiLineString") {
|
||||||
|
l.on('contextmenu', function(e) {
|
||||||
|
L.DomEvent.stopPropagation(e);
|
||||||
|
var rmen = L.popup({offset:[0,-12]}).setLatLng(e.latlng);
|
||||||
|
rmen.setContent("<b>"+n+"</b><br/><button onclick='editPoly(\""+n+"\");'>Edit points</button><button onclick='delMarker(\""+n+"\",true);'>Delete</button><button onclick='sendDrawing();'>OK</button>");
|
||||||
|
map.openPopup(rmen);
|
||||||
|
});
|
||||||
|
polygons[n] = l;
|
||||||
|
polygons[n].lay = lay;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
markers[n] = L.geoJson(g,opt);
|
markers[n] = L.geoJson(g,opt);
|
||||||
markers[n].lay = lay;
|
markers[n].lay = lay;
|
||||||
|
Loading…
Reference in New Issue
Block a user