@bravobit/bb-foundation 0.14.2 → 0.15.1

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 (413) 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/bundles/bravobit-bb-foundation-auth.umd.js +1400 -1402
  25. package/bundles/bravobit-bb-foundation-auth.umd.js.map +1 -1
  26. package/bundles/bravobit-bb-foundation-collections.umd.js +851 -0
  27. package/bundles/bravobit-bb-foundation-collections.umd.js.map +1 -0
  28. package/bundles/bravobit-bb-foundation-dashboard.umd.js +817 -819
  29. package/bundles/bravobit-bb-foundation-dashboard.umd.js.map +1 -1
  30. package/bundles/bravobit-bb-foundation-dialog.umd.js +649 -651
  31. package/bundles/bravobit-bb-foundation-dialog.umd.js.map +1 -1
  32. package/bundles/bravobit-bb-foundation-elements.umd.js +2651 -2653
  33. package/bundles/bravobit-bb-foundation-elements.umd.js.map +1 -1
  34. package/bundles/bravobit-bb-foundation-http.umd.js +488 -490
  35. package/bundles/bravobit-bb-foundation-http.umd.js.map +1 -1
  36. package/bundles/bravobit-bb-foundation-localize.umd.js +1208 -1210
  37. package/bundles/bravobit-bb-foundation-localize.umd.js.map +1 -1
  38. package/bundles/bravobit-bb-foundation-notifications.umd.js +743 -745
  39. package/bundles/bravobit-bb-foundation-notifications.umd.js.map +1 -1
  40. package/bundles/bravobit-bb-foundation-recaptcha.umd.js +640 -642
  41. package/bundles/bravobit-bb-foundation-recaptcha.umd.js.map +1 -1
  42. package/bundles/bravobit-bb-foundation-rxjs.umd.js +13 -13
  43. package/bundles/bravobit-bb-foundation-rxjs.umd.js.map +1 -1
  44. package/bundles/bravobit-bb-foundation-storage.umd.js +756 -758
  45. package/bundles/bravobit-bb-foundation-storage.umd.js.map +1 -1
  46. package/bundles/bravobit-bb-foundation-table.umd.js +993 -995
  47. package/bundles/bravobit-bb-foundation-table.umd.js.map +1 -1
  48. package/bundles/bravobit-bb-foundation.umd.js +1336 -1263
  49. package/bundles/bravobit-bb-foundation.umd.js.map +1 -1
  50. package/collections/bravobit-bb-foundation-collections.d.ts +5 -0
  51. package/collections/lib/collection.d.ts +40 -0
  52. package/collections/lib/collections.module.d.ts +10 -0
  53. package/collections/lib/components/collections-pager/collections-pager.component.d.ts +34 -0
  54. package/collections/lib/components/collections-viewer/collections-viewer.component.d.ts +12 -0
  55. package/collections/lib/components/collections.directive.d.ts +17 -0
  56. package/collections/lib/interfaces/collection.interface.d.ts +26 -0
  57. package/collections/lib/providers/api-collection.provider.d.ts +15 -0
  58. package/collections/lib/providers/collection.provider.d.ts +6 -0
  59. package/collections/lib/providers/local-collection.provider.d.ts +8 -0
  60. package/collections/package.json +10 -0
  61. package/collections/public_api.d.ts +9 -0
  62. package/dashboard/bravobit-bb-foundation-dashboard.d.ts +5 -5
  63. package/dashboard/lib/dashboard/dashboard.component.d.ts +19 -19
  64. package/dashboard/lib/dashboard-header/dashboard-header.component.d.ts +11 -11
  65. package/dashboard/lib/dashboard-menu/dashboard-menu.component.d.ts +9 -9
  66. package/dashboard/lib/dashboard-menu-item/dashboard-menu-item.component.d.ts +11 -11
  67. package/dashboard/lib/dashboard-sidebar/dashboard-sidebar.component.d.ts +21 -21
  68. package/dashboard/lib/dashboard-sidebar-group/dashboard-sidebar-group.component.d.ts +27 -27
  69. package/dashboard/lib/dashboard-sidebar-item/dashboard-sidebar-item.component.d.ts +16 -16
  70. package/dashboard/lib/dashboard.module.d.ts +16 -16
  71. package/dashboard/public_api.d.ts +8 -8
  72. package/dialog/bravobit-bb-foundation-dialog.d.ts +5 -5
  73. package/dialog/lib/dialog-actions/dialog-actions.component.d.ts +5 -5
  74. package/dialog/lib/dialog-confirm/dialog-confirm.component.d.ts +16 -16
  75. package/dialog/lib/dialog-container/dialog-container.component.d.ts +24 -24
  76. package/dialog/lib/dialog-header/dialog-header.component.d.ts +9 -9
  77. package/dialog/lib/dialog-link/dialog-link.component.d.ts +5 -5
  78. package/dialog/lib/dialog-modal/dialog-modal.component.d.ts +12 -12
  79. package/dialog/lib/dialog-overlay/dialog-overlay.component.d.ts +22 -22
  80. package/dialog/lib/dialog.injector.d.ts +8 -8
  81. package/dialog/lib/dialog.insertion.d.ts +8 -8
  82. package/dialog/lib/dialog.interfaces.d.ts +3 -3
  83. package/dialog/lib/dialog.module.d.ts +19 -19
  84. package/dialog/lib/dialog.ref.d.ts +8 -8
  85. package/dialog/lib/dialog.service.d.ts +19 -19
  86. package/dialog/public_api.d.ts +9 -9
  87. package/elements/bravobit-bb-foundation-elements.d.ts +5 -5
  88. package/elements/lib/avatar/avatar.component.d.ts +25 -25
  89. package/elements/lib/button/button.component.d.ts +23 -23
  90. package/elements/lib/checkbox/checkbox.component.d.ts +27 -27
  91. package/elements/lib/date-picker/date-picker.component.d.ts +69 -69
  92. package/elements/lib/directives/addon.directive.d.ts +9 -9
  93. package/elements/lib/directives/autosize.directive.d.ts +18 -18
  94. package/elements/lib/directives/focus-trap.directive.d.ts +17 -17
  95. package/elements/lib/directives/focus.directive.d.ts +14 -14
  96. package/elements/lib/directives/form-submit.directive.d.ts +17 -17
  97. package/elements/lib/directives/input.directive.d.ts +38 -38
  98. package/elements/lib/directives/template.directive.d.ts +10 -10
  99. package/elements/lib/dropdown/dropdown.component.d.ts +21 -21
  100. package/elements/lib/elements.interfaces.d.ts +25 -25
  101. package/elements/lib/elements.module.d.ts +116 -116
  102. package/elements/lib/file-picker/file-picker.component.d.ts +49 -49
  103. package/elements/lib/form-control/form-control.component.d.ts +21 -21
  104. package/elements/lib/form-error/form-error.component.d.ts +29 -29
  105. package/elements/lib/form-group/form-group.component.d.ts +10 -10
  106. package/elements/lib/icon/icon.component.d.ts +22 -22
  107. package/elements/lib/image-picker/image-picker.component.d.ts +38 -38
  108. package/elements/lib/pipes/file-image.pipe.d.ts +13 -13
  109. package/elements/lib/pipes/file-size.pipe.d.ts +8 -8
  110. package/elements/lib/pipes/relative-time.pipe.d.ts +19 -19
  111. package/elements/lib/spinner/spinner.component.d.ts +12 -12
  112. package/elements/lib/tag/tag.component.d.ts +7 -7
  113. package/elements/public_api.d.ts +25 -25
  114. package/esm2015/auth/bravobit-bb-foundation-auth.js +4 -4
  115. package/esm2015/auth/lib/auth.interceptor.js +95 -95
  116. package/esm2015/auth/lib/auth.module.js +54 -54
  117. package/esm2015/auth/lib/auth.service.js +299 -299
  118. package/esm2015/auth/lib/auth.session.js +136 -136
  119. package/esm2015/auth/lib/directives/authenticated.directive.js +32 -32
  120. package/esm2015/auth/lib/directives/permission.directive.js +81 -81
  121. package/esm2015/auth/lib/directives/role.directive.js +38 -38
  122. package/esm2015/auth/lib/guards/anonymous.guard.js +35 -35
  123. package/esm2015/auth/lib/guards/authenticated.guard.js +36 -36
  124. package/esm2015/auth/lib/helpers/jwt.helper.js +69 -69
  125. package/esm2015/auth/lib/helpers/mapper.helper.js +35 -35
  126. package/esm2015/auth/lib/interfaces/config.interface.js +3 -3
  127. package/esm2015/auth/lib/interfaces/mapper.interface.js +2 -2
  128. package/esm2015/auth/lib/interfaces/provider.interface.js +2 -2
  129. package/esm2015/auth/lib/interfaces/token.interface.js +2 -2
  130. package/esm2015/auth/lib/permissions.service.js +58 -58
  131. package/esm2015/auth/lib/providers/email.provider.js +26 -26
  132. package/esm2015/auth/lib/providers/verify.provider.js +20 -20
  133. package/esm2015/auth/lib/tokens/use-authorization.token.js +3 -3
  134. package/esm2015/auth/public_api.js +19 -19
  135. package/esm2015/bravobit-bb-foundation.js +4 -4
  136. package/esm2015/collections/bravobit-bb-foundation-collections.js +5 -0
  137. package/esm2015/collections/lib/collection.js +88 -0
  138. package/esm2015/collections/lib/collections.module.js +54 -0
  139. package/esm2015/collections/lib/components/collections-pager/collections-pager.component.js +136 -0
  140. package/esm2015/collections/lib/components/collections-viewer/collections-viewer.component.js +39 -0
  141. package/esm2015/collections/lib/components/collections.directive.js +43 -0
  142. package/esm2015/collections/lib/interfaces/collection.interface.js +2 -0
  143. package/esm2015/collections/lib/providers/api-collection.provider.js +69 -0
  144. package/esm2015/collections/lib/providers/collection.provider.js +14 -0
  145. package/esm2015/collections/lib/providers/local-collection.provider.js +16 -0
  146. package/esm2015/collections/public_api.js +10 -0
  147. package/esm2015/dashboard/bravobit-bb-foundation-dashboard.js +4 -4
  148. package/esm2015/dashboard/lib/dashboard/dashboard.component.js +64 -64
  149. package/esm2015/dashboard/lib/dashboard-header/dashboard-header.component.js +41 -41
  150. package/esm2015/dashboard/lib/dashboard-menu/dashboard-menu.component.js +39 -39
  151. package/esm2015/dashboard/lib/dashboard-menu-item/dashboard-menu-item.component.js +38 -38
  152. package/esm2015/dashboard/lib/dashboard-sidebar/dashboard-sidebar.component.js +83 -83
  153. package/esm2015/dashboard/lib/dashboard-sidebar-group/dashboard-sidebar-group.component.js +110 -110
  154. package/esm2015/dashboard/lib/dashboard-sidebar-item/dashboard-sidebar-item.component.js +71 -71
  155. package/esm2015/dashboard/lib/dashboard.module.js +47 -47
  156. package/esm2015/dashboard/public_api.js +9 -9
  157. package/esm2015/dialog/bravobit-bb-foundation-dialog.js +4 -4
  158. package/esm2015/dialog/lib/dialog-actions/dialog-actions.component.js +20 -20
  159. package/esm2015/dialog/lib/dialog-confirm/dialog-confirm.component.js +45 -45
  160. package/esm2015/dialog/lib/dialog-container/dialog-container.component.js +162 -162
  161. package/esm2015/dialog/lib/dialog-header/dialog-header.component.js +33 -33
  162. package/esm2015/dialog/lib/dialog-link/dialog-link.component.js +19 -19
  163. package/esm2015/dialog/lib/dialog-modal/dialog-modal.component.js +54 -54
  164. package/esm2015/dialog/lib/dialog-overlay/dialog-overlay.component.js +143 -143
  165. package/esm2015/dialog/lib/dialog.injector.js +18 -18
  166. package/esm2015/dialog/lib/dialog.insertion.js +16 -16
  167. package/esm2015/dialog/lib/dialog.interfaces.js +3 -3
  168. package/esm2015/dialog/lib/dialog.module.js +74 -74
  169. package/esm2015/dialog/lib/dialog.ref.js +22 -22
  170. package/esm2015/dialog/lib/dialog.service.js +77 -77
  171. package/esm2015/dialog/public_api.js +10 -10
  172. package/esm2015/elements/bravobit-bb-foundation-elements.js +4 -4
  173. package/esm2015/elements/lib/avatar/avatar.component.js +151 -151
  174. package/esm2015/elements/lib/button/button.component.js +79 -79
  175. package/esm2015/elements/lib/checkbox/checkbox.component.js +83 -83
  176. package/esm2015/elements/lib/date-picker/date-picker.component.js +322 -322
  177. package/esm2015/elements/lib/directives/addon.directive.js +29 -29
  178. package/esm2015/elements/lib/directives/autosize.directive.js +74 -74
  179. package/esm2015/elements/lib/directives/focus-trap.directive.js +77 -77
  180. package/esm2015/elements/lib/directives/focus.directive.js +39 -39
  181. package/esm2015/elements/lib/directives/form-submit.directive.js +53 -53
  182. package/esm2015/elements/lib/directives/input.directive.js +139 -139
  183. package/esm2015/elements/lib/directives/template.directive.js +28 -28
  184. package/esm2015/elements/lib/dropdown/dropdown.component.js +111 -111
  185. package/esm2015/elements/lib/elements.interfaces.js +4 -4
  186. package/esm2015/elements/lib/elements.module.js +177 -177
  187. package/esm2015/elements/lib/file-picker/file-picker.component.js +247 -247
  188. package/esm2015/elements/lib/form-control/form-control.component.js +58 -58
  189. package/esm2015/elements/lib/form-error/form-error.component.js +116 -116
  190. package/esm2015/elements/lib/form-group/form-group.component.js +27 -27
  191. package/esm2015/elements/lib/icon/icon.component.js +110 -110
  192. package/esm2015/elements/lib/image-picker/image-picker.component.js +119 -119
  193. package/esm2015/elements/lib/pipes/file-image.pipe.js +45 -45
  194. package/esm2015/elements/lib/pipes/file-size.pipe.js +28 -28
  195. package/esm2015/elements/lib/pipes/relative-time.pipe.js +96 -96
  196. package/esm2015/elements/lib/spinner/spinner.component.js +34 -34
  197. package/esm2015/elements/lib/tag/tag.component.js +26 -26
  198. package/esm2015/elements/public_api.js +26 -26
  199. package/esm2015/http/bravobit-bb-foundation-http.js +4 -4
  200. package/esm2015/http/lib/classes/http.config.js +31 -31
  201. package/esm2015/http/lib/classes/http.error.js +21 -21
  202. package/esm2015/http/lib/http.interfaces.js +2 -2
  203. package/esm2015/http/lib/http.module.js +43 -43
  204. package/esm2015/http/lib/interceptors/base-url.interceptor.js +52 -52
  205. package/esm2015/http/lib/interceptors/error.interceptor.js +33 -33
  206. package/esm2015/http/public_api.js +7 -7
  207. package/esm2015/lib/core/coercions/boolean-coercion.js +4 -4
  208. package/esm2015/lib/core/miscellaneous/regex.js +5 -5
  209. package/esm2015/lib/core/miscellaneous/validator.js +86 -86
  210. package/esm2015/lib/core/mixins/can-disable.js +16 -16
  211. package/esm2015/lib/core/mixins/can-hide-errors.js +16 -16
  212. package/esm2015/lib/core/mixins/can-load.js +16 -16
  213. package/esm2015/lib/core/mixins/constructor.js +2 -2
  214. package/esm2015/lib/core/mixins/has-error.js +16 -16
  215. package/esm2015/lib/core/mixins/is-focused.js +16 -16
  216. package/esm2015/lib/core/mixins/is-grouped.js +16 -16
  217. package/esm2015/lib/core/mixins/is-readonly.js +16 -16
  218. package/esm2015/lib/core/mixins/is-required.js +16 -16
  219. package/esm2015/lib/core/services/clipboard.service.js +72 -0
  220. package/esm2015/lib/core/services/exif.service.js +168 -168
  221. package/esm2015/lib/core/services/file-loader.service.js +90 -90
  222. package/esm2015/lib/core/services/image-converter.service.js +130 -130
  223. package/esm2015/lib/core/services/languages.service.js +74 -74
  224. package/esm2015/lib/core/services/network.service.js +56 -56
  225. package/esm2015/lib/core/services/patch.service.js +65 -65
  226. package/esm2015/lib/core/services/platform.service.js +42 -42
  227. package/esm2015/lib/core/tokens/accept-language.token.js +3 -3
  228. package/esm2015/lib/core/tokens/base-url.token.js +3 -3
  229. package/esm2015/lib/core/tokens/cookie.token.js +3 -3
  230. package/esm2015/lib/core/tokens/location.token.js +6 -6
  231. package/esm2015/lib/core/tokens/navigator.token.js +6 -6
  232. package/esm2015/lib/core/tokens/window.token.js +12 -12
  233. package/esm2015/localize/bravobit-bb-foundation-localize.js +4 -4
  234. package/esm2015/localize/lib/functions/date.function.js +18 -18
  235. package/esm2015/localize/lib/functions/lowercase.function.js +13 -13
  236. package/esm2015/localize/lib/functions/uppercase.function.js +13 -13
  237. package/esm2015/localize/lib/handlers/missing.handler.js +17 -17
  238. package/esm2015/localize/lib/interfaces/config.interfaces.js +10 -10
  239. package/esm2015/localize/lib/interfaces/dictionary.interfaces.js +8 -8
  240. package/esm2015/localize/lib/interfaces/functions.interfaces.js +8 -8
  241. package/esm2015/localize/lib/interfaces/handlers.interfaces.js +2 -2
  242. package/esm2015/localize/lib/interfaces/options.interfaces.js +6 -6
  243. package/esm2015/localize/lib/localizations/dutch.localization.js +53 -53
  244. package/esm2015/localize/lib/localizations/english.localization.js +53 -53
  245. package/esm2015/localize/lib/localize.dictionary.js +137 -137
  246. package/esm2015/localize/lib/localize.module.js +69 -69
  247. package/esm2015/localize/lib/localize.pipe.js +49 -49
  248. package/esm2015/localize/lib/localize.service.js +282 -282
  249. package/esm2015/localize/lib/views/localize-string/localize-string.component.js +99 -99
  250. package/esm2015/localize/lib/views/localize-template-or-string.directive.js +28 -28
  251. package/esm2015/localize/lib/views/localize-template.directive.js +21 -21
  252. package/esm2015/localize/public_api.js +18 -18
  253. package/esm2015/notifications/bravobit-bb-foundation-notifications.js +4 -4
  254. package/esm2015/notifications/lib/notifications-item/notifications-item.component.js +108 -108
  255. package/esm2015/notifications/lib/notifications-list/notifications-list.component.js +56 -56
  256. package/esm2015/notifications/lib/notifications.animations.js +28 -28
  257. package/esm2015/notifications/lib/notifications.injector.js +18 -18
  258. package/esm2015/notifications/lib/notifications.interfaces.js +20 -20
  259. package/esm2015/notifications/lib/notifications.module.js +31 -31
  260. package/esm2015/notifications/lib/notifications.service.js +145 -145
  261. package/esm2015/notifications/public_api.js +4 -4
  262. package/esm2015/public_api.js +30 -29
  263. package/esm2015/recaptcha/bravobit-bb-foundation-recaptcha.js +4 -4
  264. package/esm2015/recaptcha/lib/recaptcha/recaptcha.component.js +199 -199
  265. package/esm2015/recaptcha/lib/recaptcha-loader.service.js +93 -93
  266. package/esm2015/recaptcha/lib/recaptcha.interface.js +3 -3
  267. package/esm2015/recaptcha/lib/recaptcha.module.js +27 -27
  268. package/esm2015/recaptcha/public_api.js +5 -5
  269. package/esm2015/rxjs/bravobit-bb-foundation-rxjs.js +4 -4
  270. package/esm2015/rxjs/lib/operators/combine-latest-map.operator.js +7 -7
  271. package/esm2015/rxjs/lib/operators/filter-nil.operator.js +5 -5
  272. package/esm2015/rxjs/public_api.js +3 -3
  273. package/esm2015/storage/bravobit-bb-foundation-storage.js +4 -4
  274. package/esm2015/storage/lib/interfaces/attributes.interface.js +2 -2
  275. package/esm2015/storage/lib/interfaces/memory.interface.js +2 -2
  276. package/esm2015/storage/lib/interfaces/strategy.interface.js +2 -2
  277. package/esm2015/storage/lib/storage.service.js +111 -111
  278. package/esm2015/storage/lib/strategies/cookie-storage.strategy.js +143 -143
  279. package/esm2015/storage/lib/strategies/memory-storage.strategy.js +56 -56
  280. package/esm2015/storage/lib/strategies/polyfill-storage.strategy.js +102 -102
  281. package/esm2015/storage/public_api.js +8 -8
  282. package/esm2015/table/bravobit-bb-foundation-table.js +4 -4
  283. package/esm2015/table/lib/components/table/table.component.js +183 -183
  284. package/esm2015/table/lib/components/table-cell/table-cell.component.js +19 -19
  285. package/esm2015/table/lib/components/table-header-cell/table-header-cell.component.js +141 -141
  286. package/esm2015/table/lib/components/table-pager/table-pager.component.js +146 -146
  287. package/esm2015/table/lib/data/datasource.data.js +32 -32
  288. package/esm2015/table/lib/data/generic.data.js +73 -73
  289. package/esm2015/table/lib/interfaces/datasource.interface.js +2 -2
  290. package/esm2015/table/lib/interfaces/table.interfaces.js +2 -2
  291. package/esm2015/table/lib/table.module.js +39 -39
  292. package/esm2015/table/public_api.js +10 -10
  293. package/fesm2015/bravobit-bb-foundation-auth.js +915 -915
  294. package/fesm2015/bravobit-bb-foundation-auth.js.map +1 -1
  295. package/fesm2015/bravobit-bb-foundation-collections.js +447 -0
  296. package/fesm2015/bravobit-bb-foundation-collections.js.map +1 -0
  297. package/fesm2015/bravobit-bb-foundation-dashboard.js +434 -434
  298. package/fesm2015/bravobit-bb-foundation-dashboard.js.map +1 -1
  299. package/fesm2015/bravobit-bb-foundation-dialog.js +603 -603
  300. package/fesm2015/bravobit-bb-foundation-dialog.js.map +1 -1
  301. package/fesm2015/bravobit-bb-foundation-elements.js +2076 -2076
  302. package/fesm2015/bravobit-bb-foundation-elements.js.map +1 -1
  303. package/fesm2015/bravobit-bb-foundation-http.js +154 -154
  304. package/fesm2015/bravobit-bb-foundation-http.js.map +1 -1
  305. package/fesm2015/bravobit-bb-foundation-localize.js +796 -796
  306. package/fesm2015/bravobit-bb-foundation-localize.js.map +1 -1
  307. package/fesm2015/bravobit-bb-foundation-notifications.js +364 -364
  308. package/fesm2015/bravobit-bb-foundation-notifications.js.map +1 -1
  309. package/fesm2015/bravobit-bb-foundation-recaptcha.js +297 -297
  310. package/fesm2015/bravobit-bb-foundation-recaptcha.js.map +1 -1
  311. package/fesm2015/bravobit-bb-foundation-rxjs.js +7 -7
  312. package/fesm2015/bravobit-bb-foundation-rxjs.js.map +1 -1
  313. package/fesm2015/bravobit-bb-foundation-storage.js +399 -399
  314. package/fesm2015/bravobit-bb-foundation-storage.js.map +1 -1
  315. package/fesm2015/bravobit-bb-foundation-table.js +578 -578
  316. package/fesm2015/bravobit-bb-foundation-table.js.map +1 -1
  317. package/fesm2015/bravobit-bb-foundation.js +854 -785
  318. package/fesm2015/bravobit-bb-foundation.js.map +1 -1
  319. package/http/bravobit-bb-foundation-http.d.ts +5 -5
  320. package/http/lib/classes/http.config.d.ts +9 -9
  321. package/http/lib/classes/http.error.d.ts +7 -7
  322. package/http/lib/http.interfaces.d.ts +12 -12
  323. package/http/lib/http.module.d.ts +15 -15
  324. package/http/lib/interceptors/base-url.interceptor.d.ts +15 -15
  325. package/http/lib/interceptors/error.interceptor.d.ts +11 -11
  326. package/http/public_api.d.ts +6 -6
  327. package/lib/core/coercions/boolean-coercion.d.ts +1 -1
  328. package/lib/core/miscellaneous/regex.d.ts +4 -4
  329. package/lib/core/miscellaneous/validator.d.ts +13 -13
  330. package/lib/core/mixins/can-disable.d.ts +6 -6
  331. package/lib/core/mixins/can-hide-errors.d.ts +6 -6
  332. package/lib/core/mixins/can-load.d.ts +6 -6
  333. package/lib/core/mixins/constructor.d.ts +1 -1
  334. package/lib/core/mixins/has-error.d.ts +6 -6
  335. package/lib/core/mixins/is-focused.d.ts +6 -6
  336. package/lib/core/mixins/is-grouped.d.ts +6 -6
  337. package/lib/core/mixins/is-readonly.d.ts +6 -6
  338. package/lib/core/mixins/is-required.d.ts +6 -6
  339. package/lib/core/services/clipboard.service.d.ts +18 -0
  340. package/lib/core/services/exif.service.d.ts +15 -15
  341. package/lib/core/services/file-loader.service.d.ts +13 -13
  342. package/lib/core/services/image-converter.service.d.ts +21 -21
  343. package/lib/core/services/languages.service.d.ts +16 -16
  344. package/lib/core/services/network.service.d.ts +14 -14
  345. package/lib/core/services/patch.service.d.ts +16 -16
  346. package/lib/core/services/platform.service.d.ts +18 -18
  347. package/lib/core/tokens/accept-language.token.d.ts +2 -2
  348. package/lib/core/tokens/base-url.token.d.ts +2 -2
  349. package/lib/core/tokens/cookie.token.d.ts +2 -2
  350. package/lib/core/tokens/location.token.d.ts +2 -2
  351. package/lib/core/tokens/navigator.token.d.ts +2 -2
  352. package/lib/core/tokens/window.token.d.ts +2 -2
  353. package/localize/bravobit-bb-foundation-localize.d.ts +5 -5
  354. package/localize/lib/functions/date.function.d.ts +5 -5
  355. package/localize/lib/functions/lowercase.function.d.ts +5 -5
  356. package/localize/lib/functions/uppercase.function.d.ts +5 -5
  357. package/localize/lib/handlers/missing.handler.d.ts +6 -6
  358. package/localize/lib/interfaces/config.interfaces.d.ts +8 -8
  359. package/localize/lib/interfaces/dictionary.interfaces.d.ts +12 -12
  360. package/localize/lib/interfaces/functions.interfaces.d.ts +9 -9
  361. package/localize/lib/interfaces/handlers.interfaces.d.ts +6 -6
  362. package/localize/lib/interfaces/options.interfaces.d.ts +10 -10
  363. package/localize/lib/localizations/dutch.localization.d.ts +51 -51
  364. package/localize/lib/localizations/english.localization.d.ts +51 -51
  365. package/localize/lib/localize.dictionary.d.ts +24 -24
  366. package/localize/lib/localize.module.d.ts +18 -18
  367. package/localize/lib/localize.pipe.d.ts +12 -12
  368. package/localize/lib/localize.service.d.ts +51 -51
  369. package/localize/lib/views/localize-string/localize-string.component.d.ts +23 -23
  370. package/localize/lib/views/localize-template-or-string.directive.d.ts +10 -10
  371. package/localize/lib/views/localize-template.directive.d.ts +9 -9
  372. package/localize/public_api.d.ts +17 -17
  373. package/notifications/bravobit-bb-foundation-notifications.d.ts +5 -5
  374. package/notifications/lib/notifications-item/notifications-item.component.d.ts +34 -34
  375. package/notifications/lib/notifications-list/notifications-list.component.d.ts +16 -16
  376. package/notifications/lib/notifications.animations.d.ts +1 -1
  377. package/notifications/lib/notifications.injector.d.ts +8 -8
  378. package/notifications/lib/notifications.interfaces.d.ts +49 -49
  379. package/notifications/lib/notifications.module.d.ts +13 -13
  380. package/notifications/lib/notifications.service.d.ts +34 -34
  381. package/notifications/public_api.d.ts +3 -3
  382. package/package.json +5 -5
  383. package/public_api.d.ts +26 -25
  384. package/recaptcha/bravobit-bb-foundation-recaptcha.d.ts +5 -5
  385. package/recaptcha/lib/recaptcha/recaptcha.component.d.ts +47 -47
  386. package/recaptcha/lib/recaptcha-loader.service.d.ts +22 -22
  387. package/recaptcha/lib/recaptcha.interface.d.ts +14 -14
  388. package/recaptcha/lib/recaptcha.module.d.ts +10 -10
  389. package/recaptcha/public_api.d.ts +4 -4
  390. package/rxjs/bravobit-bb-foundation-rxjs.d.ts +5 -5
  391. package/rxjs/lib/operators/combine-latest-map.operator.d.ts +8 -8
  392. package/rxjs/lib/operators/filter-nil.operator.d.ts +1 -1
  393. package/rxjs/public_api.d.ts +2 -2
  394. package/storage/bravobit-bb-foundation-storage.d.ts +5 -5
  395. package/storage/lib/interfaces/attributes.interface.d.ts +13 -13
  396. package/storage/lib/interfaces/memory.interface.d.ts +7 -7
  397. package/storage/lib/interfaces/strategy.interface.d.ts +17 -17
  398. package/storage/lib/storage.service.d.ts +26 -26
  399. package/storage/lib/strategies/cookie-storage.strategy.d.ts +20 -20
  400. package/storage/lib/strategies/memory-storage.strategy.d.ts +11 -11
  401. package/storage/lib/strategies/polyfill-storage.strategy.d.ts +15 -15
  402. package/storage/public_api.d.ts +7 -7
  403. package/table/bravobit-bb-foundation-table.d.ts +5 -5
  404. package/table/lib/components/table/table.component.d.ts +48 -48
  405. package/table/lib/components/table-cell/table-cell.component.d.ts +5 -5
  406. package/table/lib/components/table-header-cell/table-header-cell.component.d.ts +29 -29
  407. package/table/lib/components/table-pager/table-pager.component.d.ts +41 -41
  408. package/table/lib/data/datasource.data.d.ts +14 -14
  409. package/table/lib/data/generic.data.d.ts +23 -23
  410. package/table/lib/interfaces/datasource.interface.d.ts +17 -17
  411. package/table/lib/interfaces/table.interfaces.d.ts +1 -1
  412. package/table/lib/table.module.d.ts +14 -14
  413. package/table/public_api.d.ts +9 -9
