aboutsummaryrefslogtreecommitdiffstats
path: root/extlib/leaflet/src/map/ext/Map.Control.js
blob: 46711a828d816fc8b045e915bf445efd58682caa (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
L.Map.include({
	addControl: function(control) {
		control.onAdd(this);

		var pos = control.getPosition(),
			corner = this._controlCorners[pos],
			container = control.getContainer();
		
		L.DomUtil.addClass(container, 'leaflet-control');
		
		if (pos.indexOf('bottom') != -1) {
			corner.insertBefore(container, corner.firstChild);
		} else {
			corner.appendChild(container);
		}
		return this;
	},
	
	removeControl: function(control) {
		var pos = control.getPosition(),
			corner = this._controlCorners[pos],
			container = control.getContainer();
		
		corner.removeChild(container);
		
		if (control.onRemove) {
			control.onRemove(this);
		}
		return this;
	},
	
	_initControlPos: function() {
		var corners = this._controlCorners = {},
			classPart = 'leaflet-',
			top = classPart + 'top',
			bottom = classPart + 'bottom',
			left = classPart + 'left',
			right = classPart + 'right',
			controlContainer = L.DomUtil.create('div', classPart + 'control-container', this._container);
		
		if (L.Browser.mobileWebkit) {
			controlContainer.className += ' ' + classPart + 'big-buttons';
		}
		
		corners.topLeft = L.DomUtil.create('div', top + ' ' + left, controlContainer);
		corners.topRight = L.DomUtil.create('div', top + ' ' + right, controlContainer);
		corners.bottomLeft = L.DomUtil.create('div', bottom + ' ' + left, controlContainer);
		corners.bottomRight = L.DomUtil.create('div', bottom + ' ' + right, controlContainer);
	}
});