@bravobit/bb-foundation 0.23.6 → 0.24.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (209) hide show
  1. package/auth/lib/auth.module.d.ts +2 -3
  2. package/auth/lib/auth.session.d.ts +5 -0
  3. package/auth/lib/interfaces/config.interface.d.ts +0 -4
  4. package/auth/public_api.d.ts +0 -5
  5. package/esm2020/auth/lib/auth.interceptor.mjs +4 -4
  6. package/esm2020/auth/lib/auth.module.mjs +7 -16
  7. package/esm2020/auth/lib/auth.service.mjs +6 -6
  8. package/esm2020/auth/lib/auth.session.mjs +8 -1
  9. package/esm2020/auth/lib/directives/authenticated.directive.mjs +4 -4
  10. package/esm2020/auth/lib/guards/anonymous.guard.mjs +4 -4
  11. package/esm2020/auth/lib/guards/authenticated.guard.mjs +4 -4
  12. package/esm2020/auth/lib/interfaces/config.interface.mjs +1 -1
  13. package/esm2020/auth/public_api.mjs +1 -6
  14. package/esm2020/collections/lib/collections.module.mjs +5 -5
  15. package/esm2020/collections/lib/components/collections-pager/collections-pager.component.mjs +4 -4
  16. package/esm2020/collections/lib/components/collections-viewer/collections-viewer.component.mjs +4 -4
  17. package/esm2020/collections/lib/components/collections.directive.mjs +13 -13
  18. package/esm2020/controls/lib/checkbox/checkbox/checkbox.component.mjs +4 -4
  19. package/esm2020/controls/lib/checkbox/checkbox-group/checkbox-group.component.mjs +4 -4
  20. package/esm2020/controls/lib/checkbox/checkbox.module.mjs +5 -5
  21. package/esm2020/controls/lib/control-error/control-error/control-error.component.mjs +4 -4
  22. package/esm2020/controls/lib/control-error/control-error-submit.directive.mjs +4 -4
  23. package/esm2020/controls/lib/control-error/control-error.module.mjs +5 -5
  24. package/esm2020/controls/lib/controls.module.mjs +5 -5
  25. package/esm2020/controls/lib/form-control/form-control/form-control.component.mjs +4 -4
  26. package/esm2020/controls/lib/form-control/form-control-addon/form-control-addon.component.mjs +4 -4
  27. package/esm2020/controls/lib/form-control/form-control-input.directive.mjs +4 -4
  28. package/esm2020/controls/lib/form-control/form-control.module.mjs +5 -5
  29. package/esm2020/controls/lib/radio/radio-button/radio-button.component.mjs +4 -4
  30. package/esm2020/controls/lib/radio/radio-group/radio-group.component.mjs +4 -4
  31. package/esm2020/controls/lib/radio/radio.module.mjs +5 -5
  32. package/esm2020/controls/lib/toggle/toggle/toggle.component.mjs +4 -4
  33. package/esm2020/controls/lib/toggle/toggle-group/toggle-group.component.mjs +4 -4
  34. package/esm2020/controls/lib/toggle/toggle.module.mjs +5 -5
  35. package/esm2020/dashboard/lib/dashboard/dashboard.component.mjs +4 -4
  36. package/esm2020/dashboard/lib/dashboard-header/dashboard-header.component.mjs +4 -4
  37. package/esm2020/dashboard/lib/dashboard-menu/dashboard-menu.component.mjs +4 -4
  38. package/esm2020/dashboard/lib/dashboard-menu-item/dashboard-menu-item.component.mjs +4 -4
  39. package/esm2020/dashboard/lib/dashboard-sidebar/dashboard-sidebar.component.mjs +4 -4
  40. package/esm2020/dashboard/lib/dashboard-sidebar-group/dashboard-sidebar-group.component.mjs +4 -4
  41. package/esm2020/dashboard/lib/dashboard-sidebar-item/dashboard-sidebar-item.component.mjs +4 -4
  42. package/esm2020/dashboard/lib/dashboard.module.mjs +5 -5
  43. package/esm2020/dialog/lib/dialog-actions/dialog-actions.component.mjs +4 -4
  44. package/esm2020/dialog/lib/dialog-confirm/dialog-confirm.component.mjs +4 -4
  45. package/esm2020/dialog/lib/dialog-container/dialog-container.component.mjs +4 -4
  46. package/esm2020/dialog/lib/dialog-header/dialog-header.component.mjs +4 -4
  47. package/esm2020/dialog/lib/dialog-link/dialog-link.component.mjs +4 -4
  48. package/esm2020/dialog/lib/dialog-modal/dialog-modal.component.mjs +4 -4
  49. package/esm2020/dialog/lib/dialog-overlay/dialog-overlay.component.mjs +4 -4
  50. package/esm2020/dialog/lib/dialog.insertion.mjs +4 -4
  51. package/esm2020/dialog/lib/dialog.module.mjs +5 -5
  52. package/esm2020/dialog/lib/dialog.service.mjs +4 -4
  53. package/esm2020/elements/lib/avatar/avatar.component.mjs +4 -4
  54. package/esm2020/elements/lib/button/button.component.mjs +7 -7
  55. package/esm2020/elements/lib/checkbox/checkbox.component.mjs +4 -4
  56. package/esm2020/elements/lib/date-picker/date-picker.component.mjs +4 -4
  57. package/esm2020/elements/lib/directives/addon.directive.mjs +7 -7
  58. package/esm2020/elements/lib/directives/form-submit.directive.mjs +4 -4
  59. package/esm2020/elements/lib/directives/form-submitter.directive.mjs +4 -4
  60. package/esm2020/elements/lib/directives/input.directive.mjs +7 -7
  61. package/esm2020/elements/lib/dropdown/dropdown.component.mjs +7 -7
  62. package/esm2020/elements/lib/elements.module.mjs +5 -5
  63. package/esm2020/elements/lib/file-picker/file-picker.component.mjs +4 -4
  64. package/esm2020/elements/lib/form-control/form-control.component.mjs +4 -4
  65. package/esm2020/elements/lib/form-error/form-error.component.mjs +4 -4
  66. package/esm2020/elements/lib/form-group/form-group.component.mjs +4 -4
  67. package/esm2020/elements/lib/icon/icon.component.mjs +4 -4
  68. package/esm2020/elements/lib/image-picker/image-picker.component.mjs +4 -4
  69. package/esm2020/elements/lib/pipes/file-image.pipe.mjs +4 -4
  70. package/esm2020/elements/lib/pipes/file-size.pipe.mjs +4 -4
  71. package/esm2020/elements/lib/pipes/relative-time.pipe.mjs +4 -4
  72. package/esm2020/elements/lib/spinner/spinner.component.mjs +4 -4
  73. package/esm2020/elements/lib/tag/tag.component.mjs +4 -4
  74. package/esm2020/http/lib/http.module.mjs +5 -5
  75. package/esm2020/http/lib/interceptors/base-url.interceptor.mjs +4 -4
  76. package/esm2020/http/lib/interceptors/error.interceptor.mjs +4 -4
  77. package/esm2020/lib/core/services/clipboard.service.mjs +4 -4
  78. package/esm2020/lib/core/services/exif.service.mjs +4 -4
  79. package/esm2020/lib/core/services/file-loader.service.mjs +4 -4
  80. package/esm2020/lib/core/services/image-converter.service.mjs +4 -4
  81. package/esm2020/lib/core/services/languages.service.mjs +4 -4
  82. package/esm2020/lib/core/services/network.service.mjs +4 -4
  83. package/esm2020/lib/core/services/patch.service.mjs +4 -4
  84. package/esm2020/localize/lib/localize.module.mjs +5 -5
  85. package/esm2020/localize/lib/localize.pipe.mjs +4 -4
  86. package/esm2020/localize/lib/localize.service.mjs +4 -4
  87. package/esm2020/localize/lib/views/localize-string/localize-string.component.mjs +4 -4
  88. package/esm2020/localize/lib/views/localize-template.directive.mjs +4 -4
  89. package/esm2020/masking/lib/directives/currency-mask.directive.mjs +4 -4
  90. package/esm2020/masking/lib/directives/date-mask.directive.mjs +4 -4
  91. package/esm2020/masking/lib/directives/input-mask.directive.mjs +4 -4
  92. package/esm2020/masking/lib/masking.module.mjs +5 -5
  93. package/esm2020/masking/lib/masking.service.mjs +4 -4
  94. package/esm2020/notifications/lib/notifications-item/notifications-item.component.mjs +4 -4
  95. package/esm2020/notifications/lib/notifications-list/notifications-list.component.mjs +4 -4
  96. package/esm2020/notifications/lib/notifications.module.mjs +5 -5
  97. package/esm2020/notifications/lib/notifications.service.mjs +4 -4
  98. package/esm2020/permissions/bravobit-bb-foundation-permissions.mjs +5 -0
  99. package/esm2020/permissions/lib/directives/permission.directive.mjs +88 -0
  100. package/esm2020/permissions/lib/guards/permission.guard.mjs +57 -0
  101. package/esm2020/permissions/lib/handlers/abstract.handler.mjs +3 -0
  102. package/esm2020/permissions/lib/handlers/role.handler.mjs +27 -0
  103. package/esm2020/permissions/lib/permissions.interface.mjs +3 -0
  104. package/esm2020/permissions/lib/permissions.module.mjs +39 -0
  105. package/esm2020/permissions/lib/permissions.service.mjs +86 -0
  106. package/esm2020/permissions/public_api.mjs +8 -0
  107. package/esm2020/recaptcha/lib/recaptcha/recaptcha.component.mjs +4 -4
  108. package/esm2020/recaptcha/lib/recaptcha-loader.service.mjs +4 -4
  109. package/esm2020/recaptcha/lib/recaptcha.module.mjs +5 -5
  110. package/esm2020/storage/lib/storage.service.mjs +4 -4
  111. package/esm2020/table/lib/components/table/table.component.mjs +10 -10
  112. package/esm2020/table/lib/components/table-cell/table-cell.component.mjs +4 -4
  113. package/esm2020/table/lib/components/table-header-cell/table-header-cell.component.mjs +4 -4
  114. package/esm2020/table/lib/components/table-pager/table-pager.component.mjs +4 -4
  115. package/esm2020/table/lib/table.module.mjs +5 -5
  116. package/esm2020/theming/lib/theming.directive.mjs +4 -4
  117. package/esm2020/theming/lib/theming.module.mjs +5 -5
  118. package/esm2020/utils/lib/directives/autosize.directive.mjs +4 -4
  119. package/esm2020/utils/lib/directives/focus-trap.directive.mjs +4 -4
  120. package/esm2020/utils/lib/directives/focus.directive.mjs +4 -4
  121. package/esm2020/utils/lib/directives/template.directive.mjs +4 -4
  122. package/esm2020/utils/lib/utils.module.mjs +5 -5
  123. package/fesm2015/bravobit-bb-foundation-auth.mjs +40 -254
  124. package/fesm2015/bravobit-bb-foundation-auth.mjs.map +1 -1
  125. package/fesm2015/bravobit-bb-foundation-collections.mjs +22 -22
  126. package/fesm2015/bravobit-bb-foundation-collections.mjs.map +1 -1
  127. package/fesm2015/bravobit-bb-foundation-controls.mjs +57 -57
  128. package/fesm2015/bravobit-bb-foundation-controls.mjs.map +1 -1
  129. package/fesm2015/bravobit-bb-foundation-dashboard.mjs +25 -25
  130. package/fesm2015/bravobit-bb-foundation-dashboard.mjs.map +1 -1
  131. package/fesm2015/bravobit-bb-foundation-dialog.mjs +31 -31
  132. package/fesm2015/bravobit-bb-foundation-dialog.mjs.map +1 -1
  133. package/fesm2015/bravobit-bb-foundation-elements.mjs +76 -76
  134. package/fesm2015/bravobit-bb-foundation-elements.mjs.map +1 -1
  135. package/fesm2015/bravobit-bb-foundation-http.mjs +10 -10
  136. package/fesm2015/bravobit-bb-foundation-http.mjs.map +1 -1
  137. package/fesm2015/bravobit-bb-foundation-localize.mjs +16 -16
  138. package/fesm2015/bravobit-bb-foundation-localize.mjs.map +1 -1
  139. package/fesm2015/bravobit-bb-foundation-masking.mjs +16 -16
  140. package/fesm2015/bravobit-bb-foundation-masking.mjs.map +1 -1
  141. package/fesm2015/bravobit-bb-foundation-notifications.mjs +13 -13
  142. package/fesm2015/bravobit-bb-foundation-notifications.mjs.map +1 -1
  143. package/fesm2015/bravobit-bb-foundation-permissions.mjs +301 -0
  144. package/fesm2015/bravobit-bb-foundation-permissions.mjs.map +1 -0
  145. package/fesm2015/bravobit-bb-foundation-recaptcha.mjs +10 -10
  146. package/fesm2015/bravobit-bb-foundation-recaptcha.mjs.map +1 -1
  147. package/fesm2015/bravobit-bb-foundation-storage.mjs +3 -3
  148. package/fesm2015/bravobit-bb-foundation-storage.mjs.map +1 -1
  149. package/fesm2015/bravobit-bb-foundation-table.mjs +22 -22
  150. package/fesm2015/bravobit-bb-foundation-table.mjs.map +1 -1
  151. package/fesm2015/bravobit-bb-foundation-theming.mjs +7 -7
  152. package/fesm2015/bravobit-bb-foundation-theming.mjs.map +1 -1
  153. package/fesm2015/bravobit-bb-foundation-utils.mjs +16 -16
  154. package/fesm2015/bravobit-bb-foundation-utils.mjs.map +1 -1
  155. package/fesm2015/bravobit-bb-foundation.mjs +21 -21
  156. package/fesm2015/bravobit-bb-foundation.mjs.map +1 -1
  157. package/fesm2020/bravobit-bb-foundation-auth.mjs +33 -231
  158. package/fesm2020/bravobit-bb-foundation-auth.mjs.map +1 -1
  159. package/fesm2020/bravobit-bb-foundation-collections.mjs +22 -22
  160. package/fesm2020/bravobit-bb-foundation-collections.mjs.map +1 -1
  161. package/fesm2020/bravobit-bb-foundation-controls.mjs +57 -57
  162. package/fesm2020/bravobit-bb-foundation-controls.mjs.map +1 -1
  163. package/fesm2020/bravobit-bb-foundation-dashboard.mjs +25 -25
  164. package/fesm2020/bravobit-bb-foundation-dashboard.mjs.map +1 -1
  165. package/fesm2020/bravobit-bb-foundation-dialog.mjs +31 -31
  166. package/fesm2020/bravobit-bb-foundation-dialog.mjs.map +1 -1
  167. package/fesm2020/bravobit-bb-foundation-elements.mjs +76 -76
  168. package/fesm2020/bravobit-bb-foundation-elements.mjs.map +1 -1
  169. package/fesm2020/bravobit-bb-foundation-http.mjs +10 -10
  170. package/fesm2020/bravobit-bb-foundation-http.mjs.map +1 -1
  171. package/fesm2020/bravobit-bb-foundation-localize.mjs +16 -16
  172. package/fesm2020/bravobit-bb-foundation-localize.mjs.map +1 -1
  173. package/fesm2020/bravobit-bb-foundation-masking.mjs +16 -16
  174. package/fesm2020/bravobit-bb-foundation-masking.mjs.map +1 -1
  175. package/fesm2020/bravobit-bb-foundation-notifications.mjs +13 -13
  176. package/fesm2020/bravobit-bb-foundation-notifications.mjs.map +1 -1
  177. package/fesm2020/bravobit-bb-foundation-permissions.mjs +289 -0
  178. package/fesm2020/bravobit-bb-foundation-permissions.mjs.map +1 -0
  179. package/fesm2020/bravobit-bb-foundation-recaptcha.mjs +10 -10
  180. package/fesm2020/bravobit-bb-foundation-recaptcha.mjs.map +1 -1
  181. package/fesm2020/bravobit-bb-foundation-storage.mjs +3 -3
  182. package/fesm2020/bravobit-bb-foundation-storage.mjs.map +1 -1
  183. package/fesm2020/bravobit-bb-foundation-table.mjs +22 -22
  184. package/fesm2020/bravobit-bb-foundation-table.mjs.map +1 -1
  185. package/fesm2020/bravobit-bb-foundation-theming.mjs +7 -7
  186. package/fesm2020/bravobit-bb-foundation-theming.mjs.map +1 -1
  187. package/fesm2020/bravobit-bb-foundation-utils.mjs +16 -16
  188. package/fesm2020/bravobit-bb-foundation-utils.mjs.map +1 -1
  189. package/fesm2020/bravobit-bb-foundation.mjs +21 -21
  190. package/fesm2020/bravobit-bb-foundation.mjs.map +1 -1
  191. package/package.json +13 -5
  192. package/permissions/index.d.ts +5 -0
  193. package/{auth → permissions}/lib/directives/permission.directive.d.ts +9 -4
  194. package/{auth → permissions}/lib/guards/permission.guard.d.ts +4 -5
  195. package/permissions/lib/handlers/abstract.handler.d.ts +4 -0
  196. package/permissions/lib/handlers/role.handler.d.ts +9 -0
  197. package/permissions/lib/permissions.interface.d.ts +11 -0
  198. package/permissions/lib/permissions.module.d.ts +10 -0
  199. package/permissions/lib/permissions.service.d.ts +22 -0
  200. package/permissions/public_api.d.ts +7 -0
  201. package/README.md +0 -47
  202. package/auth/lib/interfaces/permission.interface.d.ts +0 -6
  203. package/auth/lib/permissions/permissions.handler.d.ts +0 -9
  204. package/auth/lib/permissions/permissions.service.d.ts +0 -16
  205. package/esm2020/auth/lib/directives/permission.directive.mjs +0 -58
  206. package/esm2020/auth/lib/guards/permission.guard.mjs +0 -63
  207. package/esm2020/auth/lib/interfaces/permission.interface.mjs +0 -2
  208. package/esm2020/auth/lib/permissions/permissions.handler.mjs +0 -33
  209. package/esm2020/auth/lib/permissions/permissions.service.mjs +0 -64
