@pega/angular-sdk-overrides 24.2.12 → 25.1.11

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 (237) hide show
  1. package/lib/designSystemExtension/alert/alert.component.scss +3 -3
  2. package/lib/designSystemExtension/alert/alert.component.ts +0 -1
  3. package/lib/designSystemExtension/alert-banner/alert-banner.component.ts +0 -1
  4. package/lib/designSystemExtension/banner/banner.component.html +1 -1
  5. package/lib/designSystemExtension/banner/banner.component.scss +17 -3
  6. package/lib/designSystemExtension/banner/banner.component.ts +0 -1
  7. package/lib/designSystemExtension/case-create-stage/case-create-stage.component.ts +0 -1
  8. package/lib/designSystemExtension/field-group/field-group.component.ts +0 -1
  9. package/lib/designSystemExtension/material-case-summary/material-case-summary.component.html +6 -3
  10. package/lib/designSystemExtension/material-case-summary/material-case-summary.component.scss +5 -34
  11. package/lib/designSystemExtension/material-case-summary/material-case-summary.component.ts +0 -1
  12. package/lib/designSystemExtension/material-details/material-details.component.scss +0 -5
  13. package/lib/designSystemExtension/material-details/material-details.component.ts +0 -1
  14. package/lib/designSystemExtension/material-details-fields/material-details-fields.component.html +2 -2
  15. package/lib/designSystemExtension/material-details-fields/material-details-fields.component.scss +4 -3
  16. package/lib/designSystemExtension/material-details-fields/material-details-fields.component.ts +0 -1
  17. package/lib/designSystemExtension/material-summary-item/material-summary-item.component.scss +4 -17
  18. package/lib/designSystemExtension/material-summary-item/material-summary-item.component.ts +0 -1
  19. package/lib/designSystemExtension/material-summary-list/material-summary-list.component.ts +0 -1
  20. package/lib/designSystemExtension/material-utility/material-utility.component.scss +1 -2
  21. package/lib/designSystemExtension/material-vertical-tabs/material-vertical-tabs.component.scss +1 -1
  22. package/lib/designSystemExtension/material-vertical-tabs/material-vertical-tabs.component.ts +0 -1
  23. package/lib/designSystemExtension/operator/operator.component.html +1 -1
  24. package/lib/designSystemExtension/operator/operator.component.scss +3 -10
  25. package/lib/designSystemExtension/operator/operator.component.ts +0 -2
  26. package/lib/designSystemExtension/pulse/pulse.component.scss +2 -2
  27. package/lib/designSystemExtension/pulse/pulse.component.ts +0 -1
  28. package/lib/designSystemExtension/rich-text-editor/rich-text-editor.component.html +4 -17
  29. package/lib/designSystemExtension/rich-text-editor/rich-text-editor.component.scss +0 -1
  30. package/lib/designSystemExtension/rich-text-editor/rich-text-editor.component.ts +30 -1
  31. package/lib/designSystemExtension/wss-quick-create/wss-quick-create.component.scss +16 -9
  32. package/lib/designSystemExtension/wss-quick-create/wss-quick-create.component.ts +0 -1
  33. package/lib/field/auto-complete/auto-complete.component.html +0 -1
  34. package/lib/field/auto-complete/auto-complete.component.ts +35 -173
  35. package/lib/field/cancel-alert/cancel-alert.component.html +8 -12
  36. package/lib/field/cancel-alert/cancel-alert.component.scss +2 -3
  37. package/lib/field/cancel-alert/cancel-alert.component.ts +24 -37
  38. package/lib/field/check-box/check-box.component.html +19 -10
  39. package/lib/field/check-box/check-box.component.scss +6 -1
  40. package/lib/field/check-box/check-box.component.ts +25 -151
  41. package/lib/field/currency/currency.component.ts +36 -169
  42. package/lib/field/date/date.component.html +2 -2
  43. package/lib/field/date/date.component.ts +30 -151
  44. package/lib/field/date-time/date-time.component.html +1 -1
  45. package/lib/field/date-time/date-time.component.ts +34 -149
  46. package/lib/field/decimal/decimal.component.ts +38 -164
  47. package/lib/field/dropdown/dropdown.component.ts +29 -152
  48. package/lib/field/email/email.component.ts +16 -156
  49. package/lib/field/field.base.ts +149 -0
  50. package/lib/field/group/group.component.ts +7 -5
  51. package/lib/field/integer/integer.component.ts +18 -158
  52. package/lib/field/list-view-action-buttons/list-view-action-buttons.component.ts +0 -1
  53. package/lib/field/location/config-ext.json +8 -0
  54. package/lib/field/location/location.component.html +46 -0
  55. package/lib/field/location/location.component.scss +18 -0
  56. package/lib/field/location/location.component.spec.ts +22 -0
  57. package/lib/field/location/location.component.ts +280 -0
  58. package/lib/field/multiselect/multiselect.component.ts +47 -152
  59. package/lib/field/multiselect/utils.ts +55 -47
  60. package/lib/field/object-reference/object-reference.component.html +17 -0
  61. package/lib/field/object-reference/object-reference.component.scss +0 -0
  62. package/lib/field/object-reference/object-reference.component.spec.ts +22 -0
  63. package/lib/field/object-reference/object-reference.component.ts +237 -0
  64. package/lib/field/percentage/percentage.component.ts +37 -155
  65. package/lib/field/phone/phone.component.html +18 -19
  66. package/lib/field/phone/phone.component.scss +4 -0
  67. package/lib/field/phone/phone.component.ts +43 -145
  68. package/lib/field/radio-buttons/radio-buttons.component.html +14 -6
  69. package/lib/field/radio-buttons/radio-buttons.component.scss +4 -2
  70. package/lib/field/radio-buttons/radio-buttons.component.ts +37 -160
  71. package/lib/field/rich-text/rich-text.component.html +2 -0
  72. package/lib/field/rich-text/rich-text.component.scss +172 -0
  73. package/lib/field/rich-text/rich-text.component.ts +21 -91
  74. package/lib/field/scalar-list/scalar-list.component.ts +17 -73
  75. package/lib/field/selectable-card/selectable-card.component.html +70 -0
  76. package/lib/field/selectable-card/selectable-card.component.scss +11 -0
  77. package/lib/field/selectable-card/selectable-card.component.spec.ts +22 -0
  78. package/lib/field/selectable-card/selectable-card.component.ts +219 -0
  79. package/lib/field/semantic-link/semantic-link.component.html +4 -8
  80. package/lib/field/semantic-link/semantic-link.component.scss +0 -13
  81. package/lib/field/semantic-link/semantic-link.component.ts +165 -6
  82. package/lib/field/text/text.component.scss +0 -1
  83. package/lib/field/text/text.component.ts +0 -1
  84. package/lib/field/text-area/text-area.component.ts +18 -153
  85. package/lib/field/text-content/text-content.component.ts +0 -1
  86. package/lib/field/text-input/text-input.component.ts +16 -156
  87. package/lib/field/time/time.component.ts +17 -152
  88. package/lib/field/url/url.component.ts +16 -155
  89. package/lib/field/user-reference/user-reference.component.scss +0 -1
  90. package/lib/field/user-reference/user-reference.component.ts +2 -4
  91. package/lib/infra/Containers/flow-container/flow-container.component.html +2 -2
  92. package/lib/infra/Containers/flow-container/flow-container.component.ts +8 -9
  93. package/lib/infra/Containers/hybrid-view-container/hybrid-view-container.component.ts +0 -1
  94. package/lib/infra/Containers/modal-view-container/modal-view-container.component.ts +5 -11
  95. package/lib/infra/Containers/view-container/helper.ts +35 -2
  96. package/lib/infra/Containers/view-container/view-container.component.ts +1 -2
  97. package/lib/infra/action-buttons/action-buttons.component.html +13 -8
  98. package/lib/infra/action-buttons/action-buttons.component.scss +23 -0
  99. package/lib/infra/action-buttons/action-buttons.component.ts +1 -3
  100. package/lib/infra/assignment/assignment.component.ts +21 -10
  101. package/lib/infra/assignment-card/assignment-card.component.html +1 -2
  102. package/lib/infra/assignment-card/assignment-card.component.scss +0 -4
  103. package/lib/infra/assignment-card/assignment-card.component.ts +21 -5
  104. package/lib/infra/dashboard-filter/dashboard-filter.component.ts +0 -1
  105. package/lib/infra/defer-load/defer-load.component.html +6 -2
  106. package/lib/infra/defer-load/defer-load.component.ts +22 -12
  107. package/lib/infra/error-boundary/error-boundary.component.ts +0 -1
  108. package/lib/infra/multi-step/multi-step.component.html +22 -38
  109. package/lib/infra/multi-step/multi-step.component.scss +14 -27
  110. package/lib/infra/multi-step/multi-step.component.ts +0 -1
  111. package/lib/infra/navbar/navbar.component.html +36 -41
  112. package/lib/infra/navbar/navbar.component.scss +22 -4
  113. package/lib/infra/navbar/navbar.component.ts +8 -4
  114. package/lib/infra/reference/reference.component.ts +5 -0
  115. package/lib/infra/region/region.component.ts +0 -1
  116. package/lib/infra/root-container/root-container.component.scss +0 -1
  117. package/lib/infra/root-container/root-container.component.ts +1 -5
  118. package/lib/infra/stages/stages.component.html +4 -3
  119. package/lib/infra/stages/stages.component.scss +12 -36
  120. package/lib/infra/stages/stages.component.ts +4 -3
  121. package/lib/infra/view/view.component.html +1 -1
  122. package/lib/infra/view/view.component.ts +3 -7
  123. package/lib/template/advanced-search/advanced-search.component.html +12 -0
  124. package/lib/template/advanced-search/advanced-search.component.scss +0 -0
  125. package/lib/template/advanced-search/advanced-search.component.spec.ts +0 -0
  126. package/lib/template/advanced-search/advanced-search.component.ts +112 -0
  127. package/lib/template/advanced-search/advanced-search.service.ts +27 -0
  128. package/lib/template/advanced-search/search-group/persist-utils.ts +56 -0
  129. package/lib/template/advanced-search/search-groups/search-groups.component.html +32 -0
  130. package/lib/template/advanced-search/search-groups/search-groups.component.scss +0 -0
  131. package/lib/template/advanced-search/search-groups/search-groups.component.spec.ts +0 -0
  132. package/lib/template/advanced-search/search-groups/search-groups.component.ts +294 -0
  133. package/lib/template/advanced-search/search-groups/utils.ts +29 -0
  134. package/lib/template/app-shell/app-shell.component.html +4 -1
  135. package/lib/template/app-shell/app-shell.component.scss +0 -3
  136. package/lib/template/app-shell/app-shell.component.ts +46 -8
  137. package/lib/template/banner-page/banner-page.component.ts +0 -1
  138. package/lib/template/case-summary/case-summary.component.scss +0 -2
  139. package/lib/template/case-summary/case-summary.component.ts +6 -22
  140. package/lib/template/case-view/case-view.component.html +4 -4
  141. package/lib/template/case-view/case-view.component.scss +18 -10
  142. package/lib/template/case-view/case-view.component.ts +1 -11
  143. package/lib/template/confirmation/confirmation.component.html +1 -1
  144. package/lib/template/confirmation/confirmation.component.ts +0 -1
  145. package/lib/template/data-reference/data-reference.component.html +11 -8
  146. package/lib/template/data-reference/data-reference.component.ts +346 -113
  147. package/lib/template/data-reference/search-form/search-form.component.html +39 -0
  148. package/lib/template/data-reference/search-form/search-form.component.scss +11 -0
  149. package/lib/template/data-reference/search-form/search-form.component.spec.ts +0 -0
  150. package/lib/template/data-reference/search-form/search-form.component.ts +167 -0
  151. package/lib/template/data-reference/search-form/tabsData.ts +160 -0
  152. package/lib/template/data-reference/utils.ts +92 -0
  153. package/lib/template/default-form/default-form.component.ts +10 -3
  154. package/lib/template/default-page/default-page.component.html +34 -0
  155. package/lib/template/default-page/default-page.component.scss +31 -0
  156. package/lib/template/default-page/default-page.component.spec.ts +24 -0
  157. package/lib/template/default-page/default-page.component.ts +64 -0
  158. package/lib/template/details/details.component.ts +0 -1
  159. package/lib/template/details-narrow-wide/details-narrow-wide.component.ts +0 -1
  160. package/lib/template/details-one-column/details-one-column.component.ts +0 -1
  161. package/lib/template/details-sub-tabs/details-sub-tabs.component.ts +0 -1
  162. package/lib/template/details-three-column/details-three-column.component.ts +0 -1
  163. package/lib/template/details-two-column/details-two-column.component.ts +0 -1
  164. package/lib/template/details-wide-narrow/details-wide-narrow.component.ts +0 -1
  165. package/lib/template/dynamic-tabs/dynamic-tabs.component.ts +0 -1
  166. package/lib/template/field-group-list/field-group-list.component.scss +0 -1
  167. package/lib/template/field-group-list/field-group-list.component.ts +0 -1
  168. package/lib/template/field-group-template/field-group-template.component.ts +14 -28
  169. package/lib/template/field-value-list/field-value-list.component.ts +0 -1
  170. package/lib/template/inline-dashboard/inline-dashboard.component.ts +0 -1
  171. package/lib/template/inline-dashboard-page/inline-dashboard-page.component.ts +1 -2
  172. package/lib/template/list-page/list-page.component.ts +0 -1
  173. package/lib/template/list-view/list-view.component.html +170 -162
  174. package/lib/template/list-view/list-view.component.scss +25 -21
  175. package/lib/template/list-view/list-view.component.ts +207 -119
  176. package/lib/template/list-view/listViewHelpers.ts +1 -4
  177. package/lib/template/list-view/utils.ts +25 -2
  178. package/lib/template/multi-reference-readonly/multi-reference-readonly.component.ts +0 -1
  179. package/lib/template/narrow-wide-form/narrow-wide-form.component.ts +0 -1
  180. package/lib/template/object-page/object-page.component.html +1 -0
  181. package/lib/template/object-page/object-page.component.scss +0 -0
  182. package/lib/template/object-page/object-page.component.spec.ts +22 -0
  183. package/lib/template/object-page/object-page.component.ts +14 -0
  184. package/lib/template/one-column/one-column.component.ts +0 -1
  185. package/lib/template/one-column-page/one-column-page.component.ts +0 -1
  186. package/lib/template/one-column-tab/one-column-tab.component.scss +1 -1
  187. package/lib/template/one-column-tab/one-column-tab.component.ts +0 -1
  188. package/lib/template/page/page.component.ts +0 -1
  189. package/lib/template/promoted-filters/promoted-filters.component.ts +0 -1
  190. package/lib/template/repeating-structures/repeating-structures.component.ts +0 -2
  191. package/lib/template/self-service-case-view/self-service-case-view.component.html +78 -0
  192. package/lib/template/self-service-case-view/self-service-case-view.component.scss +132 -0
  193. package/lib/template/self-service-case-view/self-service-case-view.component.spec.ts +24 -0
  194. package/lib/template/self-service-case-view/self-service-case-view.component.ts +207 -0
  195. package/lib/template/simple-table/simple-table.component.ts +0 -2
  196. package/lib/template/simple-table-manual/helpers.ts +117 -3
  197. package/lib/template/simple-table-manual/simple-table-manual.component.html +4 -4
  198. package/lib/template/simple-table-manual/simple-table-manual.component.scss +4 -14
  199. package/lib/template/simple-table-manual/simple-table-manual.component.ts +45 -25
  200. package/lib/template/simple-table-select/simple-table-select.component.ts +0 -1
  201. package/lib/template/single-reference-readonly/single-reference-readonly.component.html +4 -1
  202. package/lib/template/single-reference-readonly/single-reference-readonly.component.scss +21 -0
  203. package/lib/template/single-reference-readonly/single-reference-readonly.component.ts +104 -4
  204. package/lib/template/sub-tabs/sub-tabs.component.ts +0 -1
  205. package/lib/template/three-column/three-column.component.ts +0 -1
  206. package/lib/template/three-column-page/three-column-page.component.ts +0 -1
  207. package/lib/template/two-column/two-column.component.ts +0 -1
  208. package/lib/template/two-column-page/two-column-page.component.ts +0 -1
  209. package/lib/template/two-column-tab/two-column-tab.component.ts +0 -1
  210. package/lib/template/utils.ts +42 -0
  211. package/lib/template/wide-narrow-form/wide-narrow-form.component.ts +0 -1
  212. package/lib/template/wide-narrow-page/wide-narrow-page.component.ts +0 -1
  213. package/lib/template/wss-nav-bar/wss-nav-bar.component.html +6 -5
  214. package/lib/template/wss-nav-bar/wss-nav-bar.component.scss +8 -17
  215. package/lib/template/wss-nav-bar/wss-nav-bar.component.ts +1 -9
  216. package/lib/widget/app-announcement/app-announcement.component.html +1 -2
  217. package/lib/widget/app-announcement/app-announcement.component.scss +2 -2
  218. package/lib/widget/app-announcement/app-announcement.component.ts +0 -1
  219. package/lib/widget/attachment/Attachment.types.ts +92 -0
  220. package/lib/widget/attachment/AttachmentUtils.ts +287 -0
  221. package/lib/widget/attachment/attachment.component.html +3 -3
  222. package/lib/widget/attachment/attachment.component.scss +9 -12
  223. package/lib/widget/attachment/attachment.component.ts +267 -254
  224. package/lib/widget/case-history/case-history.component.ts +0 -1
  225. package/lib/widget/feed-container/feed-container.component.scss +3 -9
  226. package/lib/widget/feed-container/feed-container.component.ts +2 -3
  227. package/lib/widget/file-utility/file-utility.component.html +3 -3
  228. package/lib/widget/file-utility/file-utility.component.scss +6 -17
  229. package/lib/widget/file-utility/file-utility.component.ts +24 -9
  230. package/lib/widget/list-utility/list-utility.component.scss +4 -5
  231. package/lib/widget/list-utility/list-utility.component.ts +0 -1
  232. package/lib/widget/quick-create/quick-create.component.ts +41 -23
  233. package/lib/widget/todo/todo.component.html +8 -5
  234. package/lib/widget/todo/todo.component.scss +11 -10
  235. package/lib/widget/todo/todo.component.ts +7 -4
  236. package/lib/widget/utility/utility.component.ts +0 -1
  237. package/package.json +1 -1
