2016-07-07 05:03:30 +08:00
|
|
|
import ko from 'ko';
|
|
|
|
|
2019-07-05 03:19:24 +08:00
|
|
|
import { FilterConditionField, FilterConditionType } from 'Common/Enums';
|
|
|
|
import { pString } from 'Common/Utils';
|
2016-07-07 05:03:30 +08:00
|
|
|
|
2019-07-05 03:19:24 +08:00
|
|
|
import { AbstractModel } from 'Knoin/AbstractModel';
|
2016-07-07 05:03:30 +08:00
|
|
|
|
2019-07-05 03:19:24 +08:00
|
|
|
class FilterConditionModel extends AbstractModel {
|
2016-07-16 05:29:42 +08:00
|
|
|
constructor() {
|
2020-10-19 01:19:45 +08:00
|
|
|
super();
|
2016-07-07 05:03:30 +08:00
|
|
|
|
|
|
|
this.field = ko.observable(FilterConditionField.From);
|
|
|
|
this.type = ko.observable(FilterConditionType.Contains);
|
|
|
|
this.value = ko.observable('');
|
|
|
|
this.value.error = ko.observable(false);
|
|
|
|
|
|
|
|
this.valueSecond = ko.observable('');
|
|
|
|
this.valueSecond.error = ko.observable(false);
|
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
this.template = ko.computed(() => {
|
|
|
|
let template = '';
|
2019-07-05 03:19:24 +08:00
|
|
|
switch (this.field()) {
|
2016-07-07 05:03:30 +08:00
|
|
|
case FilterConditionField.Size:
|
2016-08-17 06:01:20 +08:00
|
|
|
template = 'SettingsFiltersConditionSize';
|
2016-07-07 05:03:30 +08:00
|
|
|
break;
|
|
|
|
case FilterConditionField.Header:
|
2016-08-17 06:01:20 +08:00
|
|
|
template = 'SettingsFiltersConditionMore';
|
2016-07-07 05:03:30 +08:00
|
|
|
break;
|
|
|
|
default:
|
2016-08-17 06:01:20 +08:00
|
|
|
template = 'SettingsFiltersConditionDefault';
|
2016-07-07 05:03:30 +08:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
return template;
|
2016-07-07 05:03:30 +08:00
|
|
|
}, this);
|
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
this.field.subscribe(() => {
|
2016-07-07 05:03:30 +08:00
|
|
|
this.value('');
|
|
|
|
this.valueSecond('');
|
2016-08-17 06:01:20 +08:00
|
|
|
});
|
2016-07-07 05:03:30 +08:00
|
|
|
|
|
|
|
this.regDisposables([this.template]);
|
|
|
|
}
|
|
|
|
|
|
|
|
verify() {
|
2020-07-28 23:20:14 +08:00
|
|
|
if (!this.value()) {
|
2016-07-07 05:03:30 +08:00
|
|
|
this.value.error(true);
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2020-07-28 23:20:14 +08:00
|
|
|
if (FilterConditionField.Header === this.field() && !this.valueSecond()) {
|
2016-07-07 05:03:30 +08:00
|
|
|
this.valueSecond.error(true);
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
parse(json) {
|
2019-07-05 03:19:24 +08:00
|
|
|
if (json && json.Field && json.Type) {
|
2016-07-07 05:03:30 +08:00
|
|
|
this.field(pString(json.Field));
|
|
|
|
this.type(pString(json.Type));
|
|
|
|
this.value(pString(json.Value));
|
|
|
|
this.valueSecond(pString(json.ValueSecond));
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
toJson() {
|
|
|
|
return {
|
|
|
|
Field: this.field(),
|
|
|
|
Type: this.type(),
|
|
|
|
Value: this.value(),
|
|
|
|
ValueSecond: this.valueSecond()
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
cloneSelf() {
|
|
|
|
const filterCond = new FilterConditionModel();
|
|
|
|
|
|
|
|
filterCond.field(this.field());
|
|
|
|
filterCond.type(this.type());
|
|
|
|
filterCond.value(this.value());
|
|
|
|
filterCond.valueSecond(this.valueSecond());
|
|
|
|
|
|
|
|
return filterCond;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-07-05 03:19:24 +08:00
|
|
|
export { FilterConditionModel, FilterConditionModel as default };
|