-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbutton.js
64 lines (56 loc) · 2.21 KB
/
button.js
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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
function createEl (tagName, className, container) {
const el = window.document.createElement(tagName)
if (className) el.className = className
if (container) container.appendChild(el)
return el
}
function Toggle (contents, contentColors, mapDraw) {
if (!(this instanceof Toggle)) return new Toggle(el, contents)
this._map = null // mapbox-gl Map
this._mapContainer = null // HTMLElement
this._className = 'mapboxgl-ctrl' // string
this._contents = contents || []
this._contentColors = contentColors || []
this._mapDraw = mapDraw
this._contentIdx = 0
this._container = null // HTMLelement
this._toggleButton = null // HTMLElement
this.toggle = this.toggle.bind(this)
}
Toggle.prototype.onAdd = function (map) {
this._map = map
this._mapContainer = this._map.getContainer()
this._container = createEl('div', `${this._className} mapboxgl-ctrl-group`)
const button = this._toggleButton = createEl('button', (`${this._className}-icon ${this._className}-toggle`), this._container)
button.innerHTML = this._contents[this._contentIdx]
this.changeLineColor(this._contentColors[this._contentIdx])
button.type = 'button'
this._toggleButton.addEventListener('click', this.toggle)
return this._container
}
Toggle.prototype.onRemove = function () {
var node = this._container
if (node.parentNode) {
node.parentNode.removeChild(node);
}
this._map = null
}
Toggle.prototype.toggle = function () {
const button = this._toggleButton
let nextIdx = (this._contentIdx == this._contents.length - 1) ? 0 : this._contentIdx + 1
button.innerHTML = this._contents[nextIdx]
this._contentIdx = nextIdx
this.changeLineColor(this._contentColors[this._contentIdx])
}
Toggle.prototype.changeLineColor = function(color) {
var lineStyleFilter = function(value) {
return (value.id === 'gl-draw-line-active.cold') ?
true : false;
}
var styles = draw.options.styles;
var lineStyleIdx = styles.findIndex(lineStyleFilter)
console.log(lineStyleIdx)
console.log(styles[lineStyleIdx])
draw.options.styles[lineStyleIdx].paint['line-color'] = color;
}
module.exports = Toggle