/** * * @authors yutent (yutent.io@gmail.com) * @date 2020-12-08 11:30:52 * @version v1.0.0 * */ export default class Progress extends HTMLElement { static get observedAttributes() { return ["value","max"] } props = { value: 0, max: 1 } constructor() { super(); Object.defineProperty(this, 'root', { value: this.attachShadow({ mode: 'open' }), writable: true, enumerable: false, configurable: true }) this.root.innerHTML = ` ` this.__THUMB__ = this.root.children[1].lastElementChild } get value() { return this.props.value } set value(val) { this.props.value = +val this.calculate() } calculate() { var { max, value } = this.props this.__THUMB__.style.width = `${(100 * value) / max}%` } connectedCallback() { this.calculate() } attributeChangedCallback(name, old, val) { if (val === null || old === val) {return} switch (name) { case 'max': var max = +val if (max !== max || max < 1) { max = 1 } this.props.max = max this.calculate() break case 'value': var v = +val if (v === v) { this.props.value = v this.calculate() } break } } } if(!customElements.get('wc-progress')){ customElements.define('wc-progress', Progress) }