@one-paragon/angular-utilities 2.2.6 → 2.2.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (297) hide show
  1. package/action-state/action-state-spinner/action-state-spinner.component.d.ts +12 -0
  2. package/action-state/action-state-ui/action-state-ui.module.d.ts +7 -0
  3. package/{src/action-state/index.ts → action-state/index.d.ts} +4 -8
  4. package/action-state/ngrx-ext/ngrx-ext.module.d.ts +8 -0
  5. package/action-state/ngrx.d.ts +31 -0
  6. package/fesm2022/one-paragon-angular-utilities.mjs +6565 -0
  7. package/fesm2022/one-paragon-angular-utilities.mjs.map +1 -0
  8. package/http-request-state/RequestStateFactory.d.ts +17 -0
  9. package/http-request-state/RequestStateStore.d.ts +101 -0
  10. package/{src/http-request-state/deprecated.ts → http-request-state/deprecated.d.ts} +20 -20
  11. package/http-request-state/directives/HttpStateDirectiveBase.d.ts +14 -0
  12. package/http-request-state/directives/http-error-state-directive.d.ts +10 -0
  13. package/http-request-state/directives/http-inProgress-state-directive.d.ts +10 -0
  14. package/http-request-state/directives/http-notStarted-state-directive.d.ts +10 -0
  15. package/http-request-state/directives/http-success-state-directive.d.ts +17 -0
  16. package/{src/http-request-state/directives/index.ts → http-request-state/directives/index.d.ts} +5 -5
  17. package/http-request-state/directives/request-state-directive.d.ts +34 -0
  18. package/http-request-state/helpers.d.ts +9 -0
  19. package/http-request-state/http-state-module.d.ts +11 -0
  20. package/{src/http-request-state/index.ts → http-request-state/index.d.ts} +7 -7
  21. package/http-request-state/request-state.d.ts +12 -0
  22. package/http-request-state/rxjs/getRequestorBody.d.ts +3 -0
  23. package/http-request-state/rxjs/getRequestorState.d.ts +3 -0
  24. package/{src/http-request-state/rxjs/index.ts → http-request-state/rxjs/index.d.ts} +4 -4
  25. package/http-request-state/rxjs/tapError.d.ts +3 -0
  26. package/http-request-state/rxjs/tapSuccess.d.ts +3 -0
  27. package/http-request-state/types.d.ts +41 -0
  28. package/index.d.ts +5 -0
  29. package/ngrx/actionable-selector.d.ts +32 -0
  30. package/ngrx/index.d.ts +1 -0
  31. package/package.json +27 -15
  32. package/{src/public-api.ts → public-api.d.ts} +16 -35
  33. package/rxjs/defaultShareReplay.d.ts +2 -0
  34. package/{src/rxjs/index.ts → rxjs/index.d.ts} +5 -5
  35. package/rxjs/mapError.d.ts +2 -0
  36. package/rxjs/rxjs-operators.d.ts +13 -0
  37. package/rxjs/subjectifier.d.ts +10 -0
  38. package/rxjs/subscriber.directive.d.ts +14 -0
  39. package/table-builder/classes/DefaultSettings.d.ts +9 -0
  40. package/table-builder/classes/MatTableObservableDataSource.d.ts +9 -0
  41. package/table-builder/classes/TableBuilderConfig.d.ts +31 -0
  42. package/table-builder/classes/TableBuilderDataSource.d.ts +18 -0
  43. package/table-builder/classes/TableState.d.ts +81 -0
  44. package/table-builder/classes/data-store.d.ts +8 -0
  45. package/{src/table-builder/classes/display-col.ts → table-builder/classes/display-col.d.ts} +5 -5
  46. package/table-builder/classes/filter-info.d.ts +39 -0
  47. package/table-builder/classes/table-builder-general-settings.d.ts +122 -0
  48. package/table-builder/classes/table-builder.d.ts +22 -0
  49. package/table-builder/classes/table-store.d.ts +146 -0
  50. package/table-builder/classes/table-store.helpers.d.ts +31 -0
  51. package/table-builder/components/array-column.component.d.ts +15 -0
  52. package/table-builder/components/column-builder/column-builder.component.d.ts +41 -0
  53. package/table-builder/components/column-builder/column-helpers.d.ts +38 -0
  54. package/table-builder/components/column-header-menu/column-header-menu.component.d.ts +50 -0
  55. package/table-builder/components/date-filter/date-filter.component.d.ts +37 -0
  56. package/table-builder/components/date-time-filter/date-time-filter.component.d.ts +37 -0
  57. package/table-builder/components/filter/filter.component.d.ts +48 -0
  58. package/table-builder/components/filter/in-list/in-list-filter.component.d.ts +22 -0
  59. package/table-builder/components/gen-col-displayer/gen-col-displayer.component.d.ts +17 -0
  60. package/table-builder/components/generic-table/generic-table.component.d.ts +85 -0
  61. package/table-builder/components/generic-table/paginator.component.d.ts +26 -0
  62. package/table-builder/components/group-by-list/group-by-list.component.d.ts +11 -0
  63. package/table-builder/components/in-filter/in-filter.component.d.ts +20 -0
  64. package/{src/table-builder/components/index.ts → table-builder/components/index.d.ts} +9 -9
  65. package/table-builder/components/initialization-component/initialization.component.d.ts +15 -0
  66. package/table-builder/components/link-column.component.d.ts +23 -0
  67. package/table-builder/components/number-filter/number-filter.component.d.ts +39 -0
  68. package/table-builder/components/profiles-menu/profiles-menu.component.d.ts +33 -0
  69. package/table-builder/components/reset-menu/reset-menu.component.d.ts +25 -0
  70. package/table-builder/components/scroll-strategy.d.ts +45 -0
  71. package/table-builder/components/sort-menu/sort-menu.component-store.d.ts +24 -0
  72. package/table-builder/components/sort-menu/sort-menu.component.d.ts +19 -0
  73. package/table-builder/components/table-container/table-container.component.d.ts +104 -0
  74. package/table-builder/components/table-container/table-container.helpers/data-state.helpers.d.ts +7 -0
  75. package/table-builder/components/table-container/table-container.helpers/filter-state.helpers.d.ts +19 -0
  76. package/table-builder/components/table-container/table-container.helpers/groupBy.helpers.d.ts +19 -0
  77. package/table-builder/components/table-container/table-container.helpers/meta-data.helpers.d.ts +2 -0
  78. package/table-builder/components/table-container/table-container.helpers/sort-state.helpers.d.ts +12 -0
  79. package/table-builder/components/table-container/tableProps.d.ts +10 -0
  80. package/table-builder/components/table-container/virtual-scroll-container.d.ts +40 -0
  81. package/table-builder/components/table-container-filter/filter-list/filter-list.component.d.ts +15 -0
  82. package/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.d.ts +12 -0
  83. package/table-builder/components/table-container-filter/table-wrapper-filter-store.d.ts +14 -0
  84. package/table-builder/components/table-header-menu/table-header-menu.component.d.ts +15 -0
  85. package/table-builder/directives/custom-cell-directive.d.ts +34 -0
  86. package/{src/table-builder/directives/index.ts → table-builder/directives/index.d.ts} +5 -6
  87. package/table-builder/directives/multi-sort.directive.d.ts +10 -0
  88. package/table-builder/directives/resize-column.directive.d.ts +43 -0
  89. package/table-builder/directives/table-wrapper.directive.d.ts +8 -0
  90. package/table-builder/directives/tb-filter.directive.d.ts +116 -0
  91. package/table-builder/enums/filterTypes.d.ts +36 -0
  92. package/table-builder/functions/boolean-filter-function.d.ts +3 -0
  93. package/table-builder/functions/date-filter-function.d.ts +4 -0
  94. package/table-builder/functions/download-data.d.ts +1 -0
  95. package/table-builder/functions/null-filter-function.d.ts +2 -0
  96. package/table-builder/functions/number-filter-function.d.ts +4 -0
  97. package/table-builder/functions/sort-data-function.d.ts +6 -0
  98. package/table-builder/functions/string-filter-function.d.ts +5 -0
  99. package/{src/table-builder/interfaces/ColumnInfo.ts → table-builder/interfaces/ColumnInfo.d.ts} +6 -7
  100. package/{src/table-builder/interfaces/dictionary.ts → table-builder/interfaces/dictionary.d.ts} +3 -3
  101. package/table-builder/interfaces/report-def.d.ts +229 -0
  102. package/table-builder/ngrx/tableBuilderStateStore.d.ts +69 -0
  103. package/table-builder/pipes/column-total.pipe.d.ts +8 -0
  104. package/table-builder/pipes/format-filter-type.pipe.d.ts +8 -0
  105. package/table-builder/pipes/format-filter-value.pipe.d.ts +11 -0
  106. package/table-builder/pipes/key-display.d.ts +9 -0
  107. package/table-builder/services/export-to-csv.service.d.ts +22 -0
  108. package/table-builder/services/link-creator.service.d.ts +16 -0
  109. package/table-builder/services/table-template-service.d.ts +14 -0
  110. package/table-builder/services/transform-creator.d.ts +9 -0
  111. package/table-builder/table-builder.module.d.ts +14 -0
  112. package/utilities/array-helpers.d.ts +1 -0
  113. package/utilities/directives/auto-focus.directive.d.ts +9 -0
  114. package/utilities/directives/clickEmitterDirective.d.ts +7 -0
  115. package/utilities/directives/clickSubject.d.ts +9 -0
  116. package/utilities/directives/conditional-classes.directive.d.ts +12 -0
  117. package/utilities/directives/dialog-service.d.ts +10 -0
  118. package/utilities/directives/dialog.d.ts +45 -0
  119. package/utilities/directives/mat-toggle-group-directive.d.ts +21 -0
  120. package/utilities/directives/prevent-enter.directive.d.ts +6 -0
  121. package/utilities/directives/stop-propagation.directive.d.ts +7 -0
  122. package/utilities/directives/styler.d.ts +16 -0
  123. package/utilities/directives/trim-whitespace.directive.d.ts +7 -0
  124. package/{src/utilities/index.ts → utilities/index.d.ts} +15 -22
  125. package/utilities/module.d.ts +19 -0
  126. package/utilities/pipes/function.pipe.d.ts +11 -0
  127. package/utilities/pipes/phone.pipe.d.ts +8 -0
  128. package/utilities/pipes/space-case.pipes.d.ts +17 -0
  129. package/karma.conf.js +0 -44
  130. package/ng-package.json +0 -7
  131. package/src/action-state/action-state-spinner/action-state-spinner.component.css +0 -16
  132. package/src/action-state/action-state-spinner/action-state-spinner.component.html +0 -7
  133. package/src/action-state/action-state-spinner/action-state-spinner.component.spec.ts +0 -25
  134. package/src/action-state/action-state-spinner/action-state-spinner.component.ts +0 -25
  135. package/src/action-state/action-state-ui/action-state-ui.module.ts +0 -13
  136. package/src/action-state/ngrx-ext/ngrx-ext.module.ts +0 -14
  137. package/src/action-state/ngrx.ts +0 -69
  138. package/src/http-request-state/RequestStateFactory.ts +0 -56
  139. package/src/http-request-state/RequestStateStore.ts +0 -284
  140. package/src/http-request-state/directives/HttpStateDirectiveBase.ts +0 -29
  141. package/src/http-request-state/directives/http-error-state-directive.ts +0 -21
  142. package/src/http-request-state/directives/http-inProgress-state-directive.ts +0 -19
  143. package/src/http-request-state/directives/http-notStarted-state-directive.ts +0 -19
  144. package/src/http-request-state/directives/http-success-state-directive.ts +0 -29
  145. package/src/http-request-state/directives/request-state-directive.spec.ts +0 -73
  146. package/src/http-request-state/directives/request-state-directive.ts +0 -78
  147. package/src/http-request-state/helpers.ts +0 -30
  148. package/src/http-request-state/http-state-module.ts +0 -23
  149. package/src/http-request-state/models/view-context.ts +0 -18
  150. package/src/http-request-state/observable.spec.ts +0 -43
  151. package/src/http-request-state/request-state.ts +0 -66
  152. package/src/http-request-state/rxjs/getRequestorBody.ts +0 -10
  153. package/src/http-request-state/rxjs/getRequestorState.ts +0 -8
  154. package/src/http-request-state/rxjs/tapError.ts +0 -16
  155. package/src/http-request-state/rxjs/tapSuccess.ts +0 -16
  156. package/src/http-request-state/strategies.spec.ts +0 -42
  157. package/src/http-request-state/types.ts +0 -54
  158. package/src/ngrx/actionable-selector.ts +0 -160
  159. package/src/ngrx/index.ts +0 -1
  160. package/src/rxjs/defaultShareReplay.ts +0 -8
  161. package/src/rxjs/mapError.ts +0 -8
  162. package/src/rxjs/rxjs-operators.ts +0 -130
  163. package/src/rxjs/subjectifier.ts +0 -17
  164. package/src/rxjs/subscriber.directive.ts +0 -57
  165. package/src/specs/clickSubject.spec.ts +0 -95
  166. package/src/specs/dialog.spec.ts +0 -101
  167. package/src/specs/toggleGroupDirective.spec.ts +0 -229
  168. package/src/table-builder/classes/DefaultSettings.ts +0 -11
  169. package/src/table-builder/classes/MatTableObservableDataSource.ts +0 -23
  170. package/src/table-builder/classes/TableBuilderConfig.ts +0 -50
  171. package/src/table-builder/classes/TableBuilderDataSource.ts +0 -64
  172. package/src/table-builder/classes/TableState.ts +0 -125
  173. package/src/table-builder/classes/data-store.ts +0 -10
  174. package/src/table-builder/classes/filter-info.ts +0 -125
  175. package/src/table-builder/classes/table-builder-general-settings.ts +0 -205
  176. package/src/table-builder/classes/table-builder.ts +0 -105
  177. package/src/table-builder/classes/table-store.helpers.ts +0 -104
  178. package/src/table-builder/classes/table-store.ts +0 -440
  179. package/src/table-builder/components/array-column.component.ts +0 -34
  180. package/src/table-builder/components/column-builder/column-builder.component.html +0 -87
  181. package/src/table-builder/components/column-builder/column-builder.component.scss +0 -43
  182. package/src/table-builder/components/column-builder/column-builder.component.spec.ts +0 -49
  183. package/src/table-builder/components/column-builder/column-builder.component.ts +0 -129
  184. package/src/table-builder/components/column-builder/column-helpers.ts +0 -54
  185. package/src/table-builder/components/column-header-menu/column-header-menu.component.html +0 -110
  186. package/src/table-builder/components/column-header-menu/column-header-menu.component.scss +0 -97
  187. package/src/table-builder/components/column-header-menu/column-header-menu.component.ts +0 -94
  188. package/src/table-builder/components/date-filter/date-filter.component.html +0 -25
  189. package/src/table-builder/components/date-filter/date-filter.component.ts +0 -22
  190. package/src/table-builder/components/date-time-filter/date-time-filter.component.html +0 -11
  191. package/src/table-builder/components/date-time-filter/date-time-filter.component.ts +0 -20
  192. package/src/table-builder/components/filter/filter.component.html +0 -109
  193. package/src/table-builder/components/filter/filter.component.scss +0 -60
  194. package/src/table-builder/components/filter/filter.component.spec.ts +0 -86
  195. package/src/table-builder/components/filter/filter.component.ts +0 -64
  196. package/src/table-builder/components/filter/in-list/in-list-filter.component.ts +0 -102
  197. package/src/table-builder/components/gen-col-displayer/gen-col-displayer.component.html +0 -60
  198. package/src/table-builder/components/gen-col-displayer/gen-col-displayer.component.scss +0 -57
  199. package/src/table-builder/components/gen-col-displayer/gen-col-displayer.component.ts +0 -44
  200. package/src/table-builder/components/generic-table/generic-table.component.html +0 -97
  201. package/src/table-builder/components/generic-table/generic-table.component.scss +0 -38
  202. package/src/table-builder/components/generic-table/generic-table.component.ts +0 -403
  203. package/src/table-builder/components/generic-table/paginator.component.ts +0 -112
  204. package/src/table-builder/components/group-by-list/group-by-list.component.css +0 -17
  205. package/src/table-builder/components/group-by-list/group-by-list.component.html +0 -14
  206. package/src/table-builder/components/group-by-list/group-by-list.component.spec.ts +0 -23
  207. package/src/table-builder/components/group-by-list/group-by-list.component.ts +0 -25
  208. package/src/table-builder/components/in-filter/in-filter.component.css +0 -3
  209. package/src/table-builder/components/in-filter/in-filter.component.html +0 -23
  210. package/src/table-builder/components/in-filter/in-filter.component.ts +0 -65
  211. package/src/table-builder/components/initialization-component/initialization.component.html +0 -78
  212. package/src/table-builder/components/initialization-component/initialization.component.ts +0 -27
  213. package/src/table-builder/components/link-column.component.ts +0 -42
  214. package/src/table-builder/components/number-filter/number-filter.component.css +0 -10
  215. package/src/table-builder/components/number-filter/number-filter.component.html +0 -25
  216. package/src/table-builder/components/number-filter/number-filter.component.spec.ts +0 -30
  217. package/src/table-builder/components/number-filter/number-filter.component.ts +0 -25
  218. package/src/table-builder/components/profiles-menu/profiles-menu.component.html +0 -77
  219. package/src/table-builder/components/profiles-menu/profiles-menu.component.scss +0 -126
  220. package/src/table-builder/components/profiles-menu/profiles-menu.component.spec.ts +0 -23
  221. package/src/table-builder/components/profiles-menu/profiles-menu.component.ts +0 -63
  222. package/src/table-builder/components/reset-menu/reset-menu.component.css +0 -3
  223. package/src/table-builder/components/reset-menu/reset-menu.component.html +0 -10
  224. package/src/table-builder/components/reset-menu/reset-menu.component.ts +0 -87
  225. package/src/table-builder/components/scroll-strategy.ts +0 -139
  226. package/src/table-builder/components/sort-menu/sort-menu.component-store.ts +0 -57
  227. package/src/table-builder/components/sort-menu/sort-menu.component.html +0 -115
  228. package/src/table-builder/components/sort-menu/sort-menu.component.scss +0 -119
  229. package/src/table-builder/components/sort-menu/sort-menu.component.ts +0 -88
  230. package/src/table-builder/components/table-container/table-container.component.html +0 -81
  231. package/src/table-builder/components/table-container/table-container.component.ts +0 -403
  232. package/src/table-builder/components/table-container/table-container.helpers/data-state.helpers.ts +0 -113
  233. package/src/table-builder/components/table-container/table-container.helpers/filter-state.helpers.ts +0 -125
  234. package/src/table-builder/components/table-container/table-container.helpers/groupBy.helpers.ts +0 -122
  235. package/src/table-builder/components/table-container/table-container.helpers/meta-data.helpers.ts +0 -16
  236. package/src/table-builder/components/table-container/table-container.helpers/sort-state.helpers.ts +0 -47
  237. package/src/table-builder/components/table-container/table-container.scss +0 -47
  238. package/src/table-builder/components/table-container/tableProps.ts +0 -18
  239. package/src/table-builder/components/table-container/virtual-scroll-container.ts +0 -216
  240. package/src/table-builder/components/table-container-filter/filter-list/filter-list.component.html +0 -35
  241. package/src/table-builder/components/table-container-filter/filter-list/filter-list.component.ts +0 -44
  242. package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.css +0 -40
  243. package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.html +0 -11
  244. package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.spec.ts +0 -85
  245. package/src/table-builder/components/table-container-filter/gen-filter-displayer/gen-filter-displayer.component.ts +0 -36
  246. package/src/table-builder/components/table-container-filter/table-wrapper-filter-store.ts +0 -23
  247. package/src/table-builder/components/table-header-menu/table-header-menu.component.css +0 -21
  248. package/src/table-builder/components/table-header-menu/table-header-menu.component.html +0 -50
  249. package/src/table-builder/components/table-header-menu/table-header-menu.component.ts +0 -35
  250. package/src/table-builder/directives/custom-cell-directive.ts +0 -57
  251. package/src/table-builder/directives/multi-sort.directive.spec.ts +0 -124
  252. package/src/table-builder/directives/multi-sort.directive.ts +0 -50
  253. package/src/table-builder/directives/resize-column.directive.ts +0 -107
  254. package/src/table-builder/directives/table-wrapper.directive.ts +0 -13
  255. package/src/table-builder/directives/tb-filter.directive.ts +0 -376
  256. package/src/table-builder/enums/filterTypes.ts +0 -40
  257. package/src/table-builder/functions/boolean-filter-function.ts +0 -12
  258. package/src/table-builder/functions/date-filter-function.ts +0 -78
  259. package/src/table-builder/functions/download-data.ts +0 -11
  260. package/src/table-builder/functions/null-filter-function.ts +0 -9
  261. package/src/table-builder/functions/number-filter-function.ts +0 -41
  262. package/src/table-builder/functions/sort-data-function.ts +0 -80
  263. package/src/table-builder/functions/string-filter-function.ts +0 -53
  264. package/src/table-builder/interfaces/report-def.ts +0 -254
  265. package/src/table-builder/ngrx/tableBuilderStateStore.ts +0 -197
  266. package/src/table-builder/pipes/column-total.pipe.ts +0 -16
  267. package/src/table-builder/pipes/format-filter-type.pipe.ts +0 -12
  268. package/src/table-builder/pipes/format-filter-value.pipe.ts +0 -67
  269. package/src/table-builder/pipes/key-display.ts +0 -13
  270. package/src/table-builder/services/export-to-csv.service.ts +0 -113
  271. package/src/table-builder/services/link-creator.service.ts +0 -98
  272. package/src/table-builder/services/table-template-service.ts +0 -47
  273. package/src/table-builder/services/transform-creator.ts +0 -96
  274. package/src/table-builder/specs/table-custom-filters.spec.ts +0 -262
  275. package/src/table-builder/styles/collapser.styles.scss +0 -16
  276. package/src/table-builder/table-builder.module.ts +0 -38
  277. package/src/test.ts +0 -17
  278. package/src/utilities/array-helpers.ts +0 -13
  279. package/src/utilities/directives/auto-focus.directive.ts +0 -20
  280. package/src/utilities/directives/clickEmitterDirective.ts +0 -15
  281. package/src/utilities/directives/clickSubject.ts +0 -19
  282. package/src/utilities/directives/conditional-classes.directive.ts +0 -36
  283. package/src/utilities/directives/dialog-service.ts +0 -19
  284. package/src/utilities/directives/dialog.ts +0 -144
  285. package/src/utilities/directives/mat-toggle-group-directive.ts +0 -60
  286. package/src/utilities/directives/prevent-enter.directive.ts +0 -12
  287. package/src/utilities/directives/stop-propagation.directive.ts +0 -19
  288. package/src/utilities/directives/styler.ts +0 -44
  289. package/src/utilities/directives/trim-whitespace.directive.ts +0 -20
  290. package/src/utilities/module.ts +0 -53
  291. package/src/utilities/pipes/function.pipe.ts +0 -21
  292. package/src/utilities/pipes/phone.pipe.ts +0 -20
  293. package/src/utilities/pipes/space-case.pipes.spec.ts +0 -47
  294. package/src/utilities/pipes/space-case.pipes.ts +0 -26
  295. package/tsconfig.lib.json +0 -20
  296. package/tsconfig.lib.prod.json +0 -10
  297. package/tsconfig.spec.json +0 -17
@@ -1,21 +0,0 @@
1
- import { Directive, OnInit } from '@angular/core';
2
- import { isErrorState } from '../helpers';
3
- import { RequestState } from '../types';
4
- import { HttpStateDirectiveBase } from './HttpStateDirectiveBase';
5
-
6
- @Directive({ selector: '[httpErrorState]', })
7
- export class HttpErrorStateDirective<V, R = null> extends HttpStateDirectiveBase<V, R> implements OnInit {
8
-
9
-
10
- render = (state: RequestState<any>) => {
11
- if(isErrorState(state)) {
12
- this.viewContainer.createEmbeddedView(this.templateRef, { $implicit: state.error });
13
- return true;
14
- }
15
- return false;
16
- };
17
-
18
- ngOnInit() {
19
- super.ngOnInit();
20
- }
21
- }
@@ -1,19 +0,0 @@
1
- import { Directive, OnInit } from '@angular/core';
2
- import { HttpStateDirectiveBase } from './HttpStateDirectiveBase';
3
- import { RequestState, RequestStatus } from '../types'
4
-
5
-
6
- @Directive({ selector: '[httpInProgressState]', })
7
- export class HttpInProgressStateDirective<V, R = null> extends HttpStateDirectiveBase<V, R> implements OnInit {
8
- render = (state: RequestState<any>) => {
9
- if(state.status === RequestStatus.inProgress){
10
- this.viewContainer.createEmbeddedView(this.templateRef );
11
- return true;
12
- }
13
- return false;
14
- };
15
-
16
- ngOnInit() {
17
- super.ngOnInit();
18
- }
19
- }
@@ -1,19 +0,0 @@
1
- import { Directive, OnInit } from '@angular/core';
2
- import { RequestState, RequestStatus } from '../types';
3
- import { HttpStateDirectiveBase } from './HttpStateDirectiveBase';
4
-
5
-
6
- @Directive({ selector: '[httpNotStartedState]', })
7
- export class HttpNotStartedStateDirective<V, R = null> extends HttpStateDirectiveBase<V, R> implements OnInit {
8
- render = (state: RequestState<any>) => {
9
- if(state.status === RequestStatus.notStarted){
10
- this.viewContainer.createEmbeddedView(this.templateRef );
11
- return true;
12
- }
13
- return false;
14
- };
15
-
16
- ngOnInit() {
17
- super.ngOnInit();
18
- }
19
- }
@@ -1,29 +0,0 @@
1
- import { Directive, Input, OnInit } from '@angular/core';
2
- import { isSuccessState } from '../helpers';
3
- import { HttpStateDirectiveBase } from './HttpStateDirectiveBase';
4
- import { RequestState } from '../types';
5
- import { RequestStateStore } from '../RequestStateStore';
6
- import { Observable } from 'rxjs';
7
-
8
- export interface HttpSuccessStateViewContext<T> {
9
- $implicit: T;
10
- }
11
- @Directive({ selector: '[httpSuccessState]', })
12
- export class HttpSuccessStateDirective<V, R = null> extends HttpStateDirectiveBase<V, R> implements OnInit {
13
- @Input() httpSuccessStateTypeSafety?: RequestStateStore<any, V, R> | Observable<RequestState<V>>;
14
- render = (state: RequestState<R extends null ? V : R>) => {
15
- if(isSuccessState(state)) {
16
- this.viewContainer.createEmbeddedView(this.templateRef, { $implicit: state.body });
17
- return true;
18
- }
19
- return false;
20
- };
21
-
22
- ngOnInit() {
23
- super.ngOnInit();
24
- }
25
-
26
- static ngTemplateContextGuard<V, R>(dir: HttpSuccessStateDirective<V, R>, ctx: any): ctx is HttpSuccessStateViewContext<R extends null ? V : R> {
27
- return true;
28
- }
29
- }
@@ -1,73 +0,0 @@
1
- import { ComponentFixture, TestBed } from '@angular/core/testing';
2
- import { Component, inject } from '@angular/core';
3
- import { HttpRequestModule } from '../http-state-module';
4
- import { RequestStateStore } from '../RequestStateStore';
5
- import { Subject } from 'rxjs';
6
- import { RequestStateOptions } from '../types';
7
-
8
-
9
- @Component({
10
- template: `
11
- <div *httpRequestState='requestState;let state;'>
12
- <ng-container *httpNotStartedState>not started</ng-container>
13
- <ng-container *httpInProgressState>in progress</ng-container>
14
- <ng-container *httpSuccessState='let body' >success {{body}}</ng-container>
15
- <ng-container *httpErrorState='let error' >error {{error}}</ng-container>
16
- </div>
17
- `,
18
- }) export class TestHttpRequestStateDirectiveComponent {
19
- requestState = inject<RequestStateStore<any, any>>(RequestStateStore);
20
-
21
- }
22
-
23
- export class MockHttpRequestState<T> extends RequestStateStore<[], T> {
24
- subject = new Subject<T>();
25
- constructor(options?: RequestStateOptions) {
26
- super(() => {
27
- return this.subject;
28
- }, options );
29
- }
30
- }
31
-
32
- let requestState: MockHttpRequestState<string>;
33
- let fixture: ComponentFixture<TestHttpRequestStateDirectiveComponent>;
34
-
35
- describe('Request State Directive', () => {
36
-
37
- beforeEach(() => {
38
- requestState = new MockHttpRequestState<string>();
39
- fixture = TestBed.configureTestingModule({
40
- declarations: [TestHttpRequestStateDirectiveComponent],
41
- providers: [{ provide: RequestStateStore, useValue: requestState }],
42
- imports: [HttpRequestModule]
43
- }).createComponent(TestHttpRequestStateDirectiveComponent);
44
- });
45
-
46
- it('should begin with the state of not started', () => {
47
- verifyText('not started');
48
- });
49
-
50
- it('should be in progress while in progress', () => {
51
- requestState.request();
52
- verifyText('in progress');
53
- });
54
-
55
- it('should be success when success', () => {
56
- requestState.request();
57
- requestState.subject.next('yay')
58
- verifyText('success yay');
59
- });
60
-
61
- it('should be error when error', () => {
62
- requestState.request();
63
- requestState.subject.error('ouch');
64
- verifyText('error ouch');
65
- });
66
-
67
- function verifyText(text:string) {
68
- fixture.detectChanges();
69
- const node: HTMLElement = fixture.nativeElement;
70
- expect(node.innerText).toBe(text);
71
- }
72
-
73
- });
@@ -1,78 +0,0 @@
1
- import { Directive, Input, TemplateRef, ViewContainerRef, OnDestroy } from '@angular/core';
2
- import { defaultShareReplay } from '../../rxjs/defaultShareReplay';
3
- import { isObservable, Observable, Subject, Unsubscribable } from 'rxjs';
4
- import { map, switchAll } from 'rxjs/operators';
5
- import { RequestStateStore } from '../RequestStateStore';
6
- import { RequestState, RequestStatus } from '../types';
7
-
8
- export interface HttpRequestStateViewContext<T> {
9
- $implicit?: HttpRequestStateAny<T>;
10
- state?: HttpRequestStateAny<T>;
11
- status: {
12
- inProgress: boolean;
13
- notStarted: boolean;
14
- success: boolean;
15
- error: boolean;
16
- };
17
- }
18
-
19
- @Directive({ selector: '[httpRequestState]', })
20
- export class HttpRequestStateDirective<TParam extends any[], V, R, T = R extends null ? V : R> implements OnDestroy {
21
- private viewContainer: ViewContainerRef;
22
-
23
- readonly ViewContext: HttpRequestStateViewContext<T> = {
24
- $implicit: undefined,
25
- state: undefined,
26
- status: {
27
- inProgress: false,
28
- notStarted: true,
29
- success: false,
30
- error: false,
31
- }
32
- };
33
-
34
-
35
- subject = new Subject<Observable<RequestState<T>>>();
36
- state = this.subject.pipe(switchAll(), defaultShareReplay());
37
- subscription: Unsubscribable;
38
- hooks: ((state: RequestState<T>) => void)[] = [];
39
-
40
- @Input('httpRequestState') set stateStore(store: RequestStateStore<TParam, V, R, T> | Observable<RequestState<T>>) {
41
- if(isObservable(store)) {
42
- this.subject.next(store);
43
- } else {
44
- this.subject.next(store.state$.pipe(map(state => state.response)));
45
- }
46
-
47
- }
48
- constructor(templateRef: TemplateRef<any>, viewContainer: ViewContainerRef) {
49
- this.viewContainer = viewContainer;
50
- this.viewContainer.createEmbeddedView(templateRef, this.ViewContext);
51
- this.subscription = this.state.subscribe(state => {
52
- this.ViewContext.$implicit = state;
53
- this.ViewContext.state = state;
54
- this.ViewContext.status.inProgress = state.status === RequestStatus.inProgress;
55
- this.ViewContext.status.notStarted = state.status === RequestStatus.notStarted;
56
- this.ViewContext.status.success = state.status === RequestStatus.success;
57
- this.ViewContext.status.error = state.status === RequestStatus.fail;
58
- this.hooks.forEach(hook => hook(state));
59
- });
60
- }
61
-
62
-
63
- ngOnDestroy() {
64
- this.viewContainer.clear();
65
- this.subscription.unsubscribe();
66
- }
67
-
68
- static ngTemplateContextGuard<V, R>(dir: HttpRequestStateDirective<any, V, R>, ctx: any): ctx is HttpRequestStateViewContext<R extends null ? V : R> {
69
- return true;
70
- }
71
-
72
- }
73
-
74
- export type HttpRequestStateAny<T> = {
75
- status: RequestStatus;
76
- body?: T;
77
- error?: any;
78
- }
@@ -1,30 +0,0 @@
1
- import { RequestState, RequestStateError, RequestStateInProgress, RequestStateNotStarted, RequestStateSuccess, RequestStatus } from "./types";
2
-
3
- export function isErrorState<T>(state: RequestState<T>): state is RequestStateError {
4
- return state.status === RequestStatus.fail;
5
- }
6
-
7
- export function isSuccessState<T>(state: RequestState<T>): state is RequestStateSuccess<T> {
8
- return state.status === RequestStatus.success;
9
- }
10
-
11
- export function isSuccessOrErrorState<T>(state: RequestState<T>): state is (RequestStateSuccess<T> | RequestStateError) {
12
- return state.status === RequestStatus.success || state.status === RequestStatus.fail;
13
- }
14
-
15
- export function createSuccess<T>(body: T): RequestStateSuccess<T> {
16
- return { status: RequestStatus.success, body };
17
- }
18
-
19
- export function createFailure(error: any): RequestStateError {
20
- return { status: RequestStatus.fail, error };
21
- }
22
-
23
- export const notStarted: RequestStateNotStarted = { status: RequestStatus.notStarted };
24
-
25
-
26
- export const inProgress: RequestStateInProgress = { status: RequestStatus.inProgress };
27
-
28
- export function statusIsSuccessOrInProgress( status: RequestStatus) {
29
- return [RequestStatus.success, RequestStatus.inProgress].includes(status);
30
- }
@@ -1,23 +0,0 @@
1
- import { NgModule } from '@angular/core';
2
- import { HttpSuccessStateDirective } from './directives/http-success-state-directive';
3
- import { HttpRequestStateDirective } from './directives/request-state-directive';
4
- import { HttpErrorStateDirective } from './directives/http-error-state-directive';
5
- import { HttpInProgressStateDirective } from './directives/http-inProgress-state-directive';
6
- import { HttpNotStartedStateDirective } from './directives/http-notStarted-state-directive';
7
-
8
- @NgModule({
9
- imports: [
10
- HttpSuccessStateDirective,
11
- HttpRequestStateDirective,
12
- HttpErrorStateDirective,
13
- HttpInProgressStateDirective,
14
- HttpNotStartedStateDirective,
15
- ],
16
- exports: [
17
- HttpSuccessStateDirective,
18
- HttpRequestStateDirective,
19
- HttpErrorStateDirective,
20
- HttpInProgressStateDirective,
21
- HttpNotStartedStateDirective,
22
- ]
23
- }) export class HttpRequestModule { }
@@ -1,18 +0,0 @@
1
- import { RequestStatus } from "../types";
2
-
3
- export interface HttpRequestStateViewContext<T> {
4
- $implicit?: HttpRequestStateAny<T>;
5
- state?: HttpRequestStateAny<T>;
6
- status: {
7
- inProgress: boolean;
8
- notStarted: boolean;
9
- success: boolean;
10
- error: boolean;
11
- };
12
- }
13
-
14
- export type HttpRequestStateAny<T> = {
15
- status: RequestStatus;
16
- body?: T;
17
- error?: any;
18
- }
@@ -1,43 +0,0 @@
1
- import { MockHttpRequestState } from "./directives/request-state-directive.spec";
2
- import { createSuccess, inProgress, notStarted, createFailure } from "./helpers";
3
-
4
- describe('HttpRequestStateStore', () => {
5
-
6
- it('should begin with the state of not started', (done) => {
7
- const requestState = new MockHttpRequestState<string>();
8
- requestState.state$.subscribe( state => {
9
- expect(state).toEqual({ requestParams: null as any, response: notStarted });
10
- done();
11
- });
12
- });
13
-
14
- it('should be in progress when request is made', (done) => {
15
- const requestState = new MockHttpRequestState<string>();
16
- requestState.request();
17
- requestState.state$.subscribe( state => {
18
- expect(state).toEqual({ requestParams: [], response: inProgress });
19
- done();
20
- });
21
- });
22
-
23
- it('should be in success when request completes successfully', (done) => {
24
- const requestState = new MockHttpRequestState<string>();
25
- requestState.request();
26
- requestState.subject.next('hi');
27
- requestState.state$.subscribe( state => {
28
- expect(state).toEqual({ requestParams: [], response: createSuccess('hi') });
29
- done();
30
- });
31
- });
32
-
33
- it('should be in error when request errors', (done) => {
34
- const requestState = new MockHttpRequestState<string>();
35
- requestState.request();
36
- requestState.subject.error('error');
37
- requestState.state$.subscribe( state => {
38
- expect(state).toEqual({ requestParams: [], response: createFailure('error') });
39
- done();
40
- });
41
- });
42
-
43
- });
@@ -1,66 +0,0 @@
1
- import { map, startWith, switchMap } from 'rxjs/operators';
2
- import { getRequestorBody } from './rxjs/getRequestorBody';
3
- import { getRequestorStatus } from './rxjs/getRequestorState';
4
- import { mapError } from '../rxjs/mapError';
5
- import { defaultShareReplay } from '../rxjs/defaultShareReplay';
6
- import { Observable, of, ReplaySubject } from 'rxjs';
7
- import { RequestFactory, RequestState, RequestStatus } from './types';
8
- import { createFailure, createSuccess, inProgress, notStarted } from './helpers';
9
-
10
- export type HttpRequestState$ <T> = Observable<RequestState<T>>;
11
-
12
- export interface HttpRequestor <Res, Req> {
13
- httpState$: Observable<RequestState<Res>>;
14
- status$: Observable<RequestStatus>;
15
- body$: Observable<Res>;
16
- request: Req;
17
- }
18
-
19
- export function httpRequest<T = any>(req: Observable<T>): HttpRequestState$<T> {
20
- return req.pipe(
21
- map(createSuccess),
22
- mapError(createFailure),
23
- startWith(inProgress),
24
- defaultShareReplay()
25
- );
26
- }
27
-
28
- export function httpRequestor<TParam extends any[], T>(req: RequestFactory<TParam, T> ): HttpRequestor<T, (...params: [...TParam]) => Observable<RequestState<T>>> {
29
- const request$ = new ReplaySubject<[...TParam]>(1);
30
- const httpState$ : HttpRequestState$<T> = request$.pipe(
31
- switchMap( (params) => httpRequest<T>(req(...params)) ),
32
- startWith(notStarted),
33
- defaultShareReplay(),
34
- );
35
- const request = (...params: [...TParam]) => {
36
- request$.next(params);
37
- return httpState$;
38
- };
39
- return ({
40
- request,
41
- httpState$,
42
- body$: httpState$.pipe(getRequestorBody),
43
- status$: httpState$.pipe(getRequestorStatus)
44
- });
45
- }
46
-
47
- export function chainRequest<TParam extends any[], T, TT>(
48
- httpState$: Observable<RequestState<T>>,
49
- request:RequestFactory<TParam, TT>,
50
- requestParams: ((responseFromPrevious: T) => [...TParam]) | (() => [...TParam])
51
- ): Observable<RequestState<TT>> {
52
- return httpState$.pipe(
53
- switchMap( res => {
54
- if(res.status === RequestStatus.success) {
55
- const secondReq = httpRequestor<[...TParam], TT>(request);
56
- const param = requestParams(res.body);
57
- secondReq.request(...param );
58
- return secondReq.httpState$;
59
- } else {
60
- return of(res);
61
- }
62
- }),
63
- );
64
- }
65
-
66
-
@@ -1,10 +0,0 @@
1
- import { isSuccessState } from '../helpers';
2
- import { RequestState } from '../types';
3
- import { Observable } from 'rxjs';
4
- import { filter, map } from 'rxjs/operators';
5
-
6
- export const getRequestorBody = <T>(source: Observable<RequestState<T>>) =>
7
- source.pipe(
8
- filter(isSuccessState),
9
- map( res => res.body)
10
- );
@@ -1,8 +0,0 @@
1
- import { RequestState } from '../types';
2
- import { Observable } from 'rxjs';
3
- import { map } from 'rxjs/operators';
4
-
5
- export const getRequestorStatus = <T>(source: Observable<RequestState<T>>) =>
6
- source.pipe(
7
- map( res => res.status)
8
- );
@@ -1,16 +0,0 @@
1
- import { Observable } from 'rxjs';
2
- import { tap } from 'rxjs/operators';
3
- import { RequestState } from '../types';
4
- import { isErrorState } from '../helpers';
5
-
6
- export function tapError(onError: (error: any) => void) {
7
- return function (src: Observable<RequestState>): Observable<RequestState> {
8
- return src.pipe(
9
- tap( result => {
10
- if(isErrorState(result)) {
11
- onError(result.error);
12
- }
13
- })
14
- );
15
- };
16
- }
@@ -1,16 +0,0 @@
1
- import { Observable } from 'rxjs';
2
- import { tap } from 'rxjs/operators';
3
- import { RequestState } from '../types';
4
- import { isSuccessState } from '../helpers';
5
-
6
- export function tapSuccess<T>(onSuccess: (body: T) => void) {
7
- return function (src: Observable<RequestState<T>>): Observable<RequestState<T>> {
8
- return src.pipe(
9
- tap( result => {
10
- if(isSuccessState(result)) {
11
- onSuccess(result.body);
12
- }
13
- })
14
- );
15
- };
16
- }
@@ -1,42 +0,0 @@
1
- import { toArray } from "rxjs/operators";
2
- import { MockHttpRequestState } from "./directives/request-state-directive.spec";
3
- import { RequestStrategy } from "./types";
4
-
5
- describe('HttpRequestStateStore', () => {
6
-
7
- it('should throw when strategy is use once and it was reused', () => {
8
- const requestState = new MockHttpRequestState<string>({ strategy: RequestStrategy.singleUse });
9
- requestState.request();
10
- expect( () => {
11
- requestState.request();
12
- } ).toThrow();
13
- });
14
-
15
-
16
- it('should emit both when strategy is concurrent', (done) => {
17
- const requestState = new MockHttpRequestState<string>({ strategy: RequestStrategy.concurrent });
18
- requestState.request();
19
- requestState.request();
20
- requestState.selectResponse$.pipe( toArray()
21
- ).subscribe( d => {
22
- expect(d.length).toBe(2);
23
- done();
24
- });
25
- requestState.subject.next('hi');
26
- requestState.ngOnDestroy();
27
- });
28
-
29
- it('should emit only one when strategy is cancel previous', (done) => {
30
- const requestState = new MockHttpRequestState<string>({ strategy: RequestStrategy.cancelPrevious });
31
- requestState.request();
32
- requestState.request();
33
- requestState.selectResponse$.pipe( toArray()
34
- ).subscribe( d => {
35
- expect(d.length).toBe(1);
36
- done();
37
- });
38
- requestState.subject.next('hi');
39
- requestState.ngOnDestroy();
40
-
41
- });
42
- });
@@ -1,54 +0,0 @@
1
- import { Injector } from '@angular/core';
2
- import { Observable } from 'rxjs';
3
- export enum RequestStatus {
4
- notStarted,
5
- inProgress,
6
- success,
7
- fail,
8
- cancelled,
9
- }
10
-
11
- export type RequestStateCancelled = {
12
- status: RequestStatus.cancelled
13
- }
14
-
15
- export type RequestStateNotStarted = {
16
- status: RequestStatus.notStarted
17
- }
18
-
19
- export type RequestStateInProgress = {
20
- status: RequestStatus.inProgress
21
- }
22
-
23
- export type RequestStateSuccess<T> = {
24
- status: RequestStatus.success;
25
- body: T;
26
- }
27
-
28
- export type RequestStateError = {
29
- status: RequestStatus.fail;
30
- error: any;
31
- }
32
-
33
-
34
- export type RequestState<T = any> =
35
- RequestStateCancelled |
36
- RequestStateNotStarted |
37
- RequestStateInProgress |
38
- RequestStateSuccess<T> |
39
- RequestStateError ;
40
-
41
- export enum RequestStrategy {
42
- concurrent = 1,
43
- singleUse = 2,
44
- cancelPrevious = 3,
45
- sequential = 4,
46
- }
47
- export interface RequestStateOptions<TParam extends any[] = any> {
48
- strategy?: RequestStrategy;
49
- autoRequest?: TParam extends never[] ? true : never;
50
- }
51
-
52
- export interface RequestCreatorOptions<TParam extends any[] = any> extends RequestStateOptions<TParam> { injector?: Injector }
53
-
54
- export type RequestFactory<TParam extends any[], T> = (...params: [...TParam]) => Observable<T>