@@ -1,12 +1,11 @@
1
- import { Component, OnInit, Input, ChangeDetectorRef, forwardRef, OnDestroy } from '@angular/core';
1
+ import { Component, OnInit, forwardRef, OnDestroy } from '@angular/core';
2
2
  import { CommonModule } from '@angular/common';
3
- import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
3
+ import { ReactiveFormsModule } from '@angular/forms';
4
4
  import { MatCheckboxModule } from '@angular/material/checkbox';
5
5
  import { MatFormFieldModule } from '@angular/material/form-field';
6
6
  import { MatOptionModule } from '@angular/material/core';
7
- import { interval } from 'rxjs';
8
- import { AngularPConnectData, AngularPConnectService } from '@pega/angular-sdk-components';
9
- import { Utils } from '@pega/angular-sdk-components';
7
+
8
+ import { FieldBase } from '@pega/angular-sdk-components';
10
9
  import { ComponentMapperComponent } from '@pega/angular-sdk-components';
11
10
  import { PConnFieldProps } from '@pega/angular-sdk-components';
12
11
  import { deleteInstruction, insertInstruction, updateNewInstructions } from '@pega/angular-sdk-components';
@@ -26,38 +25,22 @@ interface CheckboxProps extends Omit<PConnFieldProps, 'value'> {
26
25
  primaryField: string;
27
26
  readonlyContextList: any;
28
27
  referenceList: string;
28
+ variant?: string;
29
+ renderMode: string;
29
30
  }
