@one-paragon/angular-utilities 2.1.5 → 2.1.6

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 (298) 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/fesm2022/one-paragon-angular-utilities.mjs +6338 -0
  7. package/fesm2022/one-paragon-angular-utilities.mjs.map +1 -0
  8. package/http-request-state/RequestStateFactory.d.ts +17 -0
  9. package/http-request-state/RequestStateStore.d.ts +101 -0
  10. package/{src/http-request-state/deprecated.ts → http-request-state/deprecated.d.ts} +20 -20
  11. package/http-request-state/directives/HttpStateDirectiveBase.d.ts +14 -0
  12. package/http-request-state/directives/http-error-state-directive.d.ts +9 -0
  13. package/http-request-state/directives/http-inProgress-state-directive.d.ts +9 -0
  14. package/http-request-state/directives/http-notStarted-state-directive.d.ts +9 -0
  15. package/http-request-state/directives/http-success-state-directive.d.ts +16 -0
  16. package/{src/http-request-state/directives/index.ts → http-request-state/directives/index.d.ts} +5 -5
  17. package/http-request-state/directives/request-state-directive.d.ts +34 -0
  18. package/http-request-state/helpers.d.ts +9 -0
  19. package/http-request-state/http-state-module.d.ts +11 -0
  20. package/{src/http-request-state/index.ts → http-request-state/index.d.ts} +7 -7
  21. package/http-request-state/request-state.d.ts +12 -0
  22. package/http-request-state/rxjs/getRequestorBody.d.ts +3 -0
  23. package/http-request-state/rxjs/getRequestorState.d.ts +3 -0
  24. package/{src/http-request-state/rxjs/index.ts → http-request-state/rxjs/index.d.ts} +4 -4
  25. package/http-request-state/rxjs/tapError.d.ts +3 -0
  26. package/http-request-state/rxjs/tapSuccess.d.ts +3 -0
  27. package/http-request-state/types.d.ts +41 -0
  28. package/index.d.ts +5 -0
  29. package/ngrx/actionable-selector.d.ts +32 -0
  30. package/ngrx/index.d.ts +1 -0
  31. package/package.json +27 -15
  32. package/{src/public-api.ts → public-api.d.ts} +16 -35
  33. package/rxjs/defaultShareReplay.d.ts +2 -0
  34. package/{src/rxjs/index.ts → rxjs/index.d.ts} +5 -5
  35. package/rxjs/mapError.d.ts +2 -0
  36. package/rxjs/rxjs-operators.d.ts +13 -0
  37. package/rxjs/subjectifier.d.ts +10 -0
  38. package/rxjs/subscriber.directive.d.ts +14 -0
  39. package/table-builder/classes/DefaultSettings.d.ts +9 -0
  40. package/table-builder/classes/MatTableObservableDataSource.d.ts +9 -0
  41. package/table-builder/classes/TableBuilderConfig.d.ts +23 -0
  42. package/table-builder/classes/TableBuilderDataSource.d.ts +18 -0
  43. package/table-builder/classes/TableState.d.ts +81 -0
  44. package/table-builder/classes/data-store.d.ts +8 -0
  45. package/{src/table-builder/classes/display-col.ts → table-builder/classes/display-col.d.ts} +5 -5
  46. package/table-builder/classes/filter-info.d.ts +39 -0
  47. package/table-builder/classes/table-builder-general-settings.d.ts +117 -0
  48. package/table-builder/classes/table-builder.d.ts +22 -0
  49. package/table-builder/classes/table-store.d.ts +146 -0
  50. package/table-builder/classes/table-store.helpers.d.ts +31 -0
  51. package/table-builder/components/array-column.component.d.ts +15 -0
  52. package/table-builder/components/column-builder/column-builder.component.d.ts +41 -0
  53. package/table-builder/components/column-builder/column-helpers.d.ts +38 -0
  54. package/table-builder/components/column-header-menu/column-header-menu.component.d.ts +50 -0
  55. package/table-builder/components/date-filter/date-filter.component.d.ts +37 -0
  56. package/table-builder/components/date-time-filter/date-time-filter.component.d.ts +37 -0
  57. package/table-builder/components/filter/filter.component.d.ts +48 -0
  58. package/table-builder/components/filter/in-list/in-list-filter.component.d.ts +23 -0
  59. package/table-builder/components/gen-col-displayer/gen-col-displayer.component.d.ts +17 -0
  60. package/table-builder/components/generic-table/generic-table.component.d.ts +84 -0
  61. package/table-builder/components/generic-table/paginator.component.d.ts +26 -0
  62. package/table-builder/components/group-by-list/group-by-list.component.d.ts +7 -0
  63. package/table-builder/components/in-filter/in-filter.component.d.ts +20 -0
  64. package/{src/table-builder/components/index.ts → table-builder/components/index.d.ts} +9 -9
  65. package/table-builder/components/initialization-component/initialization-component.d.ts +15 -0
  66. package/table-builder/components/link-column.component.d.ts +23 -0
  67. package/table-builder/components/number-filter/number-filter.component.d.ts +39 -0
  68. package/table-builder/components/profiles-menu/profiles-menu.component.d.ts +33 -0
  69. package/table-builder/components/reset-menu/reset-menu.component.d.ts +25 -0
  70. package/table-builder/components/scroll-strategy.d.ts +45 -0
  71. package/table-builder/components/sort-menu/sort-menu.component-store.d.ts +24 -0
  72. package/table-builder/components/sort-menu/sort-menu.component.d.ts +19 -0
  73. package/table-builder/components/table-container/table-container.d.ts +104 -0
  74. package/table-builder/components/table-container/table-container.helpers/data-state.helpers.d.ts +7 -0
  75. package/table-builder/components/table-container/table-container.helpers/filter-state.helpers.d.ts +19 -0
  76. package/table-builder/components/table-container/table-container.helpers/groupBy.helpers.d.ts +19 -0
  77. package/table-builder/components/table-container/table-container.helpers/meta-data.helpers.d.ts +2 -0
  78. package/table-builder/components/table-container/table-container.helpers/sort-state.helpers.d.ts +12 -0
  79. package/table-builder/components/table-container/tableProps.d.ts +10 -0
  80. package/table-builder/components/table-container/virtual-scroll-container.d.ts +40 -0
  81. package/table-builder/components/table-container-filter/filter-list/filter-list.component.d.ts +15 -0
  82. package/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.d.ts +12 -0
  83. package/table-builder/components/table-container-filter/table-wrapper-filter-store.d.ts +14 -0
  84. package/table-builder/components/table-header-menu/table-header-menu.component.d.ts +15 -0
  85. package/table-builder/directives/custom-cell-directive.d.ts +34 -0
  86. package/{src/table-builder/directives/index.ts → table-builder/directives/index.d.ts} +5 -6
  87. package/table-builder/directives/multi-sort.directive.d.ts +10 -0
  88. package/table-builder/directives/resize-column.directive.d.ts +43 -0
  89. package/table-builder/directives/table-wrapper.directive.d.ts +8 -0
  90. package/table-builder/directives/tb-filter.directive.d.ts +116 -0
  91. package/table-builder/enums/filterTypes.d.ts +36 -0
  92. package/table-builder/functions/boolean-filter-function.d.ts +3 -0
  93. package/table-builder/functions/date-filter-function.d.ts +4 -0
  94. package/table-builder/functions/download-data.d.ts +1 -0
  95. package/table-builder/functions/null-filter-function.d.ts +2 -0
  96. package/table-builder/functions/number-filter-function.d.ts +4 -0
  97. package/table-builder/functions/sort-data-function.d.ts +6 -0
  98. package/table-builder/functions/string-filter-function.d.ts +5 -0
  99. package/{src/table-builder/interfaces/ColumnInfo.ts → table-builder/interfaces/ColumnInfo.d.ts} +6 -7
  100. package/{src/table-builder/interfaces/dictionary.ts → table-builder/interfaces/dictionary.d.ts} +3 -3
  101. package/table-builder/interfaces/report-def.d.ts +171 -0
  102. package/table-builder/ngrx/tableBuilderStateStore.d.ts +69 -0
  103. package/table-builder/pipes/column-total.pipe.d.ts +8 -0
  104. package/table-builder/pipes/format-filter-type.pipe.d.ts +8 -0
  105. package/table-builder/pipes/format-filter-value.pipe.d.ts +11 -0
  106. package/table-builder/pipes/key-display.d.ts +9 -0
  107. package/table-builder/services/export-to-csv.service.d.ts +14 -0
  108. package/table-builder/services/link-creator.service.d.ts +16 -0
  109. package/table-builder/services/table-template-service.d.ts +14 -0
  110. package/table-builder/services/transform-creator.d.ts +7 -0
  111. package/table-builder/table-builder.module.d.ts +14 -0
  112. package/utilities/array-helpers.d.ts +1 -0
  113. package/utilities/directives/auto-focus.directive.d.ts +9 -0
  114. package/utilities/directives/clickEmitterDirective.d.ts +7 -0
  115. package/utilities/directives/clickSubject.d.ts +9 -0
  116. package/utilities/directives/conditional-classes.directive.d.ts +12 -0
  117. package/utilities/directives/dialog-service.d.ts +10 -0
  118. package/utilities/directives/dialog.d.ts +45 -0
  119. package/utilities/directives/mat-toggle-group-directive.d.ts +21 -0
  120. package/utilities/directives/prevent-enter.directive.d.ts +6 -0
  121. package/utilities/directives/stop-propagation.directive.d.ts +7 -0
  122. package/utilities/directives/styler.d.ts +16 -0
  123. package/utilities/directives/trim-whitespace.directive.d.ts +7 -0
  124. package/{src/utilities/index.ts → utilities/index.d.ts} +15 -22
  125. package/utilities/module.d.ts +19 -0
  126. package/utilities/pipes/function.pipe.d.ts +11 -0
  127. package/utilities/pipes/phone.pipe.d.ts +8 -0
  128. package/utilities/pipes/space-case.pipes.d.ts +17 -0
  129. package/karma.conf.js +0 -44
  130. package/ng-package.json +0 -7
  131. package/src/action-state/action-state-spinner/action-state-spinner.component.css +0 -16
  132. package/src/action-state/action-state-spinner/action-state-spinner.component.html +0 -6
  133. package/src/action-state/action-state-spinner/action-state-spinner.component.spec.ts +0 -25
  134. package/src/action-state/action-state-spinner/action-state-spinner.component.ts +0 -25
  135. package/src/action-state/action-state-ui/action-state-ui.module.ts +0 -13
  136. package/src/action-state/ngrx-ext/ngrx-ext.module.ts +0 -15
  137. package/src/action-state/ngrx.ts +0 -69
  138. package/src/http-request-state/RequestStateFactory.ts +0 -56
  139. package/src/http-request-state/RequestStateStore.ts +0 -284
  140. package/src/http-request-state/directives/HttpStateDirectiveBase.ts +0 -29
  141. package/src/http-request-state/directives/http-error-state-directive.ts +0 -21
  142. package/src/http-request-state/directives/http-inProgress-state-directive.ts +0 -19
  143. package/src/http-request-state/directives/http-notStarted-state-directive.ts +0 -19
  144. package/src/http-request-state/directives/http-success-state-directive.ts +0 -29
  145. package/src/http-request-state/directives/request-state-directive.spec.ts +0 -73
  146. package/src/http-request-state/directives/request-state-directive.ts +0 -78
  147. package/src/http-request-state/helpers.ts +0 -30
  148. package/src/http-request-state/http-state-module.ts +0 -23
  149. package/src/http-request-state/models/view-context.ts +0 -18
  150. package/src/http-request-state/observable.spec.ts +0 -43
  151. package/src/http-request-state/request-state.ts +0 -69
  152. package/src/http-request-state/rxjs/getRequestorBody.ts +0 -10
  153. package/src/http-request-state/rxjs/getRequestorState.ts +0 -8
  154. package/src/http-request-state/rxjs/tapError.ts +0 -16
  155. package/src/http-request-state/rxjs/tapSuccess.ts +0 -16
  156. package/src/http-request-state/strategies.spec.ts +0 -42
  157. package/src/http-request-state/types.ts +0 -54
  158. package/src/ngrx/actionable-selector.ts +0 -160
  159. package/src/ngrx/index.ts +0 -1
  160. package/src/rxjs/defaultShareReplay.ts +0 -8
  161. package/src/rxjs/mapError.ts +0 -8
  162. package/src/rxjs/rxjs-operators.ts +0 -130
  163. package/src/rxjs/subjectifier.ts +0 -17
  164. package/src/rxjs/subscriber.directive.ts +0 -57
  165. package/src/specs/clickSubject.spec.ts +0 -95
  166. package/src/specs/dialog.spec.ts +0 -101
  167. package/src/specs/toggleGroupDirective.spec.ts +0 -229
  168. package/src/table-builder/classes/DefaultSettings.ts +0 -11
  169. package/src/table-builder/classes/MatTableObservableDataSource.ts +0 -23
  170. package/src/table-builder/classes/TableBuilderConfig.ts +0 -42
  171. package/src/table-builder/classes/TableBuilderDataSource.ts +0 -65
  172. package/src/table-builder/classes/TableState.ts +0 -125
  173. package/src/table-builder/classes/data-store.ts +0 -10
  174. package/src/table-builder/classes/filter-info.ts +0 -126
  175. package/src/table-builder/classes/table-builder-general-settings.ts +0 -198
  176. package/src/table-builder/classes/table-builder.ts +0 -105
  177. package/src/table-builder/classes/table-store.helpers.ts +0 -104
  178. package/src/table-builder/classes/table-store.ts +0 -440
  179. package/src/table-builder/components/array-column.component.ts +0 -34
  180. package/src/table-builder/components/column-builder/column-builder.component.html +0 -73
  181. package/src/table-builder/components/column-builder/column-builder.component.scss +0 -43
  182. package/src/table-builder/components/column-builder/column-builder.component.spec.ts +0 -49
  183. package/src/table-builder/components/column-builder/column-builder.component.ts +0 -129
  184. package/src/table-builder/components/column-builder/column-helpers.ts +0 -54
  185. package/src/table-builder/components/column-header-menu/column-header-menu.component.html +0 -109
  186. package/src/table-builder/components/column-header-menu/column-header-menu.component.scss +0 -97
  187. package/src/table-builder/components/column-header-menu/column-header-menu.component.ts +0 -94
  188. package/src/table-builder/components/date-filter/date-filter.component.html +0 -23
  189. package/src/table-builder/components/date-filter/date-filter.component.ts +0 -22
  190. package/src/table-builder/components/date-time-filter/date-time-filter.component.html +0 -9
  191. package/src/table-builder/components/date-time-filter/date-time-filter.component.ts +0 -20
  192. package/src/table-builder/components/filter/filter.component.html +0 -103
  193. package/src/table-builder/components/filter/filter.component.scss +0 -60
  194. package/src/table-builder/components/filter/filter.component.spec.ts +0 -87
  195. package/src/table-builder/components/filter/filter.component.ts +0 -64
  196. package/src/table-builder/components/filter/in-list/in-list-filter.component.ts +0 -85
  197. package/src/table-builder/components/gen-col-displayer/gen-col-displayer.component.html +0 -60
  198. package/src/table-builder/components/gen-col-displayer/gen-col-displayer.component.scss +0 -57
  199. package/src/table-builder/components/gen-col-displayer/gen-col-displayer.component.ts +0 -44
  200. package/src/table-builder/components/generic-table/generic-table.component.html +0 -96
  201. package/src/table-builder/components/generic-table/generic-table.component.scss +0 -38
  202. package/src/table-builder/components/generic-table/generic-table.component.ts +0 -399
  203. package/src/table-builder/components/generic-table/paginator.component.ts +0 -106
  204. package/src/table-builder/components/group-by-list/group-by-list.component.css +0 -17
  205. package/src/table-builder/components/group-by-list/group-by-list.component.html +0 -14
  206. package/src/table-builder/components/group-by-list/group-by-list.component.spec.ts +0 -23
  207. package/src/table-builder/components/group-by-list/group-by-list.component.ts +0 -18
  208. package/src/table-builder/components/in-filter/in-filter.component.css +0 -3
  209. package/src/table-builder/components/in-filter/in-filter.component.html +0 -19
  210. package/src/table-builder/components/in-filter/in-filter.component.ts +0 -65
  211. package/src/table-builder/components/initialization-component/initialization-component.html +0 -78
  212. package/src/table-builder/components/initialization-component/initialization-component.ts +0 -27
  213. package/src/table-builder/components/link-column.component.ts +0 -42
  214. package/src/table-builder/components/number-filter/number-filter.component.css +0 -10
  215. package/src/table-builder/components/number-filter/number-filter.component.html +0 -22
  216. package/src/table-builder/components/number-filter/number-filter.component.spec.ts +0 -30
  217. package/src/table-builder/components/number-filter/number-filter.component.ts +0 -25
  218. package/src/table-builder/components/profiles-menu/profiles-menu.component.html +0 -76
  219. package/src/table-builder/components/profiles-menu/profiles-menu.component.scss +0 -126
  220. package/src/table-builder/components/profiles-menu/profiles-menu.component.spec.ts +0 -23
  221. package/src/table-builder/components/profiles-menu/profiles-menu.component.ts +0 -63
  222. package/src/table-builder/components/reset-menu/reset-menu.component.css +0 -3
  223. package/src/table-builder/components/reset-menu/reset-menu.component.html +0 -10
  224. package/src/table-builder/components/reset-menu/reset-menu.component.ts +0 -87
  225. package/src/table-builder/components/scroll-strategy.ts +0 -139
  226. package/src/table-builder/components/sort-menu/sort-menu.component-store.ts +0 -57
  227. package/src/table-builder/components/sort-menu/sort-menu.component.html +0 -109
  228. package/src/table-builder/components/sort-menu/sort-menu.component.scss +0 -119
  229. package/src/table-builder/components/sort-menu/sort-menu.component.ts +0 -88
  230. package/src/table-builder/components/table-container/table-container.helpers/data-state.helpers.ts +0 -112
  231. package/src/table-builder/components/table-container/table-container.helpers/filter-state.helpers.ts +0 -125
  232. package/src/table-builder/components/table-container/table-container.helpers/groupBy.helpers.ts +0 -120
  233. package/src/table-builder/components/table-container/table-container.helpers/meta-data.helpers.ts +0 -16
  234. package/src/table-builder/components/table-container/table-container.helpers/sort-state.helpers.ts +0 -47
  235. package/src/table-builder/components/table-container/table-container.html +0 -79
  236. package/src/table-builder/components/table-container/table-container.scss +0 -47
  237. package/src/table-builder/components/table-container/table-container.ts +0 -403
  238. package/src/table-builder/components/table-container/tableProps.ts +0 -18
  239. package/src/table-builder/components/table-container/virtual-scroll-container.ts +0 -216
  240. package/src/table-builder/components/table-container-filter/filter-list/filter-list.component.html +0 -34
  241. package/src/table-builder/components/table-container-filter/filter-list/filter-list.component.ts +0 -44
  242. package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.css +0 -42
  243. package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.html +0 -11
  244. package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.spec.ts +0 -85
  245. package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.ts +0 -36
  246. package/src/table-builder/components/table-container-filter/table-wrapper-filter-store.ts +0 -23
  247. package/src/table-builder/components/table-header-menu/table-header-menu.component.css +0 -21
  248. package/src/table-builder/components/table-header-menu/table-header-menu.component.html +0 -48
  249. package/src/table-builder/components/table-header-menu/table-header-menu.component.ts +0 -35
  250. package/src/table-builder/directives/custom-cell-directive.ts +0 -59
  251. package/src/table-builder/directives/multi-sort.directive.spec.ts +0 -124
  252. package/src/table-builder/directives/multi-sort.directive.ts +0 -50
  253. package/src/table-builder/directives/resize-column.directive.ts +0 -107
  254. package/src/table-builder/directives/table-wrapper.directive.ts +0 -13
  255. package/src/table-builder/directives/tb-filter.directive.ts +0 -376
  256. package/src/table-builder/enums/filterTypes.ts +0 -40
  257. package/src/table-builder/functions/boolean-filter-function.ts +0 -12
  258. package/src/table-builder/functions/date-filter-function.ts +0 -68
  259. package/src/table-builder/functions/download-data.ts +0 -11
  260. package/src/table-builder/functions/null-filter-function.ts +0 -9
  261. package/src/table-builder/functions/number-filter-function.ts +0 -41
  262. package/src/table-builder/functions/sort-data-function.ts +0 -80
  263. package/src/table-builder/functions/string-filter-function.ts +0 -51
  264. package/src/table-builder/interfaces/column-template.ts +0 -9
  265. package/src/table-builder/interfaces/report-def.ts +0 -186
  266. package/src/table-builder/ngrx/tableBuilderStateStore.ts +0 -197
  267. package/src/table-builder/pipes/column-total.pipe.ts +0 -16
  268. package/src/table-builder/pipes/format-filter-type.pipe.ts +0 -12
  269. package/src/table-builder/pipes/format-filter-value.pipe.ts +0 -40
  270. package/src/table-builder/pipes/key-display.ts +0 -13
  271. package/src/table-builder/services/export-to-csv.service.ts +0 -75
  272. package/src/table-builder/services/link-creator.service.ts +0 -98
  273. package/src/table-builder/services/table-template-service.ts +0 -47
  274. package/src/table-builder/services/transform-creator.ts +0 -96
  275. package/src/table-builder/specs/table-custom-filters.spec.ts +0 -262
  276. package/src/table-builder/styles/collapser.styles.scss +0 -16
  277. package/src/table-builder/table-builder.module.ts +0 -38
  278. package/src/test.ts +0 -17
  279. package/src/utilities/array-helpers.ts +0 -13
  280. package/src/utilities/directives/auto-focus.directive.ts +0 -20
  281. package/src/utilities/directives/clickEmitterDirective.ts +0 -15
  282. package/src/utilities/directives/clickSubject.ts +0 -19
  283. package/src/utilities/directives/conditional-classes.directive.ts +0 -36
  284. package/src/utilities/directives/dialog-service.ts +0 -19
  285. package/src/utilities/directives/dialog.ts +0 -144
  286. package/src/utilities/directives/mat-toggle-group-directive.ts +0 -60
  287. package/src/utilities/directives/prevent-enter.directive.ts +0 -12
  288. package/src/utilities/directives/stop-propagation.directive.ts +0 -19
  289. package/src/utilities/directives/styler.ts +0 -44
  290. package/src/utilities/directives/trim-whitespace.directive.ts +0 -20
  291. package/src/utilities/module.ts +0 -55
  292. package/src/utilities/pipes/function.pipe.ts +0 -21
  293. package/src/utilities/pipes/phone.pipe.ts +0 -20
  294. package/src/utilities/pipes/space-case.pipes.spec.ts +0 -47
  295. package/src/utilities/pipes/space-case.pipes.ts +0 -26
  296. package/tsconfig.lib.json +0 -20
  297. package/tsconfig.lib.prod.json +0 -10
  298. package/tsconfig.spec.json +0 -17
@@ -1,80 +0,0 @@
1
- import { Predicate } from "@angular/core";
2
- import { TableBuilderSort } from "../components/table-container/table-container.helpers/sort-state.helpers";
3
-
4
- export function sortData<T>(data: T[], sorted: TableBuilderSort[]): T[] {
5
- return data.sort(compareT(sorted));
6
- }
7
-
8
- export function filterData<T>(data: T[], filters: Predicate<T>[], resetAll = false){
9
- if(filters.length === 0){
10
- if(resetAll){
11
- for (let index = 0; index < data.length; index++) {
12
- const element = data[index];
13
- element[tbNoShowSymbol] = false;
14
- }
15
- }
16
- return data;
17
- }
18
- for (let index = 0; index < data.length; index++) {
19
- const element = data[index];
20
- const hide = !filters.every(filter => filter(element));
21
- if(hide || resetAll){
22
- element[tbNoShowSymbol] = hide;
23
- }
24
- }
25
- return data;
26
- }
27
-
28
- export const tbNoShowSymbol = Symbol('tb_no_show');
29
-
30
- function compareT<T>(criteria: TableBuilderSort[]) {
31
- const transforms = criteria.reduce((acc, c) => {
32
- acc[c.active] = {
33
- transform: c.sortBy ? c.sortBy : getFactory(c.active), nulls: c.nulls === 'first' ? -1 : 1};
34
- return acc;
35
- }, {} as Record<string, { transform: (t: T) => any, nulls: 1 | -1}>);
36
-
37
- return function (a: T, b: T): number {
38
- for (let index = 0; index < criteria.length; index++) {
39
- const c = criteria[index];
40
- const d = transforms[c.active];
41
- const nullValue = d.nulls;
42
- if (a == null) {
43
- if (b == null) return 0;
44
- return nullValue;
45
- }
46
- if (b == null) return -nullValue;
47
- const transform = d.transform;
48
- const aVal = transform(a);
49
- const bVal = transform(b);
50
- if (aVal == null) {
51
- if (bVal == null) return 0;
52
- return nullValue;
53
- }
54
-
55
- if (bVal == null) return -nullValue;
56
- if (aVal < bVal) return c.direction === 'asc' ? -1 : 1;
57
- if (aVal > bVal) return c.direction === 'asc' ? 1 : -1;
58
- }
59
- return 0;
60
- }
61
- }
62
-
63
- export function getFactory(b: string){
64
- if(typeof b !== 'string') return (a) => a[b];
65
- if(!b.includes('.')) return (a) => {
66
- if(!a) return a;
67
- return a[b];
68
- };
69
- const arr = b.split('.');
70
- return (a) => {
71
- let val = a;
72
- if(!a) return a;
73
- for (let index = 0; index < arr.length; index++) {
74
- val = val[arr[index]];
75
- if(val == undefined) return undefined;
76
- if(typeof val !== 'object' && index + 1 < arr.length) return undefined;
77
- }
78
- return val;
79
- }
80
- }
@@ -1,51 +0,0 @@
1
- import { FilterFunc, FilterFuncs, FilterInfo } from '../classes/filter-info';
2
- import { EnumFilterTypes, FilterType, StringFilterTypes } from '../enums/filterTypes';
3
- import { isNull } from './null-filter-function';
4
-
5
-
6
- const stringEqualFunc:FilterFunc<string> = (filterInfo:FilterInfo) => {
7
- const equalsVal = prepareForStringCompare(filterInfo.filterValue);
8
- return ((val)=> prepareForStringCompare(val) === equalsVal );
9
- }
10
-
11
- const stringContainsFunc:FilterFunc<string> = (filterInfo:FilterInfo) => {
12
- const containsVal = prepareForStringCompare(filterInfo.filterValue);
13
- return ((val)=>prepareForStringCompare(val).includes(containsVal));
14
- }
15
-
16
- const stringDoesNotContainFunc:FilterFunc<string> = (filterInfo:FilterInfo) => {
17
- const doesNotContainVal = prepareForStringCompare(filterInfo.filterValue);
18
- return ((val)=> !prepareForStringCompare(val)?.includes(doesNotContainVal));
19
- }
20
-
21
- const stringStartsWithFunc:FilterFunc<string> = (filterInfo:FilterInfo) => {
22
- const startsWith = prepareForStringCompare(filterInfo.filterValue);
23
- return ((val)=> prepareForStringCompare(val).startsWith(startsWith));
24
- }
25
-
26
- const stringEndsWithFunc:FilterFunc<string> = (filterInfo:FilterInfo) => {
27
- const startsWith = prepareForStringCompare(filterInfo.filterValue);
28
- return ((val)=> prepareForStringCompare(val).endsWith(startsWith));
29
- }
30
-
31
- const multipleStringValuesEqualsFunc:FilterFunc<string[],string> = (filterInfo:FilterInfo) => {
32
- const filterVals = filterInfo.filterValue.map( (v: string) => prepareForStringCompare(v));
33
- return ((val)=> filterVals.some((s:string) => prepareForStringCompare(val) === s));
34
- }
35
-
36
- export const StringFilterFuncs: FilterFuncs<StringFilterTypes> = {
37
- [FilterType.StringEquals]: stringEqualFunc,
38
- [FilterType.StringContains]: stringContainsFunc,
39
- [FilterType.StringDoesNotContain]: stringDoesNotContainFunc,
40
- [FilterType.StringStartWith]: stringStartsWithFunc,
41
- [FilterType.StringEndsWith]: stringEndsWithFunc,
42
- [FilterType.IsNull]: isNull,
43
- [FilterType.In]: multipleStringValuesEqualsFunc,
44
- };
45
-
46
- export const EnumFilterFuncs: FilterFuncs<EnumFilterTypes> = {
47
- [FilterType.IsNull]: isNull,
48
- [FilterType.In] : multipleStringValuesEqualsFunc,
49
- };
50
-
51
- export const prepareForStringCompare = (val: any):string => (val?.toString().trim().toLowerCase());
@@ -1,9 +0,0 @@
1
- import { TemplateRef } from '@angular/core';
2
- import { MetaData } from './report-def';
3
-
4
- export class ColumnTemplates {
5
- header: TemplateRef<any>;
6
- footer: TemplateRef<any>;
7
- body: TemplateRef<any>;
8
- metaData: MetaData;
9
- }
@@ -1,186 +0,0 @@
1
- import { Dictionary } from './dictionary';
2
- import { PipeTransform, Predicate, TemplateRef } from '@angular/core';
3
- import { TableBuilderExport } from '../classes/TableBuilderConfig';
4
- import { QueryParamsHandling } from '@angular/router';
5
- import { StylerStyle } from '../../utilities/directives/styler';
6
-
7
-
8
- export enum FieldType {
9
- Unknown = 0,
10
- Date = 1,
11
- /**
12
- * @deprecated If `additional.link` is set the column will be treated as a link.
13
- */
14
- Link = 2,
15
- ImageUrl = 3,
16
- Currency = 4,
17
- Array = 5,
18
- Hidden = 6,
19
- Number = 7,
20
- String = 8,
21
- Boolean = 9,
22
- PhoneNumber = 10,
23
- /**
24
- * @deprecated For mapped properties use proper type (for sorting and filtering) with `map`.
25
- * For unmapped properties use `FieldType.NotMapped` with map.
26
- */
27
- Expression = 11,
28
- Enum = 12,
29
- DateTime = 13,
30
- NotMapped = 14,
31
- }
32
-
33
- export enum SortDirection {
34
- asc= 'asc',
35
- desc= 'desc'
36
- }
37
-
38
- export enum Target {
39
- Blank = '_blank',
40
- Self = '_self',
41
- Parent = '_parent',
42
- Top = '_top'
43
- }
44
-
45
- interface BaseMeta <T = any> {
46
- displayName?: string;
47
- additional?: Additional<T>;
48
- order?: number;
49
- preSort?: SortDef;
50
- sortLogic?: {
51
- /**
52
- * defaults to last
53
- */
54
- nulls?: 'first' | 'last';
55
- sortBy?: ((t: T) => any) | 'use map';
56
- }
57
- noSort?: boolean;
58
- width?: string;
59
- noExport?: boolean;
60
- filterLogic?: {
61
- filterBy?: ((t: T) => any) | 'use map';
62
- /**
63
- * defaults to the MetaData's Field type
64
- */
65
- filterType?: FieldType;
66
- },
67
- noFilter?: boolean;
68
- customCell?: boolean;
69
- /**
70
- * @deprecated Please use map instead
71
- */
72
- transform?: ((o: T, ...args: any[])=> any) | ((o: string, ...args: any[])=> any) | PipeTransform;
73
- click?: (element: T, key: string ) => void;
74
- template?: TemplateRef<any>;
75
- classes?: Dictionary<Predicate<T> | true>;
76
- toolTip?: string | ((t:T) => string);
77
- useIcon?: boolean;
78
- map? : (t:T) => any;
79
- }
80
- type Path<T, U = never, P = never> = (T extends P ? never : T extends object ?
81
- { [K in keyof T]: K extends string | number ? `${K}` | (T[K] extends (Array<any> | undefined) ? `${K}.${keyof Array<any> & (string | number)}` : `${K}.${Path<T[K], T[K], P | U >}`) : never; }[keyof T]
82
- : never)
83
-
84
- export interface MappedMetaData<T = any, AdditionalFields extends string[] = []> extends BaseMeta<T> {
85
- key: (Path<T> | AdditionalFields[number]) & string;
86
- fieldType: Exclude<typeof FieldType[keyof typeof FieldType], FieldType.NotMapped | FieldType.Expression>;
87
- /**
88
- * if used with map, `mapItem` will only be used where the row is not available, ex. group header
89
- */
90
- mapItem?: (i: string) => any;
91
- }
92
-
93
- export type MetaData<T = any, AdditionalFields extends string[] = []> = MappedMetaData<T, AdditionalFields> | NotMappedMetaData<T>;
94
-
95
- export interface NotMappedMetaData<T = any> extends BaseMeta<T> {
96
- key: string;
97
- fieldType: FieldType.NotMapped | FieldType.Expression;
98
- }
99
- export interface ReportDef<DataType = any> {
100
- data: DataType[];
101
- metaData: MetaData [];
102
- totalRecords?: number;
103
- count: number;
104
- }
105
-
106
- export interface SortDef {
107
- direction: SortDirection;
108
- precedence?: number;
109
- }
110
-
111
- export interface FilterOptions {
112
- filterableValues : string[]
113
- }
114
- export interface DateTimeOptions {
115
- format?: string;
116
- includeSeconds?: boolean;
117
- includeMilliseconds: boolean;
118
- }
119
- type interpolatedRoute = string;
120
- export interface Additional<T = any> {
121
- link? : {
122
- base?: string;
123
- urlKey?: string;
124
- target?: Target;
125
- useRouterLink?: boolean;
126
- /**
127
- * If you want to use a route with interpolated params, you can use this. Wrap the property name in curly braces.
128
- * For example, if interpolatedRoute = /users/{id}/edit, {id} will be replaced with the value of the element's id property.
129
- */
130
- interpolatedRoute?: interpolatedRoute | ((t: T) => string);
131
- routerLinkOptions?:{
132
- queryParams?: [string, interpolatedRoute | ((t: T) => string)][];
133
- fragment?: string;
134
- preserveFragment?: boolean;
135
- queryParamsHandling?: QueryParamsHandling;
136
- }
137
- }
138
- footer?: { type: 'sum' };
139
- export?: TableBuilderExport;
140
- dateFormat?: string;
141
- dateTimeOptions?: DateTimeOptions;
142
- filterOptions?: FilterOptions;
143
- styles?: StylerStyle<T>;
144
- columnPartStyles?: {
145
- header?: Dictionary<string>,
146
- body?: StylerStyle<T>,
147
- innerBody?: StylerStyle<T>,
148
- footer?: Dictionary<string>,
149
- }
150
- columnPartClasses?: {
151
- header?: Dictionary<Predicate<T> | true>,
152
- footer?: Dictionary<Predicate<T> | true>,
153
- }
154
- enumMap?: {[key:number]:string};
155
- boolean? : {
156
- showForFalse? : true | { icon : string },
157
- forTrue? : { icon : string }
158
- }
159
- }
160
-
161
- export enum ArrayStyle {
162
- CommaDelimited,
163
- NewLine
164
- }
165
-
166
- export interface ArrayAdditional extends Additional {
167
- limit?: number;
168
- arrayStyle?: ArrayStyle;
169
- }
170
-
171
-
172
-
173
- export function metaDataArrToDict<T = MetaData>(arr: MetaData[], transform?: (m : MetaData) => T): Dictionary<T>{
174
- const dict = {};
175
- if(transform){
176
- arr.forEach(e => dict[e.key] = transform(e));
177
- } else {
178
- arr.forEach(e => dict[e.key] = e);
179
- }
180
- return dict;
181
- }
182
-
183
- export interface CustomCellMeta extends Pick<MetaData, 'key' | 'displayName' | 'preSort' | 'fieldType' | 'order' | 'width'>{
184
- customCell: true;
185
- noExport?: boolean;
186
- }
@@ -1,197 +0,0 @@
1
- import { ComponentStore } from "@ngrx/component-store";
2
- import { Injectable, Signal } from "@angular/core";
3
- import { Dictionary } from "../interfaces/dictionary";
4
- import { PersistedTableState } from "../classes/TableState";
5
-
6
- @Injectable({ providedIn: 'root'})
7
- export class TableBuilderStateStore extends ComponentStore<GlobalStorageState> {
8
- constructor(){
9
- super(loadGlobalStorageState() || defaultStorageState)
10
- }
11
-
12
- //selectors
13
- $selectLocalTableProfile = (profileKey:string): Signal<Profile | undefined> => this.selectSignal(state =>
14
- state.localProfiles[profileKey]);
15
-
16
- $selectLocalTableStateForView = (tableId: string) => this.selectSignal(
17
- this.$selectLocalTableProfile(tableId),
18
- (profile) => {
19
- if(profile?.current) {
20
- return profile.states[profile.current];
21
- }
22
- if(profile?.localSavedState) return profile.localSavedState;
23
- return null;
24
- }
25
- )
26
-
27
- $selectLocalProfileCurrentKey = (key:string) => this.selectSignal(
28
- this.$selectLocalTableProfile(key),
29
- (profile) => profile?.current);
30
-
31
- $selectLocalProfileDefaultKey = (key:string) => this.selectSignal(
32
- this.$selectLocalTableProfile(key),
33
- (profile) => profile?.default);
34
-
35
- $selectLocalProfileKeys = (tableId:string) => this.selectSignal(
36
- this.$selectLocalTableProfile(tableId),
37
- (profile) => Object.keys(profile?.states || {})
38
- );
39
-
40
-
41
- // reducers
42
-
43
-
44
- saveTableSettingsToLocalAndStorage = (tableId: string, stateName: string, tableState: PersistedTableState, asDefault?: boolean) => {
45
- this.saveTableStateToStorage(tableId, stateName, tableState, asDefault);
46
- this.saveTableStateToLocal({ tableId, tableState, stateName, asDefault });
47
- }
48
-
49
- saveTableStateToLocal = this.updater((state, props: { tableId: string, tableState: PersistedTableState, stateName?: string, asDefault?: boolean }) => {
50
- let profile = state.localProfiles[props.tableId];
51
- if(!profile?.states) {
52
- profile = {states:{}};
53
- }
54
- if(!props.stateName){
55
- profile = {...profile, localSavedState: props.tableState };
56
- } else {
57
- profile = {...profile, states: {...profile.states, [props.stateName] : props.tableState} };
58
- }
59
- if(props.asDefault){
60
- profile.default = props.stateName;
61
- }
62
- return {...state, localProfiles: {...state.localProfiles, [props.tableId]: profile} }
63
- });
64
-
65
- saveTableStateToStorage = (tableId: string, stateName: string, tableState: PersistedTableState, asDefault = false) => {
66
- const globalSavedState: PersistedGlobalStorageSate = JSON.parse(localStorage.getItem('global-state-storage') ?? JSON.stringify(defaultStorageState) );
67
- globalSavedState.localProfiles[tableId] ??= { states : {}}
68
- globalSavedState.localProfiles[tableId].states[stateName] = tableState;
69
- if(asDefault){
70
- globalSavedState.localProfiles[tableId].default = stateName;
71
- }
72
- localStorage.setItem('global-state-storage', JSON.stringify( globalSavedState));
73
- }
74
-
75
- addNewStateToLocalAndStorage = (tableId: string, newStateName: string, tableState: PersistedTableState, asDefault?: boolean) => {
76
- this.saveTableSettingsToLocalAndStorage(tableId, newStateName, tableState, asDefault);
77
- this.setLocalCurrentState({ tableId: tableId, currentStateKey: newStateName});
78
- }
79
-
80
- setLocalCurrentState = this.updater((state, props: { tableId: string, currentStateKey: string }) => {
81
- const profile = state.localProfiles[props.tableId] || { states: {}};
82
- profile.current = props.currentStateKey;
83
- return {...state, localProfiles: {...state.localProfiles, [props.tableId]: {...profile}}};
84
- });
85
-
86
- setDefaultInLocalAndStorage = (tableId: string, newDefault: string) => {
87
- this.setDefaultInLocal({ default: newDefault, key: tableId });
88
- this.setDefaultInStorage(tableId, newDefault);
89
- }
90
-
91
- setDefaultInLocal = this.updater((state, props: { key: string, default: string }) => {
92
- if(state.localProfiles[props.key]?.states[props.default]) {
93
- return ({...state, localProfiles: {...state.localProfiles, [props.key]: {...state.localProfiles[props.key], default: props.default} } });
94
- }
95
- return state;
96
- });
97
-
98
- unsetDefaultFromLocalAndStorage = (tableId: string) => {
99
- this.unsetDefaultFromLocal(tableId);
100
- this.unsetDefaultFromStorage(tableId);
101
- }
102
-
103
- unsetDefaultFromLocal = (tableId: string) => {
104
- this.patchState(tables => {
105
- const profile = { ...tables.localProfiles[tableId] };
106
- if(profile) {
107
- delete profile.default;
108
- }
109
- return { ...tables, localProfiles: { ...tables.localProfiles, [tableId]: profile } };
110
- });
111
- }
112
-
113
- unsetDefaultFromStorage = (tableId: string) => {
114
- const globalSavedState: GlobalStorageState = JSON.parse(localStorage.getItem('global-state-storage') ?? JSON.stringify(defaultStorageState) );
115
- if(globalSavedState.localProfiles[tableId]) {
116
- delete globalSavedState.localProfiles[tableId].default;
117
- localStorage.setItem('global-state-storage', JSON.stringify( globalSavedState));
118
- }
119
- }
120
-
121
- setDefaultInStorage = (tableId: string, stateName: string) => {
122
- const tableProfile = this.$selectLocalTableProfile(tableId)();
123
- const globalSavedState: GlobalStorageState = JSON.parse(localStorage.getItem('global-state-storage') ?? JSON.stringify(defaultStorageState) );
124
- let savedProfile = globalSavedState.localProfiles[stateName];
125
- if(!savedProfile?.states) {
126
- savedProfile = { default: stateName, states : tableProfile!.states };
127
- } else {
128
- savedProfile.default = stateName;
129
- }
130
- globalSavedState.localProfiles[tableId] = savedProfile;
131
- localStorage.setItem('global-state-storage', JSON.stringify( globalSavedState));
132
- }
133
-
134
- deleteLocalProfilesState = this.updater((state, props: { key: string, stateKey: string }) => {
135
- let profile = state.localProfiles[props.key];
136
- if(profile) {
137
- const current = profile.current === props.stateKey ? profile.default : profile.current;
138
- profile = {...profile,current, states: { ...profile.states}};
139
- delete profile.states[props.stateKey];
140
- if(current === props.stateKey) {
141
- profile.current = undefined;
142
- }
143
- return {...state, localProfiles: {...state.localProfiles, [props.key]: profile} };
144
- } else {
145
- return state;
146
- }
147
- });
148
-
149
- deleteProfileFromLocalAndStorage = (key: string, stateKey: string) => {
150
- const globalSavedState: GlobalStorageState = JSON.parse(localStorage.getItem('global-state-storage') ?? JSON.stringify(defaultStorageState) );
151
- if(!globalSavedState.localProfiles[key]) {
152
- return;
153
- } else {
154
- delete (globalSavedState.localProfiles[key].states ?? {})[stateKey];
155
- }
156
- if(globalSavedState.localProfiles[key].default === stateKey) {
157
- globalSavedState.localProfiles[key].default = undefined;
158
- }
159
- localStorage.setItem('global-state-storage', JSON.stringify( globalSavedState));
160
- this.deleteLocalProfilesState({ key, stateKey })
161
- }
162
- }
163
-
164
- function loadGlobalStorageState() : GlobalStorageState | void {
165
- const storage = localStorage.getItem('global-state-storage');
166
-
167
- if(storage) {
168
- const s: GlobalStorageState = (JSON.parse(storage) as PersistedGlobalStorageSate);
169
- s.localProfiles ??= {};
170
- for(const key in s.localProfiles){
171
- const profile = s.localProfiles[key];
172
- s.localProfiles[key] = { ...profile, current: profile.default } as Profile
173
- }
174
- return {...defaultStorageState, ...s};
175
- }
176
- }
177
-
178
- interface PersistedProfile {
179
- states: Dictionary<PersistedTableState>;
180
- default?: string;
181
- }
182
- export interface Profile extends PersistedProfile {
183
- current?: string;
184
- localSavedState?: PersistedTableState;
185
- }
186
-
187
- export interface GlobalStorageState {
188
- localProfiles: Dictionary<Profile>;
189
- }
190
-
191
- interface PersistedGlobalStorageSate {
192
- localProfiles: Dictionary<PersistedProfile>;
193
- }
194
-
195
- export const defaultStorageState: GlobalStorageState = {
196
- localProfiles: {}
197
- }
@@ -1,16 +0,0 @@
1
- import { Pipe, PipeTransform } from '@angular/core';
2
- import { MetaData } from '../interfaces/report-def';
3
- import {sumBy} from 'lodash';
4
-
5
- @Pipe({
6
- name: 'columnTotal',
7
- })
8
- export class ColumnTotalPipe implements PipeTransform {
9
- transform(data: any[], metaData: MetaData) {
10
- const dataToCalculate = data.filter(d => !d.isGroupHeader)
11
- switch (metaData.additional!.footer!.type) {
12
- case 'sum':
13
- return sumBy(dataToCalculate, metaData.key);
14
- }
15
- }
16
- }
@@ -1,12 +0,0 @@
1
- import { Pipe, PipeTransform } from '@angular/core';
2
- import { FilterType } from '../enums/filterTypes';
3
-
4
- @Pipe({name: 'formatFilterType' })
5
- export class FormatFilterTypePipe implements PipeTransform {
6
- transform(filterType: FilterType, value: any){
7
- if(filterType === FilterType.IsNull){
8
- return value ? filterType : 'Is Not Blank'
9
- }
10
- return filterType;
11
- }
12
- }
@@ -1,40 +0,0 @@
1
- import { Pipe, PipeTransform, computed, inject } from '@angular/core';
2
- import { TableStore } from '../classes/table-store';
3
- import { FieldType, MetaData } from '../interfaces/report-def';
4
- import { DatePipe } from '@angular/common';
5
- import { FilterType } from '../enums/filterTypes';
6
- import { spaceCase } from '../../utilities/pipes/space-case.pipes';
7
- import { DateTimeFilterFuncs } from '../functions/date-filter-function';
8
-
9
-
10
- @Pipe({name: 'formatFilterValue' })
11
- export class FormatFilterValuePipe implements PipeTransform {
12
- tableState = inject(TableStore);
13
- private datePipe = inject(DatePipe);
14
-
15
- transform(value: any, key: string, filterType: FilterType) {
16
- return computed(() => transform(value, this.tableState.$getMetaData(key)(), filterType));
17
- }
18
- }
19
-
20
- const transform = (value: any, meta: MetaData, filterType: FilterType): string => {
21
- if(filterType === FilterType.IsNull) {
22
- return '';
23
- }
24
- if(value && (filterType === FilterType.In )){
25
- if(meta.fieldType === FieldType.Enum) {
26
- return value.map( (v: any) => spaceCase(meta.additional!.enumMap![v])).join(', ') ?? value;
27
- }
28
- return value.join(', ') ?? value;
29
- }
30
- if(filterType === FilterType.NumberBetween){
31
- return value.Start + ' - ' + value.End;
32
- }
33
- if(meta.fieldType === FieldType.Date){
34
- return new DatePipe('en-US').transform(value, 'MM/dd/yy') || '';
35
- }
36
- if(meta.fieldType === FieldType.DateTime){
37
- return (!!DateTimeFilterFuncs[filterType] ? new DatePipe('en-US').transform(value, 'short') : new DatePipe('en-US').transform(value, 'MM/dd/yy')) || '';
38
- }
39
- return value
40
- }
@@ -1,13 +0,0 @@
1
- import { Pipe, PipeTransform, computed, inject } from '@angular/core';
2
- import { TableStore } from '../classes/table-store';
3
- import { spaceCase } from '../../utilities/pipes/space-case.pipes';
4
- import { Observable } from 'rxjs';
5
- import { map } from 'rxjs/operators';
6
-
7
- @Pipe({name: 'keyDisplay' })
8
- export class KeyDisplayPipe implements PipeTransform {
9
- tableState = inject(TableStore);
10
-
11
- transform = (key: string) =>
12
- computed(() => this.tableState.$getMetaData(key)()?.displayName || spaceCase(key))
13
- }
@@ -1,75 +0,0 @@
1
- import { DatePipe } from '@angular/common';
2
- import { Injectable, inject } from '@angular/core';
3
- import { TableStore } from '../classes/table-store';
4
- import { TableBuilderConfigToken } from '../classes/TableBuilderConfig';
5
- import { downloadData } from '../functions/download-data';
6
- import { ArrayAdditional, ArrayStyle, FieldType, MetaData } from '../interfaces/report-def';
7
- import { isPipe } from './transform-creator';
8
- import { getFactory } from '../functions/sort-data-function';
9
-
10
- @Injectable()
11
- export class ExportToCsvService<T> {
12
- state = inject(TableStore);
13
- private config = inject(TableBuilderConfigToken);
14
- private datePipe = inject(DatePipe);
15
-
16
-
17
- exportToCsv = (data: T[]) => {
18
- const hiddenKeys = this.state.selectSignal(s => s.hiddenKeys)();
19
- const meta = this.state.$metaDataArray().filter(md => !md.noExport && !hiddenKeys.includes(md.key));
20
- const csv = this.csvData(data, meta);
21
- downloadData(csv,'export.csv', 'text/csv') ;
22
- }
23
-
24
- csvData = (data:Array<T>, metaData: MetaData<T>[]) => {
25
- const res = data.map(row => metaData.map(meta => this.metaToField(meta, row)).join(','));
26
- res.unshift(metaData.map(meta => meta.displayName || meta.key).join(','));
27
- return res.join('\n');
28
- }
29
-
30
- metaToField = (meta: MetaData<T>, row: T) => {
31
- let val: any = getFactory(meta.key)(row);
32
- if (val == null && !meta.transform) return val
33
- if(meta.transform && meta.fieldType !== FieldType.Expression){
34
- const transform = meta.transform as any;
35
- return isPipe(transform) ? transform.transform(val) : transform(val);
36
- }
37
- if(meta.map){
38
- return meta.map(row);
39
- }
40
- switch (meta.fieldType) {
41
- case FieldType.Date:
42
- const dateFormat = meta.additional?.export?.dateFormat || this.config?.export?.dateFormat || meta.additional?.dateFormat;
43
- val = this.transform(val, dateFormat);
44
- break;
45
- case FieldType.DateTime:
46
- const dateTimeFormat = meta.additional?.export?.dateTimeFormat || this.config?.export?.dateTimeFormat || meta.additional?.dateTimeOptions?.format;
47
- val = this.transform(val, dateTimeFormat);
48
- break;
49
- case FieldType.String:
50
- const prepend: string = meta.additional?.export?.prepend || this.config?.export?.prepend || '';
51
- val = prepend + val;
52
- break;
53
- case FieldType.Array:
54
- const style = (meta.additional as ArrayAdditional).arrayStyle ?? this.config.arrayDefaults?.arrayStyle;
55
- const limit = (meta.additional as ArrayAdditional).limit ?? this.config.arrayDefaults?.limit;
56
- val = (val as Array<string>).slice(0, limit).join(style === ArrayStyle.NewLine ? '\n' : ', ');
57
- break;
58
- case FieldType.Expression:
59
- val = (meta.transform as any)(row);
60
- break;
61
- }
62
- if (typeof val === 'string' && (val.includes(',') || val.includes('"') || val.includes('\n'))) {
63
- val = val.replaceAll('"', '""');
64
- val = '"' + val + '"';
65
- }
66
- return val;
67
- }
68
-
69
- private transform(val: any, dateFormat: any) {
70
- if (this.config.transformers && this.config.transformers[FieldType.Date]) {
71
- return this.config.transformers[FieldType.Date]!(val);
72
- }
73
- return this.datePipe.transform(val, dateFormat);
74
- }
75
- }