cps-ui-kit 0.140.0 → 0.141.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/esm2020/lib/components/cps-autocomplete/cps-autocomplete.component.mjs +137 -4
- package/esm2020/lib/components/cps-button/cps-button.component.mjs +55 -2
- package/esm2020/lib/components/cps-button-toggle/cps-button-toggle.component.mjs +63 -2
- package/esm2020/lib/components/cps-checkbox/cps-checkbox.component.mjs +50 -1
- package/esm2020/lib/components/cps-chip/cps-chip.component.mjs +34 -1
- package/esm2020/lib/components/cps-datepicker/cps-datepicker.component.mjs +78 -1
- package/esm2020/lib/components/cps-expansion-panel/cps-expansion-panel.component.mjs +51 -1
- package/esm2020/lib/components/cps-icon/cps-icon.component.mjs +17 -1
- package/esm2020/lib/components/cps-info-circle/cps-info-circle.component.mjs +29 -1
- package/esm2020/lib/components/cps-input/cps-input.component.mjs +131 -1
- package/esm2020/lib/components/cps-loader/cps-loader.component.mjs +21 -1
- package/esm2020/lib/components/cps-menu/cps-menu.component.mjs +58 -2
- package/esm2020/lib/components/cps-paginator/cps-paginator.component.mjs +38 -1
- package/esm2020/lib/components/cps-paginator/pipes/cps-paginate.pipe.mjs +5 -1
- package/esm2020/lib/components/cps-progress-circular/cps-progress-circular.component.mjs +17 -1
- package/esm2020/lib/components/cps-progress-linear/cps-progress-linear.component.mjs +29 -1
- package/esm2020/lib/components/cps-radio-group/cps-radio/cps-radio.component.mjs +5 -1
- package/esm2020/lib/components/cps-radio-group/cps-radio-button/cps-radio-button.component.mjs +18 -1
- package/esm2020/lib/components/cps-radio-group/cps-radio-group.component.mjs +50 -1
- package/esm2020/lib/components/cps-select/cps-select.component.mjs +137 -4
- package/esm2020/lib/components/cps-sidebar-menu/cps-sidebar-menu.component.mjs +21 -1
- package/esm2020/lib/components/cps-tab-group/cps-tab/cps-tab.component.mjs +41 -1
- package/esm2020/lib/components/cps-tab-group/cps-tab-group.component.mjs +32 -2
- package/esm2020/lib/components/cps-table/components/internal/table-column-filter/table-column-filter.component.mjs +67 -3
- package/esm2020/lib/components/cps-table/components/internal/table-column-filter-constraint/table-column-filter-constraint.component.mjs +31 -3
- package/esm2020/lib/components/cps-table/components/internal/table-row-menu/table-row-menu.component.mjs +51 -0
- package/esm2020/lib/components/cps-table/cps-table.component.mjs +312 -8
- package/esm2020/lib/components/cps-table/directives/cps-table-column-filter.directive.mjs +67 -3
- package/esm2020/lib/components/cps-table/directives/cps-table-column-sortable.directive.mjs +9 -1
- package/esm2020/lib/components/cps-table/directives/cps-table-header-selectable.directive.mjs +5 -1
- package/esm2020/lib/components/cps-table/directives/cps-table-row-selectable.directive.mjs +5 -1
- package/esm2020/lib/components/cps-tag/cps-tag.component.mjs +35 -2
- package/esm2020/lib/components/cps-textarea/cps-textarea.component.mjs +101 -1
- package/esm2020/lib/components/cps-tree-autocomplete/cps-tree-autocomplete.component.mjs +17 -1
- package/esm2020/lib/components/cps-tree-select/cps-tree-select.component.mjs +13 -1
- package/esm2020/lib/components/cps-tree-table/cps-tree-table.component.mjs +314 -7
- package/esm2020/lib/components/cps-tree-table/directives/cps-tree-table-column-filter.directive.mjs +63 -3
- package/esm2020/lib/components/cps-tree-table/directives/cps-tree-table-column-sortable.directive.mjs +9 -1
- package/esm2020/lib/components/cps-tree-table/directives/cps-tree-table-header-selectable.directive.mjs +5 -1
- package/esm2020/lib/components/cps-tree-table/directives/cps-tree-table-row-selectable.directive.mjs +5 -1
- package/esm2020/lib/components/cps-tree-table/directives/cps-tree-table-row-toggler.directive.mjs +5 -1
- package/esm2020/lib/components/internal/cps-base-tree-dropdown/cps-base-tree-dropdown.component.mjs +118 -1
- package/esm2020/lib/directives/cps-tooltip.directive.mjs +37 -1
- package/esm2020/lib/services/cps-dialog/cps-dialog.service.mjs +2 -2
- package/fesm2015/cps-ui-kit.mjs +2312 -37
- package/fesm2015/cps-ui-kit.mjs.map +1 -1
- package/fesm2020/cps-ui-kit.mjs +2312 -37
- package/fesm2020/cps-ui-kit.mjs.map +1 -1
- package/lib/components/cps-autocomplete/cps-autocomplete.component.d.ts +133 -0
- package/lib/components/cps-button/cps-button.component.d.ts +53 -0
- package/lib/components/cps-button-toggle/cps-button-toggle.component.d.ts +61 -0
- package/lib/components/cps-checkbox/cps-checkbox.component.d.ts +49 -0
- package/lib/components/cps-chip/cps-chip.component.d.ts +33 -0
- package/lib/components/cps-datepicker/cps-datepicker.component.d.ts +85 -0
- package/lib/components/cps-expansion-panel/cps-expansion-panel.component.d.ts +50 -0
- package/lib/components/cps-icon/cps-icon.component.d.ts +16 -0
- package/lib/components/cps-info-circle/cps-info-circle.component.d.ts +28 -0
- package/lib/components/cps-input/cps-input.component.d.ts +130 -0
- package/lib/components/cps-loader/cps-loader.component.d.ts +20 -0
- package/lib/components/cps-menu/cps-menu.component.d.ts +56 -0
- package/lib/components/cps-paginator/cps-paginator.component.d.ts +37 -0
- package/lib/components/cps-paginator/pipes/cps-paginate.pipe.d.ts +4 -0
- package/lib/components/cps-progress-circular/cps-progress-circular.component.d.ts +16 -0
- package/lib/components/cps-progress-linear/cps-progress-linear.component.d.ts +28 -0
- package/lib/components/cps-radio-group/cps-radio/cps-radio.component.d.ts +8 -0
- package/lib/components/cps-radio-group/cps-radio-button/cps-radio-button.component.d.ts +21 -0
- package/lib/components/cps-radio-group/cps-radio-group.component.d.ts +49 -0
- package/lib/components/cps-select/cps-select.component.d.ts +133 -0
- package/lib/components/cps-sidebar-menu/cps-sidebar-menu.component.d.ts +21 -1
- package/lib/components/cps-tab-group/cps-tab/cps-tab.component.d.ts +40 -0
- package/lib/components/cps-tab-group/cps-tab-group.component.d.ts +30 -0
- package/lib/components/cps-table/components/internal/table-column-filter/table-column-filter.component.d.ts +68 -0
- package/lib/components/cps-table/components/internal/table-column-filter-constraint/table-column-filter-constraint.component.d.ts +36 -0
- package/lib/components/cps-table/{table-row-menu → components/internal/table-row-menu}/table-row-menu.component.d.ts +15 -1
- package/lib/components/cps-table/cps-table.component.d.ts +304 -0
- package/lib/components/cps-table/directives/cps-table-column-filter.directive.d.ts +68 -0
- package/lib/components/cps-table/directives/cps-table-column-sortable.directive.d.ts +8 -0
- package/lib/components/cps-table/directives/cps-table-header-selectable.directive.d.ts +4 -0
- package/lib/components/cps-table/directives/cps-table-row-selectable.directive.d.ts +8 -0
- package/lib/components/cps-tag/cps-tag.component.d.ts +33 -0
- package/lib/components/cps-textarea/cps-textarea.component.d.ts +100 -0
- package/lib/components/cps-tree-autocomplete/cps-tree-autocomplete.component.d.ts +16 -0
- package/lib/components/cps-tree-select/cps-tree-select.component.d.ts +12 -0
- package/lib/components/cps-tree-table/cps-tree-table.component.d.ts +307 -0
- package/lib/components/cps-tree-table/directives/cps-tree-table-column-filter.directive.d.ts +64 -0
- package/lib/components/cps-tree-table/directives/cps-tree-table-column-sortable.directive.d.ts +8 -0
- package/lib/components/cps-tree-table/directives/cps-tree-table-header-selectable.directive.d.ts +4 -0
- package/lib/components/cps-tree-table/directives/cps-tree-table-row-selectable.directive.d.ts +8 -0
- package/lib/components/cps-tree-table/directives/cps-tree-table-row-toggler.directive.d.ts +8 -0
- package/lib/components/internal/cps-base-tree-dropdown/cps-base-tree-dropdown.component.d.ts +117 -0
- package/lib/directives/cps-tooltip.directive.d.ts +40 -0
- package/lib/services/cps-dialog/cps-dialog.service.d.ts +1 -1
- package/package.json +1 -1
- package/esm2020/lib/components/cps-table/table-row-menu/table-row-menu.component.mjs +0 -37
|
@@ -1,24 +1,88 @@
|
|
|
1
1
|
import { Directive, Input } from '@angular/core';
|
|
2
2
|
import { TableColumnFilterComponent } from '../components/internal/table-column-filter/table-column-filter.component';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
|
+
/**
|
|
5
|
+
* CpsTableColumnFilterDirective is a filtering directive used to filter single or multiple columns in table.
|
|
6
|
+
* @group Directives
|
|
7
|
+
*/
|
|
4
8
|
export class CpsTableColumnFilterDirective {
|
|
5
9
|
constructor(elementRef, viewContainerRef) {
|
|
6
10
|
this.elementRef = elementRef;
|
|
7
11
|
this.viewContainerRef = viewContainerRef;
|
|
12
|
+
/**
|
|
13
|
+
* Type of a filter in table, it can be of type "number", "boolean", "text", "date" or "category".
|
|
14
|
+
* @group Props
|
|
15
|
+
*/
|
|
8
16
|
this.filterType = 'text';
|
|
17
|
+
/**
|
|
18
|
+
* Whether the filter menu should be persistent.
|
|
19
|
+
* @group Props
|
|
20
|
+
*/
|
|
9
21
|
this.filterPersistent = false;
|
|
22
|
+
/**
|
|
23
|
+
* Whether the filter should have clear button.
|
|
24
|
+
* @group Props
|
|
25
|
+
*/
|
|
10
26
|
this.filterShowClearButton = true;
|
|
27
|
+
/**
|
|
28
|
+
* Whether the filter should have apply button.
|
|
29
|
+
* @group Props
|
|
30
|
+
*/
|
|
11
31
|
this.filterShowApplyButton = true;
|
|
32
|
+
/**
|
|
33
|
+
* Whether the filter should have close button.
|
|
34
|
+
* @group Props
|
|
35
|
+
*/
|
|
12
36
|
this.filterShowCloseButton = false;
|
|
37
|
+
/**
|
|
38
|
+
* Whether the filter should have match modes.
|
|
39
|
+
* @group Props
|
|
40
|
+
*/
|
|
13
41
|
this.filterShowMatchModes = true;
|
|
42
|
+
/**
|
|
43
|
+
* Match modes for filter.
|
|
44
|
+
* @group Props
|
|
45
|
+
*/
|
|
14
46
|
this.filterMatchModes = [];
|
|
47
|
+
/**
|
|
48
|
+
* Whether the filter should have operator.
|
|
49
|
+
* @group Props
|
|
50
|
+
*/
|
|
15
51
|
this.filterShowOperator = true;
|
|
52
|
+
/**
|
|
53
|
+
* Maximum number of constraints.
|
|
54
|
+
* @group Props
|
|
55
|
+
*/
|
|
16
56
|
this.filterMaxConstraints = 2;
|
|
57
|
+
/**
|
|
58
|
+
* Title of the filter.
|
|
59
|
+
* @group Props
|
|
60
|
+
*/
|
|
17
61
|
this.filterHeaderTitle = '';
|
|
62
|
+
/**
|
|
63
|
+
* Whether the filter should hide on clear.
|
|
64
|
+
* @group Props
|
|
65
|
+
*/
|
|
18
66
|
this.filterHideOnClear = false;
|
|
67
|
+
/**
|
|
68
|
+
* Options for category filter.
|
|
69
|
+
* @group Props
|
|
70
|
+
*/
|
|
19
71
|
this.filterCategoryOptions = [];
|
|
20
|
-
|
|
21
|
-
|
|
72
|
+
/**
|
|
73
|
+
* Whether to show category filter as button toggles.
|
|
74
|
+
* @group Props
|
|
75
|
+
*/
|
|
76
|
+
this.filterAsButtonToggle = false;
|
|
77
|
+
/**
|
|
78
|
+
* Single selection for category filter.
|
|
79
|
+
* @group Props
|
|
80
|
+
*/
|
|
81
|
+
this.filterSingleSelection = false;
|
|
82
|
+
/**
|
|
83
|
+
* Placeholder for filter constraints.
|
|
84
|
+
* @group Props
|
|
85
|
+
*/
|
|
22
86
|
this.filterPlaceholder = '';
|
|
23
87
|
this.filterCompRef = this.viewContainerRef.createComponent(TableColumnFilterComponent);
|
|
24
88
|
}
|
|
@@ -114,4 +178,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
114
178
|
}], filterPlaceholder: [{
|
|
115
179
|
type: Input
|
|
116
180
|
}] } });
|
|
117
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-table-column-filter.directive.js","sourceRoot":"","sources":["../../../../../../../projects/cps-ui-kit/src/lib/components/cps-table/directives/cps-table-column-filter.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ComponentRef,\n  Directive,\n  ElementRef,\n  Input,\n  OnDestroy,\n  OnInit,\n  OnChanges,\n  ViewContainerRef\n} from '@angular/core';\n\nimport {\n  CpsColumnFilterCategoryOption,\n  CpsColumnFilterMatchMode,\n  CpsColumnFilterType\n} from '../cps-column-filter-types';\nimport { TableColumnFilterComponent } from '../components/internal/table-column-filter/table-column-filter.component';\n\n@Directive({\n  standalone: true,\n  selector: '[cpsTColFilter]',\n  exportAs: 'cpsTColFilter'\n})\nexport class CpsTableColumnFilterDirective\n  implements OnInit, OnChanges, OnDestroy\n{\n  @Input('cpsTColFilter') field: string | undefined;\n  @Input() filterType: CpsColumnFilterType = 'text';\n  @Input() filterPersistent = false;\n  @Input() filterShowClearButton = true;\n  @Input() filterShowApplyButton = true;\n  @Input() filterShowCloseButton = false;\n  @Input() filterShowMatchModes = true;\n  @Input() filterMatchModes: CpsColumnFilterMatchMode[] = [];\n  @Input() filterShowOperator = true;\n  @Input() filterMaxConstraints = 2;\n  @Input() filterHeaderTitle = '';\n  @Input() filterHideOnClear = false;\n  @Input() filterCategoryOptions: CpsColumnFilterCategoryOption[] | string[] =\n    [];\n\n  @Input() filterAsButtonToggle = false; // for category filterType only\n  @Input() filterSingleSelection = false; // for category filterType only\n  @Input() filterPlaceholder = '';\n\n  filterCompRef: ComponentRef<TableColumnFilterComponent>;\n\n  constructor(\n    private elementRef: ElementRef,\n    private viewContainerRef: ViewContainerRef\n  ) {\n    this.filterCompRef = this.viewContainerRef.createComponent(\n      TableColumnFilterComponent\n    );\n  }\n\n  ngOnInit(): void {\n    this.elementRef.nativeElement.firstChild.after(\n      this.filterCompRef.location.nativeElement\n    );\n  }\n\n  ngOnChanges(): void {\n    this.filterCompRef.setInput('field', this.field);\n    this.filterCompRef.setInput('type', this.filterType);\n    this.filterCompRef.setInput('persistent', this.filterPersistent);\n    this.filterCompRef.setInput('showClearButton', this.filterShowClearButton);\n    this.filterCompRef.setInput('showApplyButton', this.filterShowApplyButton);\n    this.filterCompRef.setInput('showCloseButton', this.filterShowCloseButton);\n    this.filterCompRef.setInput('showMatchModes', this.filterShowMatchModes);\n    this.filterCompRef.setInput('matchModes', this.filterMatchModes);\n    this.filterCompRef.setInput('showOperator', this.filterShowOperator);\n    this.filterCompRef.setInput('maxConstraints', this.filterMaxConstraints);\n    this.filterCompRef.setInput('headerTitle', this.filterHeaderTitle);\n    this.filterCompRef.setInput('hideOnClear', this.filterHideOnClear);\n    this.filterCompRef.setInput('categoryOptions', this.filterCategoryOptions);\n    this.filterCompRef.setInput('asButtonToggle', this.filterAsButtonToggle);\n    this.filterCompRef.setInput('singleSelection', this.filterSingleSelection);\n    this.filterCompRef.setInput(\n      'placeholder',\n      this.filterPlaceholder || this._getDefaultPlaceholder()\n    );\n  }\n\n  private _getDefaultPlaceholder() {\n    switch (this.filterType) {\n      case 'text':\n        return 'Please enter';\n      case 'number':\n        return 'Enter value';\n      case 'date':\n        return 'Select date';\n      case 'category':\n        return 'Please select';\n      default:\n        return '';\n    }\n  }\n\n  hideFilter() {\n    this.filterCompRef?.instance?.hide();\n  }\n\n  clearFilter() {\n    this.filterCompRef?.instance?.clearFilter();\n  }\n\n  clearFilterValues() {\n    this.filterCompRef?.instance?.clearFilterValues();\n  }\n\n  ngOnDestroy(): void {\n    this.filterCompRef.destroy();\n    this.viewContainerRef.clear();\n  }\n}\n"]}
|
|
181
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-table-column-filter.directive.js","sourceRoot":"","sources":["../../../../../../../projects/cps-ui-kit/src/lib/components/cps-table/directives/cps-table-column-filter.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ComponentRef,\n  Directive,\n  ElementRef,\n  Input,\n  OnDestroy,\n  OnInit,\n  OnChanges,\n  ViewContainerRef\n} from '@angular/core';\n\nimport {\n  CpsColumnFilterCategoryOption,\n  CpsColumnFilterMatchMode,\n  CpsColumnFilterType\n} from '../cps-column-filter-types';\nimport { TableColumnFilterComponent } from '../components/internal/table-column-filter/table-column-filter.component';\n\n/**\n * CpsTableColumnFilterDirective is a filtering directive used to filter single or multiple columns in table.\n * @group Directives\n */\n@Directive({\n  standalone: true,\n  selector: '[cpsTColFilter]',\n  exportAs: 'cpsTColFilter'\n})\nexport class CpsTableColumnFilterDirective\n  implements OnInit, OnChanges, OnDestroy\n{\n  /**\n   * Name of the column to be filtered.\n   * @group Props\n   */\n  @Input('cpsTColFilter') field: string | undefined;\n\n  /**\n   * Type of a filter in table, it can be of type \"number\", \"boolean\", \"text\", \"date\" or \"category\".\n   * @group Props\n   */\n  @Input() filterType: CpsColumnFilterType = 'text';\n\n  /**\n   * Whether the filter menu should be persistent.\n   * @group Props\n   */\n  @Input() filterPersistent = false;\n\n  /**\n   * Whether the filter should have clear button.\n   * @group Props\n   */\n  @Input() filterShowClearButton = true;\n\n  /**\n   * Whether the filter should have apply button.\n   * @group Props\n   */\n  @Input() filterShowApplyButton = true;\n\n  /**\n   * Whether the filter should have close button.\n   * @group Props\n   */\n  @Input() filterShowCloseButton = false;\n\n  /**\n   * Whether the filter should have match modes.\n   * @group Props\n   */\n  @Input() filterShowMatchModes = true;\n\n  /**\n   * Match modes for filter.\n   * @group Props\n   */\n  @Input() filterMatchModes: CpsColumnFilterMatchMode[] = [];\n\n  /**\n   * Whether the filter should have operator.\n   * @group Props\n   */\n  @Input() filterShowOperator = true;\n\n  /**\n   * Maximum number of constraints.\n   * @group Props\n   */\n  @Input() filterMaxConstraints = 2;\n\n  /**\n   * Title of the filter.\n   * @group Props\n   */\n  @Input() filterHeaderTitle = '';\n\n  /**\n   * Whether the filter should hide on clear.\n   * @group Props\n   */\n  @Input() filterHideOnClear = false;\n\n  /**\n   * Options for category filter.\n   * @group Props\n   */\n  @Input() filterCategoryOptions: CpsColumnFilterCategoryOption[] | string[] =\n    [];\n\n  /**\n   * Whether to show category filter as button toggles.\n   * @group Props\n   */\n  @Input() filterAsButtonToggle = false;\n\n  /**\n   * Single selection for category filter.\n   * @group Props\n   */\n  @Input() filterSingleSelection = false;\n\n  /**\n   * Placeholder for filter constraints.\n   * @group Props\n   */\n  @Input() filterPlaceholder = '';\n\n  filterCompRef: ComponentRef<TableColumnFilterComponent>;\n\n  constructor(\n    private elementRef: ElementRef,\n    private viewContainerRef: ViewContainerRef\n  ) {\n    this.filterCompRef = this.viewContainerRef.createComponent(\n      TableColumnFilterComponent\n    );\n  }\n\n  ngOnInit(): void {\n    this.elementRef.nativeElement.firstChild.after(\n      this.filterCompRef.location.nativeElement\n    );\n  }\n\n  ngOnChanges(): void {\n    this.filterCompRef.setInput('field', this.field);\n    this.filterCompRef.setInput('type', this.filterType);\n    this.filterCompRef.setInput('persistent', this.filterPersistent);\n    this.filterCompRef.setInput('showClearButton', this.filterShowClearButton);\n    this.filterCompRef.setInput('showApplyButton', this.filterShowApplyButton);\n    this.filterCompRef.setInput('showCloseButton', this.filterShowCloseButton);\n    this.filterCompRef.setInput('showMatchModes', this.filterShowMatchModes);\n    this.filterCompRef.setInput('matchModes', this.filterMatchModes);\n    this.filterCompRef.setInput('showOperator', this.filterShowOperator);\n    this.filterCompRef.setInput('maxConstraints', this.filterMaxConstraints);\n    this.filterCompRef.setInput('headerTitle', this.filterHeaderTitle);\n    this.filterCompRef.setInput('hideOnClear', this.filterHideOnClear);\n    this.filterCompRef.setInput('categoryOptions', this.filterCategoryOptions);\n    this.filterCompRef.setInput('asButtonToggle', this.filterAsButtonToggle);\n    this.filterCompRef.setInput('singleSelection', this.filterSingleSelection);\n    this.filterCompRef.setInput(\n      'placeholder',\n      this.filterPlaceholder || this._getDefaultPlaceholder()\n    );\n  }\n\n  private _getDefaultPlaceholder() {\n    switch (this.filterType) {\n      case 'text':\n        return 'Please enter';\n      case 'number':\n        return 'Enter value';\n      case 'date':\n        return 'Select date';\n      case 'category':\n        return 'Please select';\n      default:\n        return '';\n    }\n  }\n\n  hideFilter() {\n    this.filterCompRef?.instance?.hide();\n  }\n\n  clearFilter() {\n    this.filterCompRef?.instance?.clearFilter();\n  }\n\n  clearFilterValues() {\n    this.filterCompRef?.instance?.clearFilterValues();\n  }\n\n  ngOnDestroy(): void {\n    this.filterCompRef.destroy();\n    this.viewContainerRef.clear();\n  }\n}\n"]}
|
|
@@ -3,12 +3,20 @@ import { SortableColumn } from 'primeng/table';
|
|
|
3
3
|
import { CpsSortIconComponent } from '../components/internal/cps-sort-icon/cps-sort-icon.component';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
import * as i1 from "primeng/table";
|
|
6
|
+
/**
|
|
7
|
+
* CpsTableColumnSortableDirective is a sorting directive used to sort single or multiple columns in table.
|
|
8
|
+
* @group Directives
|
|
9
|
+
*/
|
|
6
10
|
export class CpsTableColumnSortableDirective extends SortableColumn {
|
|
7
11
|
constructor(elementRef, viewContainerRef, dt) {
|
|
8
12
|
super(dt);
|
|
9
13
|
this.elementRef = elementRef;
|
|
10
14
|
this.viewContainerRef = viewContainerRef;
|
|
11
15
|
this.dt = dt;
|
|
16
|
+
/**
|
|
17
|
+
* Name of the column to be sorted.
|
|
18
|
+
* @group Props
|
|
19
|
+
*/
|
|
12
20
|
this.field = '';
|
|
13
21
|
this.sortIconRef =
|
|
14
22
|
this.viewContainerRef.createComponent(CpsSortIconComponent);
|
|
@@ -36,4 +44,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
36
44
|
type: Input,
|
|
37
45
|
args: ['cpsTColSortable']
|
|
38
46
|
}] } });
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3BzLXRhYmxlLWNvbHVtbi1zb3J0YWJsZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jcHMtdWkta2l0L3NyYy9saWIvY29tcG9uZW50cy9jcHMtdGFibGUvZGlyZWN0aXZlcy9jcHMtdGFibGUtY29sdW1uLXNvcnRhYmxlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBRUwsU0FBUyxFQUVULEtBQUssRUFJTixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsY0FBYyxFQUFTLE1BQU0sZUFBZSxDQUFDO0FBQ3RELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDhEQUE4RCxDQUFDOzs7QUFFcEc7OztHQUdHO0FBS0gsTUFBTSxPQUFPLCtCQUNYLFNBQVEsY0FBYztJQVd0QixZQUNVLFVBQXNCLEVBQ3RCLGdCQUFrQyxFQUMxQixFQUFTO1FBRXpCLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUpGLGVBQVUsR0FBVixVQUFVLENBQVk7UUFDdEIscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtRQUMxQixPQUFFLEdBQUYsRUFBRSxDQUFPO1FBWDNCOzs7V0FHRztRQUNnQyxVQUFLLEdBQUcsRUFBRSxDQUFDO1FBVTVDLElBQUksQ0FBQyxXQUFXO1lBQ2QsSUFBSSxDQUFDLGdCQUFnQixDQUFDLGVBQWUsQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO0lBQ2hFLENBQUM7SUFFUSxRQUFRO1FBQ2YsS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQ2pCLElBQUksQ0FBQyxXQUFXLENBQUMsUUFBUSxDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDL0MsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsV0FBVyxDQUN2QyxJQUFJLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQ3hDLENBQUM7SUFDSixDQUFDO0lBRVEsV0FBVztRQUNsQixLQUFLLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDcEIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUMzQixJQUFJLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDaEMsQ0FBQzs7NEhBbENVLCtCQUErQjtnSEFBL0IsK0JBQStCOzJGQUEvQiwrQkFBK0I7a0JBSjNDLFNBQVM7bUJBQUM7b0JBQ1QsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSxtQkFBbUI7aUJBQzlCO29KQVNvQyxLQUFLO3NCQUF2QyxLQUFLO3VCQUFDLGlCQUFpQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENvbXBvbmVudFJlZixcbiAgRGlyZWN0aXZlLFxuICBFbGVtZW50UmVmLFxuICBJbnB1dCxcbiAgT25EZXN0cm95LFxuICBPbkluaXQsXG4gIFZpZXdDb250YWluZXJSZWZcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTb3J0YWJsZUNvbHVtbiwgVGFibGUgfSBmcm9tICdwcmltZW5nL3RhYmxlJztcbmltcG9ydCB7IENwc1NvcnRJY29uQ29tcG9uZW50IH0gZnJvbSAnLi4vY29tcG9uZW50cy9pbnRlcm5hbC9jcHMtc29ydC1pY29uL2Nwcy1zb3J0LWljb24uY29tcG9uZW50JztcblxuLyoqXG4gKiBDcHNUYWJsZUNvbHVtblNvcnRhYmxlRGlyZWN0aXZlIGlzIGEgc29ydGluZyBkaXJlY3RpdmUgdXNlZCB0byBzb3J0IHNpbmdsZSBvciBtdWx0aXBsZSBjb2x1bW5zIGluIHRhYmxlLlxuICogQGdyb3VwIERpcmVjdGl2ZXNcbiAqL1xuQERpcmVjdGl2ZSh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHNlbGVjdG9yOiAnW2Nwc1RDb2xTb3J0YWJsZV0nXG59KVxuZXhwb3J0IGNsYXNzIENwc1RhYmxlQ29sdW1uU29ydGFibGVEaXJlY3RpdmVcbiAgZXh0ZW5kcyBTb3J0YWJsZUNvbHVtblxuICBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95XG57XG4gIC8qKlxuICAgKiBOYW1lIG9mIHRoZSBjb2x1bW4gdG8gYmUgc29ydGVkLlxuICAgKiBAZ3JvdXAgUHJvcHNcbiAgICovXG4gIEBJbnB1dCgnY3BzVENvbFNvcnRhYmxlJykgb3ZlcnJpZGUgZmllbGQgPSAnJztcblxuICBzb3J0SWNvblJlZjogQ29tcG9uZW50UmVmPENwc1NvcnRJY29uQ29tcG9uZW50PjtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYsXG4gICAgcHJpdmF0ZSB2aWV3Q29udGFpbmVyUmVmOiBWaWV3Q29udGFpbmVyUmVmLFxuICAgIHB1YmxpYyBvdmVycmlkZSBkdDogVGFibGVcbiAgKSB7XG4gICAgc3VwZXIoZHQpO1xuICAgIHRoaXMuc29ydEljb25SZWYgPVxuICAgICAgdGhpcy52aWV3Q29udGFpbmVyUmVmLmNyZWF0ZUNvbXBvbmVudChDcHNTb3J0SWNvbkNvbXBvbmVudCk7XG4gIH1cblxuICBvdmVycmlkZSBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICBzdXBlci5uZ09uSW5pdCgpO1xuICAgIHRoaXMuc29ydEljb25SZWYuc2V0SW5wdXQoJ2ZpZWxkJywgdGhpcy5maWVsZCk7XG4gICAgdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQuYXBwZW5kQ2hpbGQoXG4gICAgICB0aGlzLnNvcnRJY29uUmVmLmxvY2F0aW9uLm5hdGl2ZUVsZW1lbnRcbiAgICApO1xuICB9XG5cbiAgb3ZlcnJpZGUgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgc3VwZXIubmdPbkRlc3Ryb3koKTtcbiAgICB0aGlzLnNvcnRJY29uUmVmLmRlc3Ryb3koKTtcbiAgICB0aGlzLnZpZXdDb250YWluZXJSZWYuY2xlYXIoKTtcbiAgfVxufVxuIl19
|
package/esm2020/lib/components/cps-table/directives/cps-table-header-selectable.directive.mjs
CHANGED
|
@@ -1,6 +1,10 @@
|
|
|
1
1
|
import { Directive } from '@angular/core';
|
|
2
2
|
import { TableHeaderCheckbox } from 'primeng/table';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
|
+
/**
|
|
5
|
+
* CpsTableHeaderSelectableDirective is a directive used to apply a checkbox to a header cell.
|
|
6
|
+
* @group Directives
|
|
7
|
+
*/
|
|
4
8
|
export class CpsTableHeaderSelectableDirective {
|
|
5
9
|
constructor(elementRef, viewContainerRef) {
|
|
6
10
|
this.elementRef = elementRef;
|
|
@@ -25,4 +29,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
25
29
|
selector: '[cpsTHdrSelectable]'
|
|
26
30
|
}]
|
|
27
31
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ViewContainerRef }]; } });
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3BzLXRhYmxlLWhlYWRlci1zZWxlY3RhYmxlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Nwcy11aS1raXQvc3JjL2xpYi9jb21wb25lbnRzL2Nwcy10YWJsZS9kaXJlY3RpdmVzL2Nwcy10YWJsZS1oZWFkZXItc2VsZWN0YWJsZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUVMLFNBQVMsRUFLVixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRXBEOzs7R0FHRztBQUtILE1BQU0sT0FBTyxpQ0FBaUM7SUFHNUMsWUFDVSxVQUFzQixFQUN0QixnQkFBa0M7UUFEbEMsZUFBVSxHQUFWLFVBQVUsQ0FBWTtRQUN0QixxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWtCO1FBRTFDLElBQUksQ0FBQyxlQUFlO1lBQ2xCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxlQUFlLENBQUMsbUJBQW1CLENBQUMsQ0FBQztJQUMvRCxDQUFDO0lBRUQsUUFBUTtRQUNOLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLFdBQVcsQ0FDdkMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUM1QyxDQUFDO0lBQ0osQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsZUFBZSxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQy9CLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUNoQyxDQUFDOzs4SEFwQlUsaUNBQWlDO2tIQUFqQyxpQ0FBaUM7MkZBQWpDLGlDQUFpQztrQkFKN0MsU0FBUzttQkFBQztvQkFDVCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFLHFCQUFxQjtpQkFDaEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDb21wb25lbnRSZWYsXG4gIERpcmVjdGl2ZSxcbiAgRWxlbWVudFJlZixcbiAgT25EZXN0cm95LFxuICBPbkluaXQsXG4gIFZpZXdDb250YWluZXJSZWZcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUYWJsZUhlYWRlckNoZWNrYm94IH0gZnJvbSAncHJpbWVuZy90YWJsZSc7XG5cbi8qKlxuICogQ3BzVGFibGVIZWFkZXJTZWxlY3RhYmxlRGlyZWN0aXZlIGlzIGEgZGlyZWN0aXZlIHVzZWQgdG8gYXBwbHkgYSBjaGVja2JveCB0byBhIGhlYWRlciBjZWxsLlxuICogQGdyb3VwIERpcmVjdGl2ZXNcbiAqL1xuQERpcmVjdGl2ZSh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHNlbGVjdG9yOiAnW2Nwc1RIZHJTZWxlY3RhYmxlXSdcbn0pXG5leHBvcnQgY2xhc3MgQ3BzVGFibGVIZWFkZXJTZWxlY3RhYmxlRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xuICBjaGVja2JveENvbXBSZWY6IENvbXBvbmVudFJlZjxUYWJsZUhlYWRlckNoZWNrYm94PjtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYsXG4gICAgcHJpdmF0ZSB2aWV3Q29udGFpbmVyUmVmOiBWaWV3Q29udGFpbmVyUmVmXG4gICkge1xuICAgIHRoaXMuY2hlY2tib3hDb21wUmVmID1cbiAgICAgIHRoaXMudmlld0NvbnRhaW5lclJlZi5jcmVhdGVDb21wb25lbnQoVGFibGVIZWFkZXJDaGVja2JveCk7XG4gIH1cblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudC5hcHBlbmRDaGlsZChcbiAgICAgIHRoaXMuY2hlY2tib3hDb21wUmVmLmxvY2F0aW9uLm5hdGl2ZUVsZW1lbnRcbiAgICApO1xuICB9XG5cbiAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgdGhpcy5jaGVja2JveENvbXBSZWYuZGVzdHJveSgpO1xuICAgIHRoaXMudmlld0NvbnRhaW5lclJlZi5jbGVhcigpO1xuICB9XG59XG4iXX0=
|
|
@@ -1,6 +1,10 @@
|
|
|
1
1
|
import { Directive, Input } from '@angular/core';
|
|
2
2
|
import { TableCheckbox } from 'primeng/table';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
|
+
/**
|
|
5
|
+
* CpsTableRowSelectableDirective is a directive used to apply a checkbox to a body cell.
|
|
6
|
+
* @group Directives
|
|
7
|
+
*/
|
|
4
8
|
export class CpsTableRowSelectableDirective {
|
|
5
9
|
constructor(elementRef, viewContainerRef) {
|
|
6
10
|
this.elementRef = elementRef;
|
|
@@ -28,4 +32,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
28
32
|
type: Input,
|
|
29
33
|
args: ['cpsTRowSelectable']
|
|
30
34
|
}] } });
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3BzLXRhYmxlLXJvdy1zZWxlY3RhYmxlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Nwcy11aS1raXQvc3JjL2xpYi9jb21wb25lbnRzL2Nwcy10YWJsZS9kaXJlY3RpdmVzL2Nwcy10YWJsZS1yb3ctc2VsZWN0YWJsZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUVMLFNBQVMsRUFFVCxLQUFLLEVBSU4sTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFFOUM7OztHQUdHO0FBS0gsTUFBTSxPQUFPLDhCQUE4QjtJQVN6QyxZQUNVLFVBQXNCLEVBQ3RCLGdCQUFrQztRQURsQyxlQUFVLEdBQVYsVUFBVSxDQUFZO1FBQ3RCLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7UUFFMUMsSUFBSSxDQUFDLGVBQWUsR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsZUFBZSxDQUFDLGFBQWEsQ0FBQyxDQUFDO0lBQzlFLENBQUM7SUFFRCxRQUFRO1FBQ04sSUFBSSxDQUFDLGVBQWUsQ0FBQyxRQUFRLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUVuRCxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxXQUFXLENBQ3ZDLElBQUksQ0FBQyxlQUFlLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FDNUMsQ0FBQztJQUNKLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLGVBQWUsQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUMvQixJQUFJLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDaEMsQ0FBQzs7MkhBM0JVLDhCQUE4QjsrR0FBOUIsOEJBQThCOzJGQUE5Qiw4QkFBOEI7a0JBSjFDLFNBQVM7bUJBQUM7b0JBQ1QsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSxxQkFBcUI7aUJBQ2hDO2dJQU02QixLQUFLO3NCQUFoQyxLQUFLO3VCQUFDLG1CQUFtQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENvbXBvbmVudFJlZixcbiAgRGlyZWN0aXZlLFxuICBFbGVtZW50UmVmLFxuICBJbnB1dCxcbiAgT25EZXN0cm95LFxuICBPbkluaXQsXG4gIFZpZXdDb250YWluZXJSZWZcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUYWJsZUNoZWNrYm94IH0gZnJvbSAncHJpbWVuZy90YWJsZSc7XG5cbi8qKlxuICogQ3BzVGFibGVSb3dTZWxlY3RhYmxlRGlyZWN0aXZlIGlzIGEgZGlyZWN0aXZlIHVzZWQgdG8gYXBwbHkgYSBjaGVja2JveCB0byBhIGJvZHkgY2VsbC5cbiAqIEBncm91cCBEaXJlY3RpdmVzXG4gKi9cbkBEaXJlY3RpdmUoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBzZWxlY3RvcjogJ1tjcHNUUm93U2VsZWN0YWJsZV0nXG59KVxuZXhwb3J0IGNsYXNzIENwc1RhYmxlUm93U2VsZWN0YWJsZURpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgLyoqXG4gICAqIENlbGwgdmFsdWUuXG4gICAqIEBncm91cCBQcm9wc1xuICAgKi9cbiAgQElucHV0KCdjcHNUUm93U2VsZWN0YWJsZScpIHZhbHVlOiBhbnk7XG5cbiAgY2hlY2tib3hDb21wUmVmOiBDb21wb25lbnRSZWY8VGFibGVDaGVja2JveD47XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBlbGVtZW50UmVmOiBFbGVtZW50UmVmLFxuICAgIHByaXZhdGUgdmlld0NvbnRhaW5lclJlZjogVmlld0NvbnRhaW5lclJlZlxuICApIHtcbiAgICB0aGlzLmNoZWNrYm94Q29tcFJlZiA9IHRoaXMudmlld0NvbnRhaW5lclJlZi5jcmVhdGVDb21wb25lbnQoVGFibGVDaGVja2JveCk7XG4gIH1cblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLmNoZWNrYm94Q29tcFJlZi5zZXRJbnB1dCgndmFsdWUnLCB0aGlzLnZhbHVlKTtcblxuICAgIHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LmFwcGVuZENoaWxkKFxuICAgICAgdGhpcy5jaGVja2JveENvbXBSZWYubG9jYXRpb24ubmF0aXZlRWxlbWVudFxuICAgICk7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLmNoZWNrYm94Q29tcFJlZi5kZXN0cm95KCk7XG4gICAgdGhpcy52aWV3Q29udGFpbmVyUmVmLmNsZWFyKCk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -4,7 +4,15 @@ import { getCSSColor } from '../../utils/colors-utils';
|
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
import * as i1 from "@angular/forms";
|
|
6
6
|
import * as i2 from "@angular/common";
|
|
7
|
+
/**
|
|
8
|
+
* CpsTagComponent is used to categorize content.
|
|
9
|
+
* @group Components
|
|
10
|
+
*/
|
|
7
11
|
export class CpsTagComponent {
|
|
12
|
+
/**
|
|
13
|
+
* Tag value.
|
|
14
|
+
* @group Props
|
|
15
|
+
*/
|
|
8
16
|
set value(value) {
|
|
9
17
|
this._value = value;
|
|
10
18
|
this.onChange(value);
|
|
@@ -14,11 +22,36 @@ export class CpsTagComponent {
|
|
|
14
22
|
}
|
|
15
23
|
constructor(_control) {
|
|
16
24
|
this._control = _control;
|
|
17
|
-
|
|
25
|
+
/**
|
|
26
|
+
* Type of the tag. It can be security, classification or custom, has higher precedence over color.
|
|
27
|
+
* @group Props
|
|
28
|
+
*/
|
|
29
|
+
this.type = 'custom';
|
|
30
|
+
/**
|
|
31
|
+
* Label of the tag.
|
|
32
|
+
* @group Props
|
|
33
|
+
*/
|
|
18
34
|
this.label = '';
|
|
35
|
+
/**
|
|
36
|
+
* Color of the tag.
|
|
37
|
+
* @group Props
|
|
38
|
+
*/
|
|
19
39
|
this.color = '';
|
|
40
|
+
/**
|
|
41
|
+
* Whether the tag should be disabled.
|
|
42
|
+
* @group Props
|
|
43
|
+
*/
|
|
20
44
|
this.disabled = false;
|
|
45
|
+
/**
|
|
46
|
+
* Whether the tag should be selectable.
|
|
47
|
+
* @group Props
|
|
48
|
+
*/
|
|
21
49
|
this.selectable = false;
|
|
50
|
+
/**
|
|
51
|
+
* Callback to invoke on value change.
|
|
52
|
+
* @param {boolean} boolean - value change.
|
|
53
|
+
* @group Emits
|
|
54
|
+
*/
|
|
22
55
|
this.valueChanged = new EventEmitter();
|
|
23
56
|
this.classesList = [];
|
|
24
57
|
this.tagColor = '';
|
|
@@ -100,4 +133,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
100
133
|
}], valueChanged: [{
|
|
101
134
|
type: Output
|
|
102
135
|
}] } });
|
|
103
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
136
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-tag.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-tag/cps-tag.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-tag/cps-tag.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EACL,SAAS,EACT,YAAY,EACZ,KAAK,EAEL,QAAQ,EACR,MAAM,EACN,IAAI,EACL,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;;;;AAGvD;;;GAGG;AAQH,MAAM,OAAO,eAAe;IA+B1B;;;OAGG;IACH,IAAa,KAAK,CAAC,KAAc;QAC/B,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACvB,CAAC;IAED,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAcD,YAAwC,QAAmB;QAAnB,aAAQ,GAAR,QAAQ,CAAW;QAvD3D;;;WAGG;QACM,SAAI,GAA6C,QAAQ,CAAC;QAEnE;;;WAGG;QACM,UAAK,GAAG,EAAE,CAAC;QAEpB;;;WAGG;QACM,UAAK,GAAG,EAAE,CAAC;QAEpB;;;WAGG;QACM,aAAQ,GAAG,KAAK,CAAC;QAE1B;;;WAGG;QACM,eAAU,GAAG,KAAK,CAAC;QAe5B;;;;WAIG;QACO,iBAAY,GAAG,IAAI,YAAY,EAAW,CAAC;QAErD,gBAAW,GAAa,EAAE,CAAC;QAC3B,aAAQ,GAAG,EAAE,CAAC;QAEN,WAAM,GAAG,KAAK,CAAC;QAmCvB,gEAAgE;QAChE,aAAQ,GAAG,CAAC,KAAU,EAAE,EAAE,GAAE,CAAC,CAAC;QAE9B,gEAAgE;QAChE,cAAS,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;QApCnB,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,QAAQ,CAAC,aAAa,GAAG,IAAI,CAAC;SACpC;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAED,UAAU;QACR,IAAI,CAAC,WAAW,GAAG,CAAC,SAAS,CAAC,CAAC;QAE/B,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;SAC9C;QACD,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;SAC5C;QACD,QAAQ,IAAI,CAAC,IAAI,EAAE;YACjB,KAAK,UAAU,CAAC,CAAC;gBACf,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;gBAC3C,MAAM;aACP;YACD,KAAK,gBAAgB,CAAC,CAAC;gBACrB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC;gBACjD,MAAM;aACP;YACD;gBACE,IAAI,IAAI,CAAC,KAAK;oBAAE,IAAI,CAAC,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SAC3D;IACH,CAAC;IAQD,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,UAAU,CAAC,KAAc;QACvB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAED,cAAc;QACZ,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,UAAU;YAAE,OAAO;QAC9C,IAAI,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAEO,YAAY,CAAC,KAAc;QACjC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QACvB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACrB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;;4GApHU,eAAe;gGAAf,eAAe,6PCxB5B,2MAOA,o9BDYY,YAAY;2FAKX,eAAe;kBAP3B,SAAS;iCACI,IAAI,WACP,CAAC,YAAY,CAAC,YACb,SAAS;;0BA4DN,IAAI;;0BAAI,QAAQ;4CAnDpB,IAAI;sBAAZ,KAAK;gBAMG,KAAK;sBAAb,KAAK;gBAMG,KAAK;sBAAb,KAAK;gBAMG,QAAQ;sBAAhB,KAAK;gBAMG,UAAU;sBAAlB,KAAK;gBAMO,KAAK;sBAAjB,KAAK;gBAcI,YAAY;sBAArB,MAAM","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  Optional,\n  Output,\n  Self\n} from '@angular/core';\nimport { getCSSColor } from '../../utils/colors-utils';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\n\n/**\n * CpsTagComponent is used to categorize content.\n * @group Components\n */\n@Component({\n  standalone: true,\n  imports: [CommonModule],\n  selector: 'cps-tag',\n  templateUrl: './cps-tag.component.html',\n  styleUrls: ['./cps-tag.component.scss']\n})\nexport class CpsTagComponent implements ControlValueAccessor, OnChanges {\n  /**\n   * Type of the tag. It can be security, classification or custom, has higher precedence over color.\n   * @group Props\n   */\n  @Input() type: 'security' | 'classification' | 'custom' = 'custom';\n\n  /**\n   * Label of the tag.\n   * @group Props\n   */\n  @Input() label = '';\n\n  /**\n   * Color of the tag.\n   * @group Props\n   */\n  @Input() color = '';\n\n  /**\n   * Whether the tag should be disabled.\n   * @group Props\n   */\n  @Input() disabled = false;\n\n  /**\n   * Whether the tag should be selectable.\n   * @group Props\n   */\n  @Input() selectable = false;\n\n  /**\n   * Tag value.\n   * @group Props\n   */\n  @Input() set value(value: boolean) {\n    this._value = value;\n    this.onChange(value);\n  }\n\n  get value(): boolean {\n    return this._value;\n  }\n\n  /**\n   * Callback to invoke on value change.\n   * @param {boolean} boolean - value change.\n   * @group Emits\n   */\n  @Output() valueChanged = new EventEmitter<boolean>();\n\n  classesList: string[] = [];\n  tagColor = '';\n\n  private _value = false;\n\n  constructor(@Self() @Optional() private _control: NgControl) {\n    if (this._control) {\n      this._control.valueAccessor = this;\n    }\n  }\n\n  ngOnChanges(): void {\n    this.setClasses();\n  }\n\n  setClasses(): void {\n    this.classesList = ['cps-tag'];\n\n    if (this.selectable) {\n      this.classesList.push('cps-tag--selectable');\n    }\n    if (this.disabled) {\n      this.classesList.push('cps-tag--disabled');\n    }\n    switch (this.type) {\n      case 'security': {\n        this.classesList.push('cps-tag--security');\n        break;\n      }\n      case 'classification': {\n        this.classesList.push('cps-tag--classification');\n        break;\n      }\n      default:\n        if (this.color) this.tagColor = getCSSColor(this.color);\n    }\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange = (event: any) => {};\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onTouched = () => {};\n\n  registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  writeValue(value: boolean) {\n    this.value = value;\n  }\n\n  toggleSelected() {\n    if (this.disabled || !this.selectable) return;\n    this._updateValue(!this.value);\n  }\n\n  private _updateValue(value: boolean) {\n    this.writeValue(value);\n    this.onChange(value);\n    this.valueChanged.emit(value);\n  }\n}\n","<div\n  [ngClass]=\"classesList\"\n  [class.unselected]=\"!value && selectable\"\n  [ngStyle]=\"{ 'border-color': tagColor || 'none' }\"\n  (click)=\"toggleSelected()\">\n  <p>{{ label }}</p>\n</div>\n"]}
|
|
@@ -7,7 +7,15 @@ import { CpsInfoCircleComponent } from '../cps-info-circle/cps-info-circle.compo
|
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
import * as i1 from "@angular/forms";
|
|
9
9
|
import * as i2 from "@angular/common";
|
|
10
|
+
/**
|
|
11
|
+
* CpsTextareaComponent is a textarea component.
|
|
12
|
+
* @group Components
|
|
13
|
+
*/
|
|
10
14
|
export class CpsTextareaComponent {
|
|
15
|
+
/**
|
|
16
|
+
* Value of the textarea.
|
|
17
|
+
* @group Props
|
|
18
|
+
*/
|
|
11
19
|
set value(value) {
|
|
12
20
|
if (!value)
|
|
13
21
|
value = '';
|
|
@@ -20,27 +28,119 @@ export class CpsTextareaComponent {
|
|
|
20
28
|
constructor(_control, _elementRef) {
|
|
21
29
|
this._control = _control;
|
|
22
30
|
this._elementRef = _elementRef;
|
|
31
|
+
/**
|
|
32
|
+
* Label of the textarea.
|
|
33
|
+
* @group Props
|
|
34
|
+
*/
|
|
23
35
|
this.label = '';
|
|
36
|
+
/**
|
|
37
|
+
* Placeholder text for the textarea.
|
|
38
|
+
* @group Props
|
|
39
|
+
*/
|
|
24
40
|
this.placeholder = 'Please enter';
|
|
41
|
+
/**
|
|
42
|
+
* Number of rows in the textarea.
|
|
43
|
+
* @group Props
|
|
44
|
+
*/
|
|
25
45
|
this.rows = 5;
|
|
46
|
+
/**
|
|
47
|
+
* The cols attribute specifies the visible width of a textarea.
|
|
48
|
+
* @group Props
|
|
49
|
+
*/
|
|
26
50
|
this.cols = 20;
|
|
51
|
+
/**
|
|
52
|
+
* Whether the textarea can auto focus.
|
|
53
|
+
* @group Props
|
|
54
|
+
*/
|
|
27
55
|
this.autofocus = false;
|
|
56
|
+
/**
|
|
57
|
+
* Bottom hint text for the textarea.
|
|
58
|
+
* @group Props
|
|
59
|
+
*/
|
|
28
60
|
this.hint = '';
|
|
61
|
+
/**
|
|
62
|
+
* Whether the textarea is disabled.
|
|
63
|
+
* @group Props
|
|
64
|
+
*/
|
|
29
65
|
this.disabled = false;
|
|
66
|
+
/**
|
|
67
|
+
* Width of the textarea, it can be of type number denoting pixels or string.
|
|
68
|
+
* @group Props
|
|
69
|
+
*/
|
|
30
70
|
this.width = '100%';
|
|
71
|
+
/**
|
|
72
|
+
* When enabled, a clear icon is displayed to clear the value.
|
|
73
|
+
* @group Props
|
|
74
|
+
*/
|
|
31
75
|
this.clearable = false;
|
|
76
|
+
/**
|
|
77
|
+
* Hides hint and validation errors.
|
|
78
|
+
* @group Props
|
|
79
|
+
*/
|
|
32
80
|
this.hideDetails = false;
|
|
81
|
+
/**
|
|
82
|
+
* Whether the textarea should have persistent clear icon.
|
|
83
|
+
* @group Props
|
|
84
|
+
*/
|
|
33
85
|
this.persistentClear = false;
|
|
86
|
+
/**
|
|
87
|
+
* Error message.
|
|
88
|
+
* @group Props
|
|
89
|
+
*/
|
|
34
90
|
this.error = '';
|
|
91
|
+
/**
|
|
92
|
+
* Whether the component can be resized vertically or not.
|
|
93
|
+
* @group Props
|
|
94
|
+
*/
|
|
35
95
|
this.resizable = 'vertical';
|
|
96
|
+
/**
|
|
97
|
+
* When it is not an empty string, an info icon is displayed to show text for more info.
|
|
98
|
+
* @group Props
|
|
99
|
+
*/
|
|
36
100
|
this.infoTooltip = '';
|
|
101
|
+
/**
|
|
102
|
+
* Info tooltip class for styling.
|
|
103
|
+
* @group Props
|
|
104
|
+
*/
|
|
37
105
|
this.infoTooltipClass = 'cps-tooltip-content';
|
|
106
|
+
/**
|
|
107
|
+
* Max width of infoTooltip, of type number denoting pixels or string.
|
|
108
|
+
* @group Props
|
|
109
|
+
*/
|
|
38
110
|
this.infoTooltipMaxWidth = '100%';
|
|
111
|
+
/**
|
|
112
|
+
* Whether the infoTooltip is persistent.
|
|
113
|
+
* @group Props
|
|
114
|
+
*/
|
|
39
115
|
this.infoTooltipPersistent = false;
|
|
116
|
+
/**
|
|
117
|
+
* Position of infoTooltip, it can be 'top', 'bottom', 'left' or 'right'.
|
|
118
|
+
* @group Props
|
|
119
|
+
*/
|
|
40
120
|
this.infoTooltipPosition = 'top';
|
|
121
|
+
/**
|
|
122
|
+
* Callback to invoke on value change.
|
|
123
|
+
* @param {string} string - value changed.
|
|
124
|
+
* @group Emits
|
|
125
|
+
*/
|
|
41
126
|
this.valueChanged = new EventEmitter();
|
|
127
|
+
/**
|
|
128
|
+
* Callback to invoke when the component receives focus.
|
|
129
|
+
* @param {any}
|
|
130
|
+
* @group Emits
|
|
131
|
+
*/
|
|
42
132
|
this.focused = new EventEmitter();
|
|
133
|
+
/**
|
|
134
|
+
* Callback to invoke when the prefixIcon is clicked.
|
|
135
|
+
* @param {any}
|
|
136
|
+
* @group Emits
|
|
137
|
+
*/
|
|
43
138
|
this.prefixIconClicked = new EventEmitter();
|
|
139
|
+
/**
|
|
140
|
+
* Callback to invoke when the component loses focus.
|
|
141
|
+
* @param {any}
|
|
142
|
+
* @group Emits
|
|
143
|
+
*/
|
|
44
144
|
this.blurred = new EventEmitter();
|
|
45
145
|
this._statusChangesSubscription = new Subscription();
|
|
46
146
|
this._value = '';
|
|
@@ -188,4 +288,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
188
288
|
}], blurred: [{
|
|
189
289
|
type: Output
|
|
190
290
|
}] } });
|
|
191
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-textarea.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-textarea/cps-textarea.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-textarea/cps-textarea.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Self\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { convertSize } from '../../utils/internal/size-utils';\nimport { CpsIconComponent } from '../cps-icon/cps-icon.component';\nimport { CpsInfoCircleComponent } from '../cps-info-circle/cps-info-circle.component';\nimport { CpsTooltipPosition } from '../../directives/cps-tooltip.directive';\n\n@Component({\n  standalone: true,\n  selector: 'cps-textarea',\n  imports: [CommonModule, CpsIconComponent, CpsInfoCircleComponent],\n  templateUrl: './cps-textarea.component.html',\n  styleUrls: ['./cps-textarea.component.scss']\n})\nexport class CpsTextareaComponent\n  implements ControlValueAccessor, OnInit, OnDestroy\n{\n  @Input() label = '';\n  @Input() placeholder = 'Please enter';\n  @Input() rows = 5;\n  @Input() cols = 20;\n  @Input() autofocus = false;\n  @Input() hint = '';\n  @Input() disabled = false;\n  @Input() width: number | string = '100%';\n  @Input() clearable = false;\n  @Input() hideDetails = false;\n  @Input() persistentClear = false;\n  @Input() error = '';\n  @Input() resizable: 'vertical' | 'none' = 'vertical';\n  @Input() infoTooltip = '';\n  @Input() infoTooltipClass = 'cps-tooltip-content';\n  @Input() infoTooltipMaxWidth: number | string = '100%';\n  @Input() infoTooltipPersistent = false;\n  @Input() infoTooltipPosition: CpsTooltipPosition = 'top';\n\n  @Input() set value(value: string) {\n    if (!value) value = '';\n    this._value = value;\n    this.onChange(value);\n  }\n\n  get value(): string {\n    return this._value;\n  }\n\n  @Output() valueChanged = new EventEmitter<string>();\n  @Output() focused = new EventEmitter();\n  @Output() prefixIconClicked = new EventEmitter();\n  @Output() blurred = new EventEmitter();\n\n  private _statusChangesSubscription: Subscription = new Subscription();\n  private _value = '';\n\n  cvtWidth = '';\n\n  constructor(\n    @Self() @Optional() private _control: NgControl,\n    private _elementRef: ElementRef<HTMLElement>\n  ) {\n    if (this._control) {\n      this._control.valueAccessor = this;\n    }\n  }\n\n  ngOnInit(): void {\n    this.cvtWidth = convertSize(this.width);\n\n    this._statusChangesSubscription = this._control?.statusChanges?.subscribe(\n      () => {\n        this._checkErrors();\n      }\n    ) as Subscription;\n  }\n\n  ngOnDestroy() {\n    this._statusChangesSubscription?.unsubscribe();\n  }\n\n  private _checkErrors() {\n    if (!this._control) return;\n    const errors = this._control?.errors;\n\n    if (!this._control?.control?.touched || !errors) {\n      this.error = '';\n      return;\n    }\n\n    if ('required' in errors) {\n      this.error = 'Field is required';\n      return;\n    }\n\n    if ('pattern' in errors) {\n      this.error = 'Value is invalid';\n      return;\n    }\n\n    if ('minlength' in errors) {\n      // eslint-disable-next-line dot-notation\n      this.error = `Field must contain at least ${errors['minlength'].requiredLength} characters`;\n      return;\n    }\n\n    if ('maxlength' in errors) {\n      // eslint-disable-next-line dot-notation\n      this.error = `Field must contain ${errors['maxlength'].requiredLength} characters maximum`;\n      return;\n    }\n\n    const errArr = Object.values(errors);\n    if (errArr.length < 1) {\n      this.error = '';\n      return;\n    }\n    const message = errArr.find((msg) => typeof msg === 'string');\n\n    this.error = message || 'Unknown error';\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange = (event: any) => {};\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onTouched = () => {};\n\n  registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  writeValue(value: string) {\n    this.value = value;\n  }\n\n  updateValueEvent(event: any) {\n    const value = event?.target?.value || '';\n    this._updateValue(value);\n  }\n\n  private _updateValue(value: string) {\n    this.writeValue(value);\n    this.onChange(value);\n    this.valueChanged.emit(value);\n  }\n\n  clear() {\n    if (this.value !== '') this._updateValue('');\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  setDisabledState(disabled: boolean) {}\n\n  onBlur() {\n    this._control?.control?.markAsTouched();\n    this._checkErrors();\n    this.blurred.emit();\n  }\n\n  onFocus() {\n    this.focused.emit();\n  }\n\n  focus() {\n    this._elementRef?.nativeElement?.querySelector('textarea')?.focus();\n  }\n}\n","<div class=\"cps-textarea-container\" [ngStyle]=\"{ width: cvtWidth }\">\n  <div\n    class=\"cps-textarea-label\"\n    [ngClass]=\"{ 'cps-textarea-label-disabled': disabled }\"\n    *ngIf=\"label\">\n    <label>{{ label }}</label>\n    <cps-info-circle\n      *ngIf=\"infoTooltip\"\n      class=\"cps-textarea-label-info-circle\"\n      size=\"xsmall\"\n      [tooltipPosition]=\"infoTooltipPosition\"\n      [tooltipContentClass]=\"infoTooltipClass\"\n      [tooltipMaxWidth]=\"infoTooltipMaxWidth\"\n      [tooltipPersistent]=\"infoTooltipPersistent\"\n      [tooltipText]=\"infoTooltip\">\n    </cps-info-circle>\n  </div>\n\n  <div\n    class=\"cps-textarea-wrap\"\n    [ngClass]=\"{\n      'cps-textarea-wrap-error': error,\n      clearable: clearable,\n      'persistent-clear': persistentClear\n    }\">\n    <textarea\n      spellcheck=\"false\"\n      [cols]=\"cols\"\n      [rows]=\"rows\"\n      [autofocus]=\"autofocus\"\n      [disabled]=\"disabled\"\n      [placeholder]=\"placeholder\"\n      [value]=\"value\"\n      [ngStyle]=\"{\n        width: cvtWidth,\n        resize: resizable\n      }\"\n      (blur)=\"onBlur()\"\n      (focus)=\"onFocus()\"\n      (input)=\"updateValueEvent($event)\"></textarea>\n\n    <span\n      *ngIf=\"clearable && !disabled\"\n      [style.visibility]=\"\n        persistentClear || (!persistentClear && value) ? 'visible' : 'hidden'\n      \"\n      class=\"clear-btn\">\n      <cps-icon icon=\"delete\" size=\"small\" (click)=\"clear()\"></cps-icon>\n    </span>\n  </div>\n  <div *ngIf=\"!error && !hideDetails\" class=\"cps-textarea-hint\">\n    {{ hint }}\n  </div>\n  <div *ngIf=\"error && !hideDetails\" class=\"cps-textarea-error\">\n    {{ error }}\n  </div>\n</div>\n"]}
|
|
291
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-textarea.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-textarea/cps-textarea.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-textarea/cps-textarea.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Self\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { convertSize } from '../../utils/internal/size-utils';\nimport { CpsIconComponent } from '../cps-icon/cps-icon.component';\nimport { CpsInfoCircleComponent } from '../cps-info-circle/cps-info-circle.component';\nimport { CpsTooltipPosition } from '../../directives/cps-tooltip.directive';\n\n/**\n * CpsTextareaComponent is a textarea component.\n * @group Components\n */\n@Component({\n  standalone: true,\n  selector: 'cps-textarea',\n  imports: [CommonModule, CpsIconComponent, CpsInfoCircleComponent],\n  templateUrl: './cps-textarea.component.html',\n  styleUrls: ['./cps-textarea.component.scss']\n})\nexport class CpsTextareaComponent\n  implements ControlValueAccessor, OnInit, OnDestroy\n{\n  /**\n   * Label of the textarea.\n   * @group Props\n   */\n  @Input() label = '';\n\n  /**\n   * Placeholder text for the textarea.\n   * @group Props\n   */\n  @Input() placeholder = 'Please enter';\n\n  /**\n   * Number of rows in the textarea.\n   * @group Props\n   */\n  @Input() rows = 5;\n\n  /**\n   * The cols attribute specifies the visible width of a textarea.\n   * @group Props\n   */\n  @Input() cols = 20;\n\n  /**\n   * Whether the textarea can auto focus.\n   * @group Props\n   */\n  @Input() autofocus = false;\n\n  /**\n   * Bottom hint text for the textarea.\n   * @group Props\n   */\n  @Input() hint = '';\n\n  /**\n   * Whether the textarea is disabled.\n   * @group Props\n   */\n  @Input() disabled = false;\n\n  /**\n   * Width of the textarea, it can be of type number denoting pixels or string.\n   * @group Props\n   */\n  @Input() width: number | string = '100%';\n\n  /**\n   * When enabled, a clear icon is displayed to clear the value.\n   * @group Props\n   */\n  @Input() clearable = false;\n\n  /**\n   * Hides hint and validation errors.\n   * @group Props\n   */\n  @Input() hideDetails = false;\n\n  /**\n   * Whether the textarea should have persistent clear icon.\n   * @group Props\n   */\n  @Input() persistentClear = false;\n\n  /**\n   * Error message.\n   * @group Props\n   */\n  @Input() error = '';\n\n  /**\n   * Whether the component can be resized vertically or not.\n   * @group Props\n   */\n  @Input() resizable: 'vertical' | 'none' = 'vertical';\n\n  /**\n   * When it is not an empty string, an info icon is displayed to show text for more info.\n   * @group Props\n   */\n  @Input() infoTooltip = '';\n\n  /**\n   * Info tooltip class for styling.\n   * @group Props\n   */\n  @Input() infoTooltipClass = 'cps-tooltip-content';\n\n  /**\n   * Max width of infoTooltip, of type number denoting pixels or string.\n   * @group Props\n   */\n  @Input() infoTooltipMaxWidth: number | string = '100%';\n\n  /**\n   * Whether the infoTooltip is persistent.\n   * @group Props\n   */\n  @Input() infoTooltipPersistent = false;\n\n  /**\n   * Position of infoTooltip, it can be 'top', 'bottom', 'left' or 'right'.\n   * @group Props\n   */\n  @Input() infoTooltipPosition: CpsTooltipPosition = 'top';\n\n  /**\n   * Value of the textarea.\n   * @group Props\n   */\n  @Input() set value(value: string) {\n    if (!value) value = '';\n    this._value = value;\n    this.onChange(value);\n  }\n\n  get value(): string {\n    return this._value;\n  }\n\n  /**\n   * Callback to invoke on value change.\n   * @param {string} string - value changed.\n   * @group Emits\n   */\n  @Output() valueChanged = new EventEmitter<string>();\n\n  /**\n   * Callback to invoke when the component receives focus.\n   * @param {any}\n   * @group Emits\n   */\n  @Output() focused = new EventEmitter();\n\n  /**\n   * Callback to invoke when the prefixIcon is clicked.\n   * @param {any}\n   * @group Emits\n   */\n  @Output() prefixIconClicked = new EventEmitter();\n\n  /**\n   * Callback to invoke when the component loses focus.\n   * @param {any}\n   * @group Emits\n   */\n  @Output() blurred = new EventEmitter();\n\n  private _statusChangesSubscription: Subscription = new Subscription();\n  private _value = '';\n\n  cvtWidth = '';\n\n  constructor(\n    @Self() @Optional() private _control: NgControl,\n    private _elementRef: ElementRef<HTMLElement>\n  ) {\n    if (this._control) {\n      this._control.valueAccessor = this;\n    }\n  }\n\n  ngOnInit(): void {\n    this.cvtWidth = convertSize(this.width);\n\n    this._statusChangesSubscription = this._control?.statusChanges?.subscribe(\n      () => {\n        this._checkErrors();\n      }\n    ) as Subscription;\n  }\n\n  ngOnDestroy() {\n    this._statusChangesSubscription?.unsubscribe();\n  }\n\n  private _checkErrors() {\n    if (!this._control) return;\n    const errors = this._control?.errors;\n\n    if (!this._control?.control?.touched || !errors) {\n      this.error = '';\n      return;\n    }\n\n    if ('required' in errors) {\n      this.error = 'Field is required';\n      return;\n    }\n\n    if ('pattern' in errors) {\n      this.error = 'Value is invalid';\n      return;\n    }\n\n    if ('minlength' in errors) {\n      // eslint-disable-next-line dot-notation\n      this.error = `Field must contain at least ${errors['minlength'].requiredLength} characters`;\n      return;\n    }\n\n    if ('maxlength' in errors) {\n      // eslint-disable-next-line dot-notation\n      this.error = `Field must contain ${errors['maxlength'].requiredLength} characters maximum`;\n      return;\n    }\n\n    const errArr = Object.values(errors);\n    if (errArr.length < 1) {\n      this.error = '';\n      return;\n    }\n    const message = errArr.find((msg) => typeof msg === 'string');\n\n    this.error = message || 'Unknown error';\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange = (event: any) => {};\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onTouched = () => {};\n\n  registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  writeValue(value: string) {\n    this.value = value;\n  }\n\n  updateValueEvent(event: any) {\n    const value = event?.target?.value || '';\n    this._updateValue(value);\n  }\n\n  private _updateValue(value: string) {\n    this.writeValue(value);\n    this.onChange(value);\n    this.valueChanged.emit(value);\n  }\n\n  clear() {\n    if (this.value !== '') this._updateValue('');\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  setDisabledState(disabled: boolean) {}\n\n  onBlur() {\n    this._control?.control?.markAsTouched();\n    this._checkErrors();\n    this.blurred.emit();\n  }\n\n  onFocus() {\n    this.focused.emit();\n  }\n\n  focus() {\n    this._elementRef?.nativeElement?.querySelector('textarea')?.focus();\n  }\n}\n","<div class=\"cps-textarea-container\" [ngStyle]=\"{ width: cvtWidth }\">\n  <div\n    class=\"cps-textarea-label\"\n    [ngClass]=\"{ 'cps-textarea-label-disabled': disabled }\"\n    *ngIf=\"label\">\n    <label>{{ label }}</label>\n    <cps-info-circle\n      *ngIf=\"infoTooltip\"\n      class=\"cps-textarea-label-info-circle\"\n      size=\"xsmall\"\n      [tooltipPosition]=\"infoTooltipPosition\"\n      [tooltipContentClass]=\"infoTooltipClass\"\n      [tooltipMaxWidth]=\"infoTooltipMaxWidth\"\n      [tooltipPersistent]=\"infoTooltipPersistent\"\n      [tooltipText]=\"infoTooltip\">\n    </cps-info-circle>\n  </div>\n\n  <div\n    class=\"cps-textarea-wrap\"\n    [ngClass]=\"{\n      'cps-textarea-wrap-error': error,\n      clearable: clearable,\n      'persistent-clear': persistentClear\n    }\">\n    <textarea\n      spellcheck=\"false\"\n      [cols]=\"cols\"\n      [rows]=\"rows\"\n      [autofocus]=\"autofocus\"\n      [disabled]=\"disabled\"\n      [placeholder]=\"placeholder\"\n      [value]=\"value\"\n      [ngStyle]=\"{\n        width: cvtWidth,\n        resize: resizable\n      }\"\n      (blur)=\"onBlur()\"\n      (focus)=\"onFocus()\"\n      (input)=\"updateValueEvent($event)\"></textarea>\n\n    <span\n      *ngIf=\"clearable && !disabled\"\n      [style.visibility]=\"\n        persistentClear || (!persistentClear && value) ? 'visible' : 'hidden'\n      \"\n      class=\"clear-btn\">\n      <cps-icon icon=\"delete\" size=\"small\" (click)=\"clear()\"></cps-icon>\n    </span>\n  </div>\n  <div *ngIf=\"!error && !hideDetails\" class=\"cps-textarea-hint\">\n    {{ hint }}\n  </div>\n  <div *ngIf=\"error && !hideDetails\" class=\"cps-textarea-error\">\n    {{ error }}\n  </div>\n</div>\n"]}
|