ca-components 0.0.78 → 0.0.79

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 (35) hide show
  1. package/esm2022/lib/components/ca-filters/ca-filter.component.mjs +59 -5
  2. package/esm2022/lib/components/ca-filters/components/ca-dispatcher-filter/ca-dispatcher-filter.component.mjs +14 -35
  3. package/esm2022/lib/components/ca-filters/components/ca-money-filter/ca-money-filter.component.mjs +10 -9
  4. package/esm2022/lib/components/ca-filters/components/ca-pm-filter/ca-pm-filter.component.mjs +8 -8
  5. package/esm2022/lib/components/ca-filters/components/ca-state-filter/ca-state-filter.component.mjs +28 -23
  6. package/esm2022/lib/components/ca-filters/components/ca-status-filter/ca-status-filter.component.mjs +13 -9
  7. package/esm2022/lib/components/ca-filters/components/ca-trailer-type-filter/ca-trailer-type-filter.component.mjs +62 -37
  8. package/esm2022/lib/components/ca-filters/components/ca-trailer-type-filter/config/ca-trailer-type-filter.config.mjs +15 -0
  9. package/esm2022/lib/components/ca-filters/components/ca-trailer-type-filter/config/index.mjs +2 -0
  10. package/esm2022/lib/components/ca-filters/components/ca-truck-type-filter/ca-truck-type-filter.component.mjs +61 -37
  11. package/esm2022/lib/components/ca-filters/components/ca-truck-type-filter/config/ca-truck-type-filter.config.mjs +15 -0
  12. package/esm2022/lib/components/ca-filters/pipes/filter-popover-conditions.pipe.mjs +2 -1
  13. package/esm2022/lib/components/ca-filters/utils/constants/directive.constants.mjs +141 -141
  14. package/esm2022/lib/components/ca-filters/utils/helpers/filter.helper.mjs +13 -12
  15. package/esm2022/lib/components/ca-payroll-list-summary-overview/ca-payroll-list-summary-overview.component.mjs +10 -5
  16. package/esm2022/lib/components/ca-payroll-list-summary-overview-table/ca-payroll-list-summary-overview-table.component.mjs +1 -1
  17. package/esm2022/lib/components/ca-upload-files/components/ca-upload-dropzone/ca-upload-dropzone.component.mjs +8 -12
  18. package/esm2022/lib/components/ca-upload-files/components/ca-upload-dropzone/helpers/file.helper.mjs +5 -7
  19. package/esm2022/lib/components/ca-upload-files/components/ca-upload-dropzone/models/file-config.model.mjs +1 -1
  20. package/esm2022/lib/models/array-status.model.mjs +1 -1
  21. package/fesm2022/ca-components.mjs +448 -328
  22. package/fesm2022/ca-components.mjs.map +1 -1
  23. package/lib/components/ca-filters/ca-filter.component.d.ts +8 -1
  24. package/lib/components/ca-filters/components/ca-money-filter/ca-money-filter.component.d.ts +4 -3
  25. package/lib/components/ca-filters/components/ca-state-filter/ca-state-filter.component.d.ts +5 -5
  26. package/lib/components/ca-filters/components/ca-trailer-type-filter/ca-trailer-type-filter.component.d.ts +12 -5
  27. package/lib/components/ca-filters/components/ca-trailer-type-filter/config/ca-trailer-type-filter.config.d.ts +4 -0
  28. package/lib/components/ca-filters/components/ca-trailer-type-filter/config/index.d.ts +1 -0
  29. package/lib/components/ca-filters/components/ca-truck-type-filter/ca-truck-type-filter.component.d.ts +13 -6
  30. package/lib/components/ca-filters/components/ca-truck-type-filter/config/ca-truck-type-filter.config.d.ts +4 -0
  31. package/lib/components/ca-payroll-list-summary-overview/ca-payroll-list-summary-overview.component.d.ts +4 -2
  32. package/lib/components/ca-upload-files/components/ca-upload-dropzone/helpers/file.helper.d.ts +1 -1
  33. package/lib/components/ca-upload-files/components/ca-upload-dropzone/models/file-config.model.d.ts +1 -1
  34. package/lib/models/array-status.model.d.ts +2 -1
  35. package/package.json +1 -1
