@bravobit/bb-foundation 0.16.5 → 0.20.0

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 (426) hide show
  1. package/README.md +47 -47
  2. package/auth/bravobit-bb-foundation-auth.d.ts +5 -5
  3. package/auth/lib/auth.interceptor.d.ts +21 -21
  4. package/auth/lib/auth.module.d.ts +15 -15
  5. package/auth/lib/auth.service.d.ts +59 -59
  6. package/auth/lib/auth.session.d.ts +34 -34
  7. package/auth/lib/directives/authenticated.directive.d.ts +14 -14
  8. package/auth/lib/directives/permission.directive.d.ts +24 -24
  9. package/auth/lib/directives/role.directive.d.ts +16 -16
  10. package/auth/lib/guards/anonymous.guard.d.ts +11 -11
  11. package/auth/lib/guards/authenticated.guard.d.ts +11 -11
  12. package/auth/lib/helpers/jwt.helper.d.ts +8 -8
  13. package/auth/lib/helpers/mapper.helper.d.ts +23 -23
  14. package/auth/lib/interfaces/config.interface.d.ts +12 -12
  15. package/auth/lib/interfaces/mapper.interface.d.ts +19 -19
  16. package/auth/lib/interfaces/provider.interface.d.ts +16 -16
  17. package/auth/lib/interfaces/token.interface.d.ts +11 -11
  18. package/auth/lib/permissions.service.d.ts +14 -14
  19. package/auth/lib/providers/email.provider.d.ts +15 -15
  20. package/auth/lib/providers/verify.provider.d.ts +13 -13
  21. package/auth/lib/tokens/use-authorization.token.d.ts +2 -2
  22. package/auth/public_api.d.ts +18 -18
  23. package/bravobit-bb-foundation.d.ts +5 -5
  24. package/collections/bravobit-bb-foundation-collections.d.ts +5 -5
  25. package/collections/lib/collection.d.ts +43 -43
  26. package/collections/lib/collections.module.d.ts +10 -10
  27. package/collections/lib/components/collections-pager/collections-pager.component.d.ts +34 -34
  28. package/collections/lib/components/collections-viewer/collections-viewer.component.d.ts +12 -12
  29. package/collections/lib/components/collections.directive.d.ts +17 -17
  30. package/collections/lib/interfaces/collection.interface.d.ts +26 -26
  31. package/collections/lib/providers/api-collection.provider.d.ts +17 -15
  32. package/collections/lib/providers/collection.provider.d.ts +6 -6
  33. package/collections/lib/providers/local-collection.provider.d.ts +8 -8
  34. package/collections/public_api.d.ts +9 -9
  35. package/controls/bravobit-bb-foundation-controls.d.ts +5 -5
  36. package/controls/lib/checkbox/checkbox/checkbox.component.d.ts +47 -47
  37. package/controls/lib/checkbox/checkbox-group/checkbox-group.component.d.ts +18 -18
  38. package/controls/lib/checkbox/checkbox.module.d.ts +9 -9
  39. package/controls/lib/controls.module.d.ts +7 -7
  40. package/controls/public_api.d.ts +4 -4
  41. package/dashboard/bravobit-bb-foundation-dashboard.d.ts +5 -5
  42. package/dashboard/lib/dashboard/dashboard.component.d.ts +19 -19
  43. package/dashboard/lib/dashboard-header/dashboard-header.component.d.ts +11 -11
  44. package/dashboard/lib/dashboard-menu/dashboard-menu.component.d.ts +9 -9
  45. package/dashboard/lib/dashboard-menu-item/dashboard-menu-item.component.d.ts +11 -11
  46. package/dashboard/lib/dashboard-sidebar/dashboard-sidebar.component.d.ts +21 -21
  47. package/dashboard/lib/dashboard-sidebar-group/dashboard-sidebar-group.component.d.ts +27 -27
  48. package/dashboard/lib/dashboard-sidebar-item/dashboard-sidebar-item.component.d.ts +16 -16
  49. package/dashboard/lib/dashboard.module.d.ts +16 -16
  50. package/dashboard/public_api.d.ts +8 -8
  51. package/dialog/bravobit-bb-foundation-dialog.d.ts +5 -5
  52. package/dialog/lib/dialog-actions/dialog-actions.component.d.ts +5 -5
  53. package/dialog/lib/dialog-confirm/dialog-confirm.component.d.ts +16 -16
  54. package/dialog/lib/dialog-container/dialog-container.component.d.ts +24 -24
  55. package/dialog/lib/dialog-header/dialog-header.component.d.ts +9 -9
  56. package/dialog/lib/dialog-link/dialog-link.component.d.ts +5 -5
  57. package/dialog/lib/dialog-modal/dialog-modal.component.d.ts +12 -12
  58. package/dialog/lib/dialog-overlay/dialog-overlay.component.d.ts +22 -22
  59. package/dialog/lib/dialog.injector.d.ts +8 -8
  60. package/dialog/lib/dialog.insertion.d.ts +8 -8
  61. package/dialog/lib/dialog.interfaces.d.ts +3 -3
  62. package/dialog/lib/dialog.module.d.ts +19 -19
  63. package/dialog/lib/dialog.ref.d.ts +8 -8
  64. package/dialog/lib/dialog.service.d.ts +19 -19
  65. package/dialog/public_api.d.ts +9 -9
  66. package/elements/bravobit-bb-foundation-elements.d.ts +5 -5
  67. package/elements/lib/avatar/avatar.component.d.ts +25 -25
  68. package/elements/lib/button/button.component.d.ts +23 -23
  69. package/elements/lib/checkbox/checkbox.component.d.ts +27 -27
  70. package/elements/lib/date-picker/date-picker.component.d.ts +69 -69
  71. package/elements/lib/directives/addon.directive.d.ts +9 -9
  72. package/elements/lib/directives/autosize.directive.d.ts +18 -18
  73. package/elements/lib/directives/focus-trap.directive.d.ts +17 -17
  74. package/elements/lib/directives/focus.directive.d.ts +14 -14
  75. package/elements/lib/directives/form-submit.directive.d.ts +17 -17
  76. package/elements/lib/directives/input.directive.d.ts +38 -38
  77. package/elements/lib/directives/template.directive.d.ts +10 -10
  78. package/elements/lib/dropdown/dropdown.component.d.ts +21 -21
  79. package/elements/lib/elements.interfaces.d.ts +25 -25
  80. package/elements/lib/elements.module.d.ts +116 -116
  81. package/elements/lib/file-picker/file-picker.component.d.ts +49 -49
  82. package/elements/lib/form-control/form-control.component.d.ts +21 -21
  83. package/elements/lib/form-error/form-error.component.d.ts +29 -29
  84. package/elements/lib/form-group/form-group.component.d.ts +10 -10
  85. package/elements/lib/icon/icon.component.d.ts +22 -22
  86. package/elements/lib/image-picker/image-picker.component.d.ts +38 -38
  87. package/elements/lib/pipes/file-image.pipe.d.ts +13 -13
  88. package/elements/lib/pipes/file-size.pipe.d.ts +8 -8
  89. package/elements/lib/pipes/relative-time.pipe.d.ts +19 -19
  90. package/elements/lib/spinner/spinner.component.d.ts +12 -12
  91. package/elements/lib/tag/tag.component.d.ts +7 -7
  92. package/elements/public_api.d.ts +25 -25
  93. package/esm2020/auth/bravobit-bb-foundation-auth.mjs +4 -4
  94. package/esm2020/auth/lib/auth.interceptor.mjs +93 -94
  95. package/esm2020/auth/lib/auth.module.mjs +54 -54
  96. package/esm2020/auth/lib/auth.service.mjs +281 -276
  97. package/esm2020/auth/lib/auth.session.mjs +131 -131
  98. package/esm2020/auth/lib/directives/authenticated.directive.mjs +31 -31
  99. package/esm2020/auth/lib/directives/permission.directive.mjs +80 -80
  100. package/esm2020/auth/lib/directives/role.directive.mjs +37 -37
  101. package/esm2020/auth/lib/guards/anonymous.guard.mjs +34 -34
  102. package/esm2020/auth/lib/guards/authenticated.guard.mjs +35 -35
  103. package/esm2020/auth/lib/helpers/jwt.helper.mjs +69 -69
  104. package/esm2020/auth/lib/helpers/mapper.helper.mjs +35 -35
  105. package/esm2020/auth/lib/interfaces/config.interface.mjs +3 -3
  106. package/esm2020/auth/lib/interfaces/mapper.interface.mjs +2 -2
  107. package/esm2020/auth/lib/interfaces/provider.interface.mjs +2 -2
  108. package/esm2020/auth/lib/interfaces/token.interface.mjs +2 -2
  109. package/esm2020/auth/lib/permissions.service.mjs +56 -56
  110. package/esm2020/auth/lib/providers/email.provider.mjs +25 -25
  111. package/esm2020/auth/lib/providers/verify.provider.mjs +19 -19
  112. package/esm2020/auth/lib/tokens/use-authorization.token.mjs +3 -3
  113. package/esm2020/auth/public_api.mjs +19 -19
  114. package/esm2020/bravobit-bb-foundation.mjs +4 -4
  115. package/esm2020/collections/bravobit-bb-foundation-collections.mjs +4 -4
  116. package/esm2020/collections/lib/collection.mjs +102 -102
  117. package/esm2020/collections/lib/collections.module.mjs +54 -54
  118. package/esm2020/collections/lib/components/collections-pager/collections-pager.component.mjs +123 -123
  119. package/esm2020/collections/lib/components/collections-viewer/collections-viewer.component.mjs +31 -31
  120. package/esm2020/collections/lib/components/collections.directive.mjs +43 -43
  121. package/esm2020/collections/lib/interfaces/collection.interface.mjs +2 -2
  122. package/esm2020/collections/lib/providers/api-collection.provider.mjs +71 -71
  123. package/esm2020/collections/lib/providers/collection.provider.mjs +13 -13
  124. package/esm2020/collections/lib/providers/local-collection.provider.mjs +16 -16
  125. package/esm2020/collections/public_api.mjs +10 -10
  126. package/esm2020/controls/bravobit-bb-foundation-controls.mjs +4 -4
  127. package/esm2020/controls/lib/checkbox/checkbox/checkbox.component.mjs +153 -153
  128. package/esm2020/controls/lib/checkbox/checkbox-group/checkbox-group.component.mjs +48 -48
  129. package/esm2020/controls/lib/checkbox/checkbox.module.mjs +19 -19
  130. package/esm2020/controls/lib/controls.module.mjs +16 -16
  131. package/esm2020/controls/public_api.mjs +5 -5
  132. package/esm2020/dashboard/bravobit-bb-foundation-dashboard.mjs +4 -4
  133. package/esm2020/dashboard/lib/dashboard/dashboard.component.mjs +56 -56
  134. package/esm2020/dashboard/lib/dashboard-header/dashboard-header.component.mjs +30 -30
  135. package/esm2020/dashboard/lib/dashboard-menu/dashboard-menu.component.mjs +31 -31
  136. package/esm2020/dashboard/lib/dashboard-menu-item/dashboard-menu-item.component.mjs +29 -29
  137. package/esm2020/dashboard/lib/dashboard-sidebar/dashboard-sidebar.component.mjs +75 -75
  138. package/esm2020/dashboard/lib/dashboard-sidebar-group/dashboard-sidebar-group.component.mjs +99 -99
  139. package/esm2020/dashboard/lib/dashboard-sidebar-item/dashboard-sidebar-item.component.mjs +62 -62
  140. package/esm2020/dashboard/lib/dashboard.module.mjs +47 -47
  141. package/esm2020/dashboard/public_api.mjs +9 -9
  142. package/esm2020/dialog/bravobit-bb-foundation-dialog.mjs +4 -4
  143. package/esm2020/dialog/lib/dialog-actions/dialog-actions.component.mjs +12 -12
  144. package/esm2020/dialog/lib/dialog-confirm/dialog-confirm.component.mjs +37 -37
  145. package/esm2020/dialog/lib/dialog-container/dialog-container.component.mjs +153 -153
  146. package/esm2020/dialog/lib/dialog-header/dialog-header.component.mjs +25 -25
  147. package/esm2020/dialog/lib/dialog-link/dialog-link.component.mjs +11 -11
  148. package/esm2020/dialog/lib/dialog-modal/dialog-modal.component.mjs +46 -46
  149. package/esm2020/dialog/lib/dialog-overlay/dialog-overlay.component.mjs +134 -134
  150. package/esm2020/dialog/lib/dialog.injector.mjs +18 -18
  151. package/esm2020/dialog/lib/dialog.insertion.mjs +16 -16
  152. package/esm2020/dialog/lib/dialog.interfaces.mjs +3 -3
  153. package/esm2020/dialog/lib/dialog.module.mjs +70 -70
  154. package/esm2020/dialog/lib/dialog.ref.mjs +22 -22
  155. package/esm2020/dialog/lib/dialog.service.mjs +77 -77
  156. package/esm2020/dialog/public_api.mjs +10 -10
  157. package/esm2020/elements/bravobit-bb-foundation-elements.mjs +4 -4
  158. package/esm2020/elements/lib/avatar/avatar.component.mjs +145 -145
  159. package/esm2020/elements/lib/button/button.component.mjs +61 -61
  160. package/esm2020/elements/lib/checkbox/checkbox.component.mjs +73 -73
  161. package/esm2020/elements/lib/date-picker/date-picker.component.mjs +304 -304
  162. package/esm2020/elements/lib/directives/addon.directive.mjs +29 -29
  163. package/esm2020/elements/lib/directives/autosize.directive.mjs +72 -72
  164. package/esm2020/elements/lib/directives/focus-trap.directive.mjs +77 -77
  165. package/esm2020/elements/lib/directives/focus.directive.mjs +39 -39
  166. package/esm2020/elements/lib/directives/form-submit.directive.mjs +50 -50
  167. package/esm2020/elements/lib/directives/input.directive.mjs +136 -136
  168. package/esm2020/elements/lib/directives/template.directive.mjs +28 -28
  169. package/esm2020/elements/lib/dropdown/dropdown.component.mjs +100 -100
  170. package/esm2020/elements/lib/elements.interfaces.mjs +4 -4
  171. package/esm2020/elements/lib/elements.module.mjs +177 -177
  172. package/esm2020/elements/lib/file-picker/file-picker.component.mjs +236 -236
  173. package/esm2020/elements/lib/form-control/form-control.component.mjs +49 -49
  174. package/esm2020/elements/lib/form-error/form-error.component.mjs +108 -108
  175. package/esm2020/elements/lib/form-group/form-group.component.mjs +18 -18
  176. package/esm2020/elements/lib/icon/icon.component.mjs +102 -102
  177. package/esm2020/elements/lib/image-picker/image-picker.component.mjs +106 -106
  178. package/esm2020/elements/lib/pipes/file-image.pipe.mjs +42 -42
  179. package/esm2020/elements/lib/pipes/file-size.pipe.mjs +28 -28
  180. package/esm2020/elements/lib/pipes/relative-time.pipe.mjs +94 -94
  181. package/esm2020/elements/lib/spinner/spinner.component.mjs +25 -25
  182. package/esm2020/elements/lib/tag/tag.component.mjs +18 -18
  183. package/esm2020/elements/public_api.mjs +26 -26
  184. package/esm2020/http/bravobit-bb-foundation-http.mjs +4 -4
  185. package/esm2020/http/lib/classes/http.config.mjs +29 -29
  186. package/esm2020/http/lib/classes/http.error.mjs +20 -20
  187. package/esm2020/http/lib/http.interfaces.mjs +2 -2
  188. package/esm2020/http/lib/http.module.mjs +43 -43
  189. package/esm2020/http/lib/interceptors/base-url.interceptor.mjs +50 -50
  190. package/esm2020/http/lib/interceptors/error.interceptor.mjs +32 -32
  191. package/esm2020/http/public_api.mjs +7 -7
  192. package/esm2020/lib/core/miscellaneous/regex.mjs +5 -5
  193. package/esm2020/lib/core/miscellaneous/validator.mjs +85 -85
  194. package/esm2020/lib/core/mixins/can-disable.mjs +16 -16
  195. package/esm2020/lib/core/mixins/can-hide-errors.mjs +16 -16
  196. package/esm2020/lib/core/mixins/can-load.mjs +16 -16
  197. package/esm2020/lib/core/mixins/constructor.mjs +2 -2
  198. package/esm2020/lib/core/mixins/has-error.mjs +16 -16
  199. package/esm2020/lib/core/mixins/is-focused.mjs +16 -16
  200. package/esm2020/lib/core/mixins/is-grouped.mjs +16 -16
  201. package/esm2020/lib/core/mixins/is-readonly.mjs +16 -16
  202. package/esm2020/lib/core/mixins/is-required.mjs +16 -16
  203. package/esm2020/lib/core/services/clipboard.service.mjs +70 -70
  204. package/esm2020/lib/core/services/exif.service.mjs +163 -163
  205. package/esm2020/lib/core/services/file-loader.service.mjs +87 -87
  206. package/esm2020/lib/core/services/image-converter.service.mjs +123 -123
  207. package/esm2020/lib/core/services/languages.service.mjs +74 -74
  208. package/esm2020/lib/core/services/network.service.mjs +55 -55
  209. package/esm2020/lib/core/services/patch.service.mjs +63 -63
  210. package/esm2020/lib/core/services/platform.service.mjs +42 -42
  211. package/esm2020/lib/core/tokens/accept-language.token.mjs +3 -3
  212. package/esm2020/lib/core/tokens/base-url.token.mjs +3 -3
  213. package/esm2020/lib/core/tokens/cookie.token.mjs +3 -3
  214. package/esm2020/lib/core/tokens/location.token.mjs +6 -6
  215. package/esm2020/lib/core/tokens/navigator.token.mjs +6 -6
  216. package/esm2020/lib/core/tokens/window.token.mjs +12 -12
  217. package/esm2020/localize/bravobit-bb-foundation-localize.mjs +4 -4
  218. package/esm2020/localize/lib/functions/date.function.mjs +18 -18
  219. package/esm2020/localize/lib/functions/lowercase.function.mjs +13 -13
  220. package/esm2020/localize/lib/functions/uppercase.function.mjs +13 -13
  221. package/esm2020/localize/lib/handlers/missing.handler.mjs +15 -17
  222. package/esm2020/localize/lib/interfaces/config.interfaces.mjs +7 -10
  223. package/esm2020/localize/lib/interfaces/functions.interfaces.mjs +8 -8
  224. package/esm2020/localize/lib/interfaces/handlers.interfaces.mjs +2 -2
  225. package/esm2020/localize/lib/interfaces/options.interfaces.mjs +6 -6
  226. package/esm2020/localize/lib/localizations/dutch.localization.mjs +45 -53
  227. package/esm2020/localize/lib/localizations/english.localization.mjs +45 -53
  228. package/esm2020/localize/lib/localize.dictionary.mjs +26 -135
  229. package/esm2020/localize/lib/localize.module.mjs +71 -72
  230. package/esm2020/localize/lib/localize.pipe.mjs +49 -49
  231. package/esm2020/localize/lib/localize.service.mjs +205 -280
  232. package/esm2020/localize/lib/views/localize-string/localize-string.component.mjs +88 -88
  233. package/esm2020/localize/lib/views/localize-template-or-string.directive.mjs +28 -28
  234. package/esm2020/localize/lib/views/localize-template.directive.mjs +21 -21
  235. package/esm2020/localize/public_api.mjs +17 -18
  236. package/esm2020/notifications/bravobit-bb-foundation-notifications.mjs +4 -4
  237. package/esm2020/notifications/lib/notifications-item/notifications-item.component.mjs +100 -100
  238. package/esm2020/notifications/lib/notifications-list/notifications-list.component.mjs +47 -47
  239. package/esm2020/notifications/lib/notifications.animations.mjs +28 -28
  240. package/esm2020/notifications/lib/notifications.injector.mjs +18 -18
  241. package/esm2020/notifications/lib/notifications.interfaces.mjs +20 -20
  242. package/esm2020/notifications/lib/notifications.module.mjs +30 -30
  243. package/esm2020/notifications/lib/notifications.service.mjs +145 -145
  244. package/esm2020/notifications/public_api.mjs +4 -4
  245. package/esm2020/public_api.mjs +29 -29
  246. package/esm2020/recaptcha/bravobit-bb-foundation-recaptcha.mjs +4 -4
  247. package/esm2020/recaptcha/lib/recaptcha/recaptcha.component.mjs +185 -185
  248. package/esm2020/recaptcha/lib/recaptcha-loader.service.mjs +90 -90
  249. package/esm2020/recaptcha/lib/recaptcha.interface.mjs +3 -3
  250. package/esm2020/recaptcha/lib/recaptcha.module.mjs +27 -27
  251. package/esm2020/recaptcha/public_api.mjs +5 -5
  252. package/esm2020/rxjs/bravobit-bb-foundation-rxjs.mjs +4 -4
  253. package/esm2020/rxjs/lib/operators/combine-latest-map.operator.mjs +10 -10
  254. package/esm2020/rxjs/lib/operators/filter-nil.operator.mjs +5 -5
  255. package/esm2020/rxjs/public_api.mjs +3 -3
  256. package/esm2020/storage/bravobit-bb-foundation-storage.mjs +4 -4
  257. package/esm2020/storage/lib/interfaces/attributes.interface.mjs +2 -2
  258. package/esm2020/storage/lib/interfaces/memory.interface.mjs +2 -2
  259. package/esm2020/storage/lib/interfaces/strategy.interface.mjs +2 -2
  260. package/esm2020/storage/lib/storage.service.mjs +109 -109
  261. package/esm2020/storage/lib/strategies/cookie-storage.strategy.mjs +142 -142
  262. package/esm2020/storage/lib/strategies/memory-storage.strategy.mjs +56 -56
  263. package/esm2020/storage/lib/strategies/polyfill-storage.strategy.mjs +102 -102
  264. package/esm2020/storage/public_api.mjs +8 -8
  265. package/esm2020/table/bravobit-bb-foundation-table.mjs +4 -4
  266. package/esm2020/table/lib/components/table/table.component.mjs +191 -191
  267. package/esm2020/table/lib/components/table-cell/table-cell.component.mjs +11 -11
  268. package/esm2020/table/lib/components/table-header-cell/table-header-cell.component.mjs +131 -131
  269. package/esm2020/table/lib/components/table-pager/table-pager.component.mjs +136 -136
  270. package/esm2020/table/lib/data/datasource.data.mjs +32 -32
  271. package/esm2020/table/lib/data/generic.data.mjs +72 -72
  272. package/esm2020/table/lib/interfaces/datasource.interface.mjs +2 -2
  273. package/esm2020/table/lib/interfaces/table.interfaces.mjs +2 -2
  274. package/esm2020/table/lib/table.module.mjs +42 -42
  275. package/esm2020/table/public_api.mjs +10 -10
  276. package/fesm2015/bravobit-bb-foundation-auth.mjs +930 -926
  277. package/fesm2015/bravobit-bb-foundation-auth.mjs.map +1 -1
  278. package/fesm2015/bravobit-bb-foundation-collections.mjs +423 -423
  279. package/fesm2015/bravobit-bb-foundation-collections.mjs.map +1 -1
  280. package/fesm2015/bravobit-bb-foundation-controls.mjs +216 -216
  281. package/fesm2015/bravobit-bb-foundation-controls.mjs.map +1 -1
  282. package/fesm2015/bravobit-bb-foundation-dashboard.mjs +382 -382
  283. package/fesm2015/bravobit-bb-foundation-dashboard.mjs.map +1 -1
  284. package/fesm2015/bravobit-bb-foundation-dialog.mjs +542 -542
  285. package/fesm2015/bravobit-bb-foundation-dialog.mjs.map +1 -1
  286. package/fesm2015/bravobit-bb-foundation-elements.mjs +1971 -1971
  287. package/fesm2015/bravobit-bb-foundation-elements.mjs.map +1 -1
  288. package/fesm2015/bravobit-bb-foundation-http.mjs +156 -156
  289. package/fesm2015/bravobit-bb-foundation-http.mjs.map +1 -1
  290. package/fesm2015/bravobit-bb-foundation-localize.mjs +611 -812
  291. package/fesm2015/bravobit-bb-foundation-localize.mjs.map +1 -1
  292. package/fesm2015/bravobit-bb-foundation-notifications.mjs +348 -348
  293. package/fesm2015/bravobit-bb-foundation-notifications.mjs.map +1 -1
  294. package/fesm2015/bravobit-bb-foundation-recaptcha.mjs +290 -290
  295. package/fesm2015/bravobit-bb-foundation-recaptcha.mjs.map +1 -1
  296. package/fesm2015/bravobit-bb-foundation-rxjs.mjs +7 -7
  297. package/fesm2015/bravobit-bb-foundation-rxjs.mjs.map +1 -1
  298. package/fesm2015/bravobit-bb-foundation-storage.mjs +401 -401
  299. package/fesm2015/bravobit-bb-foundation-storage.mjs.map +1 -1
  300. package/fesm2015/bravobit-bb-foundation-table.mjs +571 -571
  301. package/fesm2015/bravobit-bb-foundation-table.mjs.map +1 -1
  302. package/fesm2015/bravobit-bb-foundation.mjs +860 -860
  303. package/fesm2015/bravobit-bb-foundation.mjs.map +1 -1
  304. package/fesm2020/bravobit-bb-foundation-auth.mjs +882 -878
  305. package/fesm2020/bravobit-bb-foundation-auth.mjs.map +1 -1
  306. package/fesm2020/bravobit-bb-foundation-collections.mjs +413 -413
  307. package/fesm2020/bravobit-bb-foundation-collections.mjs.map +1 -1
  308. package/fesm2020/bravobit-bb-foundation-controls.mjs +214 -214
  309. package/fesm2020/bravobit-bb-foundation-controls.mjs.map +1 -1
  310. package/fesm2020/bravobit-bb-foundation-dashboard.mjs +370 -370
  311. package/fesm2020/bravobit-bb-foundation-dashboard.mjs.map +1 -1
  312. package/fesm2020/bravobit-bb-foundation-dialog.mjs +541 -541
  313. package/fesm2020/bravobit-bb-foundation-dialog.mjs.map +1 -1
  314. package/fesm2020/bravobit-bb-foundation-elements.mjs +1928 -1928
  315. package/fesm2020/bravobit-bb-foundation-elements.mjs.map +1 -1
  316. package/fesm2020/bravobit-bb-foundation-http.mjs +148 -148
  317. package/fesm2020/bravobit-bb-foundation-http.mjs.map +1 -1
  318. package/fesm2020/bravobit-bb-foundation-localize.mjs +590 -798
  319. package/fesm2020/bravobit-bb-foundation-localize.mjs.map +1 -1
  320. package/fesm2020/bravobit-bb-foundation-notifications.mjs +346 -346
  321. package/fesm2020/bravobit-bb-foundation-notifications.mjs.map +1 -1
  322. package/fesm2020/bravobit-bb-foundation-recaptcha.mjs +280 -280
  323. package/fesm2020/bravobit-bb-foundation-recaptcha.mjs.map +1 -1
  324. package/fesm2020/bravobit-bb-foundation-rxjs.mjs +10 -10
  325. package/fesm2020/bravobit-bb-foundation-rxjs.mjs.map +1 -1
  326. package/fesm2020/bravobit-bb-foundation-storage.mjs +396 -396
  327. package/fesm2020/bravobit-bb-foundation-storage.mjs.map +1 -1
  328. package/fesm2020/bravobit-bb-foundation-table.mjs +560 -560
  329. package/fesm2020/bravobit-bb-foundation-table.mjs.map +1 -1
  330. package/fesm2020/bravobit-bb-foundation.mjs +832 -832
  331. package/fesm2020/bravobit-bb-foundation.mjs.map +1 -1
  332. package/http/bravobit-bb-foundation-http.d.ts +5 -5
  333. package/http/lib/classes/http.config.d.ts +9 -9
  334. package/http/lib/classes/http.error.d.ts +7 -7
  335. package/http/lib/http.interfaces.d.ts +12 -12
  336. package/http/lib/http.module.d.ts +15 -15
  337. package/http/lib/interceptors/base-url.interceptor.d.ts +15 -15
  338. package/http/lib/interceptors/error.interceptor.d.ts +11 -11
  339. package/http/public_api.d.ts +6 -6
  340. package/lib/core/miscellaneous/regex.d.ts +4 -4
  341. package/lib/core/miscellaneous/validator.d.ts +13 -13
  342. package/lib/core/mixins/can-disable.d.ts +6 -6
  343. package/lib/core/mixins/can-hide-errors.d.ts +6 -6
  344. package/lib/core/mixins/can-load.d.ts +6 -6
  345. package/lib/core/mixins/constructor.d.ts +1 -1
  346. package/lib/core/mixins/has-error.d.ts +6 -6
  347. package/lib/core/mixins/is-focused.d.ts +6 -6
  348. package/lib/core/mixins/is-grouped.d.ts +6 -6
  349. package/lib/core/mixins/is-readonly.d.ts +6 -6
  350. package/lib/core/mixins/is-required.d.ts +6 -6
  351. package/lib/core/services/clipboard.service.d.ts +18 -18
  352. package/lib/core/services/exif.service.d.ts +15 -15
  353. package/lib/core/services/file-loader.service.d.ts +13 -13
  354. package/lib/core/services/image-converter.service.d.ts +21 -21
  355. package/lib/core/services/languages.service.d.ts +16 -16
  356. package/lib/core/services/network.service.d.ts +14 -14
  357. package/lib/core/services/patch.service.d.ts +16 -16
  358. package/lib/core/services/platform.service.d.ts +18 -18
  359. package/lib/core/tokens/accept-language.token.d.ts +2 -2
  360. package/lib/core/tokens/base-url.token.d.ts +2 -2
  361. package/lib/core/tokens/cookie.token.d.ts +2 -2
  362. package/lib/core/tokens/location.token.d.ts +2 -2
  363. package/lib/core/tokens/navigator.token.d.ts +2 -2
  364. package/lib/core/tokens/window.token.d.ts +2 -2
  365. package/localize/bravobit-bb-foundation-localize.d.ts +5 -5
  366. package/localize/lib/functions/date.function.d.ts +5 -5
  367. package/localize/lib/functions/lowercase.function.d.ts +5 -5
  368. package/localize/lib/functions/uppercase.function.d.ts +5 -5
  369. package/localize/lib/handlers/missing.handler.d.ts +6 -6
  370. package/localize/lib/interfaces/config.interfaces.d.ts +18 -9
  371. package/localize/lib/interfaces/functions.interfaces.d.ts +9 -9
  372. package/localize/lib/interfaces/handlers.interfaces.d.ts +6 -6
  373. package/localize/lib/interfaces/options.interfaces.d.ts +10 -10
  374. package/localize/lib/localizations/dutch.localization.d.ts +44 -51
  375. package/localize/lib/localizations/english.localization.d.ts +44 -51
  376. package/localize/lib/localize.dictionary.d.ts +7 -24
  377. package/localize/lib/localize.module.d.ts +17 -18
  378. package/localize/lib/localize.pipe.d.ts +12 -12
  379. package/localize/lib/localize.service.d.ts +40 -52
  380. package/localize/lib/views/localize-string/localize-string.component.d.ts +23 -23
  381. package/localize/lib/views/localize-template-or-string.directive.d.ts +10 -10
  382. package/localize/lib/views/localize-template.directive.d.ts +9 -9
  383. package/localize/public_api.d.ts +16 -17
  384. package/notifications/bravobit-bb-foundation-notifications.d.ts +5 -5
  385. package/notifications/lib/notifications-item/notifications-item.component.d.ts +34 -34
  386. package/notifications/lib/notifications-list/notifications-list.component.d.ts +16 -16
  387. package/notifications/lib/notifications.animations.d.ts +1 -1
  388. package/notifications/lib/notifications.injector.d.ts +8 -8
  389. package/notifications/lib/notifications.interfaces.d.ts +49 -49
  390. package/notifications/lib/notifications.module.d.ts +13 -13
  391. package/notifications/lib/notifications.service.d.ts +34 -34
  392. package/notifications/public_api.d.ts +3 -3
  393. package/package.json +6 -6
  394. package/public_api.d.ts +25 -25
  395. package/recaptcha/bravobit-bb-foundation-recaptcha.d.ts +5 -5
  396. package/recaptcha/lib/recaptcha/recaptcha.component.d.ts +47 -47
  397. package/recaptcha/lib/recaptcha-loader.service.d.ts +22 -22
  398. package/recaptcha/lib/recaptcha.interface.d.ts +14 -14
  399. package/recaptcha/lib/recaptcha.module.d.ts +10 -10
  400. package/recaptcha/public_api.d.ts +4 -4
  401. package/rxjs/bravobit-bb-foundation-rxjs.d.ts +5 -5
  402. package/rxjs/lib/operators/combine-latest-map.operator.d.ts +8 -8
  403. package/rxjs/lib/operators/filter-nil.operator.d.ts +1 -1
  404. package/rxjs/public_api.d.ts +2 -2
  405. package/storage/bravobit-bb-foundation-storage.d.ts +5 -5
  406. package/storage/lib/interfaces/attributes.interface.d.ts +13 -13
  407. package/storage/lib/interfaces/memory.interface.d.ts +7 -7
  408. package/storage/lib/interfaces/strategy.interface.d.ts +17 -17
  409. package/storage/lib/storage.service.d.ts +26 -26
  410. package/storage/lib/strategies/cookie-storage.strategy.d.ts +20 -20
  411. package/storage/lib/strategies/memory-storage.strategy.d.ts +11 -11
  412. package/storage/lib/strategies/polyfill-storage.strategy.d.ts +15 -15
  413. package/storage/public_api.d.ts +7 -7
  414. package/table/bravobit-bb-foundation-table.d.ts +5 -5
  415. package/table/lib/components/table/table.component.d.ts +56 -56
  416. package/table/lib/components/table-cell/table-cell.component.d.ts +5 -5
  417. package/table/lib/components/table-header-cell/table-header-cell.component.d.ts +29 -29
  418. package/table/lib/components/table-pager/table-pager.component.d.ts +41 -41
  419. package/table/lib/data/datasource.data.d.ts +14 -14
  420. package/table/lib/data/generic.data.d.ts +23 -23
  421. package/table/lib/interfaces/datasource.interface.d.ts +17 -17
  422. package/table/lib/interfaces/table.interfaces.d.ts +1 -1
  423. package/table/lib/table.module.d.ts +14 -14
  424. package/table/public_api.d.ts +9 -9
  425. package/esm2020/localize/lib/interfaces/dictionary.interfaces.mjs +0 -8
  426. package/localize/lib/interfaces/dictionary.interfaces.d.ts +0 -12
