snappymail/dev/Component/AbstractInput.js

58 lines
1.4 KiB
JavaScript
Raw Normal View History

2015-11-15 08:23:16 +08:00
import ko from 'ko';
import { pInt } from 'Common/Utils';
import { SaveSettingStatus } from 'Common/Enums';
import { koComputable } from 'External/ko';
2022-02-17 06:12:12 +08:00
import { dispose } from 'External/ko';
2015-11-15 08:23:16 +08:00
2022-02-17 06:12:12 +08:00
export class AbstractInput {
2015-11-15 08:23:16 +08:00
/**
* @param {Object} params
*/
constructor(params) {
this.value = params.value || '';
this.label = params.label || '';
2021-09-14 22:11:50 +08:00
this.enable = null == params.enable ? true : params.enable;
2022-09-02 17:52:07 +08:00
this.trigger = params.trigger?.subscribe ? params.trigger : null;
2015-11-15 08:23:16 +08:00
this.placeholder = params.placeholder || '';
2021-09-14 22:11:50 +08:00
this.labeled = null != params.label;
2015-11-15 08:23:16 +08:00
let size = 0 < params.size ? 'span' + params.size : '';
2019-07-05 03:19:24 +08:00
if (this.trigger) {
2021-09-14 22:11:50 +08:00
const
classForTrigger = ko.observable(''),
setTriggerState = value => {
switch (pInt(value)) {
case SaveSettingStatus.Success:
2021-09-14 22:11:50 +08:00
classForTrigger('success');
break;
case SaveSettingStatus.Failed:
2021-09-14 22:11:50 +08:00
classForTrigger('error');
break;
default:
classForTrigger('');
break;
}
};
setTriggerState(this.trigger());
this.className = koComputable(() =>
(size + ' settings-saved-trigger-input ' + classForTrigger()).trim()
2021-09-14 22:11:50 +08:00
);
2022-02-17 16:36:29 +08:00
this.disposables = [
2022-02-17 06:12:12 +08:00
this.trigger.subscribe(setTriggerState, this),
this.className
];
2021-09-14 22:11:50 +08:00
} else {
this.className = size;
2022-02-17 16:36:29 +08:00
this.disposables = [];
2015-11-15 08:23:16 +08:00
}
2022-02-17 06:12:12 +08:00
}
2015-11-15 08:23:16 +08:00
2022-02-17 06:12:12 +08:00
dispose() {
2022-02-17 16:36:29 +08:00
this.disposables.forEach(dispose);
2015-11-15 08:23:16 +08:00
}
}