snappymail/dev/Component/AbstractCheckbox.js

44 lines
1.2 KiB
JavaScript
Raw Normal View History

2015-11-15 08:23:16 +08:00
import ko from 'ko';
2019-07-05 03:09:27 +08:00
import { AbstractComponent } from 'Component/Abstract';
2015-11-15 08:23:16 +08:00
2019-07-05 03:09:27 +08:00
class AbstractCheckbox extends AbstractComponent {
2015-11-15 08:23:16 +08:00
/**
2015-11-19 01:32:29 +08:00
* @param {Object} params = {}
2015-11-15 08:23:16 +08:00
*/
2015-11-19 01:32:29 +08:00
constructor(params = {}) {
2015-11-15 08:23:16 +08:00
super();
this.value = params.value;
if (undefined === this.value || !this.value.subscribe) {
this.value = ko.observable(undefined === this.value ? false : !!this.value);
2015-11-15 08:23:16 +08:00
}
this.enable = params.enable;
if (undefined === this.enable || !this.enable.subscribe) {
this.enable = ko.observable(undefined === this.enable ? true : !!this.enable);
2015-11-15 08:23:16 +08:00
}
this.disable = params.disable;
if (undefined === this.disable || !this.disable.subscribe) {
this.disable = ko.observable(undefined === this.disable ? false : !!this.disable);
2015-11-15 08:23:16 +08:00
}
this.label = params.label || '';
this.inline = undefined === params.inline ? false : params.inline;
2015-11-15 08:23:16 +08:00
this.readOnly = undefined === params.readOnly ? false : !!params.readOnly;
this.inverted = undefined === params.inverted ? false : !!params.inverted;
2015-11-15 08:23:16 +08:00
this.labeled = undefined !== params.label;
2015-11-15 08:23:16 +08:00
this.labelAnimated = !!params.labelAnimated;
}
click() {
2019-07-05 03:09:27 +08:00
if (!this.readOnly && this.enable() && !this.disable()) {
2015-11-15 08:23:16 +08:00
this.value(!this.value());
}
}
}
2019-07-05 03:09:27 +08:00
export { AbstractCheckbox, AbstractCheckbox as default };