Spaces:
Running
Running
| (function (factory) { | |
| // Packaging/modules magic dance | |
| var L; | |
| if (typeof define === 'function' && define.amd) { | |
| // AMD | |
| define(['leaflet'], factory); | |
| } else if (typeof module !== 'undefined') { | |
| // Node/CommonJS | |
| L = require('leaflet'); | |
| module.exports = factory(L); | |
| } else { | |
| // Browser globals | |
| if (typeof window.L === 'undefined') | |
| throw 'Leaflet must be loaded first'; | |
| factory(window.L); | |
| } | |
| }(function (L) { | |
| 'use strict'; | |
| L.Control.Pan = L.Control.extend({ | |
| options: { | |
| position: 'topleft', | |
| panOffset: 500 | |
| }, | |
| onAdd: function (map) { | |
| var className = 'leaflet-control-pan', | |
| container = L.DomUtil.create('div', className), | |
| off = this.options.panOffset; | |
| this._panButton('Up' , className + '-up', | |
| container, map, new L.Point( 0 , -off)); | |
| this._panButton('Left' , className + '-left', | |
| container, map, new L.Point( -off , 0)); | |
| this._panButton('Right', className + '-right', | |
| container, map, new L.Point( off , 0)); | |
| this._panButton('Down' , className + '-down', | |
| container, map, new L.Point( 0 , off)); | |
| // Add pan control class to the control container | |
| if (this.options.position === 'topleft') { | |
| var controlContainer = L.DomUtil.get(map._controlCorners.topleft); | |
| } else if (this.options.position === 'topright') { | |
| var controlContainer = L.DomUtil.get(map._controlCorners.topright); | |
| } else if (this.options.position === 'bottomleft') { | |
| var controlContainer = L.DomUtil.get(map._controlCorners.bottomleft); | |
| } else { | |
| var controlContainer = L.DomUtil.get(map._controlCorners.bottomright); | |
| } | |
| if(!L.DomUtil.hasClass(controlContainer, 'has-leaflet-pan-control')) { | |
| L.DomUtil.addClass(controlContainer, 'has-leaflet-pan-control'); | |
| } | |
| return container; | |
| }, | |
| onRemove: function (map) { | |
| // Remove pan control class to the control container | |
| var controlContainer = L.DomUtil.get(map._controlCorners.topleft); | |
| if(L.DomUtil.hasClass(controlContainer, 'has-leaflet-pan-control')) { | |
| L.DomUtil.removeClass(controlContainer, 'has-leaflet-pan-control'); | |
| } | |
| }, | |
| _panButton: function (title, className, container, map, offset) { | |
| var wrapper = L.DomUtil.create('div', className + '-wrap', container); | |
| var link = L.DomUtil.create('a', className, wrapper); | |
| link.href = '#'; | |
| link.title = title; | |
| L.DomEvent | |
| .on(link, 'click', L.DomEvent.stopPropagation) | |
| .on(link, 'click', L.DomEvent.preventDefault) | |
| .on(link, 'click', function(){ map.panBy(offset); }, map) | |
| .on(link, 'dblclick', L.DomEvent.stopPropagation); | |
| return link; | |
| } | |
| }); | |
| L.Map.mergeOptions({ | |
| panControl: false | |
| }); | |
| L.Map.addInitHook(function () { | |
| if (this.options.panControl) { | |
| this.panControl = new L.Control.Pan(); | |
| this.addControl(this.panControl); | |
| } | |
| }); | |
| L.control.pan = function (options) { | |
| return new L.Control.Pan(options); | |
| }; | |
| return L.Control.Pan; | |
| })); | |