@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,20 +1,19 @@
1
- import { Component, OnInit, Input, ChangeDetectorRef, forwardRef, Inject, 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 { MatDatepickerModule } from '@angular/material/datepicker';
5
5
  import { MatNativeDateModule } from '@angular/material/core';
6
6
  import { MatInputModule } from '@angular/material/input';
7
7
  import { MatFormFieldModule } from '@angular/material/form-field';
8
8
  import { MAT_DATE_FORMATS } from '@angular/material/core';
9
9
  import { MomentDateModule } from '@angular/material-moment-adapter';
10
- import { interval } from 'rxjs';
11
- import { AngularPConnectData, AngularPConnectService } from '@pega/angular-sdk-components';
12
- import { Utils } from '@pega/angular-sdk-components';
10
+
11
+ import { FieldBase } from '@pega/angular-sdk-components';
13
12
  import { ComponentMapperComponent } from '@pega/angular-sdk-components';
14
- import { dateFormatInfoDefault, getDateFormatInfo } from '@pega/angular-sdk-components';
15
- import { PConnFieldProps } from '@pega/angular-sdk-components';
13
+ import { getDateFormatInfo } from '@pega/angular-sdk-components';
16
14
  import { format } from '@pega/angular-sdk-components';
17
15
  import { handleEvent } from '@pega/angular-sdk-components';
16
+ import { PConnFieldProps } from '@pega/angular-sdk-components';
18
17
 
19
18
  interface DateProps extends PConnFieldProps {
20
19
  // If any, enter additional props that only exist on Date here
@@ -43,7 +42,6 @@ class MyFormat {
43
42
  selector: 'app-date',
44
43
  templateUrl: './date.component.html',
45
44
  styleUrls: ['./date.component.scss'],
46
- standalone: true,
47
45
  imports: [
48
46
  CommonModule,
49
47
  ReactiveFormsModule,
@@ -56,153 +54,32 @@ class MyFormat {
56
54
  ],
57
55
  providers: [{ provide: MAT_DATE_FORMATS, useClass: MyFormat }]
58
56
  })
59
- export class DateComponent implements OnInit, OnDestroy {
60
- @Input() pConn$: typeof PConnect;
61
- @Input() formGroup$: FormGroup;
62
-
63
- // Used with AngularPConnect
64
- angularPConnectData: AngularPConnectData = {};
57
+ export class DateComponent extends FieldBase implements OnInit, OnDestroy {
65
58
  configProps$: DateProps;
66
59
 
67
- label$ = '';
68
- value$: any;
69
- bRequired$ = false;
70
- bReadonly$ = false;
71
- bDisabled$ = false;
72
- bVisible$ = true;
73
- displayMode$?: string = '';
74
- controlName$: string;
75
- bHasForm$ = true;
76
- componentReference = '';
77
- testId = '';
78
- helperText: string;
79
- placeholder: string;
80
-
81
- fieldControl = new FormControl('', null);
82
-
83
- // Start with default dateFormatInfo
84
- dateFormatInfo = dateFormatInfoDefault;
85
- // and then update, as needed, based on locale, etc.
86
60
  theDateFormat = getDateFormatInfo();
87
- actionsApi: Object;
88
- propName: string;
89
61
  formattedValue$: any;
90
62
 
91
- constructor(
92
- private angularPConnect: AngularPConnectService,
93
- private cdRef: ChangeDetectorRef,
94
- private utils: Utils,
95
- @Inject(MAT_DATE_FORMATS) private config: MyFormat
96
- ) {}
97
-
98
- ngOnInit(): void {
99
- this.dateFormatInfo = this.theDateFormat;
100
- // First thing in initialization is registering and subscribing to the AngularPConnect service
101
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
102
- this.controlName$ = this.angularPConnect.getComponentID(this);
103
-
104
- // Then, continue on with other initialization
105
- // call updateSelf when initializing
106
- // this.updateSelf();
107
- this.checkAndUpdate();
108
-
109
- if (this.formGroup$) {
110
- // add control to formGroup
111
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
112
- this.fieldControl.setValue(this.value$);
113
- this.bHasForm$ = true;
114
- } else {
115
- this.bReadonly$ = true;
116
- this.bHasForm$ = false;
117
- }
118
- }
119
-
120
- ngOnDestroy(): void {
121
- if (this.formGroup$) {
122
- this.formGroup$.removeControl(this.controlName$);
123
- }
124
-
125
- if (this.angularPConnectData.unsubscribeFn) {
126
- this.angularPConnectData.unsubscribeFn();
127
- }
128
- }
129
-
130
- // Callback passed when subscribing to store change
131
- onStateChange() {
132
- this.checkAndUpdate();
133
- }
134
-
135
- checkAndUpdate() {
136
- // Should always check the bridge to see if the component should
137
- // update itself (re-render)
138
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
139
-
140
- // ONLY call updateSelf when the component should update
141
- if (bUpdateSelf) {
142
- this.updateSelf();
143
- }
144
- }
145
-
146
- // updateSelf
147
- updateSelf(): void {
148
- // starting very simple...
149
- // moved this from ngOnInit() and call this from there instead...
63
+ /**
64
+ * Updates the component when there are changes in the state.
65
+ */
66
+ override updateSelf(): void {
67
+ // Resolve config properties
150
68
  this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps()) as DateProps;
151
69
 
152
- this.value$ = this.configProps$.value;
153
- this.testId = this.configProps$.testId;
154
- this.label$ = this.configProps$.label;
155
- this.displayMode$ = this.configProps$.displayMode;
156
- this.helperText = this.configProps$.helperText;
157
- this.placeholder = this.configProps$.placeholder || '';
158
-
159
- this.actionsApi = this.pConn$.getActionsApi();
160
- this.propName = this.pConn$.getStateProps().value;
161
-
162
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
163
- setTimeout(() => {
164
- if (this.configProps$.required != null) {
165
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$.required);
166
- }
167
- this.cdRef.detectChanges();
168
- });
70
+ // Update component common properties
71
+ this.updateComponentCommonProperties(this.configProps$);
169
72
 
170
- if (this.displayMode$ === 'DISPLAY_ONLY' || this.displayMode$ === 'STACKED_LARGE_VAL') {
73
+ // Extract and normalize the value property
74
+ const { value } = this.configProps$;
75
+ this.value$ = value;
76
+
77
+ // Format value for display modes
78
+ if (['DISPLAY_ONLY', 'STACKED_LARGE_VAL'].includes(this.displayMode$)) {
171
79
  this.formattedValue$ = format(this.value$, 'date', {
172
80
  format: this.theDateFormat.dateFormatString
173
81
  });
174
82
  }
175
-
176
- if (this.configProps$.visibility != null) {
177
- this.bVisible$ = this.utils.getBooleanValue(this.configProps$.visibility);
178
- }
179
-
180
- // disabled
181
- if (this.configProps$.disabled != undefined) {
182
- this.bDisabled$ = this.utils.getBooleanValue(this.configProps$.disabled);
183
- }
184
-
185
- if (this.bDisabled$) {
186
- this.fieldControl.disable();
187
- } else {
188
- this.fieldControl.enable();
189
- }
190
-
191
- if (this.configProps$.readOnly != null) {
192
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$.readOnly);
193
- }
194
-
195
- this.componentReference = this.pConn$.getStateProps().value;
196
-
197
- // trigger display of error message with field control
198
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
199
- const timer = interval(100).subscribe(() => {
200
- this.fieldControl.setErrors({ message: true });
201
- this.fieldControl.markAsTouched();
202
-
203
- timer.unsubscribe();
204
- });
205
- }
206
83
  }
207
84
 
208
85
  fieldOnDateChange(event: any) {
@@ -218,18 +95,20 @@ export class DateComponent implements OnInit, OnDestroy {
218
95
  return this.fieldControl.status === 'INVALID';
219
96
  }
220
97
 
221
- getErrorMessage() {
222
- let errMessage = '';
98
+ override getErrorMessage() {
223
99
  // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
224
100
  if (this.fieldControl.hasError('message')) {
225
- errMessage = this.angularPConnectData.validateMessage ?? '';
226
- return errMessage;
101
+ return this.angularPConnectData.validateMessage ?? '';
227
102
  }
103
+
228
104
  if (this.fieldControl.hasError('required')) {
229
- errMessage = 'You must enter a value';
230
- } else if (this.fieldControl.errors) {
231
- errMessage = `${this.fieldControl.errors['matDatepickerParse'].text} is not a valid date value`;
105
+ return 'You must enter a value';
106
+ }
107
+
108
+ if (this.fieldControl.errors) {
109
+ return `${this.fieldControl.errors['matDatepickerParse'].text} is not a valid date value`;
232
110
  }
233
- return errMessage;
111
+
112
+ return '';
234
113
  }
235
114
  }
@@ -17,7 +17,7 @@
17
17
  [readonly]="bDisabled$"
18
18
  />
19
19
  <mat-datepicker-toggle matSuffix [owlDateTimeTrigger]="dtPicker"></mat-datepicker-toggle>
20
- <owl-date-time #dtPicker [disabled]="bDisabled$"></owl-date-time>
20
+ <owl-date-time #dtPicker [disabled]="bDisabled$" [scrollStrategy]="scrollStrategy"></owl-date-time>
21
21
  <mat-error *ngIf="fieldControl?.invalid">{{ getErrorMessage() }}</mat-error>
22
22
  </mat-form-field>
23
23
  </div>
@@ -1,20 +1,19 @@
1
- import { Component, OnInit, Input, ChangeDetectorRef, forwardRef, OnDestroy } from '@angular/core';
1
+ import { Component, OnInit, forwardRef, OnDestroy, inject } 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 { MatDatepickerModule } from '@angular/material/datepicker';
5
5
  import { MatInputModule } from '@angular/material/input';
6
6
  import { MatFormFieldModule } from '@angular/material/form-field';
7
+ import { ScrollStrategyOptions } from '@angular/cdk/overlay';
7
8
  import { OwlDateTimeModule, OwlNativeDateTimeModule } from '@danielmoncada/angular-datetime-picker';
8
- import { interval } from 'rxjs';
9
9
  import dayjs from 'dayjs';
10
- import { AngularPConnectData, AngularPConnectService } from '@pega/angular-sdk-components';
11
- import { Utils } from '@pega/angular-sdk-components';
10
+
11
+ import { FieldBase } from '@pega/angular-sdk-components';
12
12
  import { ComponentMapperComponent } from '@pega/angular-sdk-components';
13
- import { dateFormatInfoDefault, getDateFormatInfo } from '@pega/angular-sdk-components';
14
- import { PConnFieldProps } from '@pega/angular-sdk-components';
13
+ import { getDateFormatInfo } from '@pega/angular-sdk-components';
15
14
  import { handleEvent } from '@pega/angular-sdk-components';
16
- import { format } from '@pega/angular-sdk-components';
17
15
  import { DateFormatters } from '@pega/angular-sdk-components';
16
+ import { PConnFieldProps } from '@pega/angular-sdk-components';
18
17
 
19
18
  interface DateTimeProps extends PConnFieldProps {
20
19
  // If any, enter additional props that only exist on DateTime here
@@ -24,7 +23,6 @@ interface DateTimeProps extends PConnFieldProps {
24
23
  selector: 'app-date-time',
25
24
  templateUrl: './date-time.component.html',
26
25
  styleUrls: ['./date-time.component.scss'],
27
- standalone: true,
28
26
  imports: [
29
27
  CommonModule,
30
28
  ReactiveFormsModule,
@@ -36,162 +34,64 @@ interface DateTimeProps extends PConnFieldProps {
36
34
  forwardRef(() => ComponentMapperComponent)
37
35
  ]
38
36
  })
39
- export class DateTimeComponent implements OnInit, OnDestroy {
40
- @Input() pConn$: typeof PConnect;
41
- @Input() formGroup$: FormGroup;
42
-
43
- // Used with AngularPConnect
44
- angularPConnectData: AngularPConnectData = {};
37
+ export class DateTimeComponent extends FieldBase implements OnInit, OnDestroy {
45
38
  configProps$: DateTimeProps;
46
39
 
47
- label$ = '';
48
- value$: any;
49
- bRequired$ = false;
50
- bReadonly$ = false;
51
- bDisabled$ = false;
52
- bVisible$ = true;
53
- displayMode$?: string = '';
54
- controlName$: string;
55
- bHasForm$ = true;
56
- componentReference = '';
57
- testId = '';
58
- helperText: string;
59
-
60
- fieldControl = new FormControl('', null);
61
40
  stepHour = 1;
62
41
  stepMinute = 1;
63
42
  stepSecond = 1;
64
43
  public color = 'primary';
65
- // Start with default dateFormatInfo
66
- dateFormatInfo = dateFormatInfoDefault;
67
- // and then update, as needed, based on locale, etc.
68
- theDateFormat = getDateFormatInfo();
69
- placeholder: string;
70
- actionsApi: Object;
71
- propName: string;
72
44
  formattedValue$: any;
45
+ theDateFormat = getDateFormatInfo();
73
46
  timezone = PCore.getEnvironmentInfo()?.getTimeZone();
47
+ override placeholder = `${this.theDateFormat.dateFormatStringLC}, hh:mm A`;
74
48
 
75
- constructor(
76
- private angularPConnect: AngularPConnectService,
77
- private cdRef: ChangeDetectorRef,
78
- private utils: Utils
79
- ) {}
49
+ private sso = inject(ScrollStrategyOptions);
50
+ scrollStrategy = this.sso.reposition();
80
51
 
81
- ngOnInit(): void {
82
- this.placeholder = `${this.theDateFormat.dateFormatStringLC}, hh:mm A`;
83
- // First thing in initialization is registering and subscribing to the AngularPConnect service
84
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
85
- this.controlName$ = this.angularPConnect.getComponentID(this);
86
- // Then, continue on with other initialization
87
- // call updateSelf when initializing
88
- // this.updateSelf();
89
- this.checkAndUpdate();
52
+ override ngOnInit(): void {
53
+ super.ngOnInit();
90
54
 
91
55
  if (this.formGroup$) {
92
- // add control to formGroup
93
- this.formGroup$.addControl(this.controlName$, this.fieldControl);
94
56
  let dateTimeValue = this.value$ ?? '';
95
57
 
96
58
  if (this.value$) {
97
59
  dateTimeValue = dayjs(DateFormatters?.convertToTimezone(this.value$, { timezone: this.timezone }))?.toISOString();
98
60
  }
99
61
  this.fieldControl.setValue(dateTimeValue);
100
- this.bHasForm$ = true;
101
- } else {
102
- this.bReadonly$ = true;
103
- this.bHasForm$ = false;
104
- }
105
- }
106
-
107
- ngOnDestroy(): void {
108
- if (this.formGroup$) {
109
- this.formGroup$.removeControl(this.controlName$);
110
- }
111
- if (this.angularPConnectData.unsubscribeFn) {
112
- this.angularPConnectData.unsubscribeFn();
113
62
  }
114
63
  }
115
64
 
116
- // Callback passed when subscribing to store change
117
- onStateChange() {
118
- this.checkAndUpdate();
119
- }
120
-
121
- checkAndUpdate() {
122
- // Should always check the bridge to see if the component should
123
- // update itself (re-render)
124
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
65
+ /**
66
+ * Updates the component when there are changes in the state.
67
+ */
68
+ override updateSelf(): void {
69
+ // Resolve config properties
70
+ this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps()) as DateTimeProps;
125
71
 
126
- // ONLY call updateSelf when the component should update
127
- if (bUpdateSelf) {
128
- this.updateSelf();
129
- }
130
- }
72
+ // Update component common properties
73
+ this.updateComponentCommonProperties(this.configProps$);
131
74
 
132
- // updateSelf
133
- updateSelf(): void {
134
- // starting very simple...
135
- // moved this from ngOnInit() and call this from there instead...
136
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps()) as DateTimeProps;
75
+ // Extract the value property
76
+ const { value } = this.configProps$;
137
77
 
138
- this.label$ = this.configProps$.label;
139
- this.displayMode$ = this.configProps$.displayMode;
140
- this.testId = this.configProps$.testId;
141
- this.helperText = this.configProps$.helperText;
142
- this.value$ = this.configProps$?.value;
143
- let dateTimeValue = this.configProps$?.value ?? '';
78
+ // Update component properties
79
+ this.value$ = value;
80
+ let dateTimeValue = value ?? '';
144
81
  if (this.value$) {
145
82
  dateTimeValue = dayjs(DateFormatters?.convertToTimezone(this.value$, { timezone: this.timezone }))?.toISOString();
146
83
  }
147
84
  this.fieldControl.setValue(dateTimeValue);
148
- // timeout and detectChanges to avoid ExpressionChangedAfterItHasBeenCheckedError
149
- setTimeout(() => {
150
- if (this.configProps$.required != null) {
151
- this.bRequired$ = this.utils.getBooleanValue(this.configProps$.required);
152
- }
153
- this.cdRef.detectChanges();
154
- });
155
-
156
- if (this.displayMode$ === 'DISPLAY_ONLY' || this.displayMode$ === 'STACKED_LARGE_VAL') {
157
- this.formattedValue$ = format(this.value$, 'datetime', {
158
- format: `${this.theDateFormat.dateFormatString} hh:mm A`
159
- });
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
85
 
177
- if (this.configProps$.readOnly != null) {
178
- this.bReadonly$ = this.utils.getBooleanValue(this.configProps$.readOnly);
86
+ if (['DISPLAY_ONLY', 'STACKED_LARGE_VAL'].includes(this.displayMode$)) {
87
+ this.formattedValue$ = this.generateDateTime(this.value$);
179
88
  }
89
+ }
180
90
 
181
- this.componentReference = this.pConn$.getStateProps().value;
182
-
183
- this.actionsApi = this.pConn$.getActionsApi();
184
- this.propName = this.pConn$.getStateProps().value;
185
-
186
- // trigger display of error message with field control
187
- if (this.angularPConnectData.validateMessage != null && this.angularPConnectData.validateMessage != '') {
188
- const timer = interval(100).subscribe(() => {
189
- this.fieldControl.setErrors({ message: true });
190
- this.fieldControl.markAsTouched();
191
-
192
- timer.unsubscribe();
193
- });
194
- }
91
+ generateDateTime(sVal): string {
92
+ if (!sVal) return '';
93
+ if (sVal.length === 10) return this.utils.generateDate(sVal, 'Date-Long-Custom-YYYY');
94
+ return this.utils.generateDateTime(sVal, 'DateTime-Long-YYYY-Custom');
195
95
  }
196
96
 
197
97
  fieldOnDateChange(event: any) {
@@ -204,19 +104,4 @@ export class DateTimeComponent implements OnInit, OnDestroy {
204
104
  }
205
105
  handleEvent(this.actionsApi, 'changeNblur', this.propName, event.value);
206
106
  }
207
-
208
- getErrorMessage() {
209
- let errMessage = '';
210
- // look for validation messages for json, pre-defined or just an error pushed from workitem (400)
211
- if (this.fieldControl.hasError('message')) {
212
- errMessage = this.angularPConnectData.validateMessage ?? '';
213
- return errMessage;
214
- }
215
- if (this.fieldControl.hasError('required')) {
216
- errMessage = 'You must enter a value';
217
- } else if (this.fieldControl.errors) {
218
- errMessage = this.fieldControl.errors.toString();
219
- }
220
- return errMessage;
221
- }
222
107
  }