mirror of
https://github.com/the-djmaze/snappymail.git
synced 2025-01-09 00:08:18 +08:00
49 lines
1.2 KiB
React
49 lines
1.2 KiB
React
|
|
||
|
import {_} from 'common';
|
||
|
import ko from 'ko';
|
||
|
import {componentExportHelper} from 'Component/Abstract';
|
||
|
import {AbstracCheckbox} from 'Component/AbstracCheckbox';
|
||
|
|
||
|
class CheckboxMaterialDesignComponent extends AbstracCheckbox
|
||
|
{
|
||
|
/**
|
||
|
* @param {Object} params
|
||
|
*/
|
||
|
constructor(params) {
|
||
|
|
||
|
super(params);
|
||
|
|
||
|
this.animationBox = ko.observable(false).extend({'falseTimeout': 200});
|
||
|
this.animationCheckmark = ko.observable(false).extend({'falseTimeout': 200});
|
||
|
|
||
|
this.animationBoxSetTrue = _.bind(this.animationBoxSetTrue, this);
|
||
|
this.animationCheckmarkSetTrue = _.bind(this.animationCheckmarkSetTrue, this);
|
||
|
|
||
|
this.disposable.push(
|
||
|
this.value.subscribe((value) => {
|
||
|
this.triggerAnimation(value);
|
||
|
}, this)
|
||
|
);
|
||
|
}
|
||
|
|
||
|
animationBoxSetTrue() {
|
||
|
this.animationBox(true);
|
||
|
}
|
||
|
|
||
|
animationCheckmarkSetTrue() {
|
||
|
this.animationCheckmark(true);
|
||
|
}
|
||
|
|
||
|
triggerAnimation(box) {
|
||
|
if (box) {
|
||
|
this.animationBoxSetTrue();
|
||
|
_.delay(this.animationCheckmarkSetTrue, 200);
|
||
|
} else {
|
||
|
this.animationCheckmarkSetTrue();
|
||
|
_.delay(this.animationBoxSetTrue, 200);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
module.exports = componentExportHelper(CheckboxMaterialDesignComponent, 'CheckboxMaterialDesignComponent');
|