@one-paragon/angular-utilities 1.2.16 → 1.2.18

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (407) hide show
  1. package/karma.conf.js +44 -0
  2. package/ng-package.json +7 -0
  3. package/package.json +16 -30
  4. package/src/action-state/action-state-spinner/action-state-spinner.component.css +16 -0
  5. package/src/action-state/action-state-spinner/action-state-spinner.component.html +6 -0
  6. package/src/action-state/action-state-spinner/action-state-spinner.component.spec.ts +25 -0
  7. package/src/action-state/action-state-spinner/action-state-spinner.component.ts +26 -0
  8. package/src/action-state/action-state-ui/action-state-ui.module.ts +13 -0
  9. package/{action-state/index.d.ts → src/action-state/index.ts} +8 -4
  10. package/src/action-state/ngrx-ext/ngrx-ext.module.ts +15 -0
  11. package/src/action-state/ngrx.ts +69 -0
  12. package/src/http-request-state/HttpRequestStateFactory.ts +66 -0
  13. package/src/http-request-state/HttpRequestStateStore.ts +191 -0
  14. package/src/http-request-state/directives/HttpStateDirectiveBase.ts +29 -0
  15. package/src/http-request-state/directives/http-error-state-directive.ts +21 -0
  16. package/src/http-request-state/directives/http-inProgress-state-directive.ts +19 -0
  17. package/src/http-request-state/directives/http-notStarted-state-directive.ts +19 -0
  18. package/src/http-request-state/directives/http-success-state-directive.ts +29 -0
  19. package/{http-request-state/directives/index.d.ts → src/http-request-state/directives/index.ts} +5 -5
  20. package/src/http-request-state/directives/request-state-directive.spec.ts +72 -0
  21. package/src/http-request-state/directives/request-state-directive.ts +78 -0
  22. package/src/http-request-state/helpers.ts +30 -0
  23. package/src/http-request-state/http-request-state.ts +69 -0
  24. package/src/http-request-state/http-state-module.ts +23 -0
  25. package/{http-request-state/index.d.ts → src/http-request-state/index.ts} +6 -6
  26. package/src/http-request-state/observable.spec.ts +43 -0
  27. package/src/http-request-state/rxjs/getRequestorBody.ts +10 -0
  28. package/src/http-request-state/rxjs/getRequestorState.ts +8 -0
  29. package/{http-request-state/rxjs/index.d.ts → src/http-request-state/rxjs/index.ts} +4 -4
  30. package/src/http-request-state/rxjs/tapError.ts +16 -0
  31. package/src/http-request-state/rxjs/tapSuccess.ts +16 -0
  32. package/src/http-request-state/strategies.spec.ts +42 -0
  33. package/src/http-request-state/types.ts +55 -0
  34. package/src/ngrx/actionable-selector.ts +152 -0
  35. package/src/ngrx/index.ts +1 -0
  36. package/{public-api.d.ts → src/public-api.ts} +35 -16
  37. package/src/rxjs/defaultShareReplay.ts +8 -0
  38. package/{rxjs/index.d.ts → src/rxjs/index.ts} +5 -5
  39. package/src/rxjs/mapError.ts +8 -0
  40. package/src/rxjs/rxjs-operators.ts +132 -0
  41. package/src/rxjs/subjectifier.ts +17 -0
  42. package/src/rxjs/subscriber.directive.ts +57 -0
  43. package/src/specs/clickSubject.spec.ts +95 -0
  44. package/src/specs/dialog.spec.ts +101 -0
  45. package/src/specs/toggleGroupDirective.spec.ts +229 -0
  46. package/src/table-builder/classes/DefaultSettings.ts +11 -0
  47. package/src/table-builder/classes/MatTableObservableDataSource.ts +23 -0
  48. package/src/table-builder/classes/TableBuilderConfig.ts +36 -0
  49. package/src/table-builder/classes/TableBuilderDataSource.ts +61 -0
  50. package/src/table-builder/classes/TableState.ts +93 -0
  51. package/src/table-builder/classes/data-store.ts +10 -0
  52. package/{table-builder/classes/display-col.d.ts → src/table-builder/classes/display-col.ts} +5 -5
  53. package/src/table-builder/classes/filter-info.ts +108 -0
  54. package/src/table-builder/classes/table-builder-general-settings.ts +141 -0
  55. package/src/table-builder/classes/table-builder.ts +95 -0
  56. package/src/table-builder/classes/table-store.ts +476 -0
  57. package/src/table-builder/components/array-column.component.ts +36 -0
  58. package/src/table-builder/components/column-builder/column-builder.component.html +61 -0
  59. package/src/table-builder/components/column-builder/column-builder.component.scss +43 -0
  60. package/src/table-builder/components/column-builder/column-builder.component.spec.ts +49 -0
  61. package/src/table-builder/components/column-builder/column-builder.component.ts +146 -0
  62. package/src/table-builder/components/column-builder/column-helpers.ts +52 -0
  63. package/src/table-builder/components/date-filter/date-filter.component.html +23 -0
  64. package/src/table-builder/components/date-filter/date-filter.component.ts +24 -0
  65. package/src/table-builder/components/date-time-filter/date-time-filter.component.html +9 -0
  66. package/src/table-builder/components/date-time-filter/date-time-filter.component.ts +22 -0
  67. package/src/table-builder/components/filter/filter.component.html +91 -0
  68. package/src/table-builder/components/filter/filter.component.scss +60 -0
  69. package/src/table-builder/components/filter/filter.component.spec.ts +87 -0
  70. package/src/table-builder/components/filter/filter.component.ts +60 -0
  71. package/src/table-builder/components/filter/in-list/in-list-filter.component.ts +93 -0
  72. package/src/table-builder/components/gen-col-displayer/gen-col-displayer.component.html +55 -0
  73. package/src/table-builder/components/gen-col-displayer/gen-col-displayer.component.scss +57 -0
  74. package/src/table-builder/components/gen-col-displayer/gen-col-displayer.component.ts +46 -0
  75. package/src/table-builder/components/generic-table/generic-table.component.html +77 -0
  76. package/src/table-builder/components/generic-table/generic-table.component.scss +38 -0
  77. package/src/table-builder/components/generic-table/generic-table.component.ts +325 -0
  78. package/src/table-builder/components/generic-table/paginator.component.ts +99 -0
  79. package/src/table-builder/components/group-by-list/group-by-list.component.css +8 -0
  80. package/src/table-builder/components/group-by-list/group-by-list.component.html +12 -0
  81. package/src/table-builder/components/group-by-list/group-by-list.component.spec.ts +23 -0
  82. package/src/table-builder/components/group-by-list/group-by-list.component.ts +21 -0
  83. package/src/table-builder/components/header-menu/header-menu.component.html +104 -0
  84. package/src/table-builder/components/header-menu/header-menu.component.scss +96 -0
  85. package/src/table-builder/components/header-menu/header-menu.component.ts +99 -0
  86. package/src/table-builder/components/in-filter/in-filter.component.css +3 -0
  87. package/src/table-builder/components/in-filter/in-filter.component.html +20 -0
  88. package/src/table-builder/components/in-filter/in-filter.component.ts +66 -0
  89. package/{table-builder/components/index.d.ts → src/table-builder/components/index.ts} +9 -9
  90. package/src/table-builder/components/initialization-component/initialization-component.html +29 -0
  91. package/src/table-builder/components/initialization-component/initialization-component.ts +24 -0
  92. package/src/table-builder/components/link-column.component.ts +47 -0
  93. package/src/table-builder/components/number-filter/number-filter.component.css +10 -0
  94. package/src/table-builder/components/number-filter/number-filter.component.html +19 -0
  95. package/src/table-builder/components/number-filter/number-filter.component.spec.ts +30 -0
  96. package/src/table-builder/components/number-filter/number-filter.component.ts +25 -0
  97. package/src/table-builder/components/profiles-menu/profiles-menu.component.html +78 -0
  98. package/src/table-builder/components/profiles-menu/profiles-menu.component.scss +126 -0
  99. package/src/table-builder/components/profiles-menu/profiles-menu.component.spec.ts +23 -0
  100. package/src/table-builder/components/profiles-menu/profiles-menu.component.ts +65 -0
  101. package/src/table-builder/components/scroll-strategy.ts +76 -0
  102. package/src/table-builder/components/sort-menu/sort-menu.component-store.ts +66 -0
  103. package/src/table-builder/components/sort-menu/sort-menu.component.html +111 -0
  104. package/src/table-builder/components/sort-menu/sort-menu.component.scss +119 -0
  105. package/src/table-builder/components/sort-menu/sort-menu.component.ts +98 -0
  106. package/{table-builder/components/table-container/table-container-imports.d.ts → src/table-builder/components/table-container/table-container-imports.ts} +32 -14
  107. package/src/table-builder/components/table-container/table-container.helpers/data-state.helpers.ts +141 -0
  108. package/src/table-builder/components/table-container/table-container.helpers/filter-state.helpers.ts +106 -0
  109. package/src/table-builder/components/table-container/table-container.helpers/groupBy.helpers.ts +86 -0
  110. package/src/table-builder/components/table-container/table-container.helpers/sort-state.helpers.ts +45 -0
  111. package/src/table-builder/components/table-container/table-container.html +94 -0
  112. package/src/table-builder/components/table-container/table-container.scss +47 -0
  113. package/src/table-builder/components/table-container/table-container.spec.ts +154 -0
  114. package/src/table-builder/components/table-container/table-container.ts +356 -0
  115. package/src/table-builder/components/table-container/tableProps.ts +20 -0
  116. package/src/table-builder/components/table-container/virtual-scroll-container.ts +156 -0
  117. package/src/table-builder/components/table-container-filter/filter-list/filter-list.component.html +31 -0
  118. package/src/table-builder/components/table-container-filter/filter-list/filter-list.component.ts +46 -0
  119. package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.css +42 -0
  120. package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.html +10 -0
  121. package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.spec.ts +85 -0
  122. package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.ts +33 -0
  123. package/src/table-builder/components/table-container-filter/table-wrapper-filter-store.ts +23 -0
  124. package/src/table-builder/directives/custom-cell-directive.ts +58 -0
  125. package/{table-builder/directives/index.d.ts → src/table-builder/directives/index.ts} +6 -5
  126. package/src/table-builder/directives/multi-sort.directive.spec.ts +124 -0
  127. package/src/table-builder/directives/multi-sort.directive.ts +51 -0
  128. package/src/table-builder/directives/resize-column.directive.ts +108 -0
  129. package/src/table-builder/directives/table-wrapper.directive.ts +14 -0
  130. package/src/table-builder/directives/tb-filter.directive.ts +382 -0
  131. package/src/table-builder/enums/filterTypes.ts +40 -0
  132. package/src/table-builder/functions/boolean-filter-function.ts +12 -0
  133. package/src/table-builder/functions/date-filter-function.ts +68 -0
  134. package/src/table-builder/functions/download-data.ts +11 -0
  135. package/src/table-builder/functions/null-filter-function.ts +9 -0
  136. package/src/table-builder/functions/number-filter-function.ts +41 -0
  137. package/src/table-builder/functions/sort-data-function.ts +23 -0
  138. package/src/table-builder/functions/string-filter-function.ts +51 -0
  139. package/{table-builder/interfaces/ColumnInfo.d.ts → src/table-builder/interfaces/ColumnInfo.ts} +7 -6
  140. package/src/table-builder/interfaces/column-template.ts +9 -0
  141. package/{table-builder/interfaces/dictionary.d.ts → src/table-builder/interfaces/dictionary.ts} +3 -3
  142. package/src/table-builder/interfaces/report-def.ts +155 -0
  143. package/src/table-builder/ngrx/tableBuilderStateStore.ts +199 -0
  144. package/src/table-builder/pipes/column-total.pipe.ts +17 -0
  145. package/src/table-builder/pipes/format-filter-type.pipe.ts +12 -0
  146. package/src/table-builder/pipes/format-filter-value.pipe.ts +42 -0
  147. package/src/table-builder/pipes/key-display.ts +16 -0
  148. package/src/table-builder/services/export-to-csv.service.ts +78 -0
  149. package/src/table-builder/services/link-creator.service.ts +67 -0
  150. package/src/table-builder/services/table-template-service.ts +59 -0
  151. package/src/table-builder/services/transform-creator.ts +95 -0
  152. package/src/table-builder/specs/table-custom-filters.spec.ts +262 -0
  153. package/src/table-builder/styles/collapser.styles.scss +16 -0
  154. package/src/table-builder/table-builder.module.ts +73 -0
  155. package/src/test.ts +17 -0
  156. package/src/utilities/array-helpers.ts +13 -0
  157. package/src/utilities/directives/auto-focus.directive.ts +21 -0
  158. package/src/utilities/directives/clickEmitterDirective.ts +16 -0
  159. package/src/utilities/directives/clickSubject.ts +20 -0
  160. package/src/utilities/directives/conditional-classes.directive.ts +36 -0
  161. package/src/utilities/directives/dialog-service.ts +19 -0
  162. package/src/utilities/directives/dialog.ts +144 -0
  163. package/src/utilities/directives/mat-toggle-group-directive.ts +61 -0
  164. package/src/utilities/directives/prevent-enter.directive.ts +13 -0
  165. package/src/utilities/directives/stop-propagation.directive.ts +20 -0
  166. package/src/utilities/directives/styler.ts +40 -0
  167. package/src/utilities/directives/trim-whitespace.directive.ts +21 -0
  168. package/{utilities/index.d.ts → src/utilities/index.ts} +22 -15
  169. package/src/utilities/module.ts +55 -0
  170. package/src/utilities/pipes/function.pipe.ts +16 -0
  171. package/src/utilities/pipes/phone.pipe.ts +15 -0
  172. package/src/utilities/pipes/space-case.pipes.spec.ts +47 -0
  173. package/src/utilities/pipes/space-case.pipes.ts +23 -0
  174. package/tsconfig.lib.json +19 -0
  175. package/tsconfig.lib.prod.json +10 -0
  176. package/tsconfig.spec.json +17 -0
  177. package/action-state/action-state-spinner/action-state-spinner.component.d.ts +0 -12
  178. package/action-state/action-state-ui/action-state-ui.module.d.ts +0 -7
  179. package/action-state/ngrx-ext/ngrx-ext.module.d.ts +0 -8
  180. package/action-state/ngrx.d.ts +0 -31
  181. package/esm2022/action-state/action-state-spinner/action-state-spinner.component.mjs +0 -24
  182. package/esm2022/action-state/action-state-ui/action-state-ui.module.mjs +0 -20
  183. package/esm2022/action-state/index.mjs +0 -8
  184. package/esm2022/action-state/ngrx-ext/ngrx-ext.module.mjs +0 -23
  185. package/esm2022/action-state/ngrx.mjs +0 -47
  186. package/esm2022/http-request-state/HttpRequestStateFactory.mjs +0 -51
  187. package/esm2022/http-request-state/HttpRequestStateStore.mjs +0 -121
  188. package/esm2022/http-request-state/directives/HttpStateDirectiveBase.mjs +0 -30
  189. package/esm2022/http-request-state/directives/http-error-state-directive.mjs +0 -23
  190. package/esm2022/http-request-state/directives/http-inProgress-state-directive.mjs +0 -23
  191. package/esm2022/http-request-state/directives/http-notStarted-state-directive.mjs +0 -23
  192. package/esm2022/http-request-state/directives/http-success-state-directive.mjs +0 -29
  193. package/esm2022/http-request-state/directives/index.mjs +0 -6
  194. package/esm2022/http-request-state/directives/request-state-directive.mjs +0 -61
  195. package/esm2022/http-request-state/helpers.mjs +0 -22
  196. package/esm2022/http-request-state/http-request-state.mjs +0 -39
  197. package/esm2022/http-request-state/http-state-module.mjs +0 -40
  198. package/esm2022/http-request-state/index.mjs +0 -7
  199. package/esm2022/http-request-state/rxjs/getRequestorBody.mjs +0 -4
  200. package/esm2022/http-request-state/rxjs/getRequestorState.mjs +0 -3
  201. package/esm2022/http-request-state/rxjs/index.mjs +0 -5
  202. package/esm2022/http-request-state/rxjs/tapError.mjs +0 -12
  203. package/esm2022/http-request-state/rxjs/tapSuccess.mjs +0 -12
  204. package/esm2022/http-request-state/types.mjs +0 -16
  205. package/esm2022/ngrx/actionable-selector.mjs +0 -71
  206. package/esm2022/ngrx/index.mjs +0 -2
  207. package/esm2022/one-paragon-angular-utilities.mjs +0 -5
  208. package/esm2022/public-api.mjs +0 -20
  209. package/esm2022/rxjs/defaultShareReplay.mjs +0 -7
  210. package/esm2022/rxjs/index.mjs +0 -6
  211. package/esm2022/rxjs/mapError.mjs +0 -8
  212. package/esm2022/rxjs/rxjs-operators.mjs +0 -92
  213. package/esm2022/rxjs/subjectifier.mjs +0 -15
  214. package/esm2022/rxjs/subscriber.directive.mjs +0 -50
  215. package/esm2022/table-builder/classes/DefaultSettings.mjs +0 -6
  216. package/esm2022/table-builder/classes/MatTableObservableDataSource.mjs +0 -23
  217. package/esm2022/table-builder/classes/TableBuilderConfig.mjs +0 -18
  218. package/esm2022/table-builder/classes/TableBuilderDataSource.mjs +0 -48
  219. package/esm2022/table-builder/classes/TableState.mjs +0 -48
  220. package/esm2022/table-builder/classes/data-store.mjs +0 -15
  221. package/esm2022/table-builder/classes/display-col.mjs +0 -2
  222. package/esm2022/table-builder/classes/filter-info.mjs +0 -61
  223. package/esm2022/table-builder/classes/table-builder-general-settings.mjs +0 -116
  224. package/esm2022/table-builder/classes/table-builder.mjs +0 -77
  225. package/esm2022/table-builder/classes/table-store.mjs +0 -388
  226. package/esm2022/table-builder/components/array-column.component.mjs +0 -53
  227. package/esm2022/table-builder/components/column-builder/column-builder.component.mjs +0 -134
  228. package/esm2022/table-builder/components/column-builder/column-helpers.mjs +0 -45
  229. package/esm2022/table-builder/components/date-filter/date-filter.component.mjs +0 -29
  230. package/esm2022/table-builder/components/date-time-filter/date-time-filter.component.mjs +0 -24
  231. package/esm2022/table-builder/components/filter/filter.component.mjs +0 -64
  232. package/esm2022/table-builder/components/filter/in-list/in-list-filter.component.mjs +0 -102
  233. package/esm2022/table-builder/components/gen-col-displayer/gen-col-displayer.component.mjs +0 -47
  234. package/esm2022/table-builder/components/generic-table/generic-table.component.mjs +0 -310
  235. package/esm2022/table-builder/components/generic-table/paginator.component.mjs +0 -100
  236. package/esm2022/table-builder/components/group-by-list/group-by-list.component.mjs +0 -21
  237. package/esm2022/table-builder/components/header-menu/header-menu.component.mjs +0 -103
  238. package/esm2022/table-builder/components/in-filter/in-filter.component.mjs +0 -65
  239. package/esm2022/table-builder/components/index.mjs +0 -10
  240. package/esm2022/table-builder/components/initialization-component/initialization-component.mjs +0 -47
  241. package/esm2022/table-builder/components/link-column.component.mjs +0 -74
  242. package/esm2022/table-builder/components/number-filter/number-filter.component.mjs +0 -29
  243. package/esm2022/table-builder/components/profiles-menu/profiles-menu.component.mjs +0 -64
  244. package/esm2022/table-builder/components/scroll-strategy.mjs +0 -60
  245. package/esm2022/table-builder/components/sort-menu/sort-menu.component-store.mjs +0 -46
  246. package/esm2022/table-builder/components/sort-menu/sort-menu.component.mjs +0 -82
  247. package/esm2022/table-builder/components/table-container/table-container-imports.mjs +0 -26
  248. package/esm2022/table-builder/components/table-container/table-container.helpers/data-state.helpers.mjs +0 -135
  249. package/esm2022/table-builder/components/table-container/table-container.helpers/filter-state.helpers.mjs +0 -83
  250. package/esm2022/table-builder/components/table-container/table-container.helpers/groupBy.helpers.mjs +0 -71
  251. package/esm2022/table-builder/components/table-container/table-container.helpers/sort-state.helpers.mjs +0 -36
  252. package/esm2022/table-builder/components/table-container/table-container.mjs +0 -336
  253. package/esm2022/table-builder/components/table-container/tableProps.mjs +0 -8
  254. package/esm2022/table-builder/components/table-container/virtual-scroll-container.mjs +0 -155
  255. package/esm2022/table-builder/components/table-container-filter/filter-list/filter-list.component.mjs +0 -44
  256. package/esm2022/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.mjs +0 -36
  257. package/esm2022/table-builder/components/table-container-filter/table-wrapper-filter-store.mjs +0 -25
  258. package/esm2022/table-builder/directives/custom-cell-directive.mjs +0 -73
  259. package/esm2022/table-builder/directives/index.mjs +0 -6
  260. package/esm2022/table-builder/directives/multi-sort.directive.mjs +0 -50
  261. package/esm2022/table-builder/directives/resize-column.directive.mjs +0 -87
  262. package/esm2022/table-builder/directives/table-wrapper.directive.mjs +0 -18
  263. package/esm2022/table-builder/directives/tb-filter.directive.mjs +0 -396
  264. package/esm2022/table-builder/enums/filterTypes.mjs +0 -29
  265. package/esm2022/table-builder/functions/boolean-filter-function.mjs +0 -10
  266. package/esm2022/table-builder/functions/date-filter-function.mjs +0 -58
  267. package/esm2022/table-builder/functions/download-data.mjs +0 -12
  268. package/esm2022/table-builder/functions/null-filter-function.mjs +0 -8
  269. package/esm2022/table-builder/functions/number-filter-function.mjs +0 -32
  270. package/esm2022/table-builder/functions/sort-data-function.mjs +0 -17
  271. package/esm2022/table-builder/functions/string-filter-function.mjs +0 -41
  272. package/esm2022/table-builder/interfaces/ColumnInfo.mjs +0 -2
  273. package/esm2022/table-builder/interfaces/dictionary.mjs +0 -2
  274. package/esm2022/table-builder/interfaces/report-def.mjs +0 -50
  275. package/esm2022/table-builder/ngrx/tableBuilderStateStore.mjs +0 -154
  276. package/esm2022/table-builder/pipes/column-total.pipe.mjs +0 -22
  277. package/esm2022/table-builder/pipes/format-filter-type.pipe.mjs +0 -18
  278. package/esm2022/table-builder/pipes/format-filter-value.pipe.mjs +0 -43
  279. package/esm2022/table-builder/pipes/key-display.mjs +0 -18
  280. package/esm2022/table-builder/services/export-to-csv.service.mjs +0 -75
  281. package/esm2022/table-builder/services/link-creator.service.mjs +0 -50
  282. package/esm2022/table-builder/services/table-template-service.mjs +0 -60
  283. package/esm2022/table-builder/services/transform-creator.mjs +0 -100
  284. package/esm2022/table-builder/table-builder.module.mjs +0 -124
  285. package/esm2022/utilities/array-helpers.mjs +0 -14
  286. package/esm2022/utilities/directives/auto-focus.directive.mjs +0 -25
  287. package/esm2022/utilities/directives/clickEmitterDirective.mjs +0 -22
  288. package/esm2022/utilities/directives/clickSubject.mjs +0 -29
  289. package/esm2022/utilities/directives/conditional-classes.directive.mjs +0 -36
  290. package/esm2022/utilities/directives/dialog-service.mjs +0 -21
  291. package/esm2022/utilities/directives/dialog.mjs +0 -145
  292. package/esm2022/utilities/directives/mat-toggle-group-directive.mjs +0 -59
  293. package/esm2022/utilities/directives/prevent-enter.directive.mjs +0 -20
  294. package/esm2022/utilities/directives/stop-propagation.directive.mjs +0 -26
  295. package/esm2022/utilities/directives/styler.mjs +0 -41
  296. package/esm2022/utilities/directives/trim-whitespace.directive.mjs +0 -28
  297. package/esm2022/utilities/index.mjs +0 -16
  298. package/esm2022/utilities/module.mjs +0 -90
  299. package/esm2022/utilities/pipes/function.pipe.mjs +0 -22
  300. package/esm2022/utilities/pipes/phone.pipe.mjs +0 -20
  301. package/esm2022/utilities/pipes/space-case.pipes.mjs +0 -28
  302. package/fesm2022/one-paragon-angular-utilities.mjs +0 -5700
  303. package/fesm2022/one-paragon-angular-utilities.mjs.map +0 -1
  304. package/http-request-state/HttpRequestStateFactory.d.ts +0 -17
  305. package/http-request-state/HttpRequestStateStore.d.ts +0 -54
  306. package/http-request-state/directives/HttpStateDirectiveBase.d.ts +0 -14
  307. package/http-request-state/directives/http-error-state-directive.d.ts +0 -9
  308. package/http-request-state/directives/http-inProgress-state-directive.d.ts +0 -9
  309. package/http-request-state/directives/http-notStarted-state-directive.d.ts +0 -9
  310. package/http-request-state/directives/http-success-state-directive.d.ts +0 -16
  311. package/http-request-state/directives/request-state-directive.d.ts +0 -34
  312. package/http-request-state/helpers.d.ts +0 -9
  313. package/http-request-state/http-request-state.d.ts +0 -12
  314. package/http-request-state/http-state-module.d.ts +0 -11
  315. package/http-request-state/rxjs/getRequestorBody.d.ts +0 -3
  316. package/http-request-state/rxjs/getRequestorState.d.ts +0 -3
  317. package/http-request-state/rxjs/tapError.d.ts +0 -3
  318. package/http-request-state/rxjs/tapSuccess.d.ts +0 -3
  319. package/http-request-state/types.d.ts +0 -41
  320. package/index.d.ts +0 -5
  321. package/ngrx/actionable-selector.d.ts +0 -17
  322. package/ngrx/index.d.ts +0 -1
  323. package/rxjs/defaultShareReplay.d.ts +0 -2
  324. package/rxjs/mapError.d.ts +0 -2
  325. package/rxjs/rxjs-operators.d.ts +0 -13
  326. package/rxjs/subjectifier.d.ts +0 -8
  327. package/rxjs/subscriber.directive.d.ts +0 -14
  328. package/table-builder/classes/DefaultSettings.d.ts +0 -9
  329. package/table-builder/classes/MatTableObservableDataSource.d.ts +0 -9
  330. package/table-builder/classes/TableBuilderConfig.d.ts +0 -23
  331. package/table-builder/classes/TableBuilderDataSource.d.ts +0 -12
  332. package/table-builder/classes/TableState.d.ts +0 -66
  333. package/table-builder/classes/data-store.d.ts +0 -8
  334. package/table-builder/classes/filter-info.d.ts +0 -35
  335. package/table-builder/classes/table-builder-general-settings.d.ts +0 -85
  336. package/table-builder/classes/table-builder.d.ts +0 -18
  337. package/table-builder/classes/table-store.d.ts +0 -138
  338. package/table-builder/components/array-column.component.d.ts +0 -15
  339. package/table-builder/components/column-builder/column-builder.component.d.ts +0 -47
  340. package/table-builder/components/column-builder/column-helpers.d.ts +0 -36
  341. package/table-builder/components/date-filter/date-filter.component.d.ts +0 -37
  342. package/table-builder/components/date-time-filter/date-time-filter.component.d.ts +0 -37
  343. package/table-builder/components/filter/filter.component.d.ts +0 -46
  344. package/table-builder/components/filter/in-list/in-list-filter.component.d.ts +0 -24
  345. package/table-builder/components/gen-col-displayer/gen-col-displayer.component.d.ts +0 -17
  346. package/table-builder/components/generic-table/generic-table.component.d.ts +0 -89
  347. package/table-builder/components/generic-table/paginator.component.d.ts +0 -30
  348. package/table-builder/components/group-by-list/group-by-list.component.d.ts +0 -7
  349. package/table-builder/components/header-menu/header-menu.component.d.ts +0 -51
  350. package/table-builder/components/in-filter/in-filter.component.d.ts +0 -20
  351. package/table-builder/components/initialization-component/initialization-component.d.ts +0 -13
  352. package/table-builder/components/link-column.component.d.ts +0 -25
  353. package/table-builder/components/number-filter/number-filter.component.d.ts +0 -39
  354. package/table-builder/components/profiles-menu/profiles-menu.component.d.ts +0 -32
  355. package/table-builder/components/scroll-strategy.d.ts +0 -22
  356. package/table-builder/components/sort-menu/sort-menu.component-store.d.ts +0 -24
  357. package/table-builder/components/sort-menu/sort-menu.component.d.ts +0 -24
  358. package/table-builder/components/table-container/table-container.d.ts +0 -80
  359. package/table-builder/components/table-container/table-container.helpers/data-state.helpers.d.ts +0 -6
  360. package/table-builder/components/table-container/table-container.helpers/filter-state.helpers.d.ts +0 -17
  361. package/table-builder/components/table-container/table-container.helpers/groupBy.helpers.d.ts +0 -17
  362. package/table-builder/components/table-container/table-container.helpers/sort-state.helpers.d.ts +0 -8
  363. package/table-builder/components/table-container/tableProps.d.ts +0 -12
  364. package/table-builder/components/table-container/virtual-scroll-container.d.ts +0 -36
  365. package/table-builder/components/table-container-filter/filter-list/filter-list.component.d.ts +0 -15
  366. package/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.d.ts +0 -12
  367. package/table-builder/components/table-container-filter/table-wrapper-filter-store.d.ts +0 -14
  368. package/table-builder/directives/custom-cell-directive.d.ts +0 -33
  369. package/table-builder/directives/multi-sort.directive.d.ts +0 -10
  370. package/table-builder/directives/resize-column.directive.d.ts +0 -43
  371. package/table-builder/directives/table-wrapper.directive.d.ts +0 -8
  372. package/table-builder/directives/tb-filter.directive.d.ts +0 -115
  373. package/table-builder/enums/filterTypes.d.ts +0 -36
  374. package/table-builder/functions/boolean-filter-function.d.ts +0 -3
  375. package/table-builder/functions/date-filter-function.d.ts +0 -4
  376. package/table-builder/functions/download-data.d.ts +0 -1
  377. package/table-builder/functions/null-filter-function.d.ts +0 -2
  378. package/table-builder/functions/number-filter-function.d.ts +0 -4
  379. package/table-builder/functions/sort-data-function.d.ts +0 -6
  380. package/table-builder/functions/string-filter-function.d.ts +0 -5
  381. package/table-builder/interfaces/report-def.d.ts +0 -147
  382. package/table-builder/ngrx/tableBuilderStateStore.d.ts +0 -70
  383. package/table-builder/pipes/column-total.pipe.d.ts +0 -8
  384. package/table-builder/pipes/format-filter-type.pipe.d.ts +0 -8
  385. package/table-builder/pipes/format-filter-value.pipe.d.ts +0 -12
  386. package/table-builder/pipes/key-display.d.ts +0 -10
  387. package/table-builder/services/export-to-csv.service.d.ts +0 -14
  388. package/table-builder/services/link-creator.service.d.ts +0 -16
  389. package/table-builder/services/table-template-service.d.ts +0 -14
  390. package/table-builder/services/transform-creator.d.ts +0 -16
  391. package/table-builder/table-builder.module.d.ts +0 -21
  392. package/utilities/array-helpers.d.ts +0 -1
  393. package/utilities/directives/auto-focus.directive.d.ts +0 -9
  394. package/utilities/directives/clickEmitterDirective.d.ts +0 -7
  395. package/utilities/directives/clickSubject.d.ts +0 -9
  396. package/utilities/directives/conditional-classes.directive.d.ts +0 -13
  397. package/utilities/directives/dialog-service.d.ts +0 -10
  398. package/utilities/directives/dialog.d.ts +0 -44
  399. package/utilities/directives/mat-toggle-group-directive.d.ts +0 -21
  400. package/utilities/directives/prevent-enter.directive.d.ts +0 -6
  401. package/utilities/directives/stop-propagation.directive.d.ts +0 -7
  402. package/utilities/directives/styler.d.ts +0 -15
  403. package/utilities/directives/trim-whitespace.directive.d.ts +0 -7
  404. package/utilities/module.d.ts +0 -19
  405. package/utilities/pipes/function.pipe.d.ts +0 -7
  406. package/utilities/pipes/phone.pipe.d.ts +0 -7
  407. package/utilities/pipes/space-case.pipes.d.ts +0 -17
@@ -0,0 +1,108 @@
1
+ import { Directive, OnInit, Renderer2, Input, ElementRef, booleanAttribute, inject } from "@angular/core";
2
+ import { fromEvent } from "rxjs";
3
+ import { filter, map, switchMap, takeUntil } from "rxjs/operators";
4
+ import { defaultShareReplay } from "../../rxjs";
5
+ import { TableStore } from "../classes/table-store";
6
+
7
+ @Directive({
8
+ selector: "[resizeColumn]",
9
+ standalone: true
10
+ })
11
+ export class ResizeColumnDirective implements OnInit{
12
+ private renderer = inject(Renderer2);
13
+ private el = inject(ElementRef);
14
+ store = inject(TableStore);
15
+
16
+ @Input({ alias : 'resizeColumn', transform: booleanAttribute }) resizable: boolean | string = false;
17
+
18
+ @Input() key!: string;
19
+
20
+ ngOnInit(){
21
+ if (this.resizable){
22
+ const {table, columnHead} = this.getTableAndColumnHeadHtmlElements();
23
+ const resizer = this.createResizerSpanInColumnHead(columnHead);
24
+
25
+ const aggregateMouseEventsMapped$ = this.mouseDownThroughMouseUpEventMapper(resizer,columnHead,table)
26
+
27
+ const resizeColsData$ = aggregateMouseEventsMapped$.pipe(
28
+ filter(({mouseMove})=>!!mouseMove.buttons),
29
+ map( ({mouseDownData,mouseMove}) => {
30
+ const {newTableWidth,newColumnWidth} = this.calculateNewWidths(mouseDownData,mouseMove)
31
+ return ({
32
+ key:this.key,
33
+ widthInPixel:newColumnWidth,
34
+ tableSize:newTableWidth,
35
+ })
36
+ }),
37
+ defaultShareReplay()
38
+ );
39
+
40
+ this.store.setUserDefinedWidth(resizeColsData$.pipe(
41
+ map(resizeData => ([{key: this.key, widthInPixel: resizeData.widthInPixel }]))
42
+ ));
43
+
44
+ this.store.setTableWidth(resizeColsData$.pipe(
45
+ map(resizeData => resizeData.tableSize )));
46
+ }
47
+
48
+ }
49
+
50
+ createResizerSpanInColumnHead(columnHead:HTMLElement){
51
+ const resizer = this.renderer.createElement("span");
52
+ this.renderer.addClass(resizer, "resize-holder");
53
+ resizer.style['cursor']='col-resize';
54
+ resizer.style['user-select']='none';
55
+ resizer.style['width']='10px';
56
+ resizer.style['height']='100%';
57
+ resizer.style['position']='absolute';
58
+ resizer.style['right']='0';
59
+ resizer.style['top']='0';
60
+ resizer.style['z-index']='1';
61
+ this.renderer.appendChild(columnHead, resizer);
62
+ return resizer;
63
+ }
64
+
65
+ getTableAndColumnHeadHtmlElements():{table:HTMLElement,columnHead:HTMLElement}{
66
+ const columnHead: HTMLElement = this.el.nativeElement;
67
+ const row = this.renderer.parentNode(columnHead);
68
+ const table = this.renderer.parentNode(row);
69
+ return ({table,columnHead})
70
+ }
71
+
72
+ mouseDownThroughMouseUpEventMapper(resizer:HTMLElement, columnHead:HTMLElement, table:HTMLElement){
73
+ return this.resizerMouseDownEventMapper(resizer,columnHead,table)
74
+ .pipe(
75
+ switchMap( mouseDownData => fromEvent<MouseEvent>(table, "mousemove").pipe(
76
+ map( mouseMove => ({mouseDownData, mouseMove})),
77
+ takeUntil(fromEvent<MouseEvent>(document, "mouseup"))
78
+ ) ),
79
+ )
80
+ }
81
+ resizerMouseDownEventMapper(resizer:HTMLElement, columnHead:HTMLElement, table:HTMLElement){
82
+ return fromEvent<MouseEvent>(resizer, "mousedown").pipe(
83
+ map(event => ({
84
+ startPageX: event.pageX,
85
+ startColumnWidth: this.getElementWidth(columnHead),
86
+ startTableWidth: this.getElementWidth(table),
87
+ }))
88
+ );
89
+ }
90
+
91
+ calculateNewWidths(mouseDownData: MouseDownData, mouseMove: MouseEvent):{newTableWidth:number,newColumnWidth:number}{
92
+ const change = (mouseMove.pageX - mouseDownData.startPageX );
93
+ let newColumnWidth = mouseDownData.startColumnWidth + change;
94
+ if(newColumnWidth < 1){
95
+ newColumnWidth = 1;
96
+ }
97
+ const columnChange = newColumnWidth - mouseDownData.startColumnWidth;
98
+ const newTableWidth = (mouseDownData.startTableWidth + columnChange);
99
+ return ({newTableWidth,newColumnWidth})
100
+ }
101
+ getElementWidth = (elem:HTMLElement) => (+(globalThis.getComputedStyle(elem).getPropertyValue('width').replace('px','')))
102
+
103
+ }
104
+ interface MouseDownData{
105
+ startPageX:number,
106
+ startColumnWidth:number,
107
+ startTableWidth:number,
108
+ }
@@ -0,0 +1,14 @@
1
+ import { Directive, signal } from "@angular/core";
2
+ import { TableCustomFilterDirective, TableFilterDirective } from "./tb-filter.directive";
3
+
4
+ @Directive({
5
+ selector: '[tbWrapper]',
6
+ standalone: true,
7
+ })
8
+ export class TableWrapperDirective {
9
+ $registrations = signal([] as (TableCustomFilterDirective | TableFilterDirective)[]);
10
+
11
+ register(filter: TableCustomFilterDirective | TableFilterDirective) {
12
+ this.$registrations.update( registrations => [...registrations,filter] );
13
+ }
14
+ }
@@ -0,0 +1,382 @@
1
+ import { Directive, Input, Predicate, SimpleChanges, inject } from "@angular/core";
2
+ import { BehaviorSubject, Observable, ReplaySubject, Subject, takeUntil, tap } from "rxjs";
3
+ import { CustomFilter, FilterInfo } from "../classes/filter-info";
4
+ import { v4 as uuid } from 'uuid';
5
+ import { FilterType, FilterTypes } from "../enums/filterTypes";
6
+ import { MatSlideToggle } from "@angular/material/slide-toggle";
7
+ import { MatRadioButton } from "@angular/material/radio";
8
+ import { MatButtonToggle } from '@angular/material/button-toggle';
9
+ import { MatCheckbox } from "@angular/material/checkbox";
10
+ import { FieldType } from "../interfaces/report-def";
11
+ import { NgControl } from "@angular/forms";
12
+ import { TableWrapperDirective } from "./table-wrapper.directive";
13
+ import { MatOption } from "@angular/material/core";
14
+ import { subscriber } from "../../rxjs";
15
+
16
+
17
+ const inputs = [
18
+ 'predicate: tbCustomFilter',
19
+ 'filterId: filterId',
20
+ ];
21
+
22
+
23
+ @Directive({
24
+ selector: ' '
25
+ })
26
+ export abstract class TableCustomFilterDirective<T = any> {
27
+ abstract filter$ : Observable<CustomFilter>;
28
+ filterId!: string;
29
+ savable = false;
30
+ used = false;
31
+ abstract active: boolean;
32
+ abstract reset(): void;
33
+ }
34
+
35
+
36
+
37
+
38
+ @Directive({
39
+ selector: "[tbFilter]",
40
+ standalone: true,
41
+ }) export class TableFilterDirective {
42
+ protected model = inject(NgControl, { optional: true });
43
+ private wrapper = inject(TableWrapperDirective, { optional: true });
44
+ constructor() {
45
+ if(this.wrapper) {
46
+ this.wrapper.register(this);
47
+ }
48
+ if(this.model) {
49
+ subscriber(this.model!.valueChanges!, val => {
50
+ this.filterValue = val;
51
+ this.update();
52
+ })
53
+ }
54
+ }
55
+ reset() {
56
+ this.filterValue = undefined;
57
+ }
58
+ filter$ = new Subject<FilterInfo>;
59
+
60
+ @Input() filterType!: FilterType;
61
+ @Input() key!: string;
62
+ @Input() fieldType!: FieldType;
63
+ @Input() filterId!: string;
64
+ @Input() active = true;
65
+ @Input() filterValue: any = null;
66
+
67
+ setFilterValue(value: any) {
68
+ if(this.model) {
69
+ setTimeout(() => {
70
+ this.model!.reset(value);
71
+ }, 0);
72
+ } else {
73
+ this.filterValue = value;
74
+ }
75
+ }
76
+
77
+ used = false;
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 = uuid();
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
+ standalone: true,
128
+ }) export class TableFilterStringContainsDirective extends TableFilterDirective {
129
+ constructor() {
130
+ super();
131
+ this.filterType = FilterTypes.StringContains;
132
+ this.fieldType = FieldType.String;
133
+ }
134
+
135
+ override reset() {
136
+ if(this.model) {
137
+ this.model.reset();
138
+ }
139
+ super.reset();
140
+ }
141
+
142
+ override setFilter(filter: FilterInfo) {
143
+ filter.active = filter.filterValue && this._userActive;
144
+ super.setFilter(filter);
145
+ }
146
+
147
+ ngOnChanges(changes: SimpleChanges) {
148
+ if(changes['active']) {
149
+ this._userActive = changes['active'].currentValue;
150
+ }
151
+ super.ngOnChanges(changes);
152
+ }
153
+ }
154
+
155
+ @Directive({
156
+ selector: "[tbCustomFilter]",
157
+ })
158
+ export abstract class TableCustomFilterDirectiveBase<T = any> extends TableCustomFilterDirective<T> {
159
+
160
+ filter$! : Subject<CustomFilter>;
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 = uuid();
192
+ } else {
193
+ this.savable = true;
194
+ }
195
+
196
+ this.filter = {
197
+ filterType: FilterTypes.Custom,
198
+ filterId: this.filterId,
199
+ active: this._active,
200
+ predicate: this._predicate,
201
+ };
202
+ this.ready = true;
203
+ this.filter$ = new BehaviorSubject(this.filter);
204
+ }
205
+ }
206
+
207
+ @Directive()
208
+ export abstract class TbSelectedFilterDirective<T = any> extends TableCustomFilterDirectiveBase<T> {
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
+ standalone: true,
244
+ })
245
+ export class MatCheckboxTbFilterDirective extends TbSelectedFilterDirective {
246
+ private matCheckbox = inject(MatCheckbox);
247
+
248
+
249
+ override set active(val: boolean) {
250
+ this.matCheckbox.checked = val;
251
+ super.active = val;
252
+ }
253
+ constructor() {
254
+ const matCheckbox = inject(MatCheckbox);
255
+ super(matCheckbox.change, () => matCheckbox.checked);
256
+ this.matCheckbox = matCheckbox;
257
+ }
258
+ }
259
+
260
+
261
+ @Directive({
262
+ selector: 'mat-slide-toggle[tbCustomFilter]',
263
+ inputs: [
264
+ ...inputs
265
+ ],
266
+ providers: [{ provide: TableCustomFilterDirective, useExisting: MatSlideToggleTbFilterDirective }],
267
+ standalone: true,
268
+ })
269
+ export class MatSlideToggleTbFilterDirective<T = any> extends TbSelectedFilterDirective<T> {
270
+ private matSlideToggle: MatSlideToggle;
271
+
272
+ override set active(val: boolean) {
273
+ this.matSlideToggle.checked = val;
274
+ super.active = val;
275
+ }
276
+ constructor() {
277
+ const matSlideToggle = inject(MatSlideToggle);
278
+
279
+ super(matSlideToggle.change, () => matSlideToggle.checked);
280
+ this.matSlideToggle = matSlideToggle;
281
+
282
+ }
283
+
284
+ ngOnInit(): void {
285
+ super.ngOnInit();
286
+ }
287
+ }
288
+
289
+ // Radio button
290
+ @Directive({
291
+ selector: 'mat-radio-button[tbCustomFilter]',
292
+ inputs: ['predicate: tbCustomFilter'],
293
+ providers: [{ provide: TableCustomFilterDirective, useExisting: MatRadioButtonTbFilterDirective }],
294
+ standalone: true,
295
+ })
296
+ export class MatRadioButtonTbFilterDirective extends TbSelectedFilterDirective {
297
+ private matRadioButton: MatRadioButton;
298
+
299
+
300
+ override set active(val: boolean) {
301
+ this.matRadioButton.checked = val;
302
+ super.active = val;
303
+ }
304
+ constructor() {
305
+ const matRadioButton = inject(MatRadioButton);
306
+
307
+ super(matRadioButton.change, () => matRadioButton.checked);
308
+ this.matRadioButton = matRadioButton;
309
+ }
310
+
311
+ ngOnInit(): void {
312
+ super.ngOnInit();
313
+ }
314
+ }
315
+
316
+ // Option (select)
317
+ @Directive({
318
+ selector: 'mat-option[tbCustomFilter]',
319
+ inputs: [
320
+ ...inputs
321
+ ],
322
+ providers: [{ provide: TableCustomFilterDirective, useExisting: MatOptionTbFilterDirective }],
323
+ standalone: true,
324
+ })
325
+ export class MatOptionTbFilterDirective extends TbSelectedFilterDirective {
326
+ private matOption: MatOption;
327
+
328
+
329
+ override set active(val: boolean) {
330
+ if(val) {
331
+ this.matOption.select();
332
+ } else {
333
+ this.matOption.deselect();
334
+ }
335
+ super.active = val;
336
+ }
337
+ constructor() {
338
+ const matOption = inject(MatOption);
339
+
340
+ super( matOption.onSelectionChange.pipe(tap( d => {
341
+ if(!matOption.value) {
342
+ matOption.value = uuid();
343
+ }
344
+ }
345
+
346
+ )), () => matOption.selected);
347
+ this.matOption = matOption;
348
+ }
349
+
350
+ ngOnInit(): void {
351
+ super.ngOnInit();
352
+ }
353
+ }
354
+
355
+ // Button toggle
356
+ @Directive({
357
+ selector: 'mat-button-toggle[tbCustomFilter]',
358
+ inputs: [
359
+ ...inputs
360
+ ],
361
+ providers: [{ provide: TableCustomFilterDirective, useExisting: MatButtonToggleFilterDirective }],
362
+ standalone: true,
363
+ })
364
+ export class MatButtonToggleFilterDirective extends TbSelectedFilterDirective {
365
+ private matButtonToggle: MatButtonToggle;
366
+
367
+ override set active(val: boolean) {
368
+ this.matButtonToggle.checked = val;
369
+ super.active = val;
370
+ }
371
+ constructor() {
372
+ const matButtonToggle = inject(MatButtonToggle);
373
+
374
+ super(matButtonToggle.change, () => matButtonToggle.checked);
375
+ this.matButtonToggle = matButtonToggle;
376
+
377
+ }
378
+
379
+ ngOnInit(): void {
380
+ super.ngOnInit();
381
+ }
382
+ }
@@ -0,0 +1,40 @@
1
+
2
+ export const FilterTypes = {
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 FilterTypes[keyof typeof FilterTypes];
32
+
33
+ export type SubFilterTypes<T extends typeof FilterTypes[keyof typeof FilterTypes]> = 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'>;
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'>;
@@ -0,0 +1,12 @@
1
+ import { FilterFunc, FilterFuncs, FilterInfo } from '../classes/filter-info';
2
+ import { BooleanFilterTypes, FilterTypes } 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
+ [FilterTypes.BooleanEquals]: booleanEqualsFunc,
11
+ [FilterTypes.IsNull]: isNull,
12
+ };
@@ -0,0 +1,68 @@
1
+ import { FilterFunc, FilterFuncs, FilterInfo, Range } from '../classes/filter-info';
2
+ import { DateFilterTypes, DateTimeFilterTypes, FilterTypes } 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 dateBetweenFunc:FilterFunc<Range<Date>,Date> = (filterInfo:FilterInfo) => {
32
+ const startVal = new Date(filterInfo.filterValue.Start);
33
+ const endVal = new Date(filterInfo.filterValue.End);
34
+ const clean = filterInfo.fieldType === FieldType.Date ? (a,b) => b : cleanDateTime
35
+ return (
36
+ (val)=> {
37
+ const cleanedVal = clean(filterInfo, val);
38
+ return cleanedVal>=startVal && cleanedVal <= endVal;
39
+ });
40
+ }
41
+
42
+ const cleanDateTime = (filterInfo:FilterInfo, val: Date) => {
43
+ if(!!DateFilterFuncs[filterInfo.filterType]){
44
+ const d = new Date(val);
45
+ d.setHours(0,0,0,0);
46
+ return d;
47
+ }
48
+ return val;
49
+ }
50
+
51
+ export const DateFilterFuncs: FilterFuncs<DateFilterTypes> = {
52
+ [FilterTypes.DateIsOn]: dateIsOnFunc,
53
+ [FilterTypes.DateIsNotOn]: dateIsNotOnFunc,
54
+ [FilterTypes.DateOnOrAfter]: dateIsOnOrAfterFunc,
55
+ [FilterTypes.DateOnOrBefore]: dateIsOnOrBeforeFunc,
56
+ [FilterTypes.DateBetween]: dateBetweenFunc,
57
+ [FilterTypes.IsNull]: isNull,
58
+ };
59
+
60
+ export const DateTimeFilterFuncs: FilterFuncs<DateTimeFilterTypes> = {
61
+ ...DateFilterFuncs,
62
+ [FilterTypes.DateTimeIsAt]: dateIsOnFunc,
63
+ [FilterTypes.DateTimeIsNotAt]: dateIsNotOnFunc,
64
+ [FilterTypes.DateTimeAtOrAfter]: dateIsOnOrAfterFunc,
65
+ [FilterTypes.DateTimeAtOrBefore]: dateIsOnOrBeforeFunc,
66
+ [FilterTypes.DateTimeBetween]: dateBetweenFunc,
67
+ [FilterTypes.IsNull]: isNull,
68
+ };
@@ -0,0 +1,11 @@
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
+ }
@@ -0,0 +1,9 @@
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
+ }
@@ -0,0 +1,41 @@
1
+ import { Range, FilterFunc, FilterInfo, FilterFuncs } from '../classes/filter-info';
2
+ import { FilterTypes, 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
+ [FilterTypes.NumberEquals]: numberEqalsFunc,
35
+ [FilterTypes.NumberNotEqual]: numberNotEqualFunc,
36
+ [FilterTypes.NumberGreaterThan]: numberGreaterThanFunc,
37
+ [FilterTypes.NumberLessThan]: numberLessThanFunc,
38
+ [FilterTypes.NumberBetween]: numberBetweenFunc,
39
+ [FilterTypes.IsNull]: isNull,
40
+ [FilterTypes.In]: multipleNumberValuesEqualsFunc,
41
+ };