30
31
 
31
32
  @Component({
32
33
  selector: 'app-check-box',
33
34
  templateUrl: './check-box.component.html',
34
35
  styleUrls: ['./check-box.component.scss'],
35
- standalone: true,
36
36
  imports: [CommonModule, ReactiveFormsModule, MatCheckboxModule, MatFormFieldModule, MatOptionModule, forwardRef(() => ComponentMapperComponent)]
37
37
  })
38
- export class CheckBoxComponent implements OnInit, OnDestroy {
39
- @Input() pConn$: typeof PConnect;
40
- @Input() formGroup$: FormGroup;
41
-
42
- // Used with AngularPConnect
43
- angularPConnectData: AngularPConnectData = {};
38
+ export class CheckBoxComponent extends FieldBase implements OnInit, OnDestroy {
44
39
  configProps$: CheckboxProps;
45
40
 
46
- label$ = '';
47
- value$: any = '';
48
41
  caption$?: string = '';
49
- testId = '';
50
42
  showLabel$ = false;
51
43
  isChecked$ = false;
52
- bRequired$ = false;
53
- bReadonly$ = false;
54
- bDisabled$ = false;
55
- bVisible$ = true;
56
- displayMode$?: string = '';
57
- controlName$: string;
58
- bHasForm$ = true;
59
- componentReference = '';
60
- helperText: string;
61
44
  trueLabel$?: string;
62
45
  falseLabel$?: string;
63
46
 
@@ -69,84 +52,35 @@ export class CheckBoxComponent implements OnInit, OnDestroy {
69
52
  selectedvalues: any;
70
53
  referenceList: string;
71
54
  listOfCheckboxes: any[] = [];
72
- actionsApi: Object;
73
- propName: string;
74
-
75
- fieldControl = new FormControl('', null);
76
-
77
- constructor(
78
- private angularPConnect: AngularPConnectService,
79
- private cdRef: ChangeDetectorRef,
80
- private utils: Utils
81
- ) {}
82
-
83
- ngOnInit(): void {
84
- // First thing in initialization is registering and subscribing to the AngularPConnect service
85
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
86
- this.controlName$ = this.angularPConnect.getComponentID(this);
87
-
88
- // Then, continue on with other initialization
55
+ variant?: string;
89
56
 
90
- // call updateSelf when initializing
91
- // this.updateSelf();
92
- this.checkAndUpdate();
57
+ // Override ngOnInit method
58
+ override ngOnInit(): void {
59
+ super.ngOnInit();
93
60
 
94
- if (this.selectionMode === 'multi' && this.referenceList?.length > 0) {
61
+ if (this.selectionMode === 'multi' && this.referenceList?.length > 0 && !this.bReadonly$) {
95
62
  this.pConn$.setReferenceList(this.selectionList);
96
63
  updateNewInstructions(this.pConn$, this.selectionList);
97
64
  }
98
-
99
- if (this.formGroup$) {
100
- // add control to formGroup
101
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
102
- this.fieldControl.setValue(this.value$);
103
- this.bHasForm$ = true;
104
- } else {
105
- this.bReadonly$ = true;
106
- this.bHasForm$ = false;
107
- }
108
- }
109
-
110
- ngOnDestroy(): void {
111
- if (this.formGroup$) {
112
- this.formGroup$.removeControl(this.controlName$);
113
- }
114
-
115
- if (this.angularPConnectData.unsubscribeFn) {
116
- this.angularPConnectData.unsubscribeFn();
117
- }
118
65
  }
119
66
 
120
- // Callback passed when subscribing to store change
121
- onStateChange() {
122
- this.checkAndUpdate();
123
- }
124
-
125
- checkAndUpdate() {
126
- // Should always check the bridge to see if the component should
127
- // update itself (re-render)
128
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
129
-
130
- // ONLY call updateSelf when the component should update
131
- if (bUpdateSelf) {
132
- this.updateSelf();
133
- }
134
- }
135
-
136
- // updateSelf
137
- updateSelf(): void {
67
+ /**
68
+ * Updates the component when there are changes in the state.
69
+ */
70
+ override updateSelf(): void {
138
71
  // moved this from ngOnInit() and call this from there instead...
139
72
  this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps()) as CheckboxProps;
140
73
 
141
- this.testId = this.configProps$.testId;
142
- this.displayMode$ = this.configProps$.displayMode;
143
- this.label$ = this.configProps$.label;
74
+ // Update component common properties
75
+ this.updateComponentCommonProperties(this.configProps$);
76
+
144
77
  if (this.label$ != '') {
145
78
  this.showLabel$ = true;
146
79
  }
147
-
148
- this.actionsApi = this.pConn$.getActionsApi();
149
- this.propName = this.pConn$.getStateProps().value;
80
+ this.variant = this.configProps$.variant;
81
+ if (this.bReadonly$) {
82
+ this.fieldControl?.disable();
83
+ }
150
84
 
151
85
  // multi case
152
86
  this.selectionMode = this.configProps$.selectionMode;
@@ -155,6 +89,7 @@ export class CheckBoxComponent implements OnInit, OnDestroy {
155
89
  this.selectionList = this.configProps$.selectionList;
156
90
  this.selectedvalues = this.configProps$.readonlyContextList;
157
91
  this.primaryField = this.configProps$.primaryField;
92
+ this.bReadonly$ = this.configProps$.renderMode === 'ReadOnly' || this.displayMode$ === 'DISPLAY_ONLY' || this.configProps$.readOnly;
158
93
 
159
94
  this.datasource = this.configProps$.datasource;
160
95
  this.selectionKey = this.configProps$.selectionKey;
@@ -172,54 +107,10 @@ export class CheckBoxComponent implements OnInit, OnDestroy {
172
107
  }
173
108
 
174
109
  this.caption$ = this.configProps$.caption;
175
- this.helperText = this.configProps$.helperText;
176
110
  this.trueLabel$ = this.configProps$.trueLabel || 'Yes';
177
111
  this.falseLabel$ = this.configProps$.falseLabel || 'No';
178
112
 
179
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
180
- setTimeout(() => {
181
- if (this.configProps$.required != null) {
182
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$.required);
183
- }
184
- this.cdRef.detectChanges();
185
- });
186
-
187
- if (this.configProps$.visibility != null) {
188
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$.visibility);
189
- }
190
-
191
- // disabled
192
- if (this.configProps$.disabled != undefined) {
193
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$.disabled);
194
- }
195
-
196
- if (this.configProps$.readOnly != null) {
197
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$.readOnly);
198
- }
199
-
200
- if (this.bDisabled$ || this.bReadonly$) {
201
- this.fieldControl.disable();
202
- } else {
203
- this.fieldControl.enable();
204
- }
205
-
206
- this.componentReference = this.pConn$.getStateProps().value;
207
-
208
- // eslint-disable-next-line sonarjs/no-redundant-boolean
209
- if (this.value$ === 'true' || this.value$ == true) {
210
- this.isChecked$ = true;
211
- } else {
212
- this.isChecked$ = false;
213
- }
214
- // trigger display of error message with field control
215
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
216
- const timer = interval(100).subscribe(() => {
217
- this.fieldControl.setErrors({ message: true });
218
- this.fieldControl.markAsTouched();
219
-
220
- timer.unsubscribe();
221
- });
222
- }
113
+ this.isChecked$ = this.value$ === 'true' || this.value$ == true;
223
114
  }
224
115
  }
