@one-paragon/angular-utilities 2.2.6 → 2.2.7

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 (297) 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 +6565 -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 +10 -0
  13. package/http-request-state/directives/http-inProgress-state-directive.d.ts +10 -0
  14. package/http-request-state/directives/http-notStarted-state-directive.d.ts +10 -0
  15. package/http-request-state/directives/http-success-state-directive.d.ts +17 -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 +31 -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 +122 -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 +22 -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 +85 -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 +11 -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.component.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 +229 -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 +22 -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 +9 -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 -7
  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 -14
  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 -66
  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 -50
  171. package/src/table-builder/classes/TableBuilderDataSource.ts +0 -64
  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 -125
  175. package/src/table-builder/classes/table-builder-general-settings.ts +0 -205
  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 -87
  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 -110
  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 -25
  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 -11
  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 -109
  193. package/src/table-builder/components/filter/filter.component.scss +0 -60
  194. package/src/table-builder/components/filter/filter.component.spec.ts +0 -86
  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 -102
  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 -97
  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 -403
  203. package/src/table-builder/components/generic-table/paginator.component.ts +0 -112
  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 -25
  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 -23
  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 -25
  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 -77
  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 -115
  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.component.html +0 -81
  231. package/src/table-builder/components/table-container/table-container.component.ts +0 -403
  232. package/src/table-builder/components/table-container/table-container.helpers/data-state.helpers.ts +0 -113
  233. package/src/table-builder/components/table-container/table-container.helpers/filter-state.helpers.ts +0 -125
  234. package/src/table-builder/components/table-container/table-container.helpers/groupBy.helpers.ts +0 -122
  235. package/src/table-builder/components/table-container/table-container.helpers/meta-data.helpers.ts +0 -16
  236. package/src/table-builder/components/table-container/table-container.helpers/sort-state.helpers.ts +0 -47
  237. package/src/table-builder/components/table-container/table-container.scss +0 -47
  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 -35
  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 -40
  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 -50
  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 -57
  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 -78
  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 -53
  264. package/src/table-builder/interfaces/report-def.ts +0 -254
  265. package/src/table-builder/ngrx/tableBuilderStateStore.ts +0 -197
  266. package/src/table-builder/pipes/column-total.pipe.ts +0 -16
  267. package/src/table-builder/pipes/format-filter-type.pipe.ts +0 -12
  268. package/src/table-builder/pipes/format-filter-value.pipe.ts +0 -67
  269. package/src/table-builder/pipes/key-display.ts +0 -13
  270. package/src/table-builder/services/export-to-csv.service.ts +0 -113
  271. package/src/table-builder/services/link-creator.service.ts +0 -98
  272. package/src/table-builder/services/table-template-service.ts +0 -47
  273. package/src/table-builder/services/transform-creator.ts +0 -96
  274. package/src/table-builder/specs/table-custom-filters.spec.ts +0 -262
  275. package/src/table-builder/styles/collapser.styles.scss +0 -16
  276. package/src/table-builder/table-builder.module.ts +0 -38
  277. package/src/test.ts +0 -17
  278. package/src/utilities/array-helpers.ts +0 -13
  279. package/src/utilities/directives/auto-focus.directive.ts +0 -20
  280. package/src/utilities/directives/clickEmitterDirective.ts +0 -15
  281. package/src/utilities/directives/clickSubject.ts +0 -19
  282. package/src/utilities/directives/conditional-classes.directive.ts +0 -36
  283. package/src/utilities/directives/dialog-service.ts +0 -19
  284. package/src/utilities/directives/dialog.ts +0 -144
  285. package/src/utilities/directives/mat-toggle-group-directive.ts +0 -60
  286. package/src/utilities/directives/prevent-enter.directive.ts +0 -12
  287. package/src/utilities/directives/stop-propagation.directive.ts +0 -19
  288. package/src/utilities/directives/styler.ts +0 -44
  289. package/src/utilities/directives/trim-whitespace.directive.ts +0 -20
  290. package/src/utilities/module.ts +0 -53
  291. package/src/utilities/pipes/function.pipe.ts +0 -21
  292. package/src/utilities/pipes/phone.pipe.ts +0 -20
  293. package/src/utilities/pipes/space-case.pipes.spec.ts +0 -47
  294. package/src/utilities/pipes/space-case.pipes.ts +0 -26
  295. package/tsconfig.lib.json +0 -20
  296. package/tsconfig.lib.prod.json +0 -10
  297. package/tsconfig.spec.json +0 -17
