@one-paragon/angular-utilities 2.1.5 → 2.1.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (298) hide show
  1. package/action-state/action-state-spinner/action-state-spinner.component.d.ts +12 -0
  2. package/action-state/action-state-ui/action-state-ui.module.d.ts +7 -0
  3. package/{src/action-state/index.ts → action-state/index.d.ts} +4 -8
  4. package/action-state/ngrx-ext/ngrx-ext.module.d.ts +8 -0
  5. package/action-state/ngrx.d.ts +31 -0
  6. package/fesm2022/one-paragon-angular-utilities.mjs +6338 -0
  7. package/fesm2022/one-paragon-angular-utilities.mjs.map +1 -0
  8. package/http-request-state/RequestStateFactory.d.ts +17 -0
  9. package/http-request-state/RequestStateStore.d.ts +101 -0
  10. package/{src/http-request-state/deprecated.ts → http-request-state/deprecated.d.ts} +20 -20
  11. package/http-request-state/directives/HttpStateDirectiveBase.d.ts +14 -0
  12. package/http-request-state/directives/http-error-state-directive.d.ts +9 -0
  13. package/http-request-state/directives/http-inProgress-state-directive.d.ts +9 -0
  14. package/http-request-state/directives/http-notStarted-state-directive.d.ts +9 -0
  15. package/http-request-state/directives/http-success-state-directive.d.ts +16 -0
  16. package/{src/http-request-state/directives/index.ts → http-request-state/directives/index.d.ts} +5 -5
  17. package/http-request-state/directives/request-state-directive.d.ts +34 -0
  18. package/http-request-state/helpers.d.ts +9 -0
  19. package/http-request-state/http-state-module.d.ts +11 -0
  20. package/{src/http-request-state/index.ts → http-request-state/index.d.ts} +7 -7
  21. package/http-request-state/request-state.d.ts +12 -0
  22. package/http-request-state/rxjs/getRequestorBody.d.ts +3 -0
  23. package/http-request-state/rxjs/getRequestorState.d.ts +3 -0
  24. package/{src/http-request-state/rxjs/index.ts → http-request-state/rxjs/index.d.ts} +4 -4
  25. package/http-request-state/rxjs/tapError.d.ts +3 -0
  26. package/http-request-state/rxjs/tapSuccess.d.ts +3 -0
  27. package/http-request-state/types.d.ts +41 -0
  28. package/index.d.ts +5 -0
  29. package/ngrx/actionable-selector.d.ts +32 -0
  30. package/ngrx/index.d.ts +1 -0
  31. package/package.json +27 -15
  32. package/{src/public-api.ts → public-api.d.ts} +16 -35
  33. package/rxjs/defaultShareReplay.d.ts +2 -0
  34. package/{src/rxjs/index.ts → rxjs/index.d.ts} +5 -5
  35. package/rxjs/mapError.d.ts +2 -0
  36. package/rxjs/rxjs-operators.d.ts +13 -0
  37. package/rxjs/subjectifier.d.ts +10 -0
  38. package/rxjs/subscriber.directive.d.ts +14 -0
  39. package/table-builder/classes/DefaultSettings.d.ts +9 -0
  40. package/table-builder/classes/MatTableObservableDataSource.d.ts +9 -0
  41. package/table-builder/classes/TableBuilderConfig.d.ts +23 -0
  42. package/table-builder/classes/TableBuilderDataSource.d.ts +18 -0
  43. package/table-builder/classes/TableState.d.ts +81 -0
  44. package/table-builder/classes/data-store.d.ts +8 -0
  45. package/{src/table-builder/classes/display-col.ts → table-builder/classes/display-col.d.ts} +5 -5
  46. package/table-builder/classes/filter-info.d.ts +39 -0
  47. package/table-builder/classes/table-builder-general-settings.d.ts +117 -0
  48. package/table-builder/classes/table-builder.d.ts +22 -0
  49. package/table-builder/classes/table-store.d.ts +146 -0
  50. package/table-builder/classes/table-store.helpers.d.ts +31 -0
  51. package/table-builder/components/array-column.component.d.ts +15 -0
  52. package/table-builder/components/column-builder/column-builder.component.d.ts +41 -0
  53. package/table-builder/components/column-builder/column-helpers.d.ts +38 -0
  54. package/table-builder/components/column-header-menu/column-header-menu.component.d.ts +50 -0
  55. package/table-builder/components/date-filter/date-filter.component.d.ts +37 -0
  56. package/table-builder/components/date-time-filter/date-time-filter.component.d.ts +37 -0
  57. package/table-builder/components/filter/filter.component.d.ts +48 -0
  58. package/table-builder/components/filter/in-list/in-list-filter.component.d.ts +23 -0
  59. package/table-builder/components/gen-col-displayer/gen-col-displayer.component.d.ts +17 -0
  60. package/table-builder/components/generic-table/generic-table.component.d.ts +84 -0
  61. package/table-builder/components/generic-table/paginator.component.d.ts +26 -0
  62. package/table-builder/components/group-by-list/group-by-list.component.d.ts +7 -0
  63. package/table-builder/components/in-filter/in-filter.component.d.ts +20 -0
  64. package/{src/table-builder/components/index.ts → table-builder/components/index.d.ts} +9 -9
  65. package/table-builder/components/initialization-component/initialization-component.d.ts +15 -0
  66. package/table-builder/components/link-column.component.d.ts +23 -0
  67. package/table-builder/components/number-filter/number-filter.component.d.ts +39 -0
  68. package/table-builder/components/profiles-menu/profiles-menu.component.d.ts +33 -0
  69. package/table-builder/components/reset-menu/reset-menu.component.d.ts +25 -0
  70. package/table-builder/components/scroll-strategy.d.ts +45 -0
  71. package/table-builder/components/sort-menu/sort-menu.component-store.d.ts +24 -0
  72. package/table-builder/components/sort-menu/sort-menu.component.d.ts +19 -0
  73. package/table-builder/components/table-container/table-container.d.ts +104 -0
  74. package/table-builder/components/table-container/table-container.helpers/data-state.helpers.d.ts +7 -0
  75. package/table-builder/components/table-container/table-container.helpers/filter-state.helpers.d.ts +19 -0
  76. package/table-builder/components/table-container/table-container.helpers/groupBy.helpers.d.ts +19 -0
  77. package/table-builder/components/table-container/table-container.helpers/meta-data.helpers.d.ts +2 -0
  78. package/table-builder/components/table-container/table-container.helpers/sort-state.helpers.d.ts +12 -0
  79. package/table-builder/components/table-container/tableProps.d.ts +10 -0
  80. package/table-builder/components/table-container/virtual-scroll-container.d.ts +40 -0
  81. package/table-builder/components/table-container-filter/filter-list/filter-list.component.d.ts +15 -0
  82. package/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.d.ts +12 -0
  83. package/table-builder/components/table-container-filter/table-wrapper-filter-store.d.ts +14 -0
  84. package/table-builder/components/table-header-menu/table-header-menu.component.d.ts +15 -0
  85. package/table-builder/directives/custom-cell-directive.d.ts +34 -0
  86. package/{src/table-builder/directives/index.ts → table-builder/directives/index.d.ts} +5 -6
  87. package/table-builder/directives/multi-sort.directive.d.ts +10 -0
  88. package/table-builder/directives/resize-column.directive.d.ts +43 -0
  89. package/table-builder/directives/table-wrapper.directive.d.ts +8 -0
  90. package/table-builder/directives/tb-filter.directive.d.ts +116 -0
  91. package/table-builder/enums/filterTypes.d.ts +36 -0
  92. package/table-builder/functions/boolean-filter-function.d.ts +3 -0
  93. package/table-builder/functions/date-filter-function.d.ts +4 -0
  94. package/table-builder/functions/download-data.d.ts +1 -0
  95. package/table-builder/functions/null-filter-function.d.ts +2 -0
  96. package/table-builder/functions/number-filter-function.d.ts +4 -0
  97. package/table-builder/functions/sort-data-function.d.ts +6 -0
  98. package/table-builder/functions/string-filter-function.d.ts +5 -0
  99. package/{src/table-builder/interfaces/ColumnInfo.ts → table-builder/interfaces/ColumnInfo.d.ts} +6 -7
  100. package/{src/table-builder/interfaces/dictionary.ts → table-builder/interfaces/dictionary.d.ts} +3 -3
  101. package/table-builder/interfaces/report-def.d.ts +171 -0
  102. package/table-builder/ngrx/tableBuilderStateStore.d.ts +69 -0
  103. package/table-builder/pipes/column-total.pipe.d.ts +8 -0
  104. package/table-builder/pipes/format-filter-type.pipe.d.ts +8 -0
  105. package/table-builder/pipes/format-filter-value.pipe.d.ts +11 -0
  106. package/table-builder/pipes/key-display.d.ts +9 -0
  107. package/table-builder/services/export-to-csv.service.d.ts +14 -0
  108. package/table-builder/services/link-creator.service.d.ts +16 -0
  109. package/table-builder/services/table-template-service.d.ts +14 -0
  110. package/table-builder/services/transform-creator.d.ts +7 -0
  111. package/table-builder/table-builder.module.d.ts +14 -0
  112. package/utilities/array-helpers.d.ts +1 -0
  113. package/utilities/directives/auto-focus.directive.d.ts +9 -0
  114. package/utilities/directives/clickEmitterDirective.d.ts +7 -0
  115. package/utilities/directives/clickSubject.d.ts +9 -0
  116. package/utilities/directives/conditional-classes.directive.d.ts +12 -0
  117. package/utilities/directives/dialog-service.d.ts +10 -0
  118. package/utilities/directives/dialog.d.ts +45 -0
  119. package/utilities/directives/mat-toggle-group-directive.d.ts +21 -0
  120. package/utilities/directives/prevent-enter.directive.d.ts +6 -0
  121. package/utilities/directives/stop-propagation.directive.d.ts +7 -0
  122. package/utilities/directives/styler.d.ts +16 -0
  123. package/utilities/directives/trim-whitespace.directive.d.ts +7 -0
  124. package/{src/utilities/index.ts → utilities/index.d.ts} +15 -22
  125. package/utilities/module.d.ts +19 -0
  126. package/utilities/pipes/function.pipe.d.ts +11 -0
  127. package/utilities/pipes/phone.pipe.d.ts +8 -0
  128. package/utilities/pipes/space-case.pipes.d.ts +17 -0
  129. package/karma.conf.js +0 -44
  130. package/ng-package.json +0 -7
  131. package/src/action-state/action-state-spinner/action-state-spinner.component.css +0 -16
  132. package/src/action-state/action-state-spinner/action-state-spinner.component.html +0 -6
  133. package/src/action-state/action-state-spinner/action-state-spinner.component.spec.ts +0 -25
  134. package/src/action-state/action-state-spinner/action-state-spinner.component.ts +0 -25
  135. package/src/action-state/action-state-ui/action-state-ui.module.ts +0 -13
  136. package/src/action-state/ngrx-ext/ngrx-ext.module.ts +0 -15
  137. package/src/action-state/ngrx.ts +0 -69
  138. package/src/http-request-state/RequestStateFactory.ts +0 -56
  139. package/src/http-request-state/RequestStateStore.ts +0 -284
  140. package/src/http-request-state/directives/HttpStateDirectiveBase.ts +0 -29
  141. package/src/http-request-state/directives/http-error-state-directive.ts +0 -21
  142. package/src/http-request-state/directives/http-inProgress-state-directive.ts +0 -19
  143. package/src/http-request-state/directives/http-notStarted-state-directive.ts +0 -19
  144. package/src/http-request-state/directives/http-success-state-directive.ts +0 -29
  145. package/src/http-request-state/directives/request-state-directive.spec.ts +0 -73
  146. package/src/http-request-state/directives/request-state-directive.ts +0 -78
  147. package/src/http-request-state/helpers.ts +0 -30
  148. package/src/http-request-state/http-state-module.ts +0 -23
  149. package/src/http-request-state/models/view-context.ts +0 -18
  150. package/src/http-request-state/observable.spec.ts +0 -43
  151. package/src/http-request-state/request-state.ts +0 -69
  152. package/src/http-request-state/rxjs/getRequestorBody.ts +0 -10
  153. package/src/http-request-state/rxjs/getRequestorState.ts +0 -8
  154. package/src/http-request-state/rxjs/tapError.ts +0 -16
  155. package/src/http-request-state/rxjs/tapSuccess.ts +0 -16
  156. package/src/http-request-state/strategies.spec.ts +0 -42
  157. package/src/http-request-state/types.ts +0 -54
  158. package/src/ngrx/actionable-selector.ts +0 -160
  159. package/src/ngrx/index.ts +0 -1
  160. package/src/rxjs/defaultShareReplay.ts +0 -8
  161. package/src/rxjs/mapError.ts +0 -8
  162. package/src/rxjs/rxjs-operators.ts +0 -130
  163. package/src/rxjs/subjectifier.ts +0 -17
  164. package/src/rxjs/subscriber.directive.ts +0 -57
  165. package/src/specs/clickSubject.spec.ts +0 -95
  166. package/src/specs/dialog.spec.ts +0 -101
  167. package/src/specs/toggleGroupDirective.spec.ts +0 -229
  168. package/src/table-builder/classes/DefaultSettings.ts +0 -11
  169. package/src/table-builder/classes/MatTableObservableDataSource.ts +0 -23
  170. package/src/table-builder/classes/TableBuilderConfig.ts +0 -42
  171. package/src/table-builder/classes/TableBuilderDataSource.ts +0 -65
  172. package/src/table-builder/classes/TableState.ts +0 -125
  173. package/src/table-builder/classes/data-store.ts +0 -10
  174. package/src/table-builder/classes/filter-info.ts +0 -126
  175. package/src/table-builder/classes/table-builder-general-settings.ts +0 -198
  176. package/src/table-builder/classes/table-builder.ts +0 -105
  177. package/src/table-builder/classes/table-store.helpers.ts +0 -104
  178. package/src/table-builder/classes/table-store.ts +0 -440
  179. package/src/table-builder/components/array-column.component.ts +0 -34
  180. package/src/table-builder/components/column-builder/column-builder.component.html +0 -73
  181. package/src/table-builder/components/column-builder/column-builder.component.scss +0 -43
  182. package/src/table-builder/components/column-builder/column-builder.component.spec.ts +0 -49
  183. package/src/table-builder/components/column-builder/column-builder.component.ts +0 -129
  184. package/src/table-builder/components/column-builder/column-helpers.ts +0 -54
  185. package/src/table-builder/components/column-header-menu/column-header-menu.component.html +0 -109
  186. package/src/table-builder/components/column-header-menu/column-header-menu.component.scss +0 -97
  187. package/src/table-builder/components/column-header-menu/column-header-menu.component.ts +0 -94
  188. package/src/table-builder/components/date-filter/date-filter.component.html +0 -23
  189. package/src/table-builder/components/date-filter/date-filter.component.ts +0 -22
  190. package/src/table-builder/components/date-time-filter/date-time-filter.component.html +0 -9
  191. package/src/table-builder/components/date-time-filter/date-time-filter.component.ts +0 -20
  192. package/src/table-builder/components/filter/filter.component.html +0 -103
  193. package/src/table-builder/components/filter/filter.component.scss +0 -60
  194. package/src/table-builder/components/filter/filter.component.spec.ts +0 -87
  195. package/src/table-builder/components/filter/filter.component.ts +0 -64
  196. package/src/table-builder/components/filter/in-list/in-list-filter.component.ts +0 -85
  197. package/src/table-builder/components/gen-col-displayer/gen-col-displayer.component.html +0 -60
  198. package/src/table-builder/components/gen-col-displayer/gen-col-displayer.component.scss +0 -57
  199. package/src/table-builder/components/gen-col-displayer/gen-col-displayer.component.ts +0 -44
  200. package/src/table-builder/components/generic-table/generic-table.component.html +0 -96
  201. package/src/table-builder/components/generic-table/generic-table.component.scss +0 -38
  202. package/src/table-builder/components/generic-table/generic-table.component.ts +0 -399
  203. package/src/table-builder/components/generic-table/paginator.component.ts +0 -106
  204. package/src/table-builder/components/group-by-list/group-by-list.component.css +0 -17
  205. package/src/table-builder/components/group-by-list/group-by-list.component.html +0 -14
  206. package/src/table-builder/components/group-by-list/group-by-list.component.spec.ts +0 -23
  207. package/src/table-builder/components/group-by-list/group-by-list.component.ts +0 -18
  208. package/src/table-builder/components/in-filter/in-filter.component.css +0 -3
  209. package/src/table-builder/components/in-filter/in-filter.component.html +0 -19
  210. package/src/table-builder/components/in-filter/in-filter.component.ts +0 -65
  211. package/src/table-builder/components/initialization-component/initialization-component.html +0 -78
  212. package/src/table-builder/components/initialization-component/initialization-component.ts +0 -27
  213. package/src/table-builder/components/link-column.component.ts +0 -42
  214. package/src/table-builder/components/number-filter/number-filter.component.css +0 -10
  215. package/src/table-builder/components/number-filter/number-filter.component.html +0 -22
  216. package/src/table-builder/components/number-filter/number-filter.component.spec.ts +0 -30
  217. package/src/table-builder/components/number-filter/number-filter.component.ts +0 -25
  218. package/src/table-builder/components/profiles-menu/profiles-menu.component.html +0 -76
  219. package/src/table-builder/components/profiles-menu/profiles-menu.component.scss +0 -126
  220. package/src/table-builder/components/profiles-menu/profiles-menu.component.spec.ts +0 -23
  221. package/src/table-builder/components/profiles-menu/profiles-menu.component.ts +0 -63
  222. package/src/table-builder/components/reset-menu/reset-menu.component.css +0 -3
  223. package/src/table-builder/components/reset-menu/reset-menu.component.html +0 -10
  224. package/src/table-builder/components/reset-menu/reset-menu.component.ts +0 -87
  225. package/src/table-builder/components/scroll-strategy.ts +0 -139
  226. package/src/table-builder/components/sort-menu/sort-menu.component-store.ts +0 -57
  227. package/src/table-builder/components/sort-menu/sort-menu.component.html +0 -109
  228. package/src/table-builder/components/sort-menu/sort-menu.component.scss +0 -119
  229. package/src/table-builder/components/sort-menu/sort-menu.component.ts +0 -88
  230. package/src/table-builder/components/table-container/table-container.helpers/data-state.helpers.ts +0 -112
  231. package/src/table-builder/components/table-container/table-container.helpers/filter-state.helpers.ts +0 -125
  232. package/src/table-builder/components/table-container/table-container.helpers/groupBy.helpers.ts +0 -120
  233. package/src/table-builder/components/table-container/table-container.helpers/meta-data.helpers.ts +0 -16
  234. package/src/table-builder/components/table-container/table-container.helpers/sort-state.helpers.ts +0 -47
  235. package/src/table-builder/components/table-container/table-container.html +0 -79
  236. package/src/table-builder/components/table-container/table-container.scss +0 -47
  237. package/src/table-builder/components/table-container/table-container.ts +0 -403
  238. package/src/table-builder/components/table-container/tableProps.ts +0 -18
  239. package/src/table-builder/components/table-container/virtual-scroll-container.ts +0 -216
  240. package/src/table-builder/components/table-container-filter/filter-list/filter-list.component.html +0 -34
  241. package/src/table-builder/components/table-container-filter/filter-list/filter-list.component.ts +0 -44
  242. package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.css +0 -42
  243. package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.html +0 -11
  244. package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.spec.ts +0 -85
  245. package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.ts +0 -36
  246. package/src/table-builder/components/table-container-filter/table-wrapper-filter-store.ts +0 -23
  247. package/src/table-builder/components/table-header-menu/table-header-menu.component.css +0 -21
  248. package/src/table-builder/components/table-header-menu/table-header-menu.component.html +0 -48
  249. package/src/table-builder/components/table-header-menu/table-header-menu.component.ts +0 -35
  250. package/src/table-builder/directives/custom-cell-directive.ts +0 -59
  251. package/src/table-builder/directives/multi-sort.directive.spec.ts +0 -124
  252. package/src/table-builder/directives/multi-sort.directive.ts +0 -50
  253. package/src/table-builder/directives/resize-column.directive.ts +0 -107
  254. package/src/table-builder/directives/table-wrapper.directive.ts +0 -13
  255. package/src/table-builder/directives/tb-filter.directive.ts +0 -376
  256. package/src/table-builder/enums/filterTypes.ts +0 -40
  257. package/src/table-builder/functions/boolean-filter-function.ts +0 -12
  258. package/src/table-builder/functions/date-filter-function.ts +0 -68
  259. package/src/table-builder/functions/download-data.ts +0 -11
  260. package/src/table-builder/functions/null-filter-function.ts +0 -9
  261. package/src/table-builder/functions/number-filter-function.ts +0 -41
  262. package/src/table-builder/functions/sort-data-function.ts +0 -80
  263. package/src/table-builder/functions/string-filter-function.ts +0 -51
  264. package/src/table-builder/interfaces/column-template.ts +0 -9
  265. package/src/table-builder/interfaces/report-def.ts +0 -186
  266. package/src/table-builder/ngrx/tableBuilderStateStore.ts +0 -197
  267. package/src/table-builder/pipes/column-total.pipe.ts +0 -16
  268. package/src/table-builder/pipes/format-filter-type.pipe.ts +0 -12
  269. package/src/table-builder/pipes/format-filter-value.pipe.ts +0 -40
  270. package/src/table-builder/pipes/key-display.ts +0 -13
  271. package/src/table-builder/services/export-to-csv.service.ts +0 -75
  272. package/src/table-builder/services/link-creator.service.ts +0 -98
  273. package/src/table-builder/services/table-template-service.ts +0 -47
  274. package/src/table-builder/services/transform-creator.ts +0 -96
  275. package/src/table-builder/specs/table-custom-filters.spec.ts +0 -262
  276. package/src/table-builder/styles/collapser.styles.scss +0 -16
  277. package/src/table-builder/table-builder.module.ts +0 -38
  278. package/src/test.ts +0 -17
  279. package/src/utilities/array-helpers.ts +0 -13
  280. package/src/utilities/directives/auto-focus.directive.ts +0 -20
  281. package/src/utilities/directives/clickEmitterDirective.ts +0 -15
  282. package/src/utilities/directives/clickSubject.ts +0 -19
  283. package/src/utilities/directives/conditional-classes.directive.ts +0 -36
  284. package/src/utilities/directives/dialog-service.ts +0 -19
  285. package/src/utilities/directives/dialog.ts +0 -144
  286. package/src/utilities/directives/mat-toggle-group-directive.ts +0 -60
  287. package/src/utilities/directives/prevent-enter.directive.ts +0 -12
  288. package/src/utilities/directives/stop-propagation.directive.ts +0 -19
  289. package/src/utilities/directives/styler.ts +0 -44
  290. package/src/utilities/directives/trim-whitespace.directive.ts +0 -20
  291. package/src/utilities/module.ts +0 -55
  292. package/src/utilities/pipes/function.pipe.ts +0 -21
  293. package/src/utilities/pipes/phone.pipe.ts +0 -20
  294. package/src/utilities/pipes/space-case.pipes.spec.ts +0 -47
  295. package/src/utilities/pipes/space-case.pipes.ts +0 -26
  296. package/tsconfig.lib.json +0 -20
  297. package/tsconfig.lib.prod.json +0 -10
  298. package/tsconfig.spec.json +0 -17
@@ -1,107 +0,0 @@
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
- })
10
- export class ResizeColumnDirective implements OnInit{
11
- private renderer = inject(Renderer2);
12
- private el = inject(ElementRef);
13
- store = inject(TableStore);
14
-
15
- @Input({ alias : 'resizeColumn', transform: booleanAttribute }) resizable: boolean | string = false;
16
-
17
- @Input() key!: string;
18
-
19
- ngOnInit(){
20
- if (this.resizable){
21
- const {table, columnHead} = this.getTableAndColumnHeadHtmlElements();
22
- const resizer = this.createResizerSpanInColumnHead(columnHead);
23
-
24
- const aggregateMouseEventsMapped$ = this.mouseDownThroughMouseUpEventMapper(resizer,columnHead,table)
25
-
26
- const resizeColsData$ = aggregateMouseEventsMapped$.pipe(
27
- filter(({mouseMove})=>!!mouseMove.buttons),
28
- map( ({mouseDownData,mouseMove}) => {
29
- const {newTableWidth,newColumnWidth} = this.calculateNewWidths(mouseDownData,mouseMove)
30
- return ({
31
- key:this.key,
32
- widthInPixel:newColumnWidth,
33
- tableSize:newTableWidth,
34
- })
35
- }),
36
- defaultShareReplay()
37
- );
38
-
39
- this.store.setUserDefinedWidth(resizeColsData$.pipe(
40
- map(resizeData => ([{key: this.key, widthInPixel: resizeData.widthInPixel }]))
41
- ));
42
-
43
- this.store.setTableWidth(resizeColsData$.pipe(
44
- map(resizeData => resizeData.tableSize )));
45
- }
46
-
47
- }
48
-
49
- createResizerSpanInColumnHead(columnHead:HTMLElement){
50
- const resizer = this.renderer.createElement("span");
51
- this.renderer.addClass(resizer, "resize-holder");
52
- resizer.style['cursor']='col-resize';
53
- resizer.style['user-select']='none';
54
- resizer.style['width']='10px';
55
- resizer.style['height']='100%';
56
- resizer.style['position']='absolute';
57
- resizer.style['right']='0';
58
- resizer.style['top']='0';
59
- resizer.style['z-index']='1';
60
- this.renderer.appendChild(columnHead, resizer);
61
- return resizer;
62
- }
63
-
64
- getTableAndColumnHeadHtmlElements():{table:HTMLElement,columnHead:HTMLElement}{
65
- const columnHead: HTMLElement = this.el.nativeElement;
66
- const row = this.renderer.parentNode(columnHead);
67
- const table = this.renderer.parentNode(row);
68
- return ({table,columnHead})
69
- }
70
-
71
- mouseDownThroughMouseUpEventMapper(resizer:HTMLElement, columnHead:HTMLElement, table:HTMLElement){
72
- return this.resizerMouseDownEventMapper(resizer,columnHead,table)
73
- .pipe(
74
- switchMap( mouseDownData => fromEvent<MouseEvent>(table, "mousemove").pipe(
75
- map( mouseMove => ({mouseDownData, mouseMove})),
76
- takeUntil(fromEvent<MouseEvent>(document, "mouseup"))
77
- ) ),
78
- )
79
- }
80
- resizerMouseDownEventMapper(resizer:HTMLElement, columnHead:HTMLElement, table:HTMLElement){
81
- return fromEvent<MouseEvent>(resizer, "mousedown").pipe(
82
- map(event => ({
83
- startPageX: event.pageX,
84
- startColumnWidth: this.getElementWidth(columnHead),
85
- startTableWidth: this.getElementWidth(table),
86
- }))
87
- );
88
- }
89
-
90
- calculateNewWidths(mouseDownData: MouseDownData, mouseMove: MouseEvent):{newTableWidth:number,newColumnWidth:number}{
91
- const change = (mouseMove.pageX - mouseDownData.startPageX );
92
- let newColumnWidth = mouseDownData.startColumnWidth + change;
93
- if(newColumnWidth < 1){
94
- newColumnWidth = 1;
95
- }
96
- const columnChange = newColumnWidth - mouseDownData.startColumnWidth;
97
- const newTableWidth = (mouseDownData.startTableWidth + columnChange);
98
- return ({newTableWidth,newColumnWidth})
99
- }
100
- getElementWidth = (elem:HTMLElement) => (+(globalThis.getComputedStyle(elem).getPropertyValue('width').replace('px','')))
101
-
102
- }
103
- interface MouseDownData{
104
- startPageX:number,
105
- startColumnWidth:number,
106
- startTableWidth:number,
107
- }
@@ -1,13 +0,0 @@
1
- import { Directive, signal } from "@angular/core";
2
- import { TableCustomFilterDirective, TableFilterDirective } from "./tb-filter.directive";
3
-
4
- @Directive({
5
- selector: '[tbWrapper]',
6
- })
7
- export class TableWrapperDirective {
8
- $registrations = signal([] as (TableCustomFilterDirective | TableFilterDirective)[]);
9
-
10
- register(filter: TableCustomFilterDirective | TableFilterDirective) {
11
- this.$registrations.update( registrations => [...registrations,filter] );
12
- }
13
- }
@@ -1,376 +0,0 @@
1
- import { Directive, Input, Predicate, Signal, SimpleChanges, inject } 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 {
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 {
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 {
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 {
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 {
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 {
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 {
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 {
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'>;
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,68 +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 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
- [FilterType.DateIsOn]: dateIsOnFunc,
53
- [FilterType.DateIsNotOn]: dateIsNotOnFunc,
54
- [FilterType.DateOnOrAfter]: dateIsOnOrAfterFunc,
55
- [FilterType.DateOnOrBefore]: dateIsOnOrBeforeFunc,
56
- [FilterType.DateBetween]: dateBetweenFunc,
57
- [FilterType.IsNull]: isNull,
58
- };
59
-
60
- export const DateTimeFilterFuncs: FilterFuncs<DateTimeFilterTypes> = {
61
- ...DateFilterFuncs,
62
- [FilterType.DateTimeIsAt]: dateIsOnFunc,
63
- [FilterType.DateTimeIsNotAt]: dateIsNotOnFunc,
64
- [FilterType.DateTimeAtOrAfter]: dateIsOnOrAfterFunc,
65
- [FilterType.DateTimeAtOrBefore]: dateIsOnOrBeforeFunc,
66
- [FilterType.DateTimeBetween]: dateBetweenFunc,
67
- [FilterType.IsNull]: isNull,
68
- };
@@ -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
- };