2015-11-15 08:23:16 +08:00
|
|
|
import ko from 'ko';
|
2020-08-07 00:24:46 +08:00
|
|
|
import { pInt } from 'Common/Utils';
|
2022-09-26 20:02:30 +08:00
|
|
|
import { SaveSettingStatus } from 'Common/Enums';
|
2021-12-31 20:30:05 +08:00
|
|
|
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
|
|
|
|
2021-12-31 20:30:05 +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)) {
|
2022-09-26 20:02:30 +08:00
|
|
|
case SaveSettingStatus.Success:
|
2021-09-14 22:11:50 +08:00
|
|
|
classForTrigger('success');
|
|
|
|
break;
|
2022-09-26 20:02:30 +08:00
|
|
|
case SaveSettingStatus.Failed:
|
2021-09-14 22:11:50 +08:00
|
|
|
classForTrigger('error');
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
classForTrigger('');
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
setTriggerState(this.trigger());
|
|
|
|
|
2021-12-31 20:30:05 +08:00
|
|
|
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 {
|
2021-12-31 20:30:05 +08:00
|
|
|
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
|
|
|
}
|
|
|
|
}
|