@@ -70,9 +70,9 @@ export class RecaptchaLoader {
70
70
  .join('&');
71
71
  }
72
72
  }
73
- RecaptchaLoader.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: RecaptchaLoader, deps: [{ token: i1.Platform }, { token: i0.RendererFactory2 }, { token: i2.Localize, optional: true }, { token: LOCALE_ID, optional: true }, { token: DOCUMENT, optional: true }, { token: RECAPTCHA_CONFIG, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
74
- RecaptchaLoader.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: RecaptchaLoader });
75
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: RecaptchaLoader, decorators: [{
73
+ RecaptchaLoader.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: RecaptchaLoader, deps: [{ token: i1.Platform }, { token: i0.RendererFactory2 }, { token: i2.Localize, optional: true }, { token: LOCALE_ID, optional: true }, { token: DOCUMENT, optional: true }, { token: RECAPTCHA_CONFIG, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
74
+ RecaptchaLoader.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: RecaptchaLoader });
75
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: RecaptchaLoader, decorators: [{
76
76
  type: Injectable
77
77
  }], ctorParameters: function () { return [{ type: i1.Platform }, { type: i0.RendererFactory2 }, { type: i2.Localize, decorators: [{
78
78
  type: Optional
@@ -92,4 +92,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.2", ngImpor
92
92
  type: Inject,
93
93
  args: [RECAPTCHA_CONFIG]
94
94
  }] }]; } });
95
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"recaptcha-loader.service.js","sourceRoot":"","sources":["../../../../../projects/bb-foundation/recaptcha/src/lib/recaptcha-loader.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Inject, Injectable, LOCALE_ID, Optional, Renderer2, RendererFactory2} from '@angular/core';\nimport {RECAPTCHA_CONFIG, RecaptchaConfig} from './recaptcha.interface';\nimport {Localize} from '@bravobit/bb-foundation/localize';\nimport {Platform} from '@angular/cdk/platform';\nimport {DOCUMENT} from '@angular/common';\nimport {BehaviorSubject} from 'rxjs';\n\n@Injectable()\nexport class RecaptchaLoader {\n\n    // Ready state.\n    readonly ready$: BehaviorSubject<ReCaptchaV2.ReCaptcha | null> | null = null;\n\n    // Data.\n    private readonly _windowLoadFn: string = 'bbRecaptchaLoad';\n    private readonly _renderer: Renderer2 | null = null;\n\n    constructor(private _platform: Platform,\n                private _renderFactory: RendererFactory2,\n                @Optional() private _localize?: Localize,\n                @Optional() @Inject(LOCALE_ID) private _localeId?: string,\n                @Optional() @Inject(DOCUMENT) private _document?: Document,\n                @Optional() @Inject(RECAPTCHA_CONFIG) private _config?: RecaptchaConfig) {\n        // Create a renderer.\n        this._renderer = this._renderFactory.createRenderer(null, null);\n\n        // Set the ready subject if not exists.\n        if (this.ready$) {\n            return;\n        }\n        this.ready$ = new BehaviorSubject<ReCaptchaV2.ReCaptcha | null>(null);\n\n        // Create the script.\n        this.createScript(captcha => this.ready$.next(captcha));\n    }\n\n    private createScript(callback: (grecaptcha: ReCaptchaV2.ReCaptcha) => void) {\n        // Validate we are on a browser.\n        if (!this._platform.isBrowser) {\n            return;\n        }\n\n        // Create the script.\n        const script = this._renderer.createElement('script');\n\n        // Set properties on the script.\n        this._renderer.setProperty(script, 'src', this.getUrl());\n        this._renderer.setProperty(script, 'async', true);\n        this._renderer.setProperty(script, 'defer', true);\n\n        // Set the nonce.\n        if (this._config.nonce) {\n            this._renderer.setAttribute(script, 'nonce', this._config.nonce);\n        }\n\n        // Set the loading function.\n        if (this._platform.isBrowser) {\n            window[this._windowLoadFn] = () => callback(grecaptcha);\n        }\n\n        // Append the script tag.\n        this._renderer.appendChild(this._document?.body, script);\n    }\n\n    private getUrl() {\n        const baseUrl = this._config?.baseUrl ?? 'https://www.google.com/recaptcha/api.js';\n        return [baseUrl, this.getQueryParams()]\n            .filter(item => !!item)\n            .join('?');\n    }\n\n    private getQueryParams() {\n        const localeId = this._localize?.current?.id ?? this._localeId ?? null;\n        const params = {\n            render: 'explicit',\n            onload: this._windowLoadFn ?? null,\n            hl: localeId\n        };\n\n        return Object.keys(params)\n            .map(key => ({key, value: params[key]}))\n            .filter(item => !!item.value)\n            .map(item => `${item?.key}=${item?.value}`)\n            .join('&');\n    }\n\n}\n"]}
95
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"recaptcha-loader.service.js","sourceRoot":"","sources":["../../../../../projects/bb-foundation/recaptcha/src/lib/recaptcha-loader.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Inject, Injectable, LOCALE_ID, Optional, Renderer2, RendererFactory2} from '@angular/core';\nimport {RECAPTCHA_CONFIG, RecaptchaConfig} from './recaptcha.interface';\nimport {Localize} from '@bravobit/bb-foundation/localize';\nimport {Platform} from '@angular/cdk/platform';\nimport {DOCUMENT} from '@angular/common';\nimport {BehaviorSubject} from 'rxjs';\n\n@Injectable()\nexport class RecaptchaLoader {\n\n    // Ready state.\n    readonly ready$: BehaviorSubject<ReCaptchaV2.ReCaptcha | null> | null = null;\n\n    // Data.\n    private readonly _windowLoadFn: string = 'bbRecaptchaLoad';\n    private readonly _renderer: Renderer2 | null = null;\n\n    constructor(private _platform: Platform,\n                private _renderFactory: RendererFactory2,\n                @Optional() private _localize?: Localize,\n                @Optional() @Inject(LOCALE_ID) private _localeId?: string,\n                @Optional() @Inject(DOCUMENT) private _document?: Document,\n                @Optional() @Inject(RECAPTCHA_CONFIG) private _config?: RecaptchaConfig) {\n        // Create a renderer.\n        this._renderer = this._renderFactory.createRenderer(null, null);\n\n        // Set the ready subject if not exists.\n        if (this.ready$) {\n            return;\n        }\n        this.ready$ = new BehaviorSubject<ReCaptchaV2.ReCaptcha | null>(null);\n\n        // Create the script.\n        this.createScript(captcha => this.ready$.next(captcha));\n    }\n\n    private createScript(callback: (grecaptcha: ReCaptchaV2.ReCaptcha) => void) {\n        // Validate we are on a browser.\n        if (!this._platform.isBrowser) {\n            return;\n        }\n\n        // Create the script.\n        const script = this._renderer.createElement('script');\n\n        // Set properties on the script.\n        this._renderer.setProperty(script, 'src', this.getUrl());\n        this._renderer.setProperty(script, 'async', true);\n        this._renderer.setProperty(script, 'defer', true);\n\n        // Set the nonce.\n        if (this._config.nonce) {\n            this._renderer.setAttribute(script, 'nonce', this._config.nonce);\n        }\n\n        // Set the loading function.\n        if (this._platform.isBrowser) {\n            window[this._windowLoadFn] = () => callback(grecaptcha);\n        }\n\n        // Append the script tag.\n        this._renderer.appendChild(this._document?.body, script);\n    }\n\n    private getUrl() {\n        const baseUrl = this._config?.baseUrl ?? 'https://www.google.com/recaptcha/api.js';\n        return [baseUrl, this.getQueryParams()]\n            .filter(item => !!item)\n            .join('?');\n    }\n\n    private getQueryParams() {\n        const localeId = this._localize?.current?.id ?? this._localeId ?? null;\n        const params = {\n            render: 'explicit',\n            onload: this._windowLoadFn ?? null,\n            hl: localeId\n        };\n\n        return Object.keys(params)\n            .map(key => ({key, value: params[key]}))\n            .filter(item => !!item.value)\n            .map(item => `${item?.key}=${item?.value}`)\n            .join('&');\n    }\n\n}\n"]}
@@ -14,14 +14,14 @@ export class RecaptchaModule {
14
14
  };
15
15
  }
16
16
  }
17
- RecaptchaModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: RecaptchaModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
18
- RecaptchaModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.2", ngImport: i0, type: RecaptchaModule, declarations: [RecaptchaComponent], exports: [RecaptchaComponent] });
19
- RecaptchaModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: RecaptchaModule });
20
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: RecaptchaModule, decorators: [{
17
+ RecaptchaModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: RecaptchaModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
18
+ RecaptchaModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.10", ngImport: i0, type: RecaptchaModule, declarations: [RecaptchaComponent], exports: [RecaptchaComponent] });
19
+ RecaptchaModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: RecaptchaModule });
20
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: RecaptchaModule, decorators: [{
21
21
  type: NgModule,
22
22
  args: [{
23
23
  declarations: [RecaptchaComponent],
24
24
  exports: [RecaptchaComponent]
25
25
  }]
26
26
  }] });
27
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjYXB0Y2hhLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JiLWZvdW5kYXRpb24vcmVjYXB0Y2hhL3NyYy9saWIvcmVjYXB0Y2hhLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsZ0JBQWdCLEVBQWtCLE1BQU0sdUJBQXVCLENBQUM7QUFDeEUsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0saUNBQWlDLENBQUM7QUFDbkUsT0FBTyxFQUFzQixRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDNUQsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLDRCQUE0QixDQUFDOztBQU0zRCxNQUFNLE9BQU8sZUFBZTtJQUV4QixNQUFNLENBQUMsT0FBTyxDQUFDLE1BQXdCO1FBQ25DLE9BQU87WUFDSCxRQUFRLEVBQUUsZUFBZTtZQUN6QixTQUFTLEVBQUU7Z0JBQ1AsRUFBQyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBQztnQkFDN0MsZUFBZTthQUNsQjtTQUNKLENBQUM7SUFDTixDQUFDOzs0R0FWUSxlQUFlOzZHQUFmLGVBQWUsaUJBSFQsa0JBQWtCLGFBQ3ZCLGtCQUFrQjs2R0FFbkIsZUFBZTsyRkFBZixlQUFlO2tCQUozQixRQUFRO21CQUFDO29CQUNOLFlBQVksRUFBRSxDQUFDLGtCQUFrQixDQUFDO29CQUNsQyxPQUFPLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQztpQkFDaEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1JFQ0FQVENIQV9DT05GSUcsIFJlY2FwdGNoYUNvbmZpZ30gZnJvbSAnLi9yZWNhcHRjaGEuaW50ZXJmYWNlJztcbmltcG9ydCB7UmVjYXB0Y2hhQ29tcG9uZW50fSBmcm9tICcuL3JlY2FwdGNoYS9yZWNhcHRjaGEuY29tcG9uZW50JztcbmltcG9ydCB7TW9kdWxlV2l0aFByb3ZpZGVycywgTmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtSZWNhcHRjaGFMb2FkZXJ9IGZyb20gJy4vcmVjYXB0Y2hhLWxvYWRlci5zZXJ2aWNlJztcblxuQE5nTW9kdWxlKHtcbiAgICBkZWNsYXJhdGlvbnM6IFtSZWNhcHRjaGFDb21wb25lbnRdLFxuICAgIGV4cG9ydHM6IFtSZWNhcHRjaGFDb21wb25lbnRdXG59KVxuZXhwb3J0IGNsYXNzIFJlY2FwdGNoYU1vZHVsZSB7XG5cbiAgICBzdGF0aWMgZm9yUm9vdChjb25maWc/OiBSZWNhcHRjaGFDb25maWcpOiBNb2R1bGVXaXRoUHJvdmlkZXJzPFJlY2FwdGNoYU1vZHVsZT4ge1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgbmdNb2R1bGU6IFJlY2FwdGNoYU1vZHVsZSxcbiAgICAgICAgICAgIHByb3ZpZGVyczogW1xuICAgICAgICAgICAgICAgIHtwcm92aWRlOiBSRUNBUFRDSEFfQ09ORklHLCB1c2VWYWx1ZTogY29uZmlnfSxcbiAgICAgICAgICAgICAgICBSZWNhcHRjaGFMb2FkZXJcbiAgICAgICAgICAgIF1cbiAgICAgICAgfTtcbiAgICB9XG5cbn1cbiJdfQ==
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjYXB0Y2hhLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JiLWZvdW5kYXRpb24vcmVjYXB0Y2hhL3NyYy9saWIvcmVjYXB0Y2hhLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsZ0JBQWdCLEVBQWtCLE1BQU0sdUJBQXVCLENBQUM7QUFDeEUsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0saUNBQWlDLENBQUM7QUFDbkUsT0FBTyxFQUFzQixRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDNUQsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLDRCQUE0QixDQUFDOztBQU0zRCxNQUFNLE9BQU8sZUFBZTtJQUV4QixNQUFNLENBQUMsT0FBTyxDQUFDLE1BQXdCO1FBQ25DLE9BQU87WUFDSCxRQUFRLEVBQUUsZUFBZTtZQUN6QixTQUFTLEVBQUU7Z0JBQ1AsRUFBQyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBQztnQkFDN0MsZUFBZTthQUNsQjtTQUNKLENBQUM7SUFDTixDQUFDOzs2R0FWUSxlQUFlOzhHQUFmLGVBQWUsaUJBSFQsa0JBQWtCLGFBQ3ZCLGtCQUFrQjs4R0FFbkIsZUFBZTs0RkFBZixlQUFlO2tCQUozQixRQUFRO21CQUFDO29CQUNOLFlBQVksRUFBRSxDQUFDLGtCQUFrQixDQUFDO29CQUNsQyxPQUFPLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQztpQkFDaEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1JFQ0FQVENIQV9DT05GSUcsIFJlY2FwdGNoYUNvbmZpZ30gZnJvbSAnLi9yZWNhcHRjaGEuaW50ZXJmYWNlJztcbmltcG9ydCB7UmVjYXB0Y2hhQ29tcG9uZW50fSBmcm9tICcuL3JlY2FwdGNoYS9yZWNhcHRjaGEuY29tcG9uZW50JztcbmltcG9ydCB7TW9kdWxlV2l0aFByb3ZpZGVycywgTmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtSZWNhcHRjaGFMb2FkZXJ9IGZyb20gJy4vcmVjYXB0Y2hhLWxvYWRlci5zZXJ2aWNlJztcblxuQE5nTW9kdWxlKHtcbiAgICBkZWNsYXJhdGlvbnM6IFtSZWNhcHRjaGFDb21wb25lbnRdLFxuICAgIGV4cG9ydHM6IFtSZWNhcHRjaGFDb21wb25lbnRdXG59KVxuZXhwb3J0IGNsYXNzIFJlY2FwdGNoYU1vZHVsZSB7XG5cbiAgICBzdGF0aWMgZm9yUm9vdChjb25maWc/OiBSZWNhcHRjaGFDb25maWcpOiBNb2R1bGVXaXRoUHJvdmlkZXJzPFJlY2FwdGNoYU1vZHVsZT4ge1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgbmdNb2R1bGU6IFJlY2FwdGNoYU1vZHVsZSxcbiAgICAgICAgICAgIHByb3ZpZGVyczogW1xuICAgICAgICAgICAgICAgIHtwcm92aWRlOiBSRUNBUFRDSEFfQ09ORklHLCB1c2VWYWx1ZTogY29uZmlnfSxcbiAgICAgICAgICAgICAgICBSZWNhcHRjaGFMb2FkZXJcbiAgICAgICAgICAgIF1cbiAgICAgICAgfTtcbiAgICB9XG5cbn1cbiJdfQ==
@@ -93,9 +93,9 @@ export class Storage {
93
93
  return this._strategies.memory;
94
94
  }
95
95
  }
