@firestitch/filter 18.2.47 → 18.2.49

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (36) hide show
  1. package/app/helpers/create-filter-item.d.ts +1 -1
  2. package/app/interfaces/items/base.interface.d.ts +0 -1
  3. package/app/models/items/autocomplete-chips-item.d.ts +1 -2
  4. package/app/models/items/base-autocomplete-item.d.ts +1 -2
  5. package/app/models/items/base-date-item.d.ts +1 -2
  6. package/app/models/items/base-item.d.ts +2 -2
  7. package/app/models/items/checkbox-item.d.ts +1 -2
  8. package/app/models/items/chips-item.d.ts +1 -2
  9. package/app/models/items/keyword-item.d.ts +1 -2
  10. package/app/models/items/range-item.d.ts +2 -3
  11. package/app/models/items/select-item.d.ts +1 -2
  12. package/app/models/items/text-item.d.ts +1 -2
  13. package/app/models/items/week-item.d.ts +1 -2
  14. package/esm2022/app/components/saved-filter/saved-filter-manage/components/saved-filter-chips/saved-filter-chips.component.mjs +10 -4
  15. package/esm2022/app/helpers/create-filter-item.mjs +4 -4
  16. package/esm2022/app/interfaces/items/base.interface.mjs +1 -1
  17. package/esm2022/app/models/items/autocomplete-chips-item.mjs +4 -6
  18. package/esm2022/app/models/items/autocomplete-item.mjs +2 -2
  19. package/esm2022/app/models/items/base-autocomplete-item.mjs +3 -5
  20. package/esm2022/app/models/items/base-date-item.mjs +3 -5
  21. package/esm2022/app/models/items/base-item.mjs +5 -4
  22. package/esm2022/app/models/items/checkbox-item.mjs +3 -5
  23. package/esm2022/app/models/items/chips-item.mjs +4 -6
  24. package/esm2022/app/models/items/date-item.mjs +2 -2
  25. package/esm2022/app/models/items/date-range-item.mjs +2 -2
  26. package/esm2022/app/models/items/date-time-item.mjs +2 -2
  27. package/esm2022/app/models/items/date-time-range-item.mjs +2 -2
  28. package/esm2022/app/models/items/keyword-item.mjs +4 -6
  29. package/esm2022/app/models/items/range-item.mjs +5 -7
  30. package/esm2022/app/models/items/select-item.mjs +4 -6
  31. package/esm2022/app/models/items/text-item.mjs +4 -6
  32. package/esm2022/app/models/items/week-item.mjs +4 -6
  33. package/esm2022/app/services/filter-controller.service.mjs +3 -2
  34. package/fesm2022/firestitch-filter.mjs +50 -63
  35. package/fesm2022/firestitch-filter.mjs.map +1 -1
  36. package/package.json +1 -1
@@ -776,7 +776,6 @@ function itemTypeSelect(item, param) {
776
776
  }
777
777
 