225
116
 
@@ -257,21 +148,4 @@ export class CheckBoxComponent implements OnInit, OnDestroy {
257
148
  context: ''
258
149
  });
259
150
  }
260
-
261
- getErrorMessage() {
262
- let errMessage = '';
263
-
264
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
265
- if (this.fieldControl.hasError('message')) {
266
- errMessage = this.angularPConnectData.validateMessage ?? '';
267
- return errMessage;
268
- }
269
- if (this.fieldControl.hasError('required')) {
270
- errMessage = 'You must enter a value';
271
- } else if (this.fieldControl.errors) {
272
- errMessage = this.fieldControl.errors.toString();
273
- }
274
-
275
- return errMessage;
276
- }
277
151
  }
@@ -1,17 +1,16 @@
1
- import { Component, OnInit, Input, ChangeDetectorRef, forwardRef, OnDestroy } from '@angular/core';
1
+ import { Component, forwardRef } from '@angular/core';
2
2
  import { CommonModule } from '@angular/common';
3
- import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
3
+ import { FormControl, ReactiveFormsModule } from '@angular/forms';
4
4
  import { MatInputModule } from '@angular/material/input';
5
5
  import { MatFormFieldModule } from '@angular/material/form-field';
6
- import { interval } from 'rxjs';
7
6
  import { NgxCurrencyDirective, NgxCurrencyInputMode } from 'ngx-currency';