96
- Storage.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: Storage, deps: [{ token: i1.Platform }, { token: COOKIE, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
97
- Storage.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: Storage, providedIn: 'root' });
98
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: Storage, decorators: [{
96
+ Storage.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: Storage, deps: [{ token: i1.Platform }, { token: COOKIE, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
97
+ Storage.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: Storage, providedIn: 'root' });
98
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: Storage, decorators: [{
99
99
  type: Injectable,
100
100
  args: [{
101
101
  providedIn: 'root'
@@ -106,4 +106,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.2", ngImpor
106
106
  type: Inject,
107
107
  args: [COOKIE]
108
108
  }] }]; } });
109
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"storage.service.js","sourceRoot":"","sources":["../../../../../projects/bb-foundation/storage/src/lib/storage.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {StorageOption, StorageStrategy} from './interfaces/strategy.interface';\nimport {PolyfillStorage} from './strategies/polyfill-storage.strategy';\nimport {StorageAttributes} from './interfaces/attributes.interface';\nimport {CookieStorage} from './strategies/cookie-storage.strategy';\nimport {MemoryStorage} from './strategies/memory-storage.strategy';\nimport {Inject, Injectable, Optional} from '@angular/core';\nimport {Platform} from '@angular/cdk/platform';\nimport {COOKIE} from '@bravobit/bb-foundation';\n\ndeclare let ngDevMode;\n\n@Injectable({\n    providedIn: 'root'\n})\nexport class Storage implements StorageStrategy {\n\n    // All available strategies (sorted best to last).\n    private readonly _strategies: { [key in `${StorageOption}`]: StorageStrategy };\n\n    // Current selected storage strategy.\n    private readonly _current: StorageStrategy | null = null;\n\n    constructor(private _platform: Platform,\n                @Optional() @Inject(COOKIE) private _cookieString?: string) {\n        this._strategies = {\n            [StorageOption.Local]: new PolyfillStorage(this.getLocalStorage()),\n            [StorageOption.Cookie]: new CookieStorage(this._platform.isBrowser, this._cookieString),\n            [StorageOption.Session]: new PolyfillStorage(this.getSessionStorage()),\n            [StorageOption.Memory]: new MemoryStorage()\n        };\n\n        this._current = this.findBestStorageStrategy();\n    }\n\n    select(option: StorageOption | StorageOption[]) {\n        const items = Array.isArray(option) ? option : [option];\n        for (const item of items) {\n            const strategy = this._strategies?.[item] ?? null;\n            if (strategy && strategy.isSupported()) {\n                return strategy;\n            }\n        }\n\n        if (this._platform.isBrowser && (typeof ngDevMode === 'undefined' || ngDevMode)) {\n            console?.warn?.('[Storage]: Could not select proper storage option, using memory fallback.');\n        }\n\n        // Always return as a fallback the memory storage since it should be always available.\n        return this._strategies.memory;\n    }\n\n    get local() {\n        return this._strategies.local;\n    }\n\n    get cookie() {\n        return this._strategies.cookie;\n    }\n\n    get session() {\n        return this._strategies.session;\n    }\n\n    get memory() {\n        return this._strategies.memory;\n    }\n\n    get<T = any>(token: string): T {\n        return this._current.get(token);\n    }\n\n    set<T = any>(token: string, value: T, attributes?: StorageAttributes) {\n        this._current.set<T>(token, value, attributes);\n    }\n\n    remove(token: string, attributes?: StorageAttributes) {\n        this._current.remove(token, attributes);\n    }\n\n    clear(attributes?: StorageAttributes) {\n        this._current.clear(attributes);\n    }\n\n    isSupported() {\n        return !!this._current;\n    }\n\n    private findBestStorageStrategy() {\n        // Loop through all available strategies to find the best.\n        for (const type in this._strategies) {\n            const strategy = this._strategies?.[type];\n\n            // The first supported strategy is the best.\n            if (strategy?.isSupported()) {\n                return strategy;\n            }\n        }\n\n        // If no strategy was returned we fallback to memory\n        // storage since it should be available always.\n        if (this._platform.isBrowser && (typeof ngDevMode === 'undefined' || ngDevMode)) {\n            console?.warn?.('[Storage]: Could not select proper storage option, using memory fallback.');\n        }\n\n        return this._strategies.memory;\n    }\n\n    private getLocalStorage = () => {\n        try {\n            return (typeof window !== 'undefined') ? window?.localStorage : null;\n        } catch {\n            return null;\n        }\n    };\n\n    private getSessionStorage = () => {\n        try {\n            return (typeof window !== 'undefined') ? window?.sessionStorage : null;\n        } catch {\n            return null;\n        }\n    };\n\n}\n"]}
109
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"storage.service.js","sourceRoot":"","sources":["../../../../../projects/bb-foundation/storage/src/lib/storage.service.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,eAAe,EAAC,MAAM,wCAAwC,CAAC;AAEvE,OAAO,EAAC,aAAa,EAAC,MAAM,sCAAsC,CAAC;AACnE,OAAO,EAAC,aAAa,EAAC,MAAM,sCAAsC,CAAC;AACnE,OAAO,EAAC,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAC,MAAM,eAAe,CAAC;AAE3D,OAAO,EAAC,MAAM,EAAC,MAAM,yBAAyB,CAAC;;;AAO/C,MAAM,OAAO,OAAO;IAQhB,YAAoB,SAAmB,EACS,aAAsB;QADlD,cAAS,GAAT,SAAS,CAAU;QACS,kBAAa,GAAb,aAAa,CAAS;QAJtE,qCAAqC;QACpB,aAAQ,GAA2B,IAAI,CAAC;QAuFjD,oBAAe,GAAG,GAAG,EAAE;YAC3B,IAAI;gBACA,OAAO,CAAC,OAAO,MAAM,KAAK,WAAW,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC;aACxE;YAAC,MAAM;gBACJ,OAAO,IAAI,CAAC;aACf;QACL,CAAC,CAAC;QAEM,sBAAiB,GAAG,GAAG,EAAE;YAC7B,IAAI;gBACA,OAAO,CAAC,OAAO,MAAM,KAAK,WAAW,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC;aAC1E;YAAC,MAAM;gBACJ,OAAO,IAAI,CAAC;aACf;QACL,CAAC,CAAC;QAjGE,IAAI,CAAC,WAAW,GAAG;YACf,mCAAqB,EAAE,IAAI,eAAe,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC;YAClE,qCAAsB,EAAE,IAAI,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE,IAAI,CAAC,aAAa,CAAC;YACvF,uCAAuB,EAAE,IAAI,eAAe,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACtE,qCAAsB,EAAE,IAAI,aAAa,EAAE;SAC9C,CAAC;QAEF,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,uBAAuB,EAAE,CAAC;IACnD,CAAC;IAED,MAAM,CAAC,MAAuC;QAC1C,MAAM,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;QACxD,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE;YACtB,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC;YAClD,IAAI,QAAQ,IAAI,QAAQ,CAAC,WAAW,EAAE,EAAE;gBACpC,OAAO,QAAQ,CAAC;aACnB;SACJ;QAED,IAAI,IAAI,CAAC,SAAS,CAAC,SAAS,IAAI,CAAC,OAAO,SAAS,KAAK,WAAW,IAAI,SAAS,CAAC,EAAE;YAC7E,OAAO,EAAE,IAAI,EAAE,CAAC,2EAA2E,CAAC,CAAC;SAChG;QAED,sFAAsF;QACtF,OAAO,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC;IACnC,CAAC;IAED,IAAI,KAAK;QACL,OAAO,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;IAClC,CAAC;IAED,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC;IACnC,CAAC;IAED,IAAI,OAAO;QACP,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC;IACpC,CAAC;IAED,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC;IACnC,CAAC;IAED,GAAG,CAAU,KAAa;QACtB,OAAO,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACpC,CAAC;IAED,GAAG,CAAU,KAAa,EAAE,KAAQ,EAAE,UAA8B;QAChE,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAI,KAAK,EAAE,KAAK,EAAE,UAAU,CAAC,CAAC;IACnD,CAAC;IAED,MAAM,CAAC,KAAa,EAAE,UAA8B;QAChD,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC;IAC5C,CAAC;IAED,KAAK,CAAC,UAA8B;QAChC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;IACpC,CAAC;IAED,WAAW;QACP,OAAO,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC;IAC3B,CAAC;IAEO,uBAAuB;QAC3B,0DAA0D;QAC1D,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,WAAW,EAAE;YACjC,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC,IAAI,CAAC,CAAC;YAE1C,4CAA4C;YAC5C,IAAI,QAAQ,EAAE,WAAW,EAAE,EAAE;gBACzB,OAAO,QAAQ,CAAC;aACnB;SACJ;QAED,oDAAoD;QACpD,+CAA+C;QAC/C,IAAI,IAAI,CAAC,SAAS,CAAC,SAAS,IAAI,CAAC,OAAO,SAAS,KAAK,WAAW,IAAI,SAAS,CAAC,EAAE;YAC7E,OAAO,EAAE,IAAI,EAAE,CAAC,2EAA2E,CAAC,CAAC;SAChG;QAED,OAAO,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC;IACnC,CAAC;;qGA3FQ,OAAO,0CASgB,MAAM;yGAT7B,OAAO,cAFJ,MAAM;4FAET,OAAO;kBAHnB,UAAU;mBAAC;oBACR,UAAU,EAAE,MAAM;iBACrB;;0BAUgB,QAAQ;;0BAAI,MAAM;2BAAC,MAAM","sourcesContent":["import {StorageOption, StorageStrategy} from './interfaces/strategy.interface';\nimport {PolyfillStorage} from './strategies/polyfill-storage.strategy';\nimport {StorageAttributes} from './interfaces/attributes.interface';\nimport {CookieStorage} from './strategies/cookie-storage.strategy';\nimport {MemoryStorage} from './strategies/memory-storage.strategy';\nimport {Inject, Injectable, Optional} from '@angular/core';\nimport {Platform} from '@angular/cdk/platform';\nimport {COOKIE} from '@bravobit/bb-foundation';\n\ndeclare let ngDevMode;\n\n@Injectable({\n    providedIn: 'root'\n})\nexport class Storage implements StorageStrategy {\n\n    // All available strategies (sorted best to last).\n    private readonly _strategies: { [key in `${StorageOption}`]: StorageStrategy };\n\n    // Current selected storage strategy.\n    private readonly _current: StorageStrategy | null = null;\n\n    constructor(private _platform: Platform,\n                @Optional() @Inject(COOKIE) private _cookieString?: string) {\n        this._strategies = {\n            [StorageOption.Local]: new PolyfillStorage(this.getLocalStorage()),\n            [StorageOption.Cookie]: new CookieStorage(this._platform.isBrowser, this._cookieString),\n            [StorageOption.Session]: new PolyfillStorage(this.getSessionStorage()),\n            [StorageOption.Memory]: new MemoryStorage()\n        };\n\n        this._current = this.findBestStorageStrategy();\n    }\n\n    select(option: StorageOption | StorageOption[]) {\n        const items = Array.isArray(option) ? option : [option];\n        for (const item of items) {\n            const strategy = this._strategies?.[item] ?? null;\n            if (strategy && strategy.isSupported()) {\n                return strategy;\n            }\n        }\n\n        if (this._platform.isBrowser && (typeof ngDevMode === 'undefined' || ngDevMode)) {\n            console?.warn?.('[Storage]: Could not select proper storage option, using memory fallback.');\n        }\n\n        // Always return as a fallback the memory storage since it should be always available.\n        return this._strategies.memory;\n    }\n\n    get local() {\n        return this._strategies.local;\n    }\n\n    get cookie() {\n        return this._strategies.cookie;\n    }\n\n    get session() {\n        return this._strategies.session;\n    }\n\n    get memory() {\n        return this._strategies.memory;\n    }\n\n    get<T = any>(token: string): T {\n        return this._current.get(token);\n    }\n\n    set<T = any>(token: string, value: T, attributes?: StorageAttributes) {\n        this._current.set<T>(token, value, attributes);\n    }\n\n    remove(token: string, attributes?: StorageAttributes) {\n        this._current.remove(token, attributes);\n    }\n\n    clear(attributes?: StorageAttributes) {\n        this._current.clear(attributes);\n    }\n\n    isSupported() {\n        return !!this._current;\n    }\n\n    private findBestStorageStrategy() {\n        // Loop through all available strategies to find the best.\n        for (const type in this._strategies) {\n            const strategy = this._strategies?.[type];\n\n            // The first supported strategy is the best.\n            if (strategy?.isSupported()) {\n                return strategy;\n            }\n        }\n\n        // If no strategy was returned we fallback to memory\n        // storage since it should be available always.\n        if (this._platform.isBrowser && (typeof ngDevMode === 'undefined' || ngDevMode)) {\n            console?.warn?.('[Storage]: Could not select proper storage option, using memory fallback.');\n        }\n\n        return this._strategies.memory;\n    }\n\n    private getLocalStorage = () => {\n        try {\n            return (typeof window !== 'undefined') ? window?.localStorage : null;\n        } catch {\n            return null;\n        }\n    };\n\n    private getSessionStorage = () => {\n        try {\n            return (typeof window !== 'undefined') ? window?.sessionStorage : null;\n        } catch {\n            return null;\n        }\n    };\n\n}\n"]}
@@ -11,9 +11,9 @@ import * as i4 from "../table-pager/table-pager.component";
11
11
  import * as i5 from "@bravobit/bb-foundation/localize";
12
12
  export class BbTableColumnDef {
13
13
  }
14
- BbTableColumnDef.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: BbTableColumnDef, deps: [], target: i0.ɵɵFactoryTarget.Directive });
15
- BbTableColumnDef.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.2", type: BbTableColumnDef, selector: "[bbTableColumnDef]", ngImport: i0 });
16
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: BbTableColumnDef, decorators: [{
14
+ BbTableColumnDef.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: BbTableColumnDef, deps: [], target: i0.ɵɵFactoryTarget.Directive });
15
+ BbTableColumnDef.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.10", type: BbTableColumnDef, selector: "[bbTableColumnDef]", ngImport: i0 });
16
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: BbTableColumnDef, decorators: [{
17
17
  type: Directive,
18
18
  args: [{
19
19
  selector: '[bbTableColumnDef]'
@@ -21,9 +21,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.2", ngImpor
21
21
  }] });
22
22
  export class BbTableRowDef {
23
23
  }
