@bravobit/bb-foundation 0.21.0 → 0.21.3
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.
- package/README.md +47 -47
- package/auth/index.d.ts +5 -5
- package/auth/lib/auth.interceptor.d.ts +21 -21
- package/auth/lib/auth.module.d.ts +15 -15
- package/auth/lib/auth.service.d.ts +59 -59
- package/auth/lib/auth.session.d.ts +34 -34
- package/auth/lib/directives/authenticated.directive.d.ts +14 -14
- package/auth/lib/directives/permission.directive.d.ts +24 -24
- package/auth/lib/directives/role.directive.d.ts +16 -16
- package/auth/lib/guards/anonymous.guard.d.ts +11 -11
- package/auth/lib/guards/authenticated.guard.d.ts +11 -11
- package/auth/lib/helpers/jwt.helper.d.ts +8 -8
- package/auth/lib/helpers/mapper.helper.d.ts +23 -23
- package/auth/lib/interfaces/config.interface.d.ts +12 -12
- package/auth/lib/interfaces/mapper.interface.d.ts +19 -19
- package/auth/lib/interfaces/provider.interface.d.ts +16 -16
- package/auth/lib/interfaces/token.interface.d.ts +11 -11
- package/auth/lib/permissions.service.d.ts +14 -14
- package/auth/lib/providers/email.provider.d.ts +15 -15
- package/auth/lib/providers/verify.provider.d.ts +13 -13
- package/auth/lib/tokens/use-authorization.token.d.ts +2 -2
- package/auth/public_api.d.ts +18 -18
- package/collections/index.d.ts +5 -5
- package/collections/lib/collection.d.ts +42 -43
- package/collections/lib/collections.module.d.ts +10 -10
- package/collections/lib/components/collections-pager/collections-pager.component.d.ts +34 -34
- package/collections/lib/components/collections-viewer/collections-viewer.component.d.ts +12 -12
- package/collections/lib/components/collections.directive.d.ts +17 -17
- package/collections/lib/interfaces/collection.interface.d.ts +27 -26
- package/collections/lib/providers/api-collection.provider.d.ts +18 -19
- package/collections/lib/providers/collection.provider.d.ts +6 -6
- package/collections/lib/providers/local-collection.provider.d.ts +8 -8
- package/collections/public_api.d.ts +9 -9
- package/controls/index.d.ts +5 -5
- package/controls/lib/checkbox/checkbox/checkbox.component.d.ts +47 -47
- package/controls/lib/checkbox/checkbox-group/checkbox-group.component.d.ts +22 -22
- package/controls/lib/checkbox/checkbox.module.d.ts +9 -9
- package/controls/lib/controls.module.d.ts +7 -7
- package/controls/public_api.d.ts +4 -4
- package/dashboard/index.d.ts +5 -5
- package/dashboard/lib/dashboard/dashboard.component.d.ts +19 -19
- package/dashboard/lib/dashboard-header/dashboard-header.component.d.ts +11 -11
- package/dashboard/lib/dashboard-menu/dashboard-menu.component.d.ts +9 -9
- package/dashboard/lib/dashboard-menu-item/dashboard-menu-item.component.d.ts +11 -11
- package/dashboard/lib/dashboard-sidebar/dashboard-sidebar.component.d.ts +21 -21
- package/dashboard/lib/dashboard-sidebar-group/dashboard-sidebar-group.component.d.ts +27 -27
- package/dashboard/lib/dashboard-sidebar-item/dashboard-sidebar-item.component.d.ts +16 -16
- package/dashboard/lib/dashboard.module.d.ts +16 -16
- package/dashboard/public_api.d.ts +8 -8
- package/dialog/index.d.ts +5 -5
- package/dialog/lib/dialog-actions/dialog-actions.component.d.ts +5 -5
- package/dialog/lib/dialog-confirm/dialog-confirm.component.d.ts +16 -16
- package/dialog/lib/dialog-container/dialog-container.component.d.ts +24 -24
- package/dialog/lib/dialog-header/dialog-header.component.d.ts +9 -9
- package/dialog/lib/dialog-link/dialog-link.component.d.ts +5 -5
- package/dialog/lib/dialog-modal/dialog-modal.component.d.ts +12 -12
- package/dialog/lib/dialog-overlay/dialog-overlay.component.d.ts +22 -22
- package/dialog/lib/dialog.injector.d.ts +8 -8
- package/dialog/lib/dialog.insertion.d.ts +8 -8
- package/dialog/lib/dialog.interfaces.d.ts +3 -3
- package/dialog/lib/dialog.module.d.ts +19 -19
- package/dialog/lib/dialog.ref.d.ts +8 -8
- package/dialog/lib/dialog.service.d.ts +19 -19
- package/dialog/public_api.d.ts +9 -9
- package/elements/index.d.ts +5 -5
- package/elements/lib/avatar/avatar.component.d.ts +25 -25
- package/elements/lib/button/button.component.d.ts +23 -23
- package/elements/lib/checkbox/checkbox.component.d.ts +27 -27
- package/elements/lib/date-picker/date-picker.component.d.ts +69 -69
- package/elements/lib/directives/addon.directive.d.ts +9 -9
- package/elements/lib/directives/autosize.directive.d.ts +18 -18
- package/elements/lib/directives/focus-trap.directive.d.ts +17 -17
- package/elements/lib/directives/focus.directive.d.ts +14 -14
- package/elements/lib/directives/form-submit.directive.d.ts +17 -17
- package/elements/lib/directives/input.directive.d.ts +38 -38
- package/elements/lib/directives/template.directive.d.ts +10 -10
- package/elements/lib/dropdown/dropdown.component.d.ts +21 -21
- package/elements/lib/elements.interfaces.d.ts +25 -25
- package/elements/lib/elements.module.d.ts +116 -116
- package/elements/lib/file-picker/file-picker.component.d.ts +49 -49
- package/elements/lib/form-control/form-control.component.d.ts +21 -21
- package/elements/lib/form-error/form-error.component.d.ts +29 -29
- package/elements/lib/form-group/form-group.component.d.ts +10 -10
- package/elements/lib/icon/icon.component.d.ts +22 -22
- package/elements/lib/image-picker/image-picker.component.d.ts +38 -38
- package/elements/lib/pipes/file-image.pipe.d.ts +13 -13
- package/elements/lib/pipes/file-size.pipe.d.ts +8 -8
- package/elements/lib/pipes/relative-time.pipe.d.ts +19 -19
- package/elements/lib/spinner/spinner.component.d.ts +12 -12
- package/elements/lib/tag/tag.component.d.ts +7 -7
- package/elements/public_api.d.ts +25 -25
- package/esm2020/auth/bravobit-bb-foundation-auth.mjs +4 -4
- package/esm2020/auth/lib/auth.interceptor.mjs +93 -93
- package/esm2020/auth/lib/auth.module.mjs +54 -54
- package/esm2020/auth/lib/auth.service.mjs +281 -281
- package/esm2020/auth/lib/auth.session.mjs +131 -131
- package/esm2020/auth/lib/directives/authenticated.directive.mjs +31 -31
- package/esm2020/auth/lib/directives/permission.directive.mjs +80 -80
- package/esm2020/auth/lib/directives/role.directive.mjs +37 -37
- package/esm2020/auth/lib/guards/anonymous.guard.mjs +34 -34
- package/esm2020/auth/lib/guards/authenticated.guard.mjs +35 -35
- package/esm2020/auth/lib/helpers/jwt.helper.mjs +69 -69
- package/esm2020/auth/lib/helpers/mapper.helper.mjs +35 -35
- package/esm2020/auth/lib/interfaces/config.interface.mjs +3 -3
- package/esm2020/auth/lib/interfaces/mapper.interface.mjs +2 -2
- package/esm2020/auth/lib/interfaces/provider.interface.mjs +2 -2
- package/esm2020/auth/lib/interfaces/token.interface.mjs +2 -2
- package/esm2020/auth/lib/permissions.service.mjs +56 -56
- package/esm2020/auth/lib/providers/email.provider.mjs +25 -25
- package/esm2020/auth/lib/providers/verify.provider.mjs +19 -19
- package/esm2020/auth/lib/tokens/use-authorization.token.mjs +3 -3
- package/esm2020/auth/public_api.mjs +19 -19
- package/esm2020/bravobit-bb-foundation.mjs +4 -4
- package/esm2020/collections/bravobit-bb-foundation-collections.mjs +4 -4
- package/esm2020/collections/lib/collection.mjs +100 -102
- package/esm2020/collections/lib/collections.module.mjs +54 -54
- package/esm2020/collections/lib/components/collections-pager/collections-pager.component.mjs +123 -123
- package/esm2020/collections/lib/components/collections-viewer/collections-viewer.component.mjs +31 -31
- package/esm2020/collections/lib/components/collections.directive.mjs +43 -43
- package/esm2020/collections/lib/interfaces/collection.interface.mjs +2 -2
- package/esm2020/collections/lib/providers/api-collection.provider.mjs +91 -71
- package/esm2020/collections/lib/providers/collection.provider.mjs +13 -13
- package/esm2020/collections/lib/providers/local-collection.provider.mjs +16 -16
- package/esm2020/collections/public_api.mjs +10 -10
- package/esm2020/controls/bravobit-bb-foundation-controls.mjs +4 -4
- package/esm2020/controls/lib/checkbox/checkbox/checkbox.component.mjs +153 -153
- package/esm2020/controls/lib/checkbox/checkbox-group/checkbox-group.component.mjs +61 -61
- package/esm2020/controls/lib/checkbox/checkbox.module.mjs +19 -19
- package/esm2020/controls/lib/controls.module.mjs +16 -16
- package/esm2020/controls/public_api.mjs +5 -5
- package/esm2020/dashboard/bravobit-bb-foundation-dashboard.mjs +4 -4
- package/esm2020/dashboard/lib/dashboard/dashboard.component.mjs +56 -56
- package/esm2020/dashboard/lib/dashboard-header/dashboard-header.component.mjs +30 -30
- package/esm2020/dashboard/lib/dashboard-menu/dashboard-menu.component.mjs +31 -31
- package/esm2020/dashboard/lib/dashboard-menu-item/dashboard-menu-item.component.mjs +29 -29
- package/esm2020/dashboard/lib/dashboard-sidebar/dashboard-sidebar.component.mjs +75 -75
- package/esm2020/dashboard/lib/dashboard-sidebar-group/dashboard-sidebar-group.component.mjs +99 -99
- package/esm2020/dashboard/lib/dashboard-sidebar-item/dashboard-sidebar-item.component.mjs +62 -62
- package/esm2020/dashboard/lib/dashboard.module.mjs +47 -47
- package/esm2020/dashboard/public_api.mjs +9 -9
- package/esm2020/dialog/bravobit-bb-foundation-dialog.mjs +4 -4
- package/esm2020/dialog/lib/dialog-actions/dialog-actions.component.mjs +12 -12
- package/esm2020/dialog/lib/dialog-confirm/dialog-confirm.component.mjs +37 -37
- package/esm2020/dialog/lib/dialog-container/dialog-container.component.mjs +153 -153
- package/esm2020/dialog/lib/dialog-header/dialog-header.component.mjs +25 -25
- package/esm2020/dialog/lib/dialog-link/dialog-link.component.mjs +11 -11
- package/esm2020/dialog/lib/dialog-modal/dialog-modal.component.mjs +46 -46
- package/esm2020/dialog/lib/dialog-overlay/dialog-overlay.component.mjs +134 -134
- package/esm2020/dialog/lib/dialog.injector.mjs +18 -18
- package/esm2020/dialog/lib/dialog.insertion.mjs +16 -16
- package/esm2020/dialog/lib/dialog.interfaces.mjs +3 -3
- package/esm2020/dialog/lib/dialog.module.mjs +68 -68
- package/esm2020/dialog/lib/dialog.ref.mjs +22 -22
- package/esm2020/dialog/lib/dialog.service.mjs +77 -77
- package/esm2020/dialog/public_api.mjs +10 -10
- package/esm2020/elements/bravobit-bb-foundation-elements.mjs +4 -4
- package/esm2020/elements/lib/avatar/avatar.component.mjs +145 -145
- package/esm2020/elements/lib/button/button.component.mjs +61 -61
- package/esm2020/elements/lib/checkbox/checkbox.component.mjs +73 -73
- package/esm2020/elements/lib/date-picker/date-picker.component.mjs +304 -304
- package/esm2020/elements/lib/directives/addon.directive.mjs +29 -29
- package/esm2020/elements/lib/directives/autosize.directive.mjs +72 -72
- package/esm2020/elements/lib/directives/focus-trap.directive.mjs +77 -77
- package/esm2020/elements/lib/directives/focus.directive.mjs +39 -39
- package/esm2020/elements/lib/directives/form-submit.directive.mjs +50 -50
- package/esm2020/elements/lib/directives/input.directive.mjs +136 -136
- package/esm2020/elements/lib/directives/template.directive.mjs +28 -28
- package/esm2020/elements/lib/dropdown/dropdown.component.mjs +100 -100
- package/esm2020/elements/lib/elements.interfaces.mjs +4 -4
- package/esm2020/elements/lib/elements.module.mjs +177 -177
- package/esm2020/elements/lib/file-picker/file-picker.component.mjs +236 -236
- package/esm2020/elements/lib/form-control/form-control.component.mjs +49 -49
- package/esm2020/elements/lib/form-error/form-error.component.mjs +108 -108
- package/esm2020/elements/lib/form-group/form-group.component.mjs +18 -18
- package/esm2020/elements/lib/icon/icon.component.mjs +102 -102
- package/esm2020/elements/lib/image-picker/image-picker.component.mjs +106 -106
- package/esm2020/elements/lib/pipes/file-image.pipe.mjs +42 -42
- package/esm2020/elements/lib/pipes/file-size.pipe.mjs +28 -28
- package/esm2020/elements/lib/pipes/relative-time.pipe.mjs +94 -94
- package/esm2020/elements/lib/spinner/spinner.component.mjs +25 -25
- package/esm2020/elements/lib/tag/tag.component.mjs +18 -18
- package/esm2020/elements/public_api.mjs +26 -26
- package/esm2020/http/bravobit-bb-foundation-http.mjs +4 -4
- package/esm2020/http/lib/classes/http.config.mjs +29 -29
- package/esm2020/http/lib/classes/http.error.mjs +20 -20
- package/esm2020/http/lib/http.interfaces.mjs +2 -2
- package/esm2020/http/lib/http.module.mjs +43 -43
- package/esm2020/http/lib/interceptors/base-url.interceptor.mjs +50 -50
- package/esm2020/http/lib/interceptors/error.interceptor.mjs +32 -32
- package/esm2020/http/public_api.mjs +7 -7
- package/esm2020/lib/core/miscellaneous/regex.mjs +5 -5
- package/esm2020/lib/core/miscellaneous/validator.mjs +85 -85
- package/esm2020/lib/core/mixins/can-disable.mjs +16 -16
- package/esm2020/lib/core/mixins/can-hide-errors.mjs +16 -16
- package/esm2020/lib/core/mixins/can-load.mjs +16 -16
- package/esm2020/lib/core/mixins/constructor.mjs +2 -2
- package/esm2020/lib/core/mixins/has-error.mjs +16 -16
- package/esm2020/lib/core/mixins/is-focused.mjs +16 -16
- package/esm2020/lib/core/mixins/is-grouped.mjs +16 -16
- package/esm2020/lib/core/mixins/is-readonly.mjs +16 -16
- package/esm2020/lib/core/mixins/is-required.mjs +16 -16
- package/esm2020/lib/core/services/clipboard.service.mjs +70 -70
- package/esm2020/lib/core/services/exif.service.mjs +163 -163
- package/esm2020/lib/core/services/file-loader.service.mjs +87 -87
- package/esm2020/lib/core/services/image-converter.service.mjs +123 -123
- package/esm2020/lib/core/services/languages.service.mjs +74 -74
- package/esm2020/lib/core/services/network.service.mjs +55 -55
- package/esm2020/lib/core/services/patch.service.mjs +63 -63
- package/esm2020/lib/core/services/platform.service.mjs +42 -42
- package/esm2020/lib/core/tokens/accept-language.token.mjs +3 -3
- package/esm2020/lib/core/tokens/base-url.token.mjs +3 -3
- package/esm2020/lib/core/tokens/cookie.token.mjs +3 -3
- package/esm2020/lib/core/tokens/location.token.mjs +6 -6
- package/esm2020/lib/core/tokens/navigator.token.mjs +6 -6
- package/esm2020/lib/core/tokens/window.token.mjs +12 -12
- package/esm2020/localize/bravobit-bb-foundation-localize.mjs +4 -4
- package/esm2020/localize/lib/functions/date.function.mjs +18 -18
- package/esm2020/localize/lib/functions/lowercase.function.mjs +13 -13
- package/esm2020/localize/lib/functions/uppercase.function.mjs +13 -13
- package/esm2020/localize/lib/handlers/missing.handler.mjs +15 -15
- package/esm2020/localize/lib/interfaces/config.interfaces.mjs +7 -7
- package/esm2020/localize/lib/interfaces/functions.interfaces.mjs +8 -8
- package/esm2020/localize/lib/interfaces/handlers.interfaces.mjs +2 -2
- package/esm2020/localize/lib/interfaces/options.interfaces.mjs +6 -6
- package/esm2020/localize/lib/localizations/dutch.localization.mjs +45 -45
- package/esm2020/localize/lib/localizations/english.localization.mjs +45 -45
- package/esm2020/localize/lib/localize.dictionary.mjs +26 -26
- package/esm2020/localize/lib/localize.module.mjs +71 -71
- package/esm2020/localize/lib/localize.pipe.mjs +49 -49
- package/esm2020/localize/lib/localize.service.mjs +207 -207
- package/esm2020/localize/lib/views/localize-string/localize-string.component.mjs +88 -88
- package/esm2020/localize/lib/views/localize-template-or-string.directive.mjs +28 -28
- package/esm2020/localize/lib/views/localize-template.directive.mjs +21 -21
- package/esm2020/localize/public_api.mjs +17 -17
- package/esm2020/masking/bravobit-bb-foundation-masking.mjs +4 -4
- package/esm2020/masking/lib/input-mask.directive.mjs +117 -110
- package/esm2020/masking/lib/input-mask.interface.mjs +2 -2
- package/esm2020/masking/lib/masking.module.mjs +16 -16
- package/esm2020/masking/lib/masking.service.mjs +103 -94
- package/esm2020/masking/public_api.mjs +5 -5
- package/esm2020/notifications/bravobit-bb-foundation-notifications.mjs +4 -4
- package/esm2020/notifications/lib/notifications-item/notifications-item.component.mjs +100 -100
- package/esm2020/notifications/lib/notifications-list/notifications-list.component.mjs +47 -47
- package/esm2020/notifications/lib/notifications.animations.mjs +28 -28
- package/esm2020/notifications/lib/notifications.injector.mjs +18 -18
- package/esm2020/notifications/lib/notifications.interfaces.mjs +20 -20
- package/esm2020/notifications/lib/notifications.module.mjs +30 -30
- package/esm2020/notifications/lib/notifications.service.mjs +145 -145
- package/esm2020/notifications/public_api.mjs +4 -4
- package/esm2020/public_api.mjs +29 -29
- package/esm2020/recaptcha/bravobit-bb-foundation-recaptcha.mjs +4 -4
- package/esm2020/recaptcha/lib/recaptcha/recaptcha.component.mjs +185 -185
- package/esm2020/recaptcha/lib/recaptcha-loader.service.mjs +90 -90
- package/esm2020/recaptcha/lib/recaptcha.interface.mjs +3 -3
- package/esm2020/recaptcha/lib/recaptcha.module.mjs +27 -27
- package/esm2020/recaptcha/public_api.mjs +5 -5
- package/esm2020/rxjs/bravobit-bb-foundation-rxjs.mjs +4 -4
- package/esm2020/rxjs/lib/observables/get-control-value.observable.mjs +6 -0
- package/esm2020/rxjs/lib/operators/combine-latest-map.operator.mjs +10 -10
- package/esm2020/rxjs/lib/operators/filter-nil.operator.mjs +5 -5
- package/esm2020/rxjs/public_api.mjs +4 -3
- package/esm2020/storage/bravobit-bb-foundation-storage.mjs +4 -4
- package/esm2020/storage/lib/interfaces/attributes.interface.mjs +2 -2
- package/esm2020/storage/lib/interfaces/memory.interface.mjs +2 -2
- package/esm2020/storage/lib/interfaces/strategy.interface.mjs +2 -2
- package/esm2020/storage/lib/storage.service.mjs +109 -109
- package/esm2020/storage/lib/strategies/cookie-storage.strategy.mjs +142 -142
- package/esm2020/storage/lib/strategies/memory-storage.strategy.mjs +56 -56
- package/esm2020/storage/lib/strategies/polyfill-storage.strategy.mjs +102 -102
- package/esm2020/storage/public_api.mjs +8 -8
- package/esm2020/table/bravobit-bb-foundation-table.mjs +4 -4
- package/esm2020/table/lib/components/table/table.component.mjs +191 -191
- package/esm2020/table/lib/components/table-cell/table-cell.component.mjs +11 -11
- package/esm2020/table/lib/components/table-header-cell/table-header-cell.component.mjs +131 -131
- package/esm2020/table/lib/components/table-pager/table-pager.component.mjs +136 -136
- package/esm2020/table/lib/data/datasource.data.mjs +32 -32
- package/esm2020/table/lib/data/generic.data.mjs +72 -72
- package/esm2020/table/lib/interfaces/datasource.interface.mjs +2 -2
- package/esm2020/table/lib/interfaces/table.interfaces.mjs +2 -2
- package/esm2020/table/lib/table.module.mjs +42 -42
- package/esm2020/table/public_api.mjs +10 -10
- package/esm2020/theming/bravobit-bb-foundation-theming.mjs +4 -4
- package/esm2020/theming/lib/themes/checkbox-group.theme.mjs +2 -2
- package/esm2020/theming/lib/themes/checkbox.theme.mjs +2 -2
- package/esm2020/theming/lib/themes/theme.mjs +34 -0
- package/esm2020/theming/lib/theming.interface.mjs +3 -3
- package/esm2020/theming/lib/theming.module.mjs +38 -38
- package/esm2020/theming/lib/theming.service.mjs +77 -100
- package/esm2020/theming/public_api.mjs +7 -4
- package/fesm2015/bravobit-bb-foundation-auth.mjs +930 -930
- package/fesm2015/bravobit-bb-foundation-auth.mjs.map +1 -1
- package/fesm2015/bravobit-bb-foundation-collections.mjs +443 -424
- package/fesm2015/bravobit-bb-foundation-collections.mjs.map +1 -1
- package/fesm2015/bravobit-bb-foundation-controls.mjs +229 -229
- package/fesm2015/bravobit-bb-foundation-controls.mjs.map +1 -1
- package/fesm2015/bravobit-bb-foundation-dashboard.mjs +382 -382
- package/fesm2015/bravobit-bb-foundation-dashboard.mjs.map +1 -1
- package/fesm2015/bravobit-bb-foundation-dialog.mjs +540 -540
- package/fesm2015/bravobit-bb-foundation-dialog.mjs.map +1 -1
- package/fesm2015/bravobit-bb-foundation-elements.mjs +1970 -1970
- package/fesm2015/bravobit-bb-foundation-elements.mjs.map +1 -1
- package/fesm2015/bravobit-bb-foundation-http.mjs +156 -156
- package/fesm2015/bravobit-bb-foundation-http.mjs.map +1 -1
- package/fesm2015/bravobit-bb-foundation-localize.mjs +608 -608
- package/fesm2015/bravobit-bb-foundation-localize.mjs.map +1 -1
- package/fesm2015/bravobit-bb-foundation-masking.mjs +231 -214
- package/fesm2015/bravobit-bb-foundation-masking.mjs.map +1 -1
- package/fesm2015/bravobit-bb-foundation-notifications.mjs +348 -348
- package/fesm2015/bravobit-bb-foundation-notifications.mjs.map +1 -1
- package/fesm2015/bravobit-bb-foundation-recaptcha.mjs +290 -290
- package/fesm2015/bravobit-bb-foundation-recaptcha.mjs.map +1 -1
- package/fesm2015/bravobit-bb-foundation-rxjs.mjs +14 -10
- package/fesm2015/bravobit-bb-foundation-rxjs.mjs.map +1 -1
- package/fesm2015/bravobit-bb-foundation-storage.mjs +401 -401
- package/fesm2015/bravobit-bb-foundation-storage.mjs.map +1 -1
- package/fesm2015/bravobit-bb-foundation-table.mjs +571 -571
- package/fesm2015/bravobit-bb-foundation-table.mjs.map +1 -1
- package/fesm2015/bravobit-bb-foundation-theming.mjs +151 -140
- package/fesm2015/bravobit-bb-foundation-theming.mjs.map +1 -1
- package/fesm2015/bravobit-bb-foundation.mjs +859 -859
- package/fesm2015/bravobit-bb-foundation.mjs.map +1 -1
- package/fesm2020/bravobit-bb-foundation-auth.mjs +882 -882
- package/fesm2020/bravobit-bb-foundation-auth.mjs.map +1 -1
- package/fesm2020/bravobit-bb-foundation-collections.mjs +432 -414
- package/fesm2020/bravobit-bb-foundation-collections.mjs.map +1 -1
- package/fesm2020/bravobit-bb-foundation-controls.mjs +227 -227
- package/fesm2020/bravobit-bb-foundation-controls.mjs.map +1 -1
- package/fesm2020/bravobit-bb-foundation-dashboard.mjs +370 -370
- package/fesm2020/bravobit-bb-foundation-dashboard.mjs.map +1 -1
- package/fesm2020/bravobit-bb-foundation-dialog.mjs +539 -539
- package/fesm2020/bravobit-bb-foundation-dialog.mjs.map +1 -1
- package/fesm2020/bravobit-bb-foundation-elements.mjs +1927 -1927
- package/fesm2020/bravobit-bb-foundation-elements.mjs.map +1 -1
- package/fesm2020/bravobit-bb-foundation-http.mjs +148 -148
- package/fesm2020/bravobit-bb-foundation-http.mjs.map +1 -1
- package/fesm2020/bravobit-bb-foundation-localize.mjs +587 -587
- package/fesm2020/bravobit-bb-foundation-localize.mjs.map +1 -1
- package/fesm2020/bravobit-bb-foundation-masking.mjs +219 -203
- package/fesm2020/bravobit-bb-foundation-masking.mjs.map +1 -1
- package/fesm2020/bravobit-bb-foundation-notifications.mjs +346 -346
- package/fesm2020/bravobit-bb-foundation-notifications.mjs.map +1 -1
- package/fesm2020/bravobit-bb-foundation-recaptcha.mjs +280 -280
- package/fesm2020/bravobit-bb-foundation-recaptcha.mjs.map +1 -1
- package/fesm2020/bravobit-bb-foundation-rxjs.mjs +17 -13
- package/fesm2020/bravobit-bb-foundation-rxjs.mjs.map +1 -1
- package/fesm2020/bravobit-bb-foundation-storage.mjs +396 -396
- package/fesm2020/bravobit-bb-foundation-storage.mjs.map +1 -1
- package/fesm2020/bravobit-bb-foundation-table.mjs +560 -560
- package/fesm2020/bravobit-bb-foundation-table.mjs.map +1 -1
- package/fesm2020/bravobit-bb-foundation-theming.mjs +141 -130
- package/fesm2020/bravobit-bb-foundation-theming.mjs.map +1 -1
- package/fesm2020/bravobit-bb-foundation.mjs +831 -831
- package/fesm2020/bravobit-bb-foundation.mjs.map +1 -1
- package/http/index.d.ts +5 -5
- package/http/lib/classes/http.config.d.ts +9 -9
- package/http/lib/classes/http.error.d.ts +7 -7
- package/http/lib/http.interfaces.d.ts +12 -12
- package/http/lib/http.module.d.ts +15 -15
- package/http/lib/interceptors/base-url.interceptor.d.ts +15 -15
- package/http/lib/interceptors/error.interceptor.d.ts +11 -11
- package/http/public_api.d.ts +6 -6
- package/index.d.ts +5 -5
- package/lib/core/miscellaneous/regex.d.ts +4 -4
- package/lib/core/miscellaneous/validator.d.ts +13 -13
- package/lib/core/mixins/can-disable.d.ts +6 -6
- package/lib/core/mixins/can-hide-errors.d.ts +6 -6
- package/lib/core/mixins/can-load.d.ts +6 -6
- package/lib/core/mixins/constructor.d.ts +1 -1
- package/lib/core/mixins/has-error.d.ts +6 -6
- package/lib/core/mixins/is-focused.d.ts +6 -6
- package/lib/core/mixins/is-grouped.d.ts +6 -6
- package/lib/core/mixins/is-readonly.d.ts +6 -6
- package/lib/core/mixins/is-required.d.ts +6 -6
- package/lib/core/services/clipboard.service.d.ts +18 -18
- package/lib/core/services/exif.service.d.ts +15 -15
- package/lib/core/services/file-loader.service.d.ts +13 -13
- package/lib/core/services/image-converter.service.d.ts +21 -21
- package/lib/core/services/languages.service.d.ts +16 -16
- package/lib/core/services/network.service.d.ts +14 -14
- package/lib/core/services/patch.service.d.ts +16 -16
- package/lib/core/services/platform.service.d.ts +18 -18
- package/lib/core/tokens/accept-language.token.d.ts +2 -2
- package/lib/core/tokens/base-url.token.d.ts +2 -2
- package/lib/core/tokens/cookie.token.d.ts +2 -2
- package/lib/core/tokens/location.token.d.ts +2 -2
- package/lib/core/tokens/navigator.token.d.ts +2 -2
- package/lib/core/tokens/window.token.d.ts +2 -2
- package/localize/index.d.ts +5 -5
- package/localize/lib/functions/date.function.d.ts +5 -5
- package/localize/lib/functions/lowercase.function.d.ts +5 -5
- package/localize/lib/functions/uppercase.function.d.ts +5 -5
- package/localize/lib/handlers/missing.handler.d.ts +6 -6
- package/localize/lib/interfaces/config.interfaces.d.ts +18 -18
- package/localize/lib/interfaces/functions.interfaces.d.ts +9 -9
- package/localize/lib/interfaces/handlers.interfaces.d.ts +6 -6
- package/localize/lib/interfaces/options.interfaces.d.ts +10 -10
- package/localize/lib/localizations/dutch.localization.d.ts +44 -44
- package/localize/lib/localizations/english.localization.d.ts +44 -44
- package/localize/lib/localize.dictionary.d.ts +7 -7
- package/localize/lib/localize.module.d.ts +17 -17
- package/localize/lib/localize.pipe.d.ts +12 -12
- package/localize/lib/localize.service.d.ts +40 -40
- package/localize/lib/views/localize-string/localize-string.component.d.ts +23 -23
- package/localize/lib/views/localize-template-or-string.directive.d.ts +10 -10
- package/localize/lib/views/localize-template.directive.d.ts +9 -9
- package/localize/public_api.d.ts +16 -16
- package/masking/index.d.ts +5 -5
- package/masking/lib/input-mask.directive.d.ts +38 -36
- package/masking/lib/input-mask.interface.d.ts +24 -20
- package/masking/lib/masking.module.d.ts +7 -7
- package/masking/lib/masking.service.d.ts +12 -12
- package/masking/public_api.d.ts +4 -4
- package/notifications/index.d.ts +5 -5
- package/notifications/lib/notifications-item/notifications-item.component.d.ts +34 -34
- package/notifications/lib/notifications-list/notifications-list.component.d.ts +16 -16
- package/notifications/lib/notifications.animations.d.ts +1 -1
- package/notifications/lib/notifications.injector.d.ts +8 -8
- package/notifications/lib/notifications.interfaces.d.ts +49 -49
- package/notifications/lib/notifications.module.d.ts +13 -13
- package/notifications/lib/notifications.service.d.ts +34 -34
- package/notifications/public_api.d.ts +3 -3
- package/package.json +1 -1
- package/public_api.d.ts +25 -25
- package/recaptcha/index.d.ts +5 -5
- package/recaptcha/lib/recaptcha/recaptcha.component.d.ts +47 -47
- package/recaptcha/lib/recaptcha-loader.service.d.ts +22 -22
- package/recaptcha/lib/recaptcha.interface.d.ts +14 -14
- package/recaptcha/lib/recaptcha.module.d.ts +10 -10
- package/recaptcha/public_api.d.ts +4 -4
- package/rxjs/index.d.ts +5 -5
- package/rxjs/lib/observables/get-control-value.observable.d.ts +3 -0
- package/rxjs/lib/operators/combine-latest-map.operator.d.ts +8 -8
- package/rxjs/lib/operators/filter-nil.operator.d.ts +1 -1
- package/rxjs/public_api.d.ts +3 -2
- package/storage/index.d.ts +5 -5
- package/storage/lib/interfaces/attributes.interface.d.ts +13 -13
- package/storage/lib/interfaces/memory.interface.d.ts +7 -7
- package/storage/lib/interfaces/strategy.interface.d.ts +17 -17
- package/storage/lib/storage.service.d.ts +26 -26
- package/storage/lib/strategies/cookie-storage.strategy.d.ts +20 -20
- package/storage/lib/strategies/memory-storage.strategy.d.ts +11 -11
- package/storage/lib/strategies/polyfill-storage.strategy.d.ts +15 -15
- package/storage/public_api.d.ts +7 -7
- package/table/index.d.ts +5 -5
- package/table/lib/components/table/table.component.d.ts +56 -56
- package/table/lib/components/table-cell/table-cell.component.d.ts +5 -5
- package/table/lib/components/table-header-cell/table-header-cell.component.d.ts +29 -29
- package/table/lib/components/table-pager/table-pager.component.d.ts +41 -41
- package/table/lib/data/datasource.data.d.ts +14 -14
- package/table/lib/data/generic.data.d.ts +23 -23
- package/table/lib/interfaces/datasource.interface.d.ts +17 -17
- package/table/lib/interfaces/table.interfaces.d.ts +1 -1
- package/table/lib/table.module.d.ts +14 -14
- package/table/public_api.d.ts +9 -9
- package/theming/index.d.ts +5 -5
- package/theming/lib/themes/checkbox-group.theme.d.ts +5 -5
- package/theming/lib/themes/checkbox.theme.d.ts +19 -19
- package/theming/lib/themes/theme.d.ts +12 -0
- package/theming/lib/theming.interface.d.ts +15 -14
- package/theming/lib/theming.module.d.ts +13 -13
- package/theming/lib/theming.service.d.ts +22 -24
- package/theming/public_api.d.ts +6 -3
|
@@ -3,415 +3,415 @@ import { isDevMode, Injectable, Optional, Inject } from '@angular/core';
|
|
|
3
3
|
import * as i1 from '@bravobit/bb-foundation';
|
|
4
4
|
import { COOKIE } from '@bravobit/bb-foundation';
|
|
5
5
|
|
|
6
|
-
class PolyfillStorage {
|
|
7
|
-
constructor(_storage) {
|
|
8
|
-
this._storage = _storage;
|
|
9
|
-
// State.
|
|
10
|
-
this._isSupported = false;
|
|
11
|
-
this.encode = (value, attributes) => {
|
|
12
|
-
// Make sure the expires attribute is a date and not a number.
|
|
13
|
-
const data = { value };
|
|
14
|
-
if (typeof attributes.expires === 'number') {
|
|
15
|
-
attributes.expires = new Date(attributes.expires);
|
|
16
|
-
}
|
|
17
|
-
if (attributes.expires) {
|
|
18
|
-
data['expires'] = attributes.expires;
|
|
19
|
-
}
|
|
20
|
-
return JSON.stringify(data);
|
|
21
|
-
};
|
|
22
|
-
this.testIfSupported = () => {
|
|
23
|
-
if (typeof this._storage === 'undefined') {
|
|
24
|
-
return false;
|
|
25
|
-
}
|
|
26
|
-
try {
|
|
27
|
-
const x = '__storage_test__';
|
|
28
|
-
this._storage.setItem(x, x);
|
|
29
|
-
this._storage.removeItem(x);
|
|
30
|
-
return true;
|
|
31
|
-
}
|
|
32
|
-
catch (error) {
|
|
33
|
-
return error instanceof DOMException
|
|
34
|
-
&& (error.code === 22 ||
|
|
35
|
-
error.code === 1014 ||
|
|
36
|
-
error.name === 'QuotaExceededError' ||
|
|
37
|
-
error.name === 'NS_ERROR_DOM_QUOTA_REACHED')
|
|
38
|
-
&& (this._storage && this._storage.length !== 0);
|
|
39
|
-
}
|
|
40
|
-
};
|
|
41
|
-
// Check if the storage is supported.
|
|
42
|
-
this._isSupported = this.testIfSupported();
|
|
43
|
-
}
|
|
44
|
-
get(token) {
|
|
45
|
-
// Validate that the storage is supported.
|
|
46
|
-
if (!this._isSupported) {
|
|
47
|
-
return undefined;
|
|
48
|
-
}
|
|
49
|
-
return this.decode(token);
|
|
50
|
-
}
|
|
51
|
-
set(token, value, attributes) {
|
|
52
|
-
// Validate that the storage is supported.
|
|
53
|
-
if (!this._isSupported) {
|
|
54
|
-
return;
|
|
55
|
-
}
|
|
56
|
-
// Stringify the data.
|
|
57
|
-
const rawData = this.encode(value, Object.assign({}, attributes));
|
|
58
|
-
// Set the raw data in the storage.
|
|
59
|
-
this._storage.setItem(token, rawData);
|
|
60
|
-
}
|
|
61
|
-
remove(token) {
|
|
62
|
-
// Validate that the storage is supported.
|
|
63
|
-
if (!this._isSupported) {
|
|
64
|
-
return;
|
|
65
|
-
}
|
|
66
|
-
// Remove the item in the storage.
|
|
67
|
-
this._storage.removeItem(token);
|
|
68
|
-
}
|
|
69
|
-
clear() {
|
|
70
|
-
// Validate that the storage is supported.
|
|
71
|
-
if (!this._isSupported) {
|
|
72
|
-
return;
|
|
73
|
-
}
|
|
74
|
-
// Clear the storage.
|
|
75
|
-
this._storage.clear();
|
|
76
|
-
}
|
|
77
|
-
isSupported() {
|
|
78
|
-
return this._isSupported;
|
|
79
|
-
}
|
|
80
|
-
decode(token) {
|
|
81
|
-
// Retrieve the raw data from the storage.
|
|
82
|
-
const rawData = this._storage.getItem(token);
|
|
83
|
-
// Try to parse the data.
|
|
84
|
-
let parsedData = undefined;
|
|
85
|
-
// Only parse the data when it is not null.
|
|
86
|
-
if (rawData !== null) {
|
|
87
|
-
try {
|
|
88
|
-
const { value, expires } = JSON.parse(rawData);
|
|
89
|
-
if (expires !== undefined) {
|
|
90
|
-
const now = Date.now();
|
|
91
|
-
const expireDate = new Date(expires).getTime();
|
|
92
|
-
if (expireDate <= now) {
|
|
93
|
-
this.remove(token);
|
|
94
|
-
return undefined;
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
parsedData = value;
|
|
98
|
-
}
|
|
99
|
-
catch (_a) {
|
|
100
|
-
// We dont do anything with failed parsing.
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
// Return the parsed data.
|
|
104
|
-
return parsedData;
|
|
105
|
-
}
|
|
6
|
+
class PolyfillStorage {
|
|
7
|
+
constructor(_storage) {
|
|
8
|
+
this._storage = _storage;
|
|
9
|
+
// State.
|
|
10
|
+
this._isSupported = false;
|
|
11
|
+
this.encode = (value, attributes) => {
|
|
12
|
+
// Make sure the expires attribute is a date and not a number.
|
|
13
|
+
const data = { value };
|
|
14
|
+
if (typeof attributes.expires === 'number') {
|
|
15
|
+
attributes.expires = new Date(attributes.expires);
|
|
16
|
+
}
|
|
17
|
+
if (attributes.expires) {
|
|
18
|
+
data['expires'] = attributes.expires;
|
|
19
|
+
}
|
|
20
|
+
return JSON.stringify(data);
|
|
21
|
+
};
|
|
22
|
+
this.testIfSupported = () => {
|
|
23
|
+
if (typeof this._storage === 'undefined') {
|
|
24
|
+
return false;
|
|
25
|
+
}
|
|
26
|
+
try {
|
|
27
|
+
const x = '__storage_test__';
|
|
28
|
+
this._storage.setItem(x, x);
|
|
29
|
+
this._storage.removeItem(x);
|
|
30
|
+
return true;
|
|
31
|
+
}
|
|
32
|
+
catch (error) {
|
|
33
|
+
return error instanceof DOMException
|
|
34
|
+
&& (error.code === 22 ||
|
|
35
|
+
error.code === 1014 ||
|
|
36
|
+
error.name === 'QuotaExceededError' ||
|
|
37
|
+
error.name === 'NS_ERROR_DOM_QUOTA_REACHED')
|
|
38
|
+
&& (this._storage && this._storage.length !== 0);
|
|
39
|
+
}
|
|
40
|
+
};
|
|
41
|
+
// Check if the storage is supported.
|
|
42
|
+
this._isSupported = this.testIfSupported();
|
|
43
|
+
}
|
|
44
|
+
get(token) {
|
|
45
|
+
// Validate that the storage is supported.
|
|
46
|
+
if (!this._isSupported) {
|
|
47
|
+
return undefined;
|
|
48
|
+
}
|
|
49
|
+
return this.decode(token);
|
|
50
|
+
}
|
|
51
|
+
set(token, value, attributes) {
|
|
52
|
+
// Validate that the storage is supported.
|
|
53
|
+
if (!this._isSupported) {
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
// Stringify the data.
|
|
57
|
+
const rawData = this.encode(value, Object.assign({}, attributes));
|
|
58
|
+
// Set the raw data in the storage.
|
|
59
|
+
this._storage.setItem(token, rawData);
|
|
60
|
+
}
|
|
61
|
+
remove(token) {
|
|
62
|
+
// Validate that the storage is supported.
|
|
63
|
+
if (!this._isSupported) {
|
|
64
|
+
return;
|
|
65
|
+
}
|
|
66
|
+
// Remove the item in the storage.
|
|
67
|
+
this._storage.removeItem(token);
|
|
68
|
+
}
|
|
69
|
+
clear() {
|
|
70
|
+
// Validate that the storage is supported.
|
|
71
|
+
if (!this._isSupported) {
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
// Clear the storage.
|
|
75
|
+
this._storage.clear();
|
|
76
|
+
}
|
|
77
|
+
isSupported() {
|
|
78
|
+
return this._isSupported;
|
|
79
|
+
}
|
|
80
|
+
decode(token) {
|
|
81
|
+
// Retrieve the raw data from the storage.
|
|
82
|
+
const rawData = this._storage.getItem(token);
|
|
83
|
+
// Try to parse the data.
|
|
84
|
+
let parsedData = undefined;
|
|
85
|
+
// Only parse the data when it is not null.
|
|
86
|
+
if (rawData !== null) {
|
|
87
|
+
try {
|
|
88
|
+
const { value, expires } = JSON.parse(rawData);
|
|
89
|
+
if (expires !== undefined) {
|
|
90
|
+
const now = Date.now();
|
|
91
|
+
const expireDate = new Date(expires).getTime();
|
|
92
|
+
if (expireDate <= now) {
|
|
93
|
+
this.remove(token);
|
|
94
|
+
return undefined;
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
parsedData = value;
|
|
98
|
+
}
|
|
99
|
+
catch (_a) {
|
|
100
|
+
// We dont do anything with failed parsing.
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
// Return the parsed data.
|
|
104
|
+
return parsedData;
|
|
105
|
+
}
|
|
106
106
|
}
|
|
107
107
|
|
|
108
|
-
class CookieStorage {
|
|
109
|
-
constructor(_isBrowser, _cookieString) {
|
|
110
|
-
this._isBrowser = _isBrowser;
|
|
111
|
-
this._cookieString = _cookieString;
|
|
112
|
-
// State.
|
|
113
|
-
this._isSupported = false;
|
|
114
|
-
this.decode = (cookieString) => {
|
|
115
|
-
const result = {};
|
|
116
|
-
const cookies = cookieString ? cookieString.split('; ') : [];
|
|
117
|
-
const rdecode = /(%[0-9A-Z]{2})+/g;
|
|
118
|
-
for (let index = 0; index < cookies.length; index++) {
|
|
119
|
-
const parts = cookies[index].split('=');
|
|
120
|
-
let cookie = parts.slice(1).join('=');
|
|
121
|
-
if (cookie.charAt(0) === '"') {
|
|
122
|
-
cookie = cookie.slice(1, -1);
|
|
123
|
-
}
|
|
124
|
-
try {
|
|
125
|
-
const name = parts[0].replace(rdecode, decodeURIComponent);
|
|
126
|
-
const value = cookie.replace(rdecode, decodeURIComponent);
|
|
127
|
-
result[name] = this.jsonParse(value);
|
|
128
|
-
}
|
|
129
|
-
catch (_a) {
|
|
130
|
-
// Ignore cookies with an invalid name/value encoding.
|
|
131
|
-
}
|
|
132
|
-
}
|
|
133
|
-
return result;
|
|
134
|
-
};
|
|
135
|
-
this.jsonParse = (rawValue) => {
|
|
136
|
-
// Try to parse the data.
|
|
137
|
-
let parsedValue = undefined;
|
|
138
|
-
// Only parse the value when it is not null.
|
|
139
|
-
if (rawValue !== undefined) {
|
|
140
|
-
try {
|
|
141
|
-
parsedValue = JSON.parse(rawValue);
|
|
142
|
-
}
|
|
143
|
-
catch (_a) {
|
|
144
|
-
// The string could not be parsed to JSON.
|
|
145
|
-
}
|
|
146
|
-
}
|
|
147
|
-
// Return the parsed value.
|
|
148
|
-
return parsedValue;
|
|
149
|
-
};
|
|
150
|
-
this.stringifyAttribute = (token, value) => {
|
|
151
|
-
if (!value) {
|
|
152
|
-
return '';
|
|
153
|
-
}
|
|
154
|
-
const stringified = `; ${token}`;
|
|
155
|
-
// Boolean attributes should not have a value.
|
|
156
|
-
if (value === true) {
|
|
157
|
-
return stringified;
|
|
158
|
-
}
|
|
159
|
-
return stringified + `= ${value}`;
|
|
160
|
-
};
|
|
161
|
-
this.testIfSupported = () => {
|
|
162
|
-
// We are using an aggressive test here, because we cannot rely on navigator.cookieEnabled
|
|
163
|
-
// it does not return the correct value at all times.
|
|
164
|
-
const testCookieString = `bbcookietest`;
|
|
165
|
-
try {
|
|
166
|
-
document.cookie = `${testCookieString}=1`;
|
|
167
|
-
const result = document.cookie.indexOf(`${testCookieString}=`) !== -1;
|
|
168
|
-
document.cookie = `${testCookieString}=1; expires=Thu, 01-Jan-1970 00:00:01 GMT`;
|
|
169
|
-
return result;
|
|
170
|
-
}
|
|
171
|
-
catch (_a) {
|
|
172
|
-
return false;
|
|
173
|
-
}
|
|
174
|
-
};
|
|
175
|
-
// Check if the storage is supported.
|
|
176
|
-
this._isSupported = this.testIfSupported();
|
|
177
|
-
}
|
|
178
|
-
get(token) {
|
|
179
|
-
// Get all values and pick one out.
|
|
180
|
-
const values = this.all();
|
|
181
|
-
return values === null || values === void 0 ? void 0 : values[token];
|
|
182
|
-
}
|
|
183
|
-
set(token, value, attributes) {
|
|
184
|
-
// Validate that the storage is supported.
|
|
185
|
-
if (!this._isSupported) {
|
|
186
|
-
return;
|
|
187
|
-
}
|
|
188
|
-
// Write a new cookie.
|
|
189
|
-
document.cookie = this.encode(token, value, Object.assign({ path: '/', sameSite: 'Lax' }, attributes));
|
|
190
|
-
}
|
|
191
|
-
remove(token, attributes) {
|
|
192
|
-
// Validate that the storage is supported.
|
|
193
|
-
if (!this._isSupported) {
|
|
194
|
-
return;
|
|
195
|
-
}
|
|
196
|
-
this.set(token, '', Object.assign(Object.assign({}, attributes), { expires: -1 }));
|
|
197
|
-
}
|
|
198
|
-
clear(attributes) {
|
|
199
|
-
// Validate that the storage is supported.
|
|
200
|
-
if (!this._isSupported) {
|
|
201
|
-
return;
|
|
202
|
-
}
|
|
203
|
-
const items = this.all();
|
|
204
|
-
for (const token in items) {
|
|
205
|
-
this.remove(token, attributes);
|
|
206
|
-
}
|
|
207
|
-
}
|
|
208
|
-
isSupported() {
|
|
209
|
-
return this._isSupported;
|
|
210
|
-
}
|
|
211
|
-
all() {
|
|
212
|
-
const cookieString = this._isBrowser
|
|
213
|
-
? document === null || document === void 0 ? void 0 : document.cookie
|
|
214
|
-
: this._cookieString;
|
|
215
|
-
return this.decode(cookieString);
|
|
216
|
-
}
|
|
217
|
-
encode(token, value, attributes) {
|
|
218
|
-
// Encode the token.
|
|
219
|
-
const encodedToken = encodeURIComponent(token)
|
|
220
|
-
.replace(/%(23|24|26|2B|5E|60|7C)/g, decodeURIComponent)
|
|
221
|
-
.replace(/\(/g, '%28').replace(/\)/g, '%29');
|
|
222
|
-
const rawValue = JSON.stringify(value);
|
|
223
|
-
// Encode the value.
|
|
224
|
-
const encodedValue = encodeURIComponent(rawValue)
|
|
225
|
-
.replace(/%(23|24|26|2B|3A|3C|3E|3D|2F|3F|40|5B|5D|5E|60|7B|7D|7C)/g, decodeURIComponent);
|
|
226
|
-
// Return the completed encoded string.
|
|
227
|
-
return [encodedToken, '=', encodedValue, this.stringifyCookie(attributes)].join('');
|
|
228
|
-
}
|
|
229
|
-
stringifyCookie(attributes) {
|
|
230
|
-
var _a;
|
|
231
|
-
// Make sure the expires attribute is a date and not a number.
|
|
232
|
-
if (typeof attributes.expires === 'number') {
|
|
233
|
-
const expires = new Date();
|
|
234
|
-
expires.setMilliseconds(expires.getMilliseconds() + attributes.expires * 864e+5);
|
|
235
|
-
attributes.expires = expires;
|
|
236
|
-
}
|
|
237
|
-
// Force secure when sameSite=None.
|
|
238
|
-
if (attributes.sameSite === 'None') {
|
|
239
|
-
attributes.secure = true;
|
|
240
|
-
(_a = console === null || console === void 0 ? void 0 : console.warn) === null || _a === void 0 ? void 0 : _a.call(console, 'Cooke was forced with secure flag because sameSite=None');
|
|
241
|
-
}
|
|
242
|
-
// Stringify all attributes.
|
|
243
|
-
return this.stringifyAttribute('Expires', attributes.expires ? attributes.expires.toUTCString() : '')
|
|
244
|
-
+ this.stringifyAttribute('Domain', attributes.domain)
|
|
245
|
-
+ this.stringifyAttribute('Path', attributes.path)
|
|
246
|
-
+ this.stringifyAttribute('Secure', attributes.secure)
|
|
247
|
-
+ this.stringifyAttribute('SameSite', attributes.sameSite);
|
|
248
|
-
}
|
|
108
|
+
class CookieStorage {
|
|
109
|
+
constructor(_isBrowser, _cookieString) {
|
|
110
|
+
this._isBrowser = _isBrowser;
|
|
111
|
+
this._cookieString = _cookieString;
|
|
112
|
+
// State.
|
|
113
|
+
this._isSupported = false;
|
|
114
|
+
this.decode = (cookieString) => {
|
|
115
|
+
const result = {};
|
|
116
|
+
const cookies = cookieString ? cookieString.split('; ') : [];
|
|
117
|
+
const rdecode = /(%[0-9A-Z]{2})+/g;
|
|
118
|
+
for (let index = 0; index < cookies.length; index++) {
|
|
119
|
+
const parts = cookies[index].split('=');
|
|
120
|
+
let cookie = parts.slice(1).join('=');
|
|
121
|
+
if (cookie.charAt(0) === '"') {
|
|
122
|
+
cookie = cookie.slice(1, -1);
|
|
123
|
+
}
|
|
124
|
+
try {
|
|
125
|
+
const name = parts[0].replace(rdecode, decodeURIComponent);
|
|
126
|
+
const value = cookie.replace(rdecode, decodeURIComponent);
|
|
127
|
+
result[name] = this.jsonParse(value);
|
|
128
|
+
}
|
|
129
|
+
catch (_a) {
|
|
130
|
+
// Ignore cookies with an invalid name/value encoding.
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
return result;
|
|
134
|
+
};
|
|
135
|
+
this.jsonParse = (rawValue) => {
|
|
136
|
+
// Try to parse the data.
|
|
137
|
+
let parsedValue = undefined;
|
|
138
|
+
// Only parse the value when it is not null.
|
|
139
|
+
if (rawValue !== undefined) {
|
|
140
|
+
try {
|
|
141
|
+
parsedValue = JSON.parse(rawValue);
|
|
142
|
+
}
|
|
143
|
+
catch (_a) {
|
|
144
|
+
// The string could not be parsed to JSON.
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
// Return the parsed value.
|
|
148
|
+
return parsedValue;
|
|
149
|
+
};
|
|
150
|
+
this.stringifyAttribute = (token, value) => {
|
|
151
|
+
if (!value) {
|
|
152
|
+
return '';
|
|
153
|
+
}
|
|
154
|
+
const stringified = `; ${token}`;
|
|
155
|
+
// Boolean attributes should not have a value.
|
|
156
|
+
if (value === true) {
|
|
157
|
+
return stringified;
|
|
158
|
+
}
|
|
159
|
+
return stringified + `= ${value}`;
|
|
160
|
+
};
|
|
161
|
+
this.testIfSupported = () => {
|
|
162
|
+
// We are using an aggressive test here, because we cannot rely on navigator.cookieEnabled
|
|
163
|
+
// it does not return the correct value at all times.
|
|
164
|
+
const testCookieString = `bbcookietest`;
|
|
165
|
+
try {
|
|
166
|
+
document.cookie = `${testCookieString}=1`;
|
|
167
|
+
const result = document.cookie.indexOf(`${testCookieString}=`) !== -1;
|
|
168
|
+
document.cookie = `${testCookieString}=1; expires=Thu, 01-Jan-1970 00:00:01 GMT`;
|
|
169
|
+
return result;
|
|
170
|
+
}
|
|
171
|
+
catch (_a) {
|
|
172
|
+
return false;
|
|
173
|
+
}
|
|
174
|
+
};
|
|
175
|
+
// Check if the storage is supported.
|
|
176
|
+
this._isSupported = this.testIfSupported();
|
|
177
|
+
}
|
|
178
|
+
get(token) {
|
|
179
|
+
// Get all values and pick one out.
|
|
180
|
+
const values = this.all();
|
|
181
|
+
return values === null || values === void 0 ? void 0 : values[token];
|
|
182
|
+
}
|
|
183
|
+
set(token, value, attributes) {
|
|
184
|
+
// Validate that the storage is supported.
|
|
185
|
+
if (!this._isSupported) {
|
|
186
|
+
return;
|
|
187
|
+
}
|
|
188
|
+
// Write a new cookie.
|
|
189
|
+
document.cookie = this.encode(token, value, Object.assign({ path: '/', sameSite: 'Lax' }, attributes));
|
|
190
|
+
}
|
|
191
|
+
remove(token, attributes) {
|
|
192
|
+
// Validate that the storage is supported.
|
|
193
|
+
if (!this._isSupported) {
|
|
194
|
+
return;
|
|
195
|
+
}
|
|
196
|
+
this.set(token, '', Object.assign(Object.assign({}, attributes), { expires: -1 }));
|
|
197
|
+
}
|
|
198
|
+
clear(attributes) {
|
|
199
|
+
// Validate that the storage is supported.
|
|
200
|
+
if (!this._isSupported) {
|
|
201
|
+
return;
|
|
202
|
+
}
|
|
203
|
+
const items = this.all();
|
|
204
|
+
for (const token in items) {
|
|
205
|
+
this.remove(token, attributes);
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
isSupported() {
|
|
209
|
+
return this._isSupported;
|
|
210
|
+
}
|
|
211
|
+
all() {
|
|
212
|
+
const cookieString = this._isBrowser
|
|
213
|
+
? document === null || document === void 0 ? void 0 : document.cookie
|
|
214
|
+
: this._cookieString;
|
|
215
|
+
return this.decode(cookieString);
|
|
216
|
+
}
|
|
217
|
+
encode(token, value, attributes) {
|
|
218
|
+
// Encode the token.
|
|
219
|
+
const encodedToken = encodeURIComponent(token)
|
|
220
|
+
.replace(/%(23|24|26|2B|5E|60|7C)/g, decodeURIComponent)
|
|
221
|
+
.replace(/\(/g, '%28').replace(/\)/g, '%29');
|
|
222
|
+
const rawValue = JSON.stringify(value);
|
|
223
|
+
// Encode the value.
|
|
224
|
+
const encodedValue = encodeURIComponent(rawValue)
|
|
225
|
+
.replace(/%(23|24|26|2B|3A|3C|3E|3D|2F|3F|40|5B|5D|5E|60|7B|7D|7C)/g, decodeURIComponent);
|
|
226
|
+
// Return the completed encoded string.
|
|
227
|
+
return [encodedToken, '=', encodedValue, this.stringifyCookie(attributes)].join('');
|
|
228
|
+
}
|
|
229
|
+
stringifyCookie(attributes) {
|
|
230
|
+
var _a;
|
|
231
|
+
// Make sure the expires attribute is a date and not a number.
|
|
232
|
+
if (typeof attributes.expires === 'number') {
|
|
233
|
+
const expires = new Date();
|
|
234
|
+
expires.setMilliseconds(expires.getMilliseconds() + attributes.expires * 864e+5);
|
|
235
|
+
attributes.expires = expires;
|
|
236
|
+
}
|
|
237
|
+
// Force secure when sameSite=None.
|
|
238
|
+
if (attributes.sameSite === 'None') {
|
|
239
|
+
attributes.secure = true;
|
|
240
|
+
(_a = console === null || console === void 0 ? void 0 : console.warn) === null || _a === void 0 ? void 0 : _a.call(console, 'Cooke was forced with secure flag because sameSite=None');
|
|
241
|
+
}
|
|
242
|
+
// Stringify all attributes.
|
|
243
|
+
return this.stringifyAttribute('Expires', attributes.expires ? attributes.expires.toUTCString() : '')
|
|
244
|
+
+ this.stringifyAttribute('Domain', attributes.domain)
|
|
245
|
+
+ this.stringifyAttribute('Path', attributes.path)
|
|
246
|
+
+ this.stringifyAttribute('Secure', attributes.secure)
|
|
247
|
+
+ this.stringifyAttribute('SameSite', attributes.sameSite);
|
|
248
|
+
}
|
|
249
249
|
}
|
|
250
250
|
|
|
251
|
-
class MemoryStorage {
|
|
252
|
-
constructor() {
|
|
253
|
-
// State.
|
|
254
|
-
this._storage = {};
|
|
255
|
-
this.encode = (value, attributes) => {
|
|
256
|
-
const data = { value };
|
|
257
|
-
// Make sure the expires is a date object.
|
|
258
|
-
if (typeof attributes.expires === 'number') {
|
|
259
|
-
attributes.expires = new Date(attributes.expires);
|
|
260
|
-
}
|
|
261
|
-
// Add the expire date if it was set.
|
|
262
|
-
if (attributes.expires) {
|
|
263
|
-
data['expires'] = attributes.expires;
|
|
264
|
-
}
|
|
265
|
-
// Return the encoded data.
|
|
266
|
-
return data;
|
|
267
|
-
};
|
|
268
|
-
}
|
|
269
|
-
get(token) {
|
|
270
|
-
// Grab the data from the memory storage.
|
|
271
|
-
const result = this._storage[token];
|
|
272
|
-
// Validate the data exists.
|
|
273
|
-
if (result === undefined) {
|
|
274
|
-
return undefined;
|
|
275
|
-
}
|
|
276
|
-
// Extract the value and expire date.
|
|
277
|
-
const { value, expires } = result;
|
|
278
|
-
// Validate the value is still valid.
|
|
279
|
-
if (expires !== undefined) {
|
|
280
|
-
const now = Date.now();
|
|
281
|
-
const expireDate = new Date(expires).getTime();
|
|
282
|
-
// Remove the value if it is expired.
|
|
283
|
-
if (expireDate <= now) {
|
|
284
|
-
this.remove(token);
|
|
285
|
-
return undefined;
|
|
286
|
-
}
|
|
287
|
-
}
|
|
288
|
-
// Return the value.
|
|
289
|
-
return value;
|
|
290
|
-
}
|
|
291
|
-
set(token, value, attributes) {
|
|
292
|
-
// Save the encoded value with the attributes.
|
|
293
|
-
this._storage[token] = this.encode(value, Object.assign({}, attributes));
|
|
294
|
-
}
|
|
295
|
-
remove(token) {
|
|
296
|
-
delete this._storage[token];
|
|
297
|
-
}
|
|
298
|
-
clear() {
|
|
299
|
-
this._storage = {};
|
|
300
|
-
}
|
|
301
|
-
isSupported() {
|
|
302
|
-
// The memory storage is always supported.
|
|
303
|
-
return true;
|
|
304
|
-
}
|
|
251
|
+
class MemoryStorage {
|
|
252
|
+
constructor() {
|
|
253
|
+
// State.
|
|
254
|
+
this._storage = {};
|
|
255
|
+
this.encode = (value, attributes) => {
|
|
256
|
+
const data = { value };
|
|
257
|
+
// Make sure the expires is a date object.
|
|
258
|
+
if (typeof attributes.expires === 'number') {
|
|
259
|
+
attributes.expires = new Date(attributes.expires);
|
|
260
|
+
}
|
|
261
|
+
// Add the expire date if it was set.
|
|
262
|
+
if (attributes.expires) {
|
|
263
|
+
data['expires'] = attributes.expires;
|
|
264
|
+
}
|
|
265
|
+
// Return the encoded data.
|
|
266
|
+
return data;
|
|
267
|
+
};
|
|
268
|
+
}
|
|
269
|
+
get(token) {
|
|
270
|
+
// Grab the data from the memory storage.
|
|
271
|
+
const result = this._storage[token];
|
|
272
|
+
// Validate the data exists.
|
|
273
|
+
if (result === undefined) {
|
|
274
|
+
return undefined;
|
|
275
|
+
}
|
|
276
|
+
// Extract the value and expire date.
|
|
277
|
+
const { value, expires } = result;
|
|
278
|
+
// Validate the value is still valid.
|
|
279
|
+
if (expires !== undefined) {
|
|
280
|
+
const now = Date.now();
|
|
281
|
+
const expireDate = new Date(expires).getTime();
|
|
282
|
+
// Remove the value if it is expired.
|
|
283
|
+
if (expireDate <= now) {
|
|
284
|
+
this.remove(token);
|
|
285
|
+
return undefined;
|
|
286
|
+
}
|
|
287
|
+
}
|
|
288
|
+
// Return the value.
|
|
289
|
+
return value;
|
|
290
|
+
}
|
|
291
|
+
set(token, value, attributes) {
|
|
292
|
+
// Save the encoded value with the attributes.
|
|
293
|
+
this._storage[token] = this.encode(value, Object.assign({}, attributes));
|
|
294
|
+
}
|
|
295
|
+
remove(token) {
|
|
296
|
+
delete this._storage[token];
|
|
297
|
+
}
|
|
298
|
+
clear() {
|
|
299
|
+
this._storage = {};
|
|
300
|
+
}
|
|
301
|
+
isSupported() {
|
|
302
|
+
// The memory storage is always supported.
|
|
303
|
+
return true;
|
|
304
|
+
}
|
|
305
305
|
}
|
|
306
306
|
|
|
307
|
-
class Storage {
|
|
308
|
-
constructor(_platform, _cookieString) {
|
|
309
|
-
this._platform = _platform;
|
|
310
|
-
this._cookieString = _cookieString;
|
|
311
|
-
// Current selected storage strategy.
|
|
312
|
-
this._current = null;
|
|
313
|
-
this.getLocalStorage = () => {
|
|
314
|
-
try {
|
|
315
|
-
return (typeof window !== 'undefined') ? window === null || window === void 0 ? void 0 : window.localStorage : null;
|
|
316
|
-
}
|
|
317
|
-
catch (_a) {
|
|
318
|
-
return null;
|
|
319
|
-
}
|
|
320
|
-
};
|
|
321
|
-
this.getSessionStorage = () => {
|
|
322
|
-
try {
|
|
323
|
-
return (typeof window !== 'undefined') ? window === null || window === void 0 ? void 0 : window.sessionStorage : null;
|
|
324
|
-
}
|
|
325
|
-
catch (_a) {
|
|
326
|
-
return null;
|
|
327
|
-
}
|
|
328
|
-
};
|
|
329
|
-
this._strategies = {
|
|
330
|
-
["local" /* StorageOption.Local */]: new PolyfillStorage(this.getLocalStorage()),
|
|
331
|
-
["cookie" /* StorageOption.Cookie */]: new CookieStorage(this._platform.isBrowser, this._cookieString),
|
|
332
|
-
["session" /* StorageOption.Session */]: new PolyfillStorage(this.getSessionStorage()),
|
|
333
|
-
["memory" /* StorageOption.Memory */]: new MemoryStorage()
|
|
334
|
-
};
|
|
335
|
-
this._current = this.findBestStorageStrategy();
|
|
336
|
-
}
|
|
337
|
-
select(option) {
|
|
338
|
-
var _a, _b, _c;
|
|
339
|
-
const items = Array.isArray(option) ? option : [option];
|
|
340
|
-
for (const item of items) {
|
|
341
|
-
const strategy = (_b = (_a = this._strategies) === null || _a === void 0 ? void 0 : _a[item]) !== null && _b !== void 0 ? _b : null;
|
|
342
|
-
if (strategy && strategy.isSupported()) {
|
|
343
|
-
return strategy;
|
|
344
|
-
}
|
|
345
|
-
}
|
|
346
|
-
if (this._platform.isBrowser && isDevMode()) {
|
|
347
|
-
(_c = console === null || console === void 0 ? void 0 : console.warn) === null || _c === void 0 ? void 0 : _c.call(console, '[Storage]: Could not select proper storage option, using memory fallback.');
|
|
348
|
-
}
|
|
349
|
-
// Always return as a fallback the memory storage since it should be always available.
|
|
350
|
-
return this._strategies.memory;
|
|
351
|
-
}
|
|
352
|
-
get local() {
|
|
353
|
-
return this._strategies.local;
|
|
354
|
-
}
|
|
355
|
-
get cookie() {
|
|
356
|
-
return this._strategies.cookie;
|
|
357
|
-
}
|
|
358
|
-
get session() {
|
|
359
|
-
return this._strategies.session;
|
|
360
|
-
}
|
|
361
|
-
get memory() {
|
|
362
|
-
return this._strategies.memory;
|
|
363
|
-
}
|
|
364
|
-
get(token) {
|
|
365
|
-
return this._current.get(token);
|
|
366
|
-
}
|
|
367
|
-
set(token, value, attributes) {
|
|
368
|
-
this._current.set(token, value, attributes);
|
|
369
|
-
}
|
|
370
|
-
remove(token, attributes) {
|
|
371
|
-
this._current.remove(token, attributes);
|
|
372
|
-
}
|
|
373
|
-
clear(attributes) {
|
|
374
|
-
this._current.clear(attributes);
|
|
375
|
-
}
|
|
376
|
-
isSupported() {
|
|
377
|
-
return !!this._current;
|
|
378
|
-
}
|
|
379
|
-
findBestStorageStrategy() {
|
|
380
|
-
var _a, _b;
|
|
381
|
-
// Loop through all available strategies to find the best.
|
|
382
|
-
for (const type in this._strategies) {
|
|
383
|
-
const strategy = (_a = this._strategies) === null || _a === void 0 ? void 0 : _a[type];
|
|
384
|
-
// The first supported strategy is the best.
|
|
385
|
-
if (strategy === null || strategy === void 0 ? void 0 : strategy.isSupported()) {
|
|
386
|
-
return strategy;
|
|
387
|
-
}
|
|
388
|
-
}
|
|
389
|
-
// If no strategy was returned we fallback to memory
|
|
390
|
-
// storage since it should be available always.
|
|
391
|
-
if (this._platform.isBrowser && isDevMode()) {
|
|
392
|
-
(_b = console === null || console === void 0 ? void 0 : console.warn) === null || _b === void 0 ? void 0 : _b.call(console, '[Storage]: Could not select proper storage option, using memory fallback.');
|
|
393
|
-
}
|
|
394
|
-
return this._strategies.memory;
|
|
395
|
-
}
|
|
396
|
-
}
|
|
397
|
-
Storage.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.
|
|
398
|
-
Storage.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.0.
|
|
399
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.
|
|
400
|
-
type: Injectable,
|
|
401
|
-
args: [{
|
|
402
|
-
providedIn: 'root'
|
|
403
|
-
}]
|
|
404
|
-
}], ctorParameters: function () {
|
|
405
|
-
return [{ type: i1.Platform }, { type: undefined, decorators: [{
|
|
406
|
-
type: Optional
|
|
407
|
-
}, {
|
|
408
|
-
type: Inject,
|
|
409
|
-
args: [COOKIE]
|
|
410
|
-
}] }];
|
|
307
|
+
class Storage {
|
|
308
|
+
constructor(_platform, _cookieString) {
|
|
309
|
+
this._platform = _platform;
|
|
310
|
+
this._cookieString = _cookieString;
|
|
311
|
+
// Current selected storage strategy.
|
|
312
|
+
this._current = null;
|
|
313
|
+
this.getLocalStorage = () => {
|
|
314
|
+
try {
|
|
315
|
+
return (typeof window !== 'undefined') ? window === null || window === void 0 ? void 0 : window.localStorage : null;
|
|
316
|
+
}
|
|
317
|
+
catch (_a) {
|
|
318
|
+
return null;
|
|
319
|
+
}
|
|
320
|
+
};
|
|
321
|
+
this.getSessionStorage = () => {
|
|
322
|
+
try {
|
|
323
|
+
return (typeof window !== 'undefined') ? window === null || window === void 0 ? void 0 : window.sessionStorage : null;
|
|
324
|
+
}
|
|
325
|
+
catch (_a) {
|
|
326
|
+
return null;
|
|
327
|
+
}
|
|
328
|
+
};
|
|
329
|
+
this._strategies = {
|
|
330
|
+
["local" /* StorageOption.Local */]: new PolyfillStorage(this.getLocalStorage()),
|
|
331
|
+
["cookie" /* StorageOption.Cookie */]: new CookieStorage(this._platform.isBrowser, this._cookieString),
|
|
332
|
+
["session" /* StorageOption.Session */]: new PolyfillStorage(this.getSessionStorage()),
|
|
333
|
+
["memory" /* StorageOption.Memory */]: new MemoryStorage()
|
|
334
|
+
};
|
|
335
|
+
this._current = this.findBestStorageStrategy();
|
|
336
|
+
}
|
|
337
|
+
select(option) {
|
|
338
|
+
var _a, _b, _c;
|
|
339
|
+
const items = Array.isArray(option) ? option : [option];
|
|
340
|
+
for (const item of items) {
|
|
341
|
+
const strategy = (_b = (_a = this._strategies) === null || _a === void 0 ? void 0 : _a[item]) !== null && _b !== void 0 ? _b : null;
|
|
342
|
+
if (strategy && strategy.isSupported()) {
|
|
343
|
+
return strategy;
|
|
344
|
+
}
|
|
345
|
+
}
|
|
346
|
+
if (this._platform.isBrowser && isDevMode()) {
|
|
347
|
+
(_c = console === null || console === void 0 ? void 0 : console.warn) === null || _c === void 0 ? void 0 : _c.call(console, '[Storage]: Could not select proper storage option, using memory fallback.');
|
|
348
|
+
}
|
|
349
|
+
// Always return as a fallback the memory storage since it should be always available.
|
|
350
|
+
return this._strategies.memory;
|
|
351
|
+
}
|
|
352
|
+
get local() {
|
|
353
|
+
return this._strategies.local;
|
|
354
|
+
}
|
|
355
|
+
get cookie() {
|
|
356
|
+
return this._strategies.cookie;
|
|
357
|
+
}
|
|
358
|
+
get session() {
|
|
359
|
+
return this._strategies.session;
|
|
360
|
+
}
|
|
361
|
+
get memory() {
|
|
362
|
+
return this._strategies.memory;
|
|
363
|
+
}
|
|
364
|
+
get(token) {
|
|
365
|
+
return this._current.get(token);
|
|
366
|
+
}
|
|
367
|
+
set(token, value, attributes) {
|
|
368
|
+
this._current.set(token, value, attributes);
|
|
369
|
+
}
|
|
370
|
+
remove(token, attributes) {
|
|
371
|
+
this._current.remove(token, attributes);
|
|
372
|
+
}
|
|
373
|
+
clear(attributes) {
|
|
374
|
+
this._current.clear(attributes);
|
|
375
|
+
}
|
|
376
|
+
isSupported() {
|
|
377
|
+
return !!this._current;
|
|
378
|
+
}
|
|
379
|
+
findBestStorageStrategy() {
|
|
380
|
+
var _a, _b;
|
|
381
|
+
// Loop through all available strategies to find the best.
|
|
382
|
+
for (const type in this._strategies) {
|
|
383
|
+
const strategy = (_a = this._strategies) === null || _a === void 0 ? void 0 : _a[type];
|
|
384
|
+
// The first supported strategy is the best.
|
|
385
|
+
if (strategy === null || strategy === void 0 ? void 0 : strategy.isSupported()) {
|
|
386
|
+
return strategy;
|
|
387
|
+
}
|
|
388
|
+
}
|
|
389
|
+
// If no strategy was returned we fallback to memory
|
|
390
|
+
// storage since it should be available always.
|
|
391
|
+
if (this._platform.isBrowser && isDevMode()) {
|
|
392
|
+
(_b = console === null || console === void 0 ? void 0 : console.warn) === null || _b === void 0 ? void 0 : _b.call(console, '[Storage]: Could not select proper storage option, using memory fallback.');
|
|
393
|
+
}
|
|
394
|
+
return this._strategies.memory;
|
|
395
|
+
}
|
|
396
|
+
}
|
|
397
|
+
Storage.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: Storage, deps: [{ token: i1.Platform }, { token: COOKIE, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
398
|
+
Storage.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: Storage, providedIn: 'root' });
|
|
399
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: Storage, decorators: [{
|
|
400
|
+
type: Injectable,
|
|
401
|
+
args: [{
|
|
402
|
+
providedIn: 'root'
|
|
403
|
+
}]
|
|
404
|
+
}], ctorParameters: function () {
|
|
405
|
+
return [{ type: i1.Platform }, { type: undefined, decorators: [{
|
|
406
|
+
type: Optional
|
|
407
|
+
}, {
|
|
408
|
+
type: Inject,
|
|
409
|
+
args: [COOKIE]
|
|
410
|
+
}] }];
|
|
411
411
|
} });
|
|
412
412
|
|
|
413
|
-
/**
|
|
414
|
-
* Generated bundle index. Do not edit.
|
|
413
|
+
/**
|
|
414
|
+
* Generated bundle index. Do not edit.
|
|
415
415
|
*/
|
|
416
416
|
|
|
417
417
|
export { CookieStorage, MemoryStorage, PolyfillStorage, Storage };
|