@hxui/angular
Version:
An Angular library based on the [HXUI design system](https://hxui.io).
187 lines • 22.8 kB
JavaScript
import * as _ from 'lodash';
import { DisplayMode } from '../date-range-picker/date-range-picker.model';
import { FilterType } from './filters-type.enum';
export class FiltersModel {
constructor(data) {
this.selected = [];
this.defaultIndex = [0];
this.charLimit = 2;
this.dateRangePickerDisplayMode = DisplayMode.showCustomOnly;
this.dateRangePickerDisplayDateFormat = 'dd/MM/yyyy';
this.disabled = false;
this.hidden = false;
this.isLoading = false;
this.selectAllState = {
all: false,
indeterminate: false,
none: true
};
this.selectAllValue = 'Select all';
Object.assign(this, data);
if (this.type === FilterType.MultiSelect) {
this.addSelectAll();
this.setMultiSelectOptions();
}
else if (this.type !== FilterType.Search) {
this.setSingleSelectOption();
}
this.isIconised();
}
/*
* Adds a select all option for multiselect filter types
*/
addSelectAll() {
this.options.unshift({
label: 'Select all',
value: this.selectAllValue,
selected: false
});
}
/**
* Set single select option
*/
setSingleSelectOption(option) {
if (option) {
if (this.selected.length) {
this.selected[0].selected = false;
}
this.selected = [option];
option.selected = true;
}
else {
// set preselected option
if (this.options.length && this.selected.length === 0) {
this.selected = [
this.options.find(opt => {
return opt.selected;
})
];
}
}
}
/**
* Set multi select options
*/
setMultiSelectOptions(option) {
if (option) {
this.selected = [];
if (option.value !== this.selectAllValue) {
this.options.forEach((opt, i) => {
if (opt.value !== this.selectAllValue) {
if (opt.selected) {
this.selected.push(opt);
}
}
});
}
else {
this.options.forEach((opt, i) => {
if (opt.value !== this.selectAllValue) {
opt.selected = option.selected;
if (option.selected) {
this.selected.push(opt);
}
}
});
}
}
else {
// set preselected options and select all
if (this.options.length && this.selected.length === 0) {
this.options.forEach((opt, i) => {
if (opt.selected) {
this.selected.push(opt);
}
});
}
}
this.setSelectAllState();
}
setSelectAllState() {
const reducer = (accumulator, option) => option.selected && option.value !== this.selectAllValue
? accumulator + 1
: accumulator;
const count = this.options.reduce(reducer, 0);
this.selectAllState.all = count === this.options.length - 1;
this.selectAllState.indeterminate =
count > 0 && count < this.options.length - 1;
this.selectAllState.none = count === 0;
this.options[0].selected =
this.selectAllState.all && !this.selectAllState.indeterminate;
}
setDefaultOption() {
if (this.options.length) {
if (this.type === FilterType.SingleSelect) {
this.selected[0].selected = false;
this.selected[0] = this.options[this.defaultIndex[0]];
this.selected[0].selected = true;
}
else if (this.type === FilterType.MultiSelect) {
this.selected = [];
this.options.forEach((opt, i) => {
opt.selected = false;
});
this.defaultIndex.forEach((di, i) => {
this.options[di].selected = true;
this.selected.push(this.options[di]);
});
this.setSelectAllState();
}
else {
this.selected[0].selected = false;
this.selected[0] = this.options[this.defaultIndex[0]];
this.selected[0].selected = true;
}
}
}
setSelectAll() {
this.selected = [];
this.options.forEach((opt, i) => {
opt.selected = true;
if (opt.value !== this.selectAllValue) {
this.selected.push(opt);
}
});
}
isDefaultOptionActive() {
if (this.type === FilterType.SingleSelect) {
return this.selected[0] === this.options[this.defaultIndex[0]];
}
else if (this.type === FilterType.MultiSelect) {
const selectedIndexes = [];
this.options.forEach((opt, i) => {
if (opt.selected && opt.value !== this.selectAllValue) {
selectedIndexes.push(i);
}
});
return _.isEqual(selectedIndexes, this.defaultIndex);
}
else if (this.type === FilterType.Search) {
return this.value === '' || this.value === undefined;
}
else if (this.type === FilterType.DateRange) {
return this.value === '' || this.value === undefined;
}
}
isIconised() {
if (this.options) {
const hasIcons = this.options.find(option => {
return typeof option.icon !== 'undefined' && option.icon !== '';
});
return typeof hasIcons !== 'undefined';
}
return false;
}
getSelectedLabel() {
if (this.selected.length === 1) {
return this.selected[0].label;
}
else if (this.selected.length) {
return this.selected.length + ' selected';
}
else {
return 'All';
}
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filters.model.js","sourceRoot":"","sources":["../../../../../projects/hx-ui/src/lib/filters/filters.model.ts"],"names":[],"mappings":"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","sourcesContent":["import * as _ from 'lodash';\r\nimport { DisplayMode } from '../date-range-picker/date-range-picker.model';\r\nimport { IFilterOption, IFiltersConfig } from './filters-config.interface';\r\nimport { FilterType } from './filters-type.enum';\r\n\r\nexport class FiltersModel implements IFiltersConfig {\r\n  id: string;\r\n  type: FilterType;\r\n  label: string;\r\n  options?: IFilterOption[];\r\n  value?: string;\r\n  /**\r\n   * value from source component without type parse\r\n   */\r\n  sourceValue?: any;\r\n  callback: any;\r\n  selected: IFilterOption[] = [];\r\n  defaultIndex = [0];\r\n  charLimit = 2;\r\n  dateRangePickerDisplayMode?: DisplayMode = DisplayMode.showCustomOnly;\r\n  dateRangePickerDisplayDateFormat?: string = 'dd/MM/yyyy';\r\n  width: number;\r\n  disabled = false;\r\n  hidden = false;\r\n  isLoading = false;\r\n  selectAllState = {\r\n    all: false,\r\n    indeterminate: false,\r\n    none: true\r\n  };\r\n  selectAllValue = 'Select all';\r\n\r\n  constructor(data?: IFiltersConfig) {\r\n    Object.assign(this, data);\r\n    if (this.type === FilterType.MultiSelect) {\r\n      this.addSelectAll();\r\n      this.setMultiSelectOptions();\r\n    } else if (this.type !== FilterType.Search) {\r\n      this.setSingleSelectOption();\r\n    }\r\n    this.isIconised();\r\n  }\r\n\r\n  /*\r\n   * Adds a select all option for multiselect filter types\r\n   */\r\n  addSelectAll() {\r\n    this.options.unshift({\r\n      label: 'Select all',\r\n      value: this.selectAllValue,\r\n      selected: false\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Set single select option\r\n   */\r\n  setSingleSelectOption(option?: IFilterOption) {\r\n    if (option) {\r\n      if (this.selected.length) {\r\n        this.selected[0].selected = false;\r\n      }\r\n      this.selected = [option];\r\n      option.selected = true;\r\n    } else {\r\n      // set preselected option\r\n      if (this.options.length && this.selected.length === 0) {\r\n        this.selected = [\r\n          this.options.find(opt => {\r\n            return opt.selected;\r\n          })\r\n        ];\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Set multi select options\r\n   */\r\n  setMultiSelectOptions(option?: IFilterOption) {\r\n    if (option) {\r\n      this.selected = [];\r\n      if (option.value !== this.selectAllValue) {\r\n        this.options.forEach((opt, i) => {\r\n          if (opt.value !== this.selectAllValue) {\r\n            if (opt.selected) {\r\n              this.selected.push(opt);\r\n            }\r\n          }\r\n        });\r\n      } else {\r\n        this.options.forEach((opt, i) => {\r\n          if (opt.value !== this.selectAllValue) {\r\n            opt.selected = option.selected;\r\n            if (option.selected) {\r\n              this.selected.push(opt);\r\n            }\r\n          }\r\n        });\r\n      }\r\n    } else {\r\n      // set preselected options and select all\r\n      if (this.options.length && this.selected.length === 0) {\r\n        this.options.forEach((opt, i) => {\r\n          if (opt.selected) {\r\n            this.selected.push(opt);\r\n          }\r\n        });\r\n      }\r\n    }\r\n\r\n    this.setSelectAllState();\r\n  }\r\n\r\n  setSelectAllState() {\r\n    const reducer = (accumulator, option) =>\r\n      option.selected && option.value !== this.selectAllValue\r\n        ? accumulator + 1\r\n        : accumulator;\r\n    const count = this.options.reduce(reducer, 0);\r\n    this.selectAllState.all = count === this.options.length - 1;\r\n    this.selectAllState.indeterminate =\r\n      count > 0 && count < this.options.length - 1;\r\n    this.selectAllState.none = count === 0;\r\n    this.options[0].selected =\r\n      this.selectAllState.all && !this.selectAllState.indeterminate;\r\n  }\r\n\r\n  setDefaultOption() {\r\n    if (this.options.length) {\r\n      if (this.type === FilterType.SingleSelect) {\r\n        this.selected[0].selected = false;\r\n        this.selected[0] = this.options[this.defaultIndex[0]];\r\n        this.selected[0].selected = true;\r\n      } else if (this.type === FilterType.MultiSelect) {\r\n        this.selected = [];\r\n        this.options.forEach((opt, i) => {\r\n          opt.selected = false;\r\n        });\r\n        this.defaultIndex.forEach((di, i) => {\r\n          this.options[di].selected = true;\r\n          this.selected.push(this.options[di]);\r\n        });\r\n        this.setSelectAllState();\r\n      } else {\r\n        this.selected[0].selected = false;\r\n        this.selected[0] = this.options[this.defaultIndex[0]];\r\n        this.selected[0].selected = true;\r\n      }\r\n    }\r\n  }\r\n\r\n  setSelectAll() {\r\n    this.selected = [];\r\n    this.options.forEach((opt, i) => {\r\n      opt.selected = true;\r\n      if (opt.value !== this.selectAllValue) {\r\n        this.selected.push(opt);\r\n      }\r\n    });\r\n  }\r\n\r\n  isDefaultOptionActive() {\r\n    if (this.type === FilterType.SingleSelect) {\r\n      return this.selected[0] === this.options[this.defaultIndex[0]];\r\n    } else if (this.type === FilterType.MultiSelect) {\r\n      const selectedIndexes = [];\r\n      this.options.forEach((opt, i) => {\r\n        if (opt.selected && opt.value !== this.selectAllValue) {\r\n          selectedIndexes.push(i);\r\n        }\r\n      });\r\n      return _.isEqual(selectedIndexes, this.defaultIndex);\r\n    } else if (this.type === FilterType.Search) {\r\n      return this.value === '' || this.value === undefined;\r\n    } else if (this.type === FilterType.DateRange) {\r\n      return this.value === '' || this.value === undefined;\r\n    }\r\n  }\r\n\r\n  isIconised() {\r\n    if (this.options) {\r\n      const hasIcons = this.options.find(option => {\r\n        return typeof option.icon !== 'undefined' && option.icon !== '';\r\n      });\r\n      return typeof hasIcons !== 'undefined';\r\n    }\r\n    return false;\r\n  }\r\n\r\n  getSelectedLabel() {\r\n    if (this.selected.length === 1) {\r\n      return this.selected[0].label;\r\n    } else if (this.selected.length) {\r\n      return this.selected.length + ' selected';\r\n    } else {\r\n      return 'All';\r\n    }\r\n  }\r\n}\r\n"]}