@@ -9,384 +9,384 @@ import { LocalizeModule } from '@bravobit/bb-foundation/localize';
9
9
  import { BehaviorSubject } from 'rxjs';
10
10
  import { share } from 'rxjs/operators';
11
11
 
12
- var NotificationType;
13
- (function (NotificationType) {
14
- NotificationType["Success"] = "success";
15
- NotificationType["Error"] = "error";
16
- NotificationType["Warning"] = "warning";
17
- NotificationType["Info"] = "info";
18
- NotificationType["Custom"] = "custom";
19
- })(NotificationType || (NotificationType = {}));
20
- class NotificationsConfig {
21
- }
22
- var NotificationsPosition;
23
- (function (NotificationsPosition) {
24
- NotificationsPosition["TopRight"] = "flex-start|flex-end";
25
- NotificationsPosition["BottomRight"] = "flex-end|flex-end";
26
- NotificationsPosition["TopLeft"] = "flex-start|flex-start";
27
- NotificationsPosition["BottomLeft"] = "flex-end|flex-start";
28
- })(NotificationsPosition || (NotificationsPosition = {}));
29
- class NotificationsData {
12
+ var NotificationType;
13
+ (function (NotificationType) {
14
+ NotificationType["Success"] = "success";
15
+ NotificationType["Error"] = "error";
16
+ NotificationType["Warning"] = "warning";
17
+ NotificationType["Info"] = "info";
18
+ NotificationType["Custom"] = "custom";
19
+ })(NotificationType || (NotificationType = {}));
20
+ class NotificationsConfig {
21
+ }
22
+ var NotificationsPosition;
23
+ (function (NotificationsPosition) {
24
+ NotificationsPosition["TopRight"] = "flex-start|flex-end";
25
+ NotificationsPosition["BottomRight"] = "flex-end|flex-end";
26
+ NotificationsPosition["TopLeft"] = "flex-start|flex-start";
27
+ NotificationsPosition["BottomLeft"] = "flex-end|flex-start";
28
+ })(NotificationsPosition || (NotificationsPosition = {}));
29
+ class NotificationsData {
30
30
  }
31
31
 
32
- const s = '250ms cubic-bezier(0, 0, .2, 1)';
33
- const l = '400ms cubic-bezier(0, 0, .2, 1)';
34
- const notificationAnimation = trigger('notificationListAnimation', [
35
- transition('* => *', [
36
- query(':enter', group([
37
- // 1. Set the initial state.
38
- style({ height: 0, opacity: 0, transform: 'translateX({{ to }}%) scale(0.95)' }),
39
- // 2. Start the animation to show the item.
40
- stagger(0, [
41
- animate(s, style({ height: '*' })),
42
- animate(l, style({ opacity: 1, transform: 'translateX(0) scale(0.95)' })),
43
- animate(s, style({ transform: 'translateX(0) scale(1)' }))
44
- ])
45
- ]), { optional: true }),
46
- query(':leave', group([
47
- // 1. Set the initial state.
48
- style({ height: '*', opacity: 1, transform: 'translateX(0) scale(1)' }),
49
- // 2. Start the animation to hide the item.
50
- stagger(0, [
51
- animate(s, style({ transform: 'translateX(0) scale(0.95)' })),
52
- animate(l, style({ opacity: 0, transform: 'translateX({{ to }}%) scale(0.95)' })),
53
- animate(s, style({ height: 0 }))
54
- ])
55
- ]), { optional: true })
56
- ])
32
+ const s = '250ms cubic-bezier(0, 0, .2, 1)';
33
+ const l = '400ms cubic-bezier(0, 0, .2, 1)';
34
+ const notificationAnimation = trigger('notificationListAnimation', [
35
+ transition('* => *', [
36
+ query(':enter', group([
37
+ // 1. Set the initial state.
38
+ style({ height: 0, opacity: 0, transform: 'translateX({{ to }}%) scale(0.95)' }),
39
+ // 2. Start the animation to show the item.
40
+ stagger(0, [
41
+ animate(s, style({ height: '*' })),
42
+ animate(l, style({ opacity: 1, transform: 'translateX(0) scale(0.95)' })),
43
+ animate(s, style({ transform: 'translateX(0) scale(1)' }))
44
+ ])
45
+ ]), { optional: true }),
46
+ query(':leave', group([
47
+ // 1. Set the initial state.
48
+ style({ height: '*', opacity: 1, transform: 'translateX(0) scale(1)' }),
49
+ // 2. Start the animation to hide the item.
50
+ stagger(0, [
51
+ animate(s, style({ transform: 'translateX(0) scale(0.95)' })),
52
+ animate(l, style({ opacity: 0, transform: 'translateX({{ to }}%) scale(0.95)' })),
53
+ animate(s, style({ height: 0 }))
54
+ ])
55
+ ]), { optional: true })
56
+ ])
57
57
  ]);
58
58
 
59
- class BbNotificationsItem {
60
- constructor(_zone, _platform, _changeDetection) {
61
- this._zone = _zone;
62
- this._platform = _platform;
63
- this._changeDetection = _changeDetection;
64
- // Data.
65
- this._progress = 0;
66
- this._count = 0;
67
- // Data.
68
- this._radius = 19;
69
- this._circumference = this._radius * 2 * Math.PI;
70
- this.callActionAndDestroy = (notification, action) => {
71
- // Perform the callback (if it exists).
72
- action && action.callback && action.callback();
73
- // Call the destroy method (if it exists).
74
- notification && notification.destroy && notification.destroy();
75
- };
76
- this.instance = () => {
77
- // Calculate the difference.
78
- this._difference = (Date.now() - this._startTime) - (this._count * this._speed);
79
- // Add up the count.
80
- if (this._count++ === this._steps) {
81
- this.notification.destroy();
82
- }
83
- // Add the steps to the progress.
84
- this._progress += 100 / this._steps;
85
- // Set a new timer.
86
- this._timer = this.setTimeout(this.instance, this._speed - this._difference);
87
- // Run a new change detection cycle.
88
- this._zone.run(() => this._changeDetection.detectChanges());
89
- };
90
- this.setTimeout = (method, timeout) => {
91
- // Check if the window and method exist.
92
- if (!window || !window.setTimeout) {
93
- return null;
94
- }
95
- return window.setTimeout(method, timeout);
96
- };
97
- }
98
- get getClass() {
99
- return `bb-notifications-item ${this.notification.type}`;
100
- }
101
- get progressStrokeArray() {
102
- const value = Math.floor(this._circumference);
103
- return `${value}, ${value}`;
104
- }
105
- get progressStrokeOffset() {
106
- return Math.floor(this._circumference - this._progress / 100 * this._circumference);
107
- }
108
- get isContentString() {
109
- return typeof this.notification.content === 'string';
110
- }
111
- ngOnInit() {
112
- // Check if the notification timeout is not 0 and the platform is a browser.
113
- if (this.notification.timeout <= 0 || !this._platform.isBrowser) {
114
- this.notification.dismiss = true;
115
- return;
116
- }
117
- // Start the timeout.
118
- this.startTimeout();
119
- }
120
- ngOnDestroy() {
121
- // Clear the timeout if it was set.
122
- this._timer && window && window.clearTimeout && window.clearTimeout(this._timer);
123
- }
124
- startTimeout() {
125
- // Calculate the steps of the timeout.
126
- this._steps = this.notification.timeout / 10;
127
- // Calculate the speed of the timeout.
128
- this._speed = this.notification.timeout / this._steps;
129
- // Get the start time.
130
- this._startTime = Date.now();
131
- // Set a new timer outside of Angular.
132
- this._zone.runOutsideAngular(() => this._timer = this.setTimeout(this.instance, this._speed));
133
- }
134
- }
135
- BbNotificationsItem.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.4", ngImport: i0, type: BbNotificationsItem, deps: [{ token: i0.NgZone }, { token: i1.Platform }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
136
- BbNotificationsItem.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.0.4", type: BbNotificationsItem, selector: "bb-notifications-item", inputs: { notification: "notification", dismissButtonText: "dismissButtonText" }, host: { attributes: { "role": "alert" }, properties: { "class": "this.getClass" } }, viewQueries: [{ propertyName: "progressElementRef", first: true, predicate: ["progress"], descendants: true }], ngImport: i0, template: "<div class=\"notification-content-wrapper\">\r\n <!--\r\n The icon for the notification.\r\n\r\n The icon is reflected by the type of the\r\n notification. Same goes for the color and\r\n background-color.\r\n -->\r\n <div [style.color]=\"notification?.color\"\r\n [style.background-color]=\"notification?.backgroundColor\"\r\n class=\"notification-icon-wrapper\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\"\r\n viewBox=\"0 0 16 19.5\"\r\n class=\"notification-icon\">\r\n <path\r\n d=\"M8 19.5c1.1 0 2-.9 2-2H6c0 1.1.9 2 2 2zM14 13.5v-5c0-3.1-1.6-5.6-4.5-6.3v-.7C9.5.7 8.8 0 8 0S6.5.7 6.5 1.5v.7C3.6 2.9 2 5.4 2 8.5v5l-2 2v1h16v-1l-2-2z\">\r\n </path>\r\n </svg>\r\n\r\n <!--\r\n The circular progress for the notification.\r\n\r\n The progress is only visible when a timeout is\r\n set. The progress adapts to the time remaining\r\n for the notification.\r\n -->\r\n <svg *ngIf=\"notification?.timeout > 0\"\r\n class=\"notification-progress-ring\"\r\n viewBox=\"0 0 40 40\"\r\n role=\"progressbar\">\r\n <circle #progress\r\n [attr.stroke-dasharray]=\"progressStrokeArray\"\r\n [attr.stroke-dashoffset]=\"progressStrokeOffset\"\r\n [style.stroke]=\"notification?.color\"\r\n class=\"notification-progress-circle\"\r\n stroke-width=\"2\"\r\n fill=\"transparent\"\r\n r=\"19\"\r\n cx=\"20\"\r\n cy=\"20\">\r\n </circle>\r\n </svg>\r\n </div>\r\n\r\n <!--\r\n The content for the notification.\r\n\r\n This displays a string or a template based\r\n on the given parameter by the user.\r\n -->\r\n <div class=\"notification-content\">\r\n <ng-container *ngIf=\"isContentString; else templateContent\"\r\n [ngSwitch]=\"notification?.localize\">\r\n <ng-container *ngSwitchCase=\"true\">\r\n {{ $any(notification?.content) | bbLocalize:{data: notification?.data} }}\r\n </ng-container>\r\n <ng-container *ngSwitchDefault>\r\n {{ notification?.content }}\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n</div>\r\n\r\n<!--\r\n The actions of the notification.\r\n\r\n All actions are displayed here and are\r\n based on the actions array the user provided.\r\n-->\r\n<div *ngIf=\"notification?.actions?.length > 0 || notification?.dismiss\"\r\n class=\"notification-actions\">\r\n <button *ngFor=\"let action of notification?.actions\"\r\n (click)=\"callActionAndDestroy(notification, action)\"\r\n type=\"button\"\r\n [class.destructive]=\"action?.type === 'cancel'\"\r\n class=\"notification-actions-button\">\r\n <span [ngSwitch]=\"notification?.localize\"\r\n class=\"notification-actions-button-highlight\">\r\n <ng-container *ngSwitchCase=\"true\">\r\n {{ action?.title | bbLocalize:{data: notification?.data} }}\r\n </ng-container>\r\n <ng-container *ngSwitchDefault>\r\n {{ action?.title }}\r\n </ng-container>\r\n </span>\r\n </button>\r\n <button *ngIf=\"notification?.dismiss\"\r\n (click)=\"notification?.destroy()\"\r\n class=\"notification-actions-button destructive\"\r\n type=\"button\">\r\n <span class=\"notification-actions-button-highlight\">\r\n {{ notification?.dismissText || dismissButtonText }}\r\n </span>\r\n </button>\r\n</div>\r\n\r\n<!--\r\n The outlet for the notification content template ref.\r\n-->\r\n<ng-template #templateContent>\r\n <ng-container *ngTemplateOutlet=\"$any(notification?.content)\"></ng-container>\r\n</ng-template>\r\n", styles: [".bb-notifications-item{display:flex;border-radius:4px;flex-direction:column;background-color:#fff;border:1px solid #d6dbe0}.bb-notifications-item.success .notification-icon-wrapper{color:#2dc05d;background-color:#ebfaf0}.bb-notifications-item.success .notification-progress-circle{stroke:#36d068}.bb-notifications-item.error .notification-icon-wrapper{color:#f43e3e;background-color:#feeeee}.bb-notifications-item.error .notification-progress-circle{stroke:#f55656}.bb-notifications-item.warning .notification-icon-wrapper{color:#f1ae00;background-color:#fff8e7}.bb-notifications-item.warning .notification-progress-circle{stroke:#ffbc0b}.bb-notifications-item.info .notification-icon-wrapper{color:#099bf6;background-color:#e9f6fe}.bb-notifications-item.info .notification-progress-circle{stroke:#22a5f7}.bb-notifications-item.custom .notification-icon-wrapper{color:#657385;background-color:#f3f5f6}.bb-notifications-item.custom .notification-progress-circle{stroke:#657385}.notification-content-wrapper{padding:20px;display:flex;align-items:center}.notification-icon-wrapper{width:40px;height:40px;display:flex;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;position:relative;border-radius:50%;align-items:center;justify-content:center;color:#657385;background-color:#f3f5f6}.notification-icon{width:100%;height:100%;padding:10px;fill:currentColor}.notification-content{flex:1;font-size:14px;line-height:1.5;font-weight:500;margin-left:20px;color:rgba(0,0,0,.85)}.notification-content i{font-style:italic}.notification-actions-button,.notification-content{font-family:inherit}.notification-actions{display:flex;margin:0 20px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;border-top:1px solid #f3f5f6}.notification-actions-button{flex:1;border:none;color:#22a5f7;cursor:pointer;font-size:14px;font-weight:500;padding:12px 2px;text-align:center;background-color:transparent}.notification-actions-button:focus>.notification-actions-button-highlight,.notification-actions-button:hover>.notification-actions-button-highlight{background-color:rgba(34,165,247,.1)}.notification-actions-button:active>.notification-actions-button-highlight{background-color:rgba(34,165,247,.2)}.notification-actions-button.destructive{color:#f55656}.notification-actions-button.destructive:focus>.notification-actions-button-highlight,.notification-actions-button.destructive:hover>.notification-actions-button-highlight{background-color:rgba(245,86,86,.1)}.notification-actions-button.destructive:active>.notification-actions-button-highlight{background-color:rgba(245,86,86,.2)}.notification-actions-button-highlight{padding:4px 12px;border-radius:12px;display:inline-flex;transition:background-color .15s cubic-bezier(0,0,.2,1)}.notification-progress-ring{top:0;left:0;right:0;bottom:0;width:100%;height:100%;position:absolute}.notification-progress-circle{transform:rotate(-90deg);transform-origin:50% 50%;stroke:#657385}"], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i2.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "bbLocalize": i2$1.BbLocalize }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
137
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.4", ngImport: i0, type: BbNotificationsItem, decorators: [{
138
- type: Component,
139
- args: [{
140
- selector: 'bb-notifications-item',
141
- templateUrl: './notifications-item.component.html',
142
- styleUrls: ['./notifications-item.component.scss'],
143
- changeDetection: ChangeDetectionStrategy.OnPush,
144
- encapsulation: ViewEncapsulation.None,
145
- preserveWhitespaces: false,
146
- host: {
147
- 'role': 'alert'
148
- }
149
- }]
150
- }], ctorParameters: function () { return [{ type: i0.NgZone }, { type: i1.Platform }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { notification: [{
151
- type: Input
152
- }], dismissButtonText: [{
153
- type: Input
154
- }], progressElementRef: [{
155
- type: ViewChild,
156
- args: ['progress']
157
- }], getClass: [{
158
- type: HostBinding,
159
- args: ['class']
59
+ class BbNotificationsItem {
60
+ constructor(_zone, _platform, _changeDetection) {
61
+ this._zone = _zone;
62
+ this._platform = _platform;
63
+ this._changeDetection = _changeDetection;
64
+ // Data.
65
+ this._progress = 0;
66
+ this._count = 0;
67
+ // Data.
68
+ this._radius = 19;
69
+ this._circumference = this._radius * 2 * Math.PI;
70
+ this.callActionAndDestroy = (notification, action) => {
71
+ // Perform the callback (if it exists).
72
+ action && action.callback && action.callback();
73
+ // Call the destroy method (if it exists).
74
+ notification && notification.destroy && notification.destroy();
75
+ };
76
+ this.instance = () => {
77
+ // Calculate the difference.
78
+ this._difference = (Date.now() - this._startTime) - (this._count * this._speed);
79
+ // Add up the count.
80
+ if (this._count++ === this._steps) {
81
+ this.notification.destroy();
82
+ }
83
+ // Add the steps to the progress.
84
+ this._progress += 100 / this._steps;
85
+ // Set a new timer.
86
+ this._timer = this.setTimeout(this.instance, this._speed - this._difference);
87
+ // Run a new change detection cycle.
88
+ this._zone.run(() => this._changeDetection.detectChanges());
89
+ };
90
+ this.setTimeout = (method, timeout) => {
91
+ // Check if the window and method exist.
92
+ if (!window || !window.setTimeout) {
93
+ return null;
94
+ }
95
+ return window.setTimeout(method, timeout);
96
+ };
97
+ }
98
+ get getClass() {
99
+ return `bb-notifications-item ${this.notification.type}`;
100
+ }
101
+ get progressStrokeArray() {
102
+ const value = Math.floor(this._circumference);
103
+ return `${value}, ${value}`;
104
+ }
105
+ get progressStrokeOffset() {
106
+ return Math.floor(this._circumference - this._progress / 100 * this._circumference);
107
+ }
108
+ get isContentString() {
109
+ return typeof this.notification.content === 'string';
110
+ }
111
+ ngOnInit() {
112
+ // Check if the notification timeout is not 0 and the platform is a browser.
113
+ if (this.notification.timeout <= 0 || !this._platform.isBrowser) {
114
+ this.notification.dismiss = true;
115
+ return;
116
+ }
117
+ // Start the timeout.
118
+ this.startTimeout();
119
+ }
120
+ ngOnDestroy() {
121
+ // Clear the timeout if it was set.
122
+ this._timer && window && window.clearTimeout && window.clearTimeout(this._timer);
123
+ }
124
+ startTimeout() {
125
+ // Calculate the steps of the timeout.
126
+ this._steps = this.notification.timeout / 10;
127
+ // Calculate the speed of the timeout.
128
+ this._speed = this.notification.timeout / this._steps;
129
+ // Get the start time.
130
+ this._startTime = Date.now();
131
+ // Set a new timer outside of Angular.
132
+ this._zone.runOutsideAngular(() => this._timer = this.setTimeout(this.instance, this._speed));
133
+ }
134
+ }
135
+ BbNotificationsItem.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.10", ngImport: i0, type: BbNotificationsItem, deps: [{ token: i0.NgZone }, { token: i1.Platform }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
136
+ BbNotificationsItem.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.10", type: BbNotificationsItem, selector: "bb-notifications-item", inputs: { notification: "notification", dismissButtonText: "dismissButtonText" }, host: { attributes: { "role": "alert" }, properties: { "class": "this.getClass" } }, viewQueries: [{ propertyName: "progressElementRef", first: true, predicate: ["progress"], descendants: true }], ngImport: i0, template: "<div class=\"notification-content-wrapper\">\n <!--\n The icon for the notification.\n\n The icon is reflected by the type of the\n notification. Same goes for the color and\n background-color.\n -->\n <div [style.color]=\"notification?.color\"\n [style.background-color]=\"notification?.backgroundColor\"\n class=\"notification-icon-wrapper\">\n <svg xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 16 19.5\"\n class=\"notification-icon\">\n <path\n d=\"M8 19.5c1.1 0 2-.9 2-2H6c0 1.1.9 2 2 2zM14 13.5v-5c0-3.1-1.6-5.6-4.5-6.3v-.7C9.5.7 8.8 0 8 0S6.5.7 6.5 1.5v.7C3.6 2.9 2 5.4 2 8.5v5l-2 2v1h16v-1l-2-2z\">\n </path>\n </svg>\n\n <!--\n The circular progress for the notification.\n\n The progress is only visible when a timeout is\n set. The progress adapts to the time remaining\n for the notification.\n -->\n <svg *ngIf=\"notification?.timeout > 0\"\n class=\"notification-progress-ring\"\n viewBox=\"0 0 40 40\"\n role=\"progressbar\">\n <circle #progress\n [attr.stroke-dasharray]=\"progressStrokeArray\"\n [attr.stroke-dashoffset]=\"progressStrokeOffset\"\n [style.stroke]=\"notification?.color\"\n class=\"notification-progress-circle\"\n stroke-width=\"2\"\n fill=\"transparent\"\n r=\"19\"\n cx=\"20\"\n cy=\"20\">\n </circle>\n </svg>\n </div>\n\n <!--\n The content for the notification.\n\n This displays a string or a template based\n on the given parameter by the user.\n -->\n <div class=\"notification-content\">\n <ng-container *ngIf=\"isContentString; else templateContent\"\n [ngSwitch]=\"notification?.localize\">\n <ng-container *ngSwitchCase=\"true\">\n {{ $any(notification?.content) | bbLocalize:{data: notification?.data} }}\n </ng-container>\n <ng-container *ngSwitchDefault>\n {{ notification?.content }}\n </ng-container>\n </ng-container>\n </div>\n</div>\n\n<!--\n The actions of the notification.\n\n All actions are displayed here and are\n based on the actions array the user provided.\n-->\n<div *ngIf=\"notification?.actions?.length > 0 || notification?.dismiss\"\n class=\"notification-actions\">\n <button *ngFor=\"let action of notification?.actions\"\n (click)=\"callActionAndDestroy(notification, action)\"\n type=\"button\"\n [class.destructive]=\"action?.type === 'cancel'\"\n class=\"notification-actions-button\">\n <span [ngSwitch]=\"notification?.localize\"\n class=\"notification-actions-button-highlight\">\n <ng-container *ngSwitchCase=\"true\">\n {{ action?.title | bbLocalize:{data: notification?.data} }}\n </ng-container>\n <ng-container *ngSwitchDefault>\n {{ action?.title }}\n </ng-container>\n </span>\n </button>\n <button *ngIf=\"notification?.dismiss\"\n (click)=\"notification?.destroy()\"\n class=\"notification-actions-button destructive\"\n type=\"button\">\n <span class=\"notification-actions-button-highlight\">\n {{ notification?.dismissText || dismissButtonText }}\n </span>\n </button>\n</div>\n\n<!--\n The outlet for the notification content template ref.\n-->\n<ng-template #templateContent>\n <ng-container *ngTemplateOutlet=\"$any(notification?.content)\"></ng-container>\n</ng-template>\n", styles: [".bb-notifications-item{display:flex;border-radius:4px;flex-direction:column;background-color:#fff;border:1px solid #d6dbe0}.bb-notifications-item.success .notification-icon-wrapper{color:#2dc05d;background-color:#ebfaf0}.bb-notifications-item.success .notification-progress-circle{stroke:#36d068}.bb-notifications-item.error .notification-icon-wrapper{color:#f43e3e;background-color:#feeeee}.bb-notifications-item.error .notification-progress-circle{stroke:#f55656}.bb-notifications-item.warning .notification-icon-wrapper{color:#f1ae00;background-color:#fff8e7}.bb-notifications-item.warning .notification-progress-circle{stroke:#ffbc0b}.bb-notifications-item.info .notification-icon-wrapper{color:#099bf6;background-color:#e9f6fe}.bb-notifications-item.info .notification-progress-circle{stroke:#22a5f7}.bb-notifications-item.custom .notification-icon-wrapper{color:#657385;background-color:#f3f5f6}.bb-notifications-item.custom .notification-progress-circle{stroke:#657385}.notification-content-wrapper{padding:20px;display:flex;align-items:center}.notification-icon-wrapper{width:40px;height:40px;display:flex;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;position:relative;border-radius:50%;align-items:center;justify-content:center;color:#657385;background-color:#f3f5f6}.notification-icon{width:100%;height:100%;padding:10px;fill:currentColor}.notification-content{flex:1;font-size:14px;line-height:1.5;font-weight:500;margin-left:20px;color:#000000d9}.notification-content i{font-style:italic}.notification-content,.notification-actions-button{font-family:inherit}.notification-actions{display:flex;margin:0 20px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;border-top:1px solid #f3f5f6}.notification-actions-button{flex:1;border:none;color:#22a5f7;cursor:pointer;font-size:14px;font-weight:500;padding:12px 2px;text-align:center;background-color:transparent}.notification-actions-button:hover>.notification-actions-button-highlight,.notification-actions-button:focus>.notification-actions-button-highlight{background-color:#22a5f71a}.notification-actions-button:active>.notification-actions-button-highlight{background-color:#22a5f733}.notification-actions-button.destructive{color:#f55656}.notification-actions-button.destructive:hover>.notification-actions-button-highlight,.notification-actions-button.destructive:focus>.notification-actions-button-highlight{background-color:#f556561a}.notification-actions-button.destructive:active>.notification-actions-button-highlight{background-color:#f5565633}.notification-actions-button-highlight{padding:4px 12px;border-radius:12px;display:inline-flex;transition:background-color .15s cubic-bezier(0,0,.2,1)}.notification-progress-ring{top:0;left:0;right:0;bottom:0;width:100%;height:100%;position:absolute}.notification-progress-circle{transform:rotate(-90deg);transform-origin:50% 50%;stroke:#657385}\n"], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i2.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "bbLocalize": i2$1.BbLocalize }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
137
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.10", ngImport: i0, type: BbNotificationsItem, decorators: [{
138
+ type: Component,
139
+ args: [{
140
+ selector: 'bb-notifications-item',
141
+ templateUrl: './notifications-item.component.html',
142
+ styleUrls: ['./notifications-item.component.scss'],
143
+ changeDetection: ChangeDetectionStrategy.OnPush,
144
+ encapsulation: ViewEncapsulation.None,
145
+ preserveWhitespaces: false,
146
+ host: {
147
+ 'role': 'alert'
148
+ }
149
+ }]
150
+ }], ctorParameters: function () { return [{ type: i0.NgZone }, { type: i1.Platform }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { notification: [{
151
+ type: Input
152
+ }], dismissButtonText: [{
153
+ type: Input
154
+ }], progressElementRef: [{
155
+ type: ViewChild,
156
+ args: ['progress']
157
+ }], getClass: [{
158
+ type: HostBinding,
159
+ args: ['class']
160
160
  }] } });
161
161
 
162
- class BbNotificationsList {
163
- constructor(data) {
164
- this.data = data;
165
- // Data.
166
- this.position = null;
167
- // Track by function.
168
- this.trackByFn = (_, item) => item.id;
169
- }
170
- get horizontalPosition() {
171
- return this.location.horizontal;
172
- }
173
- get verticalPosition() {
174
- return this.location.vertical;
175
- }
176
- get animation() {
177
- const to = this.horizontalPosition === 'flex-start'
178
- ? -50
179
- : 50;
180
- return { to };
181
- }
182
- get location() {
183
- const [y, x] = (this.data.position || '').split('|');
184
- return { vertical: y || null, horizontal: x || null };
185
- }
186
- }
187
- BbNotificationsList.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.4", ngImport: i0, type: BbNotificationsList, deps: [{ token: NotificationsData }], target: i0.ɵɵFactoryTarget.Component });
188
- BbNotificationsList.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.0.4", type: BbNotificationsList, selector: "bb-notifications-list", host: { attributes: { "role": "list" }, properties: { "style.justify-content": "this.horizontalPosition", "style.align-items": "this.verticalPosition" }, classAttribute: "bb-notifications-list" }, ngImport: i0, template: "<!--\r\n The notifications list.\r\n\r\n The list provides the animation effect for the\r\n incoming notifications.\r\n-->\r\n<div *ngIf=\"data?.data | async as notifications\"\r\n [@notificationListAnimation]=\"{value: notifications?.length, params: animation}\"\r\n class=\"notifications-list-wrapper\">\r\n <!--\r\n The loop for the notifications.\r\n\r\n All notifications will be displayed here. They\r\n are wrapped within a wrapper which separates them.\r\n -->\r\n <div *ngFor=\"let notification of notifications; trackBy: trackByFn\"\r\n class=\"notifications-item-wrapper\">\r\n <bb-notifications-item [notification]=\"notification\"\r\n [dismissButtonText]=\"data?.dismissText\">\r\n </bb-notifications-item>\r\n </div>\r\n</div>\r\n", styles: [".bb-notifications-list{top:0;left:0;right:0;bottom:0;z-index:1100;padding:10px;display:flex;position:fixed;pointer-events:none}.notifications-list-wrapper{width:100%;display:block;max-width:400px;position:relative}.notifications-item-wrapper{padding:0;margin:0 0 10px;pointer-events:all}"], components: [{ type: BbNotificationsItem, selector: "bb-notifications-item", inputs: ["notification", "dismissButtonText"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "async": i2.AsyncPipe }, animations: [notificationAnimation], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
189
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.4", ngImport: i0, type: BbNotificationsList, decorators: [{
190
- type: Component,
191
- args: [{
192
- selector: 'bb-notifications-list',
193
- templateUrl: './notifications-list.component.html',
194
- styleUrls: ['./notifications-list.component.scss'],
195
- animations: [notificationAnimation],
196
- changeDetection: ChangeDetectionStrategy.OnPush,
197
- encapsulation: ViewEncapsulation.None,
198
- preserveWhitespaces: false,
199
- host: {
200
- 'class': 'bb-notifications-list',
201
- 'role': 'list'
202
- }
203
- }]
204
- }], ctorParameters: function () { return [{ type: NotificationsData }]; }, propDecorators: { horizontalPosition: [{
205
- type: HostBinding,
206
- args: ['style.justify-content']
207
- }], verticalPosition: [{
208
- type: HostBinding,
209
- args: ['style.align-items']
162
+ class BbNotificationsList {
163
+ constructor(data) {
164
+ this.data = data;
165
+ // Data.
166
+ this.position = null;
167
+ // Track by function.
168
+ this.trackByFn = (_, item) => item.id;
169
+ }
170
+ get horizontalPosition() {
171
+ return this.location.horizontal;
172
+ }
173
+ get verticalPosition() {
174
+ return this.location.vertical;
175
+ }
176
+ get animation() {
177
+ const to = this.horizontalPosition === 'flex-start'
178
+ ? -50
179
+ : 50;
180
+ return { to };
181
+ }
182
+ get location() {
183
+ const [y, x] = (this.data.position || '').split('|');
184
+ return { vertical: y || null, horizontal: x || null };
185
+ }
186
+ }
187
+ BbNotificationsList.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.10", ngImport: i0, type: BbNotificationsList, deps: [{ token: NotificationsData }], target: i0.ɵɵFactoryTarget.Component });
188
+ BbNotificationsList.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.10", type: BbNotificationsList, selector: "bb-notifications-list", host: { attributes: { "role": "list" }, properties: { "style.justify-content": "this.horizontalPosition", "style.align-items": "this.verticalPosition" }, classAttribute: "bb-notifications-list" }, ngImport: i0, template: "<!--\n The notifications list.\n\n The list provides the animation effect for the\n incoming notifications.\n-->\n<div *ngIf=\"data?.data | async as notifications\"\n [@notificationListAnimation]=\"{value: notifications?.length, params: animation}\"\n class=\"notifications-list-wrapper\">\n <!--\n The loop for the notifications.\n\n All notifications will be displayed here. They\n are wrapped within a wrapper which separates them.\n -->\n <div *ngFor=\"let notification of notifications; trackBy: trackByFn\"\n class=\"notifications-item-wrapper\">\n <bb-notifications-item [notification]=\"notification\"\n [dismissButtonText]=\"data?.dismissText\">\n </bb-notifications-item>\n </div>\n</div>\n", styles: [".bb-notifications-list{top:0;left:0;right:0;bottom:0;z-index:1100;padding:10px;display:flex;position:fixed;pointer-events:none}.notifications-list-wrapper{width:100%;display:block;max-width:400px;position:relative}.notifications-item-wrapper{padding:0;margin:0 0 10px;pointer-events:all}\n"], components: [{ type: BbNotificationsItem, selector: "bb-notifications-item", inputs: ["notification", "dismissButtonText"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "async": i2.AsyncPipe }, animations: [notificationAnimation], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
189
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.10", ngImport: i0, type: BbNotificationsList, decorators: [{
190
+ type: Component,
191
+ args: [{
192
+ selector: 'bb-notifications-list',
193
+ templateUrl: './notifications-list.component.html',
194
+ styleUrls: ['./notifications-list.component.scss'],
195
+ animations: [notificationAnimation],
196
+ changeDetection: ChangeDetectionStrategy.OnPush,
197
+ encapsulation: ViewEncapsulation.None,
198
+ preserveWhitespaces: false,
199
+ host: {
200
+ 'class': 'bb-notifications-list',
201
+ 'role': 'list'
202
+ }
203
+ }]
204
+ }], ctorParameters: function () { return [{ type: NotificationsData }]; }, propDecorators: { horizontalPosition: [{
205
+ type: HostBinding,
206
+ args: ['style.justify-content']
207
+ }], verticalPosition: [{
208
+ type: HostBinding,
209
+ args: ['style.align-items']
210
210
  }] } });
211
211
 
212
- class NotificationsInjector {
213
- constructor(_parentInjector, _additionalTokens) {
214
- this._parentInjector = _parentInjector;
215
- this._additionalTokens = _additionalTokens;
216
- }
217
- get(token, notFoundValue) {
218
- // First check if the additional token
219
- // contains the token.
220
- const value = this._additionalTokens.get(token);
221
- // If that value exists return it.
222
- if (value) {
223
- return value;
224
- }
225
- // Else query the parent injector.
226
- return this._parentInjector.get(token, notFoundValue);
227
- }
212
+ class NotificationsInjector {
213
+ constructor(_parentInjector, _additionalTokens) {
214
+ this._parentInjector = _parentInjector;
215
+ this._additionalTokens = _additionalTokens;
216
+ }
217
+ get(token, notFoundValue) {
218
+ // First check if the additional token
219
+ // contains the token.
220
+ const value = this._additionalTokens.get(token);
221
+ // If that value exists return it.
222
+ if (value) {
223
+ return value;
224
+ }
225
+ // Else query the parent injector.
226
+ return this._parentInjector.get(token, notFoundValue);
227
+ }
228
228
  }
229
229
 
230
- class Notifications {
231
- constructor(_injector, _platform, _applicationRef, _localize, _config, _componentFactoryResolver) {
232
- this._injector = _injector;
233
- this._platform = _platform;
234
- this._applicationRef = _applicationRef;
235
- this._localize = _localize;
236
- this._config = _config;
237
- this._componentFactoryResolver = _componentFactoryResolver;
238
- // The data containing the notifications.
239
- this._notifications$ = new BehaviorSubject([]);
240
- this.getProperty = (property, defaultValue) => {
241
- return typeof property === 'undefined'
242
- ? defaultValue
243
- : property;
244
- };
245
- // Get the config.
246
- const config = this._config || {};
247
- // Set the config.
248
- this._defaultMode = this.getProperty(config.mode, 'prepend');
249
- this._defaultTimeout = this.getProperty(config.timeout, 8000);
250
- this._defaultLocalize = this.getProperty(config.localize, false);
251
- this._defaultDismiss = this.getProperty(config.dismiss, true);
252
- this._defaultDismissText = this.getProperty(config.dismissText, 'Dismiss');
253
- this._defaultPosition = this.getProperty(config.position, NotificationsPosition.TopRight);
254
- // Create the element that holds all notifications.
255
- this.createElement();
256
- }
257
- success(content, actions = [], timeout = this._defaultTimeout) {
258
- return this.create({ content, timeout, actions, type: NotificationType.Success });
259
- }
260
- error(content, actions = [], timeout = this._defaultTimeout) {
261
- return this.create({ content, timeout, actions, type: NotificationType.Error });
262
- }
263
- warn(content, actions = [], timeout = this._defaultTimeout) {
264
- return this.create({ content, timeout, actions, type: NotificationType.Warning });
265
- }
266
- info(content, actions = [], timeout = this._defaultTimeout) {
267
- return this.create({ content, timeout, actions, type: NotificationType.Info });
268
- }
269
- create(notification) {
270
- // Compose a new notification item.
271
- const item = this.compose(notification);
272
- // Add the destroy function to the notification.
273
- item.destroy = () => this.pull(item);
274
- // Add the notification to the list
275
- // and return the item.
276
- return this.push(item);
277
- }
278
- push(notification) {
279
- // Get the current list.
280
- const oldList = this._notifications$.getValue();
281
- // Check which mode is activated.
282
- let newList;
283
- switch (this._defaultMode) {
284
- case 'append':
285
- newList = [...oldList, notification];
286
- break;
287
- case 'prepend':
288
- default:
289
- newList = [notification, ...oldList];
290
- }
291
- // Push the new notifications.
292
- this._notifications$.next(newList);
293
- // Return the notification for further use.
294
- return notification;
295
- }
296
- pull(notification) {
297
- // Get the current list.
298
- const newList = this._notifications$
299
- .getValue()
300
- .filter(item => item.id !== notification.id);
301
- // Push a new list.
302
- this._notifications$.next(newList);
303
- }
304
- compose(notification) {
305
- // Attach a random id to the notification.
306
- notification.id = Math.random().toString(36).substr(2, 10);
307
- // Set all properties.
308
- notification.type = this.getProperty(notification.type, NotificationType.Custom);
309
- notification.content = this.getProperty(notification.content, null);
310
- notification.data = this.getProperty(notification.data, {});
311
- notification.timeout = this.getProperty(notification.timeout, this._defaultTimeout);
312
- notification.localize = this.getProperty(notification.localize, this._defaultLocalize);
313
- notification.dismiss = this.getProperty(notification.dismiss, this._defaultDismiss);
314
- // Dismiss text localization.
315
- const dismissText = this.getProperty(notification.dismissText, this._defaultDismissText);
316
- notification.dismissText = this._defaultLocalize && this._localize
317
- ? this._localize.translate(dismissText)
318
- : dismissText;
319
- // Return the composed notification.
320
- return notification;
321
- }
322
- createElement() {
323
- // Create a map with the config.
324
- const map = new WeakMap();
325
- map.set(NotificationsData, {
326
- data: this._notifications$.pipe(share()),
327
- dismissText: this._defaultDismissText,
328
- position: this._defaultPosition
329
- });
330
- // Create a custom injector.
331
- const notificationsInjector = new NotificationsInjector(this._injector, map);
332
- // Create the notification list and
333
- // get a reference to the component.
334
- this._ref = this._componentFactoryResolver
335
- .resolveComponentFactory(BbNotificationsList)
336
- .create(notificationsInjector);
337
- // Detect the changes.
338
- this._ref.changeDetectorRef.detectChanges();
339
- // Attach the component's view to the application
340
- // so that the change detection will run properly.
341
- this._applicationRef.attachView(this._ref.hostView);
342
- // If the platform is not a browser return.
343
- if (!this._platform.isBrowser) {
344
- return;
345
- }
346
- try {
347
- // Append the element to the DOM.
348
- document.body.appendChild(this._ref.location.nativeElement);
349
- }
350
- catch (_a) {
351
- // Don't do anything, because it must've failed.
352
- }
353
- }
354
- }
355
- Notifications.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.4", ngImport: i0, type: Notifications, deps: [{ token: i0.Injector }, { token: i1.Platform }, { token: i0.ApplicationRef }, { token: i2$1.Localize, optional: true }, { token: NotificationsConfig, optional: true }, { token: i0.ComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.Injectable });
356
- Notifications.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.4", ngImport: i0, type: Notifications });
357
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.4", ngImport: i0, type: Notifications, decorators: [{
358
- type: Injectable
359
- }], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.Platform }, { type: i0.ApplicationRef }, { type: i2$1.Localize, decorators: [{
360
- type: Optional
361
- }] }, { type: NotificationsConfig, decorators: [{
362
- type: Optional
230
+ class Notifications {
231
+ constructor(_injector, _platform, _applicationRef, _localize, _config, _componentFactoryResolver) {
232
+ this._injector = _injector;
233
+ this._platform = _platform;
234
+ this._applicationRef = _applicationRef;
235
+ this._localize = _localize;
236
+ this._config = _config;
237
+ this._componentFactoryResolver = _componentFactoryResolver;
238
+ // The data containing the notifications.
239
+ this._notifications$ = new BehaviorSubject([]);
240
+ this.getProperty = (property, defaultValue) => {
241
+ return typeof property === 'undefined'
242
+ ? defaultValue
243
+ : property;
244
+ };
245
+ // Get the config.
246
+ const config = this._config || {};
247
+ // Set the config.
248
+ this._defaultMode = this.getProperty(config.mode, 'prepend');
249
+ this._defaultTimeout = this.getProperty(config.timeout, 8000);
250
+ this._defaultLocalize = this.getProperty(config.localize, false);
251
+ this._defaultDismiss = this.getProperty(config.dismiss, true);
252
+ this._defaultDismissText = this.getProperty(config.dismissText, 'Dismiss');
253
+ this._defaultPosition = this.getProperty(config.position, NotificationsPosition.TopRight);
254
+ // Create the element that holds all notifications.
255
+ this.createElement();
256
+ }
257
+ success(content, actions = [], timeout = this._defaultTimeout) {
258
+ return this.create({ content, timeout, actions, type: NotificationType.Success });
259
+ }
260
+ error(content, actions = [], timeout = this._defaultTimeout) {
261
+ return this.create({ content, timeout, actions, type: NotificationType.Error });
262
+ }
263
+ warn(content, actions = [], timeout = this._defaultTimeout) {
264
+ return this.create({ content, timeout, actions, type: NotificationType.Warning });
265
+ }
266
+ info(content, actions = [], timeout = this._defaultTimeout) {
267
+ return this.create({ content, timeout, actions, type: NotificationType.Info });
268
+ }
269
+ create(notification) {
270
+ // Compose a new notification item.
271
+ const item = this.compose(notification);
272
+ // Add the destroy function to the notification.
273
+ item.destroy = () => this.pull(item);
274
+ // Add the notification to the list
275
+ // and return the item.
276
+ return this.push(item);
277
+ }
278
+ push(notification) {
279
+ // Get the current list.
280
+ const oldList = this._notifications$.getValue();
281
+ // Check which mode is activated.
282
+ let newList;
283
+ switch (this._defaultMode) {
284
+ case 'append':
285
+ newList = [...oldList, notification];
286
+ break;
287
+ case 'prepend':
288
+ default:
289
+ newList = [notification, ...oldList];
290
+ }
291
+ // Push the new notifications.
292
+ this._notifications$.next(newList);
293
+ // Return the notification for further use.
294
+ return notification;
295
+ }
296
+ pull(notification) {
297
+ // Get the current list.
298
+ const newList = this._notifications$
299
+ .getValue()
300
+ .filter(item => item.id !== notification.id);
301
+ // Push a new list.
302
+ this._notifications$.next(newList);
303
+ }
304
+ compose(notification) {
305
+ // Attach a random id to the notification.
306
+ notification.id = Math.random().toString(36).substr(2, 10);
307
+ // Set all properties.
308
+ notification.type = this.getProperty(notification.type, NotificationType.Custom);
309
+ notification.content = this.getProperty(notification.content, null);
310
+ notification.data = this.getProperty(notification.data, {});
311
+ notification.timeout = this.getProperty(notification.timeout, this._defaultTimeout);
312
+ notification.localize = this.getProperty(notification.localize, this._defaultLocalize);
313
+ notification.dismiss = this.getProperty(notification.dismiss, this._defaultDismiss);
314
+ // Dismiss text localization.
315
+ const dismissText = this.getProperty(notification.dismissText, this._defaultDismissText);
316
+ notification.dismissText = this._defaultLocalize && this._localize
317
+ ? this._localize.translate(dismissText)
318
+ : dismissText;
319
+ // Return the composed notification.
320
+ return notification;
321
+ }
322
+ createElement() {
323
+ // Create a map with the config.
324
+ const map = new WeakMap();
325
+ map.set(NotificationsData, {
326
+ data: this._notifications$.pipe(share()),
327
+ dismissText: this._defaultDismissText,
328
+ position: this._defaultPosition
329
+ });
330
+ // Create a custom injector.
331
+ const notificationsInjector = new NotificationsInjector(this._injector, map);
332
+ // Create the notification list and
333
+ // get a reference to the component.
334
+ this._ref = this._componentFactoryResolver
335
+ .resolveComponentFactory(BbNotificationsList)
336
+ .create(notificationsInjector);
337
+ // Detect the changes.
338
+ this._ref.changeDetectorRef.detectChanges();
339
+ // Attach the component's view to the application
340
+ // so that the change detection will run properly.
341
+ this._applicationRef.attachView(this._ref.hostView);
342
+ // If the platform is not a browser return.
343
+ if (!this._platform.isBrowser) {
344
+ return;
345
+ }
346
+ try {
347
+ // Append the element to the DOM.
348
+ document.body.appendChild(this._ref.location.nativeElement);
349
+ }
350
+ catch (_a) {
351
+ // Don't do anything, because it must've failed.
352
+ }
353
+ }
354
+ }
355
+ Notifications.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.10", ngImport: i0, type: Notifications, deps: [{ token: i0.Injector }, { token: i1.Platform }, { token: i0.ApplicationRef }, { token: i2$1.Localize, optional: true }, { token: NotificationsConfig, optional: true }, { token: i0.ComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.Injectable });
356
+ Notifications.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.10", ngImport: i0, type: Notifications });
357
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.10", ngImport: i0, type: Notifications, decorators: [{
358
+ type: Injectable
359
+ }], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.Platform }, { type: i0.ApplicationRef }, { type: i2$1.Localize, decorators: [{
360
+ type: Optional
361
+ }] }, { type: NotificationsConfig, decorators: [{
362
+ type: Optional
363
363
  }] }, { type: i0.ComponentFactoryResolver }]; } });
