cps-ui-kit 0.165.0 → 17.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (166) hide show
  1. package/esm2022/lib/components/cps-autocomplete/cps-autocomplete.component.mjs +824 -0
  2. package/esm2022/lib/components/cps-button/cps-button.component.mjs +190 -0
  3. package/esm2022/lib/components/cps-button-toggle/cps-button-toggle.component.mjs +235 -0
  4. package/esm2022/lib/components/cps-checkbox/cps-checkbox.component.mjs +149 -0
  5. package/esm2022/lib/components/cps-chip/cps-chip.component.mjs +94 -0
  6. package/esm2022/lib/components/cps-datepicker/cps-datepicker.component.mjs +382 -0
  7. package/esm2022/lib/components/cps-expansion-panel/cps-expansion-panel.component.mjs +209 -0
  8. package/esm2022/lib/components/cps-file-upload/cps-file-upload.component.mjs +138 -0
  9. package/esm2022/lib/components/cps-icon/cps-icon.component.mjs +193 -0
  10. package/esm2022/lib/components/cps-info-circle/cps-info-circle.component.mjs +61 -0
  11. package/esm2022/lib/components/cps-input/cps-input.component.mjs +386 -0
  12. package/{esm2020 → esm2022}/lib/components/cps-loader/cps-loader.component.mjs +5 -5
  13. package/esm2022/lib/components/cps-menu/cps-menu.component.mjs +552 -0
  14. package/esm2022/lib/components/cps-paginator/cps-paginator.component.mjs +114 -0
  15. package/esm2022/lib/components/cps-paginator/pipes/cps-paginate.pipe.mjs +30 -0
  16. package/{esm2020 → esm2022}/lib/components/cps-progress-circular/cps-progress-circular.component.mjs +4 -4
  17. package/{esm2020 → esm2022}/lib/components/cps-progress-linear/cps-progress-linear.component.mjs +4 -4
  18. package/{esm2020 → esm2022}/lib/components/cps-radio-group/cps-radio/cps-radio.component.mjs +7 -7
  19. package/esm2022/lib/components/cps-radio-group/cps-radio-button/cps-radio-button.component.mjs +55 -0
  20. package/esm2022/lib/components/cps-radio-group/cps-radio-group.component.mjs +158 -0
  21. package/esm2022/lib/components/cps-select/cps-select.component.mjs +615 -0
  22. package/esm2022/lib/components/cps-sidebar-menu/cps-sidebar-menu.component.mjs +110 -0
  23. package/{esm2020 → esm2022}/lib/components/cps-tab-group/cps-tab/cps-tab.component.mjs +4 -4
  24. package/esm2022/lib/components/cps-tab-group/cps-tab-group.component.mjs +303 -0
  25. package/esm2022/lib/components/cps-table/components/internal/cps-sort-icon/cps-sort-icon.component.mjs +79 -0
  26. package/esm2022/lib/components/cps-table/components/internal/table-column-filter/table-column-filter.component.mjs +408 -0
  27. package/esm2022/lib/components/cps-table/components/internal/table-column-filter-constraint/table-column-filter-constraint.component.mjs +149 -0
  28. package/esm2022/lib/components/cps-table/components/internal/table-row-menu/table-row-menu.component.mjs +88 -0
  29. package/esm2022/lib/components/cps-table/cps-table.component.mjs +941 -0
  30. package/esm2022/lib/components/cps-table/directives/cps-table-column-filter.directive.mjs +181 -0
  31. package/{esm2020 → esm2022}/lib/components/cps-table/directives/cps-table-column-sortable.directive.mjs +5 -5
  32. package/{esm2020 → esm2022}/lib/components/cps-table/directives/cps-table-header-selectable.directive.mjs +5 -5
  33. package/{esm2020 → esm2022}/lib/components/cps-table/directives/cps-table-row-selectable.directive.mjs +5 -5
  34. package/esm2022/lib/components/cps-table/directives/internal/table-unsort.directive.mjs +220 -0
  35. package/esm2022/lib/components/cps-tag/cps-tag.component.mjs +136 -0
  36. package/esm2022/lib/components/cps-textarea/cps-textarea.component.mjs +291 -0
  37. package/esm2022/lib/components/cps-timepicker/cps-timepicker.component.mjs +351 -0
  38. package/esm2022/lib/components/cps-tree-autocomplete/cps-tree-autocomplete.component.mjs +251 -0
  39. package/esm2022/lib/components/cps-tree-select/cps-tree-select.component.mjs +87 -0
  40. package/esm2022/lib/components/cps-tree-table/cps-tree-table.component.mjs +1196 -0
  41. package/{esm2020 → esm2022}/lib/components/cps-tree-table/directives/cps-tree-table-column-filter.directive.mjs +5 -5
  42. package/{esm2020 → esm2022}/lib/components/cps-tree-table/directives/cps-tree-table-column-sortable.directive.mjs +5 -5
  43. package/{esm2020 → esm2022}/lib/components/cps-tree-table/directives/cps-tree-table-header-selectable.directive.mjs +5 -5
  44. package/{esm2020 → esm2022}/lib/components/cps-tree-table/directives/cps-tree-table-row-selectable.directive.mjs +5 -5
  45. package/esm2022/lib/components/cps-tree-table/directives/cps-tree-table-row-toggler.directive.mjs +43 -0
  46. package/esm2022/lib/components/cps-tree-table/directives/internal/tree-table-unsort.directive.mjs +354 -0
  47. package/esm2022/lib/components/internal/cps-base-tree-dropdown/cps-base-tree-dropdown.component.mjs +619 -0
  48. package/esm2022/lib/directives/cps-tooltip/cps-tooltip.directive.mjs +257 -0
  49. package/{esm2020 → esm2022}/lib/pipes/internal/check-option-selected.pipe.mjs +4 -4
  50. package/esm2022/lib/pipes/internal/combine-labels.pipe.mjs +25 -0
  51. package/{esm2020 → esm2022}/lib/pipes/internal/label-by-value.pipe.mjs +4 -4
  52. package/esm2022/lib/services/cps-dialog/cps-dialog.service.mjs +99 -0
  53. package/{esm2020 → esm2022}/lib/services/cps-dialog/internal/components/cps-confirmation/cps-confirmation.component.mjs +5 -5
  54. package/esm2022/lib/services/cps-dialog/internal/components/cps-dialog/cps-dialog.component.mjs +470 -0
  55. package/{esm2020 → esm2022}/lib/services/cps-dialog/internal/directives/cps-dialog-content.directive.mjs +5 -5
  56. package/esm2022/lib/services/cps-dialog/utils/cps-dialog-config.mjs +3 -0
  57. package/esm2022/lib/services/cps-notification/cps-notification.service.mjs +126 -0
  58. package/esm2022/lib/services/cps-notification/internal/components/cps-notification-container/cps-notification-container.component.mjs +91 -0
  59. package/{esm2020 → esm2022}/lib/services/cps-notification/internal/components/cps-toast/cps-toast.component.mjs +23 -23
  60. package/esm2022/lib/utils/colors-utils.mjs +57 -0
  61. package/esm2022/lib/utils/internal/size-utils.mjs +24 -0
  62. package/{esm2020 → esm2022}/public-api.mjs +2 -2
  63. package/{fesm2020 → fesm2022}/cps-ui-kit.mjs +481 -391
  64. package/fesm2022/cps-ui-kit.mjs.map +1 -0
  65. package/lib/components/cps-autocomplete/cps-autocomplete.component.d.ts +2 -2
  66. package/lib/components/cps-button/cps-button.component.d.ts +1 -1
  67. package/lib/components/cps-button-toggle/cps-button-toggle.component.d.ts +2 -2
  68. package/lib/components/cps-checkbox/cps-checkbox.component.d.ts +2 -2
  69. package/lib/components/cps-chip/cps-chip.component.d.ts +1 -1
  70. package/lib/components/cps-datepicker/cps-datepicker.component.d.ts +2 -2
  71. package/lib/components/cps-expansion-panel/cps-expansion-panel.component.d.ts +1 -1
  72. package/lib/components/cps-file-upload/cps-file-upload.component.d.ts +1 -1
  73. package/lib/components/cps-icon/cps-icon.component.d.ts +1 -1
  74. package/lib/components/cps-info-circle/cps-info-circle.component.d.ts +2 -2
  75. package/lib/components/cps-input/cps-input.component.d.ts +2 -2
  76. package/lib/components/cps-loader/cps-loader.component.d.ts +1 -1
  77. package/lib/components/cps-menu/cps-menu.component.d.ts +1 -1
  78. package/lib/components/cps-paginator/cps-paginator.component.d.ts +1 -1
  79. package/lib/components/cps-progress-circular/cps-progress-circular.component.d.ts +1 -1
  80. package/lib/components/cps-progress-linear/cps-progress-linear.component.d.ts +1 -1
  81. package/lib/components/cps-radio-group/cps-radio/cps-radio.component.d.ts +1 -1
  82. package/lib/components/cps-radio-group/cps-radio-button/cps-radio-button.component.d.ts +1 -1
  83. package/lib/components/cps-radio-group/cps-radio-group.component.d.ts +2 -2
  84. package/lib/components/cps-select/cps-select.component.d.ts +2 -2
  85. package/lib/components/cps-sidebar-menu/cps-sidebar-menu.component.d.ts +1 -1
  86. package/lib/components/cps-tab-group/cps-tab/cps-tab.component.d.ts +1 -1
  87. package/lib/components/cps-tab-group/cps-tab-group.component.d.ts +1 -1
  88. package/lib/components/cps-table/components/internal/cps-sort-icon/cps-sort-icon.component.d.ts +1 -1
  89. package/lib/components/cps-table/components/internal/table-column-filter/table-column-filter.component.d.ts +1 -1
  90. package/lib/components/cps-table/components/internal/table-column-filter-constraint/table-column-filter-constraint.component.d.ts +1 -1
  91. package/lib/components/cps-table/components/internal/table-row-menu/table-row-menu.component.d.ts +1 -1
  92. package/lib/components/cps-table/cps-table.component.d.ts +1 -1
  93. package/lib/components/cps-table/directives/cps-table-column-filter.directive.d.ts +1 -1
  94. package/lib/components/cps-table/directives/cps-table-column-sortable.directive.d.ts +1 -1
  95. package/lib/components/cps-table/directives/cps-table-row-selectable.directive.d.ts +1 -1
  96. package/lib/components/cps-tag/cps-tag.component.d.ts +1 -1
  97. package/lib/components/cps-textarea/cps-textarea.component.d.ts +2 -2
  98. package/lib/components/cps-timepicker/cps-timepicker.component.d.ts +2 -2
  99. package/lib/components/cps-tree-autocomplete/cps-tree-autocomplete.component.d.ts +1 -1
  100. package/lib/components/cps-tree-select/cps-tree-select.component.d.ts +1 -1
  101. package/lib/components/cps-tree-table/cps-tree-table.component.d.ts +4 -4
  102. package/lib/components/cps-tree-table/directives/cps-tree-table-column-filter.directive.d.ts +1 -1
  103. package/lib/components/cps-tree-table/directives/cps-tree-table-column-sortable.directive.d.ts +1 -1
  104. package/lib/components/cps-tree-table/directives/cps-tree-table-row-selectable.directive.d.ts +1 -1
  105. package/lib/components/cps-tree-table/directives/cps-tree-table-row-toggler.directive.d.ts +1 -1
  106. package/lib/components/internal/cps-base-tree-dropdown/cps-base-tree-dropdown.component.d.ts +2 -2
  107. package/lib/directives/{cps-tooltip.directive.d.ts → cps-tooltip/cps-tooltip.directive.d.ts} +2 -2
  108. package/lib/services/cps-dialog/cps-dialog.service.d.ts +13 -0
  109. package/lib/services/cps-dialog/utils/cps-dialog-config.d.ts +1 -1
  110. package/lib/services/cps-notification/cps-notification.service.d.ts +32 -0
  111. package/lib/services/cps-notification/internal/components/cps-notification-container/cps-notification-container.component.d.ts +1 -1
  112. package/lib/services/cps-notification/internal/components/cps-toast/cps-toast.component.d.ts +1 -1
  113. package/package.json +12 -18
  114. package/public-api.d.ts +1 -1
  115. package/esm2020/lib/components/cps-autocomplete/cps-autocomplete.component.mjs +0 -824
  116. package/esm2020/lib/components/cps-button/cps-button.component.mjs +0 -190
  117. package/esm2020/lib/components/cps-button-toggle/cps-button-toggle.component.mjs +0 -235
  118. package/esm2020/lib/components/cps-checkbox/cps-checkbox.component.mjs +0 -149
  119. package/esm2020/lib/components/cps-chip/cps-chip.component.mjs +0 -94
  120. package/esm2020/lib/components/cps-datepicker/cps-datepicker.component.mjs +0 -382
  121. package/esm2020/lib/components/cps-expansion-panel/cps-expansion-panel.component.mjs +0 -209
  122. package/esm2020/lib/components/cps-file-upload/cps-file-upload.component.mjs +0 -138
  123. package/esm2020/lib/components/cps-icon/cps-icon.component.mjs +0 -193
  124. package/esm2020/lib/components/cps-info-circle/cps-info-circle.component.mjs +0 -61
  125. package/esm2020/lib/components/cps-input/cps-input.component.mjs +0 -386
  126. package/esm2020/lib/components/cps-menu/cps-menu.component.mjs +0 -552
  127. package/esm2020/lib/components/cps-paginator/cps-paginator.component.mjs +0 -113
  128. package/esm2020/lib/components/cps-paginator/pipes/cps-paginate.pipe.mjs +0 -30
  129. package/esm2020/lib/components/cps-radio-group/cps-radio-button/cps-radio-button.component.mjs +0 -55
  130. package/esm2020/lib/components/cps-radio-group/cps-radio-group.component.mjs +0 -158
  131. package/esm2020/lib/components/cps-select/cps-select.component.mjs +0 -615
  132. package/esm2020/lib/components/cps-sidebar-menu/cps-sidebar-menu.component.mjs +0 -110
  133. package/esm2020/lib/components/cps-tab-group/cps-tab-group.component.mjs +0 -299
  134. package/esm2020/lib/components/cps-table/components/internal/cps-sort-icon/cps-sort-icon.component.mjs +0 -79
  135. package/esm2020/lib/components/cps-table/components/internal/table-column-filter/table-column-filter.component.mjs +0 -408
  136. package/esm2020/lib/components/cps-table/components/internal/table-column-filter-constraint/table-column-filter-constraint.component.mjs +0 -148
  137. package/esm2020/lib/components/cps-table/components/internal/table-row-menu/table-row-menu.component.mjs +0 -88
  138. package/esm2020/lib/components/cps-table/cps-table.component.mjs +0 -940
  139. package/esm2020/lib/components/cps-table/directives/cps-table-column-filter.directive.mjs +0 -181
  140. package/esm2020/lib/components/cps-table/directives/internal/table-unsort.directive.mjs +0 -210
  141. package/esm2020/lib/components/cps-tag/cps-tag.component.mjs +0 -136
  142. package/esm2020/lib/components/cps-textarea/cps-textarea.component.mjs +0 -291
  143. package/esm2020/lib/components/cps-timepicker/cps-timepicker.component.mjs +0 -351
  144. package/esm2020/lib/components/cps-tree-autocomplete/cps-tree-autocomplete.component.mjs +0 -250
  145. package/esm2020/lib/components/cps-tree-select/cps-tree-select.component.mjs +0 -87
  146. package/esm2020/lib/components/cps-tree-table/cps-tree-table.component.mjs +0 -1192
  147. package/esm2020/lib/components/cps-tree-table/directives/cps-tree-table-row-toggler.directive.mjs +0 -43
  148. package/esm2020/lib/components/cps-tree-table/directives/internal/tree-table-unsort.directive.mjs +0 -334
  149. package/esm2020/lib/components/internal/cps-base-tree-dropdown/cps-base-tree-dropdown.component.mjs +0 -616
  150. package/esm2020/lib/directives/cps-tooltip.directive.mjs +0 -257
  151. package/esm2020/lib/pipes/internal/combine-labels.pipe.mjs +0 -25
  152. package/esm2020/lib/services/cps-dialog/cps-dialog.service.mjs +0 -86
  153. package/esm2020/lib/services/cps-dialog/internal/components/cps-dialog/cps-dialog.component.mjs +0 -470
  154. package/esm2020/lib/services/cps-dialog/utils/cps-dialog-config.mjs +0 -3
  155. package/esm2020/lib/services/cps-notification/cps-notification.service.mjs +0 -94
  156. package/esm2020/lib/services/cps-notification/internal/components/cps-notification-container/cps-notification-container.component.mjs +0 -91
  157. package/esm2020/lib/utils/colors-utils.mjs +0 -57
  158. package/esm2020/lib/utils/internal/size-utils.mjs +0 -24
  159. package/fesm2015/cps-ui-kit.mjs +0 -12086
  160. package/fesm2015/cps-ui-kit.mjs.map +0 -1
  161. package/fesm2020/cps-ui-kit.mjs.map +0 -1
  162. /package/{esm2020 → esm2022}/cps-ui-kit.mjs +0 -0
  163. /package/{esm2020 → esm2022}/lib/components/cps-table/cps-column-filter-types.mjs +0 -0
  164. /package/{esm2020 → esm2022}/lib/services/cps-dialog/utils/cps-dialog-ref.mjs +0 -0
  165. /package/{esm2020 → esm2022}/lib/services/cps-notification/utils/cps-notification-config.mjs +0 -0
  166. /package/{esm2020 → esm2022}/lib/services/cps-notification/utils/internal/cps-notification-data.mjs +0 -0
