@pega/angular-sdk-components 24.2.12 → 25.1.10

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 (248) hide show
  1. package/fesm2022/pega-angular-sdk-components.mjs +4828 -3717
  2. package/fesm2022/pega-angular-sdk-components.mjs.map +1 -1
  3. package/lib/_bridge/angular-pconnect.d.ts +1 -1
  4. package/lib/_bridge/component-mapper/component-mapper.component.d.ts +1 -1
  5. package/lib/_bridge/helpers/sdk-pega-component-map.d.ts +18 -0
  6. package/lib/_components/designSystemExtension/material-case-summary/material-case-summary.component.d.ts +1 -1
  7. package/lib/_components/designSystemExtension/rich-text-editor/rich-text-editor.component.d.ts +1 -0
  8. package/lib/_components/field/auto-complete/auto-complete.component.d.ts +9 -37
  9. package/lib/_components/field/cancel-alert/cancel-alert.component.d.ts +7 -5
  10. package/lib/_components/field/check-box/check-box.component.d.ts +10 -32
  11. package/lib/_components/field/currency/currency.component.d.ts +19 -34
  12. package/lib/_components/field/date/date.component.d.ts +7 -57
  13. package/lib/_components/field/date-time/date-time.component.d.ts +12 -40
  14. package/lib/_components/field/decimal/decimal.component.d.ts +16 -31
  15. package/lib/_components/field/dropdown/dropdown.component.d.ts +13 -37
  16. package/lib/_components/field/email/email.component.d.ts +7 -34
  17. package/lib/_components/field/field.base.d.ts +57 -0
  18. package/lib/_components/field/group/group.component.d.ts +5 -2
  19. package/lib/_components/field/integer/integer.component.d.ts +7 -33
  20. package/lib/_components/field/list-view-action-buttons/list-view-action-buttons.component.d.ts +1 -1
  21. package/lib/_components/field/location/location.component.d.ts +47 -0
  22. package/lib/_components/field/multiselect/multiselect.component.d.ts +7 -38
  23. package/lib/_components/field/object-reference/object-reference.component.d.ts +45 -0
  24. package/lib/_components/field/percentage/percentage.component.d.ts +18 -35
  25. package/lib/_components/field/phone/phone.component.d.ts +8 -31
  26. package/lib/_components/field/radio-buttons/radio-buttons.component.d.ts +13 -33
  27. package/lib/_components/field/rich-text/rich-text.component.d.ts +6 -29
  28. package/lib/_components/field/scalar-list/scalar-list.component.d.ts +6 -21
  29. package/lib/_components/field/selectable-card/selectable-card.component.d.ts +62 -0
  30. package/lib/_components/field/semantic-link/semantic-link.component.d.ts +21 -0
  31. package/lib/_components/field/text-area/text-area.component.d.ts +6 -33
  32. package/lib/_components/field/text-input/text-input.component.d.ts +6 -34
  33. package/lib/_components/field/time/time.component.d.ts +6 -34
  34. package/lib/_components/field/url/url.component.d.ts +6 -34
  35. package/lib/_components/field/user-reference/user-reference.component.d.ts +1 -1
  36. package/lib/_components/infra/Containers/flow-container/flow-container.component.d.ts +1 -0
  37. package/lib/_components/infra/Containers/modal-view-container/modal-view-container.component.d.ts +4 -6
  38. package/lib/_components/infra/action-buttons/action-buttons.component.d.ts +1 -1
  39. package/lib/_components/infra/assignment/assignment.component.d.ts +3 -3
  40. package/lib/_components/infra/assignment-card/assignment-card.component.d.ts +3 -2
  41. package/lib/_components/infra/defer-load/defer-load.component.d.ts +6 -6
  42. package/lib/_components/infra/error-boundary/error-boundary.component.d.ts +1 -1
  43. package/lib/_components/infra/navbar/navbar.component.d.ts +0 -1
  44. package/lib/_components/infra/stages/stages.component.d.ts +2 -1
  45. package/lib/_components/template/advanced-search/advanced-search.component.d.ts +21 -0
  46. package/lib/_components/template/advanced-search/search-group/persist-utils.d.ts +23 -0
  47. package/lib/_components/template/advanced-search/search-groups/search-groups.component.d.ts +47 -0
  48. package/lib/_components/template/advanced-search/search-groups/utils.d.ts +15 -0
  49. package/lib/_components/template/app-shell/app-shell.component.d.ts +6 -2
  50. package/lib/_components/template/base/details-template-base.d.ts +1 -1
  51. package/lib/_components/template/base/form-template-base.d.ts +1 -1
  52. package/lib/_components/template/case-summary/case-summary.component.d.ts +3 -2
  53. package/lib/_components/template/case-view/case-view.component.d.ts +0 -1
  54. package/lib/_components/template/data-reference/data-reference.component.d.ts +27 -2
  55. package/lib/_components/template/data-reference/search-form/search-form.component.d.ts +39 -0
  56. package/lib/_components/template/data-reference/search-form/tabsData.d.ts +2 -0
  57. package/lib/_components/template/data-reference/utils.d.ts +14 -0
  58. package/lib/_components/template/default-form/default-form.component.d.ts +3 -2
  59. package/lib/_components/template/default-page/default-page.component.d.ts +29 -0
  60. package/lib/_components/template/field-group-template/field-group-template.component.d.ts +3 -5
  61. package/lib/_components/template/list-view/list-view.component.d.ts +21 -5
  62. package/lib/_components/template/object-page/object-page.component.d.ts +8 -0
  63. package/lib/_components/template/self-service-case-view/self-service-case-view.component.d.ts +58 -0
  64. package/lib/_components/template/simple-table-manual/helpers.d.ts +15 -1
  65. package/lib/_components/template/simple-table-manual/simple-table-manual.component.d.ts +2 -2
  66. package/lib/_components/template/single-reference-readonly/single-reference-readonly.component.d.ts +18 -2
  67. package/lib/_components/template/utils.d.ts +4 -0
  68. package/lib/_components/template/wss-nav-bar/wss-nav-bar.component.d.ts +3 -5
  69. package/lib/_components/widget/attachment/Attachment.types.d.ts +87 -0
  70. package/lib/_components/widget/attachment/AttachmentUtils.d.ts +17 -0
  71. package/lib/_components/widget/attachment/attachment.component.d.ts +18 -33
  72. package/lib/_components/widget/feed-container/feed-container.component.d.ts +2 -2
  73. package/lib/_components/widget/file-utility/file-utility.component.d.ts +3 -1
  74. package/lib/_components/widget/todo/todo.component.d.ts +4 -2
  75. package/lib/_helpers/field-group-utils.d.ts +1 -3
  76. package/lib/_helpers/filter-utils.d.ts +1 -3
  77. package/lib/_helpers/object-utils.d.ts +8 -0
  78. package/lib/_helpers/objectReference-utils.d.ts +6 -0
  79. package/lib/_helpers/semanticLink-utils.d.ts +9 -0
  80. package/lib/_helpers/tab-utils.d.ts +4 -0
  81. package/lib/_helpers/utils.d.ts +5 -1
  82. package/lib/_services/case.service.d.ts +1 -1
  83. package/lib/_services/data-reference-advanced-search.service.d.ts +9 -0
  84. package/lib/_services/datapage.service.d.ts +1 -1
  85. package/lib/_services/google-maps-loader.service.d.ts +7 -0
  86. package/package.json +20 -6
  87. package/public-api.d.ts +14 -1
  88. package/esm2022/lib/_bridge/angular-pconnect.mjs +0 -428
  89. package/esm2022/lib/_bridge/component-mapper/component-mapper.component.mjs +0 -107
  90. package/esm2022/lib/_bridge/helpers/sdk-pega-component-map.mjs +0 -239
  91. package/esm2022/lib/_bridge/helpers/sdk_component_map.mjs +0 -142
  92. package/esm2022/lib/_components/designSystemExtension/alert/alert.component.mjs +0 -50
  93. package/esm2022/lib/_components/designSystemExtension/alert-banner/alert-banner.component.mjs +0 -29
  94. package/esm2022/lib/_components/designSystemExtension/banner/banner.component.mjs +0 -31
  95. package/esm2022/lib/_components/designSystemExtension/case-create-stage/case-create-stage.component.mjs +0 -51
  96. package/esm2022/lib/_components/designSystemExtension/field-group/field-group.component.mjs +0 -31
  97. package/esm2022/lib/_components/designSystemExtension/material-case-summary/material-case-summary.component.mjs +0 -82
  98. package/esm2022/lib/_components/designSystemExtension/material-details/material-details.component.mjs +0 -37
  99. package/esm2022/lib/_components/designSystemExtension/material-details-fields/material-details-fields.component.mjs +0 -38
  100. package/esm2022/lib/_components/designSystemExtension/material-summary-item/material-summary-item.component.mjs +0 -36
  101. package/esm2022/lib/_components/designSystemExtension/material-summary-list/material-summary-list.component.mjs +0 -25
  102. package/esm2022/lib/_components/designSystemExtension/material-utility/material-utility.component.mjs +0 -28
  103. package/esm2022/lib/_components/designSystemExtension/material-vertical-tabs/material-vertical-tabs.component.mjs +0 -42
  104. package/esm2022/lib/_components/designSystemExtension/operator/operator.component.mjs +0 -145
  105. package/esm2022/lib/_components/designSystemExtension/pulse/pulse.component.mjs +0 -33
  106. package/esm2022/lib/_components/designSystemExtension/rich-text-editor/rich-text-editor.component.mjs +0 -93
  107. package/esm2022/lib/_components/designSystemExtension/wss-quick-create/wss-quick-create.component.mjs +0 -18
  108. package/esm2022/lib/_components/field/auto-complete/auto-complete.component.mjs +0 -296
  109. package/esm2022/lib/_components/field/cancel-alert/cancel-alert.component.mjs +0 -96
  110. package/esm2022/lib/_components/field/check-box/check-box.component.mjs +0 -225
  111. package/esm2022/lib/_components/field/currency/currency.component.mjs +0 -195
  112. package/esm2022/lib/_components/field/date/date.component.mjs +0 -205
  113. package/esm2022/lib/_components/field/date-time/date-time.component.mjs +0 -196
  114. package/esm2022/lib/_components/field/decimal/decimal.component.mjs +0 -205
  115. package/esm2022/lib/_components/field/dropdown/dropdown.component.mjs +0 -300
  116. package/esm2022/lib/_components/field/email/email.component.mjs +0 -165
  117. package/esm2022/lib/_components/field/group/group.component.mjs +0 -64
  118. package/esm2022/lib/_components/field/integer/integer.component.mjs +0 -168
  119. package/esm2022/lib/_components/field/list-view-action-buttons/list-view-action-buttons.component.mjs +0 -45
  120. package/esm2022/lib/_components/field/multiselect/multiselect.component.mjs +0 -314
  121. package/esm2022/lib/_components/field/multiselect/utils.mjs +0 -187
  122. package/esm2022/lib/_components/field/percentage/percentage.component.mjs +0 -190
  123. package/esm2022/lib/_components/field/phone/phone.component.mjs +0 -155
  124. package/esm2022/lib/_components/field/radio-buttons/radio-buttons.component.mjs +0 -182
  125. package/esm2022/lib/_components/field/rich-text/rich-text.component.mjs +0 -109
  126. package/esm2022/lib/_components/field/scalar-list/scalar-list.component.mjs +0 -95
  127. package/esm2022/lib/_components/field/semantic-link/semantic-link.component.mjs +0 -57
  128. package/esm2022/lib/_components/field/text/text.component.mjs +0 -142
  129. package/esm2022/lib/_components/field/text-area/text-area.component.mjs +0 -165
  130. package/esm2022/lib/_components/field/text-content/text-content.component.mjs +0 -69
  131. package/esm2022/lib/_components/field/text-input/text-input.component.mjs +0 -165
  132. package/esm2022/lib/_components/field/time/time.component.mjs +0 -174
  133. package/esm2022/lib/_components/field/url/url.component.mjs +0 -165
  134. package/esm2022/lib/_components/field/user-reference/user-reference.component.mjs +0 -266
  135. package/esm2022/lib/_components/infra/Containers/base-components/flow-container-base.component.mjs +0 -18
  136. package/esm2022/lib/_components/infra/Containers/base-components/helper.mjs +0 -71
  137. package/esm2022/lib/_components/infra/Containers/flow-container/flow-container.component.mjs +0 -461
  138. package/esm2022/lib/_components/infra/Containers/flow-container/helpers.mjs +0 -68
  139. package/esm2022/lib/_components/infra/Containers/hybrid-view-container/hybrid-view-container.component.mjs +0 -24
  140. package/esm2022/lib/_components/infra/Containers/modal-view-container/modal-view-container.component.mjs +0 -335
  141. package/esm2022/lib/_components/infra/Containers/preview-view-container/preview-view-container.component.mjs +0 -32
  142. package/esm2022/lib/_components/infra/Containers/view-container/helper.mjs +0 -22
  143. package/esm2022/lib/_components/infra/Containers/view-container/view-container.component.mjs +0 -211
  144. package/esm2022/lib/_components/infra/action-buttons/action-buttons.component.mjs +0 -31
  145. package/esm2022/lib/_components/infra/assignment/assignment.component.mjs +0 -407
  146. package/esm2022/lib/_components/infra/assignment-card/assignment-card.component.mjs +0 -47
  147. package/esm2022/lib/_components/infra/dashboard-filter/dashboard-filter.component.mjs +0 -87
  148. package/esm2022/lib/_components/infra/defer-load/defer-load.component.mjs +0 -143
  149. package/esm2022/lib/_components/infra/error-boundary/error-boundary.component.mjs +0 -18
  150. package/esm2022/lib/_components/infra/multi-step/multi-step.component.mjs +0 -80
  151. package/esm2022/lib/_components/infra/navbar/navbar.component.mjs +0 -136
  152. package/esm2022/lib/_components/infra/reference/reference.component.mjs +0 -126
  153. package/esm2022/lib/_components/infra/region/region.component.mjs +0 -33
  154. package/esm2022/lib/_components/infra/root-container/root-container.component.mjs +0 -223
  155. package/esm2022/lib/_components/infra/stages/stages.component.mjs +0 -62
  156. package/esm2022/lib/_components/infra/view/view.component.mjs +0 -188
  157. package/esm2022/lib/_components/template/app-shell/app-shell.component.mjs +0 -156
  158. package/esm2022/lib/_components/template/banner-page/banner-page.component.mjs +0 -43
  159. package/esm2022/lib/_components/template/base/details-template-base.mjs +0 -56
  160. package/esm2022/lib/_components/template/base/form-template-base.mjs +0 -16
  161. package/esm2022/lib/_components/template/case-summary/case-summary.component.mjs +0 -101
  162. package/esm2022/lib/_components/template/case-view/case-view.component.mjs +0 -185
  163. package/esm2022/lib/_components/template/confirmation/confirmation.component.mjs +0 -68
  164. package/esm2022/lib/_components/template/data-reference/data-reference.component.mjs +0 -242
  165. package/esm2022/lib/_components/template/default-form/default-form.component.mjs +0 -73
  166. package/esm2022/lib/_components/template/details/details.component.mjs +0 -76
  167. package/esm2022/lib/_components/template/details-narrow-wide/details-narrow-wide.component.mjs +0 -45
  168. package/esm2022/lib/_components/template/details-one-column/details-one-column.component.mjs +0 -42
  169. package/esm2022/lib/_components/template/details-sub-tabs/details-sub-tabs.component.mjs +0 -39
  170. package/esm2022/lib/_components/template/details-three-column/details-three-column.component.mjs +0 -51
  171. package/esm2022/lib/_components/template/details-two-column/details-two-column.component.mjs +0 -48
  172. package/esm2022/lib/_components/template/details-wide-narrow/details-wide-narrow.component.mjs +0 -48
  173. package/esm2022/lib/_components/template/dynamic-tabs/dynamic-tabs.component.mjs +0 -65
  174. package/esm2022/lib/_components/template/field-group-list/field-group-list.component.mjs +0 -23
  175. package/esm2022/lib/_components/template/field-group-template/field-group-template.component.mjs +0 -131
  176. package/esm2022/lib/_components/template/field-value-list/field-value-list.component.mjs +0 -24
  177. package/esm2022/lib/_components/template/inline-dashboard/inline-dashboard.component.mjs +0 -22
  178. package/esm2022/lib/_components/template/inline-dashboard-page/inline-dashboard-page.component.mjs +0 -40
  179. package/esm2022/lib/_components/template/list-page/list-page.component.mjs +0 -14
  180. package/esm2022/lib/_components/template/list-view/DefaultViewMeta.mjs +0 -208
  181. package/esm2022/lib/_components/template/list-view/list-view.component.mjs +0 -1217
  182. package/esm2022/lib/_components/template/list-view/listViewHelpers.mjs +0 -60
  183. package/esm2022/lib/_components/template/list-view/utils.mjs +0 -662
  184. package/esm2022/lib/_components/template/multi-reference-readonly/multi-reference-readonly.component.mjs +0 -44
  185. package/esm2022/lib/_components/template/narrow-wide-form/narrow-wide-form.component.mjs +0 -30
  186. package/esm2022/lib/_components/template/one-column/one-column.component.mjs +0 -31
  187. package/esm2022/lib/_components/template/one-column-page/one-column-page.component.mjs +0 -16
  188. package/esm2022/lib/_components/template/one-column-tab/one-column-tab.component.mjs +0 -30
  189. package/esm2022/lib/_components/template/page/page.component.mjs +0 -52
  190. package/esm2022/lib/_components/template/promoted-filters/promoted-filters.component.mjs +0 -149
  191. package/esm2022/lib/_components/template/repeating-structures/repeating-structures.component.mjs +0 -138
  192. package/esm2022/lib/_components/template/simple-table/simple-table.component.mjs +0 -104
  193. package/esm2022/lib/_components/template/simple-table-manual/helpers.mjs +0 -271
  194. package/esm2022/lib/_components/template/simple-table-manual/simple-table-manual.component.mjs +0 -813
  195. package/esm2022/lib/_components/template/simple-table-select/simple-table-select.component.mjs +0 -129
  196. package/esm2022/lib/_components/template/single-reference-readonly/single-reference-readonly.component.mjs +0 -16
  197. package/esm2022/lib/_components/template/sub-tabs/sub-tabs.component.mjs +0 -67
  198. package/esm2022/lib/_components/template/three-column/three-column.component.mjs +0 -31
  199. package/esm2022/lib/_components/template/three-column-page/three-column-page.component.mjs +0 -16
  200. package/esm2022/lib/_components/template/two-column/two-column.component.mjs +0 -31
  201. package/esm2022/lib/_components/template/two-column-page/two-column-page.component.mjs +0 -40
  202. package/esm2022/lib/_components/template/two-column-tab/two-column-tab.component.mjs +0 -30
  203. package/esm2022/lib/_components/template/utils.mjs +0 -38
  204. package/esm2022/lib/_components/template/wide-narrow-form/wide-narrow-form.component.mjs +0 -31
  205. package/esm2022/lib/_components/template/wide-narrow-page/wide-narrow-page.component.mjs +0 -53
  206. package/esm2022/lib/_components/template/wss-nav-bar/wss-nav-bar.component.mjs +0 -137
  207. package/esm2022/lib/_components/widget/app-announcement/app-announcement.component.mjs +0 -24
  208. package/esm2022/lib/_components/widget/attachment/attachment.component.mjs +0 -393
  209. package/esm2022/lib/_components/widget/case-history/case-history.component.mjs +0 -80
  210. package/esm2022/lib/_components/widget/feed-container/feed-container.component.mjs +0 -521
  211. package/esm2022/lib/_components/widget/file-utility/file-utility.component.mjs +0 -638
  212. package/esm2022/lib/_components/widget/list-utility/list-utility.component.mjs +0 -57
  213. package/esm2022/lib/_components/widget/quick-create/quick-create.component.mjs +0 -75
  214. package/esm2022/lib/_components/widget/todo/todo.component.mjs +0 -230
  215. package/esm2022/lib/_components/widget/utility/utility.component.mjs +0 -34
  216. package/esm2022/lib/_directives/thousand-seperator.directive.mjs +0 -28
  217. package/esm2022/lib/_helpers/case-utils.mjs +0 -71
  218. package/esm2022/lib/_helpers/common.mjs +0 -20
  219. package/esm2022/lib/_helpers/createstage-utils.mjs +0 -15
  220. package/esm2022/lib/_helpers/currency-utils.mjs +0 -57
  221. package/esm2022/lib/_helpers/date-format-utils.mjs +0 -68
  222. package/esm2022/lib/_helpers/event-util.mjs +0 -18
  223. package/esm2022/lib/_helpers/field-group-utils.mjs +0 -47
  224. package/esm2022/lib/_helpers/filter-utils.mjs +0 -105
  225. package/esm2022/lib/_helpers/formatters/boolean.mjs +0 -20
  226. package/esm2022/lib/_helpers/formatters/common.mjs +0 -17
  227. package/esm2022/lib/_helpers/formatters/currency-map.mjs +0 -903
  228. package/esm2022/lib/_helpers/formatters/currency.mjs +0 -68
  229. package/esm2022/lib/_helpers/formatters/date.mjs +0 -69
  230. package/esm2022/lib/_helpers/formatters/format-utils.mjs +0 -76
  231. package/esm2022/lib/_helpers/formatters/index.mjs +0 -124
  232. package/esm2022/lib/_helpers/instructions-utils.mjs +0 -36
  233. package/esm2022/lib/_helpers/tab-utils.mjs +0 -59
  234. package/esm2022/lib/_helpers/template-utils.mjs +0 -56
  235. package/esm2022/lib/_helpers/utils.mjs +0 -412
  236. package/esm2022/lib/_helpers/versionHelpers.mjs +0 -12
  237. package/esm2022/lib/_messages/error-messages.service.mjs +0 -31
  238. package/esm2022/lib/_messages/progress-spinner.service.mjs +0 -30
  239. package/esm2022/lib/_messages/update-worklist.service.mjs +0 -30
  240. package/esm2022/lib/_services/banner.service.mjs +0 -35
  241. package/esm2022/lib/_services/case.service.mjs +0 -32
  242. package/esm2022/lib/_services/datapage.service.mjs +0 -52
  243. package/esm2022/lib/_services/endpoints.mjs +0 -60
  244. package/esm2022/lib/_services/server-config.service.mjs +0 -52
  245. package/esm2022/lib/_types/PConnProps.interface.mjs +0 -2
  246. package/esm2022/pega-angular-sdk-components.mjs +0 -5
  247. package/esm2022/public-api.mjs +0 -145
  248. package/esm2022/sdk-local-component-map.mjs +0 -9