24
- BbTableRowDef.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: BbTableRowDef, deps: [], target: i0.ɵɵFactoryTarget.Directive });
25
- BbTableRowDef.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.2", type: BbTableRowDef, selector: "[bbTableRowDef]", ngImport: i0 });
26
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: BbTableRowDef, decorators: [{
24
+ BbTableRowDef.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: BbTableRowDef, deps: [], target: i0.ɵɵFactoryTarget.Directive });
25
+ BbTableRowDef.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.10", type: BbTableRowDef, selector: "[bbTableRowDef]", ngImport: i0 });
26
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: BbTableRowDef, decorators: [{
27
27
  type: Directive,
28
28
  args: [{
29
29
  selector: '[bbTableRowDef]'
@@ -162,9 +162,9 @@ export class BbTable {
162
162
  return this.form.valueChanges.pipe(startWith(this.form.value));
163
163
  }
164
164
  }
165
- BbTable.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: BbTable, deps: [], target: i0.ɵɵFactoryTarget.Component });
166
- BbTable.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.2", type: BbTable, selector: "bb-table", inputs: { identifier: "identifier", dataSource: "dataSource", queryFields: "queryFields", sortingStrategy: "sortingStrategy", header: "header", footer: "footer", sizes: "sizes" }, host: { classAttribute: "bb-table" }, queries: [{ propertyName: "tableRowTemplate", first: true, predicate: BbTableRowDef, descendants: true, read: TemplateRef }, { propertyName: "tableColumnTemplates", predicate: BbTableColumnDef, read: TemplateRef }], ngImport: i0, template: "<!--\n This is the header of the table. It can be a user\n defined custom header or just the default header.\n-->\n\n<header *ngIf=\"(header === true ? headerTemplate : header) as template\"\n class=\"bb-table-top-actions\">\n <ng-container *ngTemplateOutlet=\"template\"></ng-container>\n</header>\n\n<!--\n This is the table that contains the\n rows and columns.\n-->\n\n<div class=\"bb-table-wrapper\">\n <div *ngIf=\"isLoading$ | async\"\n class=\"bb-table-progress\">\n <div class=\"bb-table-indeterminate\"></div>\n </div>\n <table class=\"bb-table-container\">\n <thead>\n <tr>\n <ng-content select=\"bb-table-header-cell\"></ng-content>\n </tr>\n </thead>\n <tbody *ngIf=\"data$ | async as data; else isLoadingTemplate\"\n [ngSwitch]=\"data?.state\">\n <ng-container *ngSwitchCase=\"'success'\">\n <ng-container *ngIf=\"!!tableRowTemplate; else tableCellsTemplates\">\n <ng-container\n *ngTemplateOutlet=\"tableRowTemplate; context: {data: data?.result?.data || []}\"></ng-container>\n </ng-container>\n\n <ng-template #tableCellsTemplates>\n <tr *ngFor=\"let item of data?.result?.data; trackBy: trackByFn\">\n <ng-container *ngFor=\"let template of tableColumnTemplates\">\n <ng-container *ngTemplateOutlet=\"template; context: {item: item}\"></ng-container>\n </ng-container>\n </tr>\n </ng-template>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'empty'\">\n <ng-container\n *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'error_datasource'\">\n <ng-container\n *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'error_not_found'\">\n <ng-container\n *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'error_server'\">\n <ng-container\n *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'error_down'\">\n <ng-container\n *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n </ng-container>\n\n <ng-container *ngSwitchDefault>\n <ng-container\n *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n </ng-container>\n </tbody>\n </table>\n</div>\n\n<footer *ngIf=\"(footer === true ? footerTemplate : footer) as template\"\n class=\"bb-table-bottom-actions\">\n <ng-container *ngTemplateOutlet=\"template\"></ng-container>\n</footer>\n\n<ng-template #isLoadingTemplate>\n <tr>\n <td [attr.colspan]=\"headerCount\"\n class=\"bb-table-template\">\n <div class=\"bb-table-template-content\">\n {{ 'tables.loading' | bbLocalize }}\n </div>\n </td>\n </tr>\n</ng-template>\n\n<!--\n This is the template that will be used when the user has not\n supplied a custom header template.\n-->\n\n<ng-template #headerTemplate>\n <ng-content></ng-content>\n <bb-form-control>\n <input [formControl]=\"queryControl\"\n [placeholder]=\"'tables.search' | bbLocalize\"\n bbInput\n autocomplete=\"off\">\n <bb-icon *ngIf=\"queryControl?.value?.length <= 0; else closeButtonTemplate\"\n bbSuffix\n src=\"material:search\">\n </bb-icon>\n </bb-form-control>\n</ng-template>\n\n<!--\n This is the template that will be used when the user has not\n supplied a custom footer template.\n-->\n\n<ng-template #footerTemplate>\n <bb-form-control *ngIf=\"sizes?.length > 1\">\n <select [formControl]=\"pageSizeControl\"\n bbInput\n title=\"Sizes\">\n <option *ngFor=\"let item of sizes; trackBy: trackByValue\"\n [ngValue]=\"item\">\n {{ item }} / {{ 'tables.page' | bbLocalize }}\n </option>\n </select>\n </bb-form-control>\n\n <bb-table-pager [totalPages]=\"(data$ | async)?.result?.totalPages\"\n [formControl]=\"pageNumberControl\">\n </bb-table-pager>\n</ng-template>\n\n<!--\n This the template that will be used when the user\n has filled in some data in the query control.\n-->\n\n<ng-template #closeButtonTemplate>\n <button bbSuffix\n (click)=\"queryControl?.patchValue('')\"\n type=\"button\"\n class=\"bb-table-progress-close-query\">\n <bb-icon src=\"material:close\"></bb-icon>\n </button>\n</ng-template>\n\n<ng-template #errorTemplate let-state=\"state\" let-status=\"statusCode\">\n <tr>\n <td [attr.colspan]=\"headerCount\"\n class=\"bb-table-template\">\n <div class=\"bb-table-template-content\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"64\" height=\"41\">\n <g fill=\"none\" fill-rule=\"evenodd\" transform=\"translate(0 1)\">\n <ellipse cx=\"32\" cy=\"33\" fill=\"#F5F5F5\" rx=\"32\" ry=\"7\"></ellipse>\n <g fill-rule=\"nonzero\" stroke=\"#D9D9D9\">\n <path\n d=\"M55 12.7605604L44.8543047 1.25739633C44.3674414.47382661 43.6558789 0 42.9067617 0H21.0932383c-.7491172 0-1.4606797.47395025-1.947543 1.25739633L9 12.7605604V22h46v-9.2394396z\"></path>\n <path fill=\"#FAFAFA\"\n d=\"M41.6132813 15.9315c0-1.6056489.9936718-2.931266 2.2264179-2.9315H55v18.1371277C55 33.2589574 53.6793867 35 52.0504297 35H11.94957031C10.32052344 35 9 33.2588404 9 31.1371277V13h11.1603008c1.2327461 0 2.226418 1.3228085 2.226418 2.9284574v.0211809c0 1.6056489 1.0049921 2.9015426 2.2377382 2.9015426h14.751086c1.2327461 0 2.2377383-1.3078298 2.2377383-2.9134788V15.9315z\"></path>\n </g>\n </g>\n </svg>\n <span *ngIf=\"state as stateLabel\">{{ ('tables.' + stateLabel) | bbLocalize }}</span>\n <span *ngIf=\"status as statusCode\"\n class=\"bb-table-template-content-code\">(HTTP {{ statusCode }})</span>\n </div>\n </td>\n </tr>\n</ng-template>\n", styles: [".bb-table{width:100%;display:block;box-shadow:0 6px 6px -6px #0000001a}.bb-table.plain{box-shadow:none}.bb-table.plain>.bb-table-wrapper{border-top-left-radius:0;border-top-right-radius:0}.bb-table-wrapper{overflow-x:auto;position:relative;background-color:#fff;border-top-left-radius:4px;border-top-right-radius:4px}.bb-table-container{width:100%}.bb-table-container td{border-bottom:1px solid #d8d8d8}.bb-table-top-actions{display:flex;flex-wrap:wrap;flex-direction:column;padding:20px 20px 10px;background-color:#fff;justify-content:flex-end;border-top-left-radius:4px;border-top-right-radius:4px;border-bottom:1px solid #d8d8d8}.bb-table-top-actions>*{margin-left:0;margin-bottom:10px}.bb-table-top-actions+.bb-table-wrapper{border-radius:0}.bb-table-bottom-actions{height:60px;display:flex;padding:0 20px;overflow-x:auto;align-items:center;background-color:#fff;border-bottom-left-radius:4px;border-bottom-right-radius:4px}.bb-table-template{border:none;background-color:#f5f5f5;border-bottom:1px solid #d8d8d8}.bb-table-template-content{padding:20px;display:flex;color:#3d464d;font-size:14px;line-height:1.2;font-weight:400;min-height:140px;text-align:center;align-items:center;flex-direction:column;justify-content:center}.bb-table-template-content>svg{margin-bottom:12px}.bb-table-template-content-code{opacity:.5;margin-top:5px;display:inline-block}.bb-table-progress{top:0;left:0;right:0;opacity:0;width:100%;height:4px;display:block;overflow:hidden;position:absolute;background-color:#2f408b4d;animation:fadeIn .25s cubic-bezier(0,0,.2,1) .1s forwards}.bb-table-progress .bb-table-indeterminate{background-color:#2f408b}.bb-table-progress .bb-table-indeterminate:before{top:0;left:0;bottom:0;content:\"\";position:absolute;will-change:left,right;background-color:inherit;animation:indeterminate 2.1s cubic-bezier(.65,.815,.735,.395) infinite}.bb-table-progress .bb-table-indeterminate:after{top:0;left:0;bottom:0;content:\"\";position:absolute;animation-delay:1.15s;will-change:left,right;background-color:inherit;animation:indeterminate-short 2.1s cubic-bezier(.165,.84,.44,1) infinite}.bb-table-progress-close-query{padding:0;border:none;border-radius:4px;background-color:transparent;transition:background-color .25s cubic-bezier(0,0,.2,1)}.bb-table-progress-close-query:hover{background-color:#00000014}.bb-table-progress-close-query:focus{background-color:#0000001f}.bb-table-progress-close-query:active{background-color:#00000029}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes indeterminate{0%{left:-35%;right:100%}60%{left:100%;right:-90%}to{left:100%;right:-90%}}@keyframes indeterminate-short{0%{left:-200%;right:100%}60%{left:107%;right:-8%}to{left:107%;right:-8%}}@media only screen and (min-width: 768px){.bb-table-top-actions{flex-direction:row}.bb-table-top-actions>*:not(:first-child){margin-left:10px;margin-bottom:10px}}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i1.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "directive", type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.BbInput, selector: "input[bbInput], textarea[bbInput]", inputs: ["readonly"] }, { kind: "directive", type: i3.BbSelect, selector: "select[bbInput]", inputs: ["disabled", "required"] }, { kind: "directive", type: i3.BbSuffix, selector: "[bbSuffix]" }, { kind: "component", type: i3.BbIcon, selector: "bb-icon", inputs: ["alt", "size", "src", "ariaHidden"] }, { kind: "component", type: i3.BbFormControl, selector: "bb-form-control", inputs: ["grouped", "hideErrors", "label", "hint"] }, { kind: "component", type: i4.BbTablePager, selector: "bb-table-pager", inputs: ["disabled", "amountOfButtons", "showArrowButtons", "pageNumber", "totalPages"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i5.BbLocalize, name: "bbLocalize" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
167
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: BbTable, decorators: [{
165
+ BbTable.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: BbTable, deps: [], target: i0.ɵɵFactoryTarget.Component });
166
+ BbTable.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: BbTable, selector: "bb-table", inputs: { identifier: "identifier", dataSource: "dataSource", queryFields: "queryFields", sortingStrategy: "sortingStrategy", header: "header", footer: "footer", sizes: "sizes" }, host: { classAttribute: "bb-table" }, queries: [{ propertyName: "tableRowTemplate", first: true, predicate: BbTableRowDef, descendants: true, read: TemplateRef }, { propertyName: "tableColumnTemplates", predicate: BbTableColumnDef, read: TemplateRef }], ngImport: i0, template: "<!--\n This is the header of the table. It can be a user\n defined custom header or just the default header.\n-->\n\n<header *ngIf=\"(header === true ? headerTemplate : header) as template\"\n class=\"bb-table-top-actions\">\n <ng-container *ngTemplateOutlet=\"template\"></ng-container>\n</header>\n\n<!--\n This is the table that contains the\n rows and columns.\n-->\n\n<div class=\"bb-table-wrapper\">\n <div *ngIf=\"isLoading$ | async\"\n class=\"bb-table-progress\">\n <div class=\"bb-table-indeterminate\"></div>\n </div>\n <table class=\"bb-table-container\">\n <thead>\n <tr>\n <ng-content select=\"bb-table-header-cell\"></ng-content>\n </tr>\n </thead>\n <tbody *ngIf=\"data$ | async as data; else isLoadingTemplate\"\n [ngSwitch]=\"data?.state\">\n <ng-container *ngSwitchCase=\"'success'\">\n <ng-container *ngIf=\"!!tableRowTemplate; else tableCellsTemplates\">\n <ng-container\n *ngTemplateOutlet=\"tableRowTemplate; context: {data: data?.result?.data || []}\"></ng-container>\n </ng-container>\n\n <ng-template #tableCellsTemplates>\n <tr *ngFor=\"let item of data?.result?.data; trackBy: trackByFn\">\n <ng-container *ngFor=\"let template of tableColumnTemplates\">\n <ng-container *ngTemplateOutlet=\"template; context: {item: item}\"></ng-container>\n </ng-container>\n </tr>\n </ng-template>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'empty'\">\n <ng-container\n *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'error_datasource'\">\n <ng-container\n *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'error_not_found'\">\n <ng-container\n *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'error_server'\">\n <ng-container\n *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'error_down'\">\n <ng-container\n *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n </ng-container>\n\n <ng-container *ngSwitchDefault>\n <ng-container\n *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n </ng-container>\n </tbody>\n </table>\n</div>\n\n<footer *ngIf=\"(footer === true ? footerTemplate : footer) as template\"\n class=\"bb-table-bottom-actions\">\n <ng-container *ngTemplateOutlet=\"template\"></ng-container>\n</footer>\n\n<ng-template #isLoadingTemplate>\n <tr>\n <td [attr.colspan]=\"headerCount\"\n class=\"bb-table-template\">\n <div class=\"bb-table-template-content\">\n {{ 'tables.loading' | bbLocalize }}\n </div>\n </td>\n </tr>\n</ng-template>\n\n<!--\n This is the template that will be used when the user has not\n supplied a custom header template.\n-->\n\n<ng-template #headerTemplate>\n <ng-content></ng-content>\n <bb-form-control>\n <input [formControl]=\"queryControl\"\n [placeholder]=\"'tables.search' | bbLocalize\"\n bbInput\n autocomplete=\"off\">\n <bb-icon *ngIf=\"queryControl?.value?.length <= 0; else closeButtonTemplate\"\n bbSuffix\n src=\"material:search\">\n </bb-icon>\n </bb-form-control>\n</ng-template>\n\n<!--\n This is the template that will be used when the user has not\n supplied a custom footer template.\n-->\n\n<ng-template #footerTemplate>\n <bb-form-control *ngIf=\"sizes?.length > 1\">\n <select [formControl]=\"pageSizeControl\"\n bbInput\n title=\"Sizes\">\n <option *ngFor=\"let item of sizes; trackBy: trackByValue\"\n [ngValue]=\"item\">\n {{ item }} / {{ 'tables.page' | bbLocalize }}\n </option>\n </select>\n </bb-form-control>\n\n <bb-table-pager [totalPages]=\"(data$ | async)?.result?.totalPages\"\n [formControl]=\"pageNumberControl\">\n </bb-table-pager>\n</ng-template>\n\n<!--\n This the template that will be used when the user\n has filled in some data in the query control.\n-->\n\n<ng-template #closeButtonTemplate>\n <button bbSuffix\n (click)=\"queryControl?.patchValue('')\"\n type=\"button\"\n class=\"bb-table-progress-close-query\">\n <bb-icon src=\"material:close\"></bb-icon>\n </button>\n</ng-template>\n\n<ng-template #errorTemplate let-state=\"state\" let-status=\"statusCode\">\n <tr>\n <td [attr.colspan]=\"headerCount\"\n class=\"bb-table-template\">\n <div class=\"bb-table-template-content\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"64\" height=\"41\">\n <g fill=\"none\" fill-rule=\"evenodd\" transform=\"translate(0 1)\">\n <ellipse cx=\"32\" cy=\"33\" fill=\"#F5F5F5\" rx=\"32\" ry=\"7\"></ellipse>\n <g fill-rule=\"nonzero\" stroke=\"#D9D9D9\">\n <path\n d=\"M55 12.7605604L44.8543047 1.25739633C44.3674414.47382661 43.6558789 0 42.9067617 0H21.0932383c-.7491172 0-1.4606797.47395025-1.947543 1.25739633L9 12.7605604V22h46v-9.2394396z\"></path>\n <path fill=\"#FAFAFA\"\n d=\"M41.6132813 15.9315c0-1.6056489.9936718-2.931266 2.2264179-2.9315H55v18.1371277C55 33.2589574 53.6793867 35 52.0504297 35H11.94957031C10.32052344 35 9 33.2588404 9 31.1371277V13h11.1603008c1.2327461 0 2.226418 1.3228085 2.226418 2.9284574v.0211809c0 1.6056489 1.0049921 2.9015426 2.2377382 2.9015426h14.751086c1.2327461 0 2.2377383-1.3078298 2.2377383-2.9134788V15.9315z\"></path>\n </g>\n </g>\n </svg>\n <span *ngIf=\"state as stateLabel\">{{ ('tables.' + stateLabel) | bbLocalize }}</span>\n <span *ngIf=\"status as statusCode\"\n class=\"bb-table-template-content-code\">(HTTP {{ statusCode }})</span>\n </div>\n </td>\n </tr>\n</ng-template>\n", styles: [".bb-table{width:100%;display:block;box-shadow:0 6px 6px -6px #0000001a}.bb-table.plain{box-shadow:none}.bb-table.plain>.bb-table-wrapper{border-top-left-radius:0;border-top-right-radius:0}.bb-table-wrapper{overflow-x:auto;position:relative;background-color:#fff;border-top-left-radius:4px;border-top-right-radius:4px}.bb-table-container{width:100%}.bb-table-container td{border-bottom:1px solid #d8d8d8}.bb-table-top-actions{display:flex;flex-wrap:wrap;flex-direction:column;padding:20px 20px 10px;background-color:#fff;justify-content:flex-end;border-top-left-radius:4px;border-top-right-radius:4px;border-bottom:1px solid #d8d8d8}.bb-table-top-actions>*{margin-left:0;margin-bottom:10px}.bb-table-top-actions+.bb-table-wrapper{border-radius:0}.bb-table-bottom-actions{height:60px;display:flex;padding:0 20px;overflow-x:auto;align-items:center;background-color:#fff;border-bottom-left-radius:4px;border-bottom-right-radius:4px}.bb-table-template{border:none;background-color:#f5f5f5;border-bottom:1px solid #d8d8d8}.bb-table-template-content{padding:20px;display:flex;color:#3d464d;font-size:14px;line-height:1.2;font-weight:400;min-height:140px;text-align:center;align-items:center;flex-direction:column;justify-content:center}.bb-table-template-content>svg{margin-bottom:12px}.bb-table-template-content-code{opacity:.5;margin-top:5px;display:inline-block}.bb-table-progress{top:0;left:0;right:0;opacity:0;width:100%;height:4px;display:block;overflow:hidden;position:absolute;background-color:#2f408b4d;animation:fadeIn .25s cubic-bezier(0,0,.2,1) .1s forwards}.bb-table-progress .bb-table-indeterminate{background-color:#2f408b}.bb-table-progress .bb-table-indeterminate:before{top:0;left:0;bottom:0;content:\"\";position:absolute;will-change:left,right;background-color:inherit;animation:indeterminate 2.1s cubic-bezier(.65,.815,.735,.395) infinite}.bb-table-progress .bb-table-indeterminate:after{top:0;left:0;bottom:0;content:\"\";position:absolute;animation-delay:1.15s;will-change:left,right;background-color:inherit;animation:indeterminate-short 2.1s cubic-bezier(.165,.84,.44,1) infinite}.bb-table-progress-close-query{padding:0;border:none;border-radius:4px;background-color:transparent;transition:background-color .25s cubic-bezier(0,0,.2,1)}.bb-table-progress-close-query:hover{background-color:#00000014}.bb-table-progress-close-query:focus{background-color:#0000001f}.bb-table-progress-close-query:active{background-color:#00000029}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes indeterminate{0%{left:-35%;right:100%}60%{left:100%;right:-90%}to{left:100%;right:-90%}}@keyframes indeterminate-short{0%{left:-200%;right:100%}60%{left:107%;right:-8%}to{left:107%;right:-8%}}@media only screen and (min-width: 768px){.bb-table-top-actions{flex-direction:row}.bb-table-top-actions>*:not(:first-child){margin-left:10px;margin-bottom:10px}}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i1.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "directive", type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.BbInput, selector: "input[bbInput], textarea[bbInput]", inputs: ["readonly"] }, { kind: "directive", type: i3.BbSelect, selector: "select[bbInput]", inputs: ["disabled", "required"] }, { kind: "directive", type: i3.BbSuffix, selector: "[bbSuffix]" }, { kind: "component", type: i3.BbIcon, selector: "bb-icon", inputs: ["alt", "size", "src", "ariaHidden"] }, { kind: "component", type: i3.BbFormControl, selector: "bb-form-control", inputs: ["grouped", "hideErrors", "label", "hint"] }, { kind: "component", type: i4.BbTablePager, selector: "bb-table-pager", inputs: ["disabled", "amountOfButtons", "showArrowButtons", "pageNumber", "totalPages"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i5.BbLocalize, name: "bbLocalize" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
167
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: BbTable, decorators: [{
168
168
  type: Component,
169
169
  args: [{ selector: 'bb-table', host: { 'class': 'bb-table' }, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, preserveWhitespaces: false, template: "<!--\n This is the header of the table. It can be a user\n defined custom header or just the default header.\n-->\n\n<header *ngIf=\"(header === true ? headerTemplate : header) as template\"\n class=\"bb-table-top-actions\">\n <ng-container *ngTemplateOutlet=\"template\"></ng-container>\n</header>\n\n<!--\n This is the table that contains the\n rows and columns.\n-->\n\n<div class=\"bb-table-wrapper\">\n <div *ngIf=\"isLoading$ | async\"\n class=\"bb-table-progress\">\n <div class=\"bb-table-indeterminate\"></div>\n </div>\n <table class=\"bb-table-container\">\n <thead>\n <tr>\n <ng-content select=\"bb-table-header-cell\"></ng-content>\n </tr>\n </thead>\n <tbody *ngIf=\"data$ | async as data; else isLoadingTemplate\"\n [ngSwitch]=\"data?.state\">\n <ng-container *ngSwitchCase=\"'success'\">\n <ng-container *ngIf=\"!!tableRowTemplate; else tableCellsTemplates\">\n <ng-container\n *ngTemplateOutlet=\"tableRowTemplate; context: {data: data?.result?.data || []}\"></ng-container>\n </ng-container>\n\n <ng-template #tableCellsTemplates>\n <tr *ngFor=\"let item of data?.result?.data; trackBy: trackByFn\">\n <ng-container *ngFor=\"let template of tableColumnTemplates\">\n <ng-container *ngTemplateOutlet=\"template; context: {item: item}\"></ng-container>\n </ng-container>\n </tr>\n </ng-template>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'empty'\">\n <ng-container\n *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'error_datasource'\">\n <ng-container\n *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'error_not_found'\">\n <ng-container\n *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'error_server'\">\n <ng-container\n *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'error_down'\">\n <ng-container\n *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n </ng-container>\n\n <ng-container *ngSwitchDefault>\n <ng-container\n *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n </ng-container>\n </tbody>\n </table>\n</div>\n\n<footer *ngIf=\"(footer === true ? footerTemplate : footer) as template\"\n class=\"bb-table-bottom-actions\">\n <ng-container *ngTemplateOutlet=\"template\"></ng-container>\n</footer>\n\n<ng-template #isLoadingTemplate>\n <tr>\n <td [attr.colspan]=\"headerCount\"\n class=\"bb-table-template\">\n <div class=\"bb-table-template-content\">\n {{ 'tables.loading' | bbLocalize }}\n </div>\n </td>\n </tr>\n</ng-template>\n\n<!--\n This is the template that will be used when the user has not\n supplied a custom header template.\n-->\n\n<ng-template #headerTemplate>\n <ng-content></ng-content>\n <bb-form-control>\n <input [formControl]=\"queryControl\"\n [placeholder]=\"'tables.search' | bbLocalize\"\n bbInput\n autocomplete=\"off\">\n <bb-icon *ngIf=\"queryControl?.value?.length <= 0; else closeButtonTemplate\"\n bbSuffix\n src=\"material:search\">\n </bb-icon>\n </bb-form-control>\n</ng-template>\n\n<!--\n This is the template that will be used when the user has not\n supplied a custom footer template.\n-->\n\n<ng-template #footerTemplate>\n <bb-form-control *ngIf=\"sizes?.length > 1\">\n <select [formControl]=\"pageSizeControl\"\n bbInput\n title=\"Sizes\">\n <option *ngFor=\"let item of sizes; trackBy: trackByValue\"\n [ngValue]=\"item\">\n {{ item }} / {{ 'tables.page' | bbLocalize }}\n </option>\n </select>\n </bb-form-control>\n\n <bb-table-pager [totalPages]=\"(data$ | async)?.result?.totalPages\"\n [formControl]=\"pageNumberControl\">\n </bb-table-pager>\n</ng-template>\n\n<!--\n This the template that will be used when the user\n has filled in some data in the query control.\n-->\n\n<ng-template #closeButtonTemplate>\n <button bbSuffix\n (click)=\"queryControl?.patchValue('')\"\n type=\"button\"\n class=\"bb-table-progress-close-query\">\n <bb-icon src=\"material:close\"></bb-icon>\n </button>\n</ng-template>\n\n<ng-template #errorTemplate let-state=\"state\" let-status=\"statusCode\">\n <tr>\n <td [attr.colspan]=\"headerCount\"\n class=\"bb-table-template\">\n <div class=\"bb-table-template-content\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"64\" height=\"41\">\n <g fill=\"none\" fill-rule=\"evenodd\" transform=\"translate(0 1)\">\n <ellipse cx=\"32\" cy=\"33\" fill=\"#F5F5F5\" rx=\"32\" ry=\"7\"></ellipse>\n <g fill-rule=\"nonzero\" stroke=\"#D9D9D9\">\n <path\n d=\"M55 12.7605604L44.8543047 1.25739633C44.3674414.47382661 43.6558789 0 42.9067617 0H21.0932383c-.7491172 0-1.4606797.47395025-1.947543 1.25739633L9 12.7605604V22h46v-9.2394396z\"></path>\n <path fill=\"#FAFAFA\"\n d=\"M41.6132813 15.9315c0-1.6056489.9936718-2.931266 2.2264179-2.9315H55v18.1371277C55 33.2589574 53.6793867 35 52.0504297 35H11.94957031C10.32052344 35 9 33.2588404 9 31.1371277V13h11.1603008c1.2327461 0 2.226418 1.3228085 2.226418 2.9284574v.0211809c0 1.6056489 1.0049921 2.9015426 2.2377382 2.9015426h14.751086c1.2327461 0 2.2377383-1.3078298 2.2377383-2.9134788V15.9315z\"></path>\n </g>\n </g>\n </svg>\n <span *ngIf=\"state as stateLabel\">{{ ('tables.' + stateLabel) | bbLocalize }}</span>\n <span *ngIf=\"status as statusCode\"\n class=\"bb-table-template-content-code\">(HTTP {{ statusCode }})</span>\n </div>\n </td>\n </tr>\n</ng-template>\n", styles: [".bb-table{width:100%;display:block;box-shadow:0 6px 6px -6px #0000001a}.bb-table.plain{box-shadow:none}.bb-table.plain>.bb-table-wrapper{border-top-left-radius:0;border-top-right-radius:0}.bb-table-wrapper{overflow-x:auto;position:relative;background-color:#fff;border-top-left-radius:4px;border-top-right-radius:4px}.bb-table-container{width:100%}.bb-table-container td{border-bottom:1px solid #d8d8d8}.bb-table-top-actions{display:flex;flex-wrap:wrap;flex-direction:column;padding:20px 20px 10px;background-color:#fff;justify-content:flex-end;border-top-left-radius:4px;border-top-right-radius:4px;border-bottom:1px solid #d8d8d8}.bb-table-top-actions>*{margin-left:0;margin-bottom:10px}.bb-table-top-actions+.bb-table-wrapper{border-radius:0}.bb-table-bottom-actions{height:60px;display:flex;padding:0 20px;overflow-x:auto;align-items:center;background-color:#fff;border-bottom-left-radius:4px;border-bottom-right-radius:4px}.bb-table-template{border:none;background-color:#f5f5f5;border-bottom:1px solid #d8d8d8}.bb-table-template-content{padding:20px;display:flex;color:#3d464d;font-size:14px;line-height:1.2;font-weight:400;min-height:140px;text-align:center;align-items:center;flex-direction:column;justify-content:center}.bb-table-template-content>svg{margin-bottom:12px}.bb-table-template-content-code{opacity:.5;margin-top:5px;display:inline-block}.bb-table-progress{top:0;left:0;right:0;opacity:0;width:100%;height:4px;display:block;overflow:hidden;position:absolute;background-color:#2f408b4d;animation:fadeIn .25s cubic-bezier(0,0,.2,1) .1s forwards}.bb-table-progress .bb-table-indeterminate{background-color:#2f408b}.bb-table-progress .bb-table-indeterminate:before{top:0;left:0;bottom:0;content:\"\";position:absolute;will-change:left,right;background-color:inherit;animation:indeterminate 2.1s cubic-bezier(.65,.815,.735,.395) infinite}.bb-table-progress .bb-table-indeterminate:after{top:0;left:0;bottom:0;content:\"\";position:absolute;animation-delay:1.15s;will-change:left,right;background-color:inherit;animation:indeterminate-short 2.1s cubic-bezier(.165,.84,.44,1) infinite}.bb-table-progress-close-query{padding:0;border:none;border-radius:4px;background-color:transparent;transition:background-color .25s cubic-bezier(0,0,.2,1)}.bb-table-progress-close-query:hover{background-color:#00000014}.bb-table-progress-close-query:focus{background-color:#0000001f}.bb-table-progress-close-query:active{background-color:#00000029}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes indeterminate{0%{left:-35%;right:100%}60%{left:100%;right:-90%}to{left:100%;right:-90%}}@keyframes indeterminate-short{0%{left:-200%;right:100%}60%{left:107%;right:-8%}to{left:107%;right:-8%}}@media only screen and (min-width: 768px){.bb-table-top-actions{flex-direction:row}.bb-table-top-actions>*:not(:first-child){margin-left:10px;margin-bottom:10px}}\n"] }]
170
170
  }], propDecorators: { tableColumnTemplates: [{
@@ -188,4 +188,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.2", ngImpor
188
188
  }], sizes: [{
189
189
  type: Input
190
190
  }] } });
191
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../../projects/bb-foundation/table/src/lib/components/table/table.component.ts","../../../../../../../projects/bb-foundation/table/src/lib/components/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component, ContentChild,\n    ContentChildren,\n    Directive,\n    Input,\n    OnDestroy,\n    OnInit,\n    QueryList,\n    TemplateRef,\n    ViewEncapsulation\n} from '@angular/core';\nimport {catchError, debounceTime, distinctUntilChanged, map, startWith, tap} from 'rxjs/operators';\nimport {DataSourcePageResponse} from '../../interfaces/datasource.interface';\nimport {DataSource, DataSourceRequest} from '../../data/datasource.data';\nimport {combineLatest, Observable, of, Subscription} from 'rxjs';\nimport {FormControl, FormGroup} from '@angular/forms';\n\n@Directive({\n    selector: '[bbTableColumnDef]'\n})\nexport class BbTableColumnDef {\n}\n\n@Directive({\n    selector: '[bbTableRowDef]'\n})\nexport class BbTableRowDef {\n}\n\n@Component({\n    selector: 'bb-table',\n    templateUrl: './table.component.html',\n    styleUrls: ['./table.component.scss'],\n    host: {'class': 'bb-table'},\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    preserveWhitespaces: false\n})\nexport class BbTable implements OnInit, OnDestroy {\n\n    // Content.\n    @ContentChildren(BbTableColumnDef, {read: TemplateRef}) tableColumnTemplates: QueryList<TemplateRef<any>>;\n    @ContentChild(BbTableRowDef, {read: TemplateRef, static: false}) tableRowTemplate?: TemplateRef<any>;\n\n    // Inputs.\n    @Input() identifier: string | null = null;\n    @Input() dataSource: DataSource;\n    @Input() queryFields: string[] = [];\n    @Input() sortingStrategy: 'single' | 'multiple' = 'single';\n    @Input() header: TemplateRef<any> | boolean = true;\n    @Input() footer: TemplateRef<any> | boolean = true;\n\n    // Sizes.\n    private _sizes: number[] = [25, 50, 75, 100];\n\n    get sizes() {\n        return this._sizes;\n    }\n\n    @Input()\n    set sizes(newValue: number[]) {\n        this.updateSizes(newValue);\n    }\n\n    // Optimizations.\n    trackByFn = (index, item) => this.identifier ? item[this.identifier] : index;\n    trackByValue = (_, item) => item;\n\n    // Data.\n    request: DataSourceRequest;\n    data$: Observable<{ state: string, statusCode?: number, result?: DataSourcePageResponse }>;\n    isLoading$: Observable<boolean>;\n\n    // Form.\n    form: FormGroup;\n    queryControl = new FormControl('');\n\n    // State.\n    private _headerCount: number = 0;\n\n    // Subscriptions.\n    private _subscription: Subscription;\n\n    ngOnInit() {\n        this.composeForm();\n        this.watchDataChanges();\n    }\n\n    ngOnDestroy() {\n        this._subscription?.unsubscribe();\n    }\n\n    get headerCount() {\n        return this._headerCount;\n    }\n\n    get sortControl() {\n        return this.form?.get('sort') as FormGroup;\n    }\n\n    get pageNumberControl() {\n        return this.form?.get('pageNumber') as FormControl<number>;\n    }\n\n    get pageSizeControl() {\n        return this.form?.get('pageSize') as FormControl<number>;\n    }\n\n    refresh() {\n        return this.request.update();\n    }\n\n    setHeaderCount(amount: -1 | 1) {\n        this._headerCount += amount;\n    }\n\n    private updateSizes(newValue: number[]) {\n        // Validate the sizes has at least one value.\n        if (newValue.length <= 0) {\n            throw new Error('Cannot set an empty array as the sizes.');\n        }\n\n        // Set the new size.\n        this._sizes = newValue;\n\n        // Validate that the form exists already.\n        if (!this.form) {\n            return;\n        }\n\n        // Check if the current selected value is\n        // in the new sizes array.\n        const pageSizeControl = this.form.get('pageSize');\n        if (this._sizes.includes(pageSizeControl.value)) {\n            return;\n        }\n\n        // Set the first value in the array as\n        // the new value.\n        const firstValue = this._sizes[0];\n        pageSizeControl.setValue(firstValue);\n    }\n\n    private composeForm() {\n        // Setup the form.\n        this.form = new FormGroup({\n            pageSize: new FormControl<number>(this._sizes[0]),\n            pageNumber: new FormControl<number>(1),\n            sort: new FormGroup({})\n        });\n    }\n\n    private watchDataChanges() {\n        // Create a new request.\n        this.request = new DataSourceRequest();\n        this.isLoading$ = this.request.loading;\n\n        if (!this.dataSource) {\n            this.data$ = of({state: 'error_datasource'}).pipe(\n                tap(() => this.request.stopLoading())\n            );\n            return;\n        }\n\n        // Pass the request to the data source.\n        this.data$ = this.dataSource.handle(this.request).pipe(\n            tap(() => this.request.stopLoading()),\n            map(result => {\n                const count = (result && result.data && result.data.length) || 0;\n                if (count <= 0) {\n                    return {state: 'empty', result};\n                }\n\n                return {state: 'success', result};\n            }),\n            catchError(error => {\n                this.request.stopLoading();\n\n                const statusCode = error?.status ?? null;\n                const states = {\n                    0: 'error_down',\n                    401: 'error_unauthorized',\n                    403: 'error_forbidden',\n                    404: 'error_not_found',\n                    500: 'error_server'\n                };\n\n                return of({state: states?.[statusCode] ?? 'error_unknown', statusCode: statusCode});\n            })\n        );\n\n        // Subscribe to the data changes.\n        this.subscribeToChanges();\n    }\n\n    private subscribeToChanges() {\n        const form$ = this.getFormChanges();\n        const query$ = this.getQueryChanges();\n\n        this._subscription = combineLatest([form$, query$]).subscribe(([form, query]) => {\n            const {pageNumber, pageSize} = form;\n            const sort = Object.keys(form.sort)\n                .map(name => ({name, direction: form.sort[name]}))\n                .filter(item => ['asc', 'desc'].includes(item.direction));\n\n            this.request.startLoading();\n            return this.request.update({\n                sort,\n                query,\n                pageSize,\n                pageNumber,\n                queryFields: this.queryFields\n            });\n        });\n    }\n\n    private getQueryChanges() {\n        return this.queryControl.valueChanges.pipe(\n            debounceTime(400),\n            distinctUntilChanged(),\n            startWith(this.queryControl.value as string)\n        );\n    }\n\n    private getFormChanges() {\n        return this.form.valueChanges.pipe(\n            startWith(this.form.value as object)\n        );\n    }\n\n}\n","<!--\n    This is the header of the table. It can be a user\n    defined custom header or just the default header.\n-->\n\n<header *ngIf=\"(header === true ? headerTemplate : header) as template\"\n        class=\"bb-table-top-actions\">\n    <ng-container *ngTemplateOutlet=\"template\"></ng-container>\n</header>\n\n<!--\n    This is the table that contains the\n    rows and columns.\n-->\n\n<div class=\"bb-table-wrapper\">\n    <div *ngIf=\"isLoading$ | async\"\n         class=\"bb-table-progress\">\n        <div class=\"bb-table-indeterminate\"></div>\n    </div>\n    <table class=\"bb-table-container\">\n        <thead>\n            <tr>\n                <ng-content select=\"bb-table-header-cell\"></ng-content>\n            </tr>\n        </thead>\n        <tbody *ngIf=\"data$ | async as data; else isLoadingTemplate\"\n               [ngSwitch]=\"data?.state\">\n            <ng-container *ngSwitchCase=\"'success'\">\n                <ng-container *ngIf=\"!!tableRowTemplate; else tableCellsTemplates\">\n                    <ng-container\n                        *ngTemplateOutlet=\"tableRowTemplate; context: {data: data?.result?.data || []}\"></ng-container>\n                </ng-container>\n\n                <ng-template #tableCellsTemplates>\n                    <tr *ngFor=\"let item of data?.result?.data; trackBy: trackByFn\">\n                        <ng-container *ngFor=\"let template of tableColumnTemplates\">\n                            <ng-container *ngTemplateOutlet=\"template; context: {item: item}\"></ng-container>\n                        </ng-container>\n                    </tr>\n                </ng-template>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'empty'\">\n                <ng-container\n                    *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'error_datasource'\">\n                <ng-container\n                    *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'error_not_found'\">\n                <ng-container\n                    *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'error_server'\">\n                <ng-container\n                    *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'error_down'\">\n                <ng-container\n                    *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n            </ng-container>\n\n            <ng-container *ngSwitchDefault>\n                <ng-container\n                    *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n            </ng-container>\n        </tbody>\n    </table>\n</div>\n\n<footer *ngIf=\"(footer === true ? footerTemplate : footer) as template\"\n        class=\"bb-table-bottom-actions\">\n    <ng-container *ngTemplateOutlet=\"template\"></ng-container>\n</footer>\n\n<ng-template #isLoadingTemplate>\n    <tr>\n        <td [attr.colspan]=\"headerCount\"\n            class=\"bb-table-template\">\n            <div class=\"bb-table-template-content\">\n                {{ 'tables.loading' | bbLocalize }}\n            </div>\n        </td>\n    </tr>\n</ng-template>\n\n<!--\n    This is the template that will be used when the user has not\n    supplied a custom header template.\n-->\n\n<ng-template #headerTemplate>\n    <ng-content></ng-content>\n    <bb-form-control>\n        <input [formControl]=\"queryControl\"\n               [placeholder]=\"'tables.search' | bbLocalize\"\n               bbInput\n               autocomplete=\"off\">\n        <bb-icon *ngIf=\"queryControl?.value?.length <= 0; else closeButtonTemplate\"\n                 bbSuffix\n                 src=\"material:search\">\n        </bb-icon>\n    </bb-form-control>\n</ng-template>\n\n<!--\n    This is the template that will be used when the user has not\n    supplied a custom footer template.\n-->\n\n<ng-template #footerTemplate>\n    <bb-form-control *ngIf=\"sizes?.length > 1\">\n        <select [formControl]=\"pageSizeControl\"\n                bbInput\n                title=\"Sizes\">\n            <option *ngFor=\"let item of sizes; trackBy: trackByValue\"\n                    [ngValue]=\"item\">\n                {{ item }} / {{ 'tables.page' | bbLocalize }}\n            </option>\n        </select>\n    </bb-form-control>\n\n    <bb-table-pager [totalPages]=\"(data$ | async)?.result?.totalPages\"\n                    [formControl]=\"pageNumberControl\">\n    </bb-table-pager>\n</ng-template>\n\n<!--\n    This the template that will be used when the user\n    has filled in some data in the query control.\n-->\n\n<ng-template #closeButtonTemplate>\n    <button bbSuffix\n            (click)=\"queryControl?.patchValue('')\"\n            type=\"button\"\n            class=\"bb-table-progress-close-query\">\n        <bb-icon src=\"material:close\"></bb-icon>\n    </button>\n</ng-template>\n\n<ng-template #errorTemplate let-state=\"state\" let-status=\"statusCode\">\n    <tr>\n        <td [attr.colspan]=\"headerCount\"\n            class=\"bb-table-template\">\n            <div class=\"bb-table-template-content\">\n                <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"64\" height=\"41\">\n                    <g fill=\"none\" fill-rule=\"evenodd\" transform=\"translate(0 1)\">\n                        <ellipse cx=\"32\" cy=\"33\" fill=\"#F5F5F5\" rx=\"32\" ry=\"7\"></ellipse>\n                        <g fill-rule=\"nonzero\" stroke=\"#D9D9D9\">\n                            <path\n                                d=\"M55 12.7605604L44.8543047 1.25739633C44.3674414.47382661 43.6558789 0 42.9067617 0H21.0932383c-.7491172 0-1.4606797.47395025-1.947543 1.25739633L9 12.7605604V22h46v-9.2394396z\"></path>\n                            <path fill=\"#FAFAFA\"\n                                  d=\"M41.6132813 15.9315c0-1.6056489.9936718-2.931266 2.2264179-2.9315H55v18.1371277C55 33.2589574 53.6793867 35 52.0504297 35H11.94957031C10.32052344 35 9 33.2588404 9 31.1371277V13h11.1603008c1.2327461 0 2.226418 1.3228085 2.226418 2.9284574v.0211809c0 1.6056489 1.0049921 2.9015426 2.2377382 2.9015426h14.751086c1.2327461 0 2.2377383-1.3078298 2.2377383-2.9134788V15.9315z\"></path>\n                        </g>\n                    </g>\n                </svg>\n                <span *ngIf=\"state as stateLabel\">{{ ('tables.' + stateLabel) | bbLocalize }}</span>\n                <span *ngIf=\"status as statusCode\"\n                      class=\"bb-table-template-content-code\">(HTTP {{ statusCode }})</span>\n            </div>\n        </td>\n    </tr>\n</ng-template>\n"]}
191
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../../projects/bb-foundation/table/src/lib/components/table/table.component.ts","../../../../../../../projects/bb-foundation/table/src/lib/components/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component, ContentChild,\n    ContentChildren,\n    Directive,\n    Input,\n    OnDestroy,\n    OnInit,\n    QueryList,\n    TemplateRef,\n    ViewEncapsulation\n} from '@angular/core';\nimport {catchError, debounceTime, distinctUntilChanged, map, startWith, tap} from 'rxjs/operators';\nimport {DataSourcePageResponse} from '../../interfaces/datasource.interface';\nimport {DataSource, DataSourceRequest} from '../../data/datasource.data';\nimport {combineLatest, Observable, of, Subscription} from 'rxjs';\nimport {FormControl, FormGroup} from '@angular/forms';\n\n@Directive({\n    selector: '[bbTableColumnDef]'\n})\nexport class BbTableColumnDef {\n}\n\n@Directive({\n    selector: '[bbTableRowDef]'\n})\nexport class BbTableRowDef {\n}\n\n@Component({\n    selector: 'bb-table',\n    templateUrl: './table.component.html',\n    styleUrls: ['./table.component.scss'],\n    host: {'class': 'bb-table'},\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    preserveWhitespaces: false\n})\nexport class BbTable implements OnInit, OnDestroy {\n\n    // Content.\n    @ContentChildren(BbTableColumnDef, {read: TemplateRef}) tableColumnTemplates: QueryList<TemplateRef<any>>;\n    @ContentChild(BbTableRowDef, {read: TemplateRef, static: false}) tableRowTemplate?: TemplateRef<any>;\n\n    // Inputs.\n    @Input() identifier: string | null = null;\n    @Input() dataSource: DataSource;\n    @Input() queryFields: string[] = [];\n    @Input() sortingStrategy: 'single' | 'multiple' = 'single';\n    @Input() header: TemplateRef<any> | boolean = true;\n    @Input() footer: TemplateRef<any> | boolean = true;\n\n    // Sizes.\n    private _sizes: number[] = [25, 50, 75, 100];\n\n    get sizes() {\n        return this._sizes;\n    }\n\n    @Input()\n    set sizes(newValue: number[]) {\n        this.updateSizes(newValue);\n    }\n\n    // Optimizations.\n    trackByFn = (index, item) => this.identifier ? item[this.identifier] : index;\n    trackByValue = (_, item) => item;\n\n    // Data.\n    request: DataSourceRequest;\n    data$: Observable<{ state: string, statusCode?: number, result?: DataSourcePageResponse }>;\n    isLoading$: Observable<boolean>;\n\n    // Form.\n    form: FormGroup;\n    queryControl = new FormControl('');\n\n    // State.\n    private _headerCount: number = 0;\n\n    // Subscriptions.\n    private _subscription: Subscription;\n\n    ngOnInit() {\n        this.composeForm();\n        this.watchDataChanges();\n    }\n\n    ngOnDestroy() {\n        this._subscription?.unsubscribe();\n    }\n\n    get headerCount() {\n        return this._headerCount;\n    }\n\n    get sortControl() {\n        return this.form?.get('sort') as FormGroup;\n    }\n\n    get pageNumberControl() {\n        return this.form?.get('pageNumber') as FormControl<number>;\n    }\n\n    get pageSizeControl() {\n        return this.form?.get('pageSize') as FormControl<number>;\n    }\n\n    refresh() {\n        return this.request.update();\n    }\n\n    setHeaderCount(amount: -1 | 1) {\n        this._headerCount += amount;\n    }\n\n    private updateSizes(newValue: number[]) {\n        // Validate the sizes has at least one value.\n        if (newValue.length <= 0) {\n            throw new Error('Cannot set an empty array as the sizes.');\n        }\n\n        // Set the new size.\n        this._sizes = newValue;\n\n        // Validate that the form exists already.\n        if (!this.form) {\n            return;\n        }\n\n        // Check if the current selected value is\n        // in the new sizes array.\n        const pageSizeControl = this.form.get('pageSize');\n        if (this._sizes.includes(pageSizeControl.value)) {\n            return;\n        }\n\n        // Set the first value in the array as\n        // the new value.\n        const firstValue = this._sizes[0];\n        pageSizeControl.setValue(firstValue);\n    }\n\n    private composeForm() {\n        // Setup the form.\n        this.form = new FormGroup({\n            pageSize: new FormControl<number>(this._sizes[0]),\n            pageNumber: new FormControl<number>(1),\n            sort: new FormGroup({})\n        });\n    }\n\n    private watchDataChanges() {\n        // Create a new request.\n        this.request = new DataSourceRequest();\n        this.isLoading$ = this.request.loading;\n\n        if (!this.dataSource) {\n            this.data$ = of({state: 'error_datasource'}).pipe(\n                tap(() => this.request.stopLoading())\n            );\n            return;\n        }\n\n        // Pass the request to the data source.\n        this.data$ = this.dataSource.handle(this.request).pipe(\n            tap(() => this.request.stopLoading()),\n            map(result => {\n                const count = (result && result.data && result.data.length) || 0;\n                if (count <= 0) {\n                    return {state: 'empty', result};\n                }\n\n                return {state: 'success', result};\n            }),\n            catchError(error => {\n                this.request.stopLoading();\n\n                const statusCode = error?.status ?? null;\n                const states = {\n                    0: 'error_down',\n                    401: 'error_unauthorized',\n                    403: 'error_forbidden',\n                    404: 'error_not_found',\n                    500: 'error_server'\n                };\n\n                return of({state: states?.[statusCode] ?? 'error_unknown', statusCode: statusCode});\n            })\n        );\n\n        // Subscribe to the data changes.\n        this.subscribeToChanges();\n    }\n\n    private subscribeToChanges() {\n        const form$ = this.getFormChanges();\n        const query$ = this.getQueryChanges();\n\n        this._subscription = combineLatest([form$, query$]).subscribe(([form, query]) => {\n            const {pageNumber, pageSize} = form;\n            const sort = Object.keys(form.sort)\n                .map(name => ({name, direction: form.sort[name]}))\n                .filter(item => ['asc', 'desc'].includes(item.direction));\n\n            this.request.startLoading();\n            return this.request.update({\n                sort,\n                query,\n                pageSize,\n                pageNumber,\n                queryFields: this.queryFields\n            });\n        });\n    }\n\n    private getQueryChanges() {\n        return this.queryControl.valueChanges.pipe(\n            debounceTime(400),\n            distinctUntilChanged(),\n            startWith(this.queryControl.value as string)\n        );\n    }\n\n    private getFormChanges() {\n        return this.form.valueChanges.pipe(\n            startWith(this.form.value as object)\n        );\n    }\n\n}\n","<!--\n    This is the header of the table. It can be a user\n    defined custom header or just the default header.\n-->\n\n<header *ngIf=\"(header === true ? headerTemplate : header) as template\"\n        class=\"bb-table-top-actions\">\n    <ng-container *ngTemplateOutlet=\"template\"></ng-container>\n</header>\n\n<!--\n    This is the table that contains the\n    rows and columns.\n-->\n\n<div class=\"bb-table-wrapper\">\n    <div *ngIf=\"isLoading$ | async\"\n         class=\"bb-table-progress\">\n        <div class=\"bb-table-indeterminate\"></div>\n    </div>\n    <table class=\"bb-table-container\">\n        <thead>\n            <tr>\n                <ng-content select=\"bb-table-header-cell\"></ng-content>\n            </tr>\n        </thead>\n        <tbody *ngIf=\"data$ | async as data; else isLoadingTemplate\"\n               [ngSwitch]=\"data?.state\">\n            <ng-container *ngSwitchCase=\"'success'\">\n                <ng-container *ngIf=\"!!tableRowTemplate; else tableCellsTemplates\">\n                    <ng-container\n                        *ngTemplateOutlet=\"tableRowTemplate; context: {data: data?.result?.data || []}\"></ng-container>\n                </ng-container>\n\n                <ng-template #tableCellsTemplates>\n                    <tr *ngFor=\"let item of data?.result?.data; trackBy: trackByFn\">\n                        <ng-container *ngFor=\"let template of tableColumnTemplates\">\n                            <ng-container *ngTemplateOutlet=\"template; context: {item: item}\"></ng-container>\n                        </ng-container>\n                    </tr>\n                </ng-template>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'empty'\">\n                <ng-container\n                    *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'error_datasource'\">\n                <ng-container\n                    *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'error_not_found'\">\n                <ng-container\n                    *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'error_server'\">\n                <ng-container\n                    *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'error_down'\">\n                <ng-container\n                    *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n            </ng-container>\n\n            <ng-container *ngSwitchDefault>\n                <ng-container\n                    *ngTemplateOutlet=\"errorTemplate; context: data\"></ng-container>\n            </ng-container>\n        </tbody>\n    </table>\n</div>\n\n<footer *ngIf=\"(footer === true ? footerTemplate : footer) as template\"\n        class=\"bb-table-bottom-actions\">\n    <ng-container *ngTemplateOutlet=\"template\"></ng-container>\n</footer>\n\n<ng-template #isLoadingTemplate>\n    <tr>\n        <td [attr.colspan]=\"headerCount\"\n            class=\"bb-table-template\">\n            <div class=\"bb-table-template-content\">\n                {{ 'tables.loading' | bbLocalize }}\n            </div>\n        </td>\n    </tr>\n</ng-template>\n\n<!--\n    This is the template that will be used when the user has not\n    supplied a custom header template.\n-->\n\n<ng-template #headerTemplate>\n    <ng-content></ng-content>\n    <bb-form-control>\n        <input [formControl]=\"queryControl\"\n               [placeholder]=\"'tables.search' | bbLocalize\"\n               bbInput\n               autocomplete=\"off\">\n        <bb-icon *ngIf=\"queryControl?.value?.length <= 0; else closeButtonTemplate\"\n                 bbSuffix\n                 src=\"material:search\">\n        </bb-icon>\n    </bb-form-control>\n</ng-template>\n\n<!--\n    This is the template that will be used when the user has not\n    supplied a custom footer template.\n-->\n\n<ng-template #footerTemplate>\n    <bb-form-control *ngIf=\"sizes?.length > 1\">\n        <select [formControl]=\"pageSizeControl\"\n                bbInput\n                title=\"Sizes\">\n            <option *ngFor=\"let item of sizes; trackBy: trackByValue\"\n                    [ngValue]=\"item\">\n                {{ item }} / {{ 'tables.page' | bbLocalize }}\n            </option>\n        </select>\n    </bb-form-control>\n\n    <bb-table-pager [totalPages]=\"(data$ | async)?.result?.totalPages\"\n                    [formControl]=\"pageNumberControl\">\n    </bb-table-pager>\n</ng-template>\n\n<!--\n    This the template that will be used when the user\n    has filled in some data in the query control.\n-->\n\n<ng-template #closeButtonTemplate>\n    <button bbSuffix\n            (click)=\"queryControl?.patchValue('')\"\n            type=\"button\"\n            class=\"bb-table-progress-close-query\">\n        <bb-icon src=\"material:close\"></bb-icon>\n    </button>\n</ng-template>\n\n<ng-template #errorTemplate let-state=\"state\" let-status=\"statusCode\">\n    <tr>\n        <td [attr.colspan]=\"headerCount\"\n            class=\"bb-table-template\">\n            <div class=\"bb-table-template-content\">\n                <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"64\" height=\"41\">\n                    <g fill=\"none\" fill-rule=\"evenodd\" transform=\"translate(0 1)\">\n                        <ellipse cx=\"32\" cy=\"33\" fill=\"#F5F5F5\" rx=\"32\" ry=\"7\"></ellipse>\n                        <g fill-rule=\"nonzero\" stroke=\"#D9D9D9\">\n                            <path\n                                d=\"M55 12.7605604L44.8543047 1.25739633C44.3674414.47382661 43.6558789 0 42.9067617 0H21.0932383c-.7491172 0-1.4606797.47395025-1.947543 1.25739633L9 12.7605604V22h46v-9.2394396z\"></path>\n                            <path fill=\"#FAFAFA\"\n                                  d=\"M41.6132813 15.9315c0-1.6056489.9936718-2.931266 2.2264179-2.9315H55v18.1371277C55 33.2589574 53.6793867 35 52.0504297 35H11.94957031C10.32052344 35 9 33.2588404 9 31.1371277V13h11.1603008c1.2327461 0 2.226418 1.3228085 2.226418 2.9284574v.0211809c0 1.6056489 1.0049921 2.9015426 2.2377382 2.9015426h14.751086c1.2327461 0 2.2377383-1.3078298 2.2377383-2.9134788V15.9315z\"></path>\n                        </g>\n                    </g>\n                </svg>\n                <span *ngIf=\"state as stateLabel\">{{ ('tables.' + stateLabel) | bbLocalize }}</span>\n                <span *ngIf=\"status as statusCode\"\n                      class=\"bb-table-template-content-code\">(HTTP {{ statusCode }})</span>\n            </div>\n        </td>\n    </tr>\n</ng-template>\n"]}
@@ -2,10 +2,10 @@ import { ChangeDetectionStrategy, Component, ViewEncapsulation } from '@angular/
2
2
  import * as i0 from "@angular/core";
3
3
  export class BbTableCell {
4
4
  }
5
- BbTableCell.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: BbTableCell, deps: [], target: i0.ɵɵFactoryTarget.Component });
6
- BbTableCell.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.2", type: BbTableCell, selector: "bb-table-cell", host: { classAttribute: "bb-table-cell" }, ngImport: i0, template: "<div>\n <ng-content></ng-content>\n</div>", styles: [".bb-table-cell{color:#848f99;font-size:14px;text-align:left;line-height:1.2;font-weight:400;padding:12px 20px;display:table-cell;word-wrap:break-word;vertical-align:middle;background-color:#f5f5f5;border-bottom:1px solid #d8d8d8}.bb-table-cell:not(:last-child){border-right:1px solid #d8d8d8}.bb-table-cell.fit{width:1%;white-space:nowrap}.bb-table-cell.left{text-align:left}.bb-table-cell.center{text-align:center}.bb-table-cell.right{text-align:right}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
7
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: BbTableCell, decorators: [{
5
+ BbTableCell.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: BbTableCell, deps: [], target: i0.ɵɵFactoryTarget.Component });
6
+ BbTableCell.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: BbTableCell, selector: "bb-table-cell", host: { classAttribute: "bb-table-cell" }, ngImport: i0, template: "<div>\n <ng-content></ng-content>\n</div>", styles: [".bb-table-cell{color:#848f99;font-size:14px;text-align:left;line-height:1.2;font-weight:400;padding:12px 20px;display:table-cell;word-wrap:break-word;vertical-align:middle;background-color:#f5f5f5;border-bottom:1px solid #d8d8d8}.bb-table-cell:not(:last-child){border-right:1px solid #d8d8d8}.bb-table-cell.fit{width:1%;white-space:nowrap}.bb-table-cell.left{text-align:left}.bb-table-cell.center{text-align:center}.bb-table-cell.right{text-align:right}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
7
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: BbTableCell, decorators: [{
8
8
  type: Component,
9
9
  args: [{ selector: 'bb-table-cell', changeDetection: ChangeDetectionStrategy.OnPush, host: { 'class': 'bb-table-cell' }, encapsulation: ViewEncapsulation.None, preserveWhitespaces: false, template: "<div>\n <ng-content></ng-content>\n</div>", styles: [".bb-table-cell{color:#848f99;font-size:14px;text-align:left;line-height:1.2;font-weight:400;padding:12px 20px;display:table-cell;word-wrap:break-word;vertical-align:middle;background-color:#f5f5f5;border-bottom:1px solid #d8d8d8}.bb-table-cell:not(:last-child){border-right:1px solid #d8d8d8}.bb-table-cell.fit{width:1%;white-space:nowrap}.bb-table-cell.left{text-align:left}.bb-table-cell.center{text-align:center}.bb-table-cell.right{text-align:right}\n"] }]
10
10
  }] });
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY2VsbC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYi1mb3VuZGF0aW9uL3RhYmxlL3NyYy9saWIvY29tcG9uZW50cy90YWJsZS1jZWxsL3RhYmxlLWNlbGwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmItZm91bmRhdGlvbi90YWJsZS9zcmMvbGliL2NvbXBvbmVudHMvdGFibGUtY2VsbC90YWJsZS1jZWxsLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsaUJBQWlCLEVBQUMsTUFBTSxlQUFlLENBQUM7O0FBV3BGLE1BQU0sT0FBTyxXQUFXOzt3R0FBWCxXQUFXOzRGQUFYLFdBQVcsZ0dDWHhCLDhDQUVNOzJGRFNPLFdBQVc7a0JBVHZCLFNBQVM7K0JBQ0ksZUFBZSxtQkFHUix1QkFBdUIsQ0FBQyxNQUFNLFFBQ3pDLEVBQUMsT0FBTyxFQUFFLGVBQWUsRUFBQyxpQkFDakIsaUJBQWlCLENBQUMsSUFBSSx1QkFDaEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgVmlld0VuY2Fwc3VsYXRpb259IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2JiLXRhYmxlLWNlbGwnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi90YWJsZS1jZWxsLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi90YWJsZS1jZWxsLmNvbXBvbmVudC5zY3NzJ10sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gICAgaG9zdDogeydjbGFzcyc6ICdiYi10YWJsZS1jZWxsJ30sXG4gICAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgICBwcmVzZXJ2ZVdoaXRlc3BhY2VzOiBmYWxzZVxufSlcbmV4cG9ydCBjbGFzcyBCYlRhYmxlQ2VsbCB7XG59XG4iLCI8ZGl2PlxuICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbjwvZGl2PiJdfQ==
11
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY2VsbC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYi1mb3VuZGF0aW9uL3RhYmxlL3NyYy9saWIvY29tcG9uZW50cy90YWJsZS1jZWxsL3RhYmxlLWNlbGwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmItZm91bmRhdGlvbi90YWJsZS9zcmMvbGliL2NvbXBvbmVudHMvdGFibGUtY2VsbC90YWJsZS1jZWxsLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsaUJBQWlCLEVBQUMsTUFBTSxlQUFlLENBQUM7O0FBV3BGLE1BQU0sT0FBTyxXQUFXOzt5R0FBWCxXQUFXOzZGQUFYLFdBQVcsZ0dDWHhCLDhDQUVNOzRGRFNPLFdBQVc7a0JBVHZCLFNBQVM7K0JBQ0ksZUFBZSxtQkFHUix1QkFBdUIsQ0FBQyxNQUFNLFFBQ3pDLEVBQUMsT0FBTyxFQUFFLGVBQWUsRUFBQyxpQkFDakIsaUJBQWlCLENBQUMsSUFBSSx1QkFDaEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgVmlld0VuY2Fwc3VsYXRpb259IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2JiLXRhYmxlLWNlbGwnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi90YWJsZS1jZWxsLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi90YWJsZS1jZWxsLmNvbXBvbmVudC5zY3NzJ10sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gICAgaG9zdDogeydjbGFzcyc6ICdiYi10YWJsZS1jZWxsJ30sXG4gICAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgICBwcmVzZXJ2ZVdoaXRlc3BhY2VzOiBmYWxzZVxufSlcbmV4cG9ydCBjbGFzcyBCYlRhYmxlQ2VsbCB7XG59XG4iLCI8ZGl2PlxuICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbjwvZGl2PiJdfQ==
@@ -105,9 +105,9 @@ export class BbTableHeaderCell extends BbTableHeaderCellMixinBase {
105
105
  this._table?.sortControl?.patchValue(newValue);
106
106
  }
