@one-paragon/angular-utilities 1.2.12 → 1.2.14

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 (407) hide show
  1. package/action-state/action-state-spinner/action-state-spinner.component.d.ts +12 -0
  2. package/action-state/action-state-ui/action-state-ui.module.d.ts +7 -0
  3. package/{src/action-state/index.ts → action-state/index.d.ts} +4 -8
  4. package/action-state/ngrx-ext/ngrx-ext.module.d.ts +8 -0
  5. package/action-state/ngrx.d.ts +31 -0
  6. package/esm2022/action-state/action-state-spinner/action-state-spinner.component.mjs +24 -0
  7. package/esm2022/action-state/action-state-ui/action-state-ui.module.mjs +20 -0
  8. package/esm2022/action-state/index.mjs +8 -0
  9. package/esm2022/action-state/ngrx-ext/ngrx-ext.module.mjs +23 -0
  10. package/esm2022/action-state/ngrx.mjs +47 -0
  11. package/esm2022/http-request-state/HttpRequestStateFactory.mjs +51 -0
  12. package/esm2022/http-request-state/HttpRequestStateStore.mjs +121 -0
  13. package/esm2022/http-request-state/directives/HttpStateDirectiveBase.mjs +30 -0
  14. package/esm2022/http-request-state/directives/http-error-state-directive.mjs +23 -0
  15. package/esm2022/http-request-state/directives/http-inProgress-state-directive.mjs +23 -0
  16. package/esm2022/http-request-state/directives/http-notStarted-state-directive.mjs +23 -0
  17. package/esm2022/http-request-state/directives/http-success-state-directive.mjs +29 -0
  18. package/esm2022/http-request-state/directives/index.mjs +6 -0
  19. package/esm2022/http-request-state/directives/request-state-directive.mjs +61 -0
  20. package/esm2022/http-request-state/helpers.mjs +22 -0
  21. package/esm2022/http-request-state/http-request-state.mjs +39 -0
  22. package/esm2022/http-request-state/http-state-module.mjs +40 -0
  23. package/esm2022/http-request-state/index.mjs +7 -0
  24. package/esm2022/http-request-state/rxjs/getRequestorBody.mjs +4 -0
  25. package/esm2022/http-request-state/rxjs/getRequestorState.mjs +3 -0
  26. package/esm2022/http-request-state/rxjs/index.mjs +5 -0
  27. package/esm2022/http-request-state/rxjs/tapError.mjs +12 -0
  28. package/esm2022/http-request-state/rxjs/tapSuccess.mjs +12 -0
  29. package/esm2022/http-request-state/types.mjs +16 -0
  30. package/esm2022/ngrx/actionable-selector.mjs +71 -0
  31. package/esm2022/ngrx/index.mjs +2 -0
  32. package/esm2022/one-paragon-angular-utilities.mjs +5 -0
  33. package/esm2022/public-api.mjs +20 -0
  34. package/esm2022/rxjs/defaultShareReplay.mjs +7 -0
  35. package/esm2022/rxjs/index.mjs +6 -0
  36. package/esm2022/rxjs/mapError.mjs +8 -0
  37. package/esm2022/rxjs/rxjs-operators.mjs +92 -0
  38. package/esm2022/rxjs/subjectifier.mjs +15 -0
  39. package/esm2022/rxjs/subscriber.directive.mjs +50 -0
  40. package/esm2022/table-builder/classes/DefaultSettings.mjs +6 -0
  41. package/esm2022/table-builder/classes/MatTableObservableDataSource.mjs +23 -0
  42. package/esm2022/table-builder/classes/TableBuilderConfig.mjs +18 -0
  43. package/esm2022/table-builder/classes/TableBuilderDataSource.mjs +48 -0
  44. package/esm2022/table-builder/classes/TableState.mjs +48 -0
  45. package/esm2022/table-builder/classes/data-store.mjs +15 -0
  46. package/esm2022/table-builder/classes/display-col.mjs +2 -0
  47. package/esm2022/table-builder/classes/filter-info.mjs +61 -0
  48. package/esm2022/table-builder/classes/table-builder-general-settings.mjs +116 -0
  49. package/esm2022/table-builder/classes/table-builder.mjs +77 -0
  50. package/esm2022/table-builder/classes/table-store.mjs +388 -0
  51. package/esm2022/table-builder/components/array-column.component.mjs +53 -0
  52. package/esm2022/table-builder/components/column-builder/column-builder.component.mjs +134 -0
  53. package/esm2022/table-builder/components/column-builder/column-helpers.mjs +45 -0
  54. package/esm2022/table-builder/components/date-filter/date-filter.component.mjs +29 -0
  55. package/esm2022/table-builder/components/date-time-filter/date-time-filter.component.mjs +24 -0
  56. package/esm2022/table-builder/components/filter/filter.component.mjs +64 -0
  57. package/esm2022/table-builder/components/filter/in-list/in-list-filter.component.mjs +102 -0
  58. package/esm2022/table-builder/components/gen-col-displayer/gen-col-displayer.component.mjs +47 -0
  59. package/esm2022/table-builder/components/generic-table/generic-table.component.mjs +313 -0
  60. package/esm2022/table-builder/components/generic-table/paginator.component.mjs +100 -0
  61. package/esm2022/table-builder/components/group-by-list/group-by-list.component.mjs +21 -0
  62. package/esm2022/table-builder/components/header-menu/header-menu.component.mjs +103 -0
  63. package/esm2022/table-builder/components/in-filter/in-filter.component.mjs +65 -0
  64. package/esm2022/table-builder/components/index.mjs +10 -0
  65. package/esm2022/table-builder/components/initialization-component/initialization-component.mjs +47 -0
  66. package/esm2022/table-builder/components/link-column.component.mjs +74 -0
  67. package/esm2022/table-builder/components/number-filter/number-filter.component.mjs +29 -0
  68. package/esm2022/table-builder/components/profiles-menu/profiles-menu.component.mjs +64 -0
  69. package/esm2022/table-builder/components/scroll-strategy.mjs +60 -0
  70. package/esm2022/table-builder/components/sort-menu/sort-menu.component-store.mjs +46 -0
  71. package/esm2022/table-builder/components/sort-menu/sort-menu.component.mjs +82 -0
  72. package/esm2022/table-builder/components/table-container/table-container-imports.mjs +26 -0
  73. package/esm2022/table-builder/components/table-container/table-container.helpers/data-state.helpers.mjs +135 -0
  74. package/esm2022/table-builder/components/table-container/table-container.helpers/filter-state.helpers.mjs +83 -0
  75. package/esm2022/table-builder/components/table-container/table-container.helpers/groupBy.helpers.mjs +71 -0
  76. package/esm2022/table-builder/components/table-container/table-container.helpers/sort-state.helpers.mjs +36 -0
  77. package/esm2022/table-builder/components/table-container/table-container.mjs +327 -0
  78. package/esm2022/table-builder/components/table-container/tableProps.mjs +8 -0
  79. package/esm2022/table-builder/components/table-container/virtual-scroll-container.mjs +155 -0
  80. package/esm2022/table-builder/components/table-container-filter/filter-list/filter-list.component.mjs +44 -0
  81. package/esm2022/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.mjs +36 -0
  82. package/esm2022/table-builder/components/table-container-filter/table-wrapper-filter-store.mjs +25 -0
  83. package/esm2022/table-builder/directives/custom-cell-directive.mjs +73 -0
  84. package/esm2022/table-builder/directives/index.mjs +6 -0
  85. package/esm2022/table-builder/directives/multi-sort.directive.mjs +50 -0
  86. package/esm2022/table-builder/directives/resize-column.directive.mjs +87 -0
  87. package/esm2022/table-builder/directives/table-wrapper.directive.mjs +18 -0
  88. package/esm2022/table-builder/directives/tb-filter.directive.mjs +396 -0
  89. package/esm2022/table-builder/enums/filterTypes.mjs +29 -0
  90. package/esm2022/table-builder/functions/boolean-filter-function.mjs +10 -0
  91. package/esm2022/table-builder/functions/date-filter-function.mjs +58 -0
  92. package/esm2022/table-builder/functions/download-data.mjs +12 -0
  93. package/esm2022/table-builder/functions/null-filter-function.mjs +8 -0
  94. package/esm2022/table-builder/functions/number-filter-function.mjs +32 -0
  95. package/esm2022/table-builder/functions/sort-data-function.mjs +17 -0
  96. package/esm2022/table-builder/functions/string-filter-function.mjs +41 -0
  97. package/esm2022/table-builder/interfaces/ColumnInfo.mjs +2 -0
  98. package/esm2022/table-builder/interfaces/dictionary.mjs +2 -0
  99. package/esm2022/table-builder/interfaces/report-def.mjs +50 -0
  100. package/esm2022/table-builder/ngrx/tableBuilderStateStore.mjs +154 -0
  101. package/esm2022/table-builder/pipes/column-total.pipe.mjs +22 -0
  102. package/esm2022/table-builder/pipes/format-filter-type.pipe.mjs +18 -0
  103. package/esm2022/table-builder/pipes/format-filter-value.pipe.mjs +43 -0
  104. package/esm2022/table-builder/pipes/key-display.mjs +18 -0
  105. package/esm2022/table-builder/services/export-to-csv.service.mjs +75 -0
  106. package/esm2022/table-builder/services/link-creator.service.mjs +50 -0
  107. package/esm2022/table-builder/services/table-template-service.mjs +60 -0
  108. package/esm2022/table-builder/services/transform-creator.mjs +100 -0
  109. package/esm2022/table-builder/table-builder.module.mjs +124 -0
  110. package/esm2022/utilities/array-helpers.mjs +14 -0
  111. package/esm2022/utilities/directives/auto-focus.directive.mjs +25 -0
  112. package/esm2022/utilities/directives/clickEmitterDirective.mjs +22 -0
  113. package/esm2022/utilities/directives/clickSubject.mjs +29 -0
  114. package/esm2022/utilities/directives/conditional-classes.directive.mjs +36 -0
  115. package/esm2022/utilities/directives/dialog-service.mjs +21 -0
  116. package/esm2022/utilities/directives/dialog.mjs +145 -0
  117. package/esm2022/utilities/directives/mat-toggle-group-directive.mjs +59 -0
  118. package/esm2022/utilities/directives/prevent-enter.directive.mjs +20 -0
  119. package/esm2022/utilities/directives/stop-propagation.directive.mjs +26 -0
  120. package/esm2022/utilities/directives/styler.mjs +41 -0
  121. package/esm2022/utilities/directives/trim-whitespace.directive.mjs +28 -0
  122. package/esm2022/utilities/index.mjs +16 -0
  123. package/esm2022/utilities/module.mjs +90 -0
  124. package/esm2022/utilities/pipes/function.pipe.mjs +22 -0
  125. package/esm2022/utilities/pipes/phone.pipe.mjs +20 -0
  126. package/esm2022/utilities/pipes/space-case.pipes.mjs +28 -0
  127. package/fesm2022/one-paragon-angular-utilities.mjs +5695 -0
  128. package/fesm2022/one-paragon-angular-utilities.mjs.map +1 -0
  129. package/http-request-state/HttpRequestStateFactory.d.ts +17 -0
  130. package/http-request-state/HttpRequestStateStore.d.ts +54 -0
  131. package/http-request-state/directives/HttpStateDirectiveBase.d.ts +14 -0
  132. package/http-request-state/directives/http-error-state-directive.d.ts +9 -0
  133. package/http-request-state/directives/http-inProgress-state-directive.d.ts +9 -0
  134. package/http-request-state/directives/http-notStarted-state-directive.d.ts +9 -0
  135. package/http-request-state/directives/http-success-state-directive.d.ts +16 -0
  136. package/{src/http-request-state/directives/index.ts → http-request-state/directives/index.d.ts} +5 -5
  137. package/http-request-state/directives/request-state-directive.d.ts +34 -0
  138. package/http-request-state/helpers.d.ts +9 -0
  139. package/http-request-state/http-request-state.d.ts +12 -0
  140. package/http-request-state/http-state-module.d.ts +11 -0
  141. package/{src/http-request-state/index.ts → http-request-state/index.d.ts} +6 -6
  142. package/http-request-state/rxjs/getRequestorBody.d.ts +3 -0
  143. package/http-request-state/rxjs/getRequestorState.d.ts +3 -0
  144. package/{src/http-request-state/rxjs/index.ts → http-request-state/rxjs/index.d.ts} +4 -4
  145. package/http-request-state/rxjs/tapError.d.ts +3 -0
  146. package/http-request-state/rxjs/tapSuccess.d.ts +3 -0
  147. package/http-request-state/types.d.ts +41 -0
  148. package/index.d.ts +5 -0
  149. package/ngrx/actionable-selector.d.ts +17 -0
  150. package/ngrx/index.d.ts +1 -0
  151. package/package.json +30 -16
  152. package/{src/public-api.ts → public-api.d.ts} +16 -35
  153. package/rxjs/defaultShareReplay.d.ts +2 -0
  154. package/{src/rxjs/index.ts → rxjs/index.d.ts} +5 -5
  155. package/rxjs/mapError.d.ts +2 -0
  156. package/rxjs/rxjs-operators.d.ts +13 -0
  157. package/rxjs/subjectifier.d.ts +8 -0
  158. package/rxjs/subscriber.directive.d.ts +14 -0
  159. package/table-builder/classes/DefaultSettings.d.ts +9 -0
  160. package/table-builder/classes/MatTableObservableDataSource.d.ts +9 -0
  161. package/table-builder/classes/TableBuilderConfig.d.ts +23 -0
  162. package/table-builder/classes/TableBuilderDataSource.d.ts +12 -0
  163. package/table-builder/classes/TableState.d.ts +66 -0
  164. package/table-builder/classes/data-store.d.ts +8 -0
  165. package/{src/table-builder/classes/display-col.ts → table-builder/classes/display-col.d.ts} +5 -5
  166. package/table-builder/classes/filter-info.d.ts +35 -0
  167. package/table-builder/classes/table-builder-general-settings.d.ts +85 -0
  168. package/table-builder/classes/table-builder.d.ts +18 -0
  169. package/table-builder/classes/table-store.d.ts +138 -0
  170. package/table-builder/components/array-column.component.d.ts +15 -0
  171. package/table-builder/components/column-builder/column-builder.component.d.ts +47 -0
  172. package/table-builder/components/column-builder/column-helpers.d.ts +36 -0
  173. package/table-builder/components/date-filter/date-filter.component.d.ts +37 -0
  174. package/table-builder/components/date-time-filter/date-time-filter.component.d.ts +37 -0
  175. package/table-builder/components/filter/filter.component.d.ts +46 -0
  176. package/table-builder/components/filter/in-list/in-list-filter.component.d.ts +24 -0
  177. package/table-builder/components/gen-col-displayer/gen-col-displayer.component.d.ts +17 -0
  178. package/table-builder/components/generic-table/generic-table.component.d.ts +85 -0
  179. package/table-builder/components/generic-table/paginator.component.d.ts +30 -0
  180. package/table-builder/components/group-by-list/group-by-list.component.d.ts +7 -0
  181. package/table-builder/components/header-menu/header-menu.component.d.ts +51 -0
  182. package/table-builder/components/in-filter/in-filter.component.d.ts +20 -0
  183. package/{src/table-builder/components/index.ts → table-builder/components/index.d.ts} +9 -9
  184. package/table-builder/components/initialization-component/initialization-component.d.ts +13 -0
  185. package/table-builder/components/link-column.component.d.ts +25 -0
  186. package/table-builder/components/number-filter/number-filter.component.d.ts +39 -0
  187. package/table-builder/components/profiles-menu/profiles-menu.component.d.ts +32 -0
  188. package/table-builder/components/scroll-strategy.d.ts +22 -0
  189. package/table-builder/components/sort-menu/sort-menu.component-store.d.ts +24 -0
  190. package/table-builder/components/sort-menu/sort-menu.component.d.ts +24 -0
  191. package/{src/table-builder/components/table-container/table-container-imports.ts → table-builder/components/table-container/table-container-imports.d.ts} +14 -32
  192. package/table-builder/components/table-container/table-container.d.ts +79 -0
  193. package/table-builder/components/table-container/table-container.helpers/data-state.helpers.d.ts +6 -0
  194. package/table-builder/components/table-container/table-container.helpers/filter-state.helpers.d.ts +17 -0
  195. package/table-builder/components/table-container/table-container.helpers/groupBy.helpers.d.ts +17 -0
  196. package/table-builder/components/table-container/table-container.helpers/sort-state.helpers.d.ts +8 -0
  197. package/table-builder/components/table-container/tableProps.d.ts +12 -0
  198. package/table-builder/components/table-container/virtual-scroll-container.d.ts +36 -0
  199. package/table-builder/components/table-container-filter/filter-list/filter-list.component.d.ts +15 -0
  200. package/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.d.ts +12 -0
  201. package/table-builder/components/table-container-filter/table-wrapper-filter-store.d.ts +14 -0
  202. package/table-builder/directives/custom-cell-directive.d.ts +33 -0
  203. package/{src/table-builder/directives/index.ts → table-builder/directives/index.d.ts} +5 -6
  204. package/table-builder/directives/multi-sort.directive.d.ts +10 -0
  205. package/table-builder/directives/resize-column.directive.d.ts +43 -0
  206. package/table-builder/directives/table-wrapper.directive.d.ts +8 -0
  207. package/table-builder/directives/tb-filter.directive.d.ts +115 -0
  208. package/table-builder/enums/filterTypes.d.ts +36 -0
  209. package/table-builder/functions/boolean-filter-function.d.ts +3 -0
  210. package/table-builder/functions/date-filter-function.d.ts +4 -0
  211. package/table-builder/functions/download-data.d.ts +1 -0
  212. package/table-builder/functions/null-filter-function.d.ts +2 -0
  213. package/table-builder/functions/number-filter-function.d.ts +4 -0
  214. package/table-builder/functions/sort-data-function.d.ts +6 -0
  215. package/table-builder/functions/string-filter-function.d.ts +5 -0
  216. package/{src/table-builder/interfaces/ColumnInfo.ts → table-builder/interfaces/ColumnInfo.d.ts} +6 -7
  217. package/{src/table-builder/interfaces/dictionary.ts → table-builder/interfaces/dictionary.d.ts} +3 -3
  218. package/table-builder/interfaces/report-def.d.ts +147 -0
  219. package/table-builder/ngrx/tableBuilderStateStore.d.ts +70 -0
  220. package/table-builder/pipes/column-total.pipe.d.ts +8 -0
  221. package/table-builder/pipes/format-filter-type.pipe.d.ts +8 -0
  222. package/table-builder/pipes/format-filter-value.pipe.d.ts +12 -0
  223. package/table-builder/pipes/key-display.d.ts +10 -0
  224. package/table-builder/services/export-to-csv.service.d.ts +14 -0
  225. package/table-builder/services/link-creator.service.d.ts +16 -0
  226. package/table-builder/services/table-template-service.d.ts +14 -0
  227. package/table-builder/services/transform-creator.d.ts +16 -0
  228. package/table-builder/table-builder.module.d.ts +21 -0
  229. package/utilities/array-helpers.d.ts +1 -0
  230. package/utilities/directives/auto-focus.directive.d.ts +9 -0
  231. package/utilities/directives/clickEmitterDirective.d.ts +7 -0
  232. package/utilities/directives/clickSubject.d.ts +9 -0
  233. package/utilities/directives/conditional-classes.directive.d.ts +13 -0
  234. package/utilities/directives/dialog-service.d.ts +10 -0
  235. package/utilities/directives/dialog.d.ts +44 -0
  236. package/utilities/directives/mat-toggle-group-directive.d.ts +21 -0
  237. package/utilities/directives/prevent-enter.directive.d.ts +6 -0
  238. package/utilities/directives/stop-propagation.directive.d.ts +7 -0
  239. package/utilities/directives/styler.d.ts +15 -0
  240. package/utilities/directives/trim-whitespace.directive.d.ts +7 -0
  241. package/{src/utilities/index.ts → utilities/index.d.ts} +15 -22
  242. package/utilities/module.d.ts +19 -0
  243. package/utilities/pipes/function.pipe.d.ts +7 -0
  244. package/utilities/pipes/phone.pipe.d.ts +7 -0
  245. package/utilities/pipes/space-case.pipes.d.ts +17 -0
  246. package/karma.conf.js +0 -44
  247. package/ng-package.json +0 -7
  248. package/src/action-state/action-state-spinner/action-state-spinner.component.css +0 -16
  249. package/src/action-state/action-state-spinner/action-state-spinner.component.html +0 -6
  250. package/src/action-state/action-state-spinner/action-state-spinner.component.spec.ts +0 -25
  251. package/src/action-state/action-state-spinner/action-state-spinner.component.ts +0 -26
  252. package/src/action-state/action-state-ui/action-state-ui.module.ts +0 -13
  253. package/src/action-state/ngrx-ext/ngrx-ext.module.ts +0 -15
  254. package/src/action-state/ngrx.ts +0 -69
  255. package/src/http-request-state/HttpRequestStateFactory.ts +0 -66
  256. package/src/http-request-state/HttpRequestStateStore.ts +0 -173
  257. package/src/http-request-state/directives/HttpStateDirectiveBase.ts +0 -29
  258. package/src/http-request-state/directives/http-error-state-directive.ts +0 -21
  259. package/src/http-request-state/directives/http-inProgress-state-directive.ts +0 -19
  260. package/src/http-request-state/directives/http-notStarted-state-directive.ts +0 -19
  261. package/src/http-request-state/directives/http-success-state-directive.ts +0 -29
  262. package/src/http-request-state/directives/request-state-directive.spec.ts +0 -72
  263. package/src/http-request-state/directives/request-state-directive.ts +0 -78
  264. package/src/http-request-state/helpers.ts +0 -30
  265. package/src/http-request-state/http-request-state.ts +0 -69
  266. package/src/http-request-state/http-state-module.ts +0 -23
  267. package/src/http-request-state/observable.spec.ts +0 -43
  268. package/src/http-request-state/rxjs/getRequestorBody.ts +0 -10
  269. package/src/http-request-state/rxjs/getRequestorState.ts +0 -8
  270. package/src/http-request-state/rxjs/tapError.ts +0 -16
  271. package/src/http-request-state/rxjs/tapSuccess.ts +0 -16
  272. package/src/http-request-state/strategies.spec.ts +0 -42
  273. package/src/http-request-state/types.ts +0 -55
  274. package/src/ngrx/actionable-selector.ts +0 -95
  275. package/src/ngrx/index.ts +0 -1
  276. package/src/rxjs/defaultShareReplay.ts +0 -8
  277. package/src/rxjs/mapError.ts +0 -8
  278. package/src/rxjs/rxjs-operators.ts +0 -132
  279. package/src/rxjs/subjectifier.ts +0 -17
  280. package/src/rxjs/subscriber.directive.ts +0 -57
  281. package/src/specs/clickSubject.spec.ts +0 -95
  282. package/src/specs/dialog.spec.ts +0 -101
  283. package/src/specs/toggleGroupDirective.spec.ts +0 -229
  284. package/src/table-builder/classes/DefaultSettings.ts +0 -11
  285. package/src/table-builder/classes/MatTableObservableDataSource.ts +0 -23
  286. package/src/table-builder/classes/TableBuilderConfig.ts +0 -35
  287. package/src/table-builder/classes/TableBuilderDataSource.ts +0 -80
  288. package/src/table-builder/classes/TableState.ts +0 -96
  289. package/src/table-builder/classes/data-store.ts +0 -10
  290. package/src/table-builder/classes/filter-info.ts +0 -108
  291. package/src/table-builder/classes/table-builder-general-settings.ts +0 -129
  292. package/src/table-builder/classes/table-builder.ts +0 -94
  293. package/src/table-builder/classes/table-store.ts +0 -471
  294. package/src/table-builder/components/array-column.component.ts +0 -36
  295. package/src/table-builder/components/column-builder/column-builder.component.html +0 -61
  296. package/src/table-builder/components/column-builder/column-builder.component.scss +0 -43
  297. package/src/table-builder/components/column-builder/column-builder.component.spec.ts +0 -49
  298. package/src/table-builder/components/column-builder/column-builder.component.ts +0 -135
  299. package/src/table-builder/components/column-builder/column-helpers.ts +0 -53
  300. package/src/table-builder/components/date-filter/date-filter.component.html +0 -23
  301. package/src/table-builder/components/date-filter/date-filter.component.ts +0 -24
  302. package/src/table-builder/components/date-time-filter/date-time-filter.component.html +0 -9
  303. package/src/table-builder/components/date-time-filter/date-time-filter.component.ts +0 -22
  304. package/src/table-builder/components/filter/filter.component.html +0 -91
  305. package/src/table-builder/components/filter/filter.component.scss +0 -64
  306. package/src/table-builder/components/filter/filter.component.spec.ts +0 -87
  307. package/src/table-builder/components/filter/filter.component.ts +0 -60
  308. package/src/table-builder/components/filter/in-list/in-list-filter.component.ts +0 -93
  309. package/src/table-builder/components/gen-col-displayer/gen-col-displayer.component.html +0 -55
  310. package/src/table-builder/components/gen-col-displayer/gen-col-displayer.component.scss +0 -57
  311. package/src/table-builder/components/gen-col-displayer/gen-col-displayer.component.ts +0 -59
  312. package/src/table-builder/components/generic-table/generic-table.component.html +0 -78
  313. package/src/table-builder/components/generic-table/generic-table.component.scss +0 -42
  314. package/src/table-builder/components/generic-table/generic-table.component.ts +0 -299
  315. package/src/table-builder/components/generic-table/paginator.component.ts +0 -99
  316. package/src/table-builder/components/group-by-list/group-by-list.component.css +0 -8
  317. package/src/table-builder/components/group-by-list/group-by-list.component.html +0 -12
  318. package/src/table-builder/components/group-by-list/group-by-list.component.spec.ts +0 -23
  319. package/src/table-builder/components/group-by-list/group-by-list.component.ts +0 -21
  320. package/src/table-builder/components/header-menu/header-menu.component.html +0 -104
  321. package/src/table-builder/components/header-menu/header-menu.component.scss +0 -96
  322. package/src/table-builder/components/header-menu/header-menu.component.ts +0 -99
  323. package/src/table-builder/components/in-filter/in-filter.component.css +0 -3
  324. package/src/table-builder/components/in-filter/in-filter.component.html +0 -20
  325. package/src/table-builder/components/in-filter/in-filter.component.ts +0 -66
  326. package/src/table-builder/components/initialization-component/initialization-component.html +0 -29
  327. package/src/table-builder/components/initialization-component/initialization-component.ts +0 -24
  328. package/src/table-builder/components/link-column.component.ts +0 -47
  329. package/src/table-builder/components/number-filter/number-filter.component.css +0 -10
  330. package/src/table-builder/components/number-filter/number-filter.component.html +0 -19
  331. package/src/table-builder/components/number-filter/number-filter.component.spec.ts +0 -30
  332. package/src/table-builder/components/number-filter/number-filter.component.ts +0 -25
  333. package/src/table-builder/components/profiles-menu/profiles-menu.component.html +0 -74
  334. package/src/table-builder/components/profiles-menu/profiles-menu.component.scss +0 -98
  335. package/src/table-builder/components/profiles-menu/profiles-menu.component.spec.ts +0 -23
  336. package/src/table-builder/components/profiles-menu/profiles-menu.component.ts +0 -65
  337. package/src/table-builder/components/scroll-strategy.ts +0 -76
  338. package/src/table-builder/components/sort-menu/sort-menu.component-store.ts +0 -66
  339. package/src/table-builder/components/sort-menu/sort-menu.component.html +0 -111
  340. package/src/table-builder/components/sort-menu/sort-menu.component.scss +0 -119
  341. package/src/table-builder/components/sort-menu/sort-menu.component.ts +0 -98
  342. package/src/table-builder/components/table-container/table-container.css +0 -54
  343. package/src/table-builder/components/table-container/table-container.helpers/data-state.helpers.ts +0 -141
  344. package/src/table-builder/components/table-container/table-container.helpers/filter-state.helpers.ts +0 -106
  345. package/src/table-builder/components/table-container/table-container.helpers/groupBy.helpers.ts +0 -86
  346. package/src/table-builder/components/table-container/table-container.helpers/sort-state.helpers.ts +0 -45
  347. package/src/table-builder/components/table-container/table-container.html +0 -95
  348. package/src/table-builder/components/table-container/table-container.spec.ts +0 -154
  349. package/src/table-builder/components/table-container/table-container.ts +0 -356
  350. package/src/table-builder/components/table-container/tableProps.ts +0 -20
  351. package/src/table-builder/components/table-container/virtual-scroll-container.ts +0 -145
  352. package/src/table-builder/components/table-container-filter/filter-list/filter-list.component.html +0 -31
  353. package/src/table-builder/components/table-container-filter/filter-list/filter-list.component.ts +0 -46
  354. package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.css +0 -42
  355. package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.html +0 -10
  356. package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.spec.ts +0 -86
  357. package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.ts +0 -34
  358. package/src/table-builder/components/table-container-filter/table-wrapper-filter-store.ts +0 -23
  359. package/src/table-builder/directives/custom-cell-directive.ts +0 -58
  360. package/src/table-builder/directives/multi-sort.directive.spec.ts +0 -124
  361. package/src/table-builder/directives/multi-sort.directive.ts +0 -51
  362. package/src/table-builder/directives/resize-column.directive.ts +0 -108
  363. package/src/table-builder/directives/table-wrapper.directive.ts +0 -14
  364. package/src/table-builder/directives/tb-filter.directive.ts +0 -396
  365. package/src/table-builder/enums/filterTypes.ts +0 -40
  366. package/src/table-builder/functions/boolean-filter-function.ts +0 -12
  367. package/src/table-builder/functions/date-filter-function.ts +0 -68
  368. package/src/table-builder/functions/download-data.ts +0 -11
  369. package/src/table-builder/functions/null-filter-function.ts +0 -9
  370. package/src/table-builder/functions/number-filter-function.ts +0 -41
  371. package/src/table-builder/functions/sort-data-function.ts +0 -23
  372. package/src/table-builder/functions/string-filter-function.ts +0 -51
  373. package/src/table-builder/interfaces/column-template.ts +0 -9
  374. package/src/table-builder/interfaces/report-def.ts +0 -155
  375. package/src/table-builder/ngrx/tableBuilderStateStore.ts +0 -199
  376. package/src/table-builder/pipes/column-total.pipe.ts +0 -17
  377. package/src/table-builder/pipes/format-filter-type.pipe.ts +0 -12
  378. package/src/table-builder/pipes/format-filter-value.pipe.ts +0 -42
  379. package/src/table-builder/pipes/key-display.ts +0 -16
  380. package/src/table-builder/services/export-to-csv.service.ts +0 -97
  381. package/src/table-builder/services/link-creator.service.ts +0 -67
  382. package/src/table-builder/services/table-template-service.ts +0 -59
  383. package/src/table-builder/services/transform-creator.ts +0 -95
  384. package/src/table-builder/specs/table-custom-filters.spec.ts +0 -262
  385. package/src/table-builder/styles/collapser.styles.scss +0 -16
  386. package/src/table-builder/table-builder.module.ts +0 -73
  387. package/src/test.ts +0 -17
  388. package/src/utilities/array-helpers.ts +0 -13
  389. package/src/utilities/directives/auto-focus.directive.ts +0 -21
  390. package/src/utilities/directives/clickEmitterDirective.ts +0 -16
  391. package/src/utilities/directives/clickSubject.ts +0 -20
  392. package/src/utilities/directives/conditional-classes.directive.ts +0 -36
  393. package/src/utilities/directives/dialog-service.ts +0 -19
  394. package/src/utilities/directives/dialog.ts +0 -144
  395. package/src/utilities/directives/mat-toggle-group-directive.ts +0 -61
  396. package/src/utilities/directives/prevent-enter.directive.ts +0 -13
  397. package/src/utilities/directives/stop-propagation.directive.ts +0 -20
  398. package/src/utilities/directives/styler.ts +0 -40
  399. package/src/utilities/directives/trim-whitespace.directive.ts +0 -21
  400. package/src/utilities/module.ts +0 -55
  401. package/src/utilities/pipes/function.pipe.ts +0 -16
  402. package/src/utilities/pipes/phone.pipe.ts +0 -15
  403. package/src/utilities/pipes/space-case.pipes.spec.ts +0 -47
  404. package/src/utilities/pipes/space-case.pipes.ts +0 -23
  405. package/tsconfig.lib.json +0 -19
  406. package/tsconfig.lib.prod.json +0 -10
  407. package/tsconfig.spec.json +0 -17