@@ -1,813 +0,0 @@
1
- import { Component, Input, ViewChild, forwardRef } from '@angular/core';
2
- import { CommonModule } from '@angular/common';
3
- import { MatButtonModule } from '@angular/material/button';
4
- import { MatDatepickerModule } from '@angular/material/datepicker';
5
- import { MatFormFieldModule } from '@angular/material/form-field';
6
- import { MatInputModule } from '@angular/material/input';
7
- import { MatMenuModule } from '@angular/material/menu';
8
- import { MatOptionModule } from '@angular/material/core';
9
- import { MatSelectModule } from '@angular/material/select';
10
- import { MatSort, MatSortModule } from '@angular/material/sort';
11
- import { MatTableDataSource, MatTableModule } from '@angular/material/table';
12
- import isEqual from 'fast-deep-equal';
13
- import { ComponentMapperComponent } from '../../../_bridge/component-mapper/component-mapper.component';
14
- import { getReferenceList } from '../../../_helpers/field-group-utils';
15
- import { buildFieldsForTable, filterDataByCommonFields, filterDataByDate, getContext } from './helpers';
16
- import { evaluateAllowRowAction } from '../utils';
17
- import { getSeconds } from '../../../_helpers/common';
18
- import * as i0 from "@angular/core";
19
- import * as i1 from "../../../_bridge/angular-pconnect";
20
- import * as i2 from "../../../_helpers/utils";
21
- import * as i3 from "../../../_services/datapage.service";
22
- import * as i4 from "@angular/common";
23
- import * as i5 from "@angular/material/table";
24
- import * as i6 from "@angular/material/button";
25
- import * as i7 from "@angular/material/sort";
26
- import * as i8 from "@angular/material/menu";
27
- import * as i9 from "@angular/material/form-field";
28
- import * as i10 from "@angular/material/datepicker";
29
- import * as i11 from "@angular/material/core";
30
- import * as i12 from "@angular/material/select";
31
- import * as i13 from "@angular/material/input";
32
- class Group {
33
- constructor() {
34
- this.level = 0;
35
- this.expanded = true;
36
- this.totalCounts = 0;
37
- }
38
- get visible() {
39
- return !this.parent || (this.parent.visible && this.parent.expanded);
40
- }
41
- }
42
- export class SimpleTableManualComponent {
43
- constructor(angularPConnect, utils, dataPageService) {
44
- this.angularPConnect = angularPConnect;
45
- this.utils = utils;
46
- this.dataPageService = dataPageService;
47
- // Used with AngularPConnect
48
- this.angularPConnectData = {};
49
- this.bVisible$ = true;
50
- this.displayedColumns = [];
51
- this.originalData = [];
52
- this.processedFields = [];
53
- this.fieldDefs = [];
54
- this.requestedReadOnlyMode = false;
55
- this.readOnlyMode = false;
56
- this.prevReferenceList = [];
57
- this.label = '';
58
- this.bShowSearch$ = false;
59
- this.bColumnReorder$ = false;
60
- this.bGrouping$ = false;
61
- this.arrowSvgIcon$ = '';
62
- this.groupByColumns$ = [];
63
- this.arrowDirection = 'down';
64
- this.filterByColumns = [];
65
- this.filterContainsLabel$ = '';
66
- this.filterContainsType$ = 'contains';
67
- this.bShowFilterPopover$ = false;
68
- this.bContains$ = true;
69
- this.bDateTime$ = false;
70
- this.bIsDate$ = false;
71
- this.bIsDateTime$ = false;
72
- this.bIsTime$ = false;
73
- this.arFilterMainButtons$ = [];
74
- this.arFilterSecondaryButtons$ = [];
75
- this.allowEditingInModal = false;
76
- this.isInitialized = false;
77
- this.localizedVal = PCore.getLocaleUtils().getLocaleValue;
78
- this.localeCategory = 'SimpleTable';
79
- }
80
- ngOnInit() {
81
- this.elementsData = new MatTableDataSource([]);
82
- this.isInitialized = true;
83
- // First thing in initialization is registering and subscribing to the AngularPConnect service
84
- this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
85
- this.configProps$ = this.pConn$.getConfigProps();
86
- // Then, continue on with other initialization
87
- this.menuIconOverride$ = this.utils.getImageSrc('trash', this.utils.getSDKStaticContentUrl());
88
- // call checkAndUpdate when initializing
89
- this.checkAndUpdate();
90
- this.filterSvgIcon$ = this.utils.getImageSrc('filter', this.utils.getSDKStaticContentUrl());
91
- this.filterOnSvgIcon$ = this.utils.getImageSrc('filter-on', this.utils.getSDKStaticContentUrl());
92
- this.groupBySvgIcon$ = this.utils.getImageSrc('row', this.utils.getSDKStaticContentUrl());
93
- this.bGrouping$ = this.utils.getBooleanValue(this.configProps$.grouping);
94
- this.menuSvgIcon$ = this.utils.getImageSrc('more', this.utils.getSDKStaticContentUrl());
95
- this.arFilterMainButtons$.push({ actionID: 'submit', jsAction: 'submit', name: 'Submit' });
96
- this.arFilterSecondaryButtons$.push({ actionID: 'cancel', jsAction: 'cancel', name: 'Cancel' });
97
- this.searchIcon$ = this.utils.getImageSrc('search', this.utils.getSDKStaticContentUrl());
98
- this.settingsSvgIcon$ = this.utils.getImageSrc('more', this.utils.getSDKStaticContentUrl());
99
- }
100
- ngOnDestroy() {
101
- if (this.angularPConnectData.unsubscribeFn) {
102
- this.angularPConnectData.unsubscribeFn();
103
- }
104
- }
105
- checkAndUpdate() {
106
- // Should always check the bridge to see if the component should
107
- // update itself (re-render)
108
- const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
109
- // ONLY call updateSelf when the component should update
110
- if (bUpdateSelf) {
111
- this.updateSelf();
112
- }
113
- }
114
- // updateSelf
115
- updateSelf() {
116
- // moved this from ngOnInit() and call this from there instead...
117
- this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps());
118
- if (this.configProps$.visibility != null) {
119
- // eslint-disable-next-line no-multi-assign
120
- this.bVisible$ = this.bVisible$ = this.utils.getBooleanValue(this.configProps$.visibility);
121
- }
122
- // NOTE: getConfigProps() has each child.config with datasource and value undefined
123
- // but getRawMetadata() has each child.config with datasource and value showing their unresolved values (ex: "@P thePropName")
124
- // We need to use the prop name as the "glue" to tie the Angular Material table dataSource, displayColumns and data together.
125
- // So, in the code below, we'll use the unresolved config.value (but replacing the space with an underscore to keep things happy)
126
- const rawMetadata = this.pConn$.getRawMetadata();
127
- // Adapted from Nebula
128
- const { referenceList = [], // if referenceList not in configProps$, default to empy list
129
- renderMode, children, // destructure children into an array var: "resolvedFields"
130
- presets, allowActions, allowTableEdit, allowRowDelete, label: labelProp, propertyLabel, fieldMetadata, editMode, addAndEditRowsWithin, viewForAddAndEditModal, editModeConfig, displayMode, useSeparateViewForEdit, viewForEditModal, targetClassLabel } = this.configProps$;
131
- const simpleTableManualProps = {};
132
- if (this.checkIfAllowActionsOrRowEditingExist(allowActions) && editMode) {
133
- simpleTableManualProps.hideAddRow = allowActions?.allowAdd === false;
134
- simpleTableManualProps.hideDeleteRow = allowActions?.allowDelete === false;
135
- simpleTableManualProps.hideEditRow = allowActions?.allowEdit === false;
136
- simpleTableManualProps.disableDragDrop = allowActions?.allowDragDrop === false;
137
- }
138
- else if (allowTableEdit === false) {
139
- simpleTableManualProps.hideAddRow = true;
140
- simpleTableManualProps.hideDeleteRow = true;
141
- simpleTableManualProps.disableDragDrop = true;
142
- }
143
- this.referenceListStr = getContext(this.pConn$).referenceListStr;
144
- this.label = labelProp || propertyLabel;
145
- this.parameters = fieldMetadata?.datasource?.parameters;
146
- this.targetClassLabel = targetClassLabel;
147
- let { contextClass } = this.configProps$;
148
- this.referenceList = referenceList;
149
- if (!contextClass) {
150
- let listName = this.pConn$.getComponentConfig().referenceList;
151
- listName = PCore.getAnnotationUtils().getPropertyName(listName);
152
- contextClass = this.pConn$.getFieldMetadata(listName)?.pageClass;
153
- }
154
- this.contextClass = contextClass;
155
- const resolvedFields = children?.[0]?.children || presets?.[0].children?.[0].children;
156
- // get raw config as @P and other annotations are processed and don't appear in the resolved config.
157
- // Destructure "raw" children into array var: "rawFields"
158
- // NOTE: when config.listType == "associated", the property can be found in either
159
- // config.value (ex: "@P .DeclarantChoice") or
160
- // config.datasource (ex: "@ASSOCIATED .DeclarantChoice")
161
- // Neither of these appear in the resolved (this.configProps$)
162
- const rawConfig = rawMetadata?.config;
163
- const rawFields = rawConfig?.children?.[0]?.children || rawConfig?.presets?.[0].children?.[0]?.children;
164
- this.rawFields = rawFields;
165
- // At this point, fields has resolvedFields and rawFields we can use
166
- // start of from Nebula
167
- // get context name and referenceList which will be used to prepare config of PConnect
168
- // const { contextName, referenceListStr, pageReferenceForRows } = getContext(this.pConn$);
169
- const resolvedList = getReferenceList(this.pConn$);
170
- this.pageReference = `${this.pConn$.getPageReference()}${resolvedList}`;
171
- this.pConn$.setReferenceList(resolvedList);
172
- // This gives up the "properties" we need to map to row/column values later
173
- // const processedData = populateRowKey(referenceList);
174
- this.requestedReadOnlyMode = renderMode === 'ReadOnly';
175
- this.readOnlyMode = renderMode === 'ReadOnly';
176
- this.editableMode = renderMode === 'Editable';
177
- const isDisplayModeEnabled = displayMode === 'DISPLAY_ONLY';
178
- this.showAddRowButton = !this.readOnlyMode && !simpleTableManualProps.hideAddRow;
179
- this.allowEditingInModal =
180
- (editMode ? editMode === 'modal' : addAndEditRowsWithin === 'modal') && !(renderMode === 'ReadOnly' || isDisplayModeEnabled);
181
- const showDeleteButton = this.editableMode && !simpleTableManualProps.hideDeleteRow && evaluateAllowRowAction(allowRowDelete, this.rowData);
182
- this.defaultView = editModeConfig ? editModeConfig.defaultView : viewForAddAndEditModal;
183
- this.bUseSeparateViewForEdit = editModeConfig ? editModeConfig.useSeparateViewForEdit : useSeparateViewForEdit;
184
- this.editView = editModeConfig ? editModeConfig.editView : viewForEditModal;
185
- // const showDeleteButton = !this.readOnlyMode && !hideDeleteRow;
186
- // Nebula has other handling for isReadOnlyMode but has Cosmos-specific code
187
- // so ignoring that for now...
188
- // fieldDefs will be an array where each entry will have a "name" which will be the
189
- // "resolved" property name (that we can use as the colId) though it's not really
190
- // resolved. The buildFieldsForTable helper just removes the "@P " (which is what
191
- // Nebula does). It will also have the "label", and "meta" contains the original,
192
- // unchanged config info. For now, much of the info here is carried over from
193
- // Nebula and we may not end up using it all.
194
- this.fieldDefs = buildFieldsForTable(rawFields, resolvedFields, showDeleteButton);
195
- this.initializeDefaultPageInstructions();
196
- // end of from Nebula
197
- // Here, we use the "name" field in fieldDefs since that has the assoicated property
198
- // (if one exists for the field). If no "name", use "cellRenderer" (typically get DELETE_ICON)
199
- // for our columns.
200
- this.displayedColumns = this.fieldDefs?.map(field => {
201
- return field.name ? field.name : field.cellRenderer;
202
- });
203
- // And now we can process the resolvedFields to add in the "name"
204
- // from from the fieldDefs. This "name" is the value that
205
- // we'll share to connect things together in the table.
206
- this.processedFields = [];
207
- this.processedFields = resolvedFields.map((field, i) => {
208
- field.config.name = this.displayedColumns[i]; // .config["value"].replace(/ ./g,"_"); // replace space dot with underscore
209
- return field;
210
- });
211
- // for adding rows to table when editable and not modal view
212
- if (this.prevReferenceList.length !== this.referenceList.length) {
213
- this.buildElementsForTable();
214
- }
215
- // for edit and adding rows in modal view and to generate readonly list
216
- if (!isEqual(this.prevReferenceList, this.referenceList) && (this.readOnlyMode || this.allowEditingInModal)) {
217
- this.generateRowsData();
218
- }
219
- this.prevReferenceList = this.referenceList;
220
- // These are the data structures referred to in the html file.
221
- // These are the relationships that make the table work
222
- // displayedColumns: key/value pairs where key is order of column and
223
- // value is the property shown in that column. Ex: 1: "FirstName"
224
- // processedFields: key/value pairs where each key is order of column
225
- // and each value is an object of more detailed information about that
226
- // column.
227
- // rowData: array of each row's key/value pairs. Inside each row,
228
- // each key is an entry in displayedColumns: ex: "FirstName": "Charles"
229
- // Ex: { 1: {config: {label: "First Name", readOnly: true: name: "FirstName"}}, type: "TextInput" }
230
- // The "type" indicates the type of component that should be used for editing (when editing is enabled)
231
- //
232
- // Note that the "property" shown in the column ("FirstName" in the above examples) is what
233
- // ties the 3 data structures together.
234
- }
235
- checkIfAllowActionsOrRowEditingExist(newflagobject) {
236
- return (newflagobject && Object.keys(newflagobject).length > 0) || this.pConn$.getComponentConfig().allowRowEdit;
237
- }
238
- initializeDefaultPageInstructions() {
239
- if (this.isInitialized) {
240
- this.isInitialized = false;
241
- if (this.allowEditingInModal) {
242
- this.pConn$.getListActions().initDefaultPageInstructions(this.pConn$.getReferenceList(), this.fieldDefs.filter(item => item.name).map(item => item.name));
243
- }
244
- else {
245
- // @ts-ignore - An argument for 'propertyNames' was not provided.
246
- this.pConn$.getListActions().initDefaultPageInstructions(this.pConn$.getReferenceList());
247
- }
248
- }
249
- }
250
- getResultsText() {
251
- const recordsCount = this.readOnlyMode ? this.rowData?.data.length : this.referenceList?.length;
252
- return `${recordsCount || 0} result${recordsCount > 1 ? 's' : ''}`;
253
- }
254
- sortCompare(a, b) {
255
- let aValue = a[0][this.compareRef];
256
- let bValue = b[0][this.compareRef];
257
- if (this.compareType == 'Date' || this.compareType == 'DateTime') {
258
- aValue = getSeconds(aValue);
259
- bValue = getSeconds(bValue);
260
- }
261
- if (this.compareRef == 'pxRefObjectInsName') {
262
- const result = this.compareByColumnPxRefObjectInsName(aValue, bValue);
263
- if (result !== undefined) {
264
- return result;
265
- }
266
- }
267
- //
268
- switch (this.arrowDirection) {
269
- case 'up':
270
- if (!aValue || aValue < bValue) {
271
- return -1;
272
- }
273
- if (!bValue || aValue > bValue) {
274
- return 1;
275
- }
276
- break;
277
- case 'down':
278
- if (!bValue || aValue > bValue) {
279
- return -1;
280
- }
281
- if (!aValue || aValue < bValue) {
282
- return 1;
283
- }
284
- break;
285
- default:
286
- break;
287
- }
288
- return 0;
289
- }
290
- compareByColumnPxRefObjectInsName(aValue, bValue) {
291
- const prefixX = aValue.split('-');
292
- const prefixY = bValue.split('-');
293
- switch (this.arrowDirection) {
294
- case 'up':
295
- if (prefixX[0] !== prefixY[0]) {
296
- if (prefixX[0] < prefixY[0])
297
- return -1;
298
- if (prefixX[0] > prefixY[0])
299
- return 1;
300
- return 0;
301
- }
302
- return prefixX[1] - prefixY[1];
303
- case 'down':
304
- if (prefixX[0] !== prefixY[0]) {
305
- if (prefixX[0] > prefixY[0])
306
- return -1;
307
- if (prefixX[0] < prefixY[0])
308
- return 1;
309
- return 0;
310
- }
311
- return prefixY[1] - prefixX[1];
312
- default:
313
- break;
314
- }
315
- return undefined;
316
- }
317
- updateFilterDisplay(type) {
318
- switch (type) {
319
- case 'Date':
320
- this.filterContainsType$ = 'notequal';
321
- this.bContains$ = false;
322
- this.bDateTime$ = true;
323
- this.bIsDate$ = true;
324
- this.bIsDateTime$ = false;
325
- this.bIsTime$ = false;
326
- break;
327
- case 'DateTime':
328
- this.filterContainsType$ = 'notequal';
329
- this.bContains$ = false;
330
- this.bDateTime$ = true;
331
- this.bIsDate$ = false;
332
- this.bIsDateTime$ = true;
333
- this.bIsTime$ = false;
334
- break;
335
- case 'Time':
336
- this.filterContainsType$ = 'notequal';
337
- this.bContains$ = false;
338
- this.bDateTime$ = true;
339
- this.bIsDate$ = false;
340
- this.bIsDateTime$ = false;
341
- this.bIsTime$ = true;
342
- break;
343
- default:
344
- this.filterContainsType$ = 'contains';
345
- this.bContains$ = true;
346
- this.bDateTime$ = false;
347
- this.bIsDate$ = false;
348
- this.bIsDateTime$ = false;
349
- this.bIsTime$ = false;
350
- break;
351
- }
352
- }
353
- _filter(event, columnData) {
354
- // add clickAway listener
355
- window.addEventListener('mouseup', this._clickAway.bind(this));
356
- this.currentFilterRefData = columnData;
357
- this.filterContainsLabel$ = columnData.config.label;
358
- setTimeout(() => {
359
- this.updateFilterDisplay(columnData.type);
360
- this.updateFilterVarsWithCurrent(columnData);
361
- this.bShowFilterPopover$ = true;
362
- });
363
- }
364
- _clickAway(event) {
365
- let bInPopUp = false;
366
- // run through list of elements in path, if menu not in th path, then want to
367
- // hide (toggle) the menu
368
- const eventPath = event.path;
369
- if (eventPath) {
370
- for (let eventIndex = 0; eventIndex < eventPath.length; eventIndex++) {
371
- if (eventPath[eventIndex].className == 'psdk-modal-file-top' ||
372
- eventPath[eventIndex].tagName == 'BUTTON' ||
373
- eventPath[eventIndex].tagName == 'MAT-OPTION' ||
374
- eventPath[eventIndex].tagName == 'MAT-INPUT') {
375
- bInPopUp = true;
376
- break;
377
- }
378
- }
379
- }
380
- if (!bInPopUp) {
381
- // this.bShowFilterPopover$ = false;
382
- window.removeEventListener('mouseup', this._clickAway.bind(this));
383
- }
384
- }
385
- _filterContainsType(event) {
386
- this.filterContainsType$ = event.value;
387
- }
388
- _filterContainsValue(event) {
389
- this.filterContainsValue$ = event.target.value;
390
- }
391
- _filterContainsDateValue(event, value) {
392
- this.filterContainsValue$ = value;
393
- }
394
- _filterContainsDateTimeValue(event) {
395
- this.filterContainsValue$ = event.target.value;
396
- }
397
- _filterContainsTimeValue(event) {
398
- this.filterContainsValue$ = event.target.value;
399
- }
400
- _onFilterActionButtonClick(event) {
401
- // modal buttons
402
- switch (event.action) {
403
- case 'cancel':
404
- this.currentFilterRefData = [];
405
- break;
406
- case 'submit':
407
- this.updateFilterWithInfo();
408
- this.filterSortGroupBy();
409
- break;
410
- default:
411
- break;
412
- }
413
- this.bShowFilterPopover$ = false;
414
- window.removeEventListener('mouseup', this._clickAway.bind(this));
415
- }
416
- updateFilterWithInfo() {
417
- let bFound = false;
418
- for (const filterObj of this.filterByColumns) {
419
- if (filterObj.ref === this.currentFilterRefData.config.name) {
420
- filterObj.type = this.currentFilterRefData.type;
421
- filterObj.containsFilter = this.filterContainsType$;
422
- filterObj.containsFilterValue = this.filterContainsValue$;
423
- bFound = true;
424
- break;
425
- }
426
- }
427
- if (!bFound) {
428
- // add in
429
- const filterObj = {};
430
- filterObj.ref = this.currentFilterRefData.config.name;
431
- filterObj.type = this.currentFilterRefData.type;
432
- filterObj.containsFilter = this.filterContainsType$;
433
- filterObj.containsFilterValue = this.filterContainsValue$;
434
- this.filterByColumns.push(filterObj);
435
- }
436
- // iterate through filters and update filterOn icon
437
- for (const filterObj of this.filterByColumns) {
438
- const containsFilterValue = filterObj.containsFilterValue;
439
- const containsFilter = filterObj.containsFilter;
440
- const filterRef = filterObj.ref;
441
- const filterIndex = this.displayedColumns.indexOf(filterRef);
442
- const arFilterImg = document.getElementsByName('filterOnIcon');
443
- const filterImg = arFilterImg[filterIndex];
444
- if (containsFilterValue == '' && containsFilter != 'null' && containsFilter != 'notnull') {
445
- // clear icon
446
- filterImg.src = '';
447
- }
448
- else {
449
- // show icon
450
- filterImg.src = this.filterOnSvgIcon$;
451
- }
452
- }
453
- }
454
- updateFilterVarsWithCurrent(columnData) {
455
- // find current ref, if exists, move data to variable to display
456
- let bFound = false;
457
- for (const filterObj of this.filterByColumns) {
458
- if (filterObj.ref === this.currentFilterRefData.config.name) {
459
- this.filterContainsType$ = filterObj.containsFilter;
460
- this.filterContainsValue$ = filterObj.containsFilterValue;
461
- bFound = true;
462
- break;
463
- }
464
- }
465
- if (!bFound) {
466
- switch (columnData.type) {
467
- case 'Date':
468
- case 'DateTime':
469
- case 'Time':
470
- this.filterContainsType$ = 'notequal';
471
- break;
472
- default:
473
- this.filterContainsType$ = 'contains';
474
- break;
475
- }
476
- this.filterContainsValue$ = '';
477
- }
478
- }
479
- filterData(element) {
480
- const item = element[0];
481
- let bKeep = true;
482
- for (const filterObj of this.filterByColumns) {
483
- if (filterObj.containsFilterValue != '' || filterObj.containsFilter == 'null' || filterObj.containsFilter == 'notnull') {
484
- switch (filterObj.type) {
485
- case 'Date':
486
- case 'DateTime':
487
- case 'Time':
488
- bKeep = filterDataByDate(item, filterObj);
489
- break;
490
- default:
491
- bKeep = filterDataByCommonFields(item, filterObj);
492
- break;
493
- }
494
- }
495
- else if (filterObj.containsFilterValue === '') {
496
- bKeep = true;
497
- }
498
- // if don't keep stop filtering
499
- if (!bKeep) {
500
- break;
501
- }
502
- }
503
- return bKeep;
504
- }
505
- filterSortGroupBy() {
506
- let theData = this.originalData.slice().map((item, index) => {
507
- return [item, index];
508
- });
509
- // last filter config data is global
510
- theData = theData.filter(this.filterData.bind(this));
511
- // last sort config data is global
512
- theData.sort(this.sortCompare.bind(this));
513
- this.rowData.data = theData.map(item => item[0]);
514
- const newElements = new Array(this.rowData.data.length);
515
- theData.forEach((item, index) => {
516
- newElements[index] = this.originalElementsData[item[1]];
517
- });
518
- this.elementsData = newElements;
519
- }
520
- _headerSortClick(event, columnData) {
521
- // images 0 - filter, 1 - arrow, 2 - more
522
- /** Commenting this code for now as it is giving errors not sure if it ever worked */
523
- // let arrowImage = event.srcElement.getElementsByTagName('img')[1];
524
- // let arrowAttr = arrowImage.getAttribute('arrow');
525
- // this.clearOutArrows(event, columnData);
526
- // switch (arrowAttr) {
527
- // case 'up':
528
- // arrowImage.src = this.arrowDownSvgIcon$;
529
- // arrowImage.setAttribute('arrow', 'down');
530
- // break;
531
- // case 'down':
532
- // arrowImage.src = '';
533
- // arrowImage.setAttribute('arrow', 'none');
534
- // break;
535
- // default:
536
- // arrowImage.src = this.arrowUpSvgIcon$;
537
- // arrowImage.setAttribute('arrow', 'up');
538
- // break;
539
- // }
540
- this.compareType = columnData.type;
541
- this.compareRef = columnData.config.name;
542
- // this.arrowDirection = arrowImage.getAttribute('arrow');
543
- this.arrowDirection = this.arrowDirection === 'up' ? 'down' : 'up';
544
- this.filterSortGroupBy();
545
- }
546
- _showUnGroupBy(columnData) {
547
- for (const val of this.groupByColumns$) {
548
- if (val == columnData.config.name) {
549
- return true;
550
- }
551
- }
552
- return false;
553
- }
554
- _groupBy(event, columnData) {
555
- this.checkGroupByColumn(columnData.config.name, true);
556
- this.filterSortGroupBy();
557
- }
558
- _unGroupBy(event, columnData) {
559
- // event.stopPropagation();
560
- this.checkGroupByColumn(columnData.config.name, false);
561
- this.filterSortGroupBy();
562
- }
563
- checkGroupByColumn(field, add) {
564
- let found = null;
565
- for (const column of this.groupByColumns$) {
566
- if (column === field) {
567
- found = this.groupByColumns$.indexOf(column, 0);
568
- }
569
- }
570
- if (found != null && found >= 0) {
571
- if (!add) {
572
- this.groupByColumns$.splice(found, 1);
573
- }
574
- }
575
- else if (add) {
576
- this.groupByColumns$.push(field);
577
- }
578
- }
579
- _getGroupName(fieldName) {
580
- for (let fieldIndex = 0; fieldIndex < this.fields$.length; fieldIndex++) {
581
- const field = this.fields$[fieldIndex];
582
- if (field.config.name == fieldName) {
583
- return field.config.label;
584
- }
585
- }
586
- return '';
587
- }
588
- addGroups(data, groupByColumns) {
589
- const rootGroup = new Group();
590
- rootGroup.expanded = true;
591
- return this.getSublevel(data, 0, groupByColumns, rootGroup);
592
- }
593
- getSublevel(data, level, groupByColumns, parent) {
594
- if (level >= groupByColumns.length) {
595
- return data;
596
- }
597
- const groups = this.uniqueBy(data.map(row => {
598
- const result = new Group();
599
- result.level = level + 1;
600
- result.parent = parent;
601
- for (let i = 0; i <= level; i++) {
602
- result[groupByColumns[i]] = row[groupByColumns[i]];
603
- }
604
- return result;
605
- }), JSON.stringify);
606
- const currentColumn = groupByColumns[level];
607
- let subGroups = [];
608
- groups.forEach(group => {
609
- const rowsInGroup = data.filter(row => group[currentColumn] === row[currentColumn]);
610
- group.totalCounts = rowsInGroup.length;
611
- const subGroup = this.getSublevel(rowsInGroup, level + 1, groupByColumns, group);
612
- subGroup.unshift(group);
613
- subGroups = subGroups.concat(subGroup);
614
- });
615
- return subGroups;
616
- }
617
- uniqueBy(a, key) {
618
- const seen = {};
619
- return a.filter(item => {
620
- const k = key(item);
621
- // eslint-disable-next-line no-return-assign, no-prototype-builtins
622
- return seen.hasOwnProperty(k) ? false : (seen[k] = true);
623
- });
624
- }
625
- isGroup(index, item) {
626
- return item.level;
627
- }
628
- _groupHeaderClick(row) {
629
- row.expanded = !row.expanded;
630
- // this.repeatList$.filter = "";
631
- this.perfFilter = performance.now().toString();
632
- this.rowData.filter = this.perfFilter;
633
- }
634
- // below is for grid row grouping
635
- customFilterPredicate(data, filter) {
636
- return data instanceof Group ? data.visible : this.getDataRowVisibleWithFilter(data, filter);
637
- }
638
- getDataRowVisible(data) {
639
- const groupRows = this.rowData.data.filter(row => {
640
- if (!(row instanceof Group)) {
641
- return false;
642
- }
643
- let match = true;
644
- this.groupByColumns$.forEach(column => {
645
- if (!row[column] || !data[column] || row[column] !== data[column]) {
646
- match = false;
647
- }
648
- });
649
- return match;
650
- });
651
- if (groupRows.length === 0) {
652
- return true;
653
- }
654
- const parent = groupRows[0];
655
- return parent.visible && parent.expanded;
656
- }
657
- getDataRowVisibleWithFilter(data, filter) {
658
- // fist check if row is visible with grouping
659
- let bVisible = this.getDataRowVisible(data);
660
- if (bVisible && filter && filter != '' && filter != this.perfFilter) {
661
- // now check if row is filtered.
662
- // assume not there unless we find it
663
- bVisible = false;
664
- for (const col of this.displayedColumns) {
665
- // filter is lower case
666
- if (data[col] && data[col].toString().toLowerCase().indexOf(filter) >= 0) {
667
- bVisible = true;
668
- break;
669
- }
670
- }
671
- }
672
- return bVisible;
673
- }
674
- getDisplayColumns(fields = []) {
675
- return fields.map((field) => {
676
- let theField = field.config.value.substring(field.config.value.indexOf(' ') + 1);
677
- if (theField.indexOf('.') == 0) {
678
- theField = theField.substring(1);
679
- }
680
- return theField;
681
- });
682
- }
683
- _getIconStyle(level) {
684
- let sReturn = '';
685
- let nLevel = parseInt(level, 10);
686
- nLevel--;
687
- nLevel *= 15;
688
- sReturn = `padding-left: ${nLevel}px; vertical-align: middle`;
689
- return sReturn;
690
- }
691
- // Callback passed when subscribing to store change
692
- onStateChange() {
693
- this.checkAndUpdate();
694
- }
695
- // return the value that should be shown as the contents for the given row data
696
- // of the given row field
697
- getRowValue(inRowData, inColKey) {
698
- // See what data (if any) we have to display
699
- const refKeys = inColKey.split('.');
700
- let valBuilder = inRowData;
701
- for (const key of refKeys) {
702
- valBuilder = valBuilder[key];
703
- }
704
- return valBuilder;
705
- }
706
- generateRowsData() {
707
- const { dataPageName, referenceList } = this.configProps$;
708
- const context = this.pConn$.getContextName();
709
- // if dataPageName property value exists then make a datapage fetch call and get the list of data.
710
- if (dataPageName) {
711
- this.dataPageService.getDataPageData(dataPageName, this.parameters, context).then(listData => {
712
- const data = this.formatRowsData(listData);
713
- this.originalData = data;
714
- this.rowData = new MatTableDataSource(data);
715
- });
716
- }
717
- else {
718
- // The referenceList prop has the JSON data for each row to be displayed
719
- // in the table. So, iterate over referenceList to create the dataRows that
720
- // we're using as the table's dataSource
721
- const data = this.formatRowsData(referenceList);
722
- this.originalData = data;
723
- this.rowData = new MatTableDataSource(data);
724
- }
725
- }
726
- formatRowsData(data) {
727
- return data?.map(item => {
728
- return this.displayedColumns.reduce((dataForRow, colKey) => {
729
- dataForRow[colKey] = this.getRowValue(item, colKey);
730
- return dataForRow;
731
- }, {});
732
- });
733
- }
734
- addRecord() {
735
- if (this.allowEditingInModal && this.defaultView) {
736
- this.pConn$
737
- .getActionsApi()
738
- .openEmbeddedDataModal(this.defaultView, this.pConn$, this.referenceListStr, this.referenceList.length, PCore.getConstants().RESOURCE_STATUS.CREATE, this.targetClassLabel);
739
- }
740
- else {
741
- this.pConn$.getListActions().insert({ classID: this.contextClass }, this.referenceList.length);
742
- }
743
- this.pConn$.clearErrorMessages({
744
- property: this.pConn$.getStateProps()?.referenceList?.substring(1)
745
- });
746
- }
747
- editRecord(data, index) {
748
- if (data) {
749
- this.pConn$
750
- .getActionsApi()
751
- .openEmbeddedDataModal(this.bUseSeparateViewForEdit ? this.editView : this.defaultView, this.pConn$, this.referenceListStr, index, PCore.getConstants().RESOURCE_STATUS.UPDATE, this.targetClassLabel);
752
- }
753
- }
754
- deleteRecord(index) {
755
- this.pConn$.getListActions().deleteEntry(index);
756
- }
757
- buildElementsForTable() {
758
- const context = this.pConn$.getContextName();
759
- const eleData = [];
760
- this.referenceList.forEach((element, index) => {
761
- const data = [];
762
- this.rawFields?.forEach(item => {
763
- item = {
764
- ...item,
765
- config: { ...item.config, label: '', displayMode: this.readOnlyMode || this.allowEditingInModal ? 'DISPLAY_ONLY' : undefined }
766
- };
767
- const referenceListData = getReferenceList(this.pConn$);
768
- const isDatapage = referenceListData.startsWith('D_');
769
- const pageReferenceValue = isDatapage ? `${referenceListData}[${index}]` : `${this.pConn$.getPageReference()}${referenceListData}[${index}]`;
770
- const config = {
771
- meta: item,
772
- options: {
773
- context,
774
- pageReference: pageReferenceValue,
775
- referenceList: referenceListData,
776
- hasForm: true
777
- }
778
- };
779
- const view = PCore.createPConnect(config);
780
- data.push(view);
781
- });
782
- eleData.push(data);
783
- });
784
- this.originalElementsData = eleData;
785
- this.elementsData = eleData;
786
- }
787
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SimpleTableManualComponent, deps: [{ token: i1.AngularPConnectService }, { token: i2.Utils }, { token: i3.DatapageService }], target: i0.ɵɵFactoryTarget.Component }); }
788
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: SimpleTableManualComponent, isStandalone: true, selector: "app-simple-table-manual", inputs: { pConn$: "pConn$", formGroup$: "formGroup$" }, viewQueries: [{ propertyName: "sort", first: true, predicate: MatSort, descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"bVisible$\">\n <div class=\"simple-table-wrapper\">\n <h3 *ngIf=\"label\" className=\"label\" style=\"font-weight: bold\">\n {{ label }} <span class=\"results-count\">{{ getResultsText() }}</span>\n </h3>\n <table *ngIf=\"readOnlyMode || allowEditingInModal\" mat-table [dataSource]=\"elementsData\" class=\"mat-elevation-z8\" id=\"readonly-table\" matSort>\n <ng-container *ngFor=\"let dCol of processedFields; let i = index\" [matColumnDef]=\"dCol.config.name\">\n <th mat-header-cell *matHeaderCellDef mat-sort-header (click)=\"_headerSortClick($event, dCol)\" arrowPosition=\"before\">\n <div>{{ dCol.config.label }}</div>\n <div class=\"psdk-mat-header-filter\">\n <img class=\"psdk-filter-svg-icon\" name=\"filterOnIcon\" />\n </div>\n <div (click)=\"$event.stopPropagation()\">\n <button mat-icon-button [matMenuTriggerFor]=\"groupMenu\">\n <img class=\"psdk-list-view-svg-icon\" src=\"{{ menuSvgIcon$ }}\" />\n </button>\n <mat-menu #groupMenu>\n <button mat-menu-item (click)=\"_groupBy($event, dCol)\">\n <img class=\"psdk-list-view-svg-icon\" src=\"{{ groupBySvgIcon$ }}\" /><span>Group By</span>\n </button>\n <button *ngIf=\"_showUnGroupBy(dCol) && bGrouping$\" mat-menu-item (click)=\"_unGroupBy($event, dCol)\">\n <img class=\"psdk-list-view-svg-icon\" src=\"{{ groupBySvgIcon$ }}\" /><span>Ungroup</span>\n </button>\n <button mat-menu-item (click)=\"_filter($event, dCol)\">\n <img class=\"psdk-list-view-svg-icon\" src=\"{{ filterSvgIcon$ }}\" /><span>Filter</span>\n </button>\n </mat-menu>\n </div>\n </th>\n <td mat-cell *matCellDef=\"let element\">\n <component-mapper\n [name]=\"element[i].getPConnect().getComponentName()\"\n [props]=\"{\n pConn$: element[i].getPConnect(),\n formGroup$: formGroup$\n }\"\n errorMsg=\"Table wants component not yet available: {{ element[i].getPConnect().getComponentName() }}\"\n ></component-mapper>\n </td>\n </ng-container>\n <ng-container matColumnDef=\"DeleteIcon\">\n <div *ngIf=\"allowEditingInModal\">\n <th mat-header-cell *matHeaderCellDef></th>\n <td mat-cell *matCellDef=\"let element; index as j\">\n <div class=\"header-icon\">\n <button mat-icon-button [matMenuTriggerFor]=\"utilityMenu\">\n <img class=\"psdk-utility-card-actions-svg-icon\" src=\"{{ settingsSvgIcon$ }}\" />\n </button>\n <mat-menu #utilityMenu=\"matMenu\" overlapTrigger=\"false\">\n <button mat-menu-item (click)=\"editRecord(element, j)\">Edit</button>\n <button mat-menu-item (click)=\"deleteRecord(j)\">Delete</button>\n </mat-menu>\n </div>\n </td>\n </div>\n </ng-container>\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns\"></tr>\n <tr class=\"mat-row psdk-no-records\" *matNoDataRow>\n <td id=\"no-records\" class=\"mat-cell\" [attr.colspan]=\"displayedColumns.length\">\n {{ utils.getGenericFieldsLocalizedValue('CosmosFields.fields.lists', 'No records found.') }}\n </td>\n </tr>\n </table>\n <table *ngIf=\"editableMode && !allowEditingInModal\" mat-table [dataSource]=\"elementsData\" class=\"mat-elevation-z8\" id=\"editable-table\">\n <ng-container *ngFor=\"let dCol of fieldDefs; let i = index\">\n <ng-container *ngIf=\"dCol.name != 'DeleteIcon'\" [matColumnDef]=\"dCol.name\">\n <th mat-header-cell *matHeaderCellDef class=\"psdk-mat-header\">{{ dCol.label }}</th>\n <td mat-cell *matCellDef=\"let element\">\n <component-mapper\n [name]=\"element[i].getPConnect().getComponentName()\"\n [props]=\"{\n pConn$: element[i].getPConnect(),\n formGroup$: formGroup$\n }\"\n errorMsg=\"Table wants component not yet available: {{ element[i].getPConnect().getComponentName() }}\"\n ></component-mapper>\n </td>\n </ng-container>\n </ng-container>\n <ng-container matColumnDef=\"DeleteIcon\">\n <th mat-header-cell *matHeaderCellDef></th>\n <td mat-cell *matCellDef=\"let element; index as j\">\n <button id=\"delete-button\" mat-icon-button (click)=\"deleteRecord(j)\">\n <img class=\"psdk-utility-card-action-svg-icon\" src=\"{{ menuIconOverride$ }}\" />\n </button>\n </td>\n </ng-container>\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns\"></tr>\n <tr class=\"mat-row psdk-no-records\" *matNoDataRow>\n <td id=\"no-records\" class=\"mat-cell\" [attr.colspan]=\"displayedColumns.length\">\n {{ utils.getGenericFieldsLocalizedValue('CosmosFields.fields.lists', 'No records found.') }}\n </td>\n </tr>\n </table>\n </div>\n <button *ngIf=\"showAddRowButton\" mat-button color=\"primary\" style=\"font-size: 16px\" (click)=\"addRecord()\">\n + {{ localizedVal('Add', localeCategory) }}\n </button>\n</ng-container>\n\n<!-- pop overs for filters-->\n<div *ngIf=\"bShowFilterPopover$\" class=\"psdk-dialog-background\">\n <div class=\"psdk-modal-file-top\">\n <h4>\n Filter:<b> {{ filterContainsLabel$ }}</b>\n </h4>\n <div *ngIf=\"bContains$\">\n <mat-form-field class=\"psdk-full-width\">\n <mat-select [value]=\"filterContainsType$\" (selectionChange)=\"_filterContainsType($event)\">\n <mat-option value=\"contains\">Contains</mat-option>\n <mat-option value=\"equals\">Equals</mat-option>\n <mat-option value=\"startswith\">Starts with</mat-option>\n </mat-select>\n </mat-form-field>\n\n <mat-form-field class=\"psdk-full-width\">\n <input matInput type=\"text\" [value]=\"filterContainsValue$\" (change)=\"_filterContainsValue($event)\" />\n </mat-form-field>\n </div>\n\n <div *ngIf=\"bDateTime$\">\n <mat-form-field class=\"psdk-full-width\">\n <mat-select [value]=\"filterContainsType$\" (selectionChange)=\"_filterContainsType($event)\">\n <mat-option value=\"notequal\">is not equal to</mat-option>\n <mat-option value=\"after\">after</mat-option>\n <mat-option value=\"before\">before</mat-option>\n <mat-option value=\"null\">is null</mat-option>\n <mat-option value=\"notnull\">is not null</mat-option>\n </mat-select>\n </mat-form-field>\n\n <mat-form-field *ngIf=\"bIsDate$ && filterContainsType$ !== 'null' && filterContainsType$ != 'notnull'\" class=\"psdk-full-width\">\n <mat-label>Date</mat-label>\n <input\n matInput\n #dateInput\n [matDatepicker]=\"pegadate\"\n type=\"text\"\n [value]=\"filterContainsValue$\"\n (dateChange)=\"_filterContainsDateValue($event, dateInput.value)\"\n />\n <mat-datepicker-toggle matSuffix [for]=\"pegadate\"></mat-datepicker-toggle>\n <mat-datepicker #pegadate [startAt]=\"filterContainsValue$\"></mat-datepicker>\n </mat-form-field>\n\n <mat-form-field *ngIf=\"bIsDateTime$ && filterContainsType$ !== 'null' && filterContainsType$ != 'notnull'\" class=\"psdk-full-width\">\n <mat-label>Date time</mat-label>\n <input matInput type=\"datetime-local\" [value]=\"filterContainsValue$\" (change)=\"_filterContainsDateTimeValue($event)\" />\n </mat-form-field>\n\n <mat-form-field *ngIf=\"bIsTime$ && filterContainsType$ !== 'null' && filterContainsType$ != 'notnull'\" class=\"psdk-full-width\">\n <mat-label>Time</mat-label>\n <input matInput type=\"time\" [value]=\"filterContainsValue$\" (change)=\"_filterContainsTimeValue($event)\" />\n </mat-form-field>\n </div>\n\n <component-mapper\n name=\"ActionButtons\"\n [props]=\"{ arMainButtons$: arFilterMainButtons$, arSecondaryButtons$: arFilterSecondaryButtons$ }\"\n [parent]=\"this\"\n [outputEvents]=\"{ actionButtonClick: _onFilterActionButtonClick }\"\n ></component-mapper>\n </div>\n</div>\n", styles: [".simple-table-wrapper{width:100%;margin-top:.5rem;margin-bottom:.5rem;overflow-y:auto;box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f}table{width:100%}::ng-deep .mat-sort-header-content{white-space:normal}::ng-deep td.mat-mdc-cell{white-space:normal}::ng-deep th.mat-mdc-header-cell,td.mat-mdc-cell,td.mat-mdc-footer-cell{border-right:1px solid var(--app-neutral-light-color);padding:8px!important;min-width:10rem}::ng-deep th.mat-mdc-header-cell:last-child,td.mat-mdc-cell:last-child{min-width:2rem}::ng-deep .mat-mdc-button{padding:0;text-align:left}.mat-mdc-icon-button{width:fit-content}.mat-mdc-row .mat-mdc-cell{text-align:left}.psdk-mat-header{white-space:normal;padding-right:5px}.psdk-mat-header-button{display:inline-grid}.psdk-mat-header-arrow,.psdk-mat-header-filter{display:inline-grid;vertical-align:middle}.psdk-full-width{width:100%}.psdk-search{padding-left:.625rem}.psdk-icon-search{vertical-align:sub;padding:0rem .125rem;min-width:unset;width:1.1rem}.psdk-outer-div-in-form{display:inline-grid}.psdk-inner-div-in-form{height:auto;position:relative;width:100%;overflow:auto;max-height:550px;min-height:auto}.psdk-list-view-svg-icon{width:1.4rem;display:inline-block;vertical-align:middle;filter:var(--app-primary-color-filter)}.psdk-filter-svg-icon,.psdk-arrow-svg-icon{width:1rem;display:inline-block;vertical-align:middle;filter:var(--app-neutral-color-filter)}.psdk-filter-popover{display:table;margin:auto;min-width:100px;background-color:var(--app-form-color);border:1px solid var(--app-inverse-form-color);border-radius:10px;padding:20px;box-shadow:0 0 10px 3px var(--app-box-shadow-color);position:absolute;z-index:99}.psdk-dialog-background{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;width:100%;background-color:var(--app-dialog-background-color);position:fixed;z-index:999;top:0;left:0}.psdk-modal-file-top{display:table;margin:auto;min-width:150px;background-color:var(--app-form-color);border:1px solid var(--app-inverse-form-color);border-radius:10px;padding:20px;box-shadow:0 0 10px 3px var(--app-box-shadow-color)}tr.mat-mdc-row{cursor:pointer}tr.mat-mdc-header-row{background:var(--app-table-header-background-color)}.psdk-data-readonly{margin-top:.625rem;width:100%}.psdk-no-records{height:56px;text-align:center;border:1px solid var(--app-neutral-light-color);border-top:none;background:var(--app-form-color)}.psdk-utility-card-action-svg-icon{width:1.4rem}.label{margin:8px}.results-count{opacity:.7;font-size:.8rem;font-weight:700;margin-inline-start:.625rem}\n"], dependencies: [{ kind: "ngmodule", type: i0.forwardRef(() => CommonModule) }, { kind: "directive", type: i0.forwardRef(() => i4.NgForOf), selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i0.forwardRef(() => i4.NgIf), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: i0.forwardRef(() => MatTableModule) }, { kind: "component", type: i0.forwardRef(() => i5.MatTable), selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i0.forwardRef(() => i5.MatHeaderCellDef), selector: "[matHeaderCellDef]" }, { kind: "directive", type: i0.forwardRef(() => i5.MatHeaderRowDef), selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i0.forwardRef(() => i5.MatColumnDef), selector: "[matColumnDef]", inputs: ["matColumnDef"] }, { kind: "directive", type: i0.forwardRef(() => i5.MatCellDef), selector: "[matCellDef]" }, { kind: "directive", type: i0.forwardRef(() => i5.MatRowDef), selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i0.forwardRef(() => i5.MatHeaderCell), selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i0.forwardRef(() => i5.MatCell), selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i0.forwardRef(() => i5.MatHeaderRow), selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i0.forwardRef(() => i5.MatRow), selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "directive", type: i0.forwardRef(() => i5.MatNoDataRow), selector: "ng-template[matNoDataRow]" }, { kind: "ngmodule", type: i0.forwardRef(() => MatButtonModule) }, { kind: "component", type: i0.forwardRef(() => i6.MatButton), selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i0.forwardRef(() => i6.MatIconButton), selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: i0.forwardRef(() => MatSortModule) }, { kind: "directive", type: i0.forwardRef(() => i7.MatSort), selector: "[matSort]", inputs: ["matSortActive", "matSortStart", "matSortDirection", "matSortDisableClear", "matSortDisabled"], outputs: ["matSortChange"], exportAs: ["matSort"] }, { kind: "component", type: i0.forwardRef(() => i7.MatSortHeader), selector: "[mat-sort-header]", inputs: ["mat-sort-header", "arrowPosition", "start", "disabled", "sortActionDescription", "disableClear"], exportAs: ["matSortHeader"] }, { kind: "ngmodule", type: i0.forwardRef(() => MatMenuModule) }, { kind: "component", type: i0.forwardRef(() => i8.MatMenu), selector: "mat-menu", inputs: ["backdropClass", "aria-label", "aria-labelledby", "aria-describedby", "xPosition", "yPosition", "overlapTrigger", "hasBackdrop", "class", "classList"], outputs: ["closed", "close"], exportAs: ["matMenu"] }, { kind: "component", type: i0.forwardRef(() => i8.MatMenuItem), selector: "[mat-menu-item]", inputs: ["role", "disabled", "disableRipple"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i0.forwardRef(() => i8.MatMenuTrigger), selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { kind: "ngmodule", type: i0.forwardRef(() => MatFormFieldModule) }, { kind: "component", type: i0.forwardRef(() => i9.MatFormField), selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i0.forwardRef(() => i9.MatLabel), selector: "mat-label" }, { kind: "directive", type: i0.forwardRef(() => i9.MatSuffix), selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: i0.forwardRef(() => MatDatepickerModule) }, { kind: "component", type: i0.forwardRef(() => i10.MatDatepicker), selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i0.forwardRef(() => i10.MatDatepickerInput), selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i0.forwardRef(() => i10.MatDatepickerToggle), selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "ngmodule", type: i0.forwardRef(() => MatOptionModule) }, { kind: "component", type: i0.forwardRef(() => i11.MatOption), selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "ngmodule", type: i0.forwardRef(() => MatSelectModule) }, { kind: "component", type: i0.forwardRef(() => i12.MatSelect), selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "ngmodule", type: i0.forwardRef(() => MatInputModule) }, { kind: "directive", type: i0.forwardRef(() => i13.MatInput), selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i0.forwardRef(() => ComponentMapperComponent), selector: "component-mapper", inputs: ["name", "props", "errorMsg", "outputEvents", "parent"] }] }); }
789
- }
790
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SimpleTableManualComponent, decorators: [{
791
- type: Component,
792
- args: [{ selector: 'app-simple-table-manual', standalone: true, imports: [
793
- CommonModule,
794
- MatTableModule,
795
- MatButtonModule,
796
- MatSortModule,
797
- MatMenuModule,
798
- MatFormFieldModule,
799
- MatDatepickerModule,
800
- MatOptionModule,
801
- MatSelectModule,
802
- MatInputModule,
803
- forwardRef(() => ComponentMapperComponent)
804
- ], template: "<ng-container *ngIf=\"bVisible$\">\n <div class=\"simple-table-wrapper\">\n <h3 *ngIf=\"label\" className=\"label\" style=\"font-weight: bold\">\n {{ label }} <span class=\"results-count\">{{ getResultsText() }}</span>\n </h3>\n <table *ngIf=\"readOnlyMode || allowEditingInModal\" mat-table [dataSource]=\"elementsData\" class=\"mat-elevation-z8\" id=\"readonly-table\" matSort>\n <ng-container *ngFor=\"let dCol of processedFields; let i = index\" [matColumnDef]=\"dCol.config.name\">\n <th mat-header-cell *matHeaderCellDef mat-sort-header (click)=\"_headerSortClick($event, dCol)\" arrowPosition=\"before\">\n <div>{{ dCol.config.label }}</div>\n <div class=\"psdk-mat-header-filter\">\n <img class=\"psdk-filter-svg-icon\" name=\"filterOnIcon\" />\n </div>\n <div (click)=\"$event.stopPropagation()\">\n <button mat-icon-button [matMenuTriggerFor]=\"groupMenu\">\n <img class=\"psdk-list-view-svg-icon\" src=\"{{ menuSvgIcon$ }}\" />\n </button>\n <mat-menu #groupMenu>\n <button mat-menu-item (click)=\"_groupBy($event, dCol)\">\n <img class=\"psdk-list-view-svg-icon\" src=\"{{ groupBySvgIcon$ }}\" /><span>Group By</span>\n </button>\n <button *ngIf=\"_showUnGroupBy(dCol) && bGrouping$\" mat-menu-item (click)=\"_unGroupBy($event, dCol)\">\n <img class=\"psdk-list-view-svg-icon\" src=\"{{ groupBySvgIcon$ }}\" /><span>Ungroup</span>\n </button>\n <button mat-menu-item (click)=\"_filter($event, dCol)\">\n <img class=\"psdk-list-view-svg-icon\" src=\"{{ filterSvgIcon$ }}\" /><span>Filter</span>\n </button>\n </mat-menu>\n </div>\n </th>\n <td mat-cell *matCellDef=\"let element\">\n <component-mapper\n [name]=\"element[i].getPConnect().getComponentName()\"\n [props]=\"{\n pConn$: element[i].getPConnect(),\n formGroup$: formGroup$\n }\"\n errorMsg=\"Table wants component not yet available: {{ element[i].getPConnect().getComponentName() }}\"\n ></component-mapper>\n </td>\n </ng-container>\n <ng-container matColumnDef=\"DeleteIcon\">\n <div *ngIf=\"allowEditingInModal\">\n <th mat-header-cell *matHeaderCellDef></th>\n <td mat-cell *matCellDef=\"let element; index as j\">\n <div class=\"header-icon\">\n <button mat-icon-button [matMenuTriggerFor]=\"utilityMenu\">\n <img class=\"psdk-utility-card-actions-svg-icon\" src=\"{{ settingsSvgIcon$ }}\" />\n </button>\n <mat-menu #utilityMenu=\"matMenu\" overlapTrigger=\"false\">\n <button mat-menu-item (click)=\"editRecord(element, j)\">Edit</button>\n <button mat-menu-item (click)=\"deleteRecord(j)\">Delete</button>\n </mat-menu>\n </div>\n </td>\n </div>\n </ng-container>\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns\"></tr>\n <tr class=\"mat-row psdk-no-records\" *matNoDataRow>\n <td id=\"no-records\" class=\"mat-cell\" [attr.colspan]=\"displayedColumns.length\">\n {{ utils.getGenericFieldsLocalizedValue('CosmosFields.fields.lists', 'No records found.') }}\n </td>\n </tr>\n </table>\n <table *ngIf=\"editableMode && !allowEditingInModal\" mat-table [dataSource]=\"elementsData\" class=\"mat-elevation-z8\" id=\"editable-table\">\n <ng-container *ngFor=\"let dCol of fieldDefs; let i = index\">\n <ng-container *ngIf=\"dCol.name != 'DeleteIcon'\" [matColumnDef]=\"dCol.name\">\n <th mat-header-cell *matHeaderCellDef class=\"psdk-mat-header\">{{ dCol.label }}</th>\n <td mat-cell *matCellDef=\"let element\">\n <component-mapper\n [name]=\"element[i].getPConnect().getComponentName()\"\n [props]=\"{\n pConn$: element[i].getPConnect(),\n formGroup$: formGroup$\n }\"\n errorMsg=\"Table wants component not yet available: {{ element[i].getPConnect().getComponentName() }}\"\n ></component-mapper>\n </td>\n </ng-container>\n </ng-container>\n <ng-container matColumnDef=\"DeleteIcon\">\n <th mat-header-cell *matHeaderCellDef></th>\n <td mat-cell *matCellDef=\"let element; index as j\">\n <button id=\"delete-button\" mat-icon-button (click)=\"deleteRecord(j)\">\n <img class=\"psdk-utility-card-action-svg-icon\" src=\"{{ menuIconOverride$ }}\" />\n </button>\n </td>\n </ng-container>\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns\"></tr>\n <tr class=\"mat-row psdk-no-records\" *matNoDataRow>\n <td id=\"no-records\" class=\"mat-cell\" [attr.colspan]=\"displayedColumns.length\">\n {{ utils.getGenericFieldsLocalizedValue('CosmosFields.fields.lists', 'No records found.') }}\n </td>\n </tr>\n </table>\n </div>\n <button *ngIf=\"showAddRowButton\" mat-button color=\"primary\" style=\"font-size: 16px\" (click)=\"addRecord()\">\n + {{ localizedVal('Add', localeCategory) }}\n </button>\n</ng-container>\n\n<!-- pop overs for filters-->\n<div *ngIf=\"bShowFilterPopover$\" class=\"psdk-dialog-background\">\n <div class=\"psdk-modal-file-top\">\n <h4>\n Filter:<b> {{ filterContainsLabel$ }}</b>\n </h4>\n <div *ngIf=\"bContains$\">\n <mat-form-field class=\"psdk-full-width\">\n <mat-select [value]=\"filterContainsType$\" (selectionChange)=\"_filterContainsType($event)\">\n <mat-option value=\"contains\">Contains</mat-option>\n <mat-option value=\"equals\">Equals</mat-option>\n <mat-option value=\"startswith\">Starts with</mat-option>\n </mat-select>\n </mat-form-field>\n\n <mat-form-field class=\"psdk-full-width\">\n <input matInput type=\"text\" [value]=\"filterContainsValue$\" (change)=\"_filterContainsValue($event)\" />\n </mat-form-field>\n </div>\n\n <div *ngIf=\"bDateTime$\">\n <mat-form-field class=\"psdk-full-width\">\n <mat-select [value]=\"filterContainsType$\" (selectionChange)=\"_filterContainsType($event)\">\n <mat-option value=\"notequal\">is not equal to</mat-option>\n <mat-option value=\"after\">after</mat-option>\n <mat-option value=\"before\">before</mat-option>\n <mat-option value=\"null\">is null</mat-option>\n <mat-option value=\"notnull\">is not null</mat-option>\n </mat-select>\n </mat-form-field>\n\n <mat-form-field *ngIf=\"bIsDate$ && filterContainsType$ !== 'null' && filterContainsType$ != 'notnull'\" class=\"psdk-full-width\">\n <mat-label>Date</mat-label>\n <input\n matInput\n #dateInput\n [matDatepicker]=\"pegadate\"\n type=\"text\"\n [value]=\"filterContainsValue$\"\n (dateChange)=\"_filterContainsDateValue($event, dateInput.value)\"\n />\n <mat-datepicker-toggle matSuffix [for]=\"pegadate\"></mat-datepicker-toggle>\n <mat-datepicker #pegadate [startAt]=\"filterContainsValue$\"></mat-datepicker>\n </mat-form-field>\n\n <mat-form-field *ngIf=\"bIsDateTime$ && filterContainsType$ !== 'null' && filterContainsType$ != 'notnull'\" class=\"psdk-full-width\">\n <mat-label>Date time</mat-label>\n <input matInput type=\"datetime-local\" [value]=\"filterContainsValue$\" (change)=\"_filterContainsDateTimeValue($event)\" />\n </mat-form-field>\n\n <mat-form-field *ngIf=\"bIsTime$ && filterContainsType$ !== 'null' && filterContainsType$ != 'notnull'\" class=\"psdk-full-width\">\n <mat-label>Time</mat-label>\n <input matInput type=\"time\" [value]=\"filterContainsValue$\" (change)=\"_filterContainsTimeValue($event)\" />\n </mat-form-field>\n </div>\n\n <component-mapper\n name=\"ActionButtons\"\n [props]=\"{ arMainButtons$: arFilterMainButtons$, arSecondaryButtons$: arFilterSecondaryButtons$ }\"\n [parent]=\"this\"\n [outputEvents]=\"{ actionButtonClick: _onFilterActionButtonClick }\"\n ></component-mapper>\n </div>\n</div>\n", styles: [".simple-table-wrapper{width:100%;margin-top:.5rem;margin-bottom:.5rem;overflow-y:auto;box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f}table{width:100%}::ng-deep .mat-sort-header-content{white-space:normal}::ng-deep td.mat-mdc-cell{white-space:normal}::ng-deep th.mat-mdc-header-cell,td.mat-mdc-cell,td.mat-mdc-footer-cell{border-right:1px solid var(--app-neutral-light-color);padding:8px!important;min-width:10rem}::ng-deep th.mat-mdc-header-cell:last-child,td.mat-mdc-cell:last-child{min-width:2rem}::ng-deep .mat-mdc-button{padding:0;text-align:left}.mat-mdc-icon-button{width:fit-content}.mat-mdc-row .mat-mdc-cell{text-align:left}.psdk-mat-header{white-space:normal;padding-right:5px}.psdk-mat-header-button{display:inline-grid}.psdk-mat-header-arrow,.psdk-mat-header-filter{display:inline-grid;vertical-align:middle}.psdk-full-width{width:100%}.psdk-search{padding-left:.625rem}.psdk-icon-search{vertical-align:sub;padding:0rem .125rem;min-width:unset;width:1.1rem}.psdk-outer-div-in-form{display:inline-grid}.psdk-inner-div-in-form{height:auto;position:relative;width:100%;overflow:auto;max-height:550px;min-height:auto}.psdk-list-view-svg-icon{width:1.4rem;display:inline-block;vertical-align:middle;filter:var(--app-primary-color-filter)}.psdk-filter-svg-icon,.psdk-arrow-svg-icon{width:1rem;display:inline-block;vertical-align:middle;filter:var(--app-neutral-color-filter)}.psdk-filter-popover{display:table;margin:auto;min-width:100px;background-color:var(--app-form-color);border:1px solid var(--app-inverse-form-color);border-radius:10px;padding:20px;box-shadow:0 0 10px 3px var(--app-box-shadow-color);position:absolute;z-index:99}.psdk-dialog-background{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;width:100%;background-color:var(--app-dialog-background-color);position:fixed;z-index:999;top:0;left:0}.psdk-modal-file-top{display:table;margin:auto;min-width:150px;background-color:var(--app-form-color);border:1px solid var(--app-inverse-form-color);border-radius:10px;padding:20px;box-shadow:0 0 10px 3px var(--app-box-shadow-color)}tr.mat-mdc-row{cursor:pointer}tr.mat-mdc-header-row{background:var(--app-table-header-background-color)}.psdk-data-readonly{margin-top:.625rem;width:100%}.psdk-no-records{height:56px;text-align:center;border:1px solid var(--app-neutral-light-color);border-top:none;background:var(--app-form-color)}.psdk-utility-card-action-svg-icon{width:1.4rem}.label{margin:8px}.results-count{opacity:.7;font-size:.8rem;font-weight:700;margin-inline-start:.625rem}\n"] }]
805
- }], ctorParameters: () => [{ type: i1.AngularPConnectService }, { type: i2.Utils }, { type: i3.DatapageService }], propDecorators: { sort: [{
806
- type: ViewChild,
807
- args: [MatSort]
808
- }], pConn$: [{
809
- type: Input
810
- }], formGroup$: [{
811
- type: Input
812
- }] } });
813
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"simple-table-manual.component.js","sourceRoot":"","sources":["../../../../../../../packages/angular-sdk-components/src/lib/_components/template/simple-table-manual/simple-table-manual.component.ts","../../../../../../../packages/angular-sdk-components/src/lib/_components/template/simple-table-manual/simple-table-manual.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, ViewChild, forwardRef, OnDestroy } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormGroup } from '@angular/forms';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatDatepickerModule } from '@angular/material/datepicker';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatMenuModule } from '@angular/material/menu';\nimport { MatOptionModule } from '@angular/material/core';\nimport { MatSelectModule } from '@angular/material/select';\nimport { MatSort, MatSortModule } from '@angular/material/sort';\nimport { MatTableDataSource, MatTableModule } from '@angular/material/table';\nimport isEqual from 'fast-deep-equal';\n\nimport { ComponentMapperComponent } from '../../../_bridge/component-mapper/component-mapper.component';\nimport { AngularPConnectData, AngularPConnectService } from '../../../_bridge/angular-pconnect';\nimport { DatapageService } from '../../../_services/datapage.service';\nimport { getReferenceList } from '../../../_helpers/field-group-utils';\nimport { buildFieldsForTable, filterDataByCommonFields, filterDataByDate, getContext } from './helpers';\nimport { evaluateAllowRowAction } from '../utils';\nimport { Utils } from '../../../_helpers/utils';\nimport { getSeconds } from '../../../_helpers/common';\n\ninterface SimpleTableManualProps {\n  // If any, enter additional props that only exist on this component\n  visibility?: boolean;\n  grouping?: any;\n  referenceList?: any[];\n  children?: any[];\n  renderMode?: string;\n  presets?: any[];\n  label?: string;\n  showLabel?: boolean;\n  dataPageName?: string;\n  contextClass?: string;\n  propertyLabel?: string;\n  fieldMetadata?: any;\n  allowActions?: any;\n  allowTableEdit?: boolean;\n  allowRowDelete?: any;\n  editMode?: string;\n  addAndEditRowsWithin?: any;\n  viewForAddAndEditModal?: any;\n  editModeConfig?: any;\n  displayMode?: string;\n  useSeparateViewForEdit: any;\n  viewForEditModal: any;\n  targetClassLabel: string;\n}\n\nclass Group {\n  level = 0;\n  parent: Group;\n  expanded = true;\n  totalCounts = 0;\n  get visible(): boolean {\n    return !this.parent || (this.parent.visible && this.parent.expanded);\n  }\n}\n\n@Component({\n  selector: 'app-simple-table-manual',\n  templateUrl: './simple-table-manual.component.html',\n  styleUrls: ['./simple-table-manual.component.scss'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatTableModule,\n    MatButtonModule,\n    MatSortModule,\n    MatMenuModule,\n    MatFormFieldModule,\n    MatDatepickerModule,\n    MatOptionModule,\n    MatSelectModule,\n    MatInputModule,\n    forwardRef(() => ComponentMapperComponent)\n  ]\n})\nexport class SimpleTableManualComponent implements OnInit, OnDestroy {\n  @ViewChild(MatSort) sort: MatSort;\n\n  @Input() pConn$: typeof PConnect;\n  @Input() formGroup$: FormGroup;\n\n  // Used with AngularPConnect\n  angularPConnectData: AngularPConnectData = {};\n  configProps$: SimpleTableManualProps;\n  fields$: any[];\n\n  bVisible$ = true;\n  displayedColumns: string[] = [];\n  rowData: MatTableDataSource<any>;\n  originalData: any[] = [];\n  processedFields: any[] = [];\n  fieldDefs: any[] = [];\n  requestedReadOnlyMode = false;\n  readOnlyMode = false;\n  editableMode: boolean;\n  menuIconOverride$: string;\n  pageReference: string;\n  referenceList: any;\n  contextClass: any;\n  showAddRowButton: boolean;\n  prevReferenceList: any[] = [];\n  elementsData: MatTableDataSource<any>;\n  originalElementsData: MatTableDataSource<any>;\n  rawFields: any;\n  label?: string = '';\n  searchIcon$: string;\n\n  bShowSearch$ = false;\n  bColumnReorder$ = false;\n  bGrouping$ = false;\n\n  perfFilter: string;\n  searchFilter: string;\n\n  menuSvgIcon$: string;\n  arrowSvgIcon$ = '';\n  arrowDownSvgIcon$: string;\n  arrowUpSvgIcon$: string;\n\n  filterSvgIcon$: string;\n  filterOnSvgIcon$: string;\n  groupBySvgIcon$: string;\n\n  groupByColumns$: string[] = [];\n  compareType: string;\n  compareRef: string;\n  arrowDirection = 'down';\n  filterByColumns: any[] = [];\n  currentFilterRefData: any;\n  filterContainsLabel$ = '';\n  filterContainsType$ = 'contains';\n  filterContainsValue$: any;\n  bShowFilterPopover$ = false;\n  bContains$ = true;\n  bDateTime$ = false;\n\n  bIsDate$ = false;\n  bIsDateTime$ = false;\n  bIsTime$ = false;\n  currentFilterImageEl: any;\n\n  arFilterMainButtons$: any[] = [];\n  arFilterSecondaryButtons$: any[] = [];\n  selectionMode: string;\n  singleSelectionMode: boolean;\n  multiSelectionMode: boolean;\n  rowID: any;\n  response: any;\n  compositeKeys: any;\n  parameters: any;\n  allowEditingInModal = false;\n  defaultView: any;\n  referenceListStr: any;\n  bUseSeparateViewForEdit: any;\n  editView: any;\n  settingsSvgIcon$: string;\n\n  isInitialized = false;\n  targetClassLabel: string;\n  localizedVal = PCore.getLocaleUtils().getLocaleValue;\n  localeCategory = 'SimpleTable';\n  constructor(\n    private angularPConnect: AngularPConnectService,\n    public utils: Utils,\n    private dataPageService: DatapageService\n  ) {}\n\n  ngOnInit(): void {\n    this.elementsData = new MatTableDataSource<any>([]);\n    this.isInitialized = true;\n    // First thing in initialization is registering and subscribing to the AngularPConnect service\n    this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);\n    this.configProps$ = this.pConn$.getConfigProps() as SimpleTableManualProps;\n    // Then, continue on with other initialization\n    this.menuIconOverride$ = this.utils.getImageSrc('trash', this.utils.getSDKStaticContentUrl());\n    // call checkAndUpdate when initializing\n    this.checkAndUpdate();\n    this.filterSvgIcon$ = this.utils.getImageSrc('filter', this.utils.getSDKStaticContentUrl());\n    this.filterOnSvgIcon$ = this.utils.getImageSrc('filter-on', this.utils.getSDKStaticContentUrl());\n    this.groupBySvgIcon$ = this.utils.getImageSrc('row', this.utils.getSDKStaticContentUrl());\n    this.bGrouping$ = this.utils.getBooleanValue(this.configProps$.grouping);\n    this.menuSvgIcon$ = this.utils.getImageSrc('more', this.utils.getSDKStaticContentUrl());\n\n    this.arFilterMainButtons$.push({ actionID: 'submit', jsAction: 'submit', name: 'Submit' });\n    this.arFilterSecondaryButtons$.push({ actionID: 'cancel', jsAction: 'cancel', name: 'Cancel' });\n\n    this.searchIcon$ = this.utils.getImageSrc('search', this.utils.getSDKStaticContentUrl());\n\n    this.settingsSvgIcon$ = this.utils.getImageSrc('more', this.utils.getSDKStaticContentUrl());\n  }\n\n  ngOnDestroy(): void {\n    if (this.angularPConnectData.unsubscribeFn) {\n      this.angularPConnectData.unsubscribeFn();\n    }\n  }\n\n  checkAndUpdate() {\n    // Should always check the bridge to see if the component should\n    // update itself (re-render)\n    const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);\n\n    // ONLY call updateSelf when the component should update\n    if (bUpdateSelf) {\n      this.updateSelf();\n    }\n  }\n\n  // updateSelf\n  updateSelf(): void {\n    // moved this from ngOnInit() and call this from there instead...\n    this.configProps$ = this.pConn$.resolveConfigProps(this.pConn$.getConfigProps()) as SimpleTableManualProps;\n\n    if (this.configProps$.visibility != null) {\n      // eslint-disable-next-line no-multi-assign\n      this.bVisible$ = this.bVisible$ = this.utils.getBooleanValue(this.configProps$.visibility);\n    }\n\n    // NOTE: getConfigProps() has each child.config with datasource and value undefined\n    //  but getRawMetadata() has each child.config with datasource and value showing their unresolved values (ex: \"@P thePropName\")\n    //  We need to use the prop name as the \"glue\" to tie the Angular Material table dataSource, displayColumns and data together.\n    //  So, in the code below, we'll use the unresolved config.value (but replacing the space with an underscore to keep things happy)\n    const rawMetadata = this.pConn$.getRawMetadata();\n\n    // Adapted from Nebula\n    const {\n      referenceList = [], // if referenceList not in configProps$, default to empy list\n      renderMode,\n      children, // destructure children into an array var: \"resolvedFields\"\n      presets,\n      allowActions,\n      allowTableEdit,\n      allowRowDelete,\n      label: labelProp,\n      propertyLabel,\n      fieldMetadata,\n      editMode,\n      addAndEditRowsWithin,\n      viewForAddAndEditModal,\n      editModeConfig,\n      displayMode,\n      useSeparateViewForEdit,\n      viewForEditModal,\n      targetClassLabel\n    } = this.configProps$;\n\n    const simpleTableManualProps: any = {};\n    if (this.checkIfAllowActionsOrRowEditingExist(allowActions) && editMode) {\n      simpleTableManualProps.hideAddRow = allowActions?.allowAdd === false;\n      simpleTableManualProps.hideDeleteRow = allowActions?.allowDelete === false;\n      simpleTableManualProps.hideEditRow = allowActions?.allowEdit === false;\n      simpleTableManualProps.disableDragDrop = allowActions?.allowDragDrop === false;\n    } else if (allowTableEdit === false) {\n      simpleTableManualProps.hideAddRow = true;\n      simpleTableManualProps.hideDeleteRow = true;\n      simpleTableManualProps.disableDragDrop = true;\n    }\n\n    this.referenceListStr = getContext(this.pConn$).referenceListStr;\n    this.label = labelProp || propertyLabel;\n    this.parameters = fieldMetadata?.datasource?.parameters;\n    this.targetClassLabel = targetClassLabel;\n    let { contextClass } = this.configProps$;\n    this.referenceList = referenceList;\n    if (!contextClass) {\n      let listName = this.pConn$.getComponentConfig().referenceList;\n      listName = PCore.getAnnotationUtils().getPropertyName(listName);\n      contextClass = this.pConn$.getFieldMetadata(listName)?.pageClass;\n    }\n    this.contextClass = contextClass;\n\n    const resolvedFields = children?.[0]?.children || presets?.[0].children?.[0].children;\n    // get raw config as @P and other annotations are processed and don't appear in the resolved config.\n    //  Destructure \"raw\" children into array var: \"rawFields\"\n    //  NOTE: when config.listType == \"associated\", the property can be found in either\n    //    config.value (ex: \"@P .DeclarantChoice\") or\n    //    config.datasource (ex: \"@ASSOCIATED .DeclarantChoice\")\n    //  Neither of these appear in the resolved (this.configProps$)\n    const rawConfig: any = rawMetadata?.config;\n    const rawFields = rawConfig?.children?.[0]?.children || rawConfig?.presets?.[0].children?.[0]?.children;\n    this.rawFields = rawFields;\n    // At this point, fields has resolvedFields and rawFields we can use\n\n    // start of from Nebula\n    // get context name and referenceList which will be used to prepare config of PConnect\n    // const { contextName, referenceListStr, pageReferenceForRows } = getContext(this.pConn$);\n\n    const resolvedList = getReferenceList(this.pConn$);\n    this.pageReference = `${this.pConn$.getPageReference()}${resolvedList}`;\n    this.pConn$.setReferenceList(resolvedList);\n\n    // This gives up the \"properties\" we need to map to row/column values later\n    // const processedData = populateRowKey(referenceList);\n\n    this.requestedReadOnlyMode = renderMode === 'ReadOnly';\n    this.readOnlyMode = renderMode === 'ReadOnly';\n    this.editableMode = renderMode === 'Editable';\n    const isDisplayModeEnabled = displayMode === 'DISPLAY_ONLY';\n    this.showAddRowButton = !this.readOnlyMode && !simpleTableManualProps.hideAddRow;\n    this.allowEditingInModal =\n      (editMode ? editMode === 'modal' : addAndEditRowsWithin === 'modal') && !(renderMode === 'ReadOnly' || isDisplayModeEnabled);\n    const showDeleteButton = this.editableMode && !simpleTableManualProps.hideDeleteRow && evaluateAllowRowAction(allowRowDelete, this.rowData);\n    this.defaultView = editModeConfig ? editModeConfig.defaultView : viewForAddAndEditModal;\n    this.bUseSeparateViewForEdit = editModeConfig ? editModeConfig.useSeparateViewForEdit : useSeparateViewForEdit;\n    this.editView = editModeConfig ? editModeConfig.editView : viewForEditModal;\n    // const showDeleteButton = !this.readOnlyMode && !hideDeleteRow;\n\n    // Nebula has other handling for isReadOnlyMode but has Cosmos-specific code\n    //  so ignoring that for now...\n    // fieldDefs will be an array where each entry will have a \"name\" which will be the\n    //  \"resolved\" property name (that we can use as the colId) though it's not really\n    //  resolved. The buildFieldsForTable helper just removes the \"@P \" (which is what\n    //  Nebula does). It will also have the \"label\", and \"meta\" contains the original,\n    //  unchanged config info. For now, much of the info here is carried over from\n    //  Nebula and we may not end up using it all.\n    this.fieldDefs = buildFieldsForTable(rawFields, resolvedFields, showDeleteButton);\n\n    this.initializeDefaultPageInstructions();\n\n    // end of from Nebula\n\n    // Here, we use the \"name\" field in fieldDefs since that has the assoicated property\n    //  (if one exists for the field). If no \"name\", use \"cellRenderer\" (typically get DELETE_ICON)\n    //  for our columns.\n    this.displayedColumns = this.fieldDefs?.map(field => {\n      return field.name ? field.name : field.cellRenderer;\n    });\n\n    // And now we can process the resolvedFields to add in the \"name\"\n    //  from from the fieldDefs. This \"name\" is the value that\n    //  we'll share to connect things together in the table.\n\n    this.processedFields = [];\n\n    this.processedFields = resolvedFields.map((field, i) => {\n      field.config.name = this.displayedColumns[i]; // .config[\"value\"].replace(/ ./g,\"_\");   // replace space dot with underscore\n      return field;\n    });\n\n    // for adding rows to table when editable and not modal view\n    if (this.prevReferenceList.length !== this.referenceList.length) {\n      this.buildElementsForTable();\n    }\n\n    // for edit and adding rows in modal view and to generate readonly list\n    if (!isEqual(this.prevReferenceList, this.referenceList) && (this.readOnlyMode || this.allowEditingInModal)) {\n      this.generateRowsData();\n    }\n\n    this.prevReferenceList = this.referenceList;\n\n    // These are the data structures referred to in the html file.\n    //  These are the relationships that make the table work\n    //  displayedColumns: key/value pairs where key is order of column and\n    //    value is the property shown in that column. Ex: 1: \"FirstName\"\n    //  processedFields: key/value pairs where each key is order of column\n    //    and each value is an object of more detailed information about that\n    //    column.\n    //  rowData: array of each row's key/value pairs. Inside each row,\n    //    each key is an entry in displayedColumns: ex: \"FirstName\": \"Charles\"\n    //    Ex: { 1: {config: {label: \"First Name\", readOnly: true: name: \"FirstName\"}}, type: \"TextInput\" }\n    //    The \"type\" indicates the type of component that should be used for editing (when editing is enabled)\n    //\n    //  Note that the \"property\" shown in the column (\"FirstName\" in the above examples) is what\n    //  ties the 3 data structures together.\n  }\n\n  checkIfAllowActionsOrRowEditingExist(newflagobject) {\n    return (newflagobject && Object.keys(newflagobject).length > 0) || this.pConn$.getComponentConfig().allowRowEdit;\n  }\n\n  initializeDefaultPageInstructions() {\n    if (this.isInitialized) {\n      this.isInitialized = false;\n      if (this.allowEditingInModal) {\n        this.pConn$.getListActions().initDefaultPageInstructions(\n          this.pConn$.getReferenceList(),\n          this.fieldDefs.filter(item => item.name).map(item => item.name)\n        );\n      } else {\n        // @ts-ignore - An argument for 'propertyNames' was not provided.\n        this.pConn$.getListActions().initDefaultPageInstructions(this.pConn$.getReferenceList());\n      }\n    }\n  }\n\n  getResultsText() {\n    const recordsCount = this.readOnlyMode ? this.rowData?.data.length : this.referenceList?.length;\n    return `${recordsCount || 0} result${recordsCount > 1 ? 's' : ''}`;\n  }\n\n  sortCompare(a, b): number {\n    let aValue = a[0][this.compareRef];\n    let bValue = b[0][this.compareRef];\n\n    if (this.compareType == 'Date' || this.compareType == 'DateTime') {\n      aValue = getSeconds(aValue);\n      bValue = getSeconds(bValue);\n    }\n\n    if (this.compareRef == 'pxRefObjectInsName') {\n      const result = this.compareByColumnPxRefObjectInsName(aValue, bValue);\n      if (result !== undefined) {\n        return result;\n      }\n    }\n\n    //\n    switch (this.arrowDirection) {\n      case 'up':\n        if (!aValue || aValue < bValue) {\n          return -1;\n        }\n        if (!bValue || aValue > bValue) {\n          return 1;\n        }\n        break;\n      case 'down':\n        if (!bValue || aValue > bValue) {\n          return -1;\n        }\n        if (!aValue || aValue < bValue) {\n          return 1;\n        }\n        break;\n      default:\n        break;\n    }\n\n    return 0;\n  }\n\n  compareByColumnPxRefObjectInsName(aValue, bValue) {\n    const prefixX = aValue.split('-');\n    const prefixY = bValue.split('-');\n    switch (this.arrowDirection) {\n      case 'up':\n        if (prefixX[0] !== prefixY[0]) {\n          if (prefixX[0] < prefixY[0]) return -1;\n          if (prefixX[0] > prefixY[0]) return 1;\n          return 0;\n        }\n        return prefixX[1] - prefixY[1];\n      case 'down':\n        if (prefixX[0] !== prefixY[0]) {\n          if (prefixX[0] > prefixY[0]) return -1;\n          if (prefixX[0] < prefixY[0]) return 1;\n          return 0;\n        }\n        return prefixY[1] - prefixX[1];\n      default:\n        break;\n    }\n\n    return undefined;\n  }\n\n  updateFilterDisplay(type) {\n    switch (type) {\n      case 'Date':\n        this.filterContainsType$ = 'notequal';\n        this.bContains$ = false;\n        this.bDateTime$ = true;\n        this.bIsDate$ = true;\n        this.bIsDateTime$ = false;\n        this.bIsTime$ = false;\n        break;\n      case 'DateTime':\n        this.filterContainsType$ = 'notequal';\n        this.bContains$ = false;\n        this.bDateTime$ = true;\n        this.bIsDate$ = false;\n        this.bIsDateTime$ = true;\n        this.bIsTime$ = false;\n        break;\n      case 'Time':\n        this.filterContainsType$ = 'notequal';\n        this.bContains$ = false;\n        this.bDateTime$ = true;\n        this.bIsDate$ = false;\n        this.bIsDateTime$ = false;\n        this.bIsTime$ = true;\n        break;\n      default:\n        this.filterContainsType$ = 'contains';\n        this.bContains$ = true;\n        this.bDateTime$ = false;\n        this.bIsDate$ = false;\n        this.bIsDateTime$ = false;\n        this.bIsTime$ = false;\n        break;\n    }\n  }\n\n  _filter(event, columnData) {\n    // add clickAway listener\n    window.addEventListener('mouseup', this._clickAway.bind(this));\n\n    this.currentFilterRefData = columnData;\n    this.filterContainsLabel$ = columnData.config.label;\n\n    setTimeout(() => {\n      this.updateFilterDisplay(columnData.type);\n\n      this.updateFilterVarsWithCurrent(columnData);\n\n      this.bShowFilterPopover$ = true;\n    });\n  }\n\n  _clickAway(event: any) {\n    let bInPopUp = false;\n\n    // run through list of elements in path, if menu not in th path, then want to\n    // hide (toggle) the menu\n    const eventPath = event.path;\n    if (eventPath) {\n      for (let eventIndex = 0; eventIndex < eventPath.length; eventIndex++) {\n        if (\n          eventPath[eventIndex].className == 'psdk-modal-file-top' ||\n          eventPath[eventIndex].tagName == 'BUTTON' ||\n          eventPath[eventIndex].tagName == 'MAT-OPTION' ||\n          eventPath[eventIndex].tagName == 'MAT-INPUT'\n        ) {\n          bInPopUp = true;\n          break;\n        }\n      }\n    }\n\n    if (!bInPopUp) {\n      // this.bShowFilterPopover$ = false;\n\n      window.removeEventListener('mouseup', this._clickAway.bind(this));\n    }\n  }\n\n  _filterContainsType(event) {\n    this.filterContainsType$ = event.value;\n  }\n\n  _filterContainsValue(event) {\n    this.filterContainsValue$ = event.target.value;\n  }\n\n  _filterContainsDateValue(event, value) {\n    this.filterContainsValue$ = value;\n  }\n\n  _filterContainsDateTimeValue(event) {\n    this.filterContainsValue$ = event.target.value;\n  }\n\n  _filterContainsTimeValue(event) {\n    this.filterContainsValue$ = event.target.value;\n  }\n\n  _onFilterActionButtonClick(event: any) {\n    // modal buttons\n    switch (event.action) {\n      case 'cancel':\n        this.currentFilterRefData = [];\n        break;\n      case 'submit':\n        this.updateFilterWithInfo();\n        this.filterSortGroupBy();\n        break;\n      default:\n        break;\n    }\n\n    this.bShowFilterPopover$ = false;\n\n    window.removeEventListener('mouseup', this._clickAway.bind(this));\n  }\n\n  updateFilterWithInfo() {\n    let bFound = false;\n    for (const filterObj of this.filterByColumns) {\n      if (filterObj.ref === this.currentFilterRefData.config.name) {\n        filterObj.type = this.currentFilterRefData.type;\n        filterObj.containsFilter = this.filterContainsType$;\n        filterObj.containsFilterValue = this.filterContainsValue$;\n\n        bFound = true;\n        break;\n      }\n    }\n\n    if (!bFound) {\n      // add in\n      const filterObj: any = {};\n      filterObj.ref = this.currentFilterRefData.config.name;\n      filterObj.type = this.currentFilterRefData.type;\n      filterObj.containsFilter = this.filterContainsType$;\n      filterObj.containsFilterValue = this.filterContainsValue$;\n\n      this.filterByColumns.push(filterObj);\n    }\n\n    // iterate through filters and update filterOn icon\n    for (const filterObj of this.filterByColumns) {\n      const containsFilterValue = filterObj.containsFilterValue;\n      const containsFilter = filterObj.containsFilter;\n      const filterRef = filterObj.ref;\n      const filterIndex = this.displayedColumns.indexOf(filterRef);\n      const arFilterImg = document.getElementsByName('filterOnIcon');\n      const filterImg: any = arFilterImg[filterIndex];\n      if (containsFilterValue == '' && containsFilter != 'null' && containsFilter != 'notnull') {\n        // clear icon\n        filterImg.src = '';\n      } else {\n        // show icon\n        filterImg.src = this.filterOnSvgIcon$;\n      }\n    }\n  }\n\n  updateFilterVarsWithCurrent(columnData) {\n    // find current ref, if exists, move data to variable to display\n\n    let bFound = false;\n    for (const filterObj of this.filterByColumns) {\n      if (filterObj.ref === this.currentFilterRefData.config.name) {\n        this.filterContainsType$ = filterObj.containsFilter;\n        this.filterContainsValue$ = filterObj.containsFilterValue;\n\n        bFound = true;\n        break;\n      }\n    }\n\n    if (!bFound) {\n      switch (columnData.type) {\n        case 'Date':\n        case 'DateTime':\n        case 'Time':\n          this.filterContainsType$ = 'notequal';\n          break;\n        default:\n          this.filterContainsType$ = 'contains';\n          break;\n      }\n\n      this.filterContainsValue$ = '';\n    }\n  }\n\n  filterData(element: any) {\n    const item = element[0];\n    let bKeep = true;\n    for (const filterObj of this.filterByColumns) {\n      if (filterObj.containsFilterValue != '' || filterObj.containsFilter == 'null' || filterObj.containsFilter == 'notnull') {\n        switch (filterObj.type) {\n          case 'Date':\n          case 'DateTime':\n          case 'Time':\n            bKeep = filterDataByDate(item, filterObj);\n            break;\n          default:\n            bKeep = filterDataByCommonFields(item, filterObj);\n            break;\n        }\n      } else if (filterObj.containsFilterValue === '') {\n        bKeep = true;\n      }\n\n      // if don't keep stop filtering\n      if (!bKeep) {\n        break;\n      }\n    }\n\n    return bKeep;\n  }\n\n  filterSortGroupBy() {\n    let theData = this.originalData.slice().map((item, index) => {\n      return [item, index];\n    });\n\n    // last filter config data is global\n    theData = theData.filter(this.filterData.bind(this));\n\n    // last sort config data is global\n    theData.sort(this.sortCompare.bind(this));\n    this.rowData.data = theData.map(item => item[0]);\n\n    const newElements: any = new Array(this.rowData.data.length);\n    theData.forEach((item, index) => {\n      newElements[index] = this.originalElementsData[item[1]];\n    });\n    this.elementsData = newElements;\n  }\n\n  _headerSortClick(event, columnData) {\n    // images 0 - filter, 1 - arrow, 2 - more\n\n    /** Commenting this code for now as it is giving errors not sure if it ever worked */\n    // let arrowImage = event.srcElement.getElementsByTagName('img')[1];\n    // let arrowAttr = arrowImage.getAttribute('arrow');\n\n    // this.clearOutArrows(event, columnData);\n\n    // switch (arrowAttr) {\n    //   case 'up':\n    //     arrowImage.src = this.arrowDownSvgIcon$;\n    //     arrowImage.setAttribute('arrow', 'down');\n    //     break;\n    //   case 'down':\n    //     arrowImage.src = '';\n    //     arrowImage.setAttribute('arrow', 'none');\n    //     break;\n    //   default:\n    //     arrowImage.src = this.arrowUpSvgIcon$;\n    //     arrowImage.setAttribute('arrow', 'up');\n    //     break;\n    // }\n\n    this.compareType = columnData.type;\n    this.compareRef = columnData.config.name;\n    // this.arrowDirection = arrowImage.getAttribute('arrow');\n    this.arrowDirection = this.arrowDirection === 'up' ? 'down' : 'up';\n\n    this.filterSortGroupBy();\n  }\n\n  _showUnGroupBy(columnData): boolean {\n    for (const val of this.groupByColumns$) {\n      if (val == columnData.config.name) {\n        return true;\n      }\n    }\n\n    return false;\n  }\n\n  _groupBy(event, columnData) {\n    this.checkGroupByColumn(columnData.config.name, true);\n\n    this.filterSortGroupBy();\n  }\n\n  _unGroupBy(event, columnData) {\n    // event.stopPropagation();\n    this.checkGroupByColumn(columnData.config.name, false);\n\n    this.filterSortGroupBy();\n  }\n\n  checkGroupByColumn(field, add) {\n    let found: number | null = null;\n    for (const column of this.groupByColumns$) {\n      if (column === field) {\n        found = this.groupByColumns$.indexOf(column, 0);\n      }\n    }\n    if (found != null && found >= 0) {\n      if (!add) {\n        this.groupByColumns$.splice(found, 1);\n      }\n    } else if (add) {\n      this.groupByColumns$.push(field);\n    }\n  }\n\n  _getGroupName(fieldName) {\n    for (let fieldIndex = 0; fieldIndex < this.fields$.length; fieldIndex++) {\n      const field = this.fields$[fieldIndex];\n      if (field.config.name == fieldName) {\n        return field.config.label;\n      }\n    }\n    return '';\n  }\n\n  addGroups(data: any[], groupByColumns: string[]): any[] {\n    const rootGroup = new Group();\n    rootGroup.expanded = true;\n    return this.getSublevel(data, 0, groupByColumns, rootGroup);\n  }\n\n  getSublevel(data: any[], level: number, groupByColumns: string[], parent: Group): any[] {\n    if (level >= groupByColumns.length) {\n      return data;\n    }\n    const groups = this.uniqueBy(\n      data.map(row => {\n        const result = new Group();\n        result.level = level + 1;\n        result.parent = parent;\n        for (let i = 0; i <= level; i++) {\n          result[groupByColumns[i]] = row[groupByColumns[i]];\n        }\n        return result;\n      }),\n      JSON.stringify\n    );\n\n    const currentColumn = groupByColumns[level];\n    let subGroups: any = [];\n    groups.forEach(group => {\n      const rowsInGroup = data.filter(row => group[currentColumn] === row[currentColumn]);\n      group.totalCounts = rowsInGroup.length;\n      const subGroup = this.getSublevel(rowsInGroup, level + 1, groupByColumns, group);\n      subGroup.unshift(group);\n      subGroups = subGroups.concat(subGroup);\n    });\n    return subGroups;\n  }\n\n  uniqueBy(a, key) {\n    const seen = {};\n    return a.filter(item => {\n      const k = key(item);\n      // eslint-disable-next-line no-return-assign, no-prototype-builtins\n      return seen.hasOwnProperty(k) ? false : (seen[k] = true);\n    });\n  }\n\n  isGroup(index, item): boolean {\n    return item.level;\n  }\n\n  _groupHeaderClick(row) {\n    row.expanded = !row.expanded;\n    // this.repeatList$.filter = \"\";\n    this.perfFilter = performance.now().toString();\n    this.rowData.filter = this.perfFilter;\n  }\n\n  // below is for grid row grouping\n  customFilterPredicate(data: any | Group, filter: string): boolean {\n    return data instanceof Group ? data.visible : this.getDataRowVisibleWithFilter(data, filter);\n  }\n\n  getDataRowVisible(data: any): boolean {\n    const groupRows = this.rowData.data.filter(row => {\n      if (!(row instanceof Group)) {\n        return false;\n      }\n      let match = true;\n      this.groupByColumns$.forEach(column => {\n        if (!row[column] || !data[column] || row[column] !== data[column]) {\n          match = false;\n        }\n      });\n      return match;\n    });\n\n    if (groupRows.length === 0) {\n      return true;\n    }\n    const parent = groupRows[0] as Group;\n    return parent.visible && parent.expanded;\n  }\n\n  getDataRowVisibleWithFilter(data, filter) {\n    // fist check if row is visible with grouping\n    let bVisible = this.getDataRowVisible(data);\n\n    if (bVisible && filter && filter != '' && filter != this.perfFilter) {\n      // now check if row is filtered.\n\n      // assume not there unless we find it\n      bVisible = false;\n      for (const col of this.displayedColumns) {\n        // filter is lower case\n        if (data[col] && data[col].toString().toLowerCase().indexOf(filter) >= 0) {\n          bVisible = true;\n          break;\n        }\n      }\n    }\n\n    return bVisible;\n  }\n\n  getDisplayColumns(fields = []) {\n    return fields.map((field: any) => {\n      let theField = field.config.value.substring(field.config.value.indexOf(' ') + 1);\n      if (theField.indexOf('.') == 0) {\n        theField = theField.substring(1);\n      }\n\n      return theField;\n    });\n  }\n\n  _getIconStyle(level): string {\n    let sReturn = '';\n    let nLevel = parseInt(level, 10);\n    nLevel--;\n    nLevel *= 15;\n    sReturn = `padding-left: ${nLevel}px; vertical-align: middle`;\n\n    return sReturn;\n  }\n\n  // Callback passed when subscribing to store change\n  onStateChange() {\n    this.checkAndUpdate();\n  }\n\n  // return the value that should be shown as the contents for the given row data\n  //  of the given row field\n  getRowValue(inRowData: Object, inColKey: string): any {\n    // See what data (if any) we have to display\n    const refKeys: string[] = inColKey.split('.');\n    let valBuilder = inRowData;\n    for (const key of refKeys) {\n      valBuilder = valBuilder[key];\n    }\n    return valBuilder;\n  }\n\n  generateRowsData() {\n    const { dataPageName, referenceList } = this.configProps$;\n    const context = this.pConn$.getContextName();\n    // if dataPageName property value exists then make a datapage fetch call and get the list of data.\n    if (dataPageName) {\n      this.dataPageService.getDataPageData(dataPageName, this.parameters, context).then(listData => {\n        const data = this.formatRowsData(listData);\n        this.originalData = data;\n        this.rowData = new MatTableDataSource(data);\n      });\n    } else {\n      // The referenceList prop has the JSON data for each row to be displayed\n      //  in the table. So, iterate over referenceList to create the dataRows that\n      //  we're using as the table's dataSource\n      const data = this.formatRowsData(referenceList);\n      this.originalData = data;\n      this.rowData = new MatTableDataSource(data);\n    }\n  }\n\n  formatRowsData(data) {\n    return data?.map(item => {\n      return this.displayedColumns.reduce((dataForRow, colKey) => {\n        dataForRow[colKey] = this.getRowValue(item, colKey);\n        return dataForRow;\n      }, {});\n    });\n  }\n\n  addRecord() {\n    if (this.allowEditingInModal && this.defaultView) {\n      this.pConn$\n        .getActionsApi()\n        .openEmbeddedDataModal(\n          this.defaultView,\n          this.pConn$ as any,\n          this.referenceListStr,\n          this.referenceList.length,\n          PCore.getConstants().RESOURCE_STATUS.CREATE,\n          this.targetClassLabel\n        );\n    } else {\n      this.pConn$.getListActions().insert({ classID: this.contextClass }, this.referenceList.length);\n    }\n\n    this.pConn$.clearErrorMessages({\n      property: this.pConn$.getStateProps()?.referenceList?.substring(1)\n    });\n  }\n\n  editRecord(data, index) {\n    if (data) {\n      this.pConn$\n        .getActionsApi()\n        .openEmbeddedDataModal(\n          this.bUseSeparateViewForEdit ? this.editView : this.defaultView,\n          this.pConn$ as any,\n          this.referenceListStr,\n          index,\n          PCore.getConstants().RESOURCE_STATUS.UPDATE,\n          this.targetClassLabel\n        );\n    }\n  }\n\n  deleteRecord(index) {\n    this.pConn$.getListActions().deleteEntry(index);\n  }\n\n  buildElementsForTable() {\n    const context = this.pConn$.getContextName();\n    const eleData: any = [];\n    this.referenceList.forEach((element, index) => {\n      const data: any = [];\n      this.rawFields?.forEach(item => {\n        item = {\n          ...item,\n          config: { ...item.config, label: '', displayMode: this.readOnlyMode || this.allowEditingInModal ? 'DISPLAY_ONLY' : undefined }\n        };\n        const referenceListData = getReferenceList(this.pConn$);\n        const isDatapage = referenceListData.startsWith('D_');\n        const pageReferenceValue = isDatapage ? `${referenceListData}[${index}]` : `${this.pConn$.getPageReference()}${referenceListData}[${index}]`;\n        const config = {\n          meta: item,\n          options: {\n            context,\n            pageReference: pageReferenceValue,\n            referenceList: referenceListData,\n            hasForm: true\n          }\n        };\n        const view = PCore.createPConnect(config);\n        data.push(view);\n      });\n      eleData.push(data);\n    });\n    this.originalElementsData = eleData;\n    this.elementsData = eleData;\n  }\n}\n","<ng-container *ngIf=\"bVisible$\">\n  <div class=\"simple-table-wrapper\">\n    <h3 *ngIf=\"label\" className=\"label\" style=\"font-weight: bold\">\n      {{ label }} <span class=\"results-count\">{{ getResultsText() }}</span>\n    </h3>\n    <table *ngIf=\"readOnlyMode || allowEditingInModal\" mat-table [dataSource]=\"elementsData\" class=\"mat-elevation-z8\" id=\"readonly-table\" matSort>\n      <ng-container *ngFor=\"let dCol of processedFields; let i = index\" [matColumnDef]=\"dCol.config.name\">\n        <th mat-header-cell *matHeaderCellDef mat-sort-header (click)=\"_headerSortClick($event, dCol)\" arrowPosition=\"before\">\n          <div>{{ dCol.config.label }}</div>\n          <div class=\"psdk-mat-header-filter\">\n            <img class=\"psdk-filter-svg-icon\" name=\"filterOnIcon\" />\n          </div>\n          <div (click)=\"$event.stopPropagation()\">\n            <button mat-icon-button [matMenuTriggerFor]=\"groupMenu\">\n              <img class=\"psdk-list-view-svg-icon\" src=\"{{ menuSvgIcon$ }}\" />\n            </button>\n            <mat-menu #groupMenu>\n              <button mat-menu-item (click)=\"_groupBy($event, dCol)\">\n                <img class=\"psdk-list-view-svg-icon\" src=\"{{ groupBySvgIcon$ }}\" /><span>Group By</span>\n              </button>\n              <button *ngIf=\"_showUnGroupBy(dCol) && bGrouping$\" mat-menu-item (click)=\"_unGroupBy($event, dCol)\">\n                <img class=\"psdk-list-view-svg-icon\" src=\"{{ groupBySvgIcon$ }}\" /><span>Ungroup</span>\n              </button>\n              <button mat-menu-item (click)=\"_filter($event, dCol)\">\n                <img class=\"psdk-list-view-svg-icon\" src=\"{{ filterSvgIcon$ }}\" /><span>Filter</span>\n              </button>\n            </mat-menu>\n          </div>\n        </th>\n        <td mat-cell *matCellDef=\"let element\">\n          <component-mapper\n            [name]=\"element[i].getPConnect().getComponentName()\"\n            [props]=\"{\n              pConn$: element[i].getPConnect(),\n              formGroup$: formGroup$\n            }\"\n            errorMsg=\"Table wants component not yet available: {{ element[i].getPConnect().getComponentName() }}\"\n          ></component-mapper>\n        </td>\n      </ng-container>\n      <ng-container matColumnDef=\"DeleteIcon\">\n        <div *ngIf=\"allowEditingInModal\">\n          <th mat-header-cell *matHeaderCellDef></th>\n          <td mat-cell *matCellDef=\"let element; index as j\">\n            <div class=\"header-icon\">\n              <button mat-icon-button [matMenuTriggerFor]=\"utilityMenu\">\n                <img class=\"psdk-utility-card-actions-svg-icon\" src=\"{{ settingsSvgIcon$ }}\" />\n              </button>\n              <mat-menu #utilityMenu=\"matMenu\" overlapTrigger=\"false\">\n                <button mat-menu-item (click)=\"editRecord(element, j)\">Edit</button>\n                <button mat-menu-item (click)=\"deleteRecord(j)\">Delete</button>\n              </mat-menu>\n            </div>\n          </td>\n        </div>\n      </ng-container>\n      <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n      <tr mat-row *matRowDef=\"let row; columns: displayedColumns\"></tr>\n      <tr class=\"mat-row psdk-no-records\" *matNoDataRow>\n        <td id=\"no-records\" class=\"mat-cell\" [attr.colspan]=\"displayedColumns.length\">\n          {{ utils.getGenericFieldsLocalizedValue('CosmosFields.fields.lists', 'No records found.') }}\n        </td>\n      </tr>\n    </table>\n    <table *ngIf=\"editableMode && !allowEditingInModal\" mat-table [dataSource]=\"elementsData\" class=\"mat-elevation-z8\" id=\"editable-table\">\n      <ng-container *ngFor=\"let dCol of fieldDefs; let i = index\">\n        <ng-container *ngIf=\"dCol.name != 'DeleteIcon'\" [matColumnDef]=\"dCol.name\">\n          <th mat-header-cell *matHeaderCellDef class=\"psdk-mat-header\">{{ dCol.label }}</th>\n          <td mat-cell *matCellDef=\"let element\">\n            <component-mapper\n              [name]=\"element[i].getPConnect().getComponentName()\"\n              [props]=\"{\n                pConn$: element[i].getPConnect(),\n                formGroup$: formGroup$\n              }\"\n              errorMsg=\"Table wants component not yet available: {{ element[i].getPConnect().getComponentName() }}\"\n            ></component-mapper>\n          </td>\n        </ng-container>\n      </ng-container>\n      <ng-container matColumnDef=\"DeleteIcon\">\n        <th mat-header-cell *matHeaderCellDef></th>\n        <td mat-cell *matCellDef=\"let element; index as j\">\n          <button id=\"delete-button\" mat-icon-button (click)=\"deleteRecord(j)\">\n            <img class=\"psdk-utility-card-action-svg-icon\" src=\"{{ menuIconOverride$ }}\" />\n          </button>\n        </td>\n      </ng-container>\n      <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n      <tr mat-row *matRowDef=\"let row; columns: displayedColumns\"></tr>\n      <tr class=\"mat-row psdk-no-records\" *matNoDataRow>\n        <td id=\"no-records\" class=\"mat-cell\" [attr.colspan]=\"displayedColumns.length\">\n          {{ utils.getGenericFieldsLocalizedValue('CosmosFields.fields.lists', 'No records found.') }}\n        </td>\n      </tr>\n    </table>\n  </div>\n  <button *ngIf=\"showAddRowButton\" mat-button color=\"primary\" style=\"font-size: 16px\" (click)=\"addRecord()\">\n    + {{ localizedVal('Add', localeCategory) }}\n  </button>\n</ng-container>\n\n<!-- pop overs for filters-->\n<div *ngIf=\"bShowFilterPopover$\" class=\"psdk-dialog-background\">\n  <div class=\"psdk-modal-file-top\">\n    <h4>\n      Filter:<b> {{ filterContainsLabel$ }}</b>\n    </h4>\n    <div *ngIf=\"bContains$\">\n      <mat-form-field class=\"psdk-full-width\">\n        <mat-select [value]=\"filterContainsType$\" (selectionChange)=\"_filterContainsType($event)\">\n          <mat-option value=\"contains\">Contains</mat-option>\n          <mat-option value=\"equals\">Equals</mat-option>\n          <mat-option value=\"startswith\">Starts with</mat-option>\n        </mat-select>\n      </mat-form-field>\n\n      <mat-form-field class=\"psdk-full-width\">\n        <input matInput type=\"text\" [value]=\"filterContainsValue$\" (change)=\"_filterContainsValue($event)\" />\n      </mat-form-field>\n    </div>\n\n    <div *ngIf=\"bDateTime$\">\n      <mat-form-field class=\"psdk-full-width\">\n        <mat-select [value]=\"filterContainsType$\" (selectionChange)=\"_filterContainsType($event)\">\n          <mat-option value=\"notequal\">is not equal to</mat-option>\n          <mat-option value=\"after\">after</mat-option>\n          <mat-option value=\"before\">before</mat-option>\n          <mat-option value=\"null\">is null</mat-option>\n          <mat-option value=\"notnull\">is not null</mat-option>\n        </mat-select>\n      </mat-form-field>\n\n      <mat-form-field *ngIf=\"bIsDate$ && filterContainsType$ !== 'null' && filterContainsType$ != 'notnull'\" class=\"psdk-full-width\">\n        <mat-label>Date</mat-label>\n        <input\n          matInput\n          #dateInput\n          [matDatepicker]=\"pegadate\"\n          type=\"text\"\n          [value]=\"filterContainsValue$\"\n          (dateChange)=\"_filterContainsDateValue($event, dateInput.value)\"\n        />\n        <mat-datepicker-toggle matSuffix [for]=\"pegadate\"></mat-datepicker-toggle>\n        <mat-datepicker #pegadate [startAt]=\"filterContainsValue$\"></mat-datepicker>\n      </mat-form-field>\n\n      <mat-form-field *ngIf=\"bIsDateTime$ && filterContainsType$ !== 'null' && filterContainsType$ != 'notnull'\" class=\"psdk-full-width\">\n        <mat-label>Date time</mat-label>\n        <input matInput type=\"datetime-local\" [value]=\"filterContainsValue$\" (change)=\"_filterContainsDateTimeValue($event)\" />\n      </mat-form-field>\n\n      <mat-form-field *ngIf=\"bIsTime$ && filterContainsType$ !== 'null' && filterContainsType$ != 'notnull'\" class=\"psdk-full-width\">\n        <mat-label>Time</mat-label>\n        <input matInput type=\"time\" [value]=\"filterContainsValue$\" (change)=\"_filterContainsTimeValue($event)\" />\n      </mat-form-field>\n    </div>\n\n    <component-mapper\n      name=\"ActionButtons\"\n      [props]=\"{ arMainButtons$: arFilterMainButtons$, arSecondaryButtons$: arFilterSecondaryButtons$ }\"\n      [parent]=\"this\"\n      [outputEvents]=\"{ actionButtonClick: _onFilterActionButtonClick }\"\n    ></component-mapper>\n  </div>\n</div>\n"]}