cps-ui-kit 0.24.0 → 0.26.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.
- package/README.md +1 -0
- package/esm2020/lib/components/cps-icon/cps-icon.component.mjs +2 -2
- package/esm2020/lib/components/cps-table/cps-table-column-sortable.directive.mjs +37 -0
- package/esm2020/lib/components/cps-table/cps-table.component.mjs +161 -0
- package/esm2020/lib/components/cps-table/table-unsort.directive.mjs +85 -0
- package/esm2020/public-api.mjs +3 -1
- package/fesm2015/cps-ui-kit.mjs +300 -24
- package/fesm2015/cps-ui-kit.mjs.map +1 -1
- package/fesm2020/cps-ui-kit.mjs +294 -24
- package/fesm2020/cps-ui-kit.mjs.map +1 -1
- package/lib/components/cps-table/cps-table-column-sortable.directive.d.ts +15 -0
- package/lib/components/cps-table/cps-table.component.d.ts +49 -0
- package/lib/components/cps-table/table-unsort.directive.d.ts +9 -0
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
package/README.md
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { CommonModule } from '@angular/common';
|
|
2
2
|
import { Component, Input } from '@angular/core';
|
|
3
|
-
import { getCSSColor } from '../../utils/colors-utils';
|
|
4
3
|
import { convertSize } from '../../utils/size-utils';
|
|
4
|
+
import { getCSSColor } from '../../utils/colors-utils';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@angular/common";
|
|
7
7
|
export const iconNames = [
|
|
@@ -160,4 +160,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
160
160
|
}], color: [{
|
|
161
161
|
type: Input
|
|
162
162
|
}] } });
|
|
163
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
163
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-icon.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-icon/cps-icon.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-icon/cps-icon.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, Input, OnChanges } from '@angular/core';\nimport { convertSize } from '../../utils/size-utils';\nimport { getCSSColor } from '../../utils/colors-utils';\n\nexport const iconNames = [\n  'access',\n  'access-denied',\n  'access-menu',\n  'access-unlock',\n  'add',\n  'add-domain',\n  'avatar',\n  'avatar-top-menu',\n  'bell',\n  'book',\n  'bookmark',\n  'browse',\n  'burger-arrow',\n  'caret-down',\n  'change',\n  'checked',\n  'chevron-down',\n  'chevron-down-2',\n  'circle',\n  'close-x',\n  'close-x-2',\n  'community',\n  'construction',\n  'controls',\n  'csv',\n  'cub',\n  'database',\n  'datepicker',\n  'delete',\n  'dislike',\n  'dots',\n  'download',\n  'dq',\n  'dropdown-menu',\n  'edit',\n  'expand',\n  'export',\n  'eye',\n  'filter',\n  'filter_2',\n  'follow',\n  'glossary',\n  'graph',\n  'grid',\n  'grid-view',\n  'health',\n  'heart',\n  'help-circle',\n  'home',\n  'insight',\n  'issues',\n  'jpeg',\n  'kris',\n  'last-seen-product',\n  'like',\n  'line-vertical',\n  'lock',\n  'logout',\n  'menu-expand',\n  'menu-shrink',\n  'minus',\n  'multiple_users',\n  'open',\n  'path',\n  'pdf',\n  'plus',\n  'projects',\n  'question',\n  'questions',\n  'rectangle-rounded',\n  'refresh-browse',\n  'remove',\n  'right',\n  'schema_filter',\n  'search',\n  'settings',\n  'smart',\n  'star',\n  'stepper-completed',\n  'success',\n  'suggestion',\n  'survivorship',\n  'table-row-error',\n  'table-row-success',\n  'table-row-warning',\n  'toast-error',\n  'toast-info',\n  'toast-success',\n  'toast-warning',\n  'tools',\n  'user',\n  'users',\n  'vector',\n  'vector-down',\n  'vector-right',\n  'vector-up',\n  'wallet',\n  'warning',\n  'widget-button-icon',\n  'xls'\n];\n\nexport type IconType = (typeof iconNames)[number];\n\nexport type iconSizeType =\n  | number\n  | string\n  | 'fill'\n  | 'xsmall'\n  | 'small'\n  | 'normal'\n  | 'large';\n\n@Component({\n  standalone: true,\n  imports: [CommonModule],\n  selector: 'cps-icon',\n  templateUrl: './cps-icon.component.html',\n  styleUrls: ['./cps-icon.component.scss']\n})\nexport class CpsIconComponent implements OnChanges {\n  @Input() icon: IconType = '';\n  @Input() size: iconSizeType = 'small';\n\n  @Input() color = 'currentColor';\n\n  iconColor = 'currentColor';\n  url = '../../../../assets/';\n  cvtSize = '';\n\n  classesList: string[] = ['cps-icon'];\n\n  ngOnChanges(): void {\n    this.iconColor = getCSSColor(this.color);\n    this.setClasses();\n  }\n\n  setClasses(): void {\n    switch (this.size) {\n      case 'fill': {\n        this.classesList.push('cps-icon--fill');\n        break;\n      }\n      case 'xsmall': {\n        this.classesList.push('cps-icon--xsmall');\n        break;\n      }\n      case 'small': {\n        this.classesList.push('cps-icon--small');\n        break;\n      }\n      case 'normal': {\n        this.classesList.push('cps-icon--normal');\n        break;\n      }\n      case 'large': {\n        this.classesList.push('cps-icon--large');\n        break;\n      }\n      default:\n        this.cvtSize = convertSize(this.size);\n        break;\n    }\n  }\n}\n","<i\n  *ngIf=\"icon\"\n  [ngClass]=\"classesList\"\n  [style.color]=\"iconColor\"\n  [ngStyle]=\"{ width: cvtSize || 'none', height: cvtSize || 'none' }\">\n  <svg>\n    <use attr.xlink:href=\"{{ url }}icons.svg#{{ icon }}\"></use>\n  </svg>\n</i>\n"]}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { Directive, Input } from '@angular/core';
|
|
2
|
+
import { SortIcon, SortableColumn } from 'primeng/table';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "primeng/table";
|
|
5
|
+
export class CpsTableColumnSortableDirective extends SortableColumn {
|
|
6
|
+
constructor(elementRef, viewContainerRef, dt) {
|
|
7
|
+
super(dt);
|
|
8
|
+
this.elementRef = elementRef;
|
|
9
|
+
this.viewContainerRef = viewContainerRef;
|
|
10
|
+
this.dt = dt;
|
|
11
|
+
this.field = '';
|
|
12
|
+
this.sortIconRef = this.viewContainerRef.createComponent(SortIcon);
|
|
13
|
+
}
|
|
14
|
+
ngOnInit() {
|
|
15
|
+
super.ngOnInit();
|
|
16
|
+
this.sortIconRef.setInput('field', this.field);
|
|
17
|
+
this.elementRef.nativeElement.firstChild.after(this.sortIconRef.location.nativeElement);
|
|
18
|
+
}
|
|
19
|
+
ngOnDestroy() {
|
|
20
|
+
super.ngOnDestroy();
|
|
21
|
+
this.sortIconRef.destroy();
|
|
22
|
+
this.viewContainerRef.clear();
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
CpsTableColumnSortableDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CpsTableColumnSortableDirective, deps: [{ token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: i1.Table }], target: i0.ɵɵFactoryTarget.Directive });
|
|
26
|
+
CpsTableColumnSortableDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: CpsTableColumnSortableDirective, isStandalone: true, selector: "[cpsColSortable]", inputs: { field: ["cpsColSortable", "field"] }, usesInheritance: true, ngImport: i0 });
|
|
27
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CpsTableColumnSortableDirective, decorators: [{
|
|
28
|
+
type: Directive,
|
|
29
|
+
args: [{
|
|
30
|
+
standalone: true,
|
|
31
|
+
selector: '[cpsColSortable]'
|
|
32
|
+
}]
|
|
33
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: i1.Table }]; }, propDecorators: { field: [{
|
|
34
|
+
type: Input,
|
|
35
|
+
args: ['cpsColSortable']
|
|
36
|
+
}] } });
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3BzLXRhYmxlLWNvbHVtbi1zb3J0YWJsZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jcHMtdWkta2l0L3NyYy9saWIvY29tcG9uZW50cy9jcHMtdGFibGUvY3BzLXRhYmxlLWNvbHVtbi1zb3J0YWJsZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUVMLFNBQVMsRUFFVCxLQUFLLEVBSU4sTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLFFBQVEsRUFBRSxjQUFjLEVBQVMsTUFBTSxlQUFlLENBQUM7OztBQU1oRSxNQUFNLE9BQU8sK0JBQ1gsU0FBUSxjQUFjO0lBTXRCLFlBQ1UsVUFBc0IsRUFDdEIsZ0JBQWtDLEVBQzFCLEVBQVM7UUFFekIsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBSkYsZUFBVSxHQUFWLFVBQVUsQ0FBWTtRQUN0QixxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWtCO1FBQzFCLE9BQUUsR0FBRixFQUFFLENBQU87UUFOTyxVQUFLLEdBQUcsRUFBRSxDQUFDO1FBUzNDLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDLGdCQUFnQixDQUFDLGVBQWUsQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUNyRSxDQUFDO0lBRVEsUUFBUTtRQUNmLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNqQixJQUFJLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQy9DLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQzVDLElBQUksQ0FBQyxXQUFXLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FDeEMsQ0FBQztJQUNKLENBQUM7SUFFUSxXQUFXO1FBQ2xCLEtBQUssQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUNwQixJQUFJLENBQUMsV0FBVyxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQzNCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUNoQyxDQUFDOzs0SEE1QlUsK0JBQStCO2dIQUEvQiwrQkFBK0I7MkZBQS9CLCtCQUErQjtrQkFKM0MsU0FBUzttQkFBQztvQkFDVCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFLGtCQUFrQjtpQkFDN0I7b0pBS21DLEtBQUs7c0JBQXRDLEtBQUs7dUJBQUMsZ0JBQWdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ29tcG9uZW50UmVmLFxuICBEaXJlY3RpdmUsXG4gIEVsZW1lbnRSZWYsXG4gIElucHV0LFxuICBPbkRlc3Ryb3ksXG4gIE9uSW5pdCxcbiAgVmlld0NvbnRhaW5lclJlZlxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFNvcnRJY29uLCBTb3J0YWJsZUNvbHVtbiwgVGFibGUgfSBmcm9tICdwcmltZW5nL3RhYmxlJztcblxuQERpcmVjdGl2ZSh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHNlbGVjdG9yOiAnW2Nwc0NvbFNvcnRhYmxlXSdcbn0pXG5leHBvcnQgY2xhc3MgQ3BzVGFibGVDb2x1bW5Tb3J0YWJsZURpcmVjdGl2ZVxuICBleHRlbmRzIFNvcnRhYmxlQ29sdW1uXG4gIGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3lcbntcbiAgQElucHV0KCdjcHNDb2xTb3J0YWJsZScpIG92ZXJyaWRlIGZpZWxkID0gJyc7XG4gIHNvcnRJY29uUmVmOiBDb21wb25lbnRSZWY8U29ydEljb24+O1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgZWxlbWVudFJlZjogRWxlbWVudFJlZixcbiAgICBwcml2YXRlIHZpZXdDb250YWluZXJSZWY6IFZpZXdDb250YWluZXJSZWYsXG4gICAgcHVibGljIG92ZXJyaWRlIGR0OiBUYWJsZVxuICApIHtcbiAgICBzdXBlcihkdCk7XG4gICAgdGhpcy5zb3J0SWNvblJlZiA9IHRoaXMudmlld0NvbnRhaW5lclJlZi5jcmVhdGVDb21wb25lbnQoU29ydEljb24pO1xuICB9XG5cbiAgb3ZlcnJpZGUgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgc3VwZXIubmdPbkluaXQoKTtcbiAgICB0aGlzLnNvcnRJY29uUmVmLnNldElucHV0KCdmaWVsZCcsIHRoaXMuZmllbGQpO1xuICAgIHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LmZpcnN0Q2hpbGQuYWZ0ZXIoXG4gICAgICB0aGlzLnNvcnRJY29uUmVmLmxvY2F0aW9uLm5hdGl2ZUVsZW1lbnRcbiAgICApO1xuICB9XG5cbiAgb3ZlcnJpZGUgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgc3VwZXIubmdPbkRlc3Ryb3koKTtcbiAgICB0aGlzLnNvcnRJY29uUmVmLmRlc3Ryb3koKTtcbiAgICB0aGlzLnZpZXdDb250YWluZXJSZWYuY2xlYXIoKTtcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
import { Component, ContentChild, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { Table, TableService, TableModule } from 'primeng/table';
|
|
4
|
+
import { TableUnsortDirective } from './table-unsort.directive';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/common";
|
|
7
|
+
import * as i2 from "primeng/table";
|
|
8
|
+
import * as i3 from "primeng/api";
|
|
9
|
+
export function tableFactory(tableComponent) {
|
|
10
|
+
return tableComponent.primengTable;
|
|
11
|
+
}
|
|
12
|
+
export class CpsTableComponent {
|
|
13
|
+
// eslint-disable-next-line no-useless-constructor
|
|
14
|
+
constructor(cdRef) {
|
|
15
|
+
this.cdRef = cdRef;
|
|
16
|
+
this.headers = [];
|
|
17
|
+
this.data = [];
|
|
18
|
+
this.columns = []; // combines both headers and data
|
|
19
|
+
this.striped = true;
|
|
20
|
+
this.bordered = true;
|
|
21
|
+
this.size = 'normal';
|
|
22
|
+
this.selectable = true;
|
|
23
|
+
this.emptyMessage = 'No data';
|
|
24
|
+
this.hasToolbar = true;
|
|
25
|
+
this.toolbarSize = 'normal';
|
|
26
|
+
this.toolbarTitle = '';
|
|
27
|
+
this.sortMode = 'multiple';
|
|
28
|
+
this.customSort = false;
|
|
29
|
+
this.rowHover = true;
|
|
30
|
+
this.scrollable = true;
|
|
31
|
+
this.virtualScroll = false; // works only if scrollable is true
|
|
32
|
+
// @Input() draggableRows = false; TODO
|
|
33
|
+
// @Input() columnsToggle = false; TODO
|
|
34
|
+
// @Input() export = false; TODO
|
|
35
|
+
/* @Input() */ this.resizableColumns = false; // TODO
|
|
36
|
+
/* @Input() */ this.reorderableColumns = false; // TODO
|
|
37
|
+
// TODO CpsTableColumnFilterDirective (type date, text, boolean, range, categories, numeric)
|
|
38
|
+
this.selectionChanged = new EventEmitter();
|
|
39
|
+
/**
|
|
40
|
+
* A function to implement custom sorting. customSort must be true.
|
|
41
|
+
* @param {any} any - sort meta.
|
|
42
|
+
* @group Emits
|
|
43
|
+
*/
|
|
44
|
+
this.customSortFunction = new EventEmitter();
|
|
45
|
+
this.styleClass = '';
|
|
46
|
+
this.selectedRows = [];
|
|
47
|
+
this.virtualScrollItemSize = 0;
|
|
48
|
+
}
|
|
49
|
+
ngOnInit() {
|
|
50
|
+
if (!this.scrollable)
|
|
51
|
+
this.virtualScroll = false;
|
|
52
|
+
switch (this.size) {
|
|
53
|
+
case 'small':
|
|
54
|
+
this.styleClass = 'p-datatable-sm';
|
|
55
|
+
break;
|
|
56
|
+
case 'large':
|
|
57
|
+
this.styleClass = 'p-datatable-lg';
|
|
58
|
+
break;
|
|
59
|
+
}
|
|
60
|
+
switch (this.toolbarSize) {
|
|
61
|
+
case 'small':
|
|
62
|
+
this.styleClass += ' cps-tbar-small';
|
|
63
|
+
break;
|
|
64
|
+
case 'normal':
|
|
65
|
+
this.styleClass += ' cps-tbar-normal';
|
|
66
|
+
break;
|
|
67
|
+
}
|
|
68
|
+
if (this.striped) {
|
|
69
|
+
this.styleClass += ' p-datatable-striped';
|
|
70
|
+
}
|
|
71
|
+
if (this.bordered) {
|
|
72
|
+
this.styleClass += ' p-datatable-gridlines';
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
ngAfterViewInit() {
|
|
76
|
+
this.virtualScrollItemSize =
|
|
77
|
+
this.primengTable?.el?.nativeElement
|
|
78
|
+
?.querySelector('.p-datatable-tbody')
|
|
79
|
+
?.querySelector('tr')?.clientHeight || 0;
|
|
80
|
+
this.cdRef.detectChanges();
|
|
81
|
+
}
|
|
82
|
+
onSelectionChanged(selection) {
|
|
83
|
+
this.selectionChanged.emit(
|
|
84
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
85
|
+
selection.map(({ _defaultSortOrder, ...rest }) => rest));
|
|
86
|
+
}
|
|
87
|
+
onSortFunction(event) {
|
|
88
|
+
this.customSortFunction.emit(event);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
CpsTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CpsTableComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
92
|
+
CpsTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: CpsTableComponent, isStandalone: true, selector: "cps-table", inputs: { headers: "headers", data: "data", columns: "columns", striped: "striped", bordered: "bordered", size: "size", selectable: "selectable", emptyMessage: "emptyMessage", hasToolbar: "hasToolbar", toolbarSize: "toolbarSize", toolbarTitle: "toolbarTitle", sortMode: "sortMode", customSort: "customSort", rowHover: "rowHover", scrollable: "scrollable", virtualScroll: "virtualScroll" }, outputs: { selectionChanged: "selectionChanged", customSortFunction: "customSortFunction" }, providers: [
|
|
93
|
+
TableService,
|
|
94
|
+
{
|
|
95
|
+
provide: Table,
|
|
96
|
+
useFactory: tableFactory,
|
|
97
|
+
// eslint-disable-next-line no-use-before-define
|
|
98
|
+
deps: [CpsTableComponent]
|
|
99
|
+
}
|
|
100
|
+
], queries: [{ propertyName: "toolbarTemplate", first: true, predicate: ["toolbar"], descendants: true }, { propertyName: "headerTemplate", first: true, predicate: ["header"], descendants: true }, { propertyName: "bodyTemplate", first: true, predicate: ["body"], descendants: true }], viewQueries: [{ propertyName: "primengTable", first: true, predicate: ["primengTable"], descendants: true, static: true }], ngImport: i0, template: "<p-table\n #primengTable\n withUnsort\n [styleClass]=\"styleClass\"\n [value]=\"data\"\n [columns]=\"columns\"\n (selectionChange)=\"onSelectionChanged($event)\"\n [resizableColumns]=\"resizableColumns\"\n [reorderableColumns]=\"reorderableColumns\"\n [scrollable]=\"scrollable\"\n scrollHeight=\"flex\"\n [virtualScroll]=\"virtualScroll\"\n [virtualScrollItemSize]=\"virtualScrollItemSize\"\n [virtualScrollOptions]=\"{ numToleratedItems: 3 }\"\n [(selection)]=\"selectedRows\"\n [metaKeySelection]=\"false\"\n [rowHover]=\"rowHover\"\n [customSort]=\"customSort\"\n [sortMode]=\"sortMode\"\n (sortFunction)=\"onSortFunction($event)\">\n <ng-template pTemplate=\"caption\" *ngIf=\"hasToolbar\">\n <ng-container *ngIf=\"toolbarTemplate\">\n <ng-container *ngTemplateOutlet=\"toolbarTemplate\"></ng-container>\n </ng-container>\n <ng-container *ngIf=\"!toolbarTemplate\">\n {{ toolbarTitle }}\n </ng-container>\n </ng-template>\n\n <ng-template pTemplate=\"header\" let-columns>\n <tr>\n <th style=\"width: 4rem\" *ngIf=\"selectable\">\n <p-tableHeaderCheckbox></p-tableHeaderCheckbox>\n </th>\n <ng-container *ngIf=\"headerTemplate\">\n <ng-container *ngTemplateOutlet=\"headerTemplate\"></ng-container>\n </ng-container>\n <ng-container *ngIf=\"!headerTemplate\">\n <th *ngFor=\"let h of headers\">{{ h }}</th>\n </ng-container>\n </tr>\n </ng-template>\n\n <ng-template pTemplate=\"body\" let-item let-rowIndex=\"rowIndex\">\n <tr>\n <td *ngIf=\"selectable\">\n <p-tableCheckbox [value]=\"item\"></p-tableCheckbox>\n </td>\n <ng-container\n pTemplate=\"body\"\n *ngTemplateOutlet=\"\n bodyTemplate;\n context: { $implicit: item, rowIndex: rowIndex }\n \"></ng-container>\n </tr>\n </ng-template>\n <ng-template pTemplate=\"emptymessage\">\n <tr>\n <td colspan=\"4\">{{ emptyMessage }}</td>\n </tr>\n </ng-template>\n</p-table>\n", styles: [":host ::ng-deep .p-component,:host ::ng-deep .p-component *{box-sizing:border-box}:host ::ng-deep .p-component{font-family:Source Sans Pro,sans-serif;font-size:14px;font-weight:400}:host ::ng-deep .p-datatable-flex-scrollable{display:flex;flex-direction:column;height:100%}:host ::ng-deep .p-datatable{position:relative}:host ::ng-deep .p-datatable.p-datatable-gridlines .p-datatable-header{border-width:1px 1px 0 1px}:host ::ng-deep .p-datatable .p-datatable-header{font-weight:600;display:flex;justify-content:space-between;align-items:center;padding:0 10px;border:1px solid var(--cps-color-line-mid);border-left:4px solid var(--cps-color-surprise)!important;border-radius:4px 4px 0 0;font-size:16px;line-height:150%;background-color:#fff;color:var(--cps-color-text-dark);overflow:auto}:host ::ng-deep .cps-tbar-small.p-datatable .p-datatable-header{height:43px}:host ::ng-deep .cps-tbar-normal.p-datatable .p-datatable-header{height:72px}:host ::ng-deep .p-datatable-flex-scrollable>.p-datatable-wrapper{display:flex;flex-direction:column;flex:1;height:100%}:host ::ng-deep .p-datatable-scrollable>.p-datatable-wrapper{position:relative}:host ::ng-deep .p-datatable>.p-datatable-wrapper{overflow:auto}:host ::ng-deep .p-datatable-table{border-spacing:0px;width:100%}:host ::ng-deep .p-datatable.p-datatable-scrollable>.p-datatable-wrapper>.p-datatable-table>.p-datatable-thead,:host ::ng-deep .p-datatable.p-datatable-scrollable>.p-datatable-wrapper>.p-datatable-table>.p-datatable-tfoot,:host ::ng-deep .p-datatable.p-datatable-scrollable>.p-datatable-wrapper>.p-scroller-viewport>.p-scroller>.p-datatable-table>.p-datatable-thead,:host ::ng-deep .p-datatable.p-datatable-scrollable>.p-datatable-wrapper>.p-scroller-viewport>.p-scroller>.p-datatable-table>.p-datatable-tfoot{background-color:#fff}:host ::ng-deep .p-datatable-scrollable-table>.p-datatable-thead{position:sticky;top:0;z-index:1}:host ::ng-deep .p-datatable.p-datatable-gridlines .p-datatable-thead>tr>th:last-child{border-width:1px}:host ::ng-deep .p-datatable.p-datatable-sm .p-datatable-thead>tr>th{padding:.5rem}:host ::ng-deep .p-datatable.p-datatable-lg .p-datatable-thead>tr>th{padding:1.25rem}:host ::ng-deep .p-datatable.p-datatable-gridlines .p-datatable-thead>tr>th{border-width:1px 0 1px 1px}:host ::ng-deep .p-datatable .p-sortable-column:not(.p-highlight):hover{background:white;color:var(--cps-color-text-mild)}:host ::ng-deep .p-datatable .p-sortable-column.p-highlight:hover{background:white;color:var(--cps-color-text-mild)}:host ::ng-deep .p-datatable .p-datatable-thead>tr>th{text-align:left;padding:1rem;border:1px solid var(--cps-color-line-mid);border-width:0 0 1px 0;font-weight:400;color:var(--cps-color-text-mild);background:white;transition:box-shadow .2s}:host ::ng-deep .p-datatable .p-sortable-column:not(.p-highlight):hover .p-sortable-column-icon{color:var(--cps-color-text-dark)}:host ::ng-deep .p-datatable .p-sortable-column .p-sortable-column-icon{color:var(--cps-color-text-mild);margin-left:.5rem}:host ::ng-deep .p-datatable .p-sortable-column.p-highlight .p-sortable-column-icon{color:var(--cps-color-calm)}:host ::ng-deep .p-icon-wrapper{display:inline-flex}:host ::ng-deep .p-icon{display:inline-block;width:1rem;height:1rem}:host ::ng-deep .p-sortable-column-icon{width:13px;height:13px}:host ::ng-deep .p-datatable .p-sortable-column .p-sortable-column-badge{display:inline-flex;align-items:center;justify-content:center}:host ::ng-deep .p-datatable .p-sortable-column .p-column-title,:host ::ng-deep .p-datatable .p-sortable-column .p-sortable-column-icon,:host ::ng-deep .p-datatable .p-sortable-column .p-sortable-column-badge{vertical-align:unset}:host ::ng-deep .p-datatable .p-sortable-column .p-sortable-column-badge{border-radius:50%;height:1.143rem;min-width:1.143rem;line-height:1.143rem;color:var(--cps-color-calm);background:#f1eaec;margin-left:.5rem}:host ::ng-deep filtericon{pointer-events:none}:host ::ng-deep filtericon .p-icon{width:13px;height:13px}:host ::ng-deep p-columnfilter{margin-left:4px}:host ::ng-deep .p-column-filter-menu-button:hover{color:var(--cps-color-text-dark);border-color:transparent}:host ::ng-deep .p-column-filter-menu-button.p-column-filter-menu-button-open,:host ::ng-deep .p-column-filter-menu-button.p-column-filter-menu-button-open:hover{background:transparent;color:var(--cps-color-text-dark)}:host ::ng-deep .p-column-filter-menu-button,:host ::ng-deep .p-column-filter-clear-button{display:inline-flex;justify-content:center;align-items:center;cursor:pointer;text-decoration:none;overflow:hidden;position:relative}:host ::ng-deep .p-column-filter-menu-button:focus{outline:0 none;outline-offset:0;box-shadow:none}:host ::ng-deep .p-link{text-align:left;background-color:transparent;margin:0;padding:0;border:none;cursor:pointer;-webkit-user-select:none;user-select:none}:host ::ng-deep .p-datatable .p-sortable-column{cursor:pointer;-webkit-user-select:none;user-select:none}:host ::ng-deep .p-datatable .p-sortable-column:focus{box-shadow:none;outline:0 none}:host ::ng-deep .p-datatable.p-datatable-striped .p-datatable-tbody>tr:nth-child(odd){background:var(--cps-color-bg-light)}:host ::ng-deep .p-datatable.p-datatable-striped .p-datatable-tbody>tr:nth-child(even){background:#ffffff}:host ::ng-deep .p-datatable.p-datatable-hoverable-rows .p-datatable-tbody>tr:not(.p-highlight):hover{background:#f8f4f5}:host ::ng-deep .p-datatable .p-datatable-tbody>tr{background:#ffffff;color:var(--cps-color-text-dark);transition:box-shadow .2s}:host ::ng-deep .p-datatable.p-datatable-gridlines:has(.p-datatable-thead):has(.p-datatable-tbody) .p-datatable-tbody>tr>td:last-child{border-width:0 1px 1px 1px}:host ::ng-deep .p-datatable.p-datatable-gridlines .p-datatable-tbody>tr>td:last-child{border-width:1px 1px 0 1px}:host ::ng-deep .p-datatable.p-datatable-sm .p-datatable-tbody>tr>td{padding:.5rem}:host ::ng-deep .p-datatable.p-datatable-lg .p-datatable-tbody>tr>td{padding:1.25rem}:host ::ng-deep .p-datatable.p-datatable-gridlines:has(.p-datatable-thead):has(.p-datatable-tbody) .p-datatable-tbody>tr>td{border-width:0 0 1px 1px}:host ::ng-deep .p-datatable.p-datatable-gridlines .p-datatable-tbody>tr>td{border-width:1px 0 0 1px}:host ::ng-deep .p-datatable .p-datatable-tbody>tr>td{text-align:left;border:1px solid var(--cps-color-line-mid);border-width:0 0 1px 0;padding:1rem}:host ::ng-deep td:has(p-tablecheckbox){text-align:center!important}:host ::ng-deep th:has(p-tableheadercheckbox){text-align:center!important;width:3rem!important}:host ::ng-deep .p-checkbox{display:inline-flex;cursor:pointer;-webkit-user-select:none;user-select:none;vertical-align:bottom;position:relative;width:18px;height:18px}:host ::ng-deep .p-hidden-accessible{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}:host ::ng-deep .p-hidden-accessible input,:host ::ng-deep .p-hidden-accessible select{transform:scale(0)}:host ::ng-deep .p-checkbox .p-checkbox-box{background:#ffffff;width:18px;height:18px;color:var(--cps-color-text-dark);border:2px solid var(--cps-color-text-mild);border-radius:2px;transition:background-color .2s,color .2s,border-color .2s,box-shadow .2s}:host ::ng-deep .p-checkbox-box{display:flex;justify-content:center;align-items:center}:host ::ng-deep .p-checkbox .p-checkbox-box.p-highlight{border-color:var(--cps-color-calm);background:var(--cps-color-calm)}:host ::ng-deep .p-checkbox:not(.p-checkbox-disabled) .p-checkbox-box.p-highlight:hover{border-color:var(--cps-color-calm);background:var(--cps-color-calm);color:#fff}:host ::ng-deep .p-checkbox:not(.p-checkbox-disabled) .p-checkbox-box:hover{border-color:var(--cps-color-calm)}:host ::ng-deep .p-checkbox .p-checkbox-box .p-icon{width:14px;height:14px}:host ::ng-deep .p-checkbox .p-checkbox-box .p-checkbox-icon{transition-duration:.2s;color:#fff;font-size:14px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: TableModule }, { kind: "component", type: i2.Table, selector: "p-table", inputs: ["frozenColumns", "frozenValue", "style", "styleClass", "tableStyle", "tableStyleClass", "paginator", "pageLinks", "rowsPerPageOptions", "alwaysShowPaginator", "paginatorPosition", "paginatorDropdownAppendTo", "paginatorDropdownScrollHeight", "currentPageReportTemplate", "showCurrentPageReport", "showJumpToPageDropdown", "showJumpToPageInput", "showFirstLastIcon", "showPageLinks", "defaultSortOrder", "sortMode", "resetPageOnSort", "selectionMode", "selectionPageOnly", "contextMenuSelection", "contextMenuSelectionMode", "dataKey", "metaKeySelection", "rowSelectable", "rowTrackBy", "lazy", "lazyLoadOnInit", "compareSelectionBy", "csvSeparator", "exportFilename", "filters", "globalFilterFields", "filterDelay", "filterLocale", "expandedRowKeys", "editingRowKeys", "rowExpandMode", "scrollable", "scrollDirection", "rowGroupMode", "scrollHeight", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "virtualScrollDelay", "frozenWidth", "responsive", "contextMenu", "resizableColumns", "columnResizeMode", "reorderableColumns", "loading", "loadingIcon", "showLoader", "rowHover", "customSort", "showInitialSortBadge", "autoLayout", "exportFunction", "exportHeader", "stateKey", "stateStorage", "editMode", "groupRowsBy", "groupRowsByOrder", "responsiveLayout", "breakpoint", "virtualRowHeight", "value", "columns", "first", "rows", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection", "selectAll"], outputs: ["selectAllChange", "selectionChange", "contextMenuSelectionChange", "onRowSelect", "onRowUnselect", "onPage", "onSort", "onFilter", "onLazyLoad", "onRowExpand", "onRowCollapse", "onContextMenuSelect", "onColResize", "onColReorder", "onRowReorder", "onEditInit", "onEditComplete", "onEditCancel", "onHeaderCheckboxToggle", "sortFunction", "firstChange", "rowsChange", "onStateSave", "onStateRestore"] }, { kind: "directive", type: i3.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "component", type: i2.TableCheckbox, selector: "p-tableCheckbox", inputs: ["disabled", "value", "index", "inputId", "name", "required", "ariaLabel"] }, { kind: "component", type: i2.TableHeaderCheckbox, selector: "p-tableHeaderCheckbox", inputs: ["disabled", "inputId", "name", "ariaLabel"] }, { kind: "directive", type: TableUnsortDirective, selector: "[withUnsort]" }] });
|
|
101
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CpsTableComponent, decorators: [{
|
|
102
|
+
type: Component,
|
|
103
|
+
args: [{ selector: 'cps-table', standalone: true, imports: [CommonModule, TableModule, TableUnsortDirective], providers: [
|
|
104
|
+
TableService,
|
|
105
|
+
{
|
|
106
|
+
provide: Table,
|
|
107
|
+
useFactory: tableFactory,
|
|
108
|
+
// eslint-disable-next-line no-use-before-define
|
|
109
|
+
deps: [CpsTableComponent]
|
|
110
|
+
}
|
|
111
|
+
], template: "<p-table\n #primengTable\n withUnsort\n [styleClass]=\"styleClass\"\n [value]=\"data\"\n [columns]=\"columns\"\n (selectionChange)=\"onSelectionChanged($event)\"\n [resizableColumns]=\"resizableColumns\"\n [reorderableColumns]=\"reorderableColumns\"\n [scrollable]=\"scrollable\"\n scrollHeight=\"flex\"\n [virtualScroll]=\"virtualScroll\"\n [virtualScrollItemSize]=\"virtualScrollItemSize\"\n [virtualScrollOptions]=\"{ numToleratedItems: 3 }\"\n [(selection)]=\"selectedRows\"\n [metaKeySelection]=\"false\"\n [rowHover]=\"rowHover\"\n [customSort]=\"customSort\"\n [sortMode]=\"sortMode\"\n (sortFunction)=\"onSortFunction($event)\">\n <ng-template pTemplate=\"caption\" *ngIf=\"hasToolbar\">\n <ng-container *ngIf=\"toolbarTemplate\">\n <ng-container *ngTemplateOutlet=\"toolbarTemplate\"></ng-container>\n </ng-container>\n <ng-container *ngIf=\"!toolbarTemplate\">\n {{ toolbarTitle }}\n </ng-container>\n </ng-template>\n\n <ng-template pTemplate=\"header\" let-columns>\n <tr>\n <th style=\"width: 4rem\" *ngIf=\"selectable\">\n <p-tableHeaderCheckbox></p-tableHeaderCheckbox>\n </th>\n <ng-container *ngIf=\"headerTemplate\">\n <ng-container *ngTemplateOutlet=\"headerTemplate\"></ng-container>\n </ng-container>\n <ng-container *ngIf=\"!headerTemplate\">\n <th *ngFor=\"let h of headers\">{{ h }}</th>\n </ng-container>\n </tr>\n </ng-template>\n\n <ng-template pTemplate=\"body\" let-item let-rowIndex=\"rowIndex\">\n <tr>\n <td *ngIf=\"selectable\">\n <p-tableCheckbox [value]=\"item\"></p-tableCheckbox>\n </td>\n <ng-container\n pTemplate=\"body\"\n *ngTemplateOutlet=\"\n bodyTemplate;\n context: { $implicit: item, rowIndex: rowIndex }\n \"></ng-container>\n </tr>\n </ng-template>\n <ng-template pTemplate=\"emptymessage\">\n <tr>\n <td colspan=\"4\">{{ emptyMessage }}</td>\n </tr>\n </ng-template>\n</p-table>\n", styles: [":host ::ng-deep .p-component,:host ::ng-deep .p-component *{box-sizing:border-box}:host ::ng-deep .p-component{font-family:Source Sans Pro,sans-serif;font-size:14px;font-weight:400}:host ::ng-deep .p-datatable-flex-scrollable{display:flex;flex-direction:column;height:100%}:host ::ng-deep .p-datatable{position:relative}:host ::ng-deep .p-datatable.p-datatable-gridlines .p-datatable-header{border-width:1px 1px 0 1px}:host ::ng-deep .p-datatable .p-datatable-header{font-weight:600;display:flex;justify-content:space-between;align-items:center;padding:0 10px;border:1px solid var(--cps-color-line-mid);border-left:4px solid var(--cps-color-surprise)!important;border-radius:4px 4px 0 0;font-size:16px;line-height:150%;background-color:#fff;color:var(--cps-color-text-dark);overflow:auto}:host ::ng-deep .cps-tbar-small.p-datatable .p-datatable-header{height:43px}:host ::ng-deep .cps-tbar-normal.p-datatable .p-datatable-header{height:72px}:host ::ng-deep .p-datatable-flex-scrollable>.p-datatable-wrapper{display:flex;flex-direction:column;flex:1;height:100%}:host ::ng-deep .p-datatable-scrollable>.p-datatable-wrapper{position:relative}:host ::ng-deep .p-datatable>.p-datatable-wrapper{overflow:auto}:host ::ng-deep .p-datatable-table{border-spacing:0px;width:100%}:host ::ng-deep .p-datatable.p-datatable-scrollable>.p-datatable-wrapper>.p-datatable-table>.p-datatable-thead,:host ::ng-deep .p-datatable.p-datatable-scrollable>.p-datatable-wrapper>.p-datatable-table>.p-datatable-tfoot,:host ::ng-deep .p-datatable.p-datatable-scrollable>.p-datatable-wrapper>.p-scroller-viewport>.p-scroller>.p-datatable-table>.p-datatable-thead,:host ::ng-deep .p-datatable.p-datatable-scrollable>.p-datatable-wrapper>.p-scroller-viewport>.p-scroller>.p-datatable-table>.p-datatable-tfoot{background-color:#fff}:host ::ng-deep .p-datatable-scrollable-table>.p-datatable-thead{position:sticky;top:0;z-index:1}:host ::ng-deep .p-datatable.p-datatable-gridlines .p-datatable-thead>tr>th:last-child{border-width:1px}:host ::ng-deep .p-datatable.p-datatable-sm .p-datatable-thead>tr>th{padding:.5rem}:host ::ng-deep .p-datatable.p-datatable-lg .p-datatable-thead>tr>th{padding:1.25rem}:host ::ng-deep .p-datatable.p-datatable-gridlines .p-datatable-thead>tr>th{border-width:1px 0 1px 1px}:host ::ng-deep .p-datatable .p-sortable-column:not(.p-highlight):hover{background:white;color:var(--cps-color-text-mild)}:host ::ng-deep .p-datatable .p-sortable-column.p-highlight:hover{background:white;color:var(--cps-color-text-mild)}:host ::ng-deep .p-datatable .p-datatable-thead>tr>th{text-align:left;padding:1rem;border:1px solid var(--cps-color-line-mid);border-width:0 0 1px 0;font-weight:400;color:var(--cps-color-text-mild);background:white;transition:box-shadow .2s}:host ::ng-deep .p-datatable .p-sortable-column:not(.p-highlight):hover .p-sortable-column-icon{color:var(--cps-color-text-dark)}:host ::ng-deep .p-datatable .p-sortable-column .p-sortable-column-icon{color:var(--cps-color-text-mild);margin-left:.5rem}:host ::ng-deep .p-datatable .p-sortable-column.p-highlight .p-sortable-column-icon{color:var(--cps-color-calm)}:host ::ng-deep .p-icon-wrapper{display:inline-flex}:host ::ng-deep .p-icon{display:inline-block;width:1rem;height:1rem}:host ::ng-deep .p-sortable-column-icon{width:13px;height:13px}:host ::ng-deep .p-datatable .p-sortable-column .p-sortable-column-badge{display:inline-flex;align-items:center;justify-content:center}:host ::ng-deep .p-datatable .p-sortable-column .p-column-title,:host ::ng-deep .p-datatable .p-sortable-column .p-sortable-column-icon,:host ::ng-deep .p-datatable .p-sortable-column .p-sortable-column-badge{vertical-align:unset}:host ::ng-deep .p-datatable .p-sortable-column .p-sortable-column-badge{border-radius:50%;height:1.143rem;min-width:1.143rem;line-height:1.143rem;color:var(--cps-color-calm);background:#f1eaec;margin-left:.5rem}:host ::ng-deep filtericon{pointer-events:none}:host ::ng-deep filtericon .p-icon{width:13px;height:13px}:host ::ng-deep p-columnfilter{margin-left:4px}:host ::ng-deep .p-column-filter-menu-button:hover{color:var(--cps-color-text-dark);border-color:transparent}:host ::ng-deep .p-column-filter-menu-button.p-column-filter-menu-button-open,:host ::ng-deep .p-column-filter-menu-button.p-column-filter-menu-button-open:hover{background:transparent;color:var(--cps-color-text-dark)}:host ::ng-deep .p-column-filter-menu-button,:host ::ng-deep .p-column-filter-clear-button{display:inline-flex;justify-content:center;align-items:center;cursor:pointer;text-decoration:none;overflow:hidden;position:relative}:host ::ng-deep .p-column-filter-menu-button:focus{outline:0 none;outline-offset:0;box-shadow:none}:host ::ng-deep .p-link{text-align:left;background-color:transparent;margin:0;padding:0;border:none;cursor:pointer;-webkit-user-select:none;user-select:none}:host ::ng-deep .p-datatable .p-sortable-column{cursor:pointer;-webkit-user-select:none;user-select:none}:host ::ng-deep .p-datatable .p-sortable-column:focus{box-shadow:none;outline:0 none}:host ::ng-deep .p-datatable.p-datatable-striped .p-datatable-tbody>tr:nth-child(odd){background:var(--cps-color-bg-light)}:host ::ng-deep .p-datatable.p-datatable-striped .p-datatable-tbody>tr:nth-child(even){background:#ffffff}:host ::ng-deep .p-datatable.p-datatable-hoverable-rows .p-datatable-tbody>tr:not(.p-highlight):hover{background:#f8f4f5}:host ::ng-deep .p-datatable .p-datatable-tbody>tr{background:#ffffff;color:var(--cps-color-text-dark);transition:box-shadow .2s}:host ::ng-deep .p-datatable.p-datatable-gridlines:has(.p-datatable-thead):has(.p-datatable-tbody) .p-datatable-tbody>tr>td:last-child{border-width:0 1px 1px 1px}:host ::ng-deep .p-datatable.p-datatable-gridlines .p-datatable-tbody>tr>td:last-child{border-width:1px 1px 0 1px}:host ::ng-deep .p-datatable.p-datatable-sm .p-datatable-tbody>tr>td{padding:.5rem}:host ::ng-deep .p-datatable.p-datatable-lg .p-datatable-tbody>tr>td{padding:1.25rem}:host ::ng-deep .p-datatable.p-datatable-gridlines:has(.p-datatable-thead):has(.p-datatable-tbody) .p-datatable-tbody>tr>td{border-width:0 0 1px 1px}:host ::ng-deep .p-datatable.p-datatable-gridlines .p-datatable-tbody>tr>td{border-width:1px 0 0 1px}:host ::ng-deep .p-datatable .p-datatable-tbody>tr>td{text-align:left;border:1px solid var(--cps-color-line-mid);border-width:0 0 1px 0;padding:1rem}:host ::ng-deep td:has(p-tablecheckbox){text-align:center!important}:host ::ng-deep th:has(p-tableheadercheckbox){text-align:center!important;width:3rem!important}:host ::ng-deep .p-checkbox{display:inline-flex;cursor:pointer;-webkit-user-select:none;user-select:none;vertical-align:bottom;position:relative;width:18px;height:18px}:host ::ng-deep .p-hidden-accessible{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}:host ::ng-deep .p-hidden-accessible input,:host ::ng-deep .p-hidden-accessible select{transform:scale(0)}:host ::ng-deep .p-checkbox .p-checkbox-box{background:#ffffff;width:18px;height:18px;color:var(--cps-color-text-dark);border:2px solid var(--cps-color-text-mild);border-radius:2px;transition:background-color .2s,color .2s,border-color .2s,box-shadow .2s}:host ::ng-deep .p-checkbox-box{display:flex;justify-content:center;align-items:center}:host ::ng-deep .p-checkbox .p-checkbox-box.p-highlight{border-color:var(--cps-color-calm);background:var(--cps-color-calm)}:host ::ng-deep .p-checkbox:not(.p-checkbox-disabled) .p-checkbox-box.p-highlight:hover{border-color:var(--cps-color-calm);background:var(--cps-color-calm);color:#fff}:host ::ng-deep .p-checkbox:not(.p-checkbox-disabled) .p-checkbox-box:hover{border-color:var(--cps-color-calm)}:host ::ng-deep .p-checkbox .p-checkbox-box .p-icon{width:14px;height:14px}:host ::ng-deep .p-checkbox .p-checkbox-box .p-checkbox-icon{transition-duration:.2s;color:#fff;font-size:14px}\n"] }]
|
|
112
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { headers: [{
|
|
113
|
+
type: Input
|
|
114
|
+
}], data: [{
|
|
115
|
+
type: Input
|
|
116
|
+
}], columns: [{
|
|
117
|
+
type: Input
|
|
118
|
+
}], striped: [{
|
|
119
|
+
type: Input
|
|
120
|
+
}], bordered: [{
|
|
121
|
+
type: Input
|
|
122
|
+
}], size: [{
|
|
123
|
+
type: Input
|
|
124
|
+
}], selectable: [{
|
|
125
|
+
type: Input
|
|
126
|
+
}], emptyMessage: [{
|
|
127
|
+
type: Input
|
|
128
|
+
}], hasToolbar: [{
|
|
129
|
+
type: Input
|
|
130
|
+
}], toolbarSize: [{
|
|
131
|
+
type: Input
|
|
132
|
+
}], toolbarTitle: [{
|
|
133
|
+
type: Input
|
|
134
|
+
}], sortMode: [{
|
|
135
|
+
type: Input
|
|
136
|
+
}], customSort: [{
|
|
137
|
+
type: Input
|
|
138
|
+
}], rowHover: [{
|
|
139
|
+
type: Input
|
|
140
|
+
}], scrollable: [{
|
|
141
|
+
type: Input
|
|
142
|
+
}], virtualScroll: [{
|
|
143
|
+
type: Input
|
|
144
|
+
}], selectionChanged: [{
|
|
145
|
+
type: Output
|
|
146
|
+
}], customSortFunction: [{
|
|
147
|
+
type: Output
|
|
148
|
+
}], toolbarTemplate: [{
|
|
149
|
+
type: ContentChild,
|
|
150
|
+
args: ['toolbar', { static: false }]
|
|
151
|
+
}], headerTemplate: [{
|
|
152
|
+
type: ContentChild,
|
|
153
|
+
args: ['header', { static: false }]
|
|
154
|
+
}], bodyTemplate: [{
|
|
155
|
+
type: ContentChild,
|
|
156
|
+
args: ['body', { static: false }]
|
|
157
|
+
}], primengTable: [{
|
|
158
|
+
type: ViewChild,
|
|
159
|
+
args: ['primengTable', { static: true }]
|
|
160
|
+
}] } });
|
|
161
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-table.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-table/cps-table.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-table/cps-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  TemplateRef,\n  ViewChild\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { Table, TableService, TableModule } from 'primeng/table';\nimport { TableUnsortDirective } from './table-unsort.directive';\nimport { SortEvent } from 'primeng/api';\n\nexport function tableFactory(tableComponent: CpsTableComponent) {\n  return tableComponent.primengTable;\n}\n\n@Component({\n  selector: 'cps-table',\n  standalone: true,\n  imports: [CommonModule, TableModule, TableUnsortDirective],\n  templateUrl: './cps-table.component.html',\n  styleUrls: ['./cps-table.component.scss'],\n  providers: [\n    TableService,\n    {\n      provide: Table,\n      useFactory: tableFactory,\n      // eslint-disable-next-line no-use-before-define\n      deps: [CpsTableComponent]\n    }\n  ]\n})\nexport class CpsTableComponent implements OnInit, AfterViewInit {\n  @Input() headers: string[] = [];\n  @Input() data: any[] = [];\n  @Input() columns: { [key: string]: any }[] = []; // combines both headers and data\n  @Input() striped = true;\n  @Input() bordered = true;\n  @Input() size: 'small' | 'normal' | 'large' = 'normal';\n  @Input() selectable = true;\n  @Input() emptyMessage = 'No data';\n  @Input() hasToolbar = true;\n  @Input() toolbarSize: 'small' | 'normal' = 'normal';\n  @Input() toolbarTitle = '';\n  @Input() sortMode: 'single' | 'multiple' = 'multiple';\n  @Input() customSort = false;\n  @Input() rowHover = true;\n  @Input() scrollable = true;\n  @Input() virtualScroll = false; // works only if scrollable is true\n\n  // @Input() draggableRows = false; TODO\n  // @Input() columnsToggle = false; TODO\n  // @Input() export = false; TODO\n  /* @Input() */ resizableColumns = false; // TODO\n  /* @Input() */ reorderableColumns = false; // TODO\n  // TODO CpsTableColumnFilterDirective (type date, text, boolean, range, categories, numeric)\n\n  @Output() selectionChanged = new EventEmitter<any[]>();\n\n  /**\n   * A function to implement custom sorting. customSort must be true.\n   * @param {any} any - sort meta.\n   * @group Emits\n   */\n  @Output() customSortFunction: EventEmitter<any> = new EventEmitter<any>();\n\n  styleClass = '';\n  selectedRows: any[] = [];\n\n  virtualScrollItemSize = 0;\n\n  // eslint-disable-next-line no-useless-constructor\n  constructor(private cdRef: ChangeDetectorRef) {}\n\n  ngOnInit(): void {\n    if (!this.scrollable) this.virtualScroll = false;\n    switch (this.size) {\n      case 'small':\n        this.styleClass = 'p-datatable-sm';\n        break;\n      case 'large':\n        this.styleClass = 'p-datatable-lg';\n        break;\n    }\n    switch (this.toolbarSize) {\n      case 'small':\n        this.styleClass += ' cps-tbar-small';\n        break;\n      case 'normal':\n        this.styleClass += ' cps-tbar-normal';\n        break;\n    }\n    if (this.striped) {\n      this.styleClass += ' p-datatable-striped';\n    }\n    if (this.bordered) {\n      this.styleClass += ' p-datatable-gridlines';\n    }\n  }\n\n  ngAfterViewInit() {\n    this.virtualScrollItemSize =\n      this.primengTable?.el?.nativeElement\n        ?.querySelector('.p-datatable-tbody')\n        ?.querySelector('tr')?.clientHeight || 0;\n    this.cdRef.detectChanges();\n  }\n\n  onSelectionChanged(selection: any[]) {\n    this.selectionChanged.emit(\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      selection.map(({ _defaultSortOrder, ...rest }) => rest)\n    );\n  }\n\n  onSortFunction(event: SortEvent) {\n    this.customSortFunction.emit(event);\n  }\n\n  @ContentChild('toolbar', { static: false })\n  public toolbarTemplate!: TemplateRef<any>;\n\n  @ContentChild('header', { static: false })\n  public headerTemplate!: TemplateRef<any>;\n\n  @ContentChild('body', { static: false })\n  public bodyTemplate!: TemplateRef<any>;\n\n  @ViewChild('primengTable', { static: true })\n  primengTable!: Table;\n}\n","<p-table\n  #primengTable\n  withUnsort\n  [styleClass]=\"styleClass\"\n  [value]=\"data\"\n  [columns]=\"columns\"\n  (selectionChange)=\"onSelectionChanged($event)\"\n  [resizableColumns]=\"resizableColumns\"\n  [reorderableColumns]=\"reorderableColumns\"\n  [scrollable]=\"scrollable\"\n  scrollHeight=\"flex\"\n  [virtualScroll]=\"virtualScroll\"\n  [virtualScrollItemSize]=\"virtualScrollItemSize\"\n  [virtualScrollOptions]=\"{ numToleratedItems: 3 }\"\n  [(selection)]=\"selectedRows\"\n  [metaKeySelection]=\"false\"\n  [rowHover]=\"rowHover\"\n  [customSort]=\"customSort\"\n  [sortMode]=\"sortMode\"\n  (sortFunction)=\"onSortFunction($event)\">\n  <ng-template pTemplate=\"caption\" *ngIf=\"hasToolbar\">\n    <ng-container *ngIf=\"toolbarTemplate\">\n      <ng-container *ngTemplateOutlet=\"toolbarTemplate\"></ng-container>\n    </ng-container>\n    <ng-container *ngIf=\"!toolbarTemplate\">\n      {{ toolbarTitle }}\n    </ng-container>\n  </ng-template>\n\n  <ng-template pTemplate=\"header\" let-columns>\n    <tr>\n      <th style=\"width: 4rem\" *ngIf=\"selectable\">\n        <p-tableHeaderCheckbox></p-tableHeaderCheckbox>\n      </th>\n      <ng-container *ngIf=\"headerTemplate\">\n        <ng-container *ngTemplateOutlet=\"headerTemplate\"></ng-container>\n      </ng-container>\n      <ng-container *ngIf=\"!headerTemplate\">\n        <th *ngFor=\"let h of headers\">{{ h }}</th>\n      </ng-container>\n    </tr>\n  </ng-template>\n\n  <ng-template pTemplate=\"body\" let-item let-rowIndex=\"rowIndex\">\n    <tr>\n      <td *ngIf=\"selectable\">\n        <p-tableCheckbox [value]=\"item\"></p-tableCheckbox>\n      </td>\n      <ng-container\n        pTemplate=\"body\"\n        *ngTemplateOutlet=\"\n          bodyTemplate;\n          context: { $implicit: item, rowIndex: rowIndex }\n        \"></ng-container>\n    </tr>\n  </ng-template>\n  <ng-template pTemplate=\"emptymessage\">\n    <tr>\n      <td colspan=\"4\">{{ emptyMessage }}</td>\n    </tr>\n  </ng-template>\n</p-table>\n"]}
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import { Directive, Host, Self, Optional } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "primeng/table";
|
|
4
|
+
export class TableUnsortDirective {
|
|
5
|
+
constructor(pTable) {
|
|
6
|
+
this.pTable = pTable;
|
|
7
|
+
this.defaultSortOrderInitialized = false;
|
|
8
|
+
pTable.tableService.valueSource$.subscribe((val) => {
|
|
9
|
+
if (val != null && val.length > 0 && !this.defaultSortOrderInitialized) {
|
|
10
|
+
let i = 0;
|
|
11
|
+
val.forEach((v) => {
|
|
12
|
+
v._defaultSortOrder = i++;
|
|
13
|
+
});
|
|
14
|
+
this.defaultSortOrderInitialized = true;
|
|
15
|
+
}
|
|
16
|
+
});
|
|
17
|
+
pTable.sort = (event) => {
|
|
18
|
+
if (pTable.sortMode === 'single') {
|
|
19
|
+
if (pTable.sortField === event.field && pTable.sortOrder === -1) {
|
|
20
|
+
event.field = '_defaultSortOrder';
|
|
21
|
+
}
|
|
22
|
+
pTable._sortOrder =
|
|
23
|
+
pTable.sortField === event.field
|
|
24
|
+
? pTable.sortOrder * -1
|
|
25
|
+
: pTable.defaultSortOrder;
|
|
26
|
+
pTable._sortField = event.field;
|
|
27
|
+
pTable.sortSingle();
|
|
28
|
+
}
|
|
29
|
+
if (pTable.sortMode === 'multiple') {
|
|
30
|
+
let resetIndex = false;
|
|
31
|
+
const sortMeta = pTable.getSortMeta(event.field);
|
|
32
|
+
if (sortMeta) {
|
|
33
|
+
for (let i = 0; i < pTable._multiSortMeta.length; i++) {
|
|
34
|
+
if (pTable._multiSortMeta[i].field === sortMeta.field) {
|
|
35
|
+
pTable._multiSortMeta.splice(i, 1);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
if (sortMeta.order === 1) {
|
|
39
|
+
sortMeta.order = sortMeta.order * -1;
|
|
40
|
+
pTable.multiSortMeta.push(sortMeta);
|
|
41
|
+
}
|
|
42
|
+
if (pTable._multiSortMeta?.length === 0) {
|
|
43
|
+
pTable.multiSortMeta.push({
|
|
44
|
+
field: '_defaultSortOrder',
|
|
45
|
+
order: pTable.defaultSortOrder
|
|
46
|
+
});
|
|
47
|
+
resetIndex = true;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
else {
|
|
51
|
+
if (!pTable.multiSortMeta) {
|
|
52
|
+
pTable._multiSortMeta = [];
|
|
53
|
+
}
|
|
54
|
+
pTable.multiSortMeta.push({
|
|
55
|
+
field: event.field,
|
|
56
|
+
order: pTable.defaultSortOrder
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
pTable.sortMultiple();
|
|
60
|
+
if (resetIndex)
|
|
61
|
+
pTable._multiSortMeta = [];
|
|
62
|
+
}
|
|
63
|
+
if (pTable.isStateful()) {
|
|
64
|
+
pTable.saveState();
|
|
65
|
+
}
|
|
66
|
+
pTable.anchorRowIndex = 0;
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
TableUnsortDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TableUnsortDirective, deps: [{ token: i1.Table, host: true, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Directive });
|
|
71
|
+
TableUnsortDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: TableUnsortDirective, isStandalone: true, selector: "[withUnsort]", ngImport: i0 });
|
|
72
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TableUnsortDirective, decorators: [{
|
|
73
|
+
type: Directive,
|
|
74
|
+
args: [{
|
|
75
|
+
standalone: true,
|
|
76
|
+
selector: '[withUnsort]'
|
|
77
|
+
}]
|
|
78
|
+
}], ctorParameters: function () { return [{ type: i1.Table, decorators: [{
|
|
79
|
+
type: Host
|
|
80
|
+
}, {
|
|
81
|
+
type: Self
|
|
82
|
+
}, {
|
|
83
|
+
type: Optional
|
|
84
|
+
}] }]; } });
|
|
85
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtdW5zb3J0LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Nwcy11aS1raXQvc3JjL2xpYi9jb21wb25lbnRzL2Nwcy10YWJsZS90YWJsZS11bnNvcnQuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQU9oRSxNQUFNLE9BQU8sb0JBQW9CO0lBRy9CLFlBQStDLE1BQWE7UUFBYixXQUFNLEdBQU4sTUFBTSxDQUFPO1FBRjVELGdDQUEyQixHQUFHLEtBQUssQ0FBQztRQUdsQyxNQUFNLENBQUMsWUFBWSxDQUFDLFlBQVksQ0FBQyxTQUFTLENBQUMsQ0FBQyxHQUFVLEVBQUUsRUFBRTtZQUN4RCxJQUFJLEdBQUcsSUFBSSxJQUFJLElBQUksR0FBRyxDQUFDLE1BQU0sR0FBRyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsMkJBQTJCLEVBQUU7Z0JBQ3RFLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztnQkFDVixHQUFHLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUU7b0JBQ2hCLENBQUMsQ0FBQyxpQkFBaUIsR0FBRyxDQUFDLEVBQUUsQ0FBQztnQkFDNUIsQ0FBQyxDQUFDLENBQUM7Z0JBQ0gsSUFBSSxDQUFDLDJCQUEyQixHQUFHLElBQUksQ0FBQzthQUN6QztRQUNILENBQUMsQ0FBQyxDQUFDO1FBRUgsTUFBTSxDQUFDLElBQUksR0FBRyxDQUFDLEtBQVUsRUFBRSxFQUFFO1lBQzNCLElBQUksTUFBTSxDQUFDLFFBQVEsS0FBSyxRQUFRLEVBQUU7Z0JBQ2hDLElBQUksTUFBTSxDQUFDLFNBQVMsS0FBSyxLQUFLLENBQUMsS0FBSyxJQUFJLE1BQU0sQ0FBQyxTQUFTLEtBQUssQ0FBQyxDQUFDLEVBQUU7b0JBQy9ELEtBQUssQ0FBQyxLQUFLLEdBQUcsbUJBQW1CLENBQUM7aUJBQ25DO2dCQUVELE1BQU0sQ0FBQyxVQUFVO29CQUNmLE1BQU0sQ0FBQyxTQUFTLEtBQUssS0FBSyxDQUFDLEtBQUs7d0JBQzlCLENBQUMsQ0FBQyxNQUFNLENBQUMsU0FBUyxHQUFHLENBQUMsQ0FBQzt3QkFDdkIsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQztnQkFDOUIsTUFBTSxDQUFDLFVBQVUsR0FBRyxLQUFLLENBQUMsS0FBSyxDQUFDO2dCQUNoQyxNQUFNLENBQUMsVUFBVSxFQUFFLENBQUM7YUFDckI7WUFDRCxJQUFJLE1BQU0sQ0FBQyxRQUFRLEtBQUssVUFBVSxFQUFFO2dCQUNsQyxJQUFJLFVBQVUsR0FBRyxLQUFLLENBQUM7Z0JBQ3ZCLE1BQU0sUUFBUSxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO2dCQUVqRCxJQUFJLFFBQVEsRUFBRTtvQkFDWixLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsTUFBTSxDQUFDLGNBQWMsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLEVBQUU7d0JBQ3JELElBQUksTUFBTSxDQUFDLGNBQWMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLEtBQUssUUFBUSxDQUFDLEtBQUssRUFBRTs0QkFDckQsTUFBTSxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO3lCQUNwQztxQkFDRjtvQkFDRCxJQUFJLFFBQVEsQ0FBQyxLQUFLLEtBQUssQ0FBQyxFQUFFO3dCQUN4QixRQUFRLENBQUMsS0FBSyxHQUFHLFFBQVEsQ0FBQyxLQUFLLEdBQUcsQ0FBQyxDQUFDLENBQUM7d0JBQ3JDLE1BQU0sQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO3FCQUNyQztvQkFDRCxJQUFJLE1BQU0sQ0FBQyxjQUFjLEVBQUUsTUFBTSxLQUFLLENBQUMsRUFBRTt3QkFDdkMsTUFBTSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUM7NEJBQ3hCLEtBQUssRUFBRSxtQkFBbUI7NEJBQzFCLEtBQUssRUFBRSxNQUFNLENBQUMsZ0JBQWdCO3lCQUMvQixDQUFDLENBQUM7d0JBQ0gsVUFBVSxHQUFHLElBQUksQ0FBQztxQkFDbkI7aUJBQ0Y7cUJBQU07b0JBQ0wsSUFBSSxDQUFDLE1BQU0sQ0FBQyxhQUFhLEVBQUU7d0JBQ3pCLE1BQU0sQ0FBQyxjQUFjLEdBQUcsRUFBRSxDQUFDO3FCQUM1QjtvQkFDRCxNQUFNLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQzt3QkFDeEIsS0FBSyxFQUFFLEtBQUssQ0FBQyxLQUFLO3dCQUNsQixLQUFLLEVBQUUsTUFBTSxDQUFDLGdCQUFnQjtxQkFDL0IsQ0FBQyxDQUFDO2lCQUNKO2dCQUVELE1BQU0sQ0FBQyxZQUFZLEVBQUUsQ0FBQztnQkFDdEIsSUFBSSxVQUFVO29CQUFFLE1BQU0sQ0FBQyxjQUFjLEdBQUcsRUFBRSxDQUFDO2FBQzVDO1lBRUQsSUFBSSxNQUFNLENBQUMsVUFBVSxFQUFFLEVBQUU7Z0JBQ3ZCLE1BQU0sQ0FBQyxTQUFTLEVBQUUsQ0FBQzthQUNwQjtZQUVELE1BQU0sQ0FBQyxjQUFjLEdBQUcsQ0FBQyxDQUFDO1FBQzVCLENBQUMsQ0FBQztJQUNKLENBQUM7O2lIQXBFVSxvQkFBb0I7cUdBQXBCLG9CQUFvQjsyRkFBcEIsb0JBQW9CO2tCQUpoQyxTQUFTO21CQUFDO29CQUNULFVBQVUsRUFBRSxJQUFJO29CQUNoQixRQUFRLEVBQUUsY0FBYztpQkFDekI7OzBCQUljLElBQUk7OzBCQUFJLElBQUk7OzBCQUFJLFFBQVEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEhvc3QsIFNlbGYsIE9wdGlvbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUYWJsZSB9IGZyb20gJ3ByaW1lbmcvdGFibGUnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgc2VsZWN0b3I6ICdbd2l0aFVuc29ydF0nXG59KVxuZXhwb3J0IGNsYXNzIFRhYmxlVW5zb3J0RGlyZWN0aXZlIHtcbiAgZGVmYXVsdFNvcnRPcmRlckluaXRpYWxpemVkID0gZmFsc2U7XG5cbiAgY29uc3RydWN0b3IoQEhvc3QoKSBAU2VsZigpIEBPcHRpb25hbCgpIHB1YmxpYyBwVGFibGU6IFRhYmxlKSB7XG4gICAgcFRhYmxlLnRhYmxlU2VydmljZS52YWx1ZVNvdXJjZSQuc3Vic2NyaWJlKCh2YWw6IGFueVtdKSA9PiB7XG4gICAgICBpZiAodmFsICE9IG51bGwgJiYgdmFsLmxlbmd0aCA+IDAgJiYgIXRoaXMuZGVmYXVsdFNvcnRPcmRlckluaXRpYWxpemVkKSB7XG4gICAgICAgIGxldCBpID0gMDtcbiAgICAgICAgdmFsLmZvckVhY2goKHYpID0+IHtcbiAgICAgICAgICB2Ll9kZWZhdWx0U29ydE9yZGVyID0gaSsrO1xuICAgICAgICB9KTtcbiAgICAgICAgdGhpcy5kZWZhdWx0U29ydE9yZGVySW5pdGlhbGl6ZWQgPSB0cnVlO1xuICAgICAgfVxuICAgIH0pO1xuXG4gICAgcFRhYmxlLnNvcnQgPSAoZXZlbnQ6IGFueSkgPT4ge1xuICAgICAgaWYgKHBUYWJsZS5zb3J0TW9kZSA9PT0gJ3NpbmdsZScpIHtcbiAgICAgICAgaWYgKHBUYWJsZS5zb3J0RmllbGQgPT09IGV2ZW50LmZpZWxkICYmIHBUYWJsZS5zb3J0T3JkZXIgPT09IC0xKSB7XG4gICAgICAgICAgZXZlbnQuZmllbGQgPSAnX2RlZmF1bHRTb3J0T3JkZXInO1xuICAgICAgICB9XG5cbiAgICAgICAgcFRhYmxlLl9zb3J0T3JkZXIgPVxuICAgICAgICAgIHBUYWJsZS5zb3J0RmllbGQgPT09IGV2ZW50LmZpZWxkXG4gICAgICAgICAgICA/IHBUYWJsZS5zb3J0T3JkZXIgKiAtMVxuICAgICAgICAgICAgOiBwVGFibGUuZGVmYXVsdFNvcnRPcmRlcjtcbiAgICAgICAgcFRhYmxlLl9zb3J0RmllbGQgPSBldmVudC5maWVsZDtcbiAgICAgICAgcFRhYmxlLnNvcnRTaW5nbGUoKTtcbiAgICAgIH1cbiAgICAgIGlmIChwVGFibGUuc29ydE1vZGUgPT09ICdtdWx0aXBsZScpIHtcbiAgICAgICAgbGV0IHJlc2V0SW5kZXggPSBmYWxzZTtcbiAgICAgICAgY29uc3Qgc29ydE1ldGEgPSBwVGFibGUuZ2V0U29ydE1ldGEoZXZlbnQuZmllbGQpO1xuXG4gICAgICAgIGlmIChzb3J0TWV0YSkge1xuICAgICAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgcFRhYmxlLl9tdWx0aVNvcnRNZXRhLmxlbmd0aDsgaSsrKSB7XG4gICAgICAgICAgICBpZiAocFRhYmxlLl9tdWx0aVNvcnRNZXRhW2ldLmZpZWxkID09PSBzb3J0TWV0YS5maWVsZCkge1xuICAgICAgICAgICAgICBwVGFibGUuX211bHRpU29ydE1ldGEuc3BsaWNlKGksIDEpO1xuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgICBpZiAoc29ydE1ldGEub3JkZXIgPT09IDEpIHtcbiAgICAgICAgICAgIHNvcnRNZXRhLm9yZGVyID0gc29ydE1ldGEub3JkZXIgKiAtMTtcbiAgICAgICAgICAgIHBUYWJsZS5tdWx0aVNvcnRNZXRhLnB1c2goc29ydE1ldGEpO1xuICAgICAgICAgIH1cbiAgICAgICAgICBpZiAocFRhYmxlLl9tdWx0aVNvcnRNZXRhPy5sZW5ndGggPT09IDApIHtcbiAgICAgICAgICAgIHBUYWJsZS5tdWx0aVNvcnRNZXRhLnB1c2goe1xuICAgICAgICAgICAgICBmaWVsZDogJ19kZWZhdWx0U29ydE9yZGVyJyxcbiAgICAgICAgICAgICAgb3JkZXI6IHBUYWJsZS5kZWZhdWx0U29ydE9yZGVyXG4gICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIHJlc2V0SW5kZXggPSB0cnVlO1xuICAgICAgICAgIH1cbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICBpZiAoIXBUYWJsZS5tdWx0aVNvcnRNZXRhKSB7XG4gICAgICAgICAgICBwVGFibGUuX211bHRpU29ydE1ldGEgPSBbXTtcbiAgICAgICAgICB9XG4gICAgICAgICAgcFRhYmxlLm11bHRpU29ydE1ldGEucHVzaCh7XG4gICAgICAgICAgICBmaWVsZDogZXZlbnQuZmllbGQsXG4gICAgICAgICAgICBvcmRlcjogcFRhYmxlLmRlZmF1bHRTb3J0T3JkZXJcbiAgICAgICAgICB9KTtcbiAgICAgICAgfVxuXG4gICAgICAgIHBUYWJsZS5zb3J0TXVsdGlwbGUoKTtcbiAgICAgICAgaWYgKHJlc2V0SW5kZXgpIHBUYWJsZS5fbXVsdGlTb3J0TWV0YSA9IFtdO1xuICAgICAgfVxuXG4gICAgICBpZiAocFRhYmxlLmlzU3RhdGVmdWwoKSkge1xuICAgICAgICBwVGFibGUuc2F2ZVN0YXRlKCk7XG4gICAgICB9XG5cbiAgICAgIHBUYWJsZS5hbmNob3JSb3dJbmRleCA9IDA7XG4gICAgfTtcbiAgfVxufVxuIl19
|
package/esm2020/public-api.mjs
CHANGED
|
@@ -10,6 +10,8 @@ export * from './lib/components/cps-tree-autocomplete/cps-tree-autocomplete.comp
|
|
|
10
10
|
export * from './lib/components/cps-button/cps-button.component';
|
|
11
11
|
export * from './lib/components/cps-checkbox/cps-checkbox.component';
|
|
12
12
|
export * from './lib/components/cps-radio/cps-radio.component';
|
|
13
|
+
export * from './lib/components/cps-table/cps-table.component';
|
|
14
|
+
export * from './lib/components/cps-table/cps-table-column-sortable.directive';
|
|
13
15
|
export * from './lib/components/cps-tag/cps-tag.component';
|
|
14
16
|
export * from './lib/components/cps-chip/cps-chip.component';
|
|
15
17
|
export * from './lib/components/cps-loader/cps-loader.component';
|
|
@@ -20,4 +22,4 @@ export * from './lib/components/cps-datepicker/cps-datepicker.component';
|
|
|
20
22
|
export * from './lib/components/cps-textarea/cps-textarea.component';
|
|
21
23
|
export * from './lib/components/cps-button-toggle/cps-button-toggle.component';
|
|
22
24
|
export * from './lib/utils/colors-utils';
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2Nwcy11aS1raXQvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsZ0RBQWdELENBQUM7QUFDL0QsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLDREQUE0RCxDQUFDO0FBQzNFLGNBQWMsOERBQThELENBQUM7QUFDN0UsY0FBYyx3RUFBd0UsQ0FBQztBQUN2RixjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMsc0RBQXNELENBQUM7QUFDckUsY0FBYyxnREFBZ0QsQ0FBQztBQUMvRCxjQUFjLGdEQUFnRCxDQUFDO0FBQy9ELGNBQWMsZ0VBQWdFLENBQUM7QUFDL0UsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYyxvRUFBb0UsQ0FBQztBQUNuRixjQUFjLHdFQUF3RSxDQUFDO0FBQ3ZGLGNBQWMsb0VBQW9FLENBQUM7QUFDbkYsY0FBYywwREFBMEQsQ0FBQztBQUN6RSxjQUFjLHNEQUFzRCxDQUFDO0FBQ3JFLGNBQWMsZ0VBQWdFLENBQUM7QUFDL0UsY0FBYywwQkFBMEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgY3BzLXVpLWtpdFxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWljb24vY3BzLWljb24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWlucHV0L2Nwcy1pbnB1dC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtc2VsZWN0L2Nwcy1zZWxlY3QuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRyZWUtc2VsZWN0L2Nwcy10cmVlLXNlbGVjdC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtYXV0b2NvbXBsZXRlL2Nwcy1hdXRvY29tcGxldGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRyZWUtYXV0b2NvbXBsZXRlL2Nwcy10cmVlLWF1dG9jb21wbGV0ZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtYnV0dG9uL2Nwcy1idXR0b24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWNoZWNrYm94L2Nwcy1jaGVja2JveC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtcmFkaW8vY3BzLXJhZGlvLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10YWJsZS9jcHMtdGFibGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRhYmxlL2Nwcy10YWJsZS1jb2x1bW4tc29ydGFibGUuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRhZy9jcHMtdGFnLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1jaGlwL2Nwcy1jaGlwLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1sb2FkZXIvY3BzLWxvYWRlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtZXhwYW5zaW9uLXBhbmVsL2Nwcy1leHBhbnNpb24tcGFuZWwuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXByb2dyZXNzLWNpcmN1bGFyL2Nwcy1wcm9ncmVzcy1jaXJjdWxhci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtcHJvZ3Jlc3MtbGluZWFyL2Nwcy1wcm9ncmVzcy1saW5lYXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWRhdGVwaWNrZXIvY3BzLWRhdGVwaWNrZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRleHRhcmVhL2Nwcy10ZXh0YXJlYS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtYnV0dG9uLXRvZ2dsZS9jcHMtYnV0dG9uLXRvZ2dsZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXRpbHMvY29sb3JzLXV0aWxzJztcbiJdfQ==
|