8
- import { AngularPConnectData, AngularPConnectService } from '@pega/angular-sdk-components';
9
- import { Utils } from '@pega/angular-sdk-components';
7
+
8
+ import { FieldBase } from '@pega/angular-sdk-components';
10
9
  import { ComponentMapperComponent } from '@pega/angular-sdk-components';
11
10
  import { handleEvent } from '@pega/angular-sdk-components';
12
11
  import { getCurrencyCharacters, getCurrencyOptions } from '@pega/angular-sdk-components';
13
- import { PConnFieldProps } from '@pega/angular-sdk-components';
14
12
  import { format } from '@pega/angular-sdk-components';
13
+ import { PConnFieldProps } from '@pega/angular-sdk-components';
15
14
 
16
15
  interface CurrrencyProps extends PConnFieldProps {
17
16
  // If any, enter additional props that only exist on Currency here
@@ -24,176 +23,61 @@ interface CurrrencyProps extends PConnFieldProps {
24
23
  selector: 'app-currency',
25
24
  templateUrl: './currency.component.html',
26
25
  styleUrls: ['./currency.component.scss'],
27
- standalone: true,
28
26
  imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, NgxCurrencyDirective, forwardRef(() => ComponentMapperComponent)]
29
27
  })
30
- export class CurrencyComponent implements OnInit, OnDestroy {
31
- @Input() pConn$: typeof PConnect;
32
- @Input() formGroup$: FormGroup;
33
-
34
- // Used with AngularPConnect
35
- angularPConnectData: AngularPConnectData = {};
28
+ export class CurrencyComponent extends FieldBase {
36
29
  configProps$: CurrrencyProps;
30
+ override fieldControl = new FormControl<number | null>(null, { updateOn: 'blur' });
37
31
 
38
- label$ = '';
39
- value$: any;
40
- bRequired$ = false;
41
- bReadonly$ = false;
42
- bDisabled$ = false;
43
- bVisible$ = true;
44
- displayMode$?: string = '';
45
- controlName$: string;
46
- bHasForm$ = true;
47
- componentReference = '';
48
- testId: string;
49
- helperText: string;
50
- placeholder: string;
51
- currencyISOCode = 'USD';
52
- currencyOptions: Object = {};
53
-
54
- fieldControl = new FormControl<number | null>(null, { updateOn: 'blur' });
32
+ currencyOptions: object = {};
55
33
  currencySymbol: string;
56
34
  thousandSeparator: string;
57
35
  decimalSeparator: string;
58
- inputMode: any;
59
36
  decimalPrecision: number | undefined;
60
37
  formattedValue: string;
61
38
  formatter;
39
+ inputMode = NgxCurrencyInputMode.Natural;
62
40
 
63
- constructor(
64
- private angularPConnect: AngularPConnectService,
65
- private cdRef: ChangeDetectorRef,
66
- private utils: Utils
67
- ) {}
68
-
69
- ngOnInit(): void {
70
- // First thing in initialization is registering and subscribing to the AngularPConnect service
71
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
72
- this.controlName$ = this.angularPConnect.getComponentID(this);
73
-
74
- // Then, continue on with other initialization
41
+ /**
42
+ * Updates the component when there are changes in the state.
43
+ */
44
+ override updateSelf(): void {
45
+ // Resolve configuration properties
46
+ this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps()) as CurrrencyProps;
75
47
 
76
- // call updateSelf when initializing
77
- // this.updateSelf();
78
- this.checkAndUpdate();
48
+ // Update component common properties
49
+ this.updateComponentCommonProperties(this.configProps$);
79
50
 
80
- if (this.formGroup$) {
81
- // add control to formGroup
82
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
51
+ // Extract and normalize the value property
52
+ const { value } = this.configProps$;
53
+ if (value) {
54
+ this.value$ = typeof value === 'string' ? parseFloat(value) : value;
83
55
  this.fieldControl.setValue(this.value$);
84
- this.bHasForm$ = true;
85
- } else {
86
- this.bReadonly$ = true;
87
- this.bHasForm$ = false;
88
- }
89
- }
90
-
91
- ngOnDestroy(): void {
92
- if (this.formGroup$) {
93
- this.formGroup$.removeControl(this.controlName$);
94
- }
95
-
96
- if (this.angularPConnectData.unsubscribeFn) {
97
- this.angularPConnectData.unsubscribeFn();
98
56
  }
99
- }
100
-
101
- // Callback passed when subscribing to store change
102
- onStateChange() {
103
- this.checkAndUpdate();
104
- }
105
-
106
- checkAndUpdate() {
107
- // Should always check the bridge to see if the component should
108
- // update itself (re-render)
109
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
110
57
 
111
- // ONLY call updateSelf when the component should update
112
- if (bUpdateSelf) {
113
- this.updateSelf();
114
- }
58
+ // update currency properties
59
+ this.updateCurrencyProperties(this.configProps$);
115
60
  }
116
61
 
117
- // updateSelf
118
- updateSelf(): void {
119
- // starting very simple...
120
-
121
- // moved this from ngOnInit() and call this from there instead...
122
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps()) as CurrrencyProps;
123
- this.testId = this.configProps$.testId;
124
- this.label$ = this.configProps$.label;
125
- this.displayMode$ = this.configProps$.displayMode;
126
- this.inputMode = NgxCurrencyInputMode.Natural;
127
- let nValue: any = this.configProps$.value;
128
- if (nValue) {
129
- if (typeof nValue === 'string') {
130
- nValue = parseFloat(nValue);
131
- }
132
- this.value$ = nValue;
133
- this.fieldControl.setValue(this.value$);
134
- }
135
- this.helperText = this.configProps$.helperText;
136
- this.placeholder = this.configProps$.placeholder || '';
137
- const currencyISOCode = this.configProps$?.currencyISOCode ?? '';
62
+ /**
63
+ * Updates the currency properties
64
+ *
65
+ * @param {Object} configProps - Configuration properties.
66
+ * @param {boolean} configProps.allowDecimals - Whether to allow decimal values.
67
+ * @param {string} configProps.currencyISOCode - The ISO code of the currency.
68
+ * @param {string} configProps.formatter - The formatter type (e.g., 'currency').
69
+ */
70
+ protected updateCurrencyProperties(configProps): void {
71
+ const { allowDecimals, currencyISOCode = 'USD', formatter } = configProps;
138
72
 
139
73
  const theSymbols = getCurrencyCharacters(currencyISOCode);
140
74
  this.currencySymbol = theSymbols.theCurrencySymbol;
141
75
  this.thousandSeparator = theSymbols.theDigitGroupSeparator;
142
76
  this.decimalSeparator = theSymbols.theDecimalIndicator;
143
- this.formatter = this.configProps$.formatter;
77
+ this.decimalPrecision = allowDecimals ? 2 : 0;
144
78
 
145
- if (this.displayMode$ === 'DISPLAY_ONLY' || this.displayMode$ === 'STACKED_LARGE_VAL') {
146
- const theCurrencyOptions = getCurrencyOptions(currencyISOCode);
147
- if (this.formatter) {
148
- this.formattedValue = format(this.value$, this.formatter.toLowerCase(), theCurrencyOptions);
149
- } else {
150
- this.formattedValue = format(this.value$, 'currency', theCurrencyOptions);
151
- }
152
- }
153
-
154
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
155
- setTimeout(() => {
156
- if (this.configProps$.required != null) {
157
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$.required);
158
- }
159
- this.cdRef.detectChanges();
160
- });
161
-
162
- if (this.configProps$.visibility != null) {
163
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$.visibility);
164
- }
165
-
166
- // disabled
167
- if (this.configProps$.disabled != undefined) {
168
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$.disabled);
169
- }
170
-
171
- if (this.bDisabled$) {
172
- this.fieldControl.disable();
173
- } else {
174
- this.fieldControl.enable();
175
- }
176
-
177
- if (this.configProps$.readOnly != null) {
178
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$.readOnly);
179
- }
180
-
181
- if (this.configProps$.currencyISOCode != null) {
182
- this.currencyISOCode = this.configProps$.currencyISOCode;
183
- }
184
-
185
- this.decimalPrecision = this.configProps$?.allowDecimals ? 2 : 0;
186
-
187
- this.componentReference = this.pConn$.getStateProps().value;
188
-
189
- // trigger display of error message with field control
190
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
191
- const timer = interval(100).subscribe(() => {
192
- this.fieldControl.setErrors({ message: true });
193
- this.fieldControl.markAsTouched();
194
-
195
- timer.unsubscribe();
196
- });
79
+ if (['DISPLAY_ONLY', 'STACKED_LARGE_VAL'].includes(this.displayMode$)) {
80
+ this.formattedValue = format(this.value$, formatter ? formatter.toLowerCase() : 'currency', getCurrencyOptions(currencyISOCode));
197
81
  }