@@ -51,7 +51,7 @@ export class CaStatusFilterComponent {
51
51
  const selectedUsersIdArray = [];
52
52
  this.totalFiltersNum = this.filterActiveArray.length;
53
53
  const mainArray = this.loadStatusOptionsArray;
54
- mainArray.map((item) => {
54
+ mainArray.forEach((item) => {
55
55
  if (item.isSelected) {
56
56
  item['currentSet'] = true;
57
57
  }
@@ -59,7 +59,7 @@ export class CaStatusFilterComponent {
59
59
  item['currentSet'] = false;
60
60
  }
61
61
  });
62
- this.filterActiveArray.map((data) => {
62
+ this.filterActiveArray.forEach((data) => {
63
63
  selectedUsersIdArray.push(data.id);
64
64
  });
65
65
  queryParams = selectedUsersIdArray;
@@ -79,9 +79,12 @@ export class CaStatusFilterComponent {
79
79
  if (event)
80
80
  event.stopPropagation();
81
81
  this.selectedUser = [];
82
- this.loadStatusOptionsArray.map((item) => {
82
+ this.loadStatusOptionsArray = this.loadStatusOptionsArray.map((item) => {
83
83
  item.isSelected = false;
84
+ item.currentSet = false;
85
+ return item;
84
86
  });
87
+ this.checkFilterActiveValue();
85
88
  this.isButtonAvailable = true;
86
89
  this.filterActiveArray = [];
87
90
  this.totalFiltersNum = 0;
@@ -90,6 +93,7 @@ export class CaStatusFilterComponent {
90
93
  action,
91
94
  type: this.type,
92
95
  filterType: this.type,
96
+ queryParams: [],
93
97
  };
94
98
  return data;
95
99
  }
@@ -112,7 +116,7 @@ export class CaStatusFilterComponent {
112
116
  addToSelectedUser(item, indx) {
113
117
  const mainArray = this.loadStatusOptionsArray;
114
118
  mainArray[indx].isSelected = true;
115
- this.unselectedVisibleCount = mainArray.filter((item2) => !item2.isSelected)?.length;
119
+ this.unselectedVisibleCount = mainArray.filter((status) => !status.isSelected)?.length;
116
120
  this.selectedUser.push(item);
117
121
  this.checkFilterActiveValue();
118
122
  }
@@ -120,12 +124,12 @@ export class CaStatusFilterComponent {
120
124
  this.selectedUser.splice(indx, 1);
121
125
  const id = item.id;
122
126
  const mainArray = this.loadStatusOptionsArray;
123
- mainArray.map((item2) => {
124
- if (item2.id === id) {
125
- item2.isSelected = false;
127
+ mainArray.forEach((status) => {
128
+ if (status.id === id) {
129
+ status.isSelected = false;
126
130
  }
127
131
  });
128
- this.unselectedVisibleCount = mainArray.filter((item2) => !item2.isSelected)?.length;
132
+ this.unselectedVisibleCount = mainArray.filter((status) => !status.isSelected)?.length;
129
133
  this.checkFilterActiveValue();
130
134
  }
131
135
  checkFilterActiveValue() {
@@ -173,4 +177,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
173
177
  }], loadStatusOptionsArray: [{
174
178
  type: Input
175
179
  }] } });
176
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-status-filter.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ca-components/src/lib/components/ca-filters/components/ca-status-filter/ca-status-filter.component.ts","../../../../../../../../projects/ca-components/src/lib/components/ca-filters/components/ca-status-filter/ca-status-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  OnDestroy,\n  OnInit,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { Subject, takeUntil } from 'rxjs';\n\n// modules\nimport { AngularSvgIconModule } from 'angular-svg-icon';\nimport { CommonModule } from '@angular/common';\nimport { HttpClientModule } from '@angular/common/http';\n\n// enums\nimport { LoadFilterStringEnum } from '../../../../enums/load-filter-string.enum';\nimport { ToolbarFilterStringEnum } from '../../../ca-map/enums/toolbar-filter-string.enum';\nimport { LoadStatusEnum } from '../../../../enums/load-status.enum';\n\n// pipes\nimport { DropdownLoadStatusColorPipe } from '../../../../pipes/dropdown-load-status-color.pipe';\n\n// animations\nimport { inOutAnimation } from '../../../../animations/in-out.animation';\nimport { showAnimation } from '../../../../animations/show.animation';\nimport { CaFiltersSvgRoutes } from '../../utils/svg-routes/ca-filters-svg-routes';\n\n// models\nimport { ArrayStatus } from '../../../../models/array-status.model';\nimport { filterOutput } from '../../../../models/filter-output.model';\nimport { filterOutputWithParams } from '../../../../models/filter-output-params.model';\n\n// services\nimport { TruckassistTableService } from '../../../../services/truckassist-table.service';\n\n// helpers\nimport { FilterHelper } from '../../utils/helpers/filter.helper';\n\n@Component({\n  selector: 'app-ca-status-filter',\n  standalone: true,\n  imports: [\n    // modules\n    AngularSvgIconModule,\n    CommonModule,\n    HttpClientModule,\n    // pipes\n    DropdownLoadStatusColorPipe,\n  ],\n  encapsulation: ViewEncapsulation.None,\n  templateUrl: './ca-status-filter.component.html',\n  styleUrls: ['./ca-status-filter.component.scss'],\n  animations: [\n    inOutAnimation('inOutAnimation'),\n    showAnimation('showAnimation'),\n  ],\n})\nexport class CaStatusFilterComponent implements OnInit, OnDestroy {\n  @Input() type!: string;\n  @Input() isLegendView: boolean = false;\n  @Input() isFilterActive: boolean = false;\n  @Input() toDoSubType!: string;\n  @Input() loadStatusOptionsArray!: ArrayStatus[];\n\n  private destroy$ = new Subject<void>();\n  public unselectedVisibleCount: number = 0;\n\n  public selectedUser: ArrayStatus[] = [];\n\n  public isButtonAvailable: boolean = false;\n  public isAscendingSortOrder: boolean = true;\n\n  public loadStatusEnum = LoadStatusEnum;\n  public filterActiveArray: ArrayStatus[] = [];\n  public totalFiltersNum: number = 0;\n\n  constructor(\n    // services\n    private tableService: TruckassistTableService\n  ) {}\n\n  ngOnInit(): void {\n    this.watchLoadStatusFilterValueChanges();\n  }\n\n  public trackByIndex(index: number): number {\n    return index;\n  }\n\n  public onFilterClose(): void {\n    FilterHelper.handleFilterClose(\n      this.loadStatusOptionsArray,\n      this.selectedUser,\n      this.removeFromSelectedUser.bind(this),\n      this.addToSelectedUser.bind(this)\n    );\n  }\n\n  public setFilterValue(): filterOutput | filterOutputWithParams {\n    let queryParams = {};\n    let subType = ToolbarFilterStringEnum.EMPTY_STRING_PLACEHOLDER.toString();\n\n    this.filterActiveArray = [...this.selectedUser];\n    const selectedUsersIdArray: number[] = [];\n    this.totalFiltersNum = this.filterActiveArray.length;\n\n    const mainArray: ArrayStatus[] = this.loadStatusOptionsArray;\n\n    mainArray.map((item) => {\n      if (item.isSelected) {\n        item['currentSet'] = true;\n      } else {\n        item['currentSet'] = false;\n      }\n    });\n\n    this.filterActiveArray.map((data) => {\n      selectedUsersIdArray.push(data.id!);\n    });\n\n    queryParams = selectedUsersIdArray;\n    subType =\n      this.toDoSubType ??\n      ToolbarFilterStringEnum.EMPTY_STRING_PLACEHOLDER.toString();\n\n    const action = 'Set';\n    const data = {\n      filterType: this.type,\n      action,\n      queryParams,\n      subType,\n    };\n    return data;\n  }\n\n  public clearAll(event?: Event): filterOutput | filterOutputWithParams {\n    if (event) event.stopPropagation();\n\n    this.selectedUser = [];\n\n    this.loadStatusOptionsArray.map((item) => {\n      item.isSelected = false;\n    });\n\n    this.isButtonAvailable = true;\n    this.filterActiveArray = [];\n    this.totalFiltersNum = 0;\n\n    const action = 'Clear';\n    const data = {\n      action,\n      type: this.type,\n      filterType: this.type,\n    };\n    return data;\n  }\n\n  public sortItems(): void {\n    const sortResult = FilterHelper.sortItemsCount(\n      this.loadStatusOptionsArray,\n      this.selectedUser,\n      this.isAscendingSortOrder\n    );\n\n    this.loadStatusOptionsArray = sortResult.sortedFilterArray;\n    this.selectedUser = sortResult.sortedSelectedFilterArray;\n    this.isAscendingSortOrder = sortResult.isAscendingSortOrder;\n  }\n\n  private watchLoadStatusFilterValueChanges(): void {\n    this.type = ToolbarFilterStringEnum.STATUS_FILTER;\n    this.tableService.currentLoadStatusFilterOptions\n      .pipe(takeUntil(this.destroy$))\n      .subscribe((res) => {\n        if (res && this.type === LoadFilterStringEnum.STATUS_FILTER) {\n          this.loadStatusOptionsArray = res.options;\n        }\n      });\n  }\n\n  public addToSelectedUser(item: ArrayStatus, indx: number) {\n    const mainArray = this.loadStatusOptionsArray;\n\n    mainArray[indx].isSelected = true;\n\n    this.unselectedVisibleCount = mainArray.filter(\n      (item2) => !item2.isSelected\n    )?.length;\n\n    this.selectedUser.push(item);\n\n    this.checkFilterActiveValue();\n  }\n\n  public removeFromSelectedUser(item: ArrayStatus, indx: number): void {\n    this.selectedUser.splice(indx, 1);\n    const id = item.id;\n    const mainArray = this.loadStatusOptionsArray;\n\n    mainArray.map((item2) => {\n      if (item2.id === id) {\n        item2.isSelected = false;\n      }\n    });\n\n    this.unselectedVisibleCount = mainArray.filter(\n      (item2) => !item2.isSelected\n    )?.length;\n\n    this.checkFilterActiveValue();\n  }\n\n  public checkFilterActiveValue(): void {\n    const filterCheck = FilterHelper.checkFilterActiveValue(\n      this.selectedUser,\n      this.filterActiveArray,\n      this.isButtonAvailable\n    );\n\n    this.isButtonAvailable = filterCheck.isButtonAvailable;\n  }\n\n  public getSvgPath(propertyName: keyof typeof CaFiltersSvgRoutes): string {\n    return FilterHelper.getSvgPath(propertyName);\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n}\n","<div class=\"border-filter\"></div>\n<div class=\"user-holder\" *ngIf=\"type === 'statusFilter'\">\n  <div class=\"status-data-main-holder\">\n    <ng-container\n      *ngFor=\"let item of selectedUser; let indx = index; trackBy: trackByIndex\"\n    >\n      <div class=\"user-frame-holder d-flex align-items-center\">\n        <div\n          class=\"selected-user-holder d-flex flex-column justify-content-start align-items-start\"\n        >\n          <div\n            class=\"user-main-holder\"\n            [@inOutAnimation]=\"'in'\"\n            [@showAnimation]=\"!!isFilterActive\"\n            (click)=\"removeFromSelectedUser(item, indx)\"\n          >\n            <div\n              class=\"selected-user-frame d-flex align-items-center ca-font-bold\"\n            >\n              <div class=\"user-profile-img d-flex align-items-center\">\n                <div\n                  class=\"status-circle\"\n                  [ngStyle]=\"\n                    loadStatusEnum[item.id!] | dropdownLoadStatusColor: true\n                  \"\n                ></div>\n              </div>\n              <div\n                class=\"selected-name-text d-flex align-items-center\"\n                [class.text-uppercase]=\"type === 'statusFilter'\"\n              >\n                <div\n                  class=\"selected-name-text d-flex align-items-center\"\n                  [class.text-uppercase]=\"type === 'statusFilter'\"\n                >\n                  <span> {{ item.name }}</span>\n                </div>\n              </div>\n              <ng-container *ngIf=\"item?.count; else noCount\">\n                <span\n                  class=\"count-holder d-flex align-items-center justify-content-center activeCount ca-font-semi-bold\"\n                >\n                  {{ item.count }}\n                </span>\n              </ng-container>\n\n              <ng-template #noCount>\n                <ng-container *ngIf=\"!item.count; else noCounter\">\n                  <div class=\"selected-icon\">\n                    <svg-icon\n                      [src]=\"getSvgPath('removeSelectedValue')\"\n                    ></svg-icon>\n                  </div>\n                </ng-container>\n                <ng-template #noCounter>\n                  <div class=\"counter-holder activeCounter\">2</div>\n                </ng-template>\n              </ng-template>\n              <div\n                (click)=\"removeFromSelectedUser(item, indx)\"\n                class=\"icon-delete d-flex\"\n                [class.counterMargin]=\"item.count\"\n              >\n                <svg-icon [src]=\"getSvgPath('removeSelectedValue')\"></svg-icon>\n              </div>\n            </div>\n          </div>\n        </div>\n      </div>\n      <div\n        *ngIf=\"selectedUser.length > 0 && unselectedVisibleCount\"\n        class=\"border-filter border-thrird-margin\"\n      ></div>\n    </ng-container>\n\n    <ng-container\n      *ngFor=\"\n        let item of loadStatusOptionsArray;\n        let indx = index;\n        trackBy: trackByIndex\n      \"\n    >\n      <div class=\"user-frame-holder d-flex align-items-center\">\n        <ng-container *ngIf=\"!item.hidden && !item.isSelected\">\n          <div\n            [@inOutAnimation]=\"'in'\"\n            [@showAnimation]=\"!!isFilterActive\"\n            (click)=\"addToSelectedUser(item, indx)\"\n            class=\"user-main-holder d-flex align-items-center justify-content-center;\"\n          >\n            <div class=\"user-profile-img d-flex align-items-center\">\n              <div\n                class=\"status-circle\"\n                [ngStyle]=\"\n                  loadStatusEnum[item.id!] | dropdownLoadStatusColor: true\n                \"\n              ></div>\n            </div>\n            <div\n              class=\"user-frame d-flex justify-content-between align-items-center fw-normal\"\n            >\n              <div\n                class=\"selected-name-text text-uppercase d-flex align-items-center\"\n              >\n                <span> {{ item.name }} </span>\n              </div>\n\n              <ng-container *ngIf=\"item?.count\">\n                <span\n                  class=\"count-holder d-flex align-items-center justify-content-center ca-font-semi-bold\"\n                >\n                  {{ item.count }}\n                </span>\n              </ng-container>\n            </div>\n          </div>\n        </ng-container>\n      </div>\n    </ng-container>\n  </div>\n</div>\n<ng-container\n  *ngIf=\"\n    !isLegendView && (type === 'statusFilter' || type === 'dispatcherFilter')\n  \"\n>\n  <div class=\"border-filter\"></div>\n</ng-container>\n"]}
180
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-status-filter.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ca-components/src/lib/components/ca-filters/components/ca-status-filter/ca-status-filter.component.ts","../../../../../../../../projects/ca-components/src/lib/components/ca-filters/components/ca-status-filter/ca-status-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  OnDestroy,\n  OnInit,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { Subject, takeUntil } from 'rxjs';\n\n// modules\nimport { AngularSvgIconModule } from 'angular-svg-icon';\nimport { CommonModule } from '@angular/common';\nimport { HttpClientModule } from '@angular/common/http';\n\n// enums\nimport { LoadFilterStringEnum } from '../../../../enums/load-filter-string.enum';\nimport { ToolbarFilterStringEnum } from '../../../ca-map/enums/toolbar-filter-string.enum';\nimport { LoadStatusEnum } from '../../../../enums/load-status.enum';\n\n// pipes\nimport { DropdownLoadStatusColorPipe } from '../../../../pipes/dropdown-load-status-color.pipe';\n\n// animations\nimport { inOutAnimation } from '../../../../animations/in-out.animation';\nimport { showAnimation } from '../../../../animations/show.animation';\nimport { CaFiltersSvgRoutes } from '../../utils/svg-routes/ca-filters-svg-routes';\n\n// models\nimport { ArrayStatus } from '../../../../models/array-status.model';\nimport { filterOutput } from '../../../../models/filter-output.model';\nimport { filterOutputWithParams } from '../../../../models/filter-output-params.model';\n\n// services\nimport { TruckassistTableService } from '../../../../services/truckassist-table.service';\n\n// helpers\nimport { FilterHelper } from '../../utils/helpers/filter.helper';\n\n@Component({\n  selector: 'app-ca-status-filter',\n  standalone: true,\n  imports: [\n    // modules\n    AngularSvgIconModule,\n    CommonModule,\n    HttpClientModule,\n    // pipes\n    DropdownLoadStatusColorPipe,\n  ],\n  encapsulation: ViewEncapsulation.None,\n  templateUrl: './ca-status-filter.component.html',\n  styleUrls: ['./ca-status-filter.component.scss'],\n  animations: [\n    inOutAnimation('inOutAnimation'),\n    showAnimation('showAnimation'),\n  ],\n})\nexport class CaStatusFilterComponent implements OnInit, OnDestroy {\n  @Input() type!: string;\n  @Input() isLegendView: boolean = false;\n  @Input() isFilterActive: boolean = false;\n  @Input() toDoSubType!: string;\n  @Input() loadStatusOptionsArray!: ArrayStatus[];\n\n  private destroy$ = new Subject<void>();\n  public unselectedVisibleCount: number = 0;\n\n  public selectedUser: ArrayStatus[] = [];\n\n  public isButtonAvailable: boolean = false;\n  public isAscendingSortOrder: boolean = true;\n\n  public loadStatusEnum = LoadStatusEnum;\n  public filterActiveArray: ArrayStatus[] = [];\n  public totalFiltersNum: number = 0;\n\n  constructor(\n    // services\n    private tableService: TruckassistTableService\n  ) {}\n\n  ngOnInit(): void {\n    this.watchLoadStatusFilterValueChanges();\n  }\n\n  public trackByIndex(index: number): number {\n    return index;\n  }\n\n  public onFilterClose(): void {\n    FilterHelper.handleFilterClose(\n      this.loadStatusOptionsArray,\n      this.selectedUser,\n      this.removeFromSelectedUser.bind(this),\n      this.addToSelectedUser.bind(this)\n    );\n  }\n\n  public setFilterValue(): filterOutput | filterOutputWithParams {\n    let queryParams = {};\n    let subType = ToolbarFilterStringEnum.EMPTY_STRING_PLACEHOLDER.toString();\n\n    this.filterActiveArray = [...this.selectedUser];\n    const selectedUsersIdArray: number[] = [];\n    this.totalFiltersNum = this.filterActiveArray.length;\n\n    const mainArray: ArrayStatus[] = this.loadStatusOptionsArray;\n\n    mainArray.forEach((item) => {\n      if (item.isSelected) {\n        item['currentSet'] = true;\n      } else {\n        item['currentSet'] = false;\n      }\n    });\n\n    this.filterActiveArray.forEach((data) => {\n      selectedUsersIdArray.push(data.id!);\n    });\n\n    queryParams = selectedUsersIdArray;\n    subType =\n      this.toDoSubType ??\n      ToolbarFilterStringEnum.EMPTY_STRING_PLACEHOLDER.toString();\n\n    const action = 'Set';\n    const data = {\n      filterType: this.type,\n      action,\n      queryParams,\n      subType,\n    };\n    return data;\n  }\n\n  public clearAll(event?: Event): filterOutput | filterOutputWithParams {\n    if (event) event.stopPropagation();\n\n    this.selectedUser = [];\n\n    this.loadStatusOptionsArray = this.loadStatusOptionsArray.map((item) => {\n      item.isSelected = false;\n      item.currentSet = false;\n      return item;\n    });\n\n    this.checkFilterActiveValue();\n\n    this.isButtonAvailable = true;\n    this.filterActiveArray = [];\n    this.totalFiltersNum = 0;\n\n    const action = 'Clear';\n    const data = {\n      action,\n      type: this.type,\n      filterType: this.type,\n      queryParams: [],\n    };\n\n    return data;\n  }\n\n  public sortItems(): void {\n    const sortResult = FilterHelper.sortItemsCount(\n      this.loadStatusOptionsArray,\n      this.selectedUser,\n      this.isAscendingSortOrder\n    );\n\n    this.loadStatusOptionsArray = sortResult.sortedFilterArray;\n    this.selectedUser = sortResult.sortedSelectedFilterArray;\n    this.isAscendingSortOrder = sortResult.isAscendingSortOrder;\n  }\n\n  private watchLoadStatusFilterValueChanges(): void {\n    this.type = ToolbarFilterStringEnum.STATUS_FILTER;\n    this.tableService.currentLoadStatusFilterOptions\n      .pipe(takeUntil(this.destroy$))\n      .subscribe((res) => {\n        if (res && this.type === LoadFilterStringEnum.STATUS_FILTER) {\n          this.loadStatusOptionsArray = res.options;\n        }\n      });\n  }\n\n  public addToSelectedUser(item: ArrayStatus, indx: number) {\n    const mainArray = this.loadStatusOptionsArray;\n\n    mainArray[indx].isSelected = true;\n\n    this.unselectedVisibleCount = mainArray.filter(\n      (status) => !status.isSelected\n    )?.length;\n\n    this.selectedUser.push(item);\n\n    this.checkFilterActiveValue();\n  }\n\n  public removeFromSelectedUser(item: ArrayStatus, indx: number): void {\n    this.selectedUser.splice(indx, 1);\n    const id = item.id;\n    const mainArray = this.loadStatusOptionsArray;\n\n    mainArray.forEach((status) => {\n      if (status.id === id) {\n        status.isSelected = false;\n      }\n    });\n\n    this.unselectedVisibleCount = mainArray.filter(\n      (status) => !status.isSelected\n    )?.length;\n\n    this.checkFilterActiveValue();\n  }\n\n  public checkFilterActiveValue(): void {\n    const filterCheck = FilterHelper.checkFilterActiveValue(\n      this.selectedUser,\n      this.filterActiveArray,\n      this.isButtonAvailable\n    );\n\n    this.isButtonAvailable = filterCheck.isButtonAvailable;\n  }\n\n  public getSvgPath(propertyName: keyof typeof CaFiltersSvgRoutes): string {\n    return FilterHelper.getSvgPath(propertyName);\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n}\n","<div class=\"border-filter\"></div>\n<div class=\"user-holder\" *ngIf=\"type === 'statusFilter'\">\n  <div class=\"status-data-main-holder\">\n    <ng-container\n      *ngFor=\"let item of selectedUser; let indx = index; trackBy: trackByIndex\"\n    >\n      <div class=\"user-frame-holder d-flex align-items-center\">\n        <div\n          class=\"selected-user-holder d-flex flex-column justify-content-start align-items-start\"\n        >\n          <div\n            class=\"user-main-holder\"\n            [@inOutAnimation]=\"'in'\"\n            [@showAnimation]=\"!!isFilterActive\"\n            (click)=\"removeFromSelectedUser(item, indx)\"\n          >\n            <div\n              class=\"selected-user-frame d-flex align-items-center ca-font-bold\"\n            >\n              <div class=\"user-profile-img d-flex align-items-center\">\n                <div\n                  class=\"status-circle\"\n                  [ngStyle]=\"\n                    loadStatusEnum[item.id!] | dropdownLoadStatusColor: true\n                  \"\n                ></div>\n              </div>\n              <div\n                class=\"selected-name-text d-flex align-items-center\"\n                [class.text-uppercase]=\"type === 'statusFilter'\"\n              >\n                <div\n                  class=\"selected-name-text d-flex align-items-center\"\n                  [class.text-uppercase]=\"type === 'statusFilter'\"\n                >\n                  <span> {{ item.name }}</span>\n                </div>\n              </div>\n              <ng-container *ngIf=\"item?.count; else noCount\">\n                <span\n                  class=\"count-holder d-flex align-items-center justify-content-center activeCount ca-font-semi-bold\"\n                >\n                  {{ item.count }}\n                </span>\n              </ng-container>\n\n              <ng-template #noCount>\n                <ng-container *ngIf=\"!item.count; else noCounter\">\n                  <div class=\"selected-icon\">\n                    <svg-icon\n                      [src]=\"getSvgPath('removeSelectedValue')\"\n                    ></svg-icon>\n                  </div>\n                </ng-container>\n                <ng-template #noCounter>\n                  <div class=\"counter-holder activeCounter\">2</div>\n                </ng-template>\n              </ng-template>\n              <div\n                (click)=\"removeFromSelectedUser(item, indx)\"\n                class=\"icon-delete d-flex\"\n                [class.counterMargin]=\"item.count\"\n              >\n                <svg-icon [src]=\"getSvgPath('removeSelectedValue')\"></svg-icon>\n              </div>\n            </div>\n          </div>\n        </div>\n      </div>\n      <div\n        *ngIf=\"selectedUser.length > 0 && unselectedVisibleCount\"\n        class=\"border-filter border-thrird-margin\"\n      ></div>\n    </ng-container>\n\n    <ng-container\n      *ngFor=\"\n        let item of loadStatusOptionsArray;\n        let indx = index;\n        trackBy: trackByIndex\n      \"\n    >\n      <div class=\"user-frame-holder d-flex align-items-center\">\n        <ng-container *ngIf=\"!item.hidden && !item.isSelected\">\n          <div\n            [@inOutAnimation]=\"'in'\"\n            [@showAnimation]=\"!!isFilterActive\"\n            (click)=\"addToSelectedUser(item, indx)\"\n            class=\"user-main-holder d-flex align-items-center justify-content-center;\"\n          >\n            <div class=\"user-profile-img d-flex align-items-center\">\n              <div\n                class=\"status-circle\"\n                [ngStyle]=\"\n                  loadStatusEnum[item.id!] | dropdownLoadStatusColor: true\n                \"\n              ></div>\n            </div>\n            <div\n              class=\"user-frame d-flex justify-content-between align-items-center fw-normal\"\n            >\n              <div\n                class=\"selected-name-text text-uppercase d-flex align-items-center\"\n              >\n                <span> {{ item.name }} </span>\n              </div>\n\n              <ng-container *ngIf=\"item?.count\">\n                <span\n                  class=\"count-holder d-flex align-items-center justify-content-center ca-font-semi-bold\"\n                >\n                  {{ item.count }}\n                </span>\n              </ng-container>\n            </div>\n          </div>\n        </ng-container>\n      </div>\n    </ng-container>\n  </div>\n</div>\n<ng-container\n  *ngIf=\"\n    !isLegendView && (type === 'statusFilter' || type === 'dispatcherFilter')\n  \"\n>\n  <div class=\"border-filter\"></div>\n</ng-container>\n"]}