778
778
  class BaseItem {
779
- _additionalConfig;
780
779
  _filter;
781
780
  name;
782
781
  label;
@@ -795,8 +794,7 @@ class BaseItem {
795
794
  _value$ = new BehaviorSubject({ value: undefined, emitChange: true });
796
795
  _values$ = new BehaviorSubject(null);
797
796
  _destroy$ = new Subject();
798
- constructor(itemConfig, _additionalConfig, _filter) {
799
- this._additionalConfig = _additionalConfig;
797
+ constructor(itemConfig, _filter) {
800
798
  this._filter = _filter;
801
799
  this._type = itemConfig.type;
802
800
  this._initConfig(itemConfig);
@@ -811,6 +809,9 @@ class BaseItem {
811
809
  return this._hidden$
812
810
  .pipe(map((hidden) => !hidden));
813
811
  }
812
+ get visible() {
813
+ return !this._hidden$.getValue();
814
+ }
814
815
  get hidden() {
815
816
  return this._hidden$.getValue();
816
817
  }
@@ -1086,29 +1087,27 @@ class BaseDateRangeItem extends BaseItem {
1086
1087
 
1087
1088
  class DateRangeItem extends BaseDateRangeItem {
1088
1089
  static create(config, filter) {
1089
- return new DateRangeItem(config, null, filter);
1090
+ return new DateRangeItem(config, filter);
1090
1091
  }
1091
1092
  }
1092
1093
 
1093
1094
  class DateTimeRangeItem extends BaseDateRangeItem {
1094
1095
  static create(config, filter) {
1095
- return new DateTimeRangeItem(config, null, filter);
1096
+ return new DateTimeRangeItem(config, filter);
1096
1097
  }
1097
1098
  }
1098
1099
 
1099
1100
  class RangeItem extends BaseItem {
1100
- _additionalConfig;
1101
1101
  _filter;
1102
- constructor(itemConfig, _additionalConfig, _filter) {
1103
- super(itemConfig, _additionalConfig, _filter);
1104
- this._additionalConfig = _additionalConfig;
1102
+ constructor(itemConfig, _filter) {
1103
+ super(itemConfig, _filter);
1105
1104
  this._filter = _filter;
1106
1105
  this.options = itemConfig.options;
1107
1106
  this.prefix = itemConfig.prefix;
1108
1107
  this.suffix = itemConfig.suffix;
1109
1108
  }
1110
- static create(config, additionalConfig, filter) {
1111
- return new RangeItem(config, additionalConfig, filter);
1109
+ static create(config, filter) {
1110
+ return new RangeItem(config, filter);
1112
1111
  }
1113
1112
  get query() {
1114
1113
  const value = this.value;
@@ -1178,16 +1177,14 @@ class RangeItem extends BaseItem {
1178
1177
  }
1179
1178
 
1180
1179
  class WeekItem extends BaseItem {
1181
- _additionalConfig;
1182
1180
  _filter;
1183
- constructor(itemConfig, _additionalConfig, _filter) {
1184
- super(itemConfig, _additionalConfig, _filter);
1185
- this._additionalConfig = _additionalConfig;
1181
+ constructor(itemConfig, _filter) {
1182
+ super(itemConfig, _filter);
1186
1183
  this._filter = _filter;
1187
1184
  this.seedDate = itemConfig.seedDate;
1188
1185
  }
1189
1186
  static create(config, filter) {
1190
- return new WeekItem(config, null, filter);
1187
+ return new WeekItem(config, filter);
1191
1188
  }
1192
1189
  setValue(value, emitChange = true) {
1193
1190
  if (value) {
@@ -1266,26 +1263,22 @@ function findItemWidthName(items, name) {
1266
1263
  }
1267
1264
 
1268
1265
  class BaseAutocompleteItem extends BaseItem {
1269
- _additionalConfig;
1270
1266
  _filter;
1271
1267
  search;
1272
1268
  get valuesFn() {
1273
1269
  return this._valuesFn;
1274
1270
  }
1275
- constructor(itemConfig, _additionalConfig, _filter) {
1276
- super(itemConfig, _additionalConfig, _filter);
1277
- this._additionalConfig = _additionalConfig;
1271
+ constructor(itemConfig, _filter) {
1272
+ super(itemConfig, _filter);
1278
1273
  this._filter = _filter;
1279
1274
  this.fetchOnFocus = itemConfig.fetchOnFocus ?? true;
1280
1275
  }
1281
1276
  }
1282
1277
 
1283
1278
  class AutocompleteChipsItem extends BaseAutocompleteItem {
1284
- _additionalConfig;
1285
1279
  _filter;
1286
- constructor(itemConfig, _additionalConfig, _filter) {
1287
- super(itemConfig, _additionalConfig, _filter);
1288
- this._additionalConfig = _additionalConfig;
1280
+ constructor(itemConfig, _filter) {
1281
+ super(itemConfig, _filter);
1289
1282
  this._filter = _filter;
1290
1283
  this.chipImage = itemConfig.chipImage ?? 'image';
1291
1284
  this.chipIcon = itemConfig.chipIcon;
@@ -1296,7 +1289,7 @@ class AutocompleteChipsItem extends BaseAutocompleteItem {
1296
1289
  this.panelActions = itemConfig.panelActions || [];
1297
1290
  }
1298
1291
  static create(config, filter) {
1299
- return new AutocompleteChipsItem(config, null, filter);
1292
+ return new AutocompleteChipsItem(config, filter);
1300
1293
  }
1301
1294
  get queryParam() {
1302
1295
  if (!this.hasValue) {
@@ -1352,7 +1345,7 @@ class AutocompleteChipsItem extends BaseAutocompleteItem {
1352
1345
 
1353
1346
  class AutocompleteItem extends BaseAutocompleteItem {
1354
1347
  static create(config, filter) {
1355
- return new AutocompleteItem(config, null, filter);
1348
+ return new AutocompleteItem(config, filter);
1356
1349
  }
1357
1350
  get value() {
1358
1351
  let value = clone(super.value);
@@ -1384,11 +1377,9 @@ class AutocompleteItem extends BaseAutocompleteItem {
1384
1377
  }
1385
1378
 
1386
1379
  class CheckboxItem extends BaseItem {
1387
- _additionalConfig;
1388
1380
  _filter;
1389
- constructor(itemConfig, _additionalConfig, _filter) {
1390
- super(itemConfig, _additionalConfig, _filter);
1391
- this._additionalConfig = _additionalConfig;
1381
+ constructor(itemConfig, _filter) {
1382
+ super(itemConfig, _filter);
1392
1383
  this._filter = _filter;
1393
1384
  this._checked = itemConfig.checked ? toString(itemConfig.checked) : 'true';
1394
1385
  this._unchecked = itemConfig.unchecked ? toString(itemConfig.unchecked) : undefined;
@@ -1436,16 +1427,14 @@ class CheckboxItem extends BaseItem {
1436
1427
  }
1437
1428
 
1438
1429
  class ChipsItem extends BaseItem {
1439
- _additionalConfig;
1440
1430
  _filter;
1441
- constructor(itemConfig, _additionalConfig, _filter) {
1442
- super(itemConfig, _additionalConfig, _filter);
1443
- this._additionalConfig = _additionalConfig;
1431
+ constructor(itemConfig, _filter) {
1432
+ super(itemConfig, _filter);
1444
1433
  this._filter = _filter;
1445
1434
  this.multiple = itemConfig.multiple ?? true;
1446
1435
  }
1447
1436
  static create(config, filter) {
1448
- return new ChipsItem(config, null, filter);
1437
+ return new ChipsItem(config, filter);
1449
1438
  }
1450
1439
  get hasValue() {
1451
1440
  return this.value.length > 0;
@@ -1494,13 +1483,11 @@ class ChipsItem extends BaseItem {
1494
1483
  }
1495
1484
 
1496
1485
  class BaseDateItem extends BaseItem {
1497
- _additionalConfig;
1498
1486
  _filter;
1499
1487
  maxYear;
1500
1488
  mode;
1501
- constructor(itemConfig, _additionalConfig, _filter) {
1502
- super(itemConfig, _additionalConfig, _filter);
1503
- this._additionalConfig = _additionalConfig;
1489
+ constructor(itemConfig, _filter) {
1490
+ super(itemConfig, _filter);
1504
1491
  this._filter = _filter;
1505
1492
  this.maxYear = itemConfig.maxYear;
1506
1493
  this.mode = itemConfig.mode || ItemDateMode.Calendar;
@@ -1517,7 +1504,7 @@ class BaseDateItem extends BaseItem {
1517
1504
 
1518
1505
  class DateItem extends BaseDateItem {
1519
1506
  static create(config, filter) {
1520
- return new DateItem(config, null, filter);
1507
+ return new DateItem(config, filter);
1521
1508
  }
1522
1509
  get queryParam() {
1523
1510
  if (!this.hasValue) {
@@ -1546,7 +1533,7 @@ class DateItem extends BaseDateItem {
1546
1533
 
1547
1534
  class DateTimeItem extends BaseDateItem {
1548
1535
  static create(config, filter) {
1549
- return new DateTimeItem(config, null, filter);
1536
+ return new DateTimeItem(config, filter);
1550
1537
  }
1551
1538
  get chips() {
1552
1539
  return [];
@@ -1554,17 +1541,15 @@ class DateTimeItem extends BaseDateItem {
1554
1541
  }
1555
1542
 
1556
1543
  class TextItem extends BaseItem {
1557
- _additionalConfig;
1558
1544
  _filter;
1559
- constructor(itemConfig, _additionalConfig, _filter) {
1560
- super(itemConfig, _additionalConfig, _filter);
1561
- this._additionalConfig = _additionalConfig;
1545
+ constructor(itemConfig, _filter) {
1546
+ super(itemConfig, _filter);
1562
1547
  this._filter = _filter;
1563
1548
  this.prefix = itemConfig.prefix;
1564
1549
  this.suffix = itemConfig.suffix;
1565
1550
  }
1566
1551
  static create(config, filter) {
1567
- return new TextItem(config, null, filter);
1552
+ return new TextItem(config, filter);
1568
1553
  }
1569
1554
  get hasValue() {
1570
1555
  return typeof this.value === 'string' && this.value.length > 0;
@@ -1593,16 +1578,14 @@ class TextItem extends BaseItem {
1593
1578
  }
1594
1579
 
1595
1580
  class KeywordItem extends TextItem {
1596
- _additionalConfig;
1597
1581
  _filter;
1598
- constructor(itemConfig, _additionalConfig, _filter) {
1599
- super(itemConfig, _additionalConfig, _filter);
1600
- this._additionalConfig = _additionalConfig;
1582
+ constructor(itemConfig, _filter) {
1583
+ super(itemConfig, _filter);
1601
1584
  this._filter = _filter;
1602
1585
  this.fullWidth = itemConfig.fullWidth;
1603
1586
  }
1604
1587
  static create(config, filter) {
1605
- return new KeywordItem(config, null, filter);
1588
+ return new KeywordItem(config, filter);
1606
1589
  }
1607
1590
  get hasValue() {
1608
1591
  return typeof this.value === 'string' && this.value.length > 0;
@@ -1631,11 +1614,9 @@ class KeywordItem extends TextItem {
1631
1614
  }
1632
1615
 
1633
1616
  class SelectItem extends BaseItem {
1634
- _additionalConfig;
1635
1617
  _filter;
1636
- constructor(itemConfig, _additionalConfig, _filter) {
1637
- super(itemConfig, _additionalConfig, _filter);
1638
- this._additionalConfig = _additionalConfig;
1618
+ constructor(itemConfig, _filter) {
1619
+ super(itemConfig, _filter);
1639
1620
  this._filter = _filter;
1640
1621
  this.multiple = itemConfig.multiple || false;
1641
1622
  this.children = itemConfig.children || null;
@@ -1647,7 +1628,7 @@ class SelectItem extends BaseItem {
1647
1628
  }
1648
1629
  }
1649
1630
  static create(itemConfig, filter) {
1650
- return new SelectItem(itemConfig, {}, filter);
1631
+ return new SelectItem(itemConfig, filter);
1651
1632
  }
1652
1633
  clear(emitChange = true) {
1653
1634
  this.setValue(this.multiple ? [] : undefined, emitChange);
@@ -1735,7 +1716,7 @@ class SelectItem extends BaseItem {
1735
1716
  }
1736
1717
  }
1737
1718
 
1738
- function createFilterItem(item, config, filter) {
1719
+ function createFilterItem(item, filter) {
1739
1720
  switch (item.type) {
1740
1721
  case ItemType.Select: {
1741
1722
  return SelectItem.create(item, filter);
@@ -1744,7 +1725,7 @@ function createFilterItem(item, config, filter) {
1744
1725
  return ChipsItem.create(item, filter);
1745
1726
  }
1746
1727
  case ItemType.Range: {
1747
- return RangeItem.create(item, config, filter);
1728
+ return RangeItem.create(item, filter);
1748
1729
  }
1749
1730
  case ItemType.DateRange: {
1750
1731
  return DateRangeItem.create(item, filter);
@@ -1768,7 +1749,7 @@ function createFilterItem(item, config, filter) {
1768
1749
  return AutocompleteChipsItem.create(item, filter);
1769
1750
  }
1770
1751
  case ItemType.Checkbox: {
1771
- return new CheckboxItem(item, null, filter);
1752
+ return new CheckboxItem(item, filter);
1772
1753
  }
1773
1754
  case ItemType.Keyword: {
1774
1755
  return KeywordItem.create(item, filter);
@@ -2116,6 +2097,7 @@ class FilterController {
2116
2097
  get query() {
2117
2098
  return {
2118
2099
  ...this.items
2100
+ .filter((item) => item.visible)
2119
2101
  .reduce((accum, item) => {
2120
2102
  return {
2121
2103
  ...accum,
@@ -2196,7 +2178,7 @@ class FilterController {
2196
2178
  return true;
2197
2179
  })
2198
2180
  .map((item) => {
2199
- const filterItem = createFilterItem(item, {}, this.filter);
2181
+ const filterItem = createFilterItem(item, this.filter);
2200
2182
  if (filterItem instanceof KeywordItem) {
2201
2183
  this._keywordController.keywordItem = filterItem;
2202
2184
  }
@@ -2990,9 +2972,14 @@ class FsFilterSavedFilterChipsComponent {
2990
2972
  this.items = [...this._filterController.items]
2991
2973
  .filter((item) => !!this.savedFilter.filters[item.name])
2992
2974
  .map((item) => {
2993
- const object = item.clone();
2994
- object.setValue(this.savedFilter.filters[item.name], false);
2995
- return object;
2975
+ const config = {
2976
+ ...this._filterController.config.items
2977
+ .find((configItem) => item.name === configItem.name),
2978
+ };
2979
+ const filterItem = createFilterItem(config, this._filterController.filter);
2980
+ filterItem.values = item.values;
2981
+ filterItem.initValue(this.savedFilter.filters[item.name]);
2982
+ return filterItem;
2996
2983
  });
2997
2984
  }
2998
2985
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FsFilterSavedFilterChipsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });