@one-paragon/angular-utilities 2.0.0-beta.2 → 2.0.0-beta.4

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 (290) hide show
  1. package/karma.conf.js +44 -0
  2. package/ng-package.json +7 -0
  3. package/package.json +15 -27
  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 +25 -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 +150 -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 +42 -0
  49. package/src/table-builder/classes/TableBuilderDataSource.ts +66 -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 +123 -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.helpers.ts +102 -0
  57. package/src/table-builder/classes/table-store.ts +355 -0
  58. package/src/table-builder/components/array-column.component.ts +34 -0
  59. package/src/table-builder/components/column-builder/column-builder.component.html +69 -0
  60. package/src/table-builder/components/column-builder/column-builder.component.scss +43 -0
  61. package/src/table-builder/components/column-builder/column-builder.component.spec.ts +49 -0
  62. package/src/table-builder/components/column-builder/column-builder.component.ts +128 -0
  63. package/src/table-builder/components/column-builder/column-helpers.ts +52 -0
  64. package/src/table-builder/components/date-filter/date-filter.component.html +23 -0
  65. package/src/table-builder/components/date-filter/date-filter.component.ts +22 -0
  66. package/src/table-builder/components/date-time-filter/date-time-filter.component.html +9 -0
  67. package/src/table-builder/components/date-time-filter/date-time-filter.component.ts +20 -0
  68. package/src/table-builder/components/filter/filter.component.html +91 -0
  69. package/src/table-builder/components/filter/filter.component.scss +60 -0
  70. package/src/table-builder/components/filter/filter.component.spec.ts +87 -0
  71. package/src/table-builder/components/filter/filter.component.ts +59 -0
  72. package/src/table-builder/components/filter/in-list/in-list-filter.component.ts +85 -0
  73. package/src/table-builder/components/gen-col-displayer/gen-col-displayer.component.html +55 -0
  74. package/src/table-builder/components/gen-col-displayer/gen-col-displayer.component.scss +57 -0
  75. package/src/table-builder/components/gen-col-displayer/gen-col-displayer.component.ts +44 -0
  76. package/src/table-builder/components/generic-table/generic-table.component.html +77 -0
  77. package/src/table-builder/components/generic-table/generic-table.component.scss +38 -0
  78. package/src/table-builder/components/generic-table/generic-table.component.ts +330 -0
  79. package/src/table-builder/components/generic-table/paginator.component.ts +97 -0
  80. package/src/table-builder/components/group-by-list/group-by-list.component.css +8 -0
  81. package/src/table-builder/components/group-by-list/group-by-list.component.html +12 -0
  82. package/src/table-builder/components/group-by-list/group-by-list.component.spec.ts +23 -0
  83. package/src/table-builder/components/group-by-list/group-by-list.component.ts +18 -0
  84. package/src/table-builder/components/header-menu/header-menu.component.html +105 -0
  85. package/src/table-builder/components/header-menu/header-menu.component.scss +96 -0
  86. package/src/table-builder/components/header-menu/header-menu.component.ts +93 -0
  87. package/src/table-builder/components/in-filter/in-filter.component.css +3 -0
  88. package/src/table-builder/components/in-filter/in-filter.component.html +19 -0
  89. package/src/table-builder/components/in-filter/in-filter.component.ts +65 -0
  90. package/{table-builder/components/index.d.ts → src/table-builder/components/index.ts} +9 -9
  91. package/src/table-builder/components/initialization-component/initialization-component.html +29 -0
  92. package/src/table-builder/components/initialization-component/initialization-component.ts +22 -0
  93. package/src/table-builder/components/link-column.component.ts +45 -0
  94. package/src/table-builder/components/number-filter/number-filter.component.css +10 -0
  95. package/src/table-builder/components/number-filter/number-filter.component.html +22 -0
  96. package/src/table-builder/components/number-filter/number-filter.component.spec.ts +30 -0
  97. package/src/table-builder/components/number-filter/number-filter.component.ts +25 -0
  98. package/src/table-builder/components/profiles-menu/profiles-menu.component.html +73 -0
  99. package/src/table-builder/components/profiles-menu/profiles-menu.component.scss +126 -0
  100. package/src/table-builder/components/profiles-menu/profiles-menu.component.spec.ts +23 -0
  101. package/src/table-builder/components/profiles-menu/profiles-menu.component.ts +63 -0
  102. package/src/table-builder/components/scroll-strategy.ts +76 -0
  103. package/src/table-builder/components/sort-menu/sort-menu.component-store.ts +57 -0
  104. package/src/table-builder/components/sort-menu/sort-menu.component.html +109 -0
  105. package/src/table-builder/components/sort-menu/sort-menu.component.scss +119 -0
  106. package/src/table-builder/components/sort-menu/sort-menu.component.ts +88 -0
  107. package/{table-builder/components/table-container/table-container-imports.d.ts → src/table-builder/components/table-container/table-container-imports.ts} +27 -13
  108. package/src/table-builder/components/table-container/table-container.helpers/data-state.helpers.ts +141 -0
  109. package/src/table-builder/components/table-container/table-container.helpers/filter-state.helpers.ts +126 -0
  110. package/src/table-builder/components/table-container/table-container.helpers/groupBy.helpers.ts +86 -0
  111. package/src/table-builder/components/table-container/table-container.helpers/meta-data.helpers.ts +15 -0
  112. package/src/table-builder/components/table-container/table-container.helpers/sort-state.helpers.ts +45 -0
  113. package/src/table-builder/components/table-container/table-container.html +94 -0
  114. package/src/table-builder/components/table-container/table-container.scss +47 -0
  115. package/src/table-builder/components/table-container/table-container.spec.ts +154 -0
  116. package/src/table-builder/components/table-container/table-container.ts +307 -0
  117. package/src/table-builder/components/table-container/tableProps.ts +18 -0
  118. package/src/table-builder/components/table-container/virtual-scroll-container.ts +155 -0
  119. package/src/table-builder/components/table-container-filter/filter-list/filter-list.component.html +31 -0
  120. package/src/table-builder/components/table-container-filter/filter-list/filter-list.component.ts +44 -0
  121. package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.css +42 -0
  122. package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.html +10 -0
  123. package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.spec.ts +85 -0
  124. package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.ts +32 -0
  125. package/src/table-builder/components/table-container-filter/table-wrapper-filter-store.ts +23 -0
  126. package/src/table-builder/directives/custom-cell-directive.ts +58 -0
  127. package/{table-builder/directives/index.d.ts → src/table-builder/directives/index.ts} +6 -5
  128. package/src/table-builder/directives/multi-sort.directive.spec.ts +124 -0
  129. package/src/table-builder/directives/multi-sort.directive.ts +50 -0
  130. package/src/table-builder/directives/resize-column.directive.ts +107 -0
  131. package/src/table-builder/directives/table-wrapper.directive.ts +13 -0
  132. package/src/table-builder/directives/tb-filter.directive.ts +372 -0
  133. package/src/table-builder/enums/filterTypes.ts +40 -0
  134. package/src/table-builder/functions/boolean-filter-function.ts +12 -0
  135. package/src/table-builder/functions/date-filter-function.ts +68 -0
  136. package/src/table-builder/functions/download-data.ts +11 -0
  137. package/src/table-builder/functions/null-filter-function.ts +9 -0
  138. package/src/table-builder/functions/number-filter-function.ts +41 -0
  139. package/src/table-builder/functions/sort-data-function.ts +23 -0
  140. package/src/table-builder/functions/string-filter-function.ts +51 -0
  141. package/{table-builder/interfaces/ColumnInfo.d.ts → src/table-builder/interfaces/ColumnInfo.ts} +7 -6
  142. package/src/table-builder/interfaces/column-template.ts +9 -0
  143. package/{table-builder/interfaces/dictionary.d.ts → src/table-builder/interfaces/dictionary.ts} +3 -3
  144. package/src/table-builder/interfaces/report-def.ts +160 -0
  145. package/src/table-builder/ngrx/tableBuilderStateStore.ts +199 -0
  146. package/src/table-builder/pipes/column-total.pipe.ts +16 -0
  147. package/src/table-builder/pipes/format-filter-type.pipe.ts +12 -0
  148. package/src/table-builder/pipes/format-filter-value.pipe.ts +42 -0
  149. package/src/table-builder/pipes/key-display.ts +13 -0
  150. package/src/table-builder/services/export-to-csv.service.ts +75 -0
  151. package/src/table-builder/services/link-creator.service.ts +67 -0
  152. package/src/table-builder/services/table-template-service.ts +59 -0
  153. package/src/table-builder/services/transform-creator.ts +94 -0
  154. package/src/table-builder/specs/table-custom-filters.spec.ts +262 -0
  155. package/src/table-builder/styles/collapser.styles.scss +16 -0
  156. package/src/table-builder/table-builder.module.ts +73 -0
  157. package/src/test.ts +17 -0
  158. package/src/utilities/array-helpers.ts +13 -0
  159. package/src/utilities/directives/auto-focus.directive.ts +20 -0
  160. package/src/utilities/directives/clickEmitterDirective.ts +15 -0
  161. package/src/utilities/directives/clickSubject.ts +19 -0
  162. package/src/utilities/directives/conditional-classes.directive.ts +35 -0
  163. package/src/utilities/directives/dialog-service.ts +19 -0
  164. package/src/utilities/directives/dialog.ts +142 -0
  165. package/src/utilities/directives/mat-toggle-group-directive.ts +60 -0
  166. package/src/utilities/directives/prevent-enter.directive.ts +12 -0
  167. package/src/utilities/directives/stop-propagation.directive.ts +19 -0
  168. package/src/utilities/directives/styler.ts +39 -0
  169. package/src/utilities/directives/trim-whitespace.directive.ts +20 -0
  170. package/{utilities/index.d.ts → src/utilities/index.ts} +22 -15
  171. package/src/utilities/module.ts +55 -0
  172. package/src/utilities/pipes/function.pipe.ts +21 -0
  173. package/src/utilities/pipes/phone.pipe.ts +15 -0
  174. package/src/utilities/pipes/space-case.pipes.spec.ts +47 -0
  175. package/src/utilities/pipes/space-case.pipes.ts +26 -0
  176. package/tsconfig.lib.json +19 -0
  177. package/tsconfig.lib.prod.json +10 -0
  178. package/tsconfig.spec.json +17 -0
  179. package/action-state/action-state-spinner/action-state-spinner.component.d.ts +0 -12
  180. package/action-state/action-state-ui/action-state-ui.module.d.ts +0 -7
  181. package/action-state/ngrx-ext/ngrx-ext.module.d.ts +0 -8
  182. package/action-state/ngrx.d.ts +0 -31
  183. package/fesm2022/one-paragon-angular-utilities.mjs +0 -5681
  184. package/fesm2022/one-paragon-angular-utilities.mjs.map +0 -1
  185. package/http-request-state/HttpRequestStateFactory.d.ts +0 -17
  186. package/http-request-state/HttpRequestStateStore.d.ts +0 -58
  187. package/http-request-state/directives/HttpStateDirectiveBase.d.ts +0 -14
  188. package/http-request-state/directives/http-error-state-directive.d.ts +0 -9
  189. package/http-request-state/directives/http-inProgress-state-directive.d.ts +0 -9
  190. package/http-request-state/directives/http-notStarted-state-directive.d.ts +0 -9
  191. package/http-request-state/directives/http-success-state-directive.d.ts +0 -16
  192. package/http-request-state/directives/request-state-directive.d.ts +0 -34
  193. package/http-request-state/helpers.d.ts +0 -9
  194. package/http-request-state/http-request-state.d.ts +0 -12
  195. package/http-request-state/http-state-module.d.ts +0 -11
  196. package/http-request-state/rxjs/getRequestorBody.d.ts +0 -3
  197. package/http-request-state/rxjs/getRequestorState.d.ts +0 -3
  198. package/http-request-state/rxjs/tapError.d.ts +0 -3
  199. package/http-request-state/rxjs/tapSuccess.d.ts +0 -3
  200. package/http-request-state/types.d.ts +0 -41
  201. package/index.d.ts +0 -5
  202. package/ngrx/actionable-selector.d.ts +0 -31
  203. package/ngrx/index.d.ts +0 -1
  204. package/rxjs/defaultShareReplay.d.ts +0 -2
  205. package/rxjs/mapError.d.ts +0 -2
  206. package/rxjs/rxjs-operators.d.ts +0 -13
  207. package/rxjs/subjectifier.d.ts +0 -8
  208. package/rxjs/subscriber.directive.d.ts +0 -14
  209. package/table-builder/classes/DefaultSettings.d.ts +0 -9
  210. package/table-builder/classes/MatTableObservableDataSource.d.ts +0 -9
  211. package/table-builder/classes/TableBuilderConfig.d.ts +0 -23
  212. package/table-builder/classes/TableBuilderDataSource.d.ts +0 -18
  213. package/table-builder/classes/TableState.d.ts +0 -66
  214. package/table-builder/classes/data-store.d.ts +0 -8
  215. package/table-builder/classes/filter-info.d.ts +0 -37
  216. package/table-builder/classes/table-builder-general-settings.d.ts +0 -85
  217. package/table-builder/classes/table-builder.d.ts +0 -18
  218. package/table-builder/classes/table-store.d.ts +0 -130
  219. package/table-builder/classes/table-store.helpers.d.ts +0 -28
  220. package/table-builder/components/array-column.component.d.ts +0 -15
  221. package/table-builder/components/column-builder/column-builder.component.d.ts +0 -40
  222. package/table-builder/components/column-builder/column-helpers.d.ts +0 -36
  223. package/table-builder/components/date-filter/date-filter.component.d.ts +0 -37
  224. package/table-builder/components/date-time-filter/date-time-filter.component.d.ts +0 -37
  225. package/table-builder/components/filter/filter.component.d.ts +0 -46
  226. package/table-builder/components/filter/in-list/in-list-filter.component.d.ts +0 -23
  227. package/table-builder/components/gen-col-displayer/gen-col-displayer.component.d.ts +0 -17
  228. package/table-builder/components/generic-table/generic-table.component.d.ts +0 -72
  229. package/table-builder/components/generic-table/paginator.component.d.ts +0 -28
  230. package/table-builder/components/group-by-list/group-by-list.component.d.ts +0 -7
  231. package/table-builder/components/header-menu/header-menu.component.d.ts +0 -49
  232. package/table-builder/components/in-filter/in-filter.component.d.ts +0 -20
  233. package/table-builder/components/initialization-component/initialization-component.d.ts +0 -13
  234. package/table-builder/components/link-column.component.d.ts +0 -25
  235. package/table-builder/components/number-filter/number-filter.component.d.ts +0 -39
  236. package/table-builder/components/profiles-menu/profiles-menu.component.d.ts +0 -32
  237. package/table-builder/components/scroll-strategy.d.ts +0 -22
  238. package/table-builder/components/sort-menu/sort-menu.component-store.d.ts +0 -24
  239. package/table-builder/components/sort-menu/sort-menu.component.d.ts +0 -19
  240. package/table-builder/components/table-container/table-container.d.ts +0 -83
  241. package/table-builder/components/table-container/table-container.helpers/data-state.helpers.d.ts +0 -6
  242. package/table-builder/components/table-container/table-container.helpers/filter-state.helpers.d.ts +0 -19
  243. package/table-builder/components/table-container/table-container.helpers/groupBy.helpers.d.ts +0 -17
  244. package/table-builder/components/table-container/table-container.helpers/meta-data.helpers.d.ts +0 -2
  245. package/table-builder/components/table-container/table-container.helpers/sort-state.helpers.d.ts +0 -8
  246. package/table-builder/components/table-container/tableProps.d.ts +0 -10
  247. package/table-builder/components/table-container/virtual-scroll-container.d.ts +0 -36
  248. package/table-builder/components/table-container-filter/filter-list/filter-list.component.d.ts +0 -15
  249. package/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.d.ts +0 -12
  250. package/table-builder/components/table-container-filter/table-wrapper-filter-store.d.ts +0 -14
  251. package/table-builder/directives/custom-cell-directive.d.ts +0 -32
  252. package/table-builder/directives/multi-sort.directive.d.ts +0 -10
  253. package/table-builder/directives/resize-column.directive.d.ts +0 -43
  254. package/table-builder/directives/table-wrapper.directive.d.ts +0 -8
  255. package/table-builder/directives/tb-filter.directive.d.ts +0 -113
  256. package/table-builder/enums/filterTypes.d.ts +0 -36
  257. package/table-builder/functions/boolean-filter-function.d.ts +0 -3
  258. package/table-builder/functions/date-filter-function.d.ts +0 -4
  259. package/table-builder/functions/download-data.d.ts +0 -1
  260. package/table-builder/functions/null-filter-function.d.ts +0 -2
  261. package/table-builder/functions/number-filter-function.d.ts +0 -4
  262. package/table-builder/functions/sort-data-function.d.ts +0 -6
  263. package/table-builder/functions/string-filter-function.d.ts +0 -5
  264. package/table-builder/interfaces/report-def.d.ts +0 -151
  265. package/table-builder/ngrx/tableBuilderStateStore.d.ts +0 -70
  266. package/table-builder/pipes/column-total.pipe.d.ts +0 -8
  267. package/table-builder/pipes/format-filter-type.pipe.d.ts +0 -8
  268. package/table-builder/pipes/format-filter-value.pipe.d.ts +0 -11
  269. package/table-builder/pipes/key-display.d.ts +0 -9
  270. package/table-builder/services/export-to-csv.service.d.ts +0 -14
  271. package/table-builder/services/link-creator.service.d.ts +0 -16
  272. package/table-builder/services/table-template-service.d.ts +0 -14
  273. package/table-builder/services/transform-creator.d.ts +0 -15
  274. package/table-builder/table-builder.module.d.ts +0 -21
  275. package/utilities/array-helpers.d.ts +0 -1
  276. package/utilities/directives/auto-focus.directive.d.ts +0 -9
  277. package/utilities/directives/clickEmitterDirective.d.ts +0 -7
  278. package/utilities/directives/clickSubject.d.ts +0 -9
  279. package/utilities/directives/conditional-classes.directive.d.ts +0 -13
  280. package/utilities/directives/dialog-service.d.ts +0 -10
  281. package/utilities/directives/dialog.d.ts +0 -44
  282. package/utilities/directives/mat-toggle-group-directive.d.ts +0 -21
  283. package/utilities/directives/prevent-enter.directive.d.ts +0 -6
  284. package/utilities/directives/stop-propagation.directive.d.ts +0 -7
  285. package/utilities/directives/styler.d.ts +0 -15
  286. package/utilities/directives/trim-whitespace.directive.d.ts +0 -7
  287. package/utilities/module.d.ts +0 -19
  288. package/utilities/pipes/function.pipe.d.ts +0 -11
  289. package/utilities/pipes/phone.pipe.d.ts +0 -7
  290. package/utilities/pipes/space-case.pipes.d.ts +0 -17
@@ -0,0 +1,372 @@
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 { FilterType, FilterTypes } 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
+
15
+
16
+ const inputs = [
17
+ 'predicate: tbCustomFilter',
18
+ 'filterId: filterId',
19
+ ];
20
+
21
+
22
+ @Directive({
23
+ selector: 'tb-abstract'
24
+ })
25
+ export abstract class TableCustomFilterDirective {
26
+ abstract filter$ : Observable<CustomFilter>;
27
+ filterId!: string;
28
+ savable = false;
29
+ abstract active: boolean;
30
+ abstract reset(): void;
31
+ }
32
+
33
+
34
+ @Directive({
35
+ selector: "[tbFilter]",
36
+ }) export class TableFilterDirective {
37
+ protected model = inject(NgControl, { optional: true });
38
+ private wrapper = inject(TableWrapperDirective, { optional: true });
39
+ constructor() {
40
+ if(this.wrapper) {
41
+ this.wrapper.register(this);
42
+ }
43
+ if(this.model) {
44
+ subscriber(this.model!.valueChanges!, val => {
45
+ if(this.filterType === FilterTypes.StringContains && val === ''){
46
+ val = undefined
47
+ }
48
+ this.filterValue = val;
49
+ this.update();
50
+ })
51
+ }
52
+ }
53
+ reset() {
54
+ this.filterValue = undefined;
55
+ }
56
+ filter$ = new ReplaySubject<FilterInfo>(1);
57
+
58
+ @Input() filterType!: FilterType;
59
+ @Input() key!: string;
60
+ @Input() fieldType!: FieldType;
61
+ @Input() filterId!: string;
62
+ @Input() active = true;
63
+ @Input() filterValue: any = null;
64
+
65
+ setFilterValue(value: any) {
66
+ if(this.model) {
67
+ setTimeout(() => {
68
+ this.model!.reset(value);
69
+ }, 0);
70
+ } else {
71
+ this.filterValue = value;
72
+ }
73
+ }
74
+
75
+ savable = false;
76
+ ready = false;
77
+
78
+ _userActive = true;
79
+ ngOnChanges(changes: SimpleChanges) {
80
+ this.update();
81
+ }
82
+
83
+ ngOnInit() {
84
+ if(!this.filterId) {
85
+ this.filterId = crypto.randomUUID();
86
+ } else {
87
+ this.savable = true;
88
+ }
89
+ this.ready = true;
90
+ this.update();
91
+ }
92
+
93
+ protected setFilter(filter: FilterInfo ) {
94
+ this.filter$.next(filter);
95
+ }
96
+
97
+ update() {
98
+ if (this.ready) {
99
+ this.setFilter(
100
+ {
101
+ filterId: this.filterId,
102
+ key: this.key,
103
+ filterType: this.filterType,
104
+ fieldType: this.fieldType,
105
+ filterValue: this.filterValue,
106
+ active: this.active && this.filterValue !== undefined,
107
+ _isExternallyManaged: true,
108
+ }
109
+ );
110
+
111
+ }
112
+ }
113
+ }
114
+
115
+ @Directive({
116
+ selector: '[tbFilterStringContains]',
117
+ providers: [{ provide: TableFilterDirective, useExisting: TableFilterStringContainsDirective }],
118
+ inputs: [
119
+ 'key:tbFilterStringContains',
120
+ 'filterValue:filterValue',
121
+ 'filterId: filterId',
122
+ 'active: active',
123
+ ],
124
+ }) export class TableFilterStringContainsDirective extends TableFilterDirective {
125
+ constructor() {
126
+ super();
127
+ this.filterType = FilterTypes.StringContains;
128
+ this.fieldType = FieldType.String;
129
+ }
130
+
131
+ override reset() {
132
+ if(this.model) {
133
+ this.model.reset();
134
+ }
135
+ super.reset();
136
+ }
137
+
138
+ override setFilter(filter: FilterInfo) {
139
+ filter.active = filter.filterValue && this._userActive;
140
+ super.setFilter(filter);
141
+ }
142
+
143
+ ngOnChanges(changes: SimpleChanges) {
144
+ if(changes['active']) {
145
+ this._userActive = changes['active'].currentValue;
146
+ }
147
+ super.ngOnChanges(changes);
148
+ }
149
+ }
150
+
151
+ @Directive({
152
+ selector: "[tbCustomFilter]",
153
+ })
154
+ export abstract class TableCustomFilterDirectiveBase<T = any> extends TableCustomFilterDirective {
155
+
156
+ filter$ = new ReplaySubject<CustomFilter>(1);
157
+ filter!: CustomFilter;
158
+
159
+ _predicate!: Predicate<T>;
160
+ @Input('tbCustomFilter') set predicate( val: Predicate<T> ) {
161
+ this._predicate = val;
162
+ this.update({predicate:val});
163
+ }
164
+
165
+ _active: boolean = false;
166
+ ready = false;
167
+
168
+ update(val: Partial<CustomFilter> ) {
169
+ if(this.ready) {
170
+ this.filter = {...this.filter,...val};
171
+ this.filter$.next(this.filter);
172
+ }
173
+ }
174
+
175
+ @Input() set active(val: boolean) {
176
+ if(this._active !== val) {
177
+ this._active = val;
178
+ this.update({active:val});
179
+ }
180
+ }
181
+ get active(): boolean {
182
+ return this._active;
183
+ }
184
+
185
+ ngOnInit() {
186
+ if(!this.filterId) {
187
+ this.filterId = crypto.randomUUID();
188
+ } else {
189
+ this.savable = true;
190
+ }
191
+
192
+ this.filter = {
193
+ filterType: FilterTypes.Custom,
194
+ filterId: this.filterId,
195
+ active: this._active,
196
+ predicate: this._predicate,
197
+ };
198
+ this.ready = true;
199
+ this.filter$.next(this.filter);
200
+ }
201
+ }
202
+
203
+ @Directive()
204
+ export abstract class TbSelectedFilterDirective extends TableCustomFilterDirectiveBase {
205
+
206
+ protected wrapper = inject(TableWrapperDirective, { optional: true });
207
+ protected constructor(private change: Observable<any>, private isActive: () => boolean) {
208
+ super();
209
+ if(this.wrapper) {
210
+ this.wrapper.register(this);
211
+ }
212
+ }
213
+
214
+ reset() {
215
+ this.active = false;
216
+ }
217
+
218
+ destroySubject$ = new ReplaySubject<void>(1);
219
+ ngOnDestroy() {
220
+ this.destroySubject$.next();
221
+ }
222
+
223
+ ngOnInit(): void {
224
+ this._active = this.isActive();
225
+ super.ngOnInit();
226
+ this.change.pipe(takeUntil(this.destroySubject$)).subscribe( () => {
227
+ this.active = this.isActive();
228
+ });
229
+ }
230
+ }
231
+
232
+ // Checkbox
233
+ @Directive({
234
+ selector: 'mat-checkbox[tbCustomFilter]',
235
+ inputs: [
236
+ ...inputs
237
+ ],
238
+ providers: [{ provide: TableCustomFilterDirective, useExisting: MatCheckboxTbFilterDirective }],
239
+ })
240
+ export class MatCheckboxTbFilterDirective extends TbSelectedFilterDirective {
241
+ private matCheckbox = inject(MatCheckbox);
242
+
243
+
244
+ override set active(val: boolean) {
245
+ this.matCheckbox.checked = val;
246
+ super.active = val;
247
+ }
248
+ constructor() {
249
+ const matCheckbox = inject(MatCheckbox);
250
+ super(matCheckbox.change, () => matCheckbox.checked);
251
+ this.matCheckbox = matCheckbox;
252
+ }
253
+ }
254
+
255
+
256
+ @Directive({
257
+ selector: 'mat-slide-toggle[tbCustomFilter]',
258
+ inputs: [
259
+ ...inputs
260
+ ],
261
+ providers: [{ provide: TableCustomFilterDirective, useExisting: MatSlideToggleTbFilterDirective }],
262
+ })
263
+ export class MatSlideToggleTbFilterDirective extends TbSelectedFilterDirective {
264
+ private matSlideToggle: MatSlideToggle;
265
+
266
+ override set active(val: boolean) {
267
+ this.matSlideToggle.checked = val;
268
+ super.active = val;
269
+ }
270
+ constructor() {
271
+ const matSlideToggle = inject(MatSlideToggle);
272
+
273
+ super(matSlideToggle.change, () => matSlideToggle.checked);
274
+ this.matSlideToggle = matSlideToggle;
275
+
276
+ }
277
+
278
+ ngOnInit(): void {
279
+ super.ngOnInit();
280
+ }
281
+ }
282
+
283
+ // Radio button
284
+ @Directive({
285
+ selector: 'mat-radio-button[tbCustomFilter]',
286
+ inputs: ['predicate: tbCustomFilter'],
287
+ providers: [{ provide: TableCustomFilterDirective, useExisting: MatRadioButtonTbFilterDirective }],
288
+ })
289
+ export class MatRadioButtonTbFilterDirective extends TbSelectedFilterDirective {
290
+ private matRadioButton: MatRadioButton;
291
+
292
+
293
+ override set active(val: boolean) {
294
+ this.matRadioButton.checked = val;
295
+ super.active = val;
296
+ }
297
+ constructor() {
298
+ const matRadioButton = inject(MatRadioButton);
299
+
300
+ super(matRadioButton.change, () => matRadioButton.checked);
301
+ this.matRadioButton = matRadioButton;
302
+ }
303
+
304
+ ngOnInit(): void {
305
+ super.ngOnInit();
306
+ }
307
+ }
308
+
309
+ // Option (select)
310
+ @Directive({
311
+ selector: 'mat-option[tbCustomFilter]',
312
+ inputs: [
313
+ ...inputs
314
+ ],
315
+ providers: [{ provide: TableCustomFilterDirective, useExisting: MatOptionTbFilterDirective }],
316
+ })
317
+ export class MatOptionTbFilterDirective extends TbSelectedFilterDirective {
318
+ private matOption: MatOption;
319
+
320
+ override set active(val: boolean) {
321
+ if(val) {
322
+ this.matOption.select();
323
+ } else {
324
+ this.matOption.deselect();
325
+ }
326
+ super.active = val;
327
+ }
328
+ constructor() {
329
+ const matOption = inject(MatOption);
330
+
331
+ super( matOption.onSelectionChange.pipe(tap( d => {
332
+ if(!matOption.value) {
333
+ matOption.value = crypto.randomUUID();
334
+ }
335
+ }
336
+
337
+ )), () => matOption.selected);
338
+ this.matOption = matOption;
339
+ }
340
+
341
+ ngOnInit(): void {
342
+ super.ngOnInit();
343
+ }
344
+ }
345
+
346
+ // Button toggle
347
+ @Directive({
348
+ selector: 'mat-button-toggle[tbCustomFilter]',
349
+ inputs: [
350
+ ...inputs
351
+ ],
352
+ providers: [{ provide: TableCustomFilterDirective, useExisting: MatButtonToggleFilterDirective }],
353
+ })
354
+ export class MatButtonToggleFilterDirective extends TbSelectedFilterDirective {
355
+ private matButtonToggle: MatButtonToggle;
356
+
357
+ override set active(val: boolean) {
358
+ this.matButtonToggle.checked = val;
359
+ super.active = val;
360
+ }
361
+ constructor() {
362
+ const matButtonToggle = inject(MatButtonToggle);
363
+
364
+ super(matButtonToggle.change, () => matButtonToggle.checked);
365
+ this.matButtonToggle = matButtonToggle;
366
+
367
+ }
368
+
369
+ ngOnInit(): void {
370
+ super.ngOnInit();
371
+ }
372
+ }
@@ -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
+ };
@@ -0,0 +1,23 @@
1
+ import { Sort } from "@angular/material/sort";
2
+ import { orderBy } from 'lodash';
3
+ import { Predicate } from "@angular/core";
4
+
5
+ export type direc = 'asc' | 'desc' | boolean;
6
+
7
+ export function sortData<T>(data: T[], sorted: Sort[]): T[] {
8
+ const ordered = orderBy(data, sorted.map(r => r.active), sorted.map(r => r.direction as direc ));
9
+ return ordered;
10
+ }
11
+
12
+ export function filterData<T>(data: T[], filters: Predicate<T>[], resetAll = false){
13
+ for (let index = 0; index < data.length; index++) {
14
+ const element = data[index];
15
+ const hide = !filters.every(filter => filter(element));
16
+ if(hide || resetAll){
17
+ element[tbNoShowSymbol] = hide;
18
+ }
19
+ }
20
+ return data;
21
+ }
22
+
23
+ export const tbNoShowSymbol = Symbol('tb_no_show');
@@ -0,0 +1,51 @@
1
+ import { FilterFunc, FilterFuncs, FilterInfo } from '../classes/filter-info';
2
+ import { EnumFilterTypes, FilterTypes, StringFilterTypes } from '../enums/filterTypes';
3
+ import { isNull } from './null-filter-function';
4
+
5
+
6
+ const stringEqualFunc:FilterFunc<string> = (filterInfo:FilterInfo) => {
7
+ const equalsVal = prepareForStringCompare(filterInfo.filterValue);
8
+ return ((val)=> prepareForStringCompare(val) === equalsVal );
9
+ }
10
+
11
+ const stringContainsFunc:FilterFunc<string> = (filterInfo:FilterInfo) => {
12
+ const containsVal = prepareForStringCompare(filterInfo.filterValue);
13
+ return ((val)=>prepareForStringCompare(val).includes(containsVal));
14
+ }
15
+
16
+ const stringDoesNotContainFunc:FilterFunc<string> = (filterInfo:FilterInfo) => {
17
+ const doesNotContainVal = prepareForStringCompare(filterInfo.filterValue);
18
+ return ((val)=> !prepareForStringCompare(val)?.includes(doesNotContainVal));
19
+ }
20
+
21
+ const stringStartsWithFunc:FilterFunc<string> = (filterInfo:FilterInfo) => {
22
+ const startsWith = prepareForStringCompare(filterInfo.filterValue);
23
+ return ((val)=> prepareForStringCompare(val).startsWith(startsWith));
24
+ }
25
+
26
+ const stringEndsWithFunc:FilterFunc<string> = (filterInfo:FilterInfo) => {
27
+ const startsWith = prepareForStringCompare(filterInfo.filterValue);
28
+ return ((val)=> prepareForStringCompare(val).endsWith(startsWith));
29
+ }
30
+
31
+ const multipleStringValuesEqualsFunc:FilterFunc<string[],string> = (filterInfo:FilterInfo) => {
32
+ const filterVals = filterInfo.filterValue.map( (v: string) => prepareForStringCompare(v));
33
+ return ((val)=> filterVals.some((s:string) => prepareForStringCompare(val) === s));
34
+ }
35
+
36
+ export const StringFilterFuncs: FilterFuncs<StringFilterTypes> = {
37
+ [FilterTypes.StringEquals]: stringEqualFunc,
38
+ [FilterTypes.StringContains]: stringContainsFunc,
39
+ [FilterTypes.StringDoesNotContain]: stringDoesNotContainFunc,
40
+ [FilterTypes.StringStartWith]: stringStartsWithFunc,
41
+ [FilterTypes.StringEndsWith]: stringEndsWithFunc,
42
+ [FilterTypes.IsNull]: isNull,
43
+ [FilterTypes.In]: multipleStringValuesEqualsFunc,
44
+ };
45
+
46
+ export const EnumFilterFuncs: FilterFuncs<EnumFilterTypes> = {
47
+ [FilterTypes.IsNull]: isNull,
48
+ [FilterTypes.In] : multipleStringValuesEqualsFunc,
49
+ };
50
+
51
+ export const prepareForStringCompare = (val: any):string => (val?.toString().trim().toLowerCase());
@@ -1,6 +1,7 @@
1
- import { CustomCellDirective } from "../directives/custom-cell-directive";
2
- import { MetaData } from "./report-def";
3
- export interface ColumnInfo {
4
- metaData: MetaData;
5
- customCell?: CustomCellDirective;
6
- }
1
+ import { CustomCellDirective } from "../directives/custom-cell-directive";
2
+ import { MetaData } from "./report-def";
3
+
4
+ export interface ColumnInfo {
5
+ metaData: MetaData;
6
+ customCell?: CustomCellDirective;
7
+ }
@@ -0,0 +1,9 @@
1
+ import { TemplateRef } from '@angular/core';
2
+ import { MetaData } from './report-def';
3
+
4
+ export class ColumnTemplates {
5
+ header: TemplateRef<any>;
6
+ footer: TemplateRef<any>;
7
+ body: TemplateRef<any>;
8
+ metaData: MetaData;
9
+ }
@@ -1,3 +1,3 @@
1
- export interface Dictionary<T> {
2
- [key: string]: T;
3
- }
1
+ export interface Dictionary<T> {
2
+ [key: string]: T;
3
+ }