-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinput-range.js
44 lines (41 loc) · 1.51 KB
/
input-range.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
import Component from './component';
import { createStyle } from './dom/dom';
export default function InputRange(options = {}) {
const {
cls = '',
minValue = 0,
maxValue = 100,
initialValue = (minValue + maxValue) / 2,
step = 1,
style: styleSettings = {},
unit = '',
label = ''
} = options;
const style = createStyle(styleSettings);
let inputEl;
return Component({
onInput() {
this.dispatch('change', { value: inputEl.value });
},
onRender() {
inputEl = document.getElementById(this.getId());
inputEl.addEventListener('input', this.onInput.bind(this));
inputEl.addEventListener('change', this.onInput.bind(this)); // ie11
},
setValue(value) {
inputEl = document.getElementById(this.getId());
if (inputEl !== null) {
inputEl.value = value;
}
},
render() {
return `
<div class="flex no-wrap text-smaller align-center">
<input id="${this.getId()}" type="range" min="${minValue}" max="${maxValue}" value="${initialValue}" step="${step}" class="${cls}" style="${style}" tabindex="-99" oninput="this.nextElementSibling.value = this.value" aria-labelledby="inputRange${this.getId()}">
<output class="padding-left-small text-align-center">${initialValue}</output><div> ${unit}</div>
</div>
<div class="text-smaller text-align-center padding-smallpadding-top-smallest width-full"><label id="inputRange${this.getId()}" for="${this.getId()}">${label}</label></div>
`;
}
});
}