364
364
 
365
- class NotificationsModule {
366
- static forRoot(config) {
367
- return {
368
- ngModule: NotificationsModule,
369
- providers: [
370
- { provide: NotificationsConfig, useValue: config },
371
- Notifications
372
- ]
373
- };
374
- }
375
- }
376
- NotificationsModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.4", ngImport: i0, type: NotificationsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
377
- NotificationsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.0.4", ngImport: i0, type: NotificationsModule, declarations: [BbNotificationsList, BbNotificationsItem], imports: [CommonModule, LocalizeModule] });
378
- NotificationsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.0.4", ngImport: i0, type: NotificationsModule, imports: [[CommonModule, LocalizeModule]] });
379
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.4", ngImport: i0, type: NotificationsModule, decorators: [{
380
- type: NgModule,
381
- args: [{
382
- imports: [CommonModule, LocalizeModule],
383
- declarations: [BbNotificationsList, BbNotificationsItem],
384
- entryComponents: [BbNotificationsList]
385
- }]
365
+ class NotificationsModule {
366
+ static forRoot(config) {
367
+ return {
368
+ ngModule: NotificationsModule,
369
+ providers: [
370
+ { provide: NotificationsConfig, useValue: config },
371
+ Notifications
372
+ ]
373
+ };
374
+ }
375
+ }
376
+ NotificationsModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.10", ngImport: i0, type: NotificationsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
377
+ NotificationsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.10", ngImport: i0, type: NotificationsModule, declarations: [BbNotificationsList, BbNotificationsItem], imports: [CommonModule, LocalizeModule] });
378
+ NotificationsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.10", ngImport: i0, type: NotificationsModule, imports: [[CommonModule, LocalizeModule]] });
379
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.10", ngImport: i0, type: NotificationsModule, decorators: [{
380
+ type: NgModule,
381
+ args: [{
382
+ imports: [CommonModule, LocalizeModule],
383
+ declarations: [BbNotificationsList, BbNotificationsItem],
384
+ entryComponents: [BbNotificationsList]
385
+ }]
386
386
  }] });
387
387
 
388
- /**
389
- * Generated bundle index. Do not edit.
388
+ /**
389
+ * Generated bundle index. Do not edit.
390
390
  */
391
391
 
392
392
  export { NotificationType, Notifications, NotificationsConfig, NotificationsData, NotificationsModule, NotificationsPosition };