@@ -1,95 +0,0 @@
1
- <ng-content select="[before]" />
2
-
3
- <ng-container multiSort *ngrxLet="state.tableSettings$ as tableSettings">
4
- <div class="header-wrapper">
5
- <div class="title">
6
- @if ((!(collapseHeader$ | async)) || tableSettings.showTitleWhenHeaderCollapsed) {
7
- <ng-content select=".tb-header-title"/>
8
- }
9
- @if((state.groupByKeys$ | async)?.length){
10
- <group-by-list />
11
- }
12
- </div>
13
- <div class="flx-row-end">
14
- <lib-filter-list />
15
- @if (!tableSettings.hideHeader) {
16
- @if (!(collapseHeader$ | async)) {
17
- <ng-container *ngTemplateOutlet="headerMenu"/>
18
- <button mat-icon-button color='primary' [matMenuTriggerFor]="mainMenu">
19
- <mat-icon>more_vert</mat-icon>
20
- </button>
21
- <mat-menu #mainMenu='matMenu'>
22
- <ng-container *ngTemplateOutlet="headerMenuExtra"/>
23
- </mat-menu>
24
- }
25
- @else {
26
- <mat-icon color="primary" [matMenuTriggerFor]="mainMenu" class="flat-menu-button pointer">more_horiz</mat-icon>
27
- <mat-menu #mainMenu='matMenu'>
28
- <div class="flex-column">
29
- <ng-container *ngTemplateOutlet="headerMenu"/>
30
- </div>
31
- <ng-container *ngTemplateOutlet="headerMenuExtra"/>
32
- </mat-menu>
33
- }
34
- <mat-icon [matTooltip]="(collapseHeader$ | async) ? 'expand' : 'collapse'" class="collapse-icon header"
35
- (click)="state.toggleCollapseHeader()">
36
- {{(collapseHeader$ | async) ? 'expand_less' : 'expand_more'}}
37
- </mat-icon>
38
- }
39
-
40
- </div>
41
- </div>
42
- <div class="table-wrapper">
43
- @if($useVirtual())
44
- {
45
- <tb-virtual-scroll-container>
46
- <tb-generic-table [rows]='customRows' [data]="(data | async)!" [displayData]="$displayData()"
47
- (selection$)='selection$.emit($event)' [columnInfos]='$myColumns()' [trackBy]="trackBy" />
48
- </tb-virtual-scroll-container>
49
- }
50
- @else
51
- {
52
- <tb-generic-table [rows]='customRows' [data]="(data | async)!" [displayData]="$displayData()"
53
- (selection$)='selection$.emit($event)' [columnInfos]='$myColumns()' [trackBy]="trackBy" />
54
- }
55
-
56
- </div>
57
- @if(tableSettings.usePaginator)
58
- {
59
- <div class="paginator">
60
- <tb-paginator #tbPaginator [data$]="data" [tableElRef]="tableElRef" />
61
-
62
- <mat-icon [matTooltip]="(collapseFooter$ | async) ? 'expand' : 'collapse'" class="collapse-icon footer"
63
- (click)="state.toggleCollapseFooter()">
64
- {{(collapseFooter$ | async) ? 'expand_more' : 'expand_less'}}
65
- </mat-icon>
66
- </div>
67
- }
68
-
69
- <ng-template #headerMenu>
70
- @if (!tableSettings.hideFilter) {<tb-filter-displayer/>}
71
- @if (!tableSettings.hideColumnSettings) {<tb-col-displayer/>}
72
- @if (!tableSettings.hideSort) {<tb-sort-menu/>}
73
- @if (!!tableId) {<tb-profiles-menu [$tableId]="tableId" (onSaveState)="onSaveState.emit($event)"/>}
74
- </ng-template>
75
-
76
- <ng-template #headerMenuExtra>
77
- <button mat-menu-item (click)="resetState()">
78
- <mat-icon color="primary">autorenew</mat-icon>
79
- <span>Reset table</span>
80
- </button>
81
- @if (!tableSettings.hideExport) {
82
- <button mat-menu-item (click)="exportToCsv()">
83
- <mat-icon color="primary">file_download</mat-icon>
84
- <span>Export Table</span>
85
- </button>
86
- }
87
- @if (tableId) {
88
- <button stop-propagation mat-menu-item (click)="pm.trigger()?.toggleMenu()">
89
- <mat-icon color="primary">people</mat-icon>
90
- <span>Profiles</span>
91
- </button>
92
- <tb-profiles-menu class="profiles-menu" #pm [$tableId]="tableId" (onSaveState)="onSaveState.emit($event)"/>
93
- }
94
- </ng-template>
95
- </ng-container>
@@ -1,154 +0,0 @@
1
- import { BehaviorSubject, of } from 'rxjs';
2
- import { TestBed, ComponentFixture } from '@angular/core/testing';
3
- import { SpaceCasePipe, PhoneNumberPipe } from '../../../utilities';
4
- import { FilterComponent } from '../filter/filter.component';
5
- import { CommonModule, CurrencyPipe, DatePipe } from '@angular/common';
6
- import { FormsModule } from '@angular/forms';
7
- import { FieldType } from '../../interfaces/report-def';
8
- import { NoopAnimationsModule } from '@angular/platform-browser/animations';
9
- import { DateFilterComponent } from '../date-filter/date-filter.component';
10
- import { TableContainerComponent } from './table-container';
11
- import { GenFilterDisplayerComponent } from '../table-container-filter/gen-filter-displayer/gen-filter-displayer.component';
12
- import { GenericTableComponent } from '../generic-table/generic-table.component';
13
- import { GenColDisplayerComponent } from '../gen-col-displayer/gen-col-displayer.component';
14
- import { ColumnTotalPipe } from '../../pipes/column-total.pipe';
15
- import { TableBuilder } from '../../classes/table-builder';
16
- import { MultiSortDirective } from '../../directives/multi-sort.directive';
17
- import { TableBuilderConfigToken } from '../../classes/TableBuilderConfig';
18
- import { provideMockStore } from '@ngrx/store/testing';
19
- import { PaginatorComponent } from '../generic-table/paginator.component';
20
- import { LetModule, PushModule } from '@ngrx/component';
21
- import { HarnessLoader, parallel } from '@angular/cdk/testing';
22
- import { TestbedHarnessEnvironment } from '@angular/cdk/testing/testbed';
23
- import {MatTableHarness} from '@angular/material/table/testing';
24
- import { TransformCreator } from '../../services/transform-creator';
25
-
26
- const data = [
27
- {
28
- name: 'Joe',
29
- age: 10,
30
- balance: 25
31
- },
32
- {
33
- name: 'Jane',
34
- age: 20,
35
- balance: 35
36
- }
37
- ];
38
- const metaData = [
39
- {
40
- key: 'name',
41
- fieldType: FieldType.String,
42
- additional: {},
43
- order : 1
44
- },
45
- {
46
- key: 'age',
47
- fieldType: FieldType.Number,
48
- additional: {},
49
- order : 2
50
- },
51
- {
52
- key: 'balance',
53
- fieldType: FieldType.Number,
54
- additional: {},
55
- order : 3
56
- }
57
- ];
58
-
59
- const initialState = {fullTableState: {
60
- 'test-id': {
61
- metaData,
62
- hiddenKeys: [],
63
- pageSize: 10,
64
- initialized : true ,
65
- filters: [],
66
- }
67
- },
68
- globalStorageState : {
69
- localProfiles: {}
70
- }};
71
- describe('table container', () => {
72
- let fixture: ComponentFixture<TableContainerComponent>;
73
- let component: TableContainerComponent;
74
- let loader: HarnessLoader;
75
-
76
- beforeEach(() => {
77
-
78
- TestBed.configureTestingModule({
79
- declarations: [
80
- TableContainerComponent,
81
- FilterComponent,
82
- GenFilterDisplayerComponent,
83
- GenericTableComponent,
84
- PaginatorComponent,
85
- GenColDisplayerComponent,
86
- SpaceCasePipe,
87
- CurrencyPipe,
88
- ColumnTotalPipe,
89
- DateFilterComponent,
90
- MultiSortDirective,
91
- ],
92
- providers: [
93
- { provide : TableBuilderConfigToken , useValue: {defaultTableState: { }}},
94
- provideMockStore({ initialState }),
95
- DatePipe,
96
- TransformCreator,
97
- CurrencyPipe,
98
- PhoneNumberPipe,
99
- ],
100
- imports: [
101
- NoopAnimationsModule,
102
- CommonModule,
103
- FormsModule,
104
- LetModule,
105
- ]
106
- })
107
- .compileComponents();
108
- fixture = TestBed.createComponent(TableContainerComponent);
109
- component = fixture.componentInstance;
110
- loader = TestbedHarnessEnvironment.loader(fixture);
111
- });
112
-
113
- it('can create component', () => {
114
- component.tableId = 'test-id';
115
- component.tableBuilder = new TableBuilder(of(data));
116
- fixture.detectChanges();
117
- expect(component).toBeDefined();
118
- });
119
-
120
- it('can add metadata dynamicaly after the table has already been rendered', async () => {
121
- const md = new BehaviorSubject(metaData);
122
- component.tableId = 'test-id';
123
- component.tableBuilder = new TableBuilder(of(data), md);
124
-
125
- fixture.detectChanges();
126
- expect(component).toBeDefined();
127
-
128
- const tables = await loader.getAllHarnesses(MatTableHarness);
129
- expect(tables.length).toBe(1);
130
- const table = tables[0];
131
-
132
- let rows = await table.getRows();
133
-
134
- let cells = (await parallel(() => rows.map(row => row.getCells()))).map(row => row.length);
135
-
136
- expect(cells).toEqual([3, 3]);
137
-
138
- md.next([...metaData, {
139
- key: 'dynamic',
140
- fieldType: FieldType.String,
141
- order : 4,
142
- additional: {},
143
- }]);
144
-
145
- fixture.detectChanges();
146
-
147
- rows = await table.getRows();
148
-
149
- cells = (await parallel(() => rows.map(row => row.getCells()))).map(row => row.length);
150
-
151
- expect(cells).toEqual([4, 4]);
152
-
153
- });
154
- });
@@ -1,356 +0,0 @@
1
- import {
2
- Component,
3
- Input,
4
- EventEmitter,
5
- Output,
6
- ContentChildren,
7
- QueryList,
8
- ChangeDetectionStrategy,
9
- Predicate,
10
- ViewChild,
11
- inject,
12
- TemplateRef,
13
- ContentChild,
14
- ElementRef,
15
- OnInit,
16
- OnDestroy,
17
- Injector,
18
- contentChildren,
19
- computed,
20
- effect,
21
- untracked,
22
- } from '@angular/core';
23
- import { BehaviorSubject, Observable, ReplaySubject, combineLatest, of } from 'rxjs';
24
- import { ArrayAdditional, FieldType, MetaData } from '../../interfaces/report-def';
25
- import { map, tap, withLatestFrom, mergeAll, scan, switchAll, startWith, timestamp, mergeMap, filter, switchMap } from 'rxjs/operators';
26
- import { TableBuilder } from '../../classes/table-builder';
27
- import { MatRowDef } from '@angular/material/table';
28
- import { CustomCellDirective, TableCustomFilterDirective, TableFilterDirective } from '../../directives';
29
- import { stateIs, TableStore } from '../../classes/table-store';
30
- import { notNull } from '../../../rxjs/rxjs-operators';
31
- import { ExportToCsvService } from '../../services/export-to-csv.service';
32
- import { ArrayDefaults } from '../../classes/DefaultSettings';
33
- import { TableBuilderConfigToken } from '../../classes/TableBuilderConfig';
34
- import { InitializationState, TableState } from '../../classes/TableState';
35
- import { sortData } from '../../functions/sort-data-function';
36
- import { WrapperFilterStore } from '../table-container-filter/table-wrapper-filter-store';
37
- import { cloneDeep } from 'lodash';
38
- import { defaultShareReplay } from '../../../rxjs';
39
- import { createFilterFunc, isCustomFilter, isFilterInfo } from '../../classes/filter-info';
40
- import { Dictionary } from '../../interfaces/dictionary';
41
- import { TableWrapperDirective } from '../../directives/table-wrapper.directive';
42
- import { createLinkCreatorDict } from '../../services/link-creator.service';
43
- import { TableBuilderStateStore } from '../../ngrx/tableBuilderStateStore';
44
- import { containerImports } from './table-container-imports';
45
- import { updateFilterInfoState, updateFilterPredicateState, updateFilterState } from './table-container.helpers/filter-state.helpers';
46
- import { initialSortState, updateSortState } from './table-container.helpers/sort-state.helpers';
47
- import { getAllGroupHeaderNames, initialGroupByState, updateGroupByState } from './table-container.helpers/groupBy.helpers';
48
- import { sortAndFilterData } from './table-container.helpers/data-state.helpers';
49
- import { TableProps, defaultProps } from './tableProps';
50
- import { PaginatorComponent } from '../generic-table/paginator.component';
51
- import { TableBuilderDataSource } from '../../classes/TableBuilderDataSource';
52
- import { GenericTableComponent } from '../generic-table/generic-table.component';
53
- import { toObservable, toSignal } from '@angular/core/rxjs-interop';
54
- import { DataStore } from '../../classes/data-store';
55
-
56
-
57
- @Component({
58
- selector: 'tb-table-container',
59
- templateUrl: './table-container.html',
60
- styleUrls: ['./table-container.css', '../../styles/collapser.styles.scss'],
61
- changeDetection: ChangeDetectionStrategy.OnPush,
62
- providers: [TableStore, ExportToCsvService, WrapperFilterStore, DataStore],
63
- standalone: true,
64
- imports: containerImports
65
- }) export class TableContainerComponent<T = any> implements OnInit, OnDestroy {
66
- props: TableProps = { ...defaultProps };
67
- dataSubject = new ReplaySubject<Observable<T[]>>(1);
68
-
69
- public state = inject(TableStore);
70
- private dataStore = inject(DataStore);
71
- public config = inject(TableBuilderConfigToken);
72
- public exportToCsvService = inject(ExportToCsvService<T>);
73
- public wrapper = inject(TableWrapperDirective, { optional: true });
74
- public stateService = inject(TableBuilderStateStore);
75
- public injector = inject(Injector);
76
-
77
- filterDirectives = contentChildren(TableFilterDirective, {descendants: true});
78
- customFilterDirectives = contentChildren(TableCustomFilterDirective, {descendants: true});
79
-
80
- allFilterDirectives = computed( () => {
81
- if(this.wrapper) {
82
- return [...this.filterDirectives(), ...this.customFilterDirectives(), ...this.wrapper.$registrations()];
83
- } {
84
- return [...this.filterDirectives(), ...this.customFilterDirectives()];
85
- }
86
- }
87
- );
88
-
89
-
90
- tableState = toSignal(this.state.state$.pipe(filter(stateIs(InitializationState.LoadedFromStore)))) ;
91
-
92
- allFilterDirectivesEffect = effect(() => {
93
- const state = this.tableState();
94
- untracked(() => {
95
- if(state) {
96
- this.allFilterDirectives().filter( f => !f.used).forEach( f => {
97
- f.used = true;
98
- if(f.savable) {
99
- var filter = state.filters[f.filterId];
100
- if(isFilterInfo(filter)) {
101
- const filterDirective: TableFilterDirective = f as TableFilterDirective;
102
- filterDirective.fieldType = filter.fieldType;
103
- filterDirective.filterType = filter.filterType;
104
- filterDirective.setFilterValue(filter.filterValue);
105
- filterDirective.key = filter.key;
106
- filterDirective.update();
107
- }
108
- if(isCustomFilter(filter)) {
109
- f.active = filter.active ?? false;
110
- }
111
- this.state.addFilter((f.filter$ as any));
112
- }
113
- });
114
- }
115
- })
116
- });
117
-
118
- @ViewChild(PaginatorComponent) paginatorComponent?: PaginatorComponent;
119
- @ViewChild(GenericTableComponent) genericTable?: GenericTableComponent;
120
- @ContentChildren(MatRowDef) customRows!: QueryList<MatRowDef<any>>;
121
- $customCells = contentChildren(CustomCellDirective);
122
- $myColumns = computed(() => {
123
- return this.state.$metaDataArray().map( metaData => ({metaData, customCell: this.$customCells().find(cc => cc.customCell === metaData.key)}))
124
- })
125
- @ContentChild('table', {read: ElementRef}) tableElRef!: ElementRef;
126
-
127
- @Input({ required: true }) tableBuilder!: TableBuilder;
128
- @Input() tableId!: string;
129
- @Input() set indexColumn(val: boolean) {
130
- this.props.indexColumn = val;
131
- }
132
- @Input() set selectionColumn(val: boolean) {
133
- this.props.selectionColumn = val;
134
- }
135
- @Input() set isSticky(val: boolean) {
136
- this.props.isSticky = val;
137
- }
138
- @Input() set stickyFooter(val: boolean) {
139
- this.props.stickyFooter = val;
140
- }
141
- @Input() set pageSize(value: number) {
142
- this.state.setPageSize(value);
143
- }
144
- @Input() set groupHeaderTemplate( template: TemplateRef<any>) {
145
- this.props.groupHeaderTemplate = template;
146
- }
147
- @Input() set groupHeaderHeight(value: number) {
148
- this.props.groupHeaderHeight = value;
149
- }
150
- @Input() trackBy!: string;
151
- @Input() inputFilters?: Observable<Array<Predicate<T>>>;
152
-
153
- @Output() selection$ = new EventEmitter();
154
- @Output() data = this.dataSubject.pipe(
155
- switchAll(),
156
- startWith([] as T[]),
157
- defaultShareReplay(),
158
- );
159
- @Output() onStateReset = new EventEmitter();
160
- @Output() onSaveState = new EventEmitter();
161
- @Output() state$ = this.state.getSavableState().pipe(
162
- map(state => cloneDeep(state)),
163
- defaultShareReplay(),
164
- );
165
-
166
- clearSelections(){
167
- this.genericTable?.selection.clear(true);
168
- }
169
- displayDataSubject = new ReplaySubject<Observable<T[]>>(1);
170
- displayData = this.displayDataSubject.pipe(
171
- switchAll(),
172
- defaultShareReplay(),
173
- );
174
- $displayData = toSignal(this.displayData, { initialValue: [] });
175
-
176
-
177
-
178
- collapseFooter$ = this.state.state$.pipe(map(state => state.persistedTableSettings.collapseFooter));
179
-
180
-
181
-
182
-
183
- ngOnDestroy(){
184
- if(this.tableId) {
185
- this.stateService.saveTableStateToLocal({ tableId:this.tableId, tableState: this.state.getSavableStateSignal() });
186
- }
187
- }
188
-
189
- firstPage(): void {
190
- this.paginatorComponent?.paginator?.firstPage();
191
- }
192
-
193
- lastPage(): void {
194
- this.paginatorComponent?.paginator?.lastPage();
195
- }
196
-
197
- resetState() {
198
- this.customFilterDirectives().forEach( cf => cf.reset());
199
- this.filterDirectives().forEach( cf => cf.reset() );
200
- this.state.resetState();
201
- this.onStateReset.next(null)
202
- }
203
-
204
- initializeState() {
205
- this.state.setTableSettings(this.tableBuilder.settings);
206
- this.state.runOnceWhen(
207
- stateIs(InitializationState.MetaDataLoaded),
208
- () => {
209
- if(this.tableId) {
210
- const persistedState$ = toObservable(this.stateService.$selectLocalTableStateForView(this.tableId), {injector: this.injector}).pipe(
211
- tap( persistedState => {
212
- if(!persistedState) {
213
- this.state.setInitializationState(InitializationState.LoadedFromStore);
214
- }
215
- }),
216
- notNull(),
217
- );
218
- this.state.updateStateFromPersistedState(persistedState$.pipe(notNull()));
219
- } else {
220
- this.state.setInitializationState(InitializationState.LoadedFromStore);
221
- }
222
- });
223
- }
224
- customFilters$ = new BehaviorSubject<Predicate<T>[]>([]);
225
- initializeData() {
226
-
227
- const predicateFilters$ = combineLatest([this.inputFilters?.pipe(startWith([])) ?? of([] as Predicate<T>[]), this.customFilters$])
228
- .pipe(map(([a, b]) => [...a, ...b]));
229
-
230
- const filters$ = combineLatest([
231
- this.state.filters$.pipe(scan(updateFilterInfoState, { allFilters: {} }), timestamp()),
232
- predicateFilters$.pipe(scan(updateFilterPredicateState, {allFilters: [] as Predicate<T>[]}), timestamp())
233
- ])
234
- .pipe(
235
- map(([filterInfo, pred]) => updateFilterState(filterInfo, pred))
236
- );
237
-
238
- const sortsState$ = this.state.sort$.pipe(scan(updateSortState, initialSortState));
239
-
240
- const sortedAndFilteredData$ = sortAndFilterData(this.tableBuilder.getData$(), sortsState$, filters$);
241
-
242
- const flatGrouped$ = combineLatest([sortedAndFilteredData$.pipe(timestamp()), this.state.groupByKeys$.pipe(timestamp()), this.state.expandedGroups$.pipe(timestamp())]).pipe(
243
- scan(updateGroupByState, initialGroupByState),
244
- map(({displayData}) => displayData),
245
- defaultShareReplay(),
246
- );
247
-
248
- this.displayDataSubject.next(flatGrouped$);
249
- this.dataSubject.next(sortedAndFilteredData$);
250
-
251
- this.state.on(this.displayData, (data) => {
252
- this.dataStore.patchState({dataLen: data.length})
253
- });
254
- }
255
- ngOnInit() {
256
- const customCells$ = toObservable(this.$customCells, { injector: this.injector });
257
- this.state.setLinkMaps(this.tableBuilder.metaData$!.pipe(
258
- map(createLinkCreatorDict)
259
- ));
260
- const c = customCells$.pipe(switchMap(c => c.length ? combineLatest(c.map(c => c.$metaData)) : of([] as MetaData[])));
261
- this.state.setMetaData(combineLatest([this.tableBuilder.metaData$, c]).pipe(map(([mds, customCells]) => {
262
- mds = mds.map(this.mapArrayFieldsMetaDatas);
263
- return [
264
- ...mds,
265
- ...customCells.map( md => this.mergeMetaData(md, mds.find( item => item.key === md.key ) ))
266
- ]
267
- })))
268
- const ds = new TableBuilderDataSource<T>(
269
- this.displayData,
270
- this.state,
271
- this.dataStore
272
- );
273
- this.state.updateState({props: {
274
- dataSource: ds,
275
- ...this.props
276
- }})
277
- this.initializeState();
278
- this.initializeData();
279
- }
280
-
281
- mergeMetaData(metaData1: MetaData, metaData2?: MetaData) {
282
- if(!metaData2){
283
- metaData1.noExport = true;
284
- return metaData1
285
- }
286
- if(!metaData1.displayName) metaData1.displayName = metaData2.displayName;
287
- if(!metaData1.preSort) metaData1.preSort = metaData2.preSort;
288
- if(!metaData1.order) metaData1.order = metaData2.order;
289
- if(!metaData1.width) metaData1.width = metaData2.width;
290
- if(metaData2.fieldType) metaData1.fieldType = metaData2.fieldType;
291
- metaData1.noExport = !metaData2;
292
- return metaData1;
293
- }
294
-
295
- exportToCsv(): void {
296
- const sorted = this.data.pipe(
297
- withLatestFrom(this.state.sort$),
298
- map(([data, sorted]) => sortData(data, sorted))
299
- );
300
- this.exportToCsvService.exportToCsv(sorted);
301
- }
302
-
303
- expandAllGroups = () => {
304
- const groupHeaders = getAllGroupHeaderNames(this.$displayData());
305
- this.state.expandAllOfGroup({ groupHeadersByKey: groupHeaders });
306
- }
307
-
308
- collapseAllGroups = () => this.state.collapseAll();
309
-
310
- ngAfterContentInit() {
311
- this.state.runOnceWhen(
312
- stateIs(InitializationState.LoadedFromStore),
313
- state => {
314
- this.addFilterDirectives(state);
315
- this.state.updateState({ initializationState: InitializationState.Ready });
316
- });
317
- }
318
-
319
-
320
- mapArrayFieldsMetaDatas = (meta : MetaData<T>) => {
321
- if(meta.fieldType === FieldType.Array){
322
- const additional = {...meta.additional} as ArrayAdditional;
323
- additional.arrayStyle = additional?.arrayStyle ?? ArrayDefaults.arrayStyle;
324
- additional.limit = additional.limit ?? this.config.arrayInfo?.limit ?? ArrayDefaults.limit;
325
- return {...meta,additional}
326
- }
327
- return meta;
328
- }
329
-
330
- collapseHeader$ = this.state.state$.pipe(map(state => state.persistedTableSettings.collapseHeader));
331
-
332
- addFilterDirectives = (state: TableState) => {
333
- const customFilters$ = toObservable(this.allFilterDirectives, {injector: this.injector}).pipe(
334
- mergeMap( customerFilters => customerFilters
335
- .filter( filter => !filter.savable )
336
- .map(filter => filter.filter$ )
337
- ),
338
- mergeAll(),
339
- scan( (a,b)=> {
340
- if(b.active) {
341
- a[b.filterId] = isCustomFilter(b) ? b.predicate : createFilterFunc(b);
342
- } else {
343
- delete a[b.filterId] ;
344
- }
345
- return a;
346
- }, {} as Dictionary<Predicate<any>>),
347
- map( f => Object.values(f))
348
- );
349
-
350
- this.state.on(customFilters$, (f) => {
351
- this.customFilters$.next(f);
352
- });
353
- }
354
-
355
- $useVirtual = this.state.$isVirtual;
356
- }
@@ -1,20 +0,0 @@
1
- import { TemplateRef } from '@angular/core';
2
- import { TableBuilderDataSource } from '../../classes/TableBuilderDataSource';
3
-
4
- export interface TableProps {
5
- indexColumn: boolean;
6
- selectionColumn: boolean;
7
- isSticky: boolean;
8
- stickyFooter:boolean;
9
- groupHeaderTemplate?: TemplateRef<any>;
10
- dataSource?: TableBuilderDataSource<any>;
11
- groupHeaderHeight?: number;
12
- }
13
-
14
- export const defaultProps: TableProps = {
15
- indexColumn: false,
16
- selectionColumn: false,
17
- isSticky: true,
18
- stickyFooter: false,
19
- groupHeaderHeight: undefined,
20
- }