cps-ui-kit 0.134.0 → 0.136.0

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/esm2020/lib/components/cps-autocomplete/cps-autocomplete.component.mjs +3 -3
  2. package/esm2020/lib/components/cps-datepicker/cps-datepicker.component.mjs +3 -3
  3. package/esm2020/lib/components/cps-select/cps-select.component.mjs +3 -3
  4. package/esm2020/lib/components/cps-table/components/internal/cps-sort-icon/cps-sort-icon.component.mjs +79 -0
  5. package/esm2020/lib/components/cps-table/components/internal/table-column-filter/table-column-filter.component.mjs +344 -0
  6. package/esm2020/lib/components/cps-table/components/internal/table-column-filter-constraint/table-column-filter-constraint.component.mjs +120 -0
  7. package/esm2020/lib/components/cps-table/cps-table.component.mjs +3 -3
  8. package/esm2020/lib/components/cps-table/directives/cps-table-column-filter.directive.mjs +2 -2
  9. package/esm2020/lib/components/cps-table/directives/cps-table-column-sortable.directive.mjs +5 -3
  10. package/esm2020/lib/components/cps-tree-autocomplete/cps-tree-autocomplete.component.mjs +3 -3
  11. package/esm2020/lib/components/cps-tree-select/cps-tree-select.component.mjs +3 -3
  12. package/esm2020/lib/components/cps-tree-table/cps-tree-table.component.mjs +279 -105
  13. package/esm2020/lib/components/cps-tree-table/directives/cps-tree-table-column-filter.directive.mjs +2 -2
  14. package/esm2020/lib/components/cps-tree-table/directives/cps-tree-table-column-sortable.directive.mjs +4 -3
  15. package/esm2020/lib/components/cps-tree-table/directives/cps-tree-table-header-selectable.directive.mjs +2 -1
  16. package/esm2020/lib/components/cps-tree-table/directives/cps-tree-table-row-selectable.directive.mjs +2 -1
  17. package/esm2020/lib/components/cps-tree-table/directives/cps-tree-table-row-toggler.directive.mjs +2 -1
  18. package/fesm2015/cps-ui-kit.mjs +529 -320
  19. package/fesm2015/cps-ui-kit.mjs.map +1 -1
  20. package/fesm2020/cps-ui-kit.mjs +520 -316
  21. package/fesm2020/cps-ui-kit.mjs.map +1 -1
  22. package/lib/components/cps-table/components/internal/cps-sort-icon/cps-sort-icon.component.d.ts +24 -0
  23. package/lib/components/cps-table/{table-column-filter → components/internal/table-column-filter}/table-column-filter.component.d.ts +6 -3
  24. package/lib/components/cps-table/{table-column-filter → components/internal}/table-column-filter-constraint/table-column-filter-constraint.component.d.ts +3 -3
  25. package/lib/components/cps-table/directives/cps-table-column-filter.directive.d.ts +1 -1
  26. package/lib/components/cps-table/directives/cps-table-column-sortable.directive.d.ts +3 -2
  27. package/lib/components/cps-tree-table/cps-tree-table.component.d.ts +22 -13
  28. package/lib/components/cps-tree-table/directives/cps-tree-table-column-filter.directive.d.ts +1 -1
  29. package/lib/components/cps-tree-table/directives/cps-tree-table-column-sortable.directive.d.ts +2 -2
  30. package/package.json +1 -1
  31. package/styles/_colors.scss +2 -0
  32. package/esm2020/lib/components/cps-table/table-column-filter/table-column-filter-constraint/table-column-filter-constraint.component.mjs +0 -120
  33. package/esm2020/lib/components/cps-table/table-column-filter/table-column-filter.component.mjs +0 -322
  34. package/esm2020/lib/components/cps-tree-table/tree-table-sort-icon/tree-table-sort-icon.component.mjs +0 -71
  35. package/lib/components/cps-tree-table/tree-table-sort-icon/tree-table-sort-icon.component.d.ts +0 -21
@@ -0,0 +1,24 @@
1
+ import { ChangeDetectorRef, OnDestroy, OnInit } from '@angular/core';
2
+ import { Table } from 'primeng/table';
3
+ import { TreeTable } from 'primeng/treetable';
4
+ import { Subscription } from 'rxjs';
5
+ import * as i0 from "@angular/core";
6
+ export declare class CpsSortIconComponent implements OnInit, OnDestroy {
7
+ dt: Table;
8
+ tt: TreeTable;
9
+ cd: ChangeDetectorRef;
10
+ field: string;
11
+ subscription: Subscription;
12
+ sortOrder: number;
13
+ _tableInstance: Table | TreeTable;
14
+ constructor(dt: Table, tt: TreeTable, cd: ChangeDetectorRef);
15
+ ngOnInit(): void;
16
+ onClick(event: Event): void;
17
+ updateSortState(): void;
18
+ getMultiSortMetaIndex(): number;
19
+ getBadgeValue(): number;
20
+ isMultiSorted(): boolean;
21
+ ngOnDestroy(): void;
22
+ static ɵfac: i0.ɵɵFactoryDeclaration<CpsSortIconComponent, [{ optional: true; }, { optional: true; }, null]>;
23
+ static ɵcmp: i0.ɵɵComponentDeclaration<CpsSortIconComponent, "cps-sort-icon", never, { "field": "field"; }, {}, never, never, true, never>;
24
+ }
@@ -1,10 +1,10 @@
1
1
  import { ElementRef, OnDestroy, OnInit, QueryList } from '@angular/core';
