@firestitch/filter 18.2.13 → 18.2.14

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 (22) hide show
  1. package/app/components/filter/filter.component.d.ts +2 -5
  2. package/app/components/filter-chips/filter-chips.component.d.ts +1 -0
  3. package/app/components/saved-filter/saved-filter-manage/saved-filter-manage.component.d.ts +1 -1
  4. package/app/fs-filter.module.d.ts +8 -10
  5. package/app/helpers/create-filter-item.d.ts +1 -1
  6. package/app/models/items/base-item.d.ts +5 -2
  7. package/app/services/focus-controller.service.d.ts +0 -1
  8. package/esm2022/app/components/filter/filter.component.mjs +5 -14
  9. package/esm2022/app/components/filter-chips/filter-chips.component.mjs +7 -7
  10. package/esm2022/app/components/saved-filter/saved-filter-manage/components/saved-filter-chips/saved-filter-chips.component.mjs +9 -7
  11. package/esm2022/app/components/saved-filter/saved-filter-manage/saved-filter-manage.component.mjs +3 -3
  12. package/esm2022/app/fs-filter.module.mjs +1 -8
  13. package/esm2022/app/models/items/base-item.mjs +21 -12
  14. package/esm2022/app/services/filter-controller.service.mjs +2 -2
  15. package/esm2022/app/services/focus-controller.service.mjs +2 -3
  16. package/fesm2022/firestitch-filter.mjs +64 -209
  17. package/fesm2022/firestitch-filter.mjs.map +1 -1
  18. package/package.json +1 -1
  19. package/app/components/filter-chip/filter-chip.component.d.ts +0 -37
  20. package/app/components/filter-chip-content/filter-chip-content.component.d.ts +0 -18
  21. package/esm2022/app/components/filter-chip/filter-chip.component.mjs +0 -84
  22. package/esm2022/app/components/filter-chip-content/filter-chip-content.component.mjs +0 -71
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@firestitch/filter",
3
- "version": "18.2.13",
3
+ "version": "18.2.14",
4
4
  "repository": {
5
5
  "type": "git",
6
6
  "url": "https://github.com/Firestitch/ngx-filter"
@@ -1,37 +0,0 @@
1
- import { OnDestroy, OnInit } from '@angular/core';
2
- import { Observable } from 'rxjs';
3
- import { IFilterConfigItem } from '../../interfaces/config.interface';
4
- import { BaseItem } from '../../models/items/base-item';
5
- import * as i0 from "@angular/core";
6
- export declare class FsFilterChipComponent implements OnInit, OnDestroy {
7
- item: BaseItem<IFilterConfigItem>;
8
- removable: boolean;
9
- chips: {
10
- name?: string;
11
- value: string;
12
- label: string;
13
- }[];
14
- clickable: boolean;
15
- rangeItem: boolean;
16
- chipDelayedRender$: Observable<boolean>;
17
- private _chipRenderTimer$;
18
- private _destroy$;
19
- private _cdRef;
20
- private _focusController;
21
- ngOnInit(): void;
22
- ngOnDestroy(): void;
23
- click(chip: {
24
- name?: string;
25
- value: string;
26
- label: string;
27
- }): void;
28
- remove(chip: {
29
- name?: string;
30
- value: string;
31
- label: string;
32
- }): void;
33
- listenValueChangesForRanges(): void;
34
- private _initDelayRender;
35
- static ɵfac: i0.ɵɵFactoryDeclaration<FsFilterChipComponent, never>;
36
- static ɵcmp: i0.ɵɵComponentDeclaration<FsFilterChipComponent, "fs-filter-chip", never, { "item": { "alias": "item"; "required": false; }; "removable": { "alias": "removable"; "required": false; }; "chips": { "alias": "chips"; "required": false; }; "clickable": { "alias": "clickable"; "required": false; }; }, {}, never, never, true, never>;
37
- }
@@ -1,18 +0,0 @@
1
- import { ChangeDetectorRef, OnDestroy, OnInit } from '@angular/core';
2
- import { IFilterConfigItem } from '../../interfaces/config.interface';
3
- import { BaseItem } from '../../models/items/base-item';
4
- import * as i0 from "@angular/core";
5
- export declare class FsFilterChipContentComponent implements OnInit, OnDestroy {
6
- private _cdRef;
7
- item: BaseItem<IFilterConfigItem>;
8
- type: 'from' | 'to';
9
- content: any;
10
- private _destroy$;
11
- constructor(_cdRef: ChangeDetectorRef);
12
- ngOnInit(): void;
13
- ngOnDestroy(): void;
14
- listenValueChangesForRanges(): void;
15
- private _getContent;
16
- static ɵfac: i0.ɵɵFactoryDeclaration<FsFilterChipContentComponent, never>;
17
- static ɵcmp: i0.ɵɵComponentDeclaration<FsFilterChipContentComponent, "fs-filter-chip-content", never, { "item": { "alias": "item"; "required": false; }; "type": { "alias": "type"; "required": false; }; }, {}, never, never, true, never>;
18
- }
@@ -1,84 +0,0 @@
1
- import { AsyncPipe, NgTemplateOutlet } from '@angular/common';
2
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, HostBinding, inject, Input, } from '@angular/core';
3
- import { FsChipModule } from '@firestitch/chip';
4
- import { combineLatest, Subject, timer } from 'rxjs';
5
- import { map, mapTo, startWith } from 'rxjs/operators';
6
- import { BaseItem } from '../../models/items/base-item';
7
- import { FocusControllerService } from '../../services/focus-controller.service';
8
- import { FsFilterChipContentComponent } from '../filter-chip-content/filter-chip-content.component';
9
- import * as i0 from "@angular/core";
10
- import * as i1 from "@firestitch/chip";
11
- export class FsFilterChipComponent {
12
- item;
13
- removable = false;
14
- chips;
15
- clickable = false;
16
- rangeItem;
17
- chipDelayedRender$;
18
- _chipRenderTimer$ = timer(500)
19
- .pipe(mapTo(true));
20
- _destroy$ = new Subject();
21
- _cdRef = inject(ChangeDetectorRef);
22
- _focusController = inject(FocusControllerService);
23
- ngOnInit() {
24
- // this.rangeItem = this.item.isTypeDateRange
25
- // || this.item.isTypeRange
26
- // || this.item.isTypeDateTimeRange;
27
- // this.listenValueChangesForRanges();
28
- // this._initDelayRender();
29
- // }
30
- }
31
- ngOnDestroy() {
32
- this._destroy$.next(null);
33
- this._destroy$.complete();
34
- }
35
- click(chip) {
36
- if (this.clickable) {
37
- this._focusController.click(this.item, chip.name);
38
- }
39
- }
40
- remove(chip) {
41
- this.item.clear(chip.name);
42
- }
43
- listenValueChangesForRanges() {
44
- // this.item.valueChange$
45
- // .pipe(
46
- // takeUntil(this._destroy$),
47
- // )
48
- // .subscribe(() => {
49
- // this._cdRef.markForCheck();
50
- // });
51
- }
52
- _initDelayRender() {
53
- this.chipDelayedRender$ = combineLatest([
54
- this.item.values$,
55
- this._chipRenderTimer$.pipe(startWith(false)),
56
- ])
57
- .pipe(map(([values, timerValue]) => {
58
- return !!values || timerValue;
59
- }));
60
- }
61
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FsFilterChipComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
62
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: FsFilterChipComponent, isStandalone: true, selector: "fs-filter-chip", inputs: { item: "item", removable: "removable", chips: "chips", clickable: "clickable" }, host: { properties: { "class.clickable": "this.clickable" } }, ngImport: i0, template: "@for (chip of chips; track chip) {\n <fs-chip\n [selectable]=\"false\"\n [removable]=\"item.showClear && removable\"\n size=\"small\"\n (click)=\"click(chip)\"\n (removed)=\"remove(chip)\">\n {{ chip.label }}: {{ chip.value }}\n </fs-chip>\n}\n<!-- {{ item.name }}\n@if ((chipDelayedRender$ | async)) {\n @if (rangeItem) {\n @if (item.value?.min || item.value?.from) {\n <fs-chip\n [value]=\"item\"\n [selectable]=\"false\"\n [removable]=\"item.showClear\"\n size=\"small\"\n [removable]=\"removable\"\n (click)=\"click('from')\"\n (removed)=\"removeItem($event, 'from')\">\n <ng-template\n [ngTemplateOutlet]=\"chipContent\"\n [ngTemplateOutletContext]=\"{ item: item, type: 'from' }\">\n </ng-template>\n </fs-chip>\n }\n @if (item.value?.max || item.value?.to) {\n <fs-chip\n [value]=\"item\"\n [selectable]=\"false\"\n [removable]=\"item.showClear && removable\"\n size=\"small\"\n (click)=\"click('to')\"\n (removed)=\"removeItem($event, 'to')\">\n <ng-template\n [ngTemplateOutlet]=\"chipContent\"\n [ngTemplateOutletContext]=\"{ item: item, type: 'to' }\">\n </ng-template>\n </fs-chip>\n }\n } @else {\n <fs-chip\n [value]=\"item\"\n [selectable]=\"false\"\n [removable]=\"item.showClear && removable\"\n size=\"small\"\n (click)=\"click()\"\n (removed)=\"removeItem($event)\">\n <ng-template\n [ngTemplateOutlet]=\"chipContent\"\n [ngTemplateOutletContext]=\"{ item: item }\">\n </ng-template>\n </fs-chip>\n }\n <ng-template\n #chipContent\n let-item=\"item\"\n let-type=\"type\">\n @if (!item.hasPendingValues && !item.loading) {\n <fs-filter-chip-content\n [item]=\"item\"\n [type]=\"type\">\n </fs-filter-chip-content>\n } @else {\n Loading...\n }\n </ng-template>\n} -->", styles: [":host{display:flex;flex-wrap:wrap;gap:5px;max-width:100%}:host.clickable fs-chip{cursor:pointer}\n"], dependencies: [{ kind: "ngmodule", type: FsChipModule }, { kind: "component", type: i1.FsChipComponent, selector: "fs-chip", inputs: ["selectable", "removable", "value", "maxWidth", "width", "backgroundColor", "borderColor", "color", "shape", "outlined", "icon", "image", "selected", "padding", "contrastColor", "size"], outputs: ["selectedToggled", "removed"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
63
- }
64
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FsFilterChipComponent, decorators: [{
65
- type: Component,
66
- args: [{ selector: 'fs-filter-chip', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
67
- FsChipModule,
68
- NgTemplateOutlet,
69
- FsFilterChipContentComponent,
70
- AsyncPipe,
71
- ], template: "@for (chip of chips; track chip) {\n <fs-chip\n [selectable]=\"false\"\n [removable]=\"item.showClear && removable\"\n size=\"small\"\n (click)=\"click(chip)\"\n (removed)=\"remove(chip)\">\n {{ chip.label }}: {{ chip.value }}\n </fs-chip>\n}\n<!-- {{ item.name }}\n@if ((chipDelayedRender$ | async)) {\n @if (rangeItem) {\n @if (item.value?.min || item.value?.from) {\n <fs-chip\n [value]=\"item\"\n [selectable]=\"false\"\n [removable]=\"item.showClear\"\n size=\"small\"\n [removable]=\"removable\"\n (click)=\"click('from')\"\n (removed)=\"removeItem($event, 'from')\">\n <ng-template\n [ngTemplateOutlet]=\"chipContent\"\n [ngTemplateOutletContext]=\"{ item: item, type: 'from' }\">\n </ng-template>\n </fs-chip>\n }\n @if (item.value?.max || item.value?.to) {\n <fs-chip\n [value]=\"item\"\n [selectable]=\"false\"\n [removable]=\"item.showClear && removable\"\n size=\"small\"\n (click)=\"click('to')\"\n (removed)=\"removeItem($event, 'to')\">\n <ng-template\n [ngTemplateOutlet]=\"chipContent\"\n [ngTemplateOutletContext]=\"{ item: item, type: 'to' }\">\n </ng-template>\n </fs-chip>\n }\n } @else {\n <fs-chip\n [value]=\"item\"\n [selectable]=\"false\"\n [removable]=\"item.showClear && removable\"\n size=\"small\"\n (click)=\"click()\"\n (removed)=\"removeItem($event)\">\n <ng-template\n [ngTemplateOutlet]=\"chipContent\"\n [ngTemplateOutletContext]=\"{ item: item }\">\n </ng-template>\n </fs-chip>\n }\n <ng-template\n #chipContent\n let-item=\"item\"\n let-type=\"type\">\n @if (!item.hasPendingValues && !item.loading) {\n <fs-filter-chip-content\n [item]=\"item\"\n [type]=\"type\">\n </fs-filter-chip-content>\n } @else {\n Loading...\n }\n </ng-template>\n} -->", styles: [":host{display:flex;flex-wrap:wrap;gap:5px;max-width:100%}:host.clickable fs-chip{cursor:pointer}\n"] }]
72
- }], propDecorators: { item: [{
73
- type: Input
74
- }], removable: [{
75
- type: Input
76
- }], chips: [{
77
- type: Input
78
- }], clickable: [{
79
- type: Input
80
- }, {
81
- type: HostBinding,
82
- args: ['class.clickable']
83
- }] } });
84
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-chip.component.js","sourceRoot":"","sources":["../../../../../src/app/components/filter-chip/filter-chip.component.ts","../../../../../src/app/components/filter-chip/filter-chip.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAC9D,OAAO,EACL,uBAAuB,EAAE,iBAAiB,EAC1C,SAAS,EACT,WAAW,EACX,MAAM,EACN,KAAK,GAEN,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAEhD,OAAO,EAAE,aAAa,EAAc,OAAO,EAAE,KAAK,EAAE,MAAM,MAAM,CAAC;AACjE,OAAO,EAAE,GAAG,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAGvD,OAAO,EAAE,QAAQ,EAAE,MAAM,8BAA8B,CAAC;AACxD,OAAO,EAAE,sBAAsB,EAAE,MAAM,yCAAyC,CAAC;AACjF,OAAO,EAAE,4BAA4B,EAAE,MAAM,sDAAsD,CAAC;;;AAgBpG,MAAM,OAAO,qBAAqB;IAEhB,IAAI,CAA8B;IAElC,SAAS,GAAY,KAAK,CAAC;IAE3B,KAAK,CAAoD;IAIlE,SAAS,GAAY,KAAK,CAAC;IAE3B,SAAS,CAAU;IAEnB,kBAAkB,CAAsB;IAEvC,iBAAiB,GAAG,KAAK,CAAC,GAAG,CAAC;SACnC,IAAI,CACH,KAAK,CAAC,IAAI,CAAC,CACZ,CAAC;IAEI,SAAS,GAAG,IAAI,OAAO,EAAE,CAAC;IAC1B,MAAM,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;IACnC,gBAAgB,GAAG,MAAM,CAAC,sBAAsB,CAAC,CAAC;IAEnD,QAAQ;QACb,6CAA6C;QAC7C,6BAA6B;QAC7B,sCAAsC;QAEtC,sCAAsC;QACtC,6BAA6B;QAC7B,IAAI;IACN,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC1B,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;IAEM,KAAK,CAAC,IAAqD;QAChE,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;QACpD,CAAC;IACH,CAAC;IAEM,MAAM,CAAC,IAAqD;QACjE,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;IAEM,2BAA2B;QAChC,yBAAyB;QACzB,WAAW;QACX,iCAAiC;QACjC,MAAM;QACN,uBAAuB;QACvB,kCAAkC;QAClC,QAAQ;IACV,CAAC;IAEO,gBAAgB;QACtB,IAAI,CAAC,kBAAkB,GAAG,aAAa,CAAC;YACtC,IAAI,CAAC,IAAI,CAAC,OAAO;YACjB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;SAC9C,CAAC;aACC,IAAI,CACH,GAAG,CAAC,CAAC,CAAC,MAAM,EAAE,UAAU,CAAC,EAAE,EAAE;YAC3B,OAAO,CAAC,CAAC,MAAM,IAAI,UAAU,CAAC;QAChC,CAAC,CAAC,CACH,CAAC;IACN,CAAC;wGAtEU,qBAAqB;4FAArB,qBAAqB,mOClClC,2gEAqEK,2JDzCD,YAAY;;4FAMH,qBAAqB;kBAbjC,SAAS;+BACE,gBAAgB,mBAGT,uBAAuB,CAAC,MAAM,cACnC,IAAI,WACP;wBACP,YAAY;wBACZ,gBAAgB;wBAChB,4BAA4B;wBAC5B,SAAS;qBACV;8BAIe,IAAI;sBAAnB,KAAK;gBAEU,SAAS;sBAAxB,KAAK;gBAEU,KAAK;sBAApB,KAAK;gBAIC,SAAS;sBAFf,KAAK;;sBACL,WAAW;uBAAC,iBAAiB","sourcesContent":["import { AsyncPipe, NgTemplateOutlet } from '@angular/common';\nimport {\n  ChangeDetectionStrategy, ChangeDetectorRef,\n  Component,\n  HostBinding,\n  inject,\n  Input, OnDestroy,\n  OnInit,\n} from '@angular/core';\n\nimport { FsChipModule } from '@firestitch/chip';\n\nimport { combineLatest, Observable, Subject, timer } from 'rxjs';\nimport { map, mapTo, startWith } from 'rxjs/operators';\n\nimport { IFilterConfigItem } from '../../interfaces/config.interface';\nimport { BaseItem } from '../../models/items/base-item';\nimport { FocusControllerService } from '../../services/focus-controller.service';\nimport { FsFilterChipContentComponent } from '../filter-chip-content/filter-chip-content.component';\n\n\n@Component({\n  selector: 'fs-filter-chip',\n  templateUrl: './filter-chip.component.html',\n  styleUrls: ['./filter-chip.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    FsChipModule,\n    NgTemplateOutlet,\n    FsFilterChipContentComponent,\n    AsyncPipe,\n  ],\n})\nexport class FsFilterChipComponent implements OnInit, OnDestroy {\n\n  @Input() public item: BaseItem<IFilterConfigItem>;\n\n  @Input() public removable: boolean = false;\n\n  @Input() public chips: { name?: string, value: string, label: string }[];\n\n  @Input() \n  @HostBinding('class.clickable') \n  public clickable: boolean = false;\n\n  public rangeItem: boolean;\n\n  public chipDelayedRender$: Observable<boolean>;\n\n  private _chipRenderTimer$ = timer(500)\n    .pipe(\n      mapTo(true),\n    );\n\n  private _destroy$ = new Subject();\n  private _cdRef = inject(ChangeDetectorRef);\n  private _focusController = inject(FocusControllerService);\n\n  public ngOnInit() {\n    // this.rangeItem = this.item.isTypeDateRange\n    //   || this.item.isTypeRange\n    //   || this.item.isTypeDateTimeRange;\n\n    // this.listenValueChangesForRanges();\n    //   this._initDelayRender();\n    // }\n  }\n\n  public ngOnDestroy(): void {\n    this._destroy$.next(null);\n    this._destroy$.complete();\n  }\n\n  public click(chip: { name?: string, value: string, label: string }) {\n    if (this.clickable) {\n      this._focusController.click(this.item, chip.name);\n    }\n  }\n\n  public remove(chip: { name?: string, value: string, label: string }) {\n    this.item.clear(chip.name);\n  }\n\n  public listenValueChangesForRanges() {\n    // this.item.valueChange$\n    //   .pipe(\n    //     takeUntil(this._destroy$),\n    //   )\n    //   .subscribe(() => {\n    //     this._cdRef.markForCheck();\n    //   });\n  }\n\n  private _initDelayRender() {\n    this.chipDelayedRender$ = combineLatest([\n      this.item.values$,\n      this._chipRenderTimer$.pipe(startWith(false)),\n    ])\n      .pipe(\n        map(([values, timerValue]) => {\n          return !!values || timerValue;\n        }),\n      );\n  }\n}\n","@for (chip of chips; track chip) {\n  <fs-chip\n      [selectable]=\"false\"\n      [removable]=\"item.showClear && removable\"\n      size=\"small\"\n      (click)=\"click(chip)\"\n      (removed)=\"remove(chip)\">\n    {{ chip.label }}: {{ chip.value }}\n  </fs-chip>\n}\n<!-- {{ item.name }}\n@if ((chipDelayedRender$ | async)) {\n  @if (rangeItem) {\n    @if (item.value?.min || item.value?.from) {\n      <fs-chip\n          [value]=\"item\"\n          [selectable]=\"false\"\n          [removable]=\"item.showClear\"\n          size=\"small\"\n          [removable]=\"removable\"\n          (click)=\"click('from')\"\n          (removed)=\"removeItem($event, 'from')\">\n        <ng-template\n          [ngTemplateOutlet]=\"chipContent\"\n          [ngTemplateOutletContext]=\"{ item: item, type: 'from' }\">\n        </ng-template>\n      </fs-chip>\n    }\n    @if (item.value?.max || item.value?.to) {\n      <fs-chip\n          [value]=\"item\"\n          [selectable]=\"false\"\n          [removable]=\"item.showClear && removable\"\n          size=\"small\"\n          (click)=\"click('to')\"\n          (removed)=\"removeItem($event, 'to')\">\n        <ng-template\n          [ngTemplateOutlet]=\"chipContent\"\n          [ngTemplateOutletContext]=\"{ item: item, type: 'to' }\">\n        </ng-template>\n      </fs-chip>\n    }\n  } @else {\n    <fs-chip\n        [value]=\"item\"\n        [selectable]=\"false\"\n        [removable]=\"item.showClear && removable\"\n        size=\"small\"\n        (click)=\"click()\"\n        (removed)=\"removeItem($event)\">\n      <ng-template\n        [ngTemplateOutlet]=\"chipContent\"\n        [ngTemplateOutletContext]=\"{ item: item }\">\n      </ng-template>\n    </fs-chip>\n  }\n  <ng-template\n      #chipContent\n      let-item=\"item\"\n      let-type=\"type\">\n    @if (!item.hasPendingValues && !item.loading) {\n      <fs-filter-chip-content\n        [item]=\"item\"\n        [type]=\"type\">\n      </fs-filter-chip-content>\n    } @else {\n      Loading...\n    }\n  </ng-template>\n} -->"]}
@@ -1,71 +0,0 @@
1
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, } from '@angular/core';
2
- import { Subject } from 'rxjs';
3
- import { takeUntil } from 'rxjs/operators';
4
- import { BaseItem } from '../../models/items/base-item';
5
- import * as i0 from "@angular/core";
6
- export class FsFilterChipContentComponent {
7
- _cdRef;
8
- item;
9
- type;
10
- content;
11
- _destroy$ = new Subject();
12
- constructor(_cdRef) {
13
- this._cdRef = _cdRef;
14
- }
15
- ngOnInit() {
16
- this.listenValueChangesForRanges();
17
- }
18
- ngOnDestroy() {
19
- this._destroy$.next(null);
20
- this._destroy$.complete();
21
- }
22
- listenValueChangesForRanges() {
23
- this.item.value$
24
- .pipe(takeUntil(this._destroy$))
25
- .subscribe(() => {
26
- this.content = this._getContent();
27
- this._cdRef.detectChanges();
28
- });
29
- }
30
- _getContent() {
31
- const result = this.item.chips;
32
- if (this.item.chipLabel !== undefined) {
33
- if (this.item.chipLabel === '') {
34
- return `${result}`;
35
- }
36
- if (Array.isArray(this.item.chipLabel)) {
37
- const label = getLabelFromArray(this.item.chipLabel, this.type);
38
- return `${label}: ${result}`;
39
- }
40
- return `${this.item.chipLabel}: ${result}`;
41
- }
42
- if (Array.isArray(this.item.label)) {
43
- const label = getLabelFromArray(this.item.label, this.type);
44
- return `${label}: ${result}`;
45
- }
46
- if (this.item.isTypeCheckbox) {
47
- return result;
48
- }
49
- return `${this.item.label}: ${result}`;
50
- }
51
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FsFilterChipContentComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
52
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FsFilterChipContentComponent, isStandalone: true, selector: "fs-filter-chip-content", inputs: { item: "item", type: "type" }, ngImport: i0, template: "{{ content }}\n", styles: [""], changeDetection: i0.ChangeDetectionStrategy.OnPush });
53
- }
54
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FsFilterChipContentComponent, decorators: [{
55
- type: Component,
56
- args: [{ selector: 'fs-filter-chip-content', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, template: "{{ content }}\n" }]
57
- }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { item: [{
58
- type: Input
59
- }], type: [{
60
- type: Input
61
- }] } });
62
- function getLabelFromArray(labelArr, type) {
63
- if (type === 'from' && labelArr[0]) {
64
- return `${labelArr[0]}`;
65
- }
66
- else if (type === 'to' && labelArr[1]) {
67
- return `${labelArr[1]}`;
68
- }
69
- return '';
70
- }
71
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLWNoaXAtY29udGVudC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvYXBwL2NvbXBvbmVudHMvZmlsdGVyLWNoaXAtY29udGVudC9maWx0ZXItY2hpcC1jb250ZW50LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvY29tcG9uZW50cy9maWx0ZXItY2hpcC1jb250ZW50L2ZpbHRlci1jaGlwLWNvbnRlbnQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixpQkFBaUIsRUFDakIsU0FBUyxFQUNULEtBQUssR0FHTixNQUFNLGVBQWUsQ0FBQztBQUV2QixPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQy9CLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUczQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sOEJBQThCLENBQUM7O0FBVXhELE1BQU0sT0FBTyw0QkFBNEI7SUFTbkI7SUFQSixJQUFJLENBQThCO0lBQ2xDLElBQUksQ0FBZ0I7SUFFN0IsT0FBTyxDQUFDO0lBRVAsU0FBUyxHQUFHLElBQUksT0FBTyxFQUFFLENBQUM7SUFFbEMsWUFBb0IsTUFBeUI7UUFBekIsV0FBTSxHQUFOLE1BQU0sQ0FBbUI7SUFDN0MsQ0FBQztJQUVNLFFBQVE7UUFDYixJQUFJLENBQUMsMkJBQTJCLEVBQUUsQ0FBQztJQUNyQyxDQUFDO0lBRU0sV0FBVztRQUNoQixJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUMxQixJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQzVCLENBQUM7SUFFTSwyQkFBMkI7UUFDaEMsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNO2FBQ2IsSUFBSSxDQUNILFNBQVMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQzFCO2FBQ0EsU0FBUyxDQUFDLEdBQUcsRUFBRTtZQUNkLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQ2xDLElBQUksQ0FBQyxNQUFNLENBQUMsYUFBYSxFQUFFLENBQUM7UUFDOUIsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRU8sV0FBVztRQUNqQixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQztRQUUvQixJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxLQUFLLFNBQVMsRUFBRSxDQUFDO1lBQ3RDLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEtBQUssRUFBRSxFQUFFLENBQUM7Z0JBQy9CLE9BQU8sR0FBRyxNQUFNLEVBQUUsQ0FBQztZQUNyQixDQUFDO1lBQ0QsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLEVBQUUsQ0FBQztnQkFDdkMsTUFBTSxLQUFLLEdBQUcsaUJBQWlCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO2dCQUVoRSxPQUFPLEdBQUcsS0FBSyxLQUFLLE1BQU0sRUFBRSxDQUFDO1lBQy9CLENBQUM7WUFFRCxPQUFPLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEtBQUssTUFBTSxFQUFFLENBQUM7UUFHN0MsQ0FBQztRQUNELElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUM7WUFDbkMsTUFBTSxLQUFLLEdBQUcsaUJBQWlCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1lBRTVELE9BQU8sR0FBRyxLQUFLLEtBQUssTUFBTSxFQUFFLENBQUM7UUFDL0IsQ0FBQztRQUNELElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQztZQUM3QixPQUFPLE1BQU0sQ0FBQztRQUNoQixDQUFDO1FBRUQsT0FBTyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxLQUFLLE1BQU0sRUFBRSxDQUFDO0lBR3pDLENBQUM7d0dBN0RVLDRCQUE0Qjs0RkFBNUIsNEJBQTRCLDBIQ3ZCekMsaUJBQ0E7OzRGRHNCYSw0QkFBNEI7a0JBUHhDLFNBQVM7K0JBQ0Usd0JBQXdCLG1CQUdqQix1QkFBdUIsQ0FBQyxNQUFNLGNBQ25DLElBQUk7c0ZBSUEsSUFBSTtzQkFBbkIsS0FBSztnQkFDVSxJQUFJO3NCQUFuQixLQUFLOztBQTZEUixTQUFTLGlCQUFpQixDQUFDLFFBQVEsRUFBRSxJQUFJO0lBQ3ZDLElBQUksSUFBSSxLQUFLLE1BQU0sSUFBSSxRQUFRLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztRQUNuQyxPQUFPLEdBQUcsUUFBUSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7SUFDMUIsQ0FBQztTQUFNLElBQUksSUFBSSxLQUFLLElBQUksSUFBSSxRQUFRLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztRQUN4QyxPQUFPLEdBQUcsUUFBUSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7SUFDMUIsQ0FBQztJQUVELE9BQU8sRUFBRSxDQUFDO0FBRVosQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDaGFuZ2VEZXRlY3RvclJlZixcbiAgQ29tcG9uZW50LFxuICBJbnB1dCxcbiAgT25EZXN0cm95LFxuICBPbkluaXQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyB0YWtlVW50aWwgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbmltcG9ydCB7IElGaWx0ZXJDb25maWdJdGVtIH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcy9jb25maWcuaW50ZXJmYWNlJztcbmltcG9ydCB7IEJhc2VJdGVtIH0gZnJvbSAnLi4vLi4vbW9kZWxzL2l0ZW1zL2Jhc2UtaXRlbSc7XG5cblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZnMtZmlsdGVyLWNoaXAtY29udGVudCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9maWx0ZXItY2hpcC1jb250ZW50LmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZmlsdGVyLWNoaXAtY29udGVudC5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgRnNGaWx0ZXJDaGlwQ29udGVudENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcblxuICBASW5wdXQoKSBwdWJsaWMgaXRlbTogQmFzZUl0ZW08SUZpbHRlckNvbmZpZ0l0ZW0+O1xuICBASW5wdXQoKSBwdWJsaWMgdHlwZTogJ2Zyb20nIHwgJ3RvJztcblxuICBwdWJsaWMgY29udGVudDtcblxuICBwcml2YXRlIF9kZXN0cm95JCA9IG5ldyBTdWJqZWN0KCk7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBfY2RSZWY6IENoYW5nZURldGVjdG9yUmVmKSB7XG4gIH1cblxuICBwdWJsaWMgbmdPbkluaXQoKSB7XG4gICAgdGhpcy5saXN0ZW5WYWx1ZUNoYW5nZXNGb3JSYW5nZXMoKTtcbiAgfVxuXG4gIHB1YmxpYyBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLl9kZXN0cm95JC5uZXh0KG51bGwpO1xuICAgIHRoaXMuX2Rlc3Ryb3kkLmNvbXBsZXRlKCk7XG4gIH1cblxuICBwdWJsaWMgbGlzdGVuVmFsdWVDaGFuZ2VzRm9yUmFuZ2VzKCkge1xuICAgIHRoaXMuaXRlbS52YWx1ZSRcbiAgICAgIC5waXBlKFxuICAgICAgICB0YWtlVW50aWwodGhpcy5fZGVzdHJveSQpLFxuICAgICAgKVxuICAgICAgLnN1YnNjcmliZSgoKSA9PiB7XG4gICAgICAgIHRoaXMuY29udGVudCA9IHRoaXMuX2dldENvbnRlbnQoKTtcbiAgICAgICAgdGhpcy5fY2RSZWYuZGV0ZWN0Q2hhbmdlcygpO1xuICAgICAgfSk7XG4gIH1cblxuICBwcml2YXRlIF9nZXRDb250ZW50KCkge1xuICAgIGNvbnN0IHJlc3VsdCA9IHRoaXMuaXRlbS5jaGlwcztcblxuICAgIGlmICh0aGlzLml0ZW0uY2hpcExhYmVsICE9PSB1bmRlZmluZWQpIHtcbiAgICAgIGlmICh0aGlzLml0ZW0uY2hpcExhYmVsID09PSAnJykge1xuICAgICAgICByZXR1cm4gYCR7cmVzdWx0fWA7XG4gICAgICB9IFxuICAgICAgaWYgKEFycmF5LmlzQXJyYXkodGhpcy5pdGVtLmNoaXBMYWJlbCkpIHtcbiAgICAgICAgY29uc3QgbGFiZWwgPSBnZXRMYWJlbEZyb21BcnJheSh0aGlzLml0ZW0uY2hpcExhYmVsLCB0aGlzLnR5cGUpO1xuXG4gICAgICAgIHJldHVybiBgJHtsYWJlbH06ICR7cmVzdWx0fWA7XG4gICAgICB9XG4gXG4gICAgICByZXR1cm4gYCR7dGhpcy5pdGVtLmNoaXBMYWJlbH06ICR7cmVzdWx0fWA7XG4gICAgICAgIFxuICAgICAgXG4gICAgfSBcbiAgICBpZiAoQXJyYXkuaXNBcnJheSh0aGlzLml0ZW0ubGFiZWwpKSB7XG4gICAgICBjb25zdCBsYWJlbCA9IGdldExhYmVsRnJvbUFycmF5KHRoaXMuaXRlbS5sYWJlbCwgdGhpcy50eXBlKTtcblxuICAgICAgcmV0dXJuIGAke2xhYmVsfTogJHtyZXN1bHR9YDtcbiAgICB9IFxuICAgIGlmICh0aGlzLml0ZW0uaXNUeXBlQ2hlY2tib3gpIHtcbiAgICAgIHJldHVybiByZXN1bHQ7XG4gICAgfVxuIFxuICAgIHJldHVybiBgJHt0aGlzLml0ZW0ubGFiZWx9OiAke3Jlc3VsdH1gO1xuICAgICAgXG4gICAgXG4gIH1cbn1cblxuZnVuY3Rpb24gZ2V0TGFiZWxGcm9tQXJyYXkobGFiZWxBcnIsIHR5cGUpIHtcbiAgaWYgKHR5cGUgPT09ICdmcm9tJyAmJiBsYWJlbEFyclswXSkge1xuICAgIHJldHVybiBgJHtsYWJlbEFyclswXX1gO1xuICB9IGVsc2UgaWYgKHR5cGUgPT09ICd0bycgJiYgbGFiZWxBcnJbMV0pIHtcbiAgICByZXR1cm4gYCR7bGFiZWxBcnJbMV19YDtcbiAgfVxuIFxuICByZXR1cm4gJyc7XG4gIFxufVxuIiwie3sgY29udGVudCB9fVxuIl19