198
82
  }
199
83
 
@@ -218,21 +102,4 @@ export class CurrencyComponent implements OnInit, OnDestroy {
218
102
  handleEvent(actionsApi, 'changeNblur', propName, value);
219
103
  }
220
104
  }
221
-
222
- getErrorMessage() {
223
- let errMessage = '';
224
-
225
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
226
- if (this.fieldControl.hasError('message')) {
227
- errMessage = this.angularPConnectData.validateMessage ?? '';
228
- return errMessage;
229
- }
230
- if (this.fieldControl.hasError('required')) {
231
- errMessage = 'You must enter a value';
232
- } else if (this.fieldControl.errors) {
233
- errMessage = this.fieldControl.errors.toString();
234
- }
235
-
236
- return errMessage;
237
- }
238
105
  }
@@ -11,7 +11,7 @@
11
11
  #dateInput
12
12
  [attr.data-test-id]="testId"
13
13
  [matDatepicker]="pegadate"
14
- [placeholder]="dateFormatInfo.dateFormatStringLC"
14
+ [placeholder]="theDateFormat.dateFormatStringLC"
15
15
  type="text"
16
16
  [value]="value$"
17
17
  [required]="bRequired$"
@@ -20,7 +20,7 @@
20
20
  (dateChange)="fieldOnDateChange($event)"
21
21
  />
22
22
  <mat-datepicker-toggle matSuffix [for]="pegadate" [disabled]="bDisabled$"></mat-datepicker-toggle>
23
- <mat-datepicker #pegadate [startAt]="value$"></mat-datepicker>
23
+ <mat-datepicker #pegadate [startAt]="value$" xPosition="end"></mat-datepicker>
24
24
  <mat-error *ngIf="fieldControl.invalid">{{ getErrorMessage() }}</mat-error>
25
25
  </mat-form-field>
26
26
  </div>