107
107
  }
108
- BbTableHeaderCell.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: BbTableHeaderCell, deps: [{ token: i1.BbTable, host: true, optional: true }, { token: 'name', attribute: true, optional: true }], target: i0.ɵɵFactoryTarget.Component });
109
- BbTableHeaderCell.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.2", type: BbTableHeaderCell, selector: "bb-table-header-cell", inputs: { disabled: "disabled", sort: "sort" }, host: { listeners: { "click": "onClick()" }, properties: { "class.disabled": "isDisabled" }, classAttribute: "bb-table-header-cell" }, usesInheritance: true, ngImport: i0, template: "<!-- The content. -->\n<ng-content></ng-content>\n\n<!-- The indicator for the sort direction. -->\n<ng-container *ngIf=\"valueChanges$ | async as value\">\n <button *ngIf=\"!isDisabled\"\n [class.asc]=\"value === 'asc'\"\n [class.desc]=\"value === 'desc'\"\n class=\"bb-table-header-cell-toggle\"\n type=\"button\"></button>\n</ng-container>\n", styles: [".bb-table-header-cell{height:50px;color:#212529;cursor:pointer;font-size:16px;font-weight:500;-webkit-user-select:none;user-select:none;padding:10px 20px;position:relative;display:table-cell;vertical-align:middle;border-bottom:1px solid #d8d8d8}.bb-table-header-cell:active>.bb-table-header-cell-toggle{background-color:#00000014}.bb-table-header-cell:not(.disabled){padding-right:52px}.bb-table-header-cell.fit{width:1%;white-space:nowrap}.bb-table-header-cell.left{text-align:left}.bb-table-header-cell.center{text-align:center}.bb-table-header-cell.right{text-align:right}.bb-table-header-cell.disabled{cursor:default;pointer-events:none}.bb-table-header-cell-toggle{top:50%;right:14px;width:22px;border:none;height:22px;margin-left:auto;position:absolute;border-radius:4px;transform:translateY(-50%);background-position:center;background-repeat:no-repeat;background-color:transparent;transition:background-color .2s cubic-bezier(0,0,.2,1);background-image:url('data:image/svg+xml,%3Csvg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 9 15\" width=\"9\" height=\"15\"%3E%3Cpath fill=\"%23dcdcdc\" d=\"M4.5 0L0 7h9z\"%3E%3C/path%3E%3Cpath fill=\"%23dcdcdc\" d=\"M4.5 15L9 8H0z\"%3E%3C/path%3E%3C/svg%3E')}.bb-table-header-cell-toggle.desc{background-image:url('data:image/svg+xml,%3Csvg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 9 15\" width=\"9\" height=\"15\"%3E%3Cpath fill=\"%23dcdcdc\" d=\"M4.5 0L0 7h9z\"%3E%3C/path%3E%3Cpath fill=\"black\" d=\"M4.5 15L9 8H0z\"%3E%3C/path%3E%3C/svg%3E')}.bb-table-header-cell-toggle.asc{background-image:url('data:image/svg+xml,%3Csvg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 9 15\" width=\"9\" height=\"15\"%3E%3Cpath fill=\"black\" d=\"M4.5 0L0 7h9z\"%3E%3C/path%3E%3Cpath fill=\"%23dcdcdc\" d=\"M4.5 15L9 8H0z\"%3E%3C/path%3E%3C/svg%3E')}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
110
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: BbTableHeaderCell, decorators: [{
108
+ BbTableHeaderCell.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: BbTableHeaderCell, deps: [{ token: i1.BbTable, host: true, optional: true }, { token: 'name', attribute: true, optional: true }], target: i0.ɵɵFactoryTarget.Component });
109
+ BbTableHeaderCell.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: BbTableHeaderCell, selector: "bb-table-header-cell", inputs: { disabled: "disabled", sort: "sort" }, host: { listeners: { "click": "onClick()" }, properties: { "class.disabled": "isDisabled" }, classAttribute: "bb-table-header-cell" }, usesInheritance: true, ngImport: i0, template: "<!-- The content. -->\n<ng-content></ng-content>\n\n<!-- The indicator for the sort direction. -->\n<ng-container *ngIf=\"valueChanges$ | async as value\">\n <button *ngIf=\"!isDisabled\"\n [class.asc]=\"value === 'asc'\"\n [class.desc]=\"value === 'desc'\"\n class=\"bb-table-header-cell-toggle\"\n type=\"button\"></button>\n</ng-container>\n", styles: [".bb-table-header-cell{height:50px;color:#212529;cursor:pointer;font-size:16px;font-weight:500;-webkit-user-select:none;user-select:none;padding:10px 20px;position:relative;display:table-cell;vertical-align:middle;border-bottom:1px solid #d8d8d8}.bb-table-header-cell:active>.bb-table-header-cell-toggle{background-color:#00000014}.bb-table-header-cell:not(.disabled){padding-right:52px}.bb-table-header-cell.fit{width:1%;white-space:nowrap}.bb-table-header-cell.left{text-align:left}.bb-table-header-cell.center{text-align:center}.bb-table-header-cell.right{text-align:right}.bb-table-header-cell.disabled{cursor:default;pointer-events:none}.bb-table-header-cell-toggle{top:50%;right:14px;width:22px;border:none;height:22px;margin-left:auto;position:absolute;border-radius:4px;transform:translateY(-50%);background-position:center;background-repeat:no-repeat;background-color:transparent;transition:background-color .2s cubic-bezier(0,0,.2,1);background-image:url('data:image/svg+xml,%3Csvg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 9 15\" width=\"9\" height=\"15\"%3E%3Cpath fill=\"%23dcdcdc\" d=\"M4.5 0L0 7h9z\"%3E%3C/path%3E%3Cpath fill=\"%23dcdcdc\" d=\"M4.5 15L9 8H0z\"%3E%3C/path%3E%3C/svg%3E')}.bb-table-header-cell-toggle.desc{background-image:url('data:image/svg+xml,%3Csvg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 9 15\" width=\"9\" height=\"15\"%3E%3Cpath fill=\"%23dcdcdc\" d=\"M4.5 0L0 7h9z\"%3E%3C/path%3E%3Cpath fill=\"black\" d=\"M4.5 15L9 8H0z\"%3E%3C/path%3E%3C/svg%3E')}.bb-table-header-cell-toggle.asc{background-image:url('data:image/svg+xml,%3Csvg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 9 15\" width=\"9\" height=\"15\"%3E%3Cpath fill=\"black\" d=\"M4.5 0L0 7h9z\"%3E%3C/path%3E%3Cpath fill=\"%23dcdcdc\" d=\"M4.5 15L9 8H0z\"%3E%3C/path%3E%3C/svg%3E')}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
110
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: BbTableHeaderCell, decorators: [{
111
111
  type: Component,
112
112
  args: [{ selector: 'bb-table-header-cell', changeDetection: ChangeDetectionStrategy.OnPush, host: {
113
113
  'class': 'bb-table-header-cell',
@@ -128,4 +128,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.2", ngImpor
128
128
  type: HostListener,
129
129
  args: ['click']
130
130
  }] } });
131
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-header-cell.component.js","sourceRoot":"","sources":["../../../../../../../projects/bb-foundation/table/src/lib/components/table-header-cell/table-header-cell.component.ts","../../../../../../../projects/bb-foundation/table/src/lib/components/table-header-cell/table-header-cell.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,SAAS,EACT,uBAAuB,EACvB,SAAS,EACT,IAAI,EACJ,YAAY,EACZ,KAAK,EAGL,QAAQ,EACR,iBAAiB,EACpB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAoC,aAAa,EAAC,MAAM,yBAAyB,CAAC;AAGzF,OAAO,EAAC,WAAW,EAAC,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAC,SAAS,EAAC,MAAM,gBAAgB,CAAC;;;;AAGzC,MAAM,qBAAqB;CAC1B;AAED,MAAM,0BAA0B,GACK,aAAa,CAAC,qBAAqB,CAAC,CAAC;AAe1E,MAAM,OAAO,iBAAkB,SAAQ,0BAA0B;IAyB7D,YAAwC,MAAgB,EACL,KAAc;QAC7D,KAAK,EAAE,CAAC;QAF4B,WAAM,GAAN,MAAM,CAAU;QACL,UAAK,GAAL,KAAK,CAAS;QAxBjE,aAAa;QACI,oBAAe,GAA8B,CAAC,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;QACrE,aAAQ,GAAG,IAAI,WAAW,CAA0B,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC;QAsHtF,eAAU,GAAG,CAAC,OAAe,EAAE,EAAE;YACrC,OAAO,IAAI,OAAO,CAAC,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACrD,CAAC,CAAC;IAhGF,CAAC;IAnBD,QAAQ;IACR,IACI,IAAI,CAAC,KAA8B;QACnC,2CAA2C;QAC3C,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE;YACvC,OAAO;SACV;QAED,iBAAiB;QACjB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAClC,CAAC;IAED,IAAI,IAAI;QACJ,OAAO,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC;IAC/B,CAAC;IAOD,QAAQ;QACJ,4CAA4C;QAC5C,IAAI,CAAC,MAAM,EAAE,cAAc,EAAE,CAAC,CAAC,CAAC,CAAC;QACjC,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YAC7B,OAAO;SACV;QAED,oDAAoD;QACpD,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;YAC/C,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;YACrB,OAAO,IAAI,CAAC,UAAU,CAAC,gCAAgC,IAAI,CAAC,KAAK,2DAA2D,CAAC,CAAC;SACjI;QAED,2CAA2C;QAC3C,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,UAAU,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QAE/D,6BAA6B;QAC7B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,CAChD,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAe,CAAC,CAC3C,CAAC;IACN,CAAC;IAED,WAAW;QACP,IAAI,CAAC,MAAM,EAAE,cAAc,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAClC,4CAA4C;QAC5C,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YAC7B,OAAO;SACV;QAED,8CAA8C;QAC9C,IAAI,IAAI,CAAC,MAAM,EAAE,WAAW,EAAE,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;YAChD,IAAI,CAAC,MAAM,EAAE,WAAW,EAAE,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACvD;IACL,CAAC;IAED,IAAI,UAAU;QACV,OAAO,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;IACxC,CAAC;IAGD,OAAO;QACH,wCAAwC;QACxC,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,OAAO;SACV;QAED,yCAAyC;QACzC,wBAAwB;QACxB,MAAM,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,KAAK,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACnF,MAAM,QAAQ,GAAG,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC;QAC3D,MAAM,OAAO,GAAG,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;QAE/C,oBAAoB;QACpB,OAAO,IAAI,CAAC,wBAAwB,CAAC,OAAO,CAAC,CAAC;IAClD,CAAC;IAEO,wBAAwB,CAAC,KAA8B;QAC3D,2CAA2C;QAC3C,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE;YACvC,OAAO;SACV;QAED,6BAA6B;QAC7B,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YACd,OAAO,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;SACxC;QAED,sCAAsC;QACtC,IAAI,IAAI,CAAC,MAAM,CAAC,eAAe,KAAK,QAAQ,EAAE;YAC1C,OAAO,IAAI,CAAC,2BAA2B,CAAC,KAAK,CAAC,CAAC;SAClD;QAED,sCAAsC;QACtC,WAAW;QACX,OAAO,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC;IAEO,2BAA2B,CAAC,KAAa;QAC7C,wBAAwB;QACxB,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC;QAExC,gDAAgD;QAChD,qDAAqD;QACrD,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,OAAO,EAAE,EAAE;YACxE,QAAQ,CAAC,OAAO,CAAC,GAAG,OAAO,KAAK,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC;YAC5D,OAAO,QAAQ,CAAC;QACpB,CAAC,EAAE,EAAE,CAAC,CAAC;QAEP,+BAA+B;QAC/B,IAAI,CAAC,MAAM,EAAE,WAAW,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC;IACnD,CAAC;;8GAxHQ,iBAAiB,qEA0BS,MAAM;kGA1BhC,iBAAiB,0QCtC9B,yYAWA;2FD2Ba,iBAAiB;kBAb7B,SAAS;+BACI,sBAAsB,mBAGf,uBAAuB,CAAC,MAAM,QACzC;wBACF,OAAO,EAAE,sBAAsB;wBAC/B,kBAAkB,EAAE,YAAY;qBACnC,UACO,CAAC,UAAU,CAAC,iBACL,iBAAiB,CAAC,IAAI,uBAChB,KAAK;;0BA2Bb,QAAQ;;0BAAI,IAAI;;0BAChB,QAAQ;;0BAAI,SAAS;2BAAC,MAAM;4CAfrC,IAAI;sBADP,KAAK;gBA4DN,OAAO;sBADN,YAAY;uBAAC,OAAO","sourcesContent":["import {\n    Attribute,\n    ChangeDetectionStrategy,\n    Component,\n    Host,\n    HostListener,\n    Input,\n    OnDestroy,\n    OnInit,\n    Optional,\n    ViewEncapsulation\n} from '@angular/core';\nimport {CanDisable, CanDisableConstructor, mixinDisabled} from '@bravobit/bb-foundation';\nimport {TableColumnSortStrategy} from '../../interfaces/table.interfaces';\nimport {BbTable} from '../table/table.component';\nimport {FormControl} from '@angular/forms';\nimport {startWith} from 'rxjs/operators';\nimport {Observable} from 'rxjs';\n\nclass BbTableHeaderCellBase {\n}\n\nconst BbTableHeaderCellMixinBase: CanDisableConstructor\n    & typeof BbTableHeaderCellBase = mixinDisabled(BbTableHeaderCellBase);\n\n@Component({\n    selector: 'bb-table-header-cell',\n    templateUrl: './table-header-cell.component.html',\n    styleUrls: ['./table-header-cell.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        'class': 'bb-table-header-cell',\n        '[class.disabled]': 'isDisabled'\n    },\n    inputs: ['disabled'],\n    encapsulation: ViewEncapsulation.None,\n    preserveWhitespaces: false\n})\nexport class BbTableHeaderCell extends BbTableHeaderCellMixinBase implements OnInit, OnDestroy, CanDisable {\n\n    // Constants.\n    private readonly _sortDirections: TableColumnSortStrategy[] = ['none', 'asc', 'desc'];\n    private readonly _control = new FormControl<TableColumnSortStrategy>(this._sortDirections[0]);\n\n    // Data.\n    valueChanges$: Observable<string>;\n\n    // Sort.\n    @Input()\n    set sort(value: TableColumnSortStrategy) {\n        // Check if the new value is a valid value.\n        if (!this._sortDirections.includes(value)) {\n            return;\n        }\n\n        // Set the value.\n        this._control.setValue(value);\n    }\n\n    get sort() {\n        return this._control.value;\n    }\n\n    constructor(@Optional() @Host() private _table?: BbTable,\n                @Optional() @Attribute('name') private _name?: string) {\n        super();\n    }\n\n    ngOnInit() {\n        // Validate that the name and table are set.\n        this._table?.setHeaderCount?.(1);\n        if (!this._table || !this._name) {\n            return;\n        }\n\n        // Check if the control already exists in the table.\n        if (this._table.sortControl?.contains(this._name)) {\n            this.disabled = true;\n            return this.logWarning(`BbTableHeaderCell: The name \"${this._name}\" is not unique in the table; Control was not registered.`);\n        }\n\n        // Register the header cell with the table.\n        this._table.sortControl?.addControl(this._name, this._control);\n\n        // Get all the value changes.\n        this.valueChanges$ = this._control.valueChanges.pipe(\n            startWith(this._control.value as string)\n        );\n    }\n\n    ngOnDestroy() {\n        this._table?.setHeaderCount?.(-1);\n        // Validate that the name and table are set.\n        if (!this._table || !this._name) {\n            return;\n        }\n\n        // Un-register the header cell with the table.\n        if (this._table?.sortControl?.contains(this._name)) {\n            this._table?.sortControl?.removeControl(this._name);\n        }\n    }\n\n    get isDisabled() {\n        return this.disabled || !this._name;\n    }\n\n    @HostListener('click')\n    onClick() {\n        // Check if the header cell is disabled.\n        if (this.isDisabled) {\n            return;\n        }\n\n        // Find the index of the current sort and\n        // create the new index.\n        const index = this._sortDirections.findIndex(item => item === this._control.value);\n        const newIndex = (index + 1) % this._sortDirections.length;\n        const newSort = this._sortDirections[newIndex];\n\n        // Set the new sort.\n        return this.updateTableAndHeaderCell(newSort);\n    }\n\n    private updateTableAndHeaderCell(value: TableColumnSortStrategy) {\n        // Check if the new value is a valid value.\n        if (!this._sortDirections.includes(value)) {\n            return;\n        }\n\n        // Validate the table exists.\n        if (!this._table) {\n            return this._control.setValue(value);\n        }\n\n        // Handle the single sorting strategy.\n        if (this._table.sortingStrategy === 'single') {\n            return this.handleSingleSortingStrategy(value);\n        }\n\n        // Default case when no other strategy\n        // is used.\n        return this._control.setValue(value);\n    }\n\n    private handleSingleSortingStrategy(value: string) {\n        // Get the sort control.\n        const control = this._table.sortControl;\n\n        // Set each value to false since we only want to\n        // sort on one property at a time with this strategy.\n        const newValue = Object.keys(control.controls).reduce((previous, current) => {\n            previous[current] = current === this._name ? value : 'none';\n            return previous;\n        }, {});\n\n        // Patch the entire sort value.\n        this._table?.sortControl?.patchValue(newValue);\n    }\n\n    private logWarning = (message: string) => {\n        console && console.warn && console.warn(message);\n    };\n\n}\n","<!-- The content. -->\n<ng-content></ng-content>\n\n<!-- The indicator for the sort direction. -->\n<ng-container *ngIf=\"valueChanges$ | async as value\">\n    <button *ngIf=\"!isDisabled\"\n            [class.asc]=\"value === 'asc'\"\n            [class.desc]=\"value === 'desc'\"\n            class=\"bb-table-header-cell-toggle\"\n            type=\"button\"></button>\n</ng-container>\n"]}
131
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-header-cell.component.js","sourceRoot":"","sources":["../../../../../../../projects/bb-foundation/table/src/lib/components/table-header-cell/table-header-cell.component.ts","../../../../../../../projects/bb-foundation/table/src/lib/components/table-header-cell/table-header-cell.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Attribute,\n    ChangeDetectionStrategy,\n    Component,\n    Host,\n    HostListener,\n    Input,\n    OnDestroy,\n    OnInit,\n    Optional,\n    ViewEncapsulation\n} from '@angular/core';\nimport {CanDisable, CanDisableConstructor, mixinDisabled} from '@bravobit/bb-foundation';\nimport {TableColumnSortStrategy} from '../../interfaces/table.interfaces';\nimport {BbTable} from '../table/table.component';\nimport {FormControl} from '@angular/forms';\nimport {startWith} from 'rxjs/operators';\nimport {Observable} from 'rxjs';\n\nclass BbTableHeaderCellBase {\n}\n\nconst BbTableHeaderCellMixinBase: CanDisableConstructor\n    & typeof BbTableHeaderCellBase = mixinDisabled(BbTableHeaderCellBase);\n\n@Component({\n    selector: 'bb-table-header-cell',\n    templateUrl: './table-header-cell.component.html',\n    styleUrls: ['./table-header-cell.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        'class': 'bb-table-header-cell',\n        '[class.disabled]': 'isDisabled'\n    },\n    inputs: ['disabled'],\n    encapsulation: ViewEncapsulation.None,\n    preserveWhitespaces: false\n})\nexport class BbTableHeaderCell extends BbTableHeaderCellMixinBase implements OnInit, OnDestroy, CanDisable {\n\n    // Constants.\n    private readonly _sortDirections: TableColumnSortStrategy[] = ['none', 'asc', 'desc'];\n    private readonly _control = new FormControl<TableColumnSortStrategy>(this._sortDirections[0]);\n\n    // Data.\n    valueChanges$: Observable<string>;\n\n    // Sort.\n    @Input()\n    set sort(value: TableColumnSortStrategy) {\n        // Check if the new value is a valid value.\n        if (!this._sortDirections.includes(value)) {\n            return;\n        }\n\n        // Set the value.\n        this._control.setValue(value);\n    }\n\n    get sort() {\n        return this._control.value;\n    }\n\n    constructor(@Optional() @Host() private _table?: BbTable,\n                @Optional() @Attribute('name') private _name?: string) {\n        super();\n    }\n\n    ngOnInit() {\n        // Validate that the name and table are set.\n        this._table?.setHeaderCount?.(1);\n        if (!this._table || !this._name) {\n            return;\n        }\n\n        // Check if the control already exists in the table.\n        if (this._table.sortControl?.contains(this._name)) {\n            this.disabled = true;\n            return this.logWarning(`BbTableHeaderCell: The name \"${this._name}\" is not unique in the table; Control was not registered.`);\n        }\n\n        // Register the header cell with the table.\n        this._table.sortControl?.addControl(this._name, this._control);\n\n        // Get all the value changes.\n        this.valueChanges$ = this._control.valueChanges.pipe(\n            startWith(this._control.value as string)\n        );\n    }\n\n    ngOnDestroy() {\n        this._table?.setHeaderCount?.(-1);\n        // Validate that the name and table are set.\n        if (!this._table || !this._name) {\n            return;\n        }\n\n        // Un-register the header cell with the table.\n        if (this._table?.sortControl?.contains(this._name)) {\n            this._table?.sortControl?.removeControl(this._name);\n        }\n    }\n\n    get isDisabled() {\n        return this.disabled || !this._name;\n    }\n\n    @HostListener('click')\n    onClick() {\n        // Check if the header cell is disabled.\n        if (this.isDisabled) {\n            return;\n        }\n\n        // Find the index of the current sort and\n        // create the new index.\n        const index = this._sortDirections.findIndex(item => item === this._control.value);\n        const newIndex = (index + 1) % this._sortDirections.length;\n        const newSort = this._sortDirections[newIndex];\n\n        // Set the new sort.\n        return this.updateTableAndHeaderCell(newSort);\n    }\n\n    private updateTableAndHeaderCell(value: TableColumnSortStrategy) {\n        // Check if the new value is a valid value.\n        if (!this._sortDirections.includes(value)) {\n            return;\n        }\n\n        // Validate the table exists.\n        if (!this._table) {\n            return this._control.setValue(value);\n        }\n\n        // Handle the single sorting strategy.\n        if (this._table.sortingStrategy === 'single') {\n            return this.handleSingleSortingStrategy(value);\n        }\n\n        // Default case when no other strategy\n        // is used.\n        return this._control.setValue(value);\n    }\n\n    private handleSingleSortingStrategy(value: string) {\n        // Get the sort control.\n        const control = this._table.sortControl;\n\n        // Set each value to false since we only want to\n        // sort on one property at a time with this strategy.\n        const newValue = Object.keys(control.controls).reduce((previous, current) => {\n            previous[current] = current === this._name ? value : 'none';\n            return previous;\n        }, {});\n\n        // Patch the entire sort value.\n        this._table?.sortControl?.patchValue(newValue);\n    }\n\n    private logWarning = (message: string) => {\n        console && console.warn && console.warn(message);\n    };\n\n}\n","<!-- The content. -->\n<ng-content></ng-content>\n\n<!-- The indicator for the sort direction. -->\n<ng-container *ngIf=\"valueChanges$ | async as value\">\n    <button *ngIf=\"!isDisabled\"\n            [class.asc]=\"value === 'asc'\"\n            [class.desc]=\"value === 'desc'\"\n            class=\"bb-table-header-cell-toggle\"\n            type=\"button\"></button>\n</ng-container>\n"]}