2
2
  import { FilterMetadata, SelectItem } from 'primeng/api';
3
3
  import { Table } from 'primeng/table';
4
- import { CpsMenuComponent } from '../../cps-menu/cps-menu.component';
5
- import { TableColumnFilterConstraintComponent } from './table-column-filter-constraint/table-column-filter-constraint.component';
6
4
  import { TreeTable } from 'primeng/treetable';
7
- import { CpsColumnFilterCategoryOption, CpsColumnFilterMatchMode, CpsColumnFilterType } from '../cps-column-filter-types';
5
+ import { CpsColumnFilterCategoryOption, CpsColumnFilterMatchMode, CpsColumnFilterType } from '../../../cps-column-filter-types';
6
+ import { CpsMenuComponent } from '../../../../cps-menu/cps-menu.component';
7
+ import { TableColumnFilterConstraintComponent } from '../table-column-filter-constraint/table-column-filter-constraint.component';
8
8
  import * as i0 from "@angular/core";
9
9
  export declare class TableColumnFilterComponent implements OnInit, OnDestroy {
10
10
  elementRef: ElementRef;
@@ -63,6 +63,9 @@ export declare class TableColumnFilterComponent implements OnInit, OnDestroy {
63
63
  onBeforeMenuHidden(): void;
64
64
  onMenuHidden(): void;
65
65
  onClick(event: any): void;
66
+ private _updateSortIconColor;
67
+ onMouseOver(): void;
68
+ onMouseLeave(): void;
66
69
  ngOnDestroy(): void;
67
70
  static ɵfac: i0.ɵɵFactoryDeclaration<TableColumnFilterComponent, [null, { optional: true; }, { optional: true; }]>;
68
71
  static ɵcmp: i0.ɵɵComponentDeclaration<TableColumnFilterComponent, "table-column-filter", never, { "field": "field"; "type": "type"; "persistent": "persistent"; "showClearButton": "showClearButton"; "showApplyButton": "showApplyButton"; "showCloseButton": "showCloseButton"; "showMatchModes": "showMatchModes"; "matchModes": "matchModes"; "showOperator": "showOperator"; "maxConstraints": "maxConstraints"; "headerTitle": "headerTitle"; "hideOnClear": "hideOnClear"; "categoryOptions": "categoryOptions"; "asButtonToggle": "asButtonToggle"; "singleSelection": "singleSelection"; "placeholder": "placeholder"; }, {}, never, never, true, never>;
@@ -1,10 +1,10 @@
1
1
  import { OnChanges } from '@angular/core';
2
2
  import { FilterMetadata } from 'primeng/api';
3
3
  import { Table } from 'primeng/table';
4
- import { CpsAutocompleteComponent } from '../../../cps-autocomplete/cps-autocomplete.component';
5
- import { CpsButtonToggleOption } from '../../../cps-button-toggle/cps-button-toggle.component';
6
4
  import { TreeTable } from 'primeng/treetable';
7
- import { CpsColumnFilterCategoryOption, CpsColumnFilterType } from '../../cps-column-filter-types';
5
+ import { CpsButtonToggleOption } from '../../../../cps-button-toggle/cps-button-toggle.component';
6
+ import { CpsAutocompleteComponent } from '../../../../cps-autocomplete/cps-autocomplete.component';
7
+ import { CpsColumnFilterCategoryOption, CpsColumnFilterType } from '../../../cps-column-filter-types';
8
8
  import * as i0 from "@angular/core";
9
9
  export declare class TableColumnFilterConstraintComponent implements OnChanges {
10
10
  dt: Table;
@@ -1,6 +1,6 @@
1
1
  import { ComponentRef, ElementRef, OnDestroy, OnInit, OnChanges, ViewContainerRef } from '@angular/core';
2
- import { TableColumnFilterComponent } from '../table-column-filter/table-column-filter.component';
3
2
  import { CpsColumnFilterCategoryOption, CpsColumnFilterMatchMode, CpsColumnFilterType } from '../cps-column-filter-types';
3
+ import { TableColumnFilterComponent } from '../components/internal/table-column-filter/table-column-filter.component';
4
4
  import * as i0 from "@angular/core";
5
5
  export declare class CpsTableColumnFilterDirective implements OnInit, OnChanges, OnDestroy {
6
6
  private elementRef;
@@ -1,12 +1,13 @@
1
1
  import { ComponentRef, ElementRef, OnDestroy, OnInit, ViewContainerRef } from '@angular/core';
2
- import { SortIcon, SortableColumn, Table } from 'primeng/table';
2
+ import { SortableColumn, Table } from 'primeng/table';
3
+ import { CpsSortIconComponent } from '../components/internal/cps-sort-icon/cps-sort-icon.component';
3
4
  import * as i0 from "@angular/core";
4
5
  export declare class CpsTableColumnSortableDirective extends SortableColumn implements OnInit, OnDestroy {
5
6
  private elementRef;
6
7
  private viewContainerRef;
7
8
  dt: Table;
8
9
  field: string;
9
- sortIconRef: ComponentRef<SortIcon>;
10
+ sortIconRef: ComponentRef<CpsSortIconComponent>;
10
11
  constructor(elementRef: ElementRef, viewContainerRef: ViewContainerRef, dt: Table);
11
12
  ngOnInit(): void;
12
13
  ngOnDestroy(): void;
@@ -18,6 +18,11 @@ export declare class CpsTreeTableComponent implements OnInit, AfterViewInit, OnD
18
18
  colFieldName: string;
19
19
  minWidth: number | string;
20
20
  minWidthForBodyOnly: boolean;
21
+ /**
22
+ * Whether the cell widths scale according to their content or not.
23
+ * @group Props
24
+ */
25
+ autoLayout: boolean;
21
26
  striped: boolean;
22
27
  bordered: boolean;
23
28
  size: CpsTreeTableSize;
@@ -107,27 +112,32 @@ export declare class CpsTreeTableComponent implements OnInit, AfterViewInit, OnD
107
112
  }[];
108
113
  selectedRows: any[];
109
114
  virtualScrollItemSize: number;
110
- defScrollHeightPx: number;
111
- defScrollHeightPxInitial: number;
112
115
  defScrollHeight: string;
113
- resizeObserver: ResizeObserver;
114
- windowResizeDebouncer: any;
115
- headerBox: any;
116
- scrollableBody: any;
117
- scrollbarWidth: number;
116
+ private _defScrollHeightPx;
117
+ private _defScrollHeightPxInitial;
118
+ private _resizeObserver;
119
+ private _windowResizeDebouncer;
120
+ private _scrollSubscription?;
121
+ private _headerBox;
122
+ private _scrollableBody;
123
+ private _scrollbarWidth;
124
+ private _scrollbarVisible;
125
+ private _needRecalcAutoLayout;
118
126
  constructor(cdRef: ChangeDetectorRef);
119
127
  ngOnInit(): void;
120
128
  ngAfterViewInit(): void;
121
- private _updateVirtualScrollItemSize;
122
129
  ngAfterViewChecked(): void;
123
- private _setMinWidthOverall;
124
130
  ngOnChanges(changes: SimpleChanges): void;
125
131
  ngOnDestroy(): void;
126
- clearGlobalFilter(): void;
132
+ private _calcAutoLayoutHeaderWidths;
133
+ private _updateVirtualScrollItemSize;
134
+ private _setMinWidthOverall;
127
135
  private _onWindowResize;
128
136
  get styleClass(): string;
129
- onSortFunction(event: SortEvent): void;
130
137
  private _recalcVirtualHeight;
138
+ private _removeNodeFromData;
139
+ clearGlobalFilter(): void;
140
+ onSortFunction(event: SortEvent): void;
131
141
  onFilterGlobal(value: string): void;
132
142
  onClickAdditionalBtnOnSelect(): void;
133
143
  onClickActionBtn(): void;
@@ -137,7 +147,6 @@ export declare class CpsTreeTableComponent implements OnInit, AfterViewInit, OnD
137
147
  clearSelection(): void;
138
148
  onEditRowClicked(node: any): void;
139
149
  onRemoveRowClicked(node: any): void;
140
- private _removeNodeFromData;
141
150
  toggleAllColumns(): void;
142
151
  isColumnSelected(col: any): boolean;
143
152
  onRowsPerPageChanged(): void;
@@ -155,5 +164,5 @@ export declare class CpsTreeTableComponent implements OnInit, AfterViewInit, OnD
155
164
  onSelectColumn(col: any): void;
156
165
  onSelectionChanged(selection: any[]): void;
157
166
  static ɵfac: i0.ɵɵFactoryDeclaration<CpsTreeTableComponent, never>;
158
- static ɵcmp: i0.ɵɵComponentDeclaration<CpsTreeTableComponent, "cps-tree-table", never, { "data": "data"; "columns": "columns"; "colHeaderName": "colHeaderName"; "colFieldName": "colFieldName"; "minWidth": "minWidth"; "minWidthForBodyOnly": "minWidthForBodyOnly"; "striped": "striped"; "bordered": "bordered"; "size": "size"; "selectable": "selectable"; "rowHover": "rowHover"; "showRowMenu": "showRowMenu"; "loading": "loading"; "tableStyle": "tableStyle"; "tableStyleClass": "tableStyleClass"; "sortable": "sortable"; "sortMode": "sortMode"; "customSort": "customSort"; "hasToolbar": "hasToolbar"; "toolbarSize": "toolbarSize"; "toolbarTitle": "toolbarTitle"; "toolbarIcon": "toolbarIcon"; "toolbarIconColor": "toolbarIconColor"; "scrollable": "scrollable"; "scrollHeight": "scrollHeight"; "virtualScroll": "virtualScroll"; "virtualScrollItemHeight": "virtualScrollItemHeight"; "numToleratedItems": "numToleratedItems"; "paginator": "paginator"; "alwaysShowPaginator": "alwaysShowPaginator"; "rowsPerPageOptions": "rowsPerPageOptions"; "first": "first"; "rows": "rows"; "resetPageOnRowsChange": "resetPageOnRowsChange"; "resetPageOnSort": "resetPageOnSort"; "totalRecords": "totalRecords"; "emptyMessage": "emptyMessage"; "emptyBodyHeight": "emptyBodyHeight"; "lazy": "lazy"; "lazyLoadOnInit": "lazyLoadOnInit"; "showGlobalFilter": "showGlobalFilter"; "globalFilterPlaceholder": "globalFilterPlaceholder"; "globalFilterFields": "globalFilterFields"; "clearGlobalFilterOnLoading": "clearGlobalFilterOnLoading"; "showRemoveBtnOnSelect": "showRemoveBtnOnSelect"; "removeBtnOnSelectDisabled": "removeBtnOnSelectDisabled"; "showAdditionalBtnOnSelect": "showAdditionalBtnOnSelect"; "additionalBtnOnSelectTitle": "additionalBtnOnSelectTitle"; "additionalBtnOnSelectDisabled": "additionalBtnOnSelectDisabled"; "showActionBtn": "showActionBtn"; "actionBtnTitle": "actionBtnTitle"; "actionBtnDisabled": "actionBtnDisabled"; "showDataReloadBtn": "showDataReloadBtn"; "dataReloadBtnDisabled": "dataReloadBtnDisabled"; "showColumnsToggleBtn": "showColumnsToggleBtn"; "columnsToggleBtnDisabled": "columnsToggleBtnDisabled"; }, { "selectionChanged": "selectionChanged"; "actionBtnClicked": "actionBtnClicked"; "additionalBtnOnSelectClicked": "additionalBtnOnSelectClicked"; "editRowBtnClicked": "editRowBtnClicked"; "rowsRemoved": "rowsRemoved"; "pageChanged": "pageChanged"; "sorted": "sorted"; "filtered": "filtered"; "columnsSelected": "columnsSelected"; "lazyLoaded": "lazyLoaded"; "dataReloadBtnClicked": "dataReloadBtnClicked"; "nodeExpanded": "nodeExpanded"; "nodeCollapsed": "nodeCollapsed"; "nodeSelected": "nodeSelected"; "nodeUnselected": "nodeUnselected"; "customSortFunction": "customSortFunction"; }, ["toolbarTemplate", "headerTemplate", "nestedHeaderTemplate", "bodyTemplate"], never, true, never>;
167
+ static ɵcmp: i0.ɵɵComponentDeclaration<CpsTreeTableComponent, "cps-tree-table", never, { "data": "data"; "columns": "columns"; "colHeaderName": "colHeaderName"; "colFieldName": "colFieldName"; "minWidth": "minWidth"; "minWidthForBodyOnly": "minWidthForBodyOnly"; "autoLayout": "autoLayout"; "striped": "striped"; "bordered": "bordered"; "size": "size"; "selectable": "selectable"; "rowHover": "rowHover"; "showRowMenu": "showRowMenu"; "loading": "loading"; "tableStyle": "tableStyle"; "tableStyleClass": "tableStyleClass"; "sortable": "sortable"; "sortMode": "sortMode"; "customSort": "customSort"; "hasToolbar": "hasToolbar"; "toolbarSize": "toolbarSize"; "toolbarTitle": "toolbarTitle"; "toolbarIcon": "toolbarIcon"; "toolbarIconColor": "toolbarIconColor"; "scrollable": "scrollable"; "scrollHeight": "scrollHeight"; "virtualScroll": "virtualScroll"; "virtualScrollItemHeight": "virtualScrollItemHeight"; "numToleratedItems": "numToleratedItems"; "paginator": "paginator"; "alwaysShowPaginator": "alwaysShowPaginator"; "rowsPerPageOptions": "rowsPerPageOptions"; "first": "first"; "rows": "rows"; "resetPageOnRowsChange": "resetPageOnRowsChange"; "resetPageOnSort": "resetPageOnSort"; "totalRecords": "totalRecords"; "emptyMessage": "emptyMessage"; "emptyBodyHeight": "emptyBodyHeight"; "lazy": "lazy"; "lazyLoadOnInit": "lazyLoadOnInit"; "showGlobalFilter": "showGlobalFilter"; "globalFilterPlaceholder": "globalFilterPlaceholder"; "globalFilterFields": "globalFilterFields"; "clearGlobalFilterOnLoading": "clearGlobalFilterOnLoading"; "showRemoveBtnOnSelect": "showRemoveBtnOnSelect"; "removeBtnOnSelectDisabled": "removeBtnOnSelectDisabled"; "showAdditionalBtnOnSelect": "showAdditionalBtnOnSelect"; "additionalBtnOnSelectTitle": "additionalBtnOnSelectTitle"; "additionalBtnOnSelectDisabled": "additionalBtnOnSelectDisabled"; "showActionBtn": "showActionBtn"; "actionBtnTitle": "actionBtnTitle"; "actionBtnDisabled": "actionBtnDisabled"; "showDataReloadBtn": "showDataReloadBtn"; "dataReloadBtnDisabled": "dataReloadBtnDisabled"; "showColumnsToggleBtn": "showColumnsToggleBtn"; "columnsToggleBtnDisabled": "columnsToggleBtnDisabled"; }, { "selectionChanged": "selectionChanged"; "actionBtnClicked": "actionBtnClicked"; "additionalBtnOnSelectClicked": "additionalBtnOnSelectClicked"; "editRowBtnClicked": "editRowBtnClicked"; "rowsRemoved": "rowsRemoved"; "pageChanged": "pageChanged"; "sorted": "sorted"; "filtered": "filtered"; "columnsSelected": "columnsSelected"; "lazyLoaded": "lazyLoaded"; "dataReloadBtnClicked": "dataReloadBtnClicked"; "nodeExpanded": "nodeExpanded"; "nodeCollapsed": "nodeCollapsed"; "nodeSelected": "nodeSelected"; "nodeUnselected": "nodeUnselected"; "customSortFunction": "customSortFunction"; }, ["toolbarTemplate", "headerTemplate", "nestedHeaderTemplate", "bodyTemplate"], never, true, never>;
159
168
  }
@@ -1,5 +1,5 @@
1
1
  import { ComponentRef, ElementRef, OnDestroy, OnInit, OnChanges, ViewContainerRef } from '@angular/core';
2
- import { TableColumnFilterComponent } from '../../cps-table/table-column-filter/table-column-filter.component';
2
+ import { TableColumnFilterComponent } from '../../cps-table/components/internal/table-column-filter/table-column-filter.component';
3
3
  import { CpsColumnFilterType, CpsColumnFilterMatchMode, CpsColumnFilterCategoryOption } from '../../cps-table/cps-column-filter-types';
4
4
  import * as i0 from "@angular/core";
5
5
  export declare class CpsTreeTableColumnFilterDirective implements OnInit, OnChanges, OnDestroy {
@@ -1,13 +1,13 @@
1
1
  import { ComponentRef, ElementRef, OnDestroy, OnInit, ViewContainerRef } from '@angular/core';
2
2
  import { TTSortableColumn, TreeTable } from 'primeng/treetable';
3
- import { TreeTableSortIconComponent } from '../tree-table-sort-icon/tree-table-sort-icon.component';
3
+ import { CpsSortIconComponent } from '../../cps-table/components/internal/cps-sort-icon/cps-sort-icon.component';
4
4
  import * as i0 from "@angular/core";
5
5
  export declare class CpsTreeTableColumnSortableDirective extends TTSortableColumn implements OnInit, OnDestroy {
6
6
  private elementRef;
7
7
  private viewContainerRef;
8
8
  tt: TreeTable;
9
9
  field: string;
10
- sortIconRef: ComponentRef<TreeTableSortIconComponent>;
10
+ sortIconRef: ComponentRef<CpsSortIconComponent>;
11
11
  constructor(elementRef: ElementRef, viewContainerRef: ViewContainerRef, tt: TreeTable);
12
12
  ngOnInit(): void;
13
13
  ngOnDestroy(): void;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "cps-ui-kit",
3
- "version": "0.134.0",
3
+ "version": "0.136.0",
4
4
  "peerDependencies": {
5
5
  "@angular/common": "15 - 16",
6
6
  "@angular/core": "15 - 16",
@@ -251,6 +251,8 @@
251
251
  // Highlights
252
252
  --cps-color-highlight-hover: #f8f4f5;
253
253
  --cps-color-highlight-active: #f1eaec;
254
+ --cps-color-highlight-selected: #efe4e7;
255
+ --cps-color-highlight-selected-dark: #e6d4d9;
254
256
 
255
257
  //Backgrounds
256
258
  --cps-color-bg-light: #f9f8f8;
@@ -1,120 +0,0 @@
1
- import { Component, Input, Optional, ViewChild } from '@angular/core';
2
- import { CommonModule } from '@angular/common';
3
- import { FormsModule } from '@angular/forms';
4
- import { Table } from 'primeng/table';
5
- import { CpsInputComponent } from '../../../cps-input/cps-input.component';
6
- import { CpsDatepickerComponent } from '../../../cps-datepicker/cps-datepicker.component';
7
- import { CpsAutocompleteComponent } from '../../../cps-autocomplete/cps-autocomplete.component';
8
- import { CpsButtonToggleComponent } from '../../../cps-button-toggle/cps-button-toggle.component';
9
- import * as i0 from "@angular/core";
10
- import * as i1 from "primeng/table";
11
- import * as i2 from "primeng/treetable";
12
- import * as i3 from "@angular/common";
13
- export class TableColumnFilterConstraintComponent {
14
- get isCategoryDropdownOpened() {
15
- return this.categoryAutocompleteComponent?.isOpened || false;
16
- }
17
- constructor(dt, tt) {
18
- this.dt = dt;
19
- this.tt = tt;
20
- this.type = 'text';
21
- this.categoryOptions = [];
22
- this.asButtonToggle = false; // for category type only
23
- this.singleSelection = false; // for category type only
24
- this.placeholder = '';
25
- this.hasApplyButton = true;
26
- this.booleanOptions = [
27
- { label: 'True', value: 'true' },
28
- { label: 'False', value: 'false' }
29
- ];
30
- this.categories = [];
31
- this._tableInstance = dt || tt;
32
- }
33
- ngOnChanges() {
34
- this._updateCategories();
35
- }
36
- _updateCategories() {
37
- if (this.type !== 'category')
38
- return;
39
- if (this.categoryOptions.length > 0) {
40
- if (typeof this.categoryOptions[0] === 'string') {
41
- this.categories = this.categoryOptions.map((o) => ({
42
- label: o,
43
- value: o
44
- }));
45
- }
46
- else {
47
- this.categories = this
48
- .categoryOptions;
49
- }
50
- }
51
- else {
52
- let cats = [];
53
- if (this._tableInstance instanceof Table) {
54
- cats =
55
- this._tableInstance.value?.map((v) => v[this.field]) || [];
56
- }
57
- else {
58
- const fillCats = (nodes) => {
59
- nodes?.forEach((v) => {
60
- cats.push(v.data[this.field]);
61
- fillCats(v.children);
62
- });
63
- };
64
- fillCats(this._tableInstance.value);
65
- }
66
- this.categories =
67
- Array.from(new Set(cats))?.map((c) => ({
68
- label: c,
69
- value: c
70
- })) || [];
71
- }
72
- }
73
- onValueChange(value) {
74
- this.filterConstraint.value = value;
75
- if (this._tableInstance.isFilterBlank(value) || !this.hasApplyButton) {
76
- this._tableInstance._filter();
77
- }
78
- }
79
- onEnterKeyDown(event) {
80
- this._tableInstance._filter();
81
- event.preventDefault();
82
- }
83
- }
84
- TableColumnFilterConstraintComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TableColumnFilterConstraintComponent, deps: [{ token: i1.Table, optional: true }, { token: i2.TreeTable, optional: true }], target: i0.ɵɵFactoryTarget.Component });
85
- TableColumnFilterConstraintComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: TableColumnFilterConstraintComponent, isStandalone: true, selector: "table-column-filter-constraint", inputs: { type: "type", field: "field", filterConstraint: "filterConstraint", categoryOptions: "categoryOptions", asButtonToggle: "asButtonToggle", singleSelection: "singleSelection", placeholder: "placeholder", hasApplyButton: "hasApplyButton" }, viewQueries: [{ propertyName: "categoryAutocompleteComponent", first: true, predicate: ["categoryAutocompleteComponent"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<ng-container [ngSwitch]=\"type\">\n <cps-input\n *ngSwitchCase=\"'text'\"\n [placeholder]=\"placeholder\"\n [hideDetails]=\"true\"\n (keydown.enter)=\"onEnterKeyDown($event)\"\n [value]=\"filterConstraint?.value\"\n (valueChanged)=\"onValueChange($event)\"\n type=\"text\"></cps-input>\n\n <cps-input\n *ngSwitchCase=\"'number'\"\n [hideDetails]=\"true\"\n [placeholder]=\"placeholder\"\n (keydown.enter)=\"onEnterKeyDown($event)\"\n [value]=\"filterConstraint?.value\"\n (valueChanged)=\"onValueChange($event)\"\n type=\"number\"></cps-input>\n\n <div\n class=\"cps-table-col-filter-constraint-btn-toggles\"\n *ngSwitchCase=\"'boolean'\">\n <cps-button-toggle\n [options]=\"booleanOptions\"\n [value]=\"filterConstraint?.value\"\n (valueChanged)=\"onValueChange($event)\"\n [mandatory]=\"false\">\n </cps-button-toggle>\n </div>\n\n <cps-datepicker\n *ngSwitchCase=\"'date'\"\n [openOnInputFocus]=\"true\"\n [hideDetails]=\"true\"\n [placeholder]=\"placeholder\"\n [value]=\"filterConstraint?.value\"\n (keydown.enter)=\"onEnterKeyDown($event)\"\n (valueChanged)=\"onValueChange($event)\">\n </cps-datepicker>\n\n <ng-container *ngSwitchCase=\"'category'\">\n <cps-autocomplete\n #categoryAutocompleteComponent\n *ngIf=\"!asButtonToggle\"\n class=\"cps-table-col-filter-category-autocomplete\"\n [placeholder]=\"placeholder\"\n [options]=\"categories\"\n [hideDetails]=\"true\"\n [clearable]=\"true\"\n [value]=\"filterConstraint?.value\"\n (valueChanged)=\"onValueChange($event)\"\n [returnObject]=\"false\"\n [multiple]=\"!singleSelection\">\n </cps-autocomplete>\n <div class=\"cps-table-col-filter-constraint-btn-toggles\">\n <cps-button-toggle\n *ngIf=\"asButtonToggle\"\n [options]=\"categories\"\n [value]=\"filterConstraint?.value\"\n (valueChanged)=\"onValueChange($event)\"\n [mandatory]=\"false\"\n [multiple]=\"!singleSelection\">\n </cps-button-toggle>\n </div>\n </ng-container>\n</ng-container>\n", styles: [":host .cps-table-col-filter-constraint-btn-toggles{display:flex;justify-content:center}:host .cps-table-col-filter-category-autocomplete{min-width:200px;max-width:400px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "ngmodule", type: FormsModule }, { kind: "component", type: CpsInputComponent, selector: "cps-input", inputs: ["label", "hint", "placeholder", "disabled", "readonly", "width", "type", "loading", "clearable", "prefixIcon", "prefixIconClickable", "prefixIconSize", "prefixText", "hideDetails", "persistentClear", "error", "infoTooltip", "infoTooltipClass", "infoTooltipMaxWidth", "infoTooltipPersistent", "infoTooltipPosition", "appearance", "valueToDisplay", "value"], outputs: ["valueChanged", "focused", "prefixIconClicked", "blurred", "cleared", "enterClicked"] }, { kind: "component", type: CpsDatepickerComponent, selector: "cps-datepicker", inputs: ["label", "disabled", "width", "placeholder", "hint", "clearable", "hideDetails", "persistentClear", "showTodayButton", "openOnInputFocus", "infoTooltip", "infoTooltipClass", "infoTooltipMaxWidth", "infoTooltipPersistent", "infoTooltipPosition", "appearance", "minDate", "maxDate", "value"], outputs: ["valueChanged"] }, { kind: "component", type: CpsButtonToggleComponent, selector: "cps-button-toggle", inputs: ["label", "options", "multiple", "disabled", "mandatory", "equalWidths", "optionTooltipPosition", "infoTooltip", "infoTooltipClass", "infoTooltipMaxWidth", "infoTooltipPersistent", "infoTooltipPosition", "value"], outputs: ["valueChanged"] }, { kind: "component", type: CpsAutocompleteComponent, selector: "cps-autocomplete", inputs: ["label", "placeholder", "hint", "returnObject", "multiple", "disabled", "width", "selectAll", "chips", "closableChips", "clearable", "openOnClear", "options", "optionLabel", "optionValue", "optionInfo", "hideDetails", "persistentClear", "prefixIcon", "prefixIconSize", "loading", "emptyMessage", "virtualScroll", "numToleratedItems", "infoTooltip", "infoTooltipClass", "infoTooltipMaxWidth", "infoTooltipPersistent", "infoTooltipPosition", "appearance", "value"], outputs: ["valueChanged"] }] });
86
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TableColumnFilterConstraintComponent, decorators: [{
87
- type: Component,
88
- args: [{ selector: 'table-column-filter-constraint', standalone: true, imports: [
89
- CommonModule,
90
- FormsModule,
91
- CpsInputComponent,
92
- CpsDatepickerComponent,
93
- CpsButtonToggleComponent,
94
- CpsAutocompleteComponent
95
- ], template: "<ng-container [ngSwitch]=\"type\">\n <cps-input\n *ngSwitchCase=\"'text'\"\n [placeholder]=\"placeholder\"\n [hideDetails]=\"true\"\n (keydown.enter)=\"onEnterKeyDown($event)\"\n [value]=\"filterConstraint?.value\"\n (valueChanged)=\"onValueChange($event)\"\n type=\"text\"></cps-input>\n\n <cps-input\n *ngSwitchCase=\"'number'\"\n [hideDetails]=\"true\"\n [placeholder]=\"placeholder\"\n (keydown.enter)=\"onEnterKeyDown($event)\"\n [value]=\"filterConstraint?.value\"\n (valueChanged)=\"onValueChange($event)\"\n type=\"number\"></cps-input>\n\n <div\n class=\"cps-table-col-filter-constraint-btn-toggles\"\n *ngSwitchCase=\"'boolean'\">\n <cps-button-toggle\n [options]=\"booleanOptions\"\n [value]=\"filterConstraint?.value\"\n (valueChanged)=\"onValueChange($event)\"\n [mandatory]=\"false\">\n </cps-button-toggle>\n </div>\n\n <cps-datepicker\n *ngSwitchCase=\"'date'\"\n [openOnInputFocus]=\"true\"\n [hideDetails]=\"true\"\n [placeholder]=\"placeholder\"\n [value]=\"filterConstraint?.value\"\n (keydown.enter)=\"onEnterKeyDown($event)\"\n (valueChanged)=\"onValueChange($event)\">\n </cps-datepicker>\n\n <ng-container *ngSwitchCase=\"'category'\">\n <cps-autocomplete\n #categoryAutocompleteComponent\n *ngIf=\"!asButtonToggle\"\n class=\"cps-table-col-filter-category-autocomplete\"\n [placeholder]=\"placeholder\"\n [options]=\"categories\"\n [hideDetails]=\"true\"\n [clearable]=\"true\"\n [value]=\"filterConstraint?.value\"\n (valueChanged)=\"onValueChange($event)\"\n [returnObject]=\"false\"\n [multiple]=\"!singleSelection\">\n </cps-autocomplete>\n <div class=\"cps-table-col-filter-constraint-btn-toggles\">\n <cps-button-toggle\n *ngIf=\"asButtonToggle\"\n [options]=\"categories\"\n [value]=\"filterConstraint?.value\"\n (valueChanged)=\"onValueChange($event)\"\n [mandatory]=\"false\"\n [multiple]=\"!singleSelection\">\n </cps-button-toggle>\n </div>\n </ng-container>\n</ng-container>\n", styles: [":host .cps-table-col-filter-constraint-btn-toggles{display:flex;justify-content:center}:host .cps-table-col-filter-category-autocomplete{min-width:200px;max-width:400px}\n"] }]
96
- }], ctorParameters: function () { return [{ type: i1.Table, decorators: [{
97
- type: Optional
98
- }] }, { type: i2.TreeTable, decorators: [{
99
- type: Optional
100
- }] }]; }, propDecorators: { type: [{
101
- type: Input
102
- }], field: [{
103
- type: Input
104
- }], filterConstraint: [{
105
- type: Input
106
- }], categoryOptions: [{
107
- type: Input
108
- }], asButtonToggle: [{
109
- type: Input
110
- }], singleSelection: [{
111
- type: Input
112
- }], placeholder: [{
113
- type: Input
114
- }], hasApplyButton: [{
115
- type: Input
116
- }], categoryAutocompleteComponent: [{
117
- type: ViewChild,
118
- args: ['categoryAutocompleteComponent']
119
- }] } });
120
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-column-filter-constraint.component.js","sourceRoot":"","sources":["../../../../../../../../projects/cps-ui-kit/src/lib/components/cps-table/table-column-filter/table-column-filter-constraint/table-column-filter-constraint.component.ts","../../../../../../../../projects/cps-ui-kit/src/lib/components/cps-table/table-column-filter/table-column-filter-constraint/table-column-filter-constraint.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  OnChanges,\n  Optional,\n  ViewChild\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport { FilterMetadata } from 'primeng/api';\nimport { Table } from 'primeng/table';\nimport { CpsInputComponent } from '../../../cps-input/cps-input.component';\nimport { CpsDatepickerComponent } from '../../../cps-datepicker/cps-datepicker.component';\nimport { CpsAutocompleteComponent } from '../../../cps-autocomplete/cps-autocomplete.component';\nimport {\n  CpsButtonToggleOption,\n  CpsButtonToggleComponent\n} from '../../../cps-button-toggle/cps-button-toggle.component';\nimport { TreeTable } from 'primeng/treetable';\nimport {\n  CpsColumnFilterCategoryOption,\n  CpsColumnFilterType\n} from '../../cps-column-filter-types';\n\n@Component({\n  selector: 'table-column-filter-constraint',\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    CpsInputComponent,\n    CpsDatepickerComponent,\n    CpsButtonToggleComponent,\n    CpsAutocompleteComponent\n  ],\n  templateUrl: './table-column-filter-constraint.component.html',\n  styleUrls: ['./table-column-filter-constraint.component.scss']\n})\nexport class TableColumnFilterConstraintComponent implements OnChanges {\n  @Input() type: CpsColumnFilterType = 'text';\n  @Input() field: string | undefined;\n  @Input() filterConstraint: FilterMetadata | undefined;\n  @Input() categoryOptions: CpsColumnFilterCategoryOption[] | string[] = [];\n  @Input() asButtonToggle = false; // for category type only\n  @Input() singleSelection = false; // for category type only\n  @Input() placeholder = '';\n  @Input() hasApplyButton = true;\n\n  @ViewChild('categoryAutocompleteComponent')\n  categoryAutocompleteComponent?: CpsAutocompleteComponent;\n\n  booleanOptions = [\n    { label: 'True', value: 'true' },\n    { label: 'False', value: 'false' }\n  ] as CpsButtonToggleOption[];\n\n  categories: CpsColumnFilterCategoryOption[] = [];\n\n  _tableInstance: Table | TreeTable;\n\n  get isCategoryDropdownOpened() {\n    return this.categoryAutocompleteComponent?.isOpened || false;\n  }\n\n  constructor(@Optional() public dt: Table, @Optional() public tt: TreeTable) {\n    this._tableInstance = dt || tt;\n  }\n\n  ngOnChanges(): void {\n    this._updateCategories();\n  }\n\n  private _updateCategories() {\n    if (this.type !== 'category') return;\n    if (this.categoryOptions.length > 0) {\n      if (typeof this.categoryOptions[0] === 'string') {\n        this.categories = (this.categoryOptions as string[]).map((o) => ({\n          label: o,\n          value: o\n        }));\n      } else {\n        this.categories = this\n          .categoryOptions as CpsColumnFilterCategoryOption[];\n      }\n    } else {\n      let cats = [];\n      if (this._tableInstance instanceof Table) {\n        cats =\n          this._tableInstance.value?.map((v) => v[this.field as string]) || [];\n      } else {\n        const fillCats = (nodes: any[]) => {\n          nodes?.forEach((v) => {\n            cats.push(v.data[this.field as string]);\n            fillCats(v.children);\n          });\n        };\n        fillCats(this._tableInstance.value);\n      }\n      this.categories =\n        Array.from(new Set(cats))?.map((c) => ({\n          label: c,\n          value: c\n        })) || [];\n    }\n  }\n\n  onValueChange(value: any) {\n    (<any>this.filterConstraint).value = value;\n\n    if (this._tableInstance.isFilterBlank(value) || !this.hasApplyButton) {\n      this._tableInstance._filter();\n    }\n  }\n\n  onEnterKeyDown(event: any) {\n    this._tableInstance._filter();\n    event.preventDefault();\n  }\n}\n","<ng-container [ngSwitch]=\"type\">\n  <cps-input\n    *ngSwitchCase=\"'text'\"\n    [placeholder]=\"placeholder\"\n    [hideDetails]=\"true\"\n    (keydown.enter)=\"onEnterKeyDown($event)\"\n    [value]=\"filterConstraint?.value\"\n    (valueChanged)=\"onValueChange($event)\"\n    type=\"text\"></cps-input>\n\n  <cps-input\n    *ngSwitchCase=\"'number'\"\n    [hideDetails]=\"true\"\n    [placeholder]=\"placeholder\"\n    (keydown.enter)=\"onEnterKeyDown($event)\"\n    [value]=\"filterConstraint?.value\"\n    (valueChanged)=\"onValueChange($event)\"\n    type=\"number\"></cps-input>\n\n  <div\n    class=\"cps-table-col-filter-constraint-btn-toggles\"\n    *ngSwitchCase=\"'boolean'\">\n    <cps-button-toggle\n      [options]=\"booleanOptions\"\n      [value]=\"filterConstraint?.value\"\n      (valueChanged)=\"onValueChange($event)\"\n      [mandatory]=\"false\">\n    </cps-button-toggle>\n  </div>\n\n  <cps-datepicker\n    *ngSwitchCase=\"'date'\"\n    [openOnInputFocus]=\"true\"\n    [hideDetails]=\"true\"\n    [placeholder]=\"placeholder\"\n    [value]=\"filterConstraint?.value\"\n    (keydown.enter)=\"onEnterKeyDown($event)\"\n    (valueChanged)=\"onValueChange($event)\">\n  </cps-datepicker>\n\n  <ng-container *ngSwitchCase=\"'category'\">\n    <cps-autocomplete\n      #categoryAutocompleteComponent\n      *ngIf=\"!asButtonToggle\"\n      class=\"cps-table-col-filter-category-autocomplete\"\n      [placeholder]=\"placeholder\"\n      [options]=\"categories\"\n      [hideDetails]=\"true\"\n      [clearable]=\"true\"\n      [value]=\"filterConstraint?.value\"\n      (valueChanged)=\"onValueChange($event)\"\n      [returnObject]=\"false\"\n      [multiple]=\"!singleSelection\">\n    </cps-autocomplete>\n    <div class=\"cps-table-col-filter-constraint-btn-toggles\">\n      <cps-button-toggle\n        *ngIf=\"asButtonToggle\"\n        [options]=\"categories\"\n        [value]=\"filterConstraint?.value\"\n        (valueChanged)=\"onValueChange($event)\"\n        [mandatory]=\"false\"\n        [multiple]=\"!singleSelection\">\n      </cps-button-toggle>\n    </div>\n  </ng-container>\n</ng-container>\n"]}