@@ -0,0 +1,136 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { Component, EventEmitter, Input, Optional, Output, Self } from '@angular/core';
3
+ import { getCSSColor } from '../../utils/colors-utils';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/forms";
6
+ import * as i2 from "@angular/common";
7
+ /**
8
+ * CpsTagComponent is used to categorize content.
9
+ * @group Components
10
+ */
11
+ export class CpsTagComponent {
12
+ /**
13
+ * Tag value.
14
+ * @group Props
15
+ */
16
+ set value(value) {
17
+ this._value = value;
18
+ this.onChange(value);
19
+ }
20
+ get value() {
21
+ return this._value;
22
+ }
23
+ constructor(_control) {
24
+ this._control = _control;
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
+ */
34
+ this.label = '';
35
+ /**
36
+ * Color of the tag.
37
+ * @group Props
38
+ */
39
+ this.color = '';
40
+ /**
41
+ * Determines whether the tag should be disabled.
42
+ * @group Props
43
+ */
44
+ this.disabled = false;
45
+ /**
46
+ * Determines whether the tag should be selectable.
47
+ * @group Props
48
+ */
49
+ this.selectable = false;
50
+ /**
51
+ * Callback to invoke on value change.
52
+ * @param {boolean} boolean - value change.
53
+ * @group Emits
54
+ */
55
+ this.valueChanged = new EventEmitter();
56
+ this.classesList = [];
57
+ this.tagColor = '';
58
+ this._value = false;
59
+ // eslint-disable-next-line @typescript-eslint/no-empty-function
60
+ this.onChange = (event) => { };
61
+ // eslint-disable-next-line @typescript-eslint/no-empty-function
62
+ this.onTouched = () => { };
63
+ if (this._control) {
64
+ this._control.valueAccessor = this;
65
+ }
66
+ }
67
+ ngOnChanges() {
68
+ this.setClasses();
69
+ }
70
+ setClasses() {
71
+ this.classesList = ['cps-tag'];
72
+ if (this.selectable) {
73
+ this.classesList.push('cps-tag--selectable');
74
+ }
75
+ if (this.disabled) {
76
+ this.classesList.push('cps-tag--disabled');
77
+ }
78
+ switch (this.type) {
79
+ case 'security': {
80
+ this.classesList.push('cps-tag--security');
81
+ break;
82
+ }
83
+ case 'classification': {
84
+ this.classesList.push('cps-tag--classification');
85
+ break;
86
+ }
87
+ default:
88
+ if (this.color)
89
+ this.tagColor = getCSSColor(this.color);
90
+ }
91
+ }
92
+ registerOnChange(fn) {
93
+ this.onChange = fn;
94
+ }
95
+ registerOnTouched(fn) {
96
+ this.onTouched = fn;
97
+ }
98
+ writeValue(value) {
99
+ this.value = value;
100
+ }
101
+ toggleSelected() {
102
+ if (this.disabled || !this.selectable)
103
+ return;
104
+ this._updateValue(!this.value);
105
+ }
106
+ _updateValue(value) {
107
+ this.writeValue(value);
108
+ this.onChange(value);
109
+ this.valueChanged.emit(value);
110
+ }
111
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsTagComponent, deps: [{ token: i1.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component }); }
112
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: CpsTagComponent, isStandalone: true, selector: "cps-tag", inputs: { type: "type", label: "label", color: "color", disabled: "disabled", selectable: "selectable", value: "value" }, outputs: { valueChanged: "valueChanged" }, usesOnChanges: true, ngImport: i0, template: "<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", styles: [":host{width:fit-content;display:inline-block;-webkit-user-select:none;-ms-user-select:none;user-select:none}:host .cps-tag{font-family:Source Sans Pro,sans-serif;min-height:25px;align-items:center;padding:0 10px;background-color:#fff;display:inline-flex;cursor:default;border:solid 1px;border-left:solid 4px}:host .cps-tag.cps-tag--security{border-color:var(--cps-color-warn)}:host .cps-tag.cps-tag--classification{border-color:var(--cps-color-info)}:host .cps-tag.cps-tag--selectable{cursor:pointer}:host .cps-tag.cps-tag--selectable:not(:active):not(:disabled){box-shadow:1px 3px 4px #0000001a}:host .cps-tag.cps-tag--disabled{pointer-events:none;border-color:var(--cps-color-line-dark)!important}:host .cps-tag.cps-tag--disabled p{color:var(--cps-color-text-light)}:host .cps-tag.unselected{border-color:var(--cps-color-text-light)!important}:host .cps-tag p{margin:0;font-size:11px;color:var(--cps-color-text-dark)}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); }
113
+ }
114
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsTagComponent, decorators: [{
115
+ type: Component,
116
+ args: [{ standalone: true, imports: [CommonModule], selector: 'cps-tag', template: "<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", styles: [":host{width:fit-content;display:inline-block;-webkit-user-select:none;-ms-user-select:none;user-select:none}:host .cps-tag{font-family:Source Sans Pro,sans-serif;min-height:25px;align-items:center;padding:0 10px;background-color:#fff;display:inline-flex;cursor:default;border:solid 1px;border-left:solid 4px}:host .cps-tag.cps-tag--security{border-color:var(--cps-color-warn)}:host .cps-tag.cps-tag--classification{border-color:var(--cps-color-info)}:host .cps-tag.cps-tag--selectable{cursor:pointer}:host .cps-tag.cps-tag--selectable:not(:active):not(:disabled){box-shadow:1px 3px 4px #0000001a}:host .cps-tag.cps-tag--disabled{pointer-events:none;border-color:var(--cps-color-line-dark)!important}:host .cps-tag.cps-tag--disabled p{color:var(--cps-color-text-light)}:host .cps-tag.unselected{border-color:var(--cps-color-text-light)!important}:host .cps-tag p{margin:0;font-size:11px;color:var(--cps-color-text-dark)}\n"] }]
117
+ }], ctorParameters: () => [{ type: i1.NgControl, decorators: [{
118
+ type: Self
119
+ }, {
120
+ type: Optional
121
+ }] }], propDecorators: { type: [{
122
+ type: Input
123
+ }], label: [{
124
+ type: Input
125
+ }], color: [{
126
+ type: Input
127
+ }], disabled: [{
128
+ type: Input
129
+ }], selectable: [{
130
+ type: Input
131
+ }], value: [{
132
+ type: Input
133
+ }], valueChanged: [{
134
+ type: Output
135
+ }] } });
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":"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","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   * Determines whether the tag should be disabled.\n   * @group Props\n   */\n  @Input() disabled = false;\n\n  /**\n   * Determines 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"]}
@@ -0,0 +1,291 @@
1
+ import { Component, EventEmitter, Input, Optional, Output, Self } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { Subscription } from 'rxjs';
4
+ import { convertSize } from '../../utils/internal/size-utils';
5
+ import { CpsIconComponent } from '../cps-icon/cps-icon.component';
6
+ import { CpsInfoCircleComponent } from '../cps-info-circle/cps-info-circle.component';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@angular/forms";
9
+ import * as i2 from "@angular/common";
10
+ /**
11
+ * CpsTextareaComponent is a textarea component.
12
+ * @group Components
13
+ */
14
+ export class CpsTextareaComponent {
15
+ /**
16
+ * Value of the textarea.
17
+ * @group Props
18
+ */
19
+ set value(value) {
20
+ if (!value)
21
+ value = '';
22
+ this._value = value;
23
+ this.onChange(value);
24
+ }
25
+ get value() {
26
+ return this._value;
27
+ }
28
+ constructor(_control, _elementRef) {
29
+ this._control = _control;
30
+ this._elementRef = _elementRef;
31
+ /**
32
+ * Label of the textarea.
33
+ * @group Props
34
+ */
35
+ this.label = '';
36
+ /**
37
+ * Placeholder text for the textarea.
38
+ * @group Props
39
+ */
40
+ this.placeholder = 'Please enter';
41
+ /**
42
+ * Number of rows in the textarea.
43
+ * @group Props
44
+ */
45
+ this.rows = 5;
46
+ /**
47
+ * The cols attribute specifies the visible width of a textarea.
48
+ * @group Props
49
+ */
50
+ this.cols = 20;
51
+ /**
52
+ * Determines whether the textarea can auto focus.
53
+ * @group Props
54
+ */
55
+ this.autofocus = false;
56
+ /**
57
+ * Bottom hint text for the textarea.
58
+ * @group Props
59
+ */
60
+ this.hint = '';
61
+ /**
62
+ * Determines whether the textarea is disabled.
63
+ * @group Props
64
+ */
65
+ this.disabled = false;
66
+ /**
67
+ * Width of the textarea, it can be of type number denoting pixels or string.
68
+ * @group Props
69
+ */
70
+ this.width = '100%';
71
+ /**
72
+ * When enabled, a clear icon is displayed to clear the value.
73
+ * @group Props
74
+ */
75
+ this.clearable = false;
76
+ /**
77
+ * Hides hint and validation errors.
78
+ * @group Props
79
+ */
80
+ this.hideDetails = false;
81
+ /**
82
+ * Determines whether the textarea should have persistent clear icon.
83
+ * @group Props
84
+ */
85
+ this.persistentClear = false;
86
+ /**
87
+ * Error message.
88
+ * @group Props
89
+ */
90
+ this.error = '';
91
+ /**
92
+ * Determines whether the component can be resized vertically or not.
93
+ * @group Props
94
+ */
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
+ */
100
+ this.infoTooltip = '';
101
+ /**
102
+ * Info tooltip class for styling.
103
+ * @group Props
104
+ */
105
+ this.infoTooltipClass = 'cps-tooltip-content';
106
+ /**
107
+ * Max width of infoTooltip, of type number denoting pixels or string.
108
+ * @group Props
109
+ */
110
+ this.infoTooltipMaxWidth = '100%';
111
+ /**
112
+ * Determines whether the infoTooltip is persistent.
113
+ * @group Props
114
+ */
115
+ this.infoTooltipPersistent = false;
116
+ /**
117
+ * Position of infoTooltip, it can be 'top', 'bottom', 'left' or 'right'.
118
+ * @group Props
119
+ */
120
+ this.infoTooltipPosition = 'top';
121
+ /**
122
+ * Callback to invoke on value change.
123
+ * @param {string} string - value changed.
124
+ * @group Emits
125
+ */
126
+ this.valueChanged = new EventEmitter();
127
+ /**
128
+ * Callback to invoke when the component receives focus.
129
+ * @param {any}
130
+ * @group Emits
131
+ */
132
+ this.focused = new EventEmitter();
133
+ /**
134
+ * Callback to invoke when the prefixIcon is clicked.
135
+ * @param {any}
136
+ * @group Emits
137
+ */
138
+ this.prefixIconClicked = new EventEmitter();
139
+ /**
140
+ * Callback to invoke when the component loses focus.
141
+ * @param {any}
142
+ * @group Emits
143
+ */
144
+ this.blurred = new EventEmitter();
145
+ this._statusChangesSubscription = new Subscription();
146
+ this._value = '';
147
+ this.cvtWidth = '';
148
+ // eslint-disable-next-line @typescript-eslint/no-empty-function
149
+ this.onChange = (event) => { };
150
+ // eslint-disable-next-line @typescript-eslint/no-empty-function
151
+ this.onTouched = () => { };
152
+ if (this._control) {
153
+ this._control.valueAccessor = this;
154
+ }
155
+ }
156
+ ngOnInit() {
157
+ this.cvtWidth = convertSize(this.width);
158
+ this._statusChangesSubscription = this._control?.statusChanges?.subscribe(() => {
159
+ this._checkErrors();
160
+ });
161
+ }
162
+ ngOnDestroy() {
163
+ this._statusChangesSubscription?.unsubscribe();
164
+ }
165
+ _checkErrors() {
166
+ if (!this._control)
167
+ return;
168
+ const errors = this._control?.errors;
169
+ if (!this._control?.control?.touched || !errors) {
170
+ this.error = '';
171
+ return;
172
+ }
173
+ if ('required' in errors) {
174
+ this.error = 'Field is required';
175
+ return;
176
+ }
177
+ if ('pattern' in errors) {
178
+ this.error = 'Value is invalid';
179
+ return;
180
+ }
181
+ if ('minlength' in errors) {
182
+ // eslint-disable-next-line dot-notation
183
+ this.error = `Field must contain at least ${errors['minlength'].requiredLength} characters`;
184
+ return;
185
+ }
186
+ if ('maxlength' in errors) {
187
+ // eslint-disable-next-line dot-notation
188
+ this.error = `Field must contain ${errors['maxlength'].requiredLength} characters maximum`;
189
+ return;
190
+ }
191
+ const errArr = Object.values(errors);
192
+ if (errArr.length < 1) {
193
+ this.error = '';
194
+ return;
195
+ }
196
+ const message = errArr.find((msg) => typeof msg === 'string');
197
+ this.error = message || 'Unknown error';
198
+ }
199
+ registerOnChange(fn) {
200
+ this.onChange = fn;
201
+ }
202
+ registerOnTouched(fn) {
203
+ this.onTouched = fn;
204
+ }
205
+ writeValue(value) {
206
+ this.value = value;
207
+ }
208
+ updateValueEvent(event) {
209
+ const value = event?.target?.value || '';
210
+ this._updateValue(value);
211
+ }
212
+ _updateValue(value) {
213
+ this.writeValue(value);
214
+ this.onChange(value);
215
+ this.valueChanged.emit(value);
216
+ }
217
+ clear() {
218
+ if (this.value !== '')
219
+ this._updateValue('');
220
+ }
221
+ // eslint-disable-next-line @typescript-eslint/no-empty-function
222
+ setDisabledState(disabled) { }
223
+ onBlur() {
224
+ this._control?.control?.markAsTouched();
225
+ this._checkErrors();
226
+ this.blurred.emit();
227
+ }
228
+ onFocus() {
229
+ this.focused.emit();
230
+ }
231
+ focus() {
232
+ this._elementRef?.nativeElement?.querySelector('textarea')?.focus();
233
+ }
234
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsTextareaComponent, deps: [{ token: i1.NgControl, optional: true, self: true }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
235
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: CpsTextareaComponent, isStandalone: true, selector: "cps-textarea", inputs: { label: "label", placeholder: "placeholder", rows: "rows", cols: "cols", autofocus: "autofocus", hint: "hint", disabled: "disabled", width: "width", clearable: "clearable", hideDetails: "hideDetails", persistentClear: "persistentClear", error: "error", resizable: "resizable", infoTooltip: "infoTooltip", infoTooltipClass: "infoTooltipClass", infoTooltipMaxWidth: "infoTooltipMaxWidth", infoTooltipPersistent: "infoTooltipPersistent", infoTooltipPosition: "infoTooltipPosition", value: "value" }, outputs: { valueChanged: "valueChanged", focused: "focused", prefixIconClicked: "prefixIconClicked", blurred: "blurred" }, ngImport: i0, template: "<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", styles: [":host{display:flex}:host .cps-textarea-container{width:100%;gap:.2rem!important;display:flex!important;flex-direction:column!important;font-family:Source Sans Pro,sans-serif}:host .cps-textarea-container .cps-textarea-wrap{position:relative;overflow:hidden}:host .cps-textarea-container .cps-textarea-wrap:hover textarea:enabled{border:1px solid var(--cps-color-calm)}:host .cps-textarea-container .cps-textarea-wrap-error textarea{border-color:var(--cps-color-error)!important}:host .cps-textarea-container .cps-textarea-wrap-error textarea:not(:focus){background:#fef3f2!important}:host .cps-textarea-container .cps-textarea-wrap textarea{display:block;font-family:Source Sans Pro,sans-serif;font-size:1rem;color:var(--cps-color-text-dark);background:#fff;padding:.375rem .75rem;line-height:1.5;min-height:38px;border:1px solid var(--cps-color-line-light);transition-property:border-color;transition-duration:.2s;appearance:none;border-radius:4px;width:100%}:host .cps-textarea-container .cps-textarea-wrap textarea:focus{border:1px solid var(--cps-color-calm);outline:0}:host .cps-textarea-container .cps-textarea-wrap textarea:disabled{color:var(--cps-color-text-light);background-color:#f7f7f7;opacity:1;pointer-events:none}:host .cps-textarea-container .cps-textarea-wrap textarea:focus+.clear-btn cps-icon{opacity:.5}:host .cps-textarea-container .cps-textarea-wrap:hover .clear-btn cps-icon{opacity:.5}:host .cps-textarea-container .cps-textarea-wrap .clear-btn{position:absolute;top:.75rem;right:.75rem;cursor:pointer;color:var(--cps-color-calm)}:host .cps-textarea-container .cps-textarea-wrap .clear-btn cps-icon{opacity:0;transition-duration:.2s}:host .cps-textarea-container .cps-textarea-wrap .clear-btn cps-icon:hover{opacity:1!important}:host .cps-textarea-container .persistent-clear .clear-btn cps-icon{opacity:.5}:host .cps-textarea-container .clearable>textarea{padding-right:2.2rem}:host .cps-textarea-container .cps-textarea-hint{color:var(--cps-color-text-mild);font-size:.75rem;min-height:1.125rem;line-height:1.125rem;cursor:default}:host .cps-textarea-container .cps-textarea-error{color:var(--cps-color-error);font-weight:700;font-size:.75rem;min-height:1.125rem;line-height:1.125rem;cursor:default}:host .cps-textarea-container .cps-textarea-label{color:var(--cps-color-text-dark);font-size:.875rem;align-items:center;display:inline-flex;font-weight:600}:host .cps-textarea-container .cps-textarea-label .cps-textarea-label-info-circle{margin-left:8px}:host .cps-textarea-container .cps-textarea-label-disabled{color:var(--cps-color-text-mild)}:host .cps-textarea-container ::placeholder{font-family:Source Sans Pro,sans-serif;color:var(--cps-color-text-lightest);font-style:italic;opacity:1}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: CpsIconComponent, selector: "cps-icon", inputs: ["icon", "size", "color"] }, { kind: "component", type: CpsInfoCircleComponent, selector: "cps-info-circle", inputs: ["size", "tooltipText", "tooltipPosition", "tooltipContentClass", "tooltipMaxWidth", "tooltipPersistent"] }] }); }
236
+ }
237
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsTextareaComponent, decorators: [{
238
+ type: Component,
239
+ args: [{ standalone: true, selector: 'cps-textarea', imports: [CommonModule, CpsIconComponent, CpsInfoCircleComponent], template: "<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", styles: [":host{display:flex}:host .cps-textarea-container{width:100%;gap:.2rem!important;display:flex!important;flex-direction:column!important;font-family:Source Sans Pro,sans-serif}:host .cps-textarea-container .cps-textarea-wrap{position:relative;overflow:hidden}:host .cps-textarea-container .cps-textarea-wrap:hover textarea:enabled{border:1px solid var(--cps-color-calm)}:host .cps-textarea-container .cps-textarea-wrap-error textarea{border-color:var(--cps-color-error)!important}:host .cps-textarea-container .cps-textarea-wrap-error textarea:not(:focus){background:#fef3f2!important}:host .cps-textarea-container .cps-textarea-wrap textarea{display:block;font-family:Source Sans Pro,sans-serif;font-size:1rem;color:var(--cps-color-text-dark);background:#fff;padding:.375rem .75rem;line-height:1.5;min-height:38px;border:1px solid var(--cps-color-line-light);transition-property:border-color;transition-duration:.2s;appearance:none;border-radius:4px;width:100%}:host .cps-textarea-container .cps-textarea-wrap textarea:focus{border:1px solid var(--cps-color-calm);outline:0}:host .cps-textarea-container .cps-textarea-wrap textarea:disabled{color:var(--cps-color-text-light);background-color:#f7f7f7;opacity:1;pointer-events:none}:host .cps-textarea-container .cps-textarea-wrap textarea:focus+.clear-btn cps-icon{opacity:.5}:host .cps-textarea-container .cps-textarea-wrap:hover .clear-btn cps-icon{opacity:.5}:host .cps-textarea-container .cps-textarea-wrap .clear-btn{position:absolute;top:.75rem;right:.75rem;cursor:pointer;color:var(--cps-color-calm)}:host .cps-textarea-container .cps-textarea-wrap .clear-btn cps-icon{opacity:0;transition-duration:.2s}:host .cps-textarea-container .cps-textarea-wrap .clear-btn cps-icon:hover{opacity:1!important}:host .cps-textarea-container .persistent-clear .clear-btn cps-icon{opacity:.5}:host .cps-textarea-container .clearable>textarea{padding-right:2.2rem}:host .cps-textarea-container .cps-textarea-hint{color:var(--cps-color-text-mild);font-size:.75rem;min-height:1.125rem;line-height:1.125rem;cursor:default}:host .cps-textarea-container .cps-textarea-error{color:var(--cps-color-error);font-weight:700;font-size:.75rem;min-height:1.125rem;line-height:1.125rem;cursor:default}:host .cps-textarea-container .cps-textarea-label{color:var(--cps-color-text-dark);font-size:.875rem;align-items:center;display:inline-flex;font-weight:600}:host .cps-textarea-container .cps-textarea-label .cps-textarea-label-info-circle{margin-left:8px}:host .cps-textarea-container .cps-textarea-label-disabled{color:var(--cps-color-text-mild)}:host .cps-textarea-container ::placeholder{font-family:Source Sans Pro,sans-serif;color:var(--cps-color-text-lightest);font-style:italic;opacity:1}\n"] }]
240
+ }], ctorParameters: () => [{ type: i1.NgControl, decorators: [{
241
+ type: Self
242
+ }, {
243
+ type: Optional
244
+ }] }, { type: i0.ElementRef }], propDecorators: { label: [{
245
+ type: Input
246
+ }], placeholder: [{
247
+ type: Input
248
+ }], rows: [{
249
+ type: Input
250
+ }], cols: [{
251
+ type: Input
252
+ }], autofocus: [{
253
+ type: Input
254
+ }], hint: [{
255
+ type: Input
256
+ }], disabled: [{
257
+ type: Input
258
+ }], width: [{
259
+ type: Input
260
+ }], clearable: [{
261
+ type: Input
262
+ }], hideDetails: [{
263
+ type: Input
264
+ }], persistentClear: [{
265
+ type: Input
266
+ }], error: [{
267
+ type: Input
268
+ }], resizable: [{
269
+ type: Input
270
+ }], infoTooltip: [{
271
+ type: Input
272
+ }], infoTooltipClass: [{
273
+ type: Input
274
+ }], infoTooltipMaxWidth: [{
275
+ type: Input
276
+ }], infoTooltipPersistent: [{
277
+ type: Input
278
+ }], infoTooltipPosition: [{
279
+ type: Input
280
+ }], value: [{
281
+ type: Input
282
+ }], valueChanged: [{
283
+ type: Output
284
+ }], focused: [{
285
+ type: Output
286
+ }], prefixIconClicked: [{
287
+ type: Output
288
+ }], blurred: [{
289
+ type: Output
290
+ }] } });
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/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   * Determines 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   * Determines 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   * Determines 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   * Determines 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   * Determines 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"]}