@pega/angular-sdk-components 0.23.1

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