@@ -1,376 +0,0 @@
1
- import { Directive, Input, Predicate, Signal, SimpleChanges, inject, OnChanges, OnInit, OnDestroy } from "@angular/core";
2
- import { Observable, ReplaySubject, takeUntil, tap } from "rxjs";
3
- import { CustomFilter, FilterInfo } from "../classes/filter-info";
4
- import { FilterType } from "../enums/filterTypes";
5
- import { MatSlideToggle } from "@angular/material/slide-toggle";
6
- import { MatRadioButton } from "@angular/material/radio";
7
- import { MatButtonToggle } from '@angular/material/button-toggle';
8
- import { MatCheckbox } from "@angular/material/checkbox";
9
- import { FieldType } from "../interfaces/report-def";
10
- import { NgControl } from "@angular/forms";
11
- import { TableWrapperDirective } from "./table-wrapper.directive";
12
- import { MatOption } from "@angular/material/core";
13
- import { subscriber } from "../../rxjs";
14
- import { toSignal } from "@angular/core/rxjs-interop";
15
-
16
-
17
- const inputs = [
18
- 'predicate: tbCustomFilter',
19
- 'filterId: filterId',
20
- ];
21
-
22
-
23
- @Directive({
24
- selector: 'tb-abstract'
25
- })
26
- export abstract class TableCustomFilterDirective {
27
- abstract filter$ : Observable<CustomFilter>;
28
- abstract $filter: Signal<CustomFilter | undefined>;
29
- filterId!: string;
30
- savable = false;
31
- abstract active: boolean;
32
- abstract reset(): void;
33
- }
34
-
35
-
36
- @Directive({
37
- selector: "[tbFilter]",
38
- }) export class TableFilterDirective implements OnChanges, OnInit {
39
- protected model = inject(NgControl, { optional: true });
40
- private wrapper = inject(TableWrapperDirective, { optional: true });
41
- constructor() {
42
- if(this.wrapper) {
43
- this.wrapper.register(this);
44
- }
45
- if(this.model) {
46
- subscriber(this.model!.valueChanges!, val => {
47
- if(this.filterType === FilterType.StringContains && val === ''){
48
- val = undefined
49
- }
50
- this.filterValue = val;
51
- this.update();
52
- })
53
- }
54
- }
55
- reset() {
56
- this.filterValue = undefined;
57
- }
58
- filter$ = new ReplaySubject<FilterInfo>(1);
59
- $filter = toSignal(this.filter$);
60
-
61
- @Input() filterType!: FilterType;
62
- @Input() key!: string;
63
- @Input() fieldType!: FieldType;
64
- @Input() filterId!: string;
65
- @Input() active = true;
66
- @Input() filterValue: any = null;
67
-
68
- setFilterValue(value: any) {
69
- if(this.model) {
70
- setTimeout(() => {
71
- this.model!.reset(value);
72
- }, 0);
73
- } else {
74
- this.filterValue = value;
75
- }
76
- }
77
-
78
- savable = false;
79
- ready = false;
80
-
81
- _userActive = true;
82
- ngOnChanges(changes: SimpleChanges) {
83
- this.update();
84
- }
85
-
86
- ngOnInit() {
87
- if(!this.filterId) {
88
- this.filterId = crypto.randomUUID();
89
- } else {
90
- this.savable = true;
91
- }
92
- this.ready = true;
93
- this.update();
94
- }
95
-
96
- protected setFilter(filter: FilterInfo ) {
97
- this.filter$.next(filter);
98
- }
99
-
100
- update() {
101
- if(this.ready) {
102
- this.setFilter(
103
- {
104
- filterId: this.filterId,
105
- key: this.key,
106
- filterType: this.filterType,
107
- fieldType: this.fieldType,
108
- filterValue: this.filterValue,
109
- active: this.active && this.filterValue !== undefined,
110
- _isExternallyManaged: true,
111
- }
112
- );
113
-
114
- }
115
- }
116
- }
117
-
118
- @Directive({
119
- selector: '[tbFilterStringContains]',
120
- providers: [{ provide: TableFilterDirective, useExisting: TableFilterStringContainsDirective }],
121
- inputs: [
122
- 'key:tbFilterStringContains',
123
- 'filterValue:filterValue',
124
- 'filterId: filterId',
125
- 'active: active',
126
- ],
127
- }) export class TableFilterStringContainsDirective extends TableFilterDirective implements OnChanges {
128
- constructor() {
129
- super();
130
- this.filterType = FilterType.StringContains;
131
- this.fieldType = FieldType.String;
132
- }
133
-
134
- override reset() {
135
- if(this.model) {
136
- this.model.reset();
137
- }
138
- super.reset();
139
- }
140
-
141
- override setFilter(filter: FilterInfo) {
142
- filter.active = filter.filterValue && this._userActive;
143
- super.setFilter(filter);
144
- }
145
-
146
- ngOnChanges(changes: SimpleChanges) {
147
- if(changes['active']) {
148
- this._userActive = changes['active'].currentValue;
149
- }
150
- super.ngOnChanges(changes);
151
- }
152
- }
153
-
154
- @Directive({
155
- selector: "[tbCustomFilter]",
156
- })
157
- export abstract class TableCustomFilterDirectiveBase<T = any> extends TableCustomFilterDirective implements OnInit {
158
-
159
- filter$ = new ReplaySubject<CustomFilter>(1);
160
- $filter = toSignal(this.filter$);
161
- filter!: CustomFilter;
162
-
163
- _predicate!: Predicate<T>;
164
- @Input('tbCustomFilter') set predicate( val: Predicate<T> ) {
165
- this._predicate = val;
166
- this.update({ predicate: val });
167
- }
168
-
169
- _active: boolean = false;
170
- ready = false;
171
-
172
- update(val: Partial<CustomFilter> ) {
173
- if(this.ready) {
174
- this.filter = { ...this.filter, ...val };
175
- this.filter$.next(this.filter);
176
- }
177
- }
178
-
179
- @Input() set active(val: boolean) {
180
- if(this._active !== val) {
181
- this._active = val;
182
- this.update({ active: val });
183
- }
184
- }
185
- get active(): boolean {
186
- return this._active;
187
- }
188
-
189
- ngOnInit() {
190
- if(!this.filterId) {
191
- this.filterId = crypto.randomUUID();
192
- } else {
193
- this.savable = true;
194
- }
195
-
196
- this.filter = {
197
- filterType: FilterType.Custom,
198
- filterId: this.filterId,
199
- active: this._active,
200
- predicate: this._predicate,
201
- };
202
- this.ready = true;
203
- this.filter$.next(this.filter);
204
- }
205
- }
206
-
207
- @Directive()
208
- export abstract class TbSelectedFilterDirective extends TableCustomFilterDirectiveBase implements OnDestroy, OnInit {
209
-
210
- protected wrapper = inject(TableWrapperDirective, { optional: true });
211
- protected constructor(private change: Observable<any>, private isActive: () => boolean) {
212
- super();
213
- if(this.wrapper) {
214
- this.wrapper.register(this);
215
- }
216
- }
217
-
218
- reset() {
219
- this.active = false;
220
- }
221
-
222
- destroySubject$ = new ReplaySubject<void>(1);
223
- ngOnDestroy() {
224
- this.destroySubject$.next();
225
- }
226
-
227
- ngOnInit(): void {
228
- this._active = this.isActive();
229
- super.ngOnInit();
230
- this.change.pipe(takeUntil(this.destroySubject$)).subscribe( () => {
231
- this.active = this.isActive();
232
- });
233
- }
234
- }
235
-
236
- // Checkbox
237
- @Directive({
238
- selector: 'mat-checkbox[tbCustomFilter]',
239
- inputs: [
240
- ...inputs
241
- ],
242
- providers: [{ provide: TableCustomFilterDirective, useExisting: MatCheckboxTbFilterDirective }],
243
- })
244
- export class MatCheckboxTbFilterDirective extends TbSelectedFilterDirective {
245
- private matCheckbox = inject(MatCheckbox);
246
-
247
-
248
- override set active(val: boolean) {
249
- this.matCheckbox.checked = val;
250
- super.active = val;
251
- }
252
- constructor() {
253
- const matCheckbox = inject(MatCheckbox);
254
- super(matCheckbox.change, () => matCheckbox.checked);
255
- this.matCheckbox = matCheckbox;
256
- }
257
- }
258
-
259
-
260
- @Directive({
261
- selector: 'mat-slide-toggle[tbCustomFilter]',
262
- inputs: [
263
- ...inputs
264
- ],
265
- providers: [{ provide: TableCustomFilterDirective, useExisting: MatSlideToggleTbFilterDirective }],
266
- })
267
- export class MatSlideToggleTbFilterDirective extends TbSelectedFilterDirective implements OnInit {
268
- private matSlideToggle: MatSlideToggle;
269
-
270
- override set active(val: boolean) {
271
- this.matSlideToggle.checked = val;
272
- super.active = val;
273
- }
274
- constructor() {
275
- const matSlideToggle = inject(MatSlideToggle);
276
-
277
- super(matSlideToggle.change, () => matSlideToggle.checked);
278
- this.matSlideToggle = matSlideToggle;
279
-
280
- }
281
-
282
- ngOnInit(): void {
283
- super.ngOnInit();
284
- }
285
- }
286
-
287
- // Radio button
288
- @Directive({
289
- selector: 'mat-radio-button[tbCustomFilter]',
290
- inputs: ['predicate: tbCustomFilter'],
291
- providers: [{ provide: TableCustomFilterDirective, useExisting: MatRadioButtonTbFilterDirective }],
292
- })
293
- export class MatRadioButtonTbFilterDirective extends TbSelectedFilterDirective implements OnInit {
294
- private matRadioButton: MatRadioButton;
295
-
296
-
297
- override set active(val: boolean) {
298
- this.matRadioButton.checked = val;
299
- super.active = val;
300
- }
301
- constructor() {
302
- const matRadioButton = inject(MatRadioButton);
303
-
304
- super(matRadioButton.change, () => matRadioButton.checked);
305
- this.matRadioButton = matRadioButton;
306
- }
307
-
308
- ngOnInit(): void {
309
- super.ngOnInit();
310
- }
311
- }
312
-
313
- // Option (select)
314
- @Directive({
315
- selector: 'mat-option[tbCustomFilter]',
316
- inputs: [
317
- ...inputs
318
- ],
319
- providers: [{ provide: TableCustomFilterDirective, useExisting: MatOptionTbFilterDirective }],
320
- })
321
- export class MatOptionTbFilterDirective extends TbSelectedFilterDirective implements OnInit {
322
- private matOption: MatOption;
323
-
324
- override set active(val: boolean) {
325
- if(val) {
326
- this.matOption.select();
327
- } else {
328
- this.matOption.deselect();
329
- }
330
- super.active = val;
331
- }
332
- constructor() {
333
- const matOption = inject(MatOption);
334
-
335
- super( matOption.onSelectionChange.pipe(tap( d => {
336
- if(!matOption.value) {
337
- matOption.value = crypto.randomUUID();
338
- }
339
- }
340
-
341
- )), () => matOption.selected);
342
- this.matOption = matOption;
343
- }
344
-
345
- ngOnInit(): void {
346
- super.ngOnInit();
347
- }
348
- }
349
-
350
- // Button toggle
351
- @Directive({
352
- selector: 'mat-button-toggle[tbCustomFilter]',
353
- inputs: [
354
- ...inputs
355
- ],
356
- providers: [{ provide: TableCustomFilterDirective, useExisting: MatButtonToggleFilterDirective }],
357
- })
358
- export class MatButtonToggleFilterDirective extends TbSelectedFilterDirective implements OnInit {
359
- private matButtonToggle: MatButtonToggle;
360
-
361
- override set active(val: boolean) {
362
- this.matButtonToggle.checked = val;
363
- super.active = val;
364
- }
365
- constructor() {
366
- const matButtonToggle = inject(MatButtonToggle);
367
-
368
- super(matButtonToggle.change, () => matButtonToggle.checked);
369
- this.matButtonToggle = matButtonToggle;
370
-
371
- }
372
-
373
- ngOnInit(): void {
374
- super.ngOnInit();
375
- }
376
- }
@@ -1,40 +0,0 @@
1
-
2
- export const FilterType = {
3
- NumberEquals: 'Equals',
4
- NumberNotEqual: 'Does Not Equal',
5
- NumberGreaterThan: 'Greater Than',
6
- NumberLessThan: 'Less Than',
7
- NumberBetween: 'Between',
8
- StringEquals: 'Equals',
9
- StringContains: 'Contains',
10
- StringDoesNotContain: 'Does Not Contain',
11
- StringStartWith: 'Start With',
12
- StringEndsWith: 'Ends With',
13
- DateIsOn: 'Is on',
14
- DateIsNotOn: 'Is Not On',
15
- DateOnOrAfter: 'On or After',
16
- DateOnOrBefore: 'On or Before',
17
- DateBetween: 'Between',
18
- DateTimeIsAt: 'Is At',
19
- DateTimeIsNotAt: 'Is Not At',
20
- DateTimeAtOrAfter: 'At or After',
21
- DateTimeAtOrBefore: 'At or Before',
22
- DateTimeBetween: 'Between',
23
- BooleanEquals: 'Is',
24
- IsNull: 'Is Blank',
25
- Or: 'Or',
26
- And: 'And',
27
- In: 'In',
28
- Custom: 'Custom',
29
- } as const;
30
-
31
- export type FilterType = typeof FilterType[keyof typeof FilterType];
32
-
33
- export type SubFilterTypes<T extends typeof FilterType[keyof typeof FilterType]> = T;
34
-
35
- export type StringFilterTypes = SubFilterTypes<'Equals' | 'Contains' | 'Does Not Contain' | 'Start With' | 'Ends With' | 'Is Blank' | 'In'>;
36
- export type NumberFilterTypes = SubFilterTypes<'Equals' | 'Does Not Equal' | 'Greater Than' | 'Less Than' | 'Between' | 'Is Blank' | 'In'>;
37
- export type DateFilterTypes = SubFilterTypes<'Is on' | 'Is Not On' | 'On or After' | 'On or Before' | 'Between' | 'Is Blank' | 'In'>;
38
- export type DateTimeFilterTypes = SubFilterTypes<'Is At' | 'Is Not At' | 'At or After' | 'At or Before' | 'Between' | DateFilterTypes>;
39
- export type BooleanFilterTypes = SubFilterTypes<'Is' | 'Is Blank'>;
40
- export type EnumFilterTypes = SubFilterTypes<'In' | 'Is Blank'>;
@@ -1,12 +0,0 @@
1
- import { FilterFunc, FilterFuncs, FilterInfo } from '../classes/filter-info';
2
- import { BooleanFilterTypes, FilterType } from '../enums/filterTypes';
3
- import { isNull } from './null-filter-function';
4
-
5
- const booleanEqualsFunc : FilterFunc<boolean> = (filterInfo:FilterInfo) => (val): boolean => {
6
- return filterInfo.filterValue === val;
7
- }
8
-
9
- export const BooleanFilterFuncs: FilterFuncs<BooleanFilterTypes> = {
10
- [FilterType.BooleanEquals]: booleanEqualsFunc,
11
- [FilterType.IsNull]: isNull,
12
- };
@@ -1,78 +0,0 @@
1
- import { FilterFunc, FilterFuncs, FilterInfo, Range } from '../classes/filter-info';
2
- import { DateFilterTypes, DateTimeFilterTypes, FilterType } from '../enums/filterTypes';
3
- import { FieldType } from '../interfaces/report-def';
4
- import { isNull } from './null-filter-function';
5
-
6
-
7
- const dateIsOnFunc: FilterFunc<Date> = (filterInfo:FilterInfo) => {
8
- const isOnVal = new Date( filterInfo.filterValue).getTime();
9
- const clean = filterInfo.fieldType === FieldType.Date ? (a, b) => b : cleanDateTime
10
- return ((val) => clean(filterInfo, val).getTime() === isOnVal);
11
- }
12
-
13
- const dateIsNotOnFunc: FilterFunc<Date> = (filterInfo:FilterInfo) => {
14
- const isNotOnVal = new Date( filterInfo.filterValue).getTime();
15
- const clean = filterInfo.fieldType === FieldType.Date ? (a, b) => b : cleanDateTime
16
- return ((val) => clean(filterInfo, val).getTime() !== isNotOnVal);
17
- }
18
-
19
- const dateIsOnOrAfterFunc: FilterFunc<Date> = (filterInfo:FilterInfo) => {
20
- const afterVal = new Date( filterInfo.filterValue).getTime();
21
- const clean = filterInfo.fieldType === FieldType.Date ? (a, b) => b : cleanDateTime
22
- return ((val) => clean(filterInfo, val).getTime() >= afterVal);
23
- }
24
-
25
- const dateIsOnOrBeforeFunc: FilterFunc<Date> = (filterInfo:FilterInfo) => {
26
- const beforeVal = new Date( filterInfo.filterValue).getTime();
27
- const clean = filterInfo.fieldType === FieldType.Date ? (a, b) => b : cleanDateTime
28
- return ((val) => clean(filterInfo, val).getTime() <= beforeVal);
29
- }
30
-
31
- const dateIsInFunc: FilterFunc<Date[], Date> = (filterInfo:FilterInfo) => {
32
- const filterVals = (filterInfo.filterValue as Date[]).map(v => new Date(v).getTime());
33
- const clean = filterInfo.fieldType === FieldType.Date ? (a, b) => b : cleanDateTime
34
- return ((val) => {
35
- const d = clean(filterInfo, val).getTime();
36
- return filterVals.some((f) => f === d)});
37
- }
38
-
39
- const dateBetweenFunc: FilterFunc<Range<Date>, Date> = (filterInfo:FilterInfo) => {
40
- const startVal = new Date(filterInfo.filterValue.Start);
41
- const endVal = new Date(filterInfo.filterValue.End);
42
- const clean = filterInfo.fieldType === FieldType.Date ? (a, b) => b : cleanDateTime
43
- return (
44
- (val) => {
45
- const cleanedVal = clean(filterInfo, val);
46
- return cleanedVal >= startVal && cleanedVal <= endVal;
47
- });
48
- }
49
-
50
- const cleanDateTime = (filterInfo:FilterInfo, val: Date) => {
51
- if(!!DateFilterFuncs[filterInfo.filterType]){
52
- const d = new Date(val);
53
- d.setHours(0, 0, 0, 0);
54
- return d;
55
- }
56
- return val;
57
- }
58
-
59
- export const DateFilterFuncs: FilterFuncs<DateFilterTypes> = {
60
- [FilterType.DateIsOn]: dateIsOnFunc,
61
- [FilterType.DateIsNotOn]: dateIsNotOnFunc,
62
- [FilterType.DateOnOrAfter]: dateIsOnOrAfterFunc,
63
- [FilterType.DateOnOrBefore]: dateIsOnOrBeforeFunc,
64
- [FilterType.DateBetween]: dateBetweenFunc,
65
- [FilterType.In]: dateIsInFunc,
66
- [FilterType.IsNull]: isNull,
67
- };
68
-
69
- export const DateTimeFilterFuncs: FilterFuncs<DateTimeFilterTypes> = {
70
- ...DateFilterFuncs,
71
- [FilterType.DateTimeIsAt]: dateIsOnFunc,
72
- [FilterType.DateTimeIsNotAt]: dateIsNotOnFunc,
73
- [FilterType.DateTimeAtOrAfter]: dateIsOnOrAfterFunc,
74
- [FilterType.DateTimeAtOrBefore]: dateIsOnOrBeforeFunc,
75
- [FilterType.DateTimeBetween]: dateBetweenFunc,
76
- [FilterType.In]: dateIsInFunc,
77
- [FilterType.IsNull]: isNull,
78
- };
@@ -1,11 +0,0 @@
1
- export function downloadData(data: string, filename: string, mimeType: string) {
2
- const url = URL.createObjectURL(new Blob([data], { type: mimeType }));
3
- const downloadLink = document.createElement('a');
4
- downloadLink.download = filename;
5
- downloadLink.href = url;
6
- downloadLink.style.display = 'none';
7
- document.body.appendChild(downloadLink);
8
- downloadLink.click();
9
- document.body.removeChild(downloadLink);
10
- URL.revokeObjectURL(url);
11
- }
@@ -1,9 +0,0 @@
1
- import { FilterFunc, FilterInfo } from '../classes/filter-info';
2
-
3
- export const isNull:FilterFunc<boolean, any> = (filterInfo:FilterInfo) => {
4
- const func = filterInfo.filterValue ?
5
- (val: any) => val == null || val === ''
6
- :
7
- (val: any) => val != null && val !== '';
8
- return func;
9
- }
@@ -1,41 +0,0 @@
1
- import { Range, FilterFunc, FilterInfo, FilterFuncs } from '../classes/filter-info';
2
- import { FilterType, NumberFilterTypes } from '../enums/filterTypes';
3
- import { isNull } from './null-filter-function';
4
-
5
- type NumberFilterFunc = FilterFunc<number>
6
-
7
- const numberEqalsFunc:NumberFilterFunc = (filterInfo : FilterInfo<number>) => (val: number): boolean => {
8
- return val === filterInfo.filterValue;
9
- }
10
-
11
- const numberNotEqualFunc:NumberFilterFunc = (filterInfo : FilterInfo<number>) => (val: number): boolean => {
12
- return val !== filterInfo.filterValue;
13
- }
14
-
15
- const numberGreaterThanFunc:NumberFilterFunc = (filterInfo : FilterInfo<number>) => (val: number): boolean => {
16
- return val > filterInfo.filterValue;
17
- }
18
-
19
- const numberLessThanFunc:NumberFilterFunc = (filterInfo : FilterInfo<number>) => (val: number): boolean => {
20
- return val < filterInfo.filterValue;
21
- }
22
-
23
- const numberBetweenFunc:FilterFunc<Range<number>, number> = (filterInfo : FilterInfo) => {
24
- const startVal = Number(filterInfo.filterValue.Start);
25
- const endVal = Number(filterInfo.filterValue.End);
26
- return ((val) => (val > startVal) && (val < endVal));
27
- }
28
-
29
- export const multipleNumberValuesEqualsFunc:FilterFunc<number[], number> = (filterInfo:FilterInfo) => {
30
- return ((val) => filterInfo.filterValue.some((value: any) => val === value));
31
- }
32
-
33
- export const NumberFilterFuncs: FilterFuncs<NumberFilterTypes> = {
34
- [FilterType.NumberEquals]: numberEqalsFunc,
35
- [FilterType.NumberNotEqual]: numberNotEqualFunc,
36
- [FilterType.NumberGreaterThan]: numberGreaterThanFunc,
37
- [FilterType.NumberLessThan]: numberLessThanFunc,
38
- [FilterType.NumberBetween]: numberBetweenFunc,
39
- [FilterType.IsNull]: isNull,
40
- [FilterType.In]: multipleNumberValuesEqualsFunc,
41
- };
@@ -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
- }