@@ -6,435 +6,435 @@ import * as i1 from '@angular/common';
6
6
  import { CommonModule } from '@angular/common';
7
7
  import { FormControl } from '@angular/forms';
8
8
 
9
- class CollectionProvider {
10
- formatArrayToCollectionData(items) {
11
- const count = items?.length ?? 1;
12
- return {
13
- pageSize: count,
14
- totalEntries: count,
15
- pageNumber: 1,
16
- totalPages: 1,
17
- data: items
18
- };
19
- }
9
+ class CollectionProvider {
10
+ formatArrayToCollectionData(items) {
11
+ const count = items?.length ?? 1;
12
+ return {
13
+ pageSize: count,
14
+ totalEntries: count,
15
+ pageNumber: 1,
16
+ totalPages: 1,
17
+ data: items
18
+ };
19
+ }
20
20
  }
21
21
 
22
- class ApiCollectionProvider extends CollectionProvider {
23
- constructor(_endpoint, _httpClient) {
24
- super();
25
- this._endpoint = _endpoint;
26
- this._httpClient = _httpClient;
27
- // State.
28
- this._extraParams = {};
29
- this.getBackendFormat = (request) => {
30
- const params = {};
31
- params['page'] = request?.pageNumber ?? 1;
32
- params['page_size'] = request?.pageSize ?? 25;
33
- if (request?.sort) {
34
- const sort = Array.isArray(request?.sort) ? request?.sort : [request?.sort];
35
- const filteredSort = sort?.filter(item => !!item?.name && !!item?.direction);
36
- params['sort'] = filteredSort?.map(item => item?.name)?.join(',');
37
- params['sort_direction'] = filteredSort?.map(item => item?.direction)?.join(',');
38
- }
39
- if (request?.query && request?.query?.length > 0 && request?.queryFields && request?.queryFields?.length > 0) {
40
- params['query'] = request?.query;
41
- params['query_fields'] = request?.queryFields?.join(',');
42
- }
43
- return params;
44
- };
45
- }
46
- append(name, value) {
47
- this._extraParams[name] = isObservable(value) ? value : of(value);
48
- return this;
49
- }
50
- transform(request) {
51
- const endpoint$ = isObservable(this._endpoint) ? this._endpoint : of(this._endpoint);
52
- const params = this.getBackendFormat(request);
53
- const extraParams$ = this.getExtraParams(this._extraParams);
54
- return combineLatest([endpoint$, extraParams$]).pipe(switchMap(([endpoint, extraParams]) => {
55
- return this._httpClient.get(endpoint, {
56
- params: { ...params, ...extraParams }
57
- });
58
- }), map(response => this.formatToCollectionData(response)));
59
- }
60
- getExtraParams(params) {
61
- const keys = Object.keys(params ?? {});
62
- if (keys.length <= 0) {
63
- return of({});
64
- }
65
- const observables$ = keys.map(key => params?.[key]);
66
- return combineLatest(observables$).pipe(map(data => {
67
- return data.reduce((previous, current, index) => {
68
- if (current === null || current === undefined) {
69
- return previous;
70
- }
71
- const key = keys?.[index];
72
- return { ...previous, [key]: current };
73
- }, {});
74
- }));
75
- }
76
- formatToCollectionData(response) {
77
- if (Array.isArray(response)) {
78
- return this.formatArrayToCollectionData(response);
79
- }
80
- return {
81
- pageSize: response?.['page_size'],
82
- pageNumber: response?.['page_number'],
83
- totalPages: response?.['total_pages'],
84
- totalEntries: response?.['total_entries'],
85
- data: response?.['data']
86
- };
87
- }
22
+ class ApiCollectionProvider extends CollectionProvider {
23
+ constructor(_endpoint, _httpClient) {
24
+ super();
25
+ this._endpoint = _endpoint;
26
+ this._httpClient = _httpClient;
27
+ // State.
28
+ this._extraParams = {};
29
+ }
30
+ append(name, value) {
31
+ this._extraParams[name] = isObservable(value) ? value : of(value);
32
+ return this;
33
+ }
34
+ transform(request) {
35
+ const endpoint$ = isObservable(this._endpoint) ? this._endpoint : of(this._endpoint);
36
+ const params = this.getBackendFormat(request);
37
+ const extraParams$ = this.getExtraParams(this._extraParams);
38
+ return combineLatest([endpoint$, extraParams$]).pipe(switchMap(([endpoint, extraParams]) => {
39
+ return this._httpClient.get(endpoint, {
40
+ params: { ...params, ...extraParams }
41
+ });
42
+ }), map(response => this.formatToCollectionData(response)));
43
+ }
44
+ getExtraParams(params) {
45
+ const keys = Object.keys(params ?? {});
46
+ if (keys.length <= 0) {
47
+ return of({});
48
+ }
49
+ const observables$ = keys.map(key => params?.[key]);
50
+ return combineLatest(observables$).pipe(map(data => {
51
+ return data.reduce((previous, current, index) => {
52
+ if (current === null || current === undefined) {
53
+ return previous;
54
+ }
55
+ const key = keys?.[index];
56
+ return { ...previous, [key]: current };
57
+ }, {});
58
+ }));
59
+ }
60
+ formatToCollectionData(response) {
61
+ if (Array.isArray(response)) {
62
+ return this.formatArrayToCollectionData(response);
63
+ }
64
+ return {
65
+ pageSize: response?.page_size,
66
+ pageNumber: response?.page_number,
67
+ totalPages: response?.total_pages,
68
+ totalEntries: response?.total_entries,
69
+ data: response?.data
70
+ };
71
+ }
72
+ getBackendFormat(request) {
73
+ const params = {};
74
+ params['page'] = request?.pageNumber ?? 1;
75
+ params['page_size'] = request?.pageSize ?? 25;
76
+ if (request?.sort) {
77
+ const sort = Array.isArray(request?.sort) ? request?.sort : [request?.sort];
78
+ const filteredSort = sort?.filter(item => !!item?.name && !!item?.direction);
79
+ params['sort'] = filteredSort?.map(item => item?.name)?.join(',');
80
+ params['sort_direction'] = filteredSort?.map(item => item?.direction)?.join(',');
81
+ }
82
+ if (request?.query && request?.query?.length > 0 && request?.queryFields && request?.queryFields?.length > 0) {
83
+ params['query'] = request?.query;
84
+ params['query_fields'] = request?.queryFields?.join(',');
85
+ }
86
+ return params;
87
+ }
88
88
  }
89
89
 
90
- class LocalCollectionProvider extends CollectionProvider {
91
- constructor(_items) {
92
- super();
93
- this._items = _items;
94
- }
95
- transform(request) {
96
- const items$ = Array.isArray(this._items)
97
- ? of(this._items)
98
- : this._items;
99
- return items$.pipe(map(items => this.formatArrayToCollectionData(items)));
100
- }
90
+ class LocalCollectionProvider extends CollectionProvider {
91
+ constructor(_items) {
92
+ super();
93
+ this._items = _items;
94
+ }
95
+ transform(request) {
96
+ const items$ = Array.isArray(this._items)
97
+ ? of(this._items)
98
+ : this._items;
99
+ return items$.pipe(map(items => this.formatArrayToCollectionData(items)));
100
+ }
101
101
  }
102
102
 
103
- class BbCollectionsData {
104
- }
105
- BbCollectionsData.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: BbCollectionsData, deps: [], target: i0.ɵɵFactoryTarget.Directive });
106
- BbCollectionsData.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.5", type: BbCollectionsData, selector: "[bbCollectionsData]", ngImport: i0 });
107
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: BbCollectionsData, decorators: [{
108
- type: Directive,
109
- args: [{
110
- selector: '[bbCollectionsData]'
111
- }]
112
- }] });
113
- class BbCollectionsEmpty {
114
- }
115
- BbCollectionsEmpty.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: BbCollectionsEmpty, deps: [], target: i0.ɵɵFactoryTarget.Directive });
116
- BbCollectionsEmpty.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.5", type: BbCollectionsEmpty, selector: "[bbCollectionsEmpty]", ngImport: i0 });
117
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: BbCollectionsEmpty, decorators: [{
118
- type: Directive,
119
- args: [{
120
- selector: '[bbCollectionsEmpty]'
121
- }]
122
- }] });
123
- class BbCollectionsError {
124
- }
125
- BbCollectionsError.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: BbCollectionsError, deps: [], target: i0.ɵɵFactoryTarget.Directive });
126
- BbCollectionsError.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.5", type: BbCollectionsError, selector: "[bbCollectionsError]", ngImport: i0 });
127
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: BbCollectionsError, decorators: [{
128
- type: Directive,
129
- args: [{
130
- selector: '[bbCollectionsError]'
131
- }]
132
- }] });
133
- class BbCollectionsInitial {
134
- }
135
- BbCollectionsInitial.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: BbCollectionsInitial, deps: [], target: i0.ɵɵFactoryTarget.Directive });
136
- BbCollectionsInitial.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.5", type: BbCollectionsInitial, selector: "[bbCollectionsInitial]", ngImport: i0 });
137
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: BbCollectionsInitial, decorators: [{
138
- type: Directive,
139
- args: [{
140
- selector: '[bbCollectionsInitial]'
141
- }]
103
+ class BbCollectionsData {
104
+ }
105
+ BbCollectionsData.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: BbCollectionsData, deps: [], target: i0.ɵɵFactoryTarget.Directive });
106
+ BbCollectionsData.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.6", type: BbCollectionsData, selector: "[bbCollectionsData]", ngImport: i0 });
107
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: BbCollectionsData, decorators: [{
108
+ type: Directive,
109
+ args: [{
110
+ selector: '[bbCollectionsData]'
111
+ }]
112
+ }] });
113
+ class BbCollectionsEmpty {
114
+ }
115
+ BbCollectionsEmpty.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: BbCollectionsEmpty, deps: [], target: i0.ɵɵFactoryTarget.Directive });
116
+ BbCollectionsEmpty.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.6", type: BbCollectionsEmpty, selector: "[bbCollectionsEmpty]", ngImport: i0 });
117
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: BbCollectionsEmpty, decorators: [{
118
+ type: Directive,
119
+ args: [{
120
+ selector: '[bbCollectionsEmpty]'
121
+ }]
122
+ }] });
123
+ class BbCollectionsError {
124
+ }
125
+ BbCollectionsError.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: BbCollectionsError, deps: [], target: i0.ɵɵFactoryTarget.Directive });
126
+ BbCollectionsError.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.6", type: BbCollectionsError, selector: "[bbCollectionsError]", ngImport: i0 });
127
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: BbCollectionsError, decorators: [{
128
+ type: Directive,
129
+ args: [{
130
+ selector: '[bbCollectionsError]'
131
+ }]
132
+ }] });
133
+ class BbCollectionsInitial {
134
+ }
135
+ BbCollectionsInitial.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: BbCollectionsInitial, deps: [], target: i0.ɵɵFactoryTarget.Directive });
136
+ BbCollectionsInitial.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.6", type: BbCollectionsInitial, selector: "[bbCollectionsInitial]", ngImport: i0 });
137
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: BbCollectionsInitial, decorators: [{
138
+ type: Directive,
139
+ args: [{
140
+ selector: '[bbCollectionsInitial]'
141
+ }]
142
142
  }] });
143
143
 
144
- class BbCollectionsViewer {
145
- constructor() {
146
- // Inputs.
147
- this.collection = null;
148
- }
149
- }
150
- BbCollectionsViewer.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: BbCollectionsViewer, deps: [], target: i0.ɵɵFactoryTarget.Component });
151
- BbCollectionsViewer.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.5", type: BbCollectionsViewer, selector: "[bb-collections-viewer]", inputs: { collection: "collection" }, host: { classAttribute: "bb-collections-viewer" }, queries: [{ propertyName: "dataTemplate", first: true, predicate: BbCollectionsData, descendants: true, read: TemplateRef }, { propertyName: "emptyTemplate", first: true, predicate: BbCollectionsEmpty, descendants: true, read: TemplateRef }, { propertyName: "errorTemplate", first: true, predicate: BbCollectionsError, descendants: true, read: TemplateRef }, { propertyName: "initialTemplate", first: true, predicate: BbCollectionsInitial, descendants: true, read: TemplateRef }], ngImport: i0, template: "<ng-container *ngIf=\"collection?.data$ | async as data\"\n [ngSwitch]=\"data?.state\">\n <ng-container *ngSwitchDefault>\n <ng-container *ngTemplateOutlet=\"dataTemplate; context: {items: data?.response?.data}\"></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"'initial'\">\n <ng-container *ngTemplateOutlet=\"initialTemplate\"></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"'empty'\">\n <ng-container *ngTemplateOutlet=\"emptyTemplate; context: {query: data?.request?.query}\"></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"'error'\">\n <ng-container *ngTemplateOutlet=\"errorTemplate; context: {error: data?.error}\"></ng-container>\n </ng-container>\n</ng-container>\n", styles: [".bb-collections-viewer{display:block}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i1.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }], pipes: { "async": i1.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
152
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: BbCollectionsViewer, decorators: [{
153
- type: Component,
154
- args: [{ selector: '[bb-collections-viewer]', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: { 'class': 'bb-collections-viewer' }, preserveWhitespaces: false, template: "<ng-container *ngIf=\"collection?.data$ | async as data\"\n [ngSwitch]=\"data?.state\">\n <ng-container *ngSwitchDefault>\n <ng-container *ngTemplateOutlet=\"dataTemplate; context: {items: data?.response?.data}\"></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"'initial'\">\n <ng-container *ngTemplateOutlet=\"initialTemplate\"></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"'empty'\">\n <ng-container *ngTemplateOutlet=\"emptyTemplate; context: {query: data?.request?.query}\"></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"'error'\">\n <ng-container *ngTemplateOutlet=\"errorTemplate; context: {error: data?.error}\"></ng-container>\n </ng-container>\n</ng-container>\n", styles: [".bb-collections-viewer{display:block}\n"] }]
155
- }], propDecorators: { dataTemplate: [{
156
- type: ContentChild,
157
- args: [BbCollectionsData, { read: TemplateRef, static: false }]
158
- }], emptyTemplate: [{
159
- type: ContentChild,
160
- args: [BbCollectionsEmpty, { read: TemplateRef, static: false }]
161
- }], errorTemplate: [{
162
- type: ContentChild,
163
- args: [BbCollectionsError, { read: TemplateRef, static: false }]
164
- }], initialTemplate: [{
165
- type: ContentChild,
166
- args: [BbCollectionsInitial, { read: TemplateRef, static: false }]
167
- }], collection: [{
168
- type: Input
144
+ class BbCollectionsViewer {
145
+ constructor() {
146
+ // Inputs.
147
+ this.collection = null;
148
+ }
149
+ }
150
+ BbCollectionsViewer.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: BbCollectionsViewer, deps: [], target: i0.ɵɵFactoryTarget.Component });
151
+ BbCollectionsViewer.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.6", type: BbCollectionsViewer, selector: "[bb-collections-viewer]", inputs: { collection: "collection" }, host: { classAttribute: "bb-collections-viewer" }, queries: [{ propertyName: "dataTemplate", first: true, predicate: BbCollectionsData, descendants: true, read: TemplateRef }, { propertyName: "emptyTemplate", first: true, predicate: BbCollectionsEmpty, descendants: true, read: TemplateRef }, { propertyName: "errorTemplate", first: true, predicate: BbCollectionsError, descendants: true, read: TemplateRef }, { propertyName: "initialTemplate", first: true, predicate: BbCollectionsInitial, descendants: true, read: TemplateRef }], ngImport: i0, template: "<ng-container *ngIf=\"collection?.data$ | async as data\"\r\n [ngSwitch]=\"data?.state\">\r\n <ng-container *ngSwitchDefault>\r\n <ng-container *ngTemplateOutlet=\"dataTemplate; context: {items: data?.response?.data}\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'initial'\">\r\n <ng-container *ngTemplateOutlet=\"initialTemplate\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'empty'\">\r\n <ng-container *ngTemplateOutlet=\"emptyTemplate; context: {query: data?.request?.query}\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'error'\">\r\n <ng-container *ngTemplateOutlet=\"errorTemplate; context: {error: data?.error}\"></ng-container>\r\n </ng-container>\r\n</ng-container>\r\n", styles: [".bb-collections-viewer{display:block}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i1.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }], pipes: { "async": i1.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
152
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: BbCollectionsViewer, decorators: [{
153
+ type: Component,
154
+ args: [{ selector: '[bb-collections-viewer]', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: { 'class': 'bb-collections-viewer' }, preserveWhitespaces: false, template: "<ng-container *ngIf=\"collection?.data$ | async as data\"\r\n [ngSwitch]=\"data?.state\">\r\n <ng-container *ngSwitchDefault>\r\n <ng-container *ngTemplateOutlet=\"dataTemplate; context: {items: data?.response?.data}\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'initial'\">\r\n <ng-container *ngTemplateOutlet=\"initialTemplate\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'empty'\">\r\n <ng-container *ngTemplateOutlet=\"emptyTemplate; context: {query: data?.request?.query}\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'error'\">\r\n <ng-container *ngTemplateOutlet=\"errorTemplate; context: {error: data?.error}\"></ng-container>\r\n </ng-container>\r\n</ng-container>\r\n", styles: [".bb-collections-viewer{display:block}\n"] }]
155
+ }], propDecorators: { dataTemplate: [{
156
+ type: ContentChild,
157
+ args: [BbCollectionsData, { read: TemplateRef, static: false }]
158
+ }], emptyTemplate: [{
159
+ type: ContentChild,
160
+ args: [BbCollectionsEmpty, { read: TemplateRef, static: false }]
161
+ }], errorTemplate: [{
162
+ type: ContentChild,
163
+ args: [BbCollectionsError, { read: TemplateRef, static: false }]
164
+ }], initialTemplate: [{
165
+ type: ContentChild,
166
+ args: [BbCollectionsInitial, { read: TemplateRef, static: false }]
167
+ }], collection: [{
168
+ type: Input
169
169
  }] } });
170
170
 
171
- class BbCollectionsPager {
172
- constructor() {
173
- // Readonly data.
174
- this.maxAmountOfButtons = 5;
175
- this.cache$ = new BehaviorSubject({});
176
- // State and subscriptions.
177
- this._label = null;
178
- this._collection = null;
179
- this._subscription = null;
180
- }
181
- // Inputs.
182
- set label(value) {
183
- this._label = value;
184
- this.cache$.next(this.cache$.getValue());
185
- }
186
- set collection(collection) {
187
- this._collection = collection;
188
- this.observeCollectionChanges();
189
- }
190
- ngOnInit() {
191
- this.data$ = this.cache$.pipe(map(cache => {
192
- const pageSize = cache?.pageSize ?? 1;
193
- const pageNumber = cache?.pageNumber ?? 1;
194
- const totalPages = Math.max(0, cache?.totalPages ?? 1);
195
- const totalEntries = Math.max(0, cache?.totalEntries ?? 0);
196
- const fromStart = Math.max(0, Math.min((pageSize * (pageNumber - 1)) + 1, totalEntries));
197
- const fromEnd = Math.max(0, Math.min((fromStart - 1) + pageSize, totalEntries));
198
- const pages = this.filterActivePages(pageNumber, totalPages);
199
- const allowNext = pageNumber < totalPages;
200
- const allowPrevious = pageNumber > 1;
201
- return {
202
- totalPages,
203
- pages,
204
- pageNumber,
205
- allowNext,
206
- allowPrevious,
207
- label: this.calculateLabel(fromStart, fromEnd, totalEntries)
208
- };
209
- }));
210
- }
211
- ngOnDestroy() {
212
- this._subscription?.unsubscribe();
213
- }
214
- setPage(pageNumber, totalPages) {
215
- // Calculate the new value.
216
- const newValue = Math.min(totalPages, Math.max(1, pageNumber));
217
- // Validate the value is actually different.
218
- const currentValue = this._collection?.pageNumberControl?.value;
219
- if (currentValue === newValue) {
220
- return;
221
- }
222
- this._collection?.pageNumberControl?.setValue(pageNumber);
223
- }
224
- observeCollectionChanges() {
225
- if (!this._collection) {
226
- return;
227
- }
228
- if (this._subscription) {
229
- this._subscription?.unsubscribe();
230
- }
231
- const pageNumber = this._collection?.pageNumberControl?.value;
232
- const pageSize = this._collection?.pageSizeControl?.value;
233
- this.cache$.next({ pageNumber, pageSize });
234
- this._subscription = this._collection.raw$.subscribe(data => {
235
- if (data) {
236
- this.cache$.next(data);
237
- }
238
- });
239
- }
240
- calculateLabel(start, end, total) {
241
- const startPoint = '[start]';
242
- const endPoint = '[end]';
243
- const totalPoint = '[total]';
244
- const label = this._label ?? `Showing ${startPoint} to ${endPoint} of ${totalPoint} results`;
245
- return label
246
- .replace(startPoint, `<strong>${start}</strong>`)
247
- .replace(endPoint, `<strong>${end}</strong>`)
248
- .replace(totalPoint, `<strong>${total}</strong>`);
249
- }
250
- calculatePages(pageNumber, totalPages) {
251
- const min = 1;
252
- const max = totalPages;
253
- const amount = Math.max(1, this.maxAmountOfButtons);
254
- const data = Array(amount)
255
- .fill(0)
256
- .map((_, index) => pageNumber + (index - 1));
257
- // Validate if the minimum value less than
258
- // the first value.
259
- if (data[0] < min) {
260
- return data.map(item => item + 1);
261
- }
262
- // Calculate the difference with the max
263
- // if this value is higher than 0 we should minus it.
264
- const lastValueInArray = data[data.length - 1];
265
- const differenceWithMax = lastValueInArray - max;
266
- if (differenceWithMax > 0) {
267
- return data.map(item => item - differenceWithMax);
268
- }
269
- // Just return the default data.
270
- return data;
271
- }
272
- filterActivePages(pageNumber, totalPages) {
273
- return this.calculatePages(pageNumber, totalPages)
274
- .filter(page => page > 0 && page <= totalPages)
275
- .map(page => ({ page, active: pageNumber === page }));
276
- }
277
- }
278
- BbCollectionsPager.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: BbCollectionsPager, deps: [], target: i0.ɵɵFactoryTarget.Component });
279
- BbCollectionsPager.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.5", type: BbCollectionsPager, selector: "bb-collections-pager", inputs: { label: "label", collection: "collection" }, host: { classAttribute: "bb-collections-pager" }, ngImport: i0, template: "<ng-container *ngIf=\"data$ | async as data\">\n <div [innerHTML]=\"data?.label\"\n class=\"bb-collections-pager-text\">\n </div>\n\n <div class=\"bb-collections-pager-container\">\n <ul class=\"bb-collections-pager-list\">\n <li class=\"bb-collections-pager-item\"\n title=\"Previous page\">\n <button [disabled]=\"!data?.allowPrevious\"\n (click)=\"setPage(data?.pageNumber - 1, data?.totalPages)\"\n class=\"bb-collections-pager-button arrow first\"\n type=\"button\">\n &#8592;\n </button>\n </li>\n <li *ngFor=\"let item of data?.pages\"\n [title]=\"'Page ' + item?.page\"\n class=\"bb-collections-pager-item\">\n <button [class.active]=\"item?.active\"\n (click)=\"setPage(item?.page, data?.totalPages)\"\n class=\"bb-collections-pager-button\"\n type=\"button\">\n {{ item?.page }}\n </button>\n </li>\n <li class=\"bb-collections-pager-item\"\n title=\"Next page\">\n <button [disabled]=\"!data?.allowNext\"\n (click)=\"setPage(data?.pageNumber + 1, data?.totalPages)\"\n class=\"bb-collections-pager-button arrow last\"\n type=\"button\">\n &#8594;\n </button>\n </li>\n </ul>\n </div>\n</ng-container>\n", styles: [".bb-collections-pager{display:flex;align-items:center;flex-direction:column-reverse}.bb-collections-pager-text{display:block;margin-top:10px}.bb-collections-pager-text>strong{font-weight:500}.bb-collections-pager-container{width:100%;display:flex;overflow-x:auto;align-items:center;justify-content:center}.bb-collections-pager-list{display:flex;border-radius:6px;align-items:center;background-color:#fff;border:1px solid rgba(67,90,111,.3);box-shadow:#435a6f24 0 1px 2px inset}.bb-collections-pager-item:not(:last-child){border-right:1px solid #cccccc}.bb-collections-pager-button{height:34px;border:none;display:flex;padding:0 4px;min-width:40px;-webkit-appearance:none;appearance:none;min-height:34px;-webkit-user-select:none;user-select:none;align-items:center;justify-content:center;background-color:transparent}.bb-collections-pager-button:hover,.bb-collections-pager-button:focus,.bb-collections-pager-button:active,.bb-collections-pager-button.active{color:#1565c0;font-weight:500}.bb-collections-pager-button:hover,.bb-collections-pager-button:focus{background-color:#1565c00d}.bb-collections-pager-button:active,.bb-collections-pager-button.active{background-color:#1565c033}.bb-collections-pager-button:not(.arrow):hover,.bb-collections-pager-button:not(.arrow):focus{outline:1px solid rgba(21,101,192,.5)}.bb-collections-pager-button:not(.arrow):focus,.bb-collections-pager-button:not(.arrow):active{outline:1px solid #1565c0;box-shadow:#1565c066 0 0 0 3px}.bb-collections-pager-button:not(.arrow).active{outline:1px solid #1565c0}.bb-collections-pager-button.arrow{font-weight:500}.bb-collections-pager-button.arrow.first{border-top-left-radius:2px;border-bottom-left-radius:2px}.bb-collections-pager-button.arrow.last{border-top-right-radius:2px;border-bottom-right-radius:2px}.bb-collections-pager-button:disabled{color:#000;outline:none;opacity:.25;cursor:default;pointer-events:none;background-color:transparent}@media only screen and (min-width: 768px){.bb-collections-pager{flex-wrap:wrap;align-items:center;flex-direction:row;justify-content:space-between}.bb-collections-pager-text{margin-top:0}.bb-collections-pager-container{width:auto;overflow-x:unset}}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "async": i1.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
280
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: BbCollectionsPager, decorators: [{
281
- type: Component,
282
- args: [{ selector: 'bb-collections-pager', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: { 'class': 'bb-collections-pager' }, preserveWhitespaces: false, template: "<ng-container *ngIf=\"data$ | async as data\">\n <div [innerHTML]=\"data?.label\"\n class=\"bb-collections-pager-text\">\n </div>\n\n <div class=\"bb-collections-pager-container\">\n <ul class=\"bb-collections-pager-list\">\n <li class=\"bb-collections-pager-item\"\n title=\"Previous page\">\n <button [disabled]=\"!data?.allowPrevious\"\n (click)=\"setPage(data?.pageNumber - 1, data?.totalPages)\"\n class=\"bb-collections-pager-button arrow first\"\n type=\"button\">\n &#8592;\n </button>\n </li>\n <li *ngFor=\"let item of data?.pages\"\n [title]=\"'Page ' + item?.page\"\n class=\"bb-collections-pager-item\">\n <button [class.active]=\"item?.active\"\n (click)=\"setPage(item?.page, data?.totalPages)\"\n class=\"bb-collections-pager-button\"\n type=\"button\">\n {{ item?.page }}\n </button>\n </li>\n <li class=\"bb-collections-pager-item\"\n title=\"Next page\">\n <button [disabled]=\"!data?.allowNext\"\n (click)=\"setPage(data?.pageNumber + 1, data?.totalPages)\"\n class=\"bb-collections-pager-button arrow last\"\n type=\"button\">\n &#8594;\n </button>\n </li>\n </ul>\n </div>\n</ng-container>\n", styles: [".bb-collections-pager{display:flex;align-items:center;flex-direction:column-reverse}.bb-collections-pager-text{display:block;margin-top:10px}.bb-collections-pager-text>strong{font-weight:500}.bb-collections-pager-container{width:100%;display:flex;overflow-x:auto;align-items:center;justify-content:center}.bb-collections-pager-list{display:flex;border-radius:6px;align-items:center;background-color:#fff;border:1px solid rgba(67,90,111,.3);box-shadow:#435a6f24 0 1px 2px inset}.bb-collections-pager-item:not(:last-child){border-right:1px solid #cccccc}.bb-collections-pager-button{height:34px;border:none;display:flex;padding:0 4px;min-width:40px;-webkit-appearance:none;appearance:none;min-height:34px;-webkit-user-select:none;user-select:none;align-items:center;justify-content:center;background-color:transparent}.bb-collections-pager-button:hover,.bb-collections-pager-button:focus,.bb-collections-pager-button:active,.bb-collections-pager-button.active{color:#1565c0;font-weight:500}.bb-collections-pager-button:hover,.bb-collections-pager-button:focus{background-color:#1565c00d}.bb-collections-pager-button:active,.bb-collections-pager-button.active{background-color:#1565c033}.bb-collections-pager-button:not(.arrow):hover,.bb-collections-pager-button:not(.arrow):focus{outline:1px solid rgba(21,101,192,.5)}.bb-collections-pager-button:not(.arrow):focus,.bb-collections-pager-button:not(.arrow):active{outline:1px solid #1565c0;box-shadow:#1565c066 0 0 0 3px}.bb-collections-pager-button:not(.arrow).active{outline:1px solid #1565c0}.bb-collections-pager-button.arrow{font-weight:500}.bb-collections-pager-button.arrow.first{border-top-left-radius:2px;border-bottom-left-radius:2px}.bb-collections-pager-button.arrow.last{border-top-right-radius:2px;border-bottom-right-radius:2px}.bb-collections-pager-button:disabled{color:#000;outline:none;opacity:.25;cursor:default;pointer-events:none;background-color:transparent}@media only screen and (min-width: 768px){.bb-collections-pager{flex-wrap:wrap;align-items:center;flex-direction:row;justify-content:space-between}.bb-collections-pager-text{margin-top:0}.bb-collections-pager-container{width:auto;overflow-x:unset}}\n"] }]
283
- }], propDecorators: { label: [{
284
- type: Input
285
- }], collection: [{
286
- type: Input
171
+ class BbCollectionsPager {
172
+ constructor() {
173
+ // Readonly data.
174
+ this.maxAmountOfButtons = 5;
175
+ this.cache$ = new BehaviorSubject({});
176
+ // State and subscriptions.
177
+ this._label = null;
178
+ this._collection = null;
179
+ this._subscription = null;
180
+ }
181
+ // Inputs.
182
+ set label(value) {
183
+ this._label = value;
184
+ this.cache$.next(this.cache$.getValue());
185
+ }
186
+ set collection(collection) {
187
+ this._collection = collection;
188
+ this.observeCollectionChanges();
189
+ }
190
+ ngOnInit() {
191
+ this.data$ = this.cache$.pipe(map(cache => {
192
+ const pageSize = cache?.pageSize ?? 1;
193
+ const pageNumber = cache?.pageNumber ?? 1;
194
+ const totalPages = Math.max(0, cache?.totalPages ?? 1);
195
+ const totalEntries = Math.max(0, cache?.totalEntries ?? 0);
196
+ const fromStart = Math.max(0, Math.min((pageSize * (pageNumber - 1)) + 1, totalEntries));
197
+ const fromEnd = Math.max(0, Math.min((fromStart - 1) + pageSize, totalEntries));
198
+ const pages = this.filterActivePages(pageNumber, totalPages);
199
+ const allowNext = pageNumber < totalPages;
200
+ const allowPrevious = pageNumber > 1;
201
+ return {
202
+ totalPages,
203
+ pages,
204
+ pageNumber,
205
+ allowNext,
206
+ allowPrevious,
207
+ label: this.calculateLabel(fromStart, fromEnd, totalEntries)
208
+ };
209
+ }));
210
+ }
211
+ ngOnDestroy() {
212
+ this._subscription?.unsubscribe();
213
+ }
214
+ setPage(pageNumber, totalPages) {
215
+ // Calculate the new value.
216
+ const newValue = Math.min(totalPages, Math.max(1, pageNumber));
217
+ // Validate the value is actually different.
218
+ const currentValue = this._collection?.pageNumberControl?.value;
219
+ if (currentValue === newValue) {
220
+ return;
221
+ }
222
+ this._collection?.pageNumberControl?.setValue(pageNumber);
223
+ }
224
+ observeCollectionChanges() {
225
+ if (!this._collection) {
226
+ return;
227
+ }
228
+ if (this._subscription) {
229
+ this._subscription?.unsubscribe();
230
+ }
231
+ const pageNumber = this._collection?.pageNumberControl?.value;
232
+ const pageSize = this._collection?.pageSizeControl?.value;
233
+ this.cache$.next({ pageNumber, pageSize });
234
+ this._subscription = this._collection.raw$.subscribe(data => {
235
+ if (data) {
236
+ this.cache$.next(data);
237
+ }
238
+ });
239
+ }
240
+ calculateLabel(start, end, total) {
241
+ const startPoint = '[start]';
242
+ const endPoint = '[end]';
243
+ const totalPoint = '[total]';
244
+ const label = this._label ?? `Showing ${startPoint} to ${endPoint} of ${totalPoint} results`;
245
+ return label
246
+ .replace(startPoint, `<strong>${start}</strong>`)
247
+ .replace(endPoint, `<strong>${end}</strong>`)
248
+ .replace(totalPoint, `<strong>${total}</strong>`);
249
+ }
250
+ calculatePages(pageNumber, totalPages) {
251
+ const min = 1;
252
+ const max = totalPages;
253
+ const amount = Math.max(1, this.maxAmountOfButtons);
254
+ const data = Array(amount)
255
+ .fill(0)
256
+ .map((_, index) => pageNumber + (index - 1));
257
+ // Validate if the minimum value less than
258
+ // the first value.
259
+ if (data[0] < min) {
260
+ return data.map(item => item + 1);
261
+ }
262
+ // Calculate the difference with the max
263
+ // if this value is higher than 0 we should minus it.
264
+ const lastValueInArray = data[data.length - 1];
265
+ const differenceWithMax = lastValueInArray - max;
266
+ if (differenceWithMax > 0) {
267
+ return data.map(item => item - differenceWithMax);
268
+ }
269
+ // Just return the default data.
270
+ return data;
271
+ }
272
+ filterActivePages(pageNumber, totalPages) {
273
+ return this.calculatePages(pageNumber, totalPages)
274
+ .filter(page => page > 0 && page <= totalPages)
275
+ .map(page => ({ page, active: pageNumber === page }));
276
+ }
277
+ }
278
+ BbCollectionsPager.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: BbCollectionsPager, deps: [], target: i0.ɵɵFactoryTarget.Component });
279
+ BbCollectionsPager.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.6", type: BbCollectionsPager, selector: "bb-collections-pager", inputs: { label: "label", collection: "collection" }, host: { classAttribute: "bb-collections-pager" }, ngImport: i0, template: "<ng-container *ngIf=\"data$ | async as data\">\r\n <div [innerHTML]=\"data?.label\"\r\n class=\"bb-collections-pager-text\">\r\n </div>\r\n\r\n <div class=\"bb-collections-pager-container\">\r\n <ul class=\"bb-collections-pager-list\">\r\n <li class=\"bb-collections-pager-item\"\r\n title=\"Previous page\">\r\n <button [disabled]=\"!data?.allowPrevious\"\r\n (click)=\"setPage(data?.pageNumber - 1, data?.totalPages)\"\r\n class=\"bb-collections-pager-button arrow first\"\r\n type=\"button\">\r\n &#8592;\r\n </button>\r\n </li>\r\n <li *ngFor=\"let item of data?.pages\"\r\n [title]=\"'Page ' + item?.page\"\r\n class=\"bb-collections-pager-item\">\r\n <button [class.active]=\"item?.active\"\r\n (click)=\"setPage(item?.page, data?.totalPages)\"\r\n class=\"bb-collections-pager-button\"\r\n type=\"button\">\r\n {{ item?.page }}\r\n </button>\r\n </li>\r\n <li class=\"bb-collections-pager-item\"\r\n title=\"Next page\">\r\n <button [disabled]=\"!data?.allowNext\"\r\n (click)=\"setPage(data?.pageNumber + 1, data?.totalPages)\"\r\n class=\"bb-collections-pager-button arrow last\"\r\n type=\"button\">\r\n &#8594;\r\n </button>\r\n </li>\r\n </ul>\r\n </div>\r\n</ng-container>\r\n", styles: [".bb-collections-pager{display:flex;align-items:center;flex-direction:column-reverse}.bb-collections-pager-text{display:block;margin-top:10px}.bb-collections-pager-text>strong{font-weight:500}.bb-collections-pager-container{width:100%;display:flex;overflow-x:auto;align-items:center;justify-content:center}.bb-collections-pager-list{display:flex;border-radius:6px;align-items:center;background-color:#fff;border:1px solid rgba(67,90,111,.3);box-shadow:#435a6f24 0 1px 2px inset}.bb-collections-pager-item:not(:last-child){border-right:1px solid #cccccc}.bb-collections-pager-button{height:34px;border:none;display:flex;padding:0 4px;min-width:40px;-webkit-appearance:none;appearance:none;min-height:34px;-webkit-user-select:none;user-select:none;align-items:center;justify-content:center;background-color:transparent}.bb-collections-pager-button:hover,.bb-collections-pager-button:focus,.bb-collections-pager-button:active,.bb-collections-pager-button.active{color:#1565c0;font-weight:500}.bb-collections-pager-button:hover,.bb-collections-pager-button:focus{background-color:#1565c00d}.bb-collections-pager-button:active,.bb-collections-pager-button.active{background-color:#1565c033}.bb-collections-pager-button:not(.arrow):hover,.bb-collections-pager-button:not(.arrow):focus{outline:1px solid rgba(21,101,192,.5)}.bb-collections-pager-button:not(.arrow):focus,.bb-collections-pager-button:not(.arrow):active{outline:1px solid #1565c0;box-shadow:#1565c066 0 0 0 3px}.bb-collections-pager-button:not(.arrow).active{outline:1px solid #1565c0}.bb-collections-pager-button.arrow{font-weight:500}.bb-collections-pager-button.arrow.first{border-top-left-radius:2px;border-bottom-left-radius:2px}.bb-collections-pager-button.arrow.last{border-top-right-radius:2px;border-bottom-right-radius:2px}.bb-collections-pager-button:disabled{color:#000;outline:none;opacity:.25;cursor:default;pointer-events:none;background-color:transparent}@media only screen and (min-width: 768px){.bb-collections-pager{flex-wrap:wrap;align-items:center;flex-direction:row;justify-content:space-between}.bb-collections-pager-text{margin-top:0}.bb-collections-pager-container{width:auto;overflow-x:unset}}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "async": i1.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
280
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: BbCollectionsPager, decorators: [{
281
+ type: Component,
282
+ args: [{ selector: 'bb-collections-pager', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: { 'class': 'bb-collections-pager' }, preserveWhitespaces: false, template: "<ng-container *ngIf=\"data$ | async as data\">\r\n <div [innerHTML]=\"data?.label\"\r\n class=\"bb-collections-pager-text\">\r\n </div>\r\n\r\n <div class=\"bb-collections-pager-container\">\r\n <ul class=\"bb-collections-pager-list\">\r\n <li class=\"bb-collections-pager-item\"\r\n title=\"Previous page\">\r\n <button [disabled]=\"!data?.allowPrevious\"\r\n (click)=\"setPage(data?.pageNumber - 1, data?.totalPages)\"\r\n class=\"bb-collections-pager-button arrow first\"\r\n type=\"button\">\r\n &#8592;\r\n </button>\r\n </li>\r\n <li *ngFor=\"let item of data?.pages\"\r\n [title]=\"'Page ' + item?.page\"\r\n class=\"bb-collections-pager-item\">\r\n <button [class.active]=\"item?.active\"\r\n (click)=\"setPage(item?.page, data?.totalPages)\"\r\n class=\"bb-collections-pager-button\"\r\n type=\"button\">\r\n {{ item?.page }}\r\n </button>\r\n </li>\r\n <li class=\"bb-collections-pager-item\"\r\n title=\"Next page\">\r\n <button [disabled]=\"!data?.allowNext\"\r\n (click)=\"setPage(data?.pageNumber + 1, data?.totalPages)\"\r\n class=\"bb-collections-pager-button arrow last\"\r\n type=\"button\">\r\n &#8594;\r\n </button>\r\n </li>\r\n </ul>\r\n </div>\r\n</ng-container>\r\n", styles: [".bb-collections-pager{display:flex;align-items:center;flex-direction:column-reverse}.bb-collections-pager-text{display:block;margin-top:10px}.bb-collections-pager-text>strong{font-weight:500}.bb-collections-pager-container{width:100%;display:flex;overflow-x:auto;align-items:center;justify-content:center}.bb-collections-pager-list{display:flex;border-radius:6px;align-items:center;background-color:#fff;border:1px solid rgba(67,90,111,.3);box-shadow:#435a6f24 0 1px 2px inset}.bb-collections-pager-item:not(:last-child){border-right:1px solid #cccccc}.bb-collections-pager-button{height:34px;border:none;display:flex;padding:0 4px;min-width:40px;-webkit-appearance:none;appearance:none;min-height:34px;-webkit-user-select:none;user-select:none;align-items:center;justify-content:center;background-color:transparent}.bb-collections-pager-button:hover,.bb-collections-pager-button:focus,.bb-collections-pager-button:active,.bb-collections-pager-button.active{color:#1565c0;font-weight:500}.bb-collections-pager-button:hover,.bb-collections-pager-button:focus{background-color:#1565c00d}.bb-collections-pager-button:active,.bb-collections-pager-button.active{background-color:#1565c033}.bb-collections-pager-button:not(.arrow):hover,.bb-collections-pager-button:not(.arrow):focus{outline:1px solid rgba(21,101,192,.5)}.bb-collections-pager-button:not(.arrow):focus,.bb-collections-pager-button:not(.arrow):active{outline:1px solid #1565c0;box-shadow:#1565c066 0 0 0 3px}.bb-collections-pager-button:not(.arrow).active{outline:1px solid #1565c0}.bb-collections-pager-button.arrow{font-weight:500}.bb-collections-pager-button.arrow.first{border-top-left-radius:2px;border-bottom-left-radius:2px}.bb-collections-pager-button.arrow.last{border-top-right-radius:2px;border-bottom-right-radius:2px}.bb-collections-pager-button:disabled{color:#000;outline:none;opacity:.25;cursor:default;pointer-events:none;background-color:transparent}@media only screen and (min-width: 768px){.bb-collections-pager{flex-wrap:wrap;align-items:center;flex-direction:row;justify-content:space-between}.bb-collections-pager-text{margin-top:0}.bb-collections-pager-container{width:auto;overflow-x:unset}}\n"] }]
283
+ }], propDecorators: { label: [{
284
+ type: Input
285
+ }], collection: [{
286
+ type: Input
287
287
  }] } });
288
288
 
289
- class Collection {
290
- constructor(_provider, _initialValues = {}) {
291
- this._provider = _provider;
292
- this._initialValues = _initialValues;
293
- this.raw$ = new BehaviorSubject(null);
294
- this.loading$ = new BehaviorSubject(true);
295
- // State.
296
- this._formatter = null;
297
- this._refresh$ = new BehaviorSubject(0);
298
- this._requestCache = null;
299
- this.controlToObservable = (control) => {
300
- return control.valueChanges.pipe(distinctUntilChanged(), startWith(control?.value));
301
- };
302
- this.queryControl = new FormControl(_initialValues?.query ?? null);
303
- this.queryFieldsControl = new FormControl(_initialValues?.queryFields ?? []);
304
- this.pageNumberControl = new FormControl(_initialValues?.pageNumber ?? 1);
305
- this.pageSizeControl = new FormControl(_initialValues?.pageSize ?? 25);
306
- this.sortControl = new FormControl(_initialValues?.sort ?? null);
307
- this.data$ = this.getData();
308
- }
309
- refresh() {
310
- this._refresh$.next(0);
311
- }
312
- setFormatter(callback) {
313
- this._formatter = callback;
314
- return this;
315
- }
316
- getData() {
317
- const data$ = this.request.pipe(tap(() => this.loading$.next(true)), map(request => this.validateRequest(request)), switchMap(request => {
318
- return this._provider.transform(request).pipe(tap(response => this.cacheCollectionData(response)), map(response => ({ response, request, initial: false })), catchError(error => of({
319
- error,
320
- request,
321
- response: null,
322
- initial: false
323
- })));
324
- }), startWith({ initial: true, response: null }));
325
- return combineLatest([data$, this.loading$.asObservable()]).pipe(switchMap(([data, loading]) => {
326
- const combined = { ...data, loading };
327
- return this.formatResponse(data?.response).pipe(map(response => ({
328
- ...combined,
329
- response,
330
- state: this.getState(combined)
331
- })));
332
- }));
333
- }
334
- formatResponse(response) {
335
- if (!response || !this._formatter) {
336
- return of(response);
337
- }
338
- const items = response?.data ?? [];
339
- const data = this._formatter?.(items) ?? items;
340
- const data$ = isObservable(data) ? data : of(data);
341
- return data$.pipe(map(data => ({ ...response, data })));
342
- }
343
- validateRequest(request) {
344
- // We should reset the page number whenever we change the query or the page size.
345
- if (this._requestCache && request && (this._requestCache?.query !== request?.query || this._requestCache?.pageSize !== request?.pageSize)) {
346
- this.pageNumberControl?.setValue(1, { emitEvent: false });
347
- request.pageNumber = this.pageNumberControl?.value;
348
- }
349
- this._requestCache = { ...request };
350
- return request;
351
- }
352
- getState(data) {
353
- if (!!data?.error) {
354
- return "error" /* Error */;
355
- }
356
- if (!!data?.initial) {
357
- return "initial" /* Initial */;
358
- }
359
- const count = data?.response?.data?.length ?? 0;
360
- if (count <= 0) {
361
- return "empty" /* Empty */;
362
- }
363
- return "data" /* Data */;
364
- }
365
- cacheCollectionData(data) {
366
- this.raw$.next(data);
367
- this.loading$.next(false);
368
- }
369
- get request() {
370
- const pageNumber$ = this.controlToObservable(this.pageNumberControl);
371
- const pageSize$ = this.controlToObservable(this.pageSizeControl);
372
- const query$ = this.getQueryObservable();
373
- const queryFields$ = this.controlToObservable(this.queryFieldsControl);
374
- const sort$ = this.controlToObservable(this.sortControl);
375
- return combineLatest([pageNumber$, pageSize$, query$, queryFields$, sort$, this._refresh$.asObservable()]).pipe(map(([pageNumber, pageSize, query, queryFields, sort]) => ({
376
- pageNumber,
377
- pageSize,
378
- query,
379
- queryFields,
380
- sort
381
- })));
382
- }
383
- getQueryObservable() {
384
- return this.queryControl.valueChanges.pipe(debounceTime(400), distinctUntilChanged(), startWith(this.queryControl?.value));
385
- }
289
+ class Collection {
290
+ constructor(_provider, _initialValues = {}) {
291
+ this._provider = _provider;
292
+ this._initialValues = _initialValues;
293
+ this.raw$ = new BehaviorSubject(null);
294
+ this.loading$ = new BehaviorSubject(true);
295
+ // State.
296
+ this._formatter = null;
297
+ this._refresh$ = new BehaviorSubject(0);
298
+ this._requestCache = null;
299
+ this.controlToObservable = (control) => {
300
+ return control.valueChanges.pipe(distinctUntilChanged(), startWith(control?.value));
301
+ };
302
+ this.queryControl = new FormControl(_initialValues?.query ?? null);
303
+ this.queryFieldsControl = new FormControl(_initialValues?.queryFields ?? []);
304
+ this.pageNumberControl = new FormControl(_initialValues?.pageNumber ?? 1);
305
+ this.pageSizeControl = new FormControl(_initialValues?.pageSize ?? 25);
306
+ this.sortControl = new FormControl(_initialValues?.sort ?? null);
307
+ this.data$ = this.getData();
308
+ }
309
+ refresh() {
310
+ this._refresh$.next(0);
311
+ }
312
+ setFormatter(callback) {
313
+ this._formatter = callback;
314
+ return this;
315
+ }
316
+ getData() {
317
+ const data$ = this.request.pipe(tap(() => this.loading$.next(true)), map(request => this.validateRequest(request)), switchMap(request => {
318
+ return this._provider.transform(request).pipe(tap(response => this.cacheCollectionData(response)), map(response => ({ response, request, initial: false })), catchError(error => of({
319
+ error,
320
+ request,
321
+ response: null,
322
+ initial: false
323
+ })));
324
+ }), startWith({ initial: true, response: null }));
325
+ return combineLatest([data$, this.loading$.asObservable()]).pipe(switchMap(([data, loading]) => {
326
+ const combined = { ...data, loading };
327
+ return this.formatResponse(data?.response).pipe(map(response => ({
328
+ ...combined,
329
+ response,
330
+ state: this.getState(combined)
331
+ })));
332
+ }));
333
+ }
334
+ formatResponse(response) {
335
+ if (!response || !this._formatter) {
336
+ return of(response);
337
+ }
338
+ const items = response?.data ?? [];
339
+ const data = this._formatter?.(items) ?? items;
340
+ const data$ = isObservable(data) ? data : of(data);
341
+ return data$.pipe(map(data => ({ ...response, data })));
342
+ }
343
+ validateRequest(request) {
344
+ // We should reset the page number whenever we change the query or the page size.
345
+ if (this._requestCache && request && (this._requestCache?.query !== request?.query || this._requestCache?.pageSize !== request?.pageSize)) {
346
+ this.pageNumberControl?.setValue(1, { emitEvent: false });
347
+ request.pageNumber = this.pageNumberControl?.value;
348
+ }
349
+ this._requestCache = { ...request };
350
+ return request;
351
+ }
352
+ getState(data) {
353
+ if (!!data?.error) {
354
+ return "error" /* Error */;
355
+ }
356
+ if (!!data?.initial) {
357
+ return "initial" /* Initial */;
358
+ }
359
+ const count = data?.response?.data?.length ?? 0;
360
+ if (count <= 0) {
361
+ return "empty" /* Empty */;
362
+ }
363
+ return "data" /* Data */;
364
+ }
365
+ cacheCollectionData(data) {
366
+ this.raw$.next(data);
367
+ this.loading$.next(false);
368
+ }
369
+ get request() {
370
+ const pageNumber$ = this.controlToObservable(this.pageNumberControl);
371
+ const pageSize$ = this.controlToObservable(this.pageSizeControl);
372
+ const query$ = this.getQueryObservable();
373
+ const queryFields$ = this.controlToObservable(this.queryFieldsControl);
374
+ const sort$ = this.controlToObservable(this.sortControl);
375
+ return combineLatest([pageNumber$, pageSize$, query$, queryFields$, sort$, this._refresh$.asObservable()]).pipe(map(([pageNumber, pageSize, query, queryFields, sort]) => ({
376
+ pageNumber,
377
+ pageSize,
378
+ query,
379
+ queryFields,
380
+ sort
381
+ })));
382
+ }
383
+ getQueryObservable() {
384
+ return this.queryControl.valueChanges.pipe(debounceTime(400), distinctUntilChanged(), startWith(this.queryControl?.value));
385
+ }
386
386
  }
387
387
 
388
- class CollectionsModule {
389
- }
390
- CollectionsModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: CollectionsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
391
- CollectionsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: CollectionsModule, declarations: [
392
- // Components.
393
- BbCollectionsViewer,
394
- BbCollectionsPager,
395
- // Directives.
396
- BbCollectionsData,
397
- BbCollectionsEmpty,
398
- BbCollectionsError,
399
- BbCollectionsInitial], imports: [CommonModule], exports: [
400
- // Components.
401
- BbCollectionsViewer,
402
- BbCollectionsPager,
403
- // Directives.
404
- BbCollectionsData,
405
- BbCollectionsEmpty,
406
- BbCollectionsError,
407
- BbCollectionsInitial] });
408
- CollectionsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: CollectionsModule, imports: [[CommonModule]] });
409
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: CollectionsModule, decorators: [{
410
- type: NgModule,
411
- args: [{
412
- imports: [CommonModule],
413
- declarations: [
414
- // Components.
415
- BbCollectionsViewer,
416
- BbCollectionsPager,
417
- // Directives.
418
- BbCollectionsData,
419
- BbCollectionsEmpty,
420
- BbCollectionsError,
421
- BbCollectionsInitial
422
- ],
423
- exports: [
424
- // Components.
425
- BbCollectionsViewer,
426
- BbCollectionsPager,
427
- // Directives.
428
- BbCollectionsData,
429
- BbCollectionsEmpty,
430
- BbCollectionsError,
431
- BbCollectionsInitial
432
- ]
433
- }]
388
+ class CollectionsModule {
389
+ }
390
+ CollectionsModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: CollectionsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
391
+ CollectionsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: CollectionsModule, declarations: [
392
+ // Components.
393
+ BbCollectionsViewer,
394
+ BbCollectionsPager,
395
+ // Directives.
396
+ BbCollectionsData,
397
+ BbCollectionsEmpty,
398
+ BbCollectionsError,
399
+ BbCollectionsInitial], imports: [CommonModule], exports: [
400
+ // Components.
401
+ BbCollectionsViewer,
402
+ BbCollectionsPager,
403
+ // Directives.
404
+ BbCollectionsData,
405
+ BbCollectionsEmpty,
406
+ BbCollectionsError,
407
+ BbCollectionsInitial] });
408
+ CollectionsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: CollectionsModule, imports: [[CommonModule]] });
409
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: CollectionsModule, decorators: [{
410
+ type: NgModule,
411
+ args: [{
412
+ imports: [CommonModule],
413
+ declarations: [
414
+ // Components.
415
+ BbCollectionsViewer,
416
+ BbCollectionsPager,
417
+ // Directives.
418
+ BbCollectionsData,
419
+ BbCollectionsEmpty,
420
+ BbCollectionsError,
421
+ BbCollectionsInitial
422
+ ],
423
+ exports: [
424
+ // Components.
425
+ BbCollectionsViewer,
426
+ BbCollectionsPager,
427
+ // Directives.
428
+ BbCollectionsData,
429
+ BbCollectionsEmpty,
430
+ BbCollectionsError,
431
+ BbCollectionsInitial
432
+ ]
433
+ }]
434
434
  }] });
435
435
 
436
- /**
437
- * Generated bundle index. Do not edit.
436
+ /**
437
+ * Generated bundle index. Do not edit.
438
438
  */
439
439
 
440
440
  export { ApiCollectionProvider, BbCollectionsData, BbCollectionsEmpty, BbCollectionsError, BbCollectionsInitial, BbCollectionsPager, BbCollectionsViewer, Collection, CollectionProvider, CollectionsModule, LocalCollectionProvider };