flowbite-angular 1.0.0 → 1.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (139) hide show
  1. package/README.md +15 -15
  2. package/accordion/accordion-content.component.d.ts +20 -4
  3. package/accordion/accordion-content.theme.d.ts +0 -2
  4. package/accordion/accordion-panel.component.d.ts +10 -3
  5. package/accordion/accordion-title.component.d.ts +27 -0
  6. package/accordion/accordion.component.d.ts +10 -1
  7. package/accordion/index.d.ts +4 -4
  8. package/alert/alert.component.d.ts +42 -1
  9. package/alert/index.d.ts +1 -1
  10. package/badge/badge.component.d.ts +40 -0
  11. package/badge/index.d.ts +1 -1
  12. package/base-component.directive.d.ts +0 -4
  13. package/breadcrumb/breadcrumb-item.component.d.ts +19 -0
  14. package/breadcrumb/breadcrumb.component.d.ts +8 -1
  15. package/breadcrumb/index.d.ts +2 -2
  16. package/button/button.component.d.ts +100 -1
  17. package/button/index.d.ts +1 -1
  18. package/dark-theme-toggle/dark-theme-toggle.component.d.ts +12 -17
  19. package/dark-theme-toggle/index.d.ts +1 -1
  20. package/dropdown/dropdown-divider.component.d.ts +13 -2
  21. package/dropdown/dropdown-divider.theme.d.ts +2 -2
  22. package/dropdown/dropdown-header.component.d.ts +19 -2
  23. package/dropdown/dropdown-item.component.d.ts +7 -0
  24. package/dropdown/dropdown.component.d.ts +39 -13
  25. package/dropdown/index.d.ts +4 -4
  26. package/esm2022/accordion/accordion-content.component.mjs +29 -16
  27. package/esm2022/accordion/accordion-content.theme.mjs +2 -6
  28. package/esm2022/accordion/accordion-content.theme.service.mjs +2 -2
  29. package/esm2022/accordion/accordion-panel.component.mjs +18 -15
  30. package/esm2022/accordion/accordion-title.component.mjs +14 -8
  31. package/esm2022/accordion/accordion.component.mjs +28 -13
  32. package/esm2022/accordion/index.mjs +5 -5
  33. package/esm2022/alert/alert.component.mjs +93 -37
  34. package/esm2022/alert/index.mjs +2 -2
  35. package/esm2022/badge/badge.component.mjs +34 -9
  36. package/esm2022/badge/index.mjs +2 -2
  37. package/esm2022/base-component.directive.mjs +1 -7
  38. package/esm2022/breadcrumb/breadcrumb-item.component.mjs +14 -8
  39. package/esm2022/breadcrumb/breadcrumb.component.mjs +16 -11
  40. package/esm2022/breadcrumb/index.mjs +3 -3
  41. package/esm2022/button/button.component.mjs +72 -34
  42. package/esm2022/button/index.mjs +2 -2
  43. package/esm2022/core/flowbite.theme.init.mjs +48 -14
  44. package/esm2022/dark-theme-toggle/dark-theme-toggle.component.mjs +17 -42
  45. package/esm2022/dark-theme-toggle/index.mjs +2 -2
  46. package/esm2022/dropdown/dropdown-divider.component.mjs +10 -5
  47. package/esm2022/dropdown/dropdown-divider.theme.mjs +1 -1
  48. package/esm2022/dropdown/dropdown-header.component.mjs +13 -10
  49. package/esm2022/dropdown/dropdown-item.component.mjs +10 -5
  50. package/esm2022/dropdown/dropdown.component.mjs +51 -72
  51. package/esm2022/dropdown/dropdown.theme.mjs +6 -6
  52. package/esm2022/dropdown/index.mjs +5 -5
  53. package/esm2022/indicator/index.mjs +2 -2
  54. package/esm2022/indicator/indicators.component.mjs +64 -14
  55. package/esm2022/modal/index.mjs +5 -5
  56. package/esm2022/modal/modal-body.component.mjs +10 -5
  57. package/esm2022/modal/modal-footer.component.mjs +10 -5
  58. package/esm2022/modal/modal-header.component.mjs +16 -10
  59. package/esm2022/modal/modal.component.mjs +42 -23
  60. package/esm2022/navbar/index.mjs +7 -7
  61. package/esm2022/navbar/navbar-brand.component.mjs +10 -5
  62. package/esm2022/navbar/navbar-content.component.mjs +35 -11
  63. package/esm2022/navbar/navbar-content.theme.mjs +2 -6
  64. package/esm2022/navbar/navbar-content.theme.service.mjs +2 -2
  65. package/esm2022/navbar/navbar-icon-button.component.mjs +10 -9
  66. package/esm2022/navbar/navbar-item.component.mjs +10 -5
  67. package/esm2022/navbar/navbar-toggle.component.mjs +12 -6
  68. package/esm2022/navbar/navbar.component.mjs +41 -16
  69. package/esm2022/navbar/navbar.theme.mjs +2 -2
  70. package/esm2022/scroll-top/index.mjs +2 -2
  71. package/esm2022/scroll-top/scroll-top.component.mjs +22 -5
  72. package/esm2022/sidebar/index.mjs +7 -7
  73. package/esm2022/sidebar/sidebar-item-group.component.mjs +19 -14
  74. package/esm2022/sidebar/sidebar-item.component.mjs +45 -26
  75. package/esm2022/sidebar/sidebar-menu.component.mjs +10 -9
  76. package/esm2022/sidebar/sidebar-page-content.component.mjs +10 -4
  77. package/esm2022/sidebar/sidebar-toggle.component.mjs +22 -5
  78. package/esm2022/sidebar/sidebar.component.mjs +36 -19
  79. package/esm2022/theme/flowbite-angular-theme.mjs +5 -0
  80. package/esm2022/theme/flowbite-theme.directive.mjs +71 -0
  81. package/esm2022/theme/index.mjs +2 -0
  82. package/fesm2022/flowbite-angular-accordion.mjs +85 -50
  83. package/fesm2022/flowbite-angular-accordion.mjs.map +1 -1
  84. package/fesm2022/flowbite-angular-alert.mjs +93 -37
  85. package/fesm2022/flowbite-angular-alert.mjs.map +1 -1
  86. package/fesm2022/flowbite-angular-badge.mjs +34 -9
  87. package/fesm2022/flowbite-angular-badge.mjs.map +1 -1
  88. package/fesm2022/flowbite-angular-breadcrumb.mjs +28 -16
  89. package/fesm2022/flowbite-angular-breadcrumb.mjs.map +1 -1
  90. package/fesm2022/flowbite-angular-button.mjs +72 -34
  91. package/fesm2022/flowbite-angular-button.mjs.map +1 -1
  92. package/fesm2022/flowbite-angular-core.mjs +47 -13
  93. package/fesm2022/flowbite-angular-core.mjs.map +1 -1
  94. package/fesm2022/flowbite-angular-dark-theme-toggle.mjs +17 -42
  95. package/fesm2022/flowbite-angular-dark-theme-toggle.mjs.map +1 -1
  96. package/fesm2022/flowbite-angular-dropdown.mjs +83 -88
  97. package/fesm2022/flowbite-angular-dropdown.mjs.map +1 -1
  98. package/fesm2022/flowbite-angular-indicator.mjs +64 -14
  99. package/fesm2022/flowbite-angular-indicator.mjs.map +1 -1
  100. package/fesm2022/flowbite-angular-modal.mjs +72 -34
  101. package/fesm2022/flowbite-angular-modal.mjs.map +1 -1
  102. package/fesm2022/flowbite-angular-navbar.mjs +110 -44
  103. package/fesm2022/flowbite-angular-navbar.mjs.map +1 -1
  104. package/fesm2022/flowbite-angular-scroll-top.mjs +22 -5
  105. package/fesm2022/flowbite-angular-scroll-top.mjs.map +1 -1
  106. package/fesm2022/flowbite-angular-sidebar.mjs +132 -65
  107. package/fesm2022/flowbite-angular-sidebar.mjs.map +1 -1
  108. package/fesm2022/flowbite-angular-theme.mjs +78 -0
  109. package/fesm2022/flowbite-angular-theme.mjs.map +1 -0
  110. package/fesm2022/flowbite-angular.mjs +0 -6
  111. package/fesm2022/flowbite-angular.mjs.map +1 -1
  112. package/indicator/index.d.ts +1 -1
  113. package/indicator/indicators.component.d.ts +81 -0
  114. package/modal/index.d.ts +4 -4
  115. package/modal/modal-body.component.d.ts +7 -0
  116. package/modal/modal-footer.component.d.ts +7 -0
  117. package/modal/modal-header.component.d.ts +13 -0
  118. package/modal/modal.component.d.ts +40 -2
  119. package/navbar/index.d.ts +6 -6
  120. package/navbar/navbar-brand.component.d.ts +7 -0
  121. package/navbar/navbar-content.component.d.ts +13 -4
  122. package/navbar/navbar-content.theme.d.ts +1 -3
  123. package/navbar/navbar-icon-button.component.d.ts +12 -1
  124. package/navbar/navbar-item.component.d.ts +12 -0
  125. package/navbar/navbar-toggle.component.d.ts +7 -0
  126. package/navbar/navbar.component.d.ts +30 -2
  127. package/package.json +7 -2
  128. package/scroll-top/index.d.ts +1 -1
  129. package/scroll-top/scroll-top.component.d.ts +31 -0
  130. package/sidebar/index.d.ts +6 -6
  131. package/sidebar/sidebar-item-group.component.d.ts +19 -1
  132. package/sidebar/sidebar-item.component.d.ts +21 -1
  133. package/sidebar/sidebar-menu.component.d.ts +25 -1
  134. package/sidebar/sidebar-page-content.component.d.ts +12 -0
  135. package/sidebar/sidebar-toggle.component.d.ts +22 -0
  136. package/sidebar/sidebar.component.d.ts +17 -3
  137. package/theme/README.md +4 -0
  138. package/theme/flowbite-theme.directive.d.ts +36 -0
  139. package/theme/index.d.ts +1 -0
@@ -6,9 +6,25 @@ import { BadgeComponent } from 'flowbite-angular/badge';
6
6
  import { FlowbiteRouterLinkDirective } from 'flowbite-angular/router-link';
7
7
  import { FlowbiteRouterLinkActiveDirective } from 'flowbite-angular/router-link-active';
8
8
  import { SanitizeHtmlPipe } from 'flowbite-angular/sanitize-html';
9
- import { NgClass, NgIf } from '@angular/common';
10
- import { ChangeDetectionStrategy, Component, inject, model, ViewEncapsulation, } from '@angular/core';
9
+ import { ChangeDetectionStrategy, Component, inject, InjectionToken, makeEnvironmentProviders, model, ViewEncapsulation, } from '@angular/core';
11
10
  import * as i0 from "@angular/core";
11
+ export const FLOWBITE_SIDEBAR_ITEM_ICON_DEFAULT_VALUE = new InjectionToken('FLOWBITE_SIDEBAR_ITEM_ICON_DEFAULT_VALUE');
12
+ export const FLOWBITE_SIDEBAR_ITEM_LABEL_DEFAULT_VALUE = new InjectionToken('FLOWBITE_SIDEBAR_ITEM_LABEL_DEFAULT_VALUE');
13
+ export const FLOWBITE_SIDEBAR_ITEM_CUSTOM_STYLE_DEFAULT_VALUE = new InjectionToken('FLOWBITE_SIDEBAR_ITEM_CUSTOM_STYLE_DEFAULT_VALUE');
14
+ export const sidebarItemDefaultValueProvider = makeEnvironmentProviders([
15
+ {
16
+ provide: FLOWBITE_SIDEBAR_ITEM_ICON_DEFAULT_VALUE,
17
+ useValue: undefined,
18
+ },
19
+ {
20
+ provide: FLOWBITE_SIDEBAR_ITEM_LABEL_DEFAULT_VALUE,
21
+ useValue: undefined,
22
+ },
23
+ {
24
+ provide: FLOWBITE_SIDEBAR_ITEM_CUSTOM_STYLE_DEFAULT_VALUE,
25
+ useValue: {},
26
+ },
27
+ ]);
12
28
  /**
13
29
  * @see https://flowbite.com/docs/components/sidebar/
14
30
  */
@@ -43,7 +59,7 @@ export class SidebarItemComponent extends BaseComponent {
43
59
  *
44
60
  * @default undefined
45
61
  */
46
- this.icon = model(undefined);
62
+ this.icon = model(inject(FLOWBITE_SIDEBAR_ITEM_ICON_DEFAULT_VALUE));
47
63
  /**
48
64
  * Set the sidebar item color
49
65
  *
@@ -56,11 +72,11 @@ export class SidebarItemComponent extends BaseComponent {
56
72
  *
57
73
  * @default undefined
58
74
  */
59
- this.label = model(undefined);
75
+ this.label = model(inject(FLOWBITE_SIDEBAR_ITEM_LABEL_DEFAULT_VALUE));
60
76
  /**
61
77
  * Set the custom style for this sidebar item
62
78
  */
63
- this.customStyle = model({});
79
+ this.customStyle = model(inject(FLOWBITE_SIDEBAR_ITEM_CUSTOM_STYLE_DEFAULT_VALUE));
64
80
  }
65
81
  //#endregion
66
82
  //#region BaseComponent implementation
@@ -72,11 +88,6 @@ export class SidebarItemComponent extends BaseComponent {
72
88
  customStyle: this.customStyle(),
73
89
  });
74
90
  }
75
- verify() {
76
- if (this.sidebarMenuComponent === undefined && this.sidebarItemGroupComponent === undefined) {
77
- throw new Error('No SidebarMenuComponent/SidebarItemGroupComponent available');
78
- }
79
- }
80
91
  //#endregion
81
92
  /**
82
93
  * Toggle sidebar menu visibility
@@ -86,36 +97,44 @@ export class SidebarItemComponent extends BaseComponent {
86
97
  (this.sidebarMenuComponent || this.sidebarItemGroupComponent?.sidebarMenuComponent)?.sidebarComponent.toggleVisibility(false);
87
98
  }
88
99
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: SidebarItemComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
89
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.0.0", type: SidebarItemComponent, isStandalone: true, selector: "flowbite-sidebar-item", inputs: { icon: { classPropertyName: "icon", publicName: "icon", isSignal: true, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: false, transformFunction: null }, customStyle: { classPropertyName: "customStyle", publicName: "customStyle", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { icon: "iconChange", color: "colorChange", label: "labelChange", customStyle: "customStyleChange" }, host: { listeners: { "click": "onClick()" } }, usesInheritance: true, ngImport: i0, template: `
90
- <span
91
- class="flex-shrink-0"
92
- [innerHTML]="icon()! | sanitizeHtml"
93
- *ngIf="icon()"></span>
100
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: SidebarItemComponent, isStandalone: true, selector: "flowbite-sidebar-item", inputs: { icon: { classPropertyName: "icon", publicName: "icon", isSignal: true, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: false, transformFunction: null }, customStyle: { classPropertyName: "customStyle", publicName: "customStyle", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { icon: "iconChange", color: "colorChange", label: "labelChange", customStyle: "customStyleChange" }, host: { listeners: { "click": "onClick()" } }, usesInheritance: true, ngImport: i0, template: `
101
+ @if (icon()) {
102
+ <span
103
+ class="flex-shrink-0"
104
+ [innerHTML]="icon()! | sanitizeHtml"></span>
105
+ }
106
+
94
107
  <span
95
- [ngClass]="contentClasses().sidebarIconClass"
108
+ [class]="contentClasses().sidebarIconClass"
96
109
  [class.ml-3]="icon()">
97
110
  <ng-content />
98
111
  </span>
99
- <flowbite-badge *ngIf="label()">{{ label() }}</flowbite-badge>
100
- `, isInline: true, dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "pipe", type: SanitizeHtmlPipe, name: "sanitizeHtml" }, { kind: "component", type: BadgeComponent, selector: "flowbite-badge", inputs: ["color", "size", "isIconOnly", "isPill", "customStyle"], outputs: ["colorChange", "sizeChange", "isIconOnlyChange", "isPillChange", "customStyleChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
112
+ @if (label()) {
113
+ <flowbite-badge>{{ label() }}</flowbite-badge>
114
+ }
115
+ `, isInline: true, dependencies: [{ kind: "pipe", type: SanitizeHtmlPipe, name: "sanitizeHtml" }, { kind: "component", type: BadgeComponent, selector: "flowbite-badge", inputs: ["color", "size", "isIconOnly", "isPill", "customStyle"], outputs: ["colorChange", "sizeChange", "isIconOnlyChange", "isPillChange", "customStyleChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
101
116
  }
102
117
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: SidebarItemComponent, decorators: [{
103
118
  type: Component,
104
119
  args: [{
105
120
  standalone: true,
106
- imports: [NgIf, NgClass, SanitizeHtmlPipe, BadgeComponent],
121
+ imports: [SanitizeHtmlPipe, BadgeComponent],
107
122
  selector: 'flowbite-sidebar-item',
108
123
  template: `
124
+ @if (icon()) {
125
+ <span
126
+ class="flex-shrink-0"
127
+ [innerHTML]="icon()! | sanitizeHtml"></span>
128
+ }
129
+
109
130
  <span
110
- class="flex-shrink-0"
111
- [innerHTML]="icon()! | sanitizeHtml"
112
- *ngIf="icon()"></span>
113
- <span
114
- [ngClass]="contentClasses().sidebarIconClass"
131
+ [class]="contentClasses().sidebarIconClass"
115
132
  [class.ml-3]="icon()">
116
133
  <ng-content />
117
134
  </span>
118
- <flowbite-badge *ngIf="label()">{{ label() }}</flowbite-badge>
135
+ @if (label()) {
136
+ <flowbite-badge>{{ label() }}</flowbite-badge>
137
+ }
119
138
  `,
120
139
  host: {
121
140
  '(click)': 'onClick()',
@@ -124,4 +143,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
124
143
  changeDetection: ChangeDetectionStrategy.OnPush,
125
144
  }]
126
145
  }] });
127
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sidebar-item.component.js","sourceRoot":"","sources":["../../../../../libs/flowbite-angular/sidebar/sidebar-item.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { SidebarItemGroupComponent } from './sidebar-item-group.component';\nimport type { SidebarItemClass, SidebarItemTheme } from './sidebar-item.theme';\nimport { SidebarItemThemeService } from './sidebar-item.theme.service';\nimport { SidebarMenuComponent } from './sidebar-menu.component';\nimport type { SidebarColors } from './sidebar.theme';\n\nimport type { DeepPartial } from 'flowbite-angular';\nimport { BaseComponent } from 'flowbite-angular';\nimport { BadgeComponent } from 'flowbite-angular/badge';\nimport { FlowbiteRouterLinkDirective } from 'flowbite-angular/router-link';\nimport { FlowbiteRouterLinkActiveDirective } from 'flowbite-angular/router-link-active';\nimport { SanitizeHtmlPipe } from 'flowbite-angular/sanitize-html';\n\nimport { NgClass, NgIf } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  inject,\n  model,\n  ViewEncapsulation,\n} from '@angular/core';\n\n/**\n * @see https://flowbite.com/docs/components/sidebar/\n */\n@Component({\n  standalone: true,\n  imports: [NgIf, NgClass, SanitizeHtmlPipe, BadgeComponent],\n  selector: 'flowbite-sidebar-item',\n  template: `\n    <span\n      class=\"flex-shrink-0\"\n      [innerHTML]=\"icon()! | sanitizeHtml\"\n      *ngIf=\"icon()\"></span>\n    <span\n      [ngClass]=\"contentClasses().sidebarIconClass\"\n      [class.ml-3]=\"icon()\">\n      <ng-content />\n    </span>\n    <flowbite-badge *ngIf=\"label()\">{{ label() }}</flowbite-badge>\n  `,\n  host: {\n    '(click)': 'onClick()',\n  },\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SidebarItemComponent extends BaseComponent<SidebarItemClass> {\n  /**\n   * Optional `FlowbiteRouterLinkDirective` injected\n   */\n  public readonly flowbiteRouterLink = inject(FlowbiteRouterLinkDirective, { optional: true });\n  /**\n   * Optional `FlowbiteRouterLinkActiveDirective` injected\n   */\n  public readonly flowbiteRouterLinkActive = inject(FlowbiteRouterLinkActiveDirective, {\n    optional: true,\n  });\n  /**\n   * Service injected used to generate class\n   */\n  public readonly themeService = inject(SidebarItemThemeService);\n  /**\n   * The optional parent `SidebarItemGroupComponent`\n   */\n  public readonly sidebarItemGroupComponent = inject(SidebarItemGroupComponent, { optional: true });\n  /**\n   * The optional parent `SidebarMenuComponent`\n   */\n  public readonly sidebarMenuComponent = inject(SidebarMenuComponent, { optional: true });\n\n  //#region properties\n  /**\n   * Set the sidebar item icon\n   *\n   * @default undefined\n   */\n  public icon = model<string | undefined>(undefined);\n  /**\n   * Set the sidebar item color\n   *\n   * @default `SidebarItemGroupComponent`'s color\n   * @default `SidebarMenuComponent`'s color\n   */\n  public color = model<keyof SidebarColors>(\n    (this.sidebarItemGroupComponent ?? this.sidebarMenuComponent)!.color()\n  );\n  /**\n   * Set the sidebar item label\n   *\n   * @default undefined\n   */\n  public label = model<string | undefined>(undefined);\n  /**\n   * Set the custom style for this sidebar item\n   */\n  public customStyle = model<DeepPartial<SidebarItemTheme>>({});\n  //#endregion\n\n  //#region BaseComponent implementation\n  public override fetchClass(): SidebarItemClass {\n    return this.themeService.getClasses({\n      icon: this.icon(),\n      color: this.color(),\n      label: this.label(),\n      customStyle: this.customStyle(),\n    });\n  }\n\n  public override verify(): void {\n    if (this.sidebarMenuComponent === undefined && this.sidebarItemGroupComponent === undefined) {\n      throw new Error('No SidebarMenuComponent/SidebarItemGroupComponent available');\n    }\n  }\n  //#endregion\n\n  /**\n   * Toggle sidebar menu visibility\n   */\n  onClick(): void {\n    (this.sidebarMenuComponent || this.sidebarItemGroupComponent?.sidebarMenuComponent)?.closeAll();\n    (\n      this.sidebarMenuComponent || this.sidebarItemGroupComponent?.sidebarMenuComponent\n    )?.sidebarComponent.toggleVisibility(false);\n  }\n}\n"]}
146
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sidebar-item.component.js","sourceRoot":"","sources":["../../../../../libs/flowbite-angular/sidebar/sidebar-item.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { SidebarItemGroupComponent } from './sidebar-item-group.component';\nimport type { SidebarItemClass, SidebarItemTheme } from './sidebar-item.theme';\nimport { SidebarItemThemeService } from './sidebar-item.theme.service';\nimport { SidebarMenuComponent } from './sidebar-menu.component';\nimport type { SidebarColors } from './sidebar.theme';\n\nimport type { DeepPartial } from 'flowbite-angular';\nimport { BaseComponent } from 'flowbite-angular';\nimport { BadgeComponent } from 'flowbite-angular/badge';\nimport { FlowbiteRouterLinkDirective } from 'flowbite-angular/router-link';\nimport { FlowbiteRouterLinkActiveDirective } from 'flowbite-angular/router-link-active';\nimport { SanitizeHtmlPipe } from 'flowbite-angular/sanitize-html';\n\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  inject,\n  InjectionToken,\n  makeEnvironmentProviders,\n  model,\n  ViewEncapsulation,\n} from '@angular/core';\n\nexport const FLOWBITE_SIDEBAR_ITEM_ICON_DEFAULT_VALUE = new InjectionToken<string | undefined>(\n  'FLOWBITE_SIDEBAR_ITEM_ICON_DEFAULT_VALUE'\n);\n\nexport const FLOWBITE_SIDEBAR_ITEM_LABEL_DEFAULT_VALUE = new InjectionToken<string | undefined>(\n  'FLOWBITE_SIDEBAR_ITEM_LABEL_DEFAULT_VALUE'\n);\n\nexport const FLOWBITE_SIDEBAR_ITEM_CUSTOM_STYLE_DEFAULT_VALUE = new InjectionToken<\n  DeepPartial<SidebarItemTheme>\n>('FLOWBITE_SIDEBAR_ITEM_CUSTOM_STYLE_DEFAULT_VALUE');\n\nexport const sidebarItemDefaultValueProvider = makeEnvironmentProviders([\n  {\n    provide: FLOWBITE_SIDEBAR_ITEM_ICON_DEFAULT_VALUE,\n    useValue: undefined,\n  },\n  {\n    provide: FLOWBITE_SIDEBAR_ITEM_LABEL_DEFAULT_VALUE,\n    useValue: undefined,\n  },\n  {\n    provide: FLOWBITE_SIDEBAR_ITEM_CUSTOM_STYLE_DEFAULT_VALUE,\n    useValue: {},\n  },\n]);\n\n/**\n * @see https://flowbite.com/docs/components/sidebar/\n */\n@Component({\n  standalone: true,\n  imports: [SanitizeHtmlPipe, BadgeComponent],\n  selector: 'flowbite-sidebar-item',\n  template: `\n    @if (icon()) {\n      <span\n        class=\"flex-shrink-0\"\n        [innerHTML]=\"icon()! | sanitizeHtml\"></span>\n    }\n\n    <span\n      [class]=\"contentClasses().sidebarIconClass\"\n      [class.ml-3]=\"icon()\">\n      <ng-content />\n    </span>\n    @if (label()) {\n      <flowbite-badge>{{ label() }}</flowbite-badge>\n    }\n  `,\n  host: {\n    '(click)': 'onClick()',\n  },\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SidebarItemComponent extends BaseComponent<SidebarItemClass> {\n  /**\n   * Optional `FlowbiteRouterLinkDirective` injected\n   */\n  public readonly flowbiteRouterLink = inject(FlowbiteRouterLinkDirective, { optional: true });\n  /**\n   * Optional `FlowbiteRouterLinkActiveDirective` injected\n   */\n  public readonly flowbiteRouterLinkActive = inject(FlowbiteRouterLinkActiveDirective, {\n    optional: true,\n  });\n  /**\n   * Service injected used to generate class\n   */\n  public readonly themeService = inject(SidebarItemThemeService);\n  /**\n   * The optional parent `SidebarItemGroupComponent`\n   */\n  public readonly sidebarItemGroupComponent = inject(SidebarItemGroupComponent, { optional: true });\n  /**\n   * The optional parent `SidebarMenuComponent`\n   */\n  public readonly sidebarMenuComponent = inject(SidebarMenuComponent, { optional: true });\n\n  //#region properties\n  /**\n   * Set the sidebar item icon\n   *\n   * @default undefined\n   */\n  public icon = model(inject(FLOWBITE_SIDEBAR_ITEM_ICON_DEFAULT_VALUE));\n  /**\n   * Set the sidebar item color\n   *\n   * @default `SidebarItemGroupComponent`'s color\n   * @default `SidebarMenuComponent`'s color\n   */\n  public color = model<keyof SidebarColors>(\n    (this.sidebarItemGroupComponent ?? this.sidebarMenuComponent)!.color()\n  );\n  /**\n   * Set the sidebar item label\n   *\n   * @default undefined\n   */\n  public label = model(inject(FLOWBITE_SIDEBAR_ITEM_LABEL_DEFAULT_VALUE));\n  /**\n   * Set the custom style for this sidebar item\n   */\n  public customStyle = model(inject(FLOWBITE_SIDEBAR_ITEM_CUSTOM_STYLE_DEFAULT_VALUE));\n  //#endregion\n\n  //#region BaseComponent implementation\n  public override fetchClass(): SidebarItemClass {\n    return this.themeService.getClasses({\n      icon: this.icon(),\n      color: this.color(),\n      label: this.label(),\n      customStyle: this.customStyle(),\n    });\n  }\n  //#endregion\n\n  /**\n   * Toggle sidebar menu visibility\n   */\n  onClick(): void {\n    (this.sidebarMenuComponent || this.sidebarItemGroupComponent?.sidebarMenuComponent)?.closeAll();\n    (\n      this.sidebarMenuComponent || this.sidebarItemGroupComponent?.sidebarMenuComponent\n    )?.sidebarComponent.toggleVisibility(false);\n  }\n}\n"]}
@@ -3,8 +3,15 @@ import { SidebarItemComponent } from './sidebar-item.component';
3
3
  import { SidebarMenuThemeService } from './sidebar-menu.theme.service';
4
4
  import { SidebarComponent } from './sidebar.component';
5
5
  import { BaseComponent, booleanToFlowbiteBoolean } from 'flowbite-angular';
6
- import { ChangeDetectionStrategy, Component, contentChildren, inject, model, ViewEncapsulation, } from '@angular/core';
6
+ import { ChangeDetectionStrategy, Component, contentChildren, inject, InjectionToken, makeEnvironmentProviders, model, ViewEncapsulation, } from '@angular/core';
7
7
  import * as i0 from "@angular/core";
8
+ export const FLOWBITE_SIDEBAR_MENU_CUSTOM_STYLE_DEFAULT_VALUE = new InjectionToken('FLOWBITE_SIDEBAR_MENU_CUSTOM_STYLE_DEFAULT_VALUE');
9
+ export const sidebarMenuDefaultValueProvider = makeEnvironmentProviders([
10
+ {
11
+ provide: FLOWBITE_SIDEBAR_MENU_CUSTOM_STYLE_DEFAULT_VALUE,
12
+ useValue: {},
13
+ },
14
+ ]);
8
15
  /**
9
16
  * @see https://flowbite.com/docs/components/sidebar/
10
17
  */
@@ -37,7 +44,7 @@ export class SidebarMenuComponent extends BaseComponent {
37
44
  /**
38
45
  * Set the custom style for this sidebar menu
39
46
  */
40
- this.customStyle = model({});
47
+ this.customStyle = model(inject(FLOWBITE_SIDEBAR_MENU_CUSTOM_STYLE_DEFAULT_VALUE));
41
48
  }
42
49
  //#endregion
43
50
  fetchClass() {
@@ -48,11 +55,6 @@ export class SidebarMenuComponent extends BaseComponent {
48
55
  customStyle: this.customStyle(),
49
56
  });
50
57
  }
51
- verify() {
52
- if (this.sidebarItemChildren().length === 0 && this.sidebarItemGroupChildren().length === 0) {
53
- throw new Error('No SidebarItemComponent/SidebarItemGroupComponent available');
54
- }
55
- }
56
58
  /**
57
59
  * Toggle visibility of ll children to false
58
60
  */
@@ -66,11 +68,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
66
68
  type: Component,
67
69
  args: [{
68
70
  standalone: true,
69
- imports: [],
70
71
  selector: 'flowbite-sidebar-menu',
71
72
  template: '<ng-content />',
72
73
  encapsulation: ViewEncapsulation.None,
73
74
  changeDetection: ChangeDetectionStrategy.OnPush,
74
75
  }]
75
76
  }] });
76
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZWJhci1tZW51LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvZmxvd2JpdGUtYW5ndWxhci9zaWRlYmFyL3NpZGViYXItbWVudS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDM0UsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFFaEUsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDdkUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFJdkQsT0FBTyxFQUFFLGFBQWEsRUFBRSx3QkFBd0IsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBRTNFLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULGVBQWUsRUFDZixNQUFNLEVBQ04sS0FBSyxFQUNMLGlCQUFpQixHQUNsQixNQUFNLGVBQWUsQ0FBQzs7QUFFdkI7O0dBRUc7QUFTSCxNQUFNLE9BQU8sb0JBQXFCLFNBQVEsYUFBK0I7SUFSekU7O1FBU0U7O1dBRUc7UUFDYSxpQkFBWSxHQUFHLE1BQU0sQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDO1FBQy9EOztXQUVHO1FBQ2EscUJBQWdCLEdBQUcsTUFBTSxDQUFDLGdCQUFnQixDQUFDLENBQUM7UUFDNUQ7O1dBRUc7UUFDYSw2QkFBd0IsR0FBRyxlQUFlLENBQUMseUJBQXlCLENBQUMsQ0FBQztRQUN0Rjs7V0FFRztRQUNhLHdCQUFtQixHQUFHLGVBQWUsQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO1FBRTVFLG9CQUFvQjtRQUNwQjs7OztXQUlHO1FBQ0ksVUFBSyxHQUFHLEtBQUssQ0FBc0IsSUFBSSxDQUFDLGdCQUFnQixDQUFDLEtBQUssRUFBRSxDQUFDLENBQUM7UUFDekU7O1dBRUc7UUFDSSxnQkFBVyxHQUFHLEtBQUssQ0FBZ0MsRUFBRSxDQUFDLENBQUM7S0F3Qi9EO0lBdkJDLFlBQVk7SUFFSSxVQUFVO1FBQ3hCLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQyxVQUFVLENBQUM7WUFDbEMsTUFBTSxFQUFFLHdCQUF3QixDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUNoRSxLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUssRUFBRTtZQUNuQixXQUFXLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFdBQVcsRUFBRTtZQUNoRCxXQUFXLEVBQUUsSUFBSSxDQUFDLFdBQVcsRUFBRTtTQUNoQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRWUsTUFBTTtRQUNwQixJQUFJLElBQUksQ0FBQyxtQkFBbUIsRUFBRSxDQUFDLE1BQU0sS0FBSyxDQUFDLElBQUksSUFBSSxDQUFDLHdCQUF3QixFQUFFLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRSxDQUFDO1lBQzVGLE1BQU0sSUFBSSxLQUFLLENBQUMsNkRBQTZELENBQUMsQ0FBQztRQUNqRixDQUFDO0lBQ0gsQ0FBQztJQUVEOztPQUVHO0lBQ0ksUUFBUTtRQUNiLElBQUksQ0FBQyx3QkFBd0IsRUFBRSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLGdCQUFnQixDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7SUFDNUUsQ0FBQzs4R0FuRFUsb0JBQW9CO2tHQUFwQixvQkFBb0IsNmNBWTRCLHlCQUF5QixzRUFJOUIsb0JBQW9CLG9FQXBCaEUsZ0JBQWdCOzsyRkFJZixvQkFBb0I7a0JBUmhDLFNBQVM7bUJBQUM7b0JBQ1QsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLE9BQU8sRUFBRSxFQUFFO29CQUNYLFFBQVEsRUFBRSx1QkFBdUI7b0JBQ2pDLFFBQVEsRUFBRSxnQkFBZ0I7b0JBQzFCLGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO29CQUNyQyxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDaEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTaWRlYmFySXRlbUdyb3VwQ29tcG9uZW50IH0gZnJvbSAnLi9zaWRlYmFyLWl0ZW0tZ3JvdXAuY29tcG9uZW50JztcbmltcG9ydCB7IFNpZGViYXJJdGVtQ29tcG9uZW50IH0gZnJvbSAnLi9zaWRlYmFyLWl0ZW0uY29tcG9uZW50JztcbmltcG9ydCB0eXBlIHsgU2lkZWJhck1lbnVDbGFzcywgU2lkZWJhck1lbnVUaGVtZSB9IGZyb20gJy4vc2lkZWJhci1tZW51LnRoZW1lJztcbmltcG9ydCB7IFNpZGViYXJNZW51VGhlbWVTZXJ2aWNlIH0gZnJvbSAnLi9zaWRlYmFyLW1lbnUudGhlbWUuc2VydmljZSc7XG5pbXBvcnQgeyBTaWRlYmFyQ29tcG9uZW50IH0gZnJvbSAnLi9zaWRlYmFyLmNvbXBvbmVudCc7XG5pbXBvcnQgdHlwZSB7IFNpZGViYXJDb2xvcnMgfSBmcm9tICcuL3NpZGViYXIudGhlbWUnO1xuXG5pbXBvcnQgdHlwZSB7IERlZXBQYXJ0aWFsIH0gZnJvbSAnZmxvd2JpdGUtYW5ndWxhcic7XG5pbXBvcnQgeyBCYXNlQ29tcG9uZW50LCBib29sZWFuVG9GbG93Yml0ZUJvb2xlYW4gfSBmcm9tICdmbG93Yml0ZS1hbmd1bGFyJztcblxuaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgY29udGVudENoaWxkcmVuLFxuICBpbmplY3QsXG4gIG1vZGVsLFxuICBWaWV3RW5jYXBzdWxhdGlvbixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbi8qKlxuICogQHNlZSBodHRwczovL2Zsb3diaXRlLmNvbS9kb2NzL2NvbXBvbmVudHMvc2lkZWJhci9cbiAqL1xuQENvbXBvbmVudCh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtdLFxuICBzZWxlY3RvcjogJ2Zsb3diaXRlLXNpZGViYXItbWVudScsXG4gIHRlbXBsYXRlOiAnPG5nLWNvbnRlbnQgLz4nLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgU2lkZWJhck1lbnVDb21wb25lbnQgZXh0ZW5kcyBCYXNlQ29tcG9uZW50PFNpZGViYXJNZW51Q2xhc3M+IHtcbiAgLyoqXG4gICAqIFNlcnZpY2UgaW5qZWN0ZWQgdXNlZCB0byBnZW5lcmF0ZSBjbGFzc1xuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IHRoZW1lU2VydmljZSA9IGluamVjdChTaWRlYmFyTWVudVRoZW1lU2VydmljZSk7XG4gIC8qKlxuICAgKiBUaGUgcGFyZW50IGBTaWRlYmFyQ29tcG9uZW50YFxuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IHNpZGViYXJDb21wb25lbnQgPSBpbmplY3QoU2lkZWJhckNvbXBvbmVudCk7XG4gIC8qKlxuICAgKiBMaXN0IG9mIGBTaWRlYmFySXRlbUdyb3VwQ29tcG9uZW50YFxuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IHNpZGViYXJJdGVtR3JvdXBDaGlsZHJlbiA9IGNvbnRlbnRDaGlsZHJlbihTaWRlYmFySXRlbUdyb3VwQ29tcG9uZW50KTtcbiAgLyoqXG4gICAqIExpc3Qgb2YgYFNpZGViYXJJdGVtQ29tcG9uZW50YFxuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IHNpZGViYXJJdGVtQ2hpbGRyZW4gPSBjb250ZW50Q2hpbGRyZW4oU2lkZWJhckl0ZW1Db21wb25lbnQpO1xuXG4gIC8vI3JlZ2lvbiBwcm9wZXJ0aWVzXG4gIC8qKlxuICAgKiBTZXQgdGhlIHNpZGViYXIgbWVudSBjb2xvclxuICAgKlxuICAgKiBAZGVmYXVsdCBgU2lkZWJhckNvbXBvbmVudGAncyBjb2xvclxuICAgKi9cbiAgcHVibGljIGNvbG9yID0gbW9kZWw8a2V5b2YgU2lkZWJhckNvbG9ycz4odGhpcy5zaWRlYmFyQ29tcG9uZW50LmNvbG9yKCkpO1xuICAvKipcbiAgICogU2V0IHRoZSBjdXN0b20gc3R5bGUgZm9yIHRoaXMgc2lkZWJhciBtZW51XG4gICAqL1xuICBwdWJsaWMgY3VzdG9tU3R5bGUgPSBtb2RlbDxEZWVwUGFydGlhbDxTaWRlYmFyTWVudVRoZW1lPj4oe30pO1xuICAvLyNlbmRyZWdpb25cblxuICBwdWJsaWMgb3ZlcnJpZGUgZmV0Y2hDbGFzcygpOiBTaWRlYmFyTWVudUNsYXNzIHtcbiAgICByZXR1cm4gdGhpcy50aGVtZVNlcnZpY2UuZ2V0Q2xhc3Nlcyh7XG4gICAgICBpc09wZW46IGJvb2xlYW5Ub0Zsb3diaXRlQm9vbGVhbih0aGlzLnNpZGViYXJDb21wb25lbnQuaXNPcGVuKCkpLFxuICAgICAgY29sb3I6IHRoaXMuY29sb3IoKSxcbiAgICAgIGRpc3BsYXlNb2RlOiB0aGlzLnNpZGViYXJDb21wb25lbnQuZGlzcGxheU1vZGUoKSxcbiAgICAgIGN1c3RvbVN0eWxlOiB0aGlzLmN1c3RvbVN0eWxlKCksXG4gICAgfSk7XG4gIH1cblxuICBwdWJsaWMgb3ZlcnJpZGUgdmVyaWZ5KCk6IHZvaWQge1xuICAgIGlmICh0aGlzLnNpZGViYXJJdGVtQ2hpbGRyZW4oKS5sZW5ndGggPT09IDAgJiYgdGhpcy5zaWRlYmFySXRlbUdyb3VwQ2hpbGRyZW4oKS5sZW5ndGggPT09IDApIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignTm8gU2lkZWJhckl0ZW1Db21wb25lbnQvU2lkZWJhckl0ZW1Hcm91cENvbXBvbmVudCBhdmFpbGFibGUnKTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogVG9nZ2xlIHZpc2liaWxpdHkgb2YgbGwgY2hpbGRyZW4gdG8gZmFsc2VcbiAgICovXG4gIHB1YmxpYyBjbG9zZUFsbCgpOiB2b2lkIHtcbiAgICB0aGlzLnNpZGViYXJJdGVtR3JvdXBDaGlsZHJlbigpLmZvckVhY2goKHgpID0+IHgudG9nZ2xlVmlzaWJpbGl0eShmYWxzZSkpO1xuICB9XG59XG4iXX0=
77
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZWJhci1tZW51LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvZmxvd2JpdGUtYW5ndWxhci9zaWRlYmFyL3NpZGViYXItbWVudS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDM0UsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFFaEUsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDdkUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFJdkQsT0FBTyxFQUFFLGFBQWEsRUFBRSx3QkFBd0IsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBRTNFLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULGVBQWUsRUFDZixNQUFNLEVBQ04sY0FBYyxFQUNkLHdCQUF3QixFQUN4QixLQUFLLEVBQ0wsaUJBQWlCLEdBQ2xCLE1BQU0sZUFBZSxDQUFDOztBQUV2QixNQUFNLENBQUMsTUFBTSxnREFBZ0QsR0FBRyxJQUFJLGNBQWMsQ0FFaEYsa0RBQWtELENBQUMsQ0FBQztBQUV0RCxNQUFNLENBQUMsTUFBTSwrQkFBK0IsR0FBRyx3QkFBd0IsQ0FBQztJQUN0RTtRQUNFLE9BQU8sRUFBRSxnREFBZ0Q7UUFDekQsUUFBUSxFQUFFLEVBQUU7S0FDYjtDQUNGLENBQUMsQ0FBQztBQUVIOztHQUVHO0FBUUgsTUFBTSxPQUFPLG9CQUFxQixTQUFRLGFBQStCO0lBUHpFOztRQVFFOztXQUVHO1FBQ2EsaUJBQVksR0FBRyxNQUFNLENBQUMsdUJBQXVCLENBQUMsQ0FBQztRQUMvRDs7V0FFRztRQUNhLHFCQUFnQixHQUFHLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBQzVEOztXQUVHO1FBQ2EsNkJBQXdCLEdBQUcsZUFBZSxDQUFDLHlCQUF5QixDQUFDLENBQUM7UUFDdEY7O1dBRUc7UUFDYSx3QkFBbUIsR0FBRyxlQUFlLENBQUMsb0JBQW9CLENBQUMsQ0FBQztRQUU1RSxvQkFBb0I7UUFDcEI7Ozs7V0FJRztRQUNJLFVBQUssR0FBRyxLQUFLLENBQXNCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDO1FBQ3pFOztXQUVHO1FBQ0ksZ0JBQVcsR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDLGdEQUFnRCxDQUFDLENBQUMsQ0FBQztLQWtCdEY7SUFqQkMsWUFBWTtJQUVJLFVBQVU7UUFDeEIsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLFVBQVUsQ0FBQztZQUNsQyxNQUFNLEVBQUUsd0JBQXdCLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sRUFBRSxDQUFDO1lBQ2hFLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSyxFQUFFO1lBQ25CLFdBQVcsRUFBRSxJQUFJLENBQUMsZ0JBQWdCLENBQUMsV0FBVyxFQUFFO1lBQ2hELFdBQVcsRUFBRSxJQUFJLENBQUMsV0FBVyxFQUFFO1NBQ2hDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRDs7T0FFRztJQUNJLFFBQVE7UUFDYixJQUFJLENBQUMsd0JBQXdCLEVBQUUsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO0lBQzVFLENBQUM7OEdBN0NVLG9CQUFvQjtrR0FBcEIsb0JBQW9CLDZjQVk0Qix5QkFBeUIsc0VBSTlCLG9CQUFvQixvRUFwQmhFLGdCQUFnQjs7MkZBSWYsb0JBQW9CO2tCQVBoQyxTQUFTO21CQUFDO29CQUNULFVBQVUsRUFBRSxJQUFJO29CQUNoQixRQUFRLEVBQUUsdUJBQXVCO29CQUNqQyxRQUFRLEVBQUUsZ0JBQWdCO29CQUMxQixhQUFhLEVBQUUsaUJBQWlCLENBQUMsSUFBSTtvQkFDckMsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07aUJBQ2hEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2lkZWJhckl0ZW1Hcm91cENvbXBvbmVudCB9IGZyb20gJy4vc2lkZWJhci1pdGVtLWdyb3VwLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBTaWRlYmFySXRlbUNvbXBvbmVudCB9IGZyb20gJy4vc2lkZWJhci1pdGVtLmNvbXBvbmVudCc7XG5pbXBvcnQgdHlwZSB7IFNpZGViYXJNZW51Q2xhc3MsIFNpZGViYXJNZW51VGhlbWUgfSBmcm9tICcuL3NpZGViYXItbWVudS50aGVtZSc7XG5pbXBvcnQgeyBTaWRlYmFyTWVudVRoZW1lU2VydmljZSB9IGZyb20gJy4vc2lkZWJhci1tZW51LnRoZW1lLnNlcnZpY2UnO1xuaW1wb3J0IHsgU2lkZWJhckNvbXBvbmVudCB9IGZyb20gJy4vc2lkZWJhci5jb21wb25lbnQnO1xuaW1wb3J0IHR5cGUgeyBTaWRlYmFyQ29sb3JzIH0gZnJvbSAnLi9zaWRlYmFyLnRoZW1lJztcblxuaW1wb3J0IHR5cGUgeyBEZWVwUGFydGlhbCB9IGZyb20gJ2Zsb3diaXRlLWFuZ3VsYXInO1xuaW1wb3J0IHsgQmFzZUNvbXBvbmVudCwgYm9vbGVhblRvRmxvd2JpdGVCb29sZWFuIH0gZnJvbSAnZmxvd2JpdGUtYW5ndWxhcic7XG5cbmltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIGNvbnRlbnRDaGlsZHJlbixcbiAgaW5qZWN0LFxuICBJbmplY3Rpb25Ub2tlbixcbiAgbWFrZUVudmlyb25tZW50UHJvdmlkZXJzLFxuICBtb2RlbCxcbiAgVmlld0VuY2Fwc3VsYXRpb24sXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgY29uc3QgRkxPV0JJVEVfU0lERUJBUl9NRU5VX0NVU1RPTV9TVFlMRV9ERUZBVUxUX1ZBTFVFID0gbmV3IEluamVjdGlvblRva2VuPFxuICBEZWVwUGFydGlhbDxTaWRlYmFyTWVudVRoZW1lPlxuPignRkxPV0JJVEVfU0lERUJBUl9NRU5VX0NVU1RPTV9TVFlMRV9ERUZBVUxUX1ZBTFVFJyk7XG5cbmV4cG9ydCBjb25zdCBzaWRlYmFyTWVudURlZmF1bHRWYWx1ZVByb3ZpZGVyID0gbWFrZUVudmlyb25tZW50UHJvdmlkZXJzKFtcbiAge1xuICAgIHByb3ZpZGU6IEZMT1dCSVRFX1NJREVCQVJfTUVOVV9DVVNUT01fU1RZTEVfREVGQVVMVF9WQUxVRSxcbiAgICB1c2VWYWx1ZToge30sXG4gIH0sXG5dKTtcblxuLyoqXG4gKiBAc2VlIGh0dHBzOi8vZmxvd2JpdGUuY29tL2RvY3MvY29tcG9uZW50cy9zaWRlYmFyL1xuICovXG5AQ29tcG9uZW50KHtcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgc2VsZWN0b3I6ICdmbG93Yml0ZS1zaWRlYmFyLW1lbnUnLFxuICB0ZW1wbGF0ZTogJzxuZy1jb250ZW50IC8+JyxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIFNpZGViYXJNZW51Q29tcG9uZW50IGV4dGVuZHMgQmFzZUNvbXBvbmVudDxTaWRlYmFyTWVudUNsYXNzPiB7XG4gIC8qKlxuICAgKiBTZXJ2aWNlIGluamVjdGVkIHVzZWQgdG8gZ2VuZXJhdGUgY2xhc3NcbiAgICovXG4gIHB1YmxpYyByZWFkb25seSB0aGVtZVNlcnZpY2UgPSBpbmplY3QoU2lkZWJhck1lbnVUaGVtZVNlcnZpY2UpO1xuICAvKipcbiAgICogVGhlIHBhcmVudCBgU2lkZWJhckNvbXBvbmVudGBcbiAgICovXG4gIHB1YmxpYyByZWFkb25seSBzaWRlYmFyQ29tcG9uZW50ID0gaW5qZWN0KFNpZGViYXJDb21wb25lbnQpO1xuICAvKipcbiAgICogTGlzdCBvZiBgU2lkZWJhckl0ZW1Hcm91cENvbXBvbmVudGBcbiAgICovXG4gIHB1YmxpYyByZWFkb25seSBzaWRlYmFySXRlbUdyb3VwQ2hpbGRyZW4gPSBjb250ZW50Q2hpbGRyZW4oU2lkZWJhckl0ZW1Hcm91cENvbXBvbmVudCk7XG4gIC8qKlxuICAgKiBMaXN0IG9mIGBTaWRlYmFySXRlbUNvbXBvbmVudGBcbiAgICovXG4gIHB1YmxpYyByZWFkb25seSBzaWRlYmFySXRlbUNoaWxkcmVuID0gY29udGVudENoaWxkcmVuKFNpZGViYXJJdGVtQ29tcG9uZW50KTtcblxuICAvLyNyZWdpb24gcHJvcGVydGllc1xuICAvKipcbiAgICogU2V0IHRoZSBzaWRlYmFyIG1lbnUgY29sb3JcbiAgICpcbiAgICogQGRlZmF1bHQgYFNpZGViYXJDb21wb25lbnRgJ3MgY29sb3JcbiAgICovXG4gIHB1YmxpYyBjb2xvciA9IG1vZGVsPGtleW9mIFNpZGViYXJDb2xvcnM+KHRoaXMuc2lkZWJhckNvbXBvbmVudC5jb2xvcigpKTtcbiAgLyoqXG4gICAqIFNldCB0aGUgY3VzdG9tIHN0eWxlIGZvciB0aGlzIHNpZGViYXIgbWVudVxuICAgKi9cbiAgcHVibGljIGN1c3RvbVN0eWxlID0gbW9kZWwoaW5qZWN0KEZMT1dCSVRFX1NJREVCQVJfTUVOVV9DVVNUT01fU1RZTEVfREVGQVVMVF9WQUxVRSkpO1xuICAvLyNlbmRyZWdpb25cblxuICBwdWJsaWMgb3ZlcnJpZGUgZmV0Y2hDbGFzcygpOiBTaWRlYmFyTWVudUNsYXNzIHtcbiAgICByZXR1cm4gdGhpcy50aGVtZVNlcnZpY2UuZ2V0Q2xhc3Nlcyh7XG4gICAgICBpc09wZW46IGJvb2xlYW5Ub0Zsb3diaXRlQm9vbGVhbih0aGlzLnNpZGViYXJDb21wb25lbnQuaXNPcGVuKCkpLFxuICAgICAgY29sb3I6IHRoaXMuY29sb3IoKSxcbiAgICAgIGRpc3BsYXlNb2RlOiB0aGlzLnNpZGViYXJDb21wb25lbnQuZGlzcGxheU1vZGUoKSxcbiAgICAgIGN1c3RvbVN0eWxlOiB0aGlzLmN1c3RvbVN0eWxlKCksXG4gICAgfSk7XG4gIH1cblxuICAvKipcbiAgICogVG9nZ2xlIHZpc2liaWxpdHkgb2YgbGwgY2hpbGRyZW4gdG8gZmFsc2VcbiAgICovXG4gIHB1YmxpYyBjbG9zZUFsbCgpOiB2b2lkIHtcbiAgICB0aGlzLnNpZGViYXJJdGVtR3JvdXBDaGlsZHJlbigpLmZvckVhY2goKHgpID0+IHgudG9nZ2xlVmlzaWJpbGl0eShmYWxzZSkpO1xuICB9XG59XG4iXX0=
@@ -1,8 +1,15 @@
1
1
  import { SidebarPageContentThemeService } from './sidebar-page-content.theme.service';
2
2
  import { SidebarComponent } from './sidebar.component';
3
3
  import { BaseComponent, booleanToFlowbiteBoolean } from 'flowbite-angular';
4
- import { ChangeDetectionStrategy, Component, inject, model, ViewEncapsulation, } from '@angular/core';
4
+ import { ChangeDetectionStrategy, Component, inject, InjectionToken, makeEnvironmentProviders, model, ViewEncapsulation, } from '@angular/core';
5
5
  import * as i0 from "@angular/core";
6
+ export const FLOWBITE_SIDEBAR_PAGE_CONTENT_CUSTOM_STYLE_DEFAULT_VALUE = new InjectionToken('FLOWBITE_SIDEBAR_PAGE_CONTENT_CUSTOM_STYLE_DEFAULT_VALUE');
7
+ export const sidebarPageContentDefaultValueProvider = makeEnvironmentProviders([
8
+ {
9
+ provide: FLOWBITE_SIDEBAR_PAGE_CONTENT_CUSTOM_STYLE_DEFAULT_VALUE,
10
+ useValue: {},
11
+ },
12
+ ]);
6
13
  /**
7
14
  * @see https://flowbite.com/docs/components/sidebar/
8
15
  */
@@ -21,7 +28,7 @@ export class SidebarPageContentComponent extends BaseComponent {
21
28
  /**
22
29
  * Set the custom style for this sidebar page content
23
30
  */
24
- this.customStyle = model({});
31
+ this.customStyle = model(inject(FLOWBITE_SIDEBAR_PAGE_CONTENT_CUSTOM_STYLE_DEFAULT_VALUE));
25
32
  }
26
33
  //endregion
27
34
  //region BaseComponent implementation
@@ -39,11 +46,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
39
46
  type: Component,
40
47
  args: [{
41
48
  standalone: true,
42
- imports: [],
43
49
  selector: 'flowbite-sidebar-page-content',
44
50
  template: `<ng-content />`,
45
51
  encapsulation: ViewEncapsulation.None,
46
52
  changeDetection: ChangeDetectionStrategy.OnPush,
47
53
  }]
48
54
  }] });
49
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZWJhci1wYWdlLWNvbnRlbnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9mbG93Yml0ZS1hbmd1bGFyL3NpZGViYXIvc2lkZWJhci1wYWdlLWNvbnRlbnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlBLE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQ3RGLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBR3ZELE9BQU8sRUFBRSxhQUFhLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUUzRSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxNQUFNLEVBQ04sS0FBSyxFQUNMLGlCQUFpQixHQUNsQixNQUFNLGVBQWUsQ0FBQzs7QUFFdkI7O0dBRUc7QUFTSCxNQUFNLE9BQU8sMkJBQTRCLFNBQVEsYUFBc0M7SUFSdkY7O1FBU0U7O1dBRUc7UUFDYSxpQkFBWSxHQUFHLE1BQU0sQ0FBQyw4QkFBOEIsQ0FBQyxDQUFDO1FBQ3RFOztXQUVHO1FBQ2EscUJBQWdCLEdBQUcsTUFBTSxDQUFDLGdCQUFnQixDQUFDLENBQUM7UUFFNUQsb0JBQW9CO1FBQ3BCOztXQUVHO1FBQ0ksZ0JBQVcsR0FBRyxLQUFLLENBQXVDLEVBQUUsQ0FBQyxDQUFDO0tBWXRFO0lBWEMsV0FBVztJQUVYLHFDQUFxQztJQUNyQixVQUFVO1FBQ3hCLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQyxVQUFVLENBQUM7WUFDbEMsTUFBTSxFQUFFLHdCQUF3QixDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUNoRSxXQUFXLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFdBQVcsRUFBRTtZQUNoRCxXQUFXLEVBQUUsSUFBSSxDQUFDLFdBQVcsRUFBRTtTQUNoQyxDQUFDLENBQUM7SUFDTCxDQUFDOzhHQXhCVSwyQkFBMkI7a0dBQTNCLDJCQUEyQixxVEFKNUIsZ0JBQWdCOzsyRkFJZiwyQkFBMkI7a0JBUnZDLFNBQVM7bUJBQUM7b0JBQ1QsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLE9BQU8sRUFBRSxFQUFFO29CQUNYLFFBQVEsRUFBRSwrQkFBK0I7b0JBQ3pDLFFBQVEsRUFBRSxnQkFBZ0I7b0JBQzFCLGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO29CQUNyQyxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDaEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7XG4gIFNpZGViYXJQYWdlQ29udGVudENsYXNzLFxuICBTaWRlYmFyUGFnZUNvbnRlbnRUaGVtZSxcbn0gZnJvbSAnLi9zaWRlYmFyLXBhZ2UtY29udGVudC50aGVtZSc7XG5pbXBvcnQgeyBTaWRlYmFyUGFnZUNvbnRlbnRUaGVtZVNlcnZpY2UgfSBmcm9tICcuL3NpZGViYXItcGFnZS1jb250ZW50LnRoZW1lLnNlcnZpY2UnO1xuaW1wb3J0IHsgU2lkZWJhckNvbXBvbmVudCB9IGZyb20gJy4vc2lkZWJhci5jb21wb25lbnQnO1xuXG5pbXBvcnQgdHlwZSB7IERlZXBQYXJ0aWFsIH0gZnJvbSAnZmxvd2JpdGUtYW5ndWxhcic7XG5pbXBvcnQgeyBCYXNlQ29tcG9uZW50LCBib29sZWFuVG9GbG93Yml0ZUJvb2xlYW4gfSBmcm9tICdmbG93Yml0ZS1hbmd1bGFyJztcblxuaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgaW5qZWN0LFxuICBtb2RlbCxcbiAgVmlld0VuY2Fwc3VsYXRpb24sXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIEBzZWUgaHR0cHM6Ly9mbG93Yml0ZS5jb20vZG9jcy9jb21wb25lbnRzL3NpZGViYXIvXG4gKi9cbkBDb21wb25lbnQoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbXSxcbiAgc2VsZWN0b3I6ICdmbG93Yml0ZS1zaWRlYmFyLXBhZ2UtY29udGVudCcsXG4gIHRlbXBsYXRlOiBgPG5nLWNvbnRlbnQgLz5gLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgU2lkZWJhclBhZ2VDb250ZW50Q29tcG9uZW50IGV4dGVuZHMgQmFzZUNvbXBvbmVudDxTaWRlYmFyUGFnZUNvbnRlbnRDbGFzcz4ge1xuICAvKipcbiAgICogU2VydmljZSBpbmplY3RlZCB1c2VkIHRvIGdlbmVyYXRlIGNsYXNzXG4gICAqL1xuICBwdWJsaWMgcmVhZG9ubHkgdGhlbWVTZXJ2aWNlID0gaW5qZWN0KFNpZGViYXJQYWdlQ29udGVudFRoZW1lU2VydmljZSk7XG4gIC8qKlxuICAgKiBUaGUgcGFyZW50IGBTaWRlYmFyQ29tcG9uZW50YFxuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IHNpZGViYXJDb21wb25lbnQgPSBpbmplY3QoU2lkZWJhckNvbXBvbmVudCk7XG5cbiAgLy8jcmVnaW9uIHByb3BlcnRpZXNcbiAgLyoqXG4gICAqIFNldCB0aGUgY3VzdG9tIHN0eWxlIGZvciB0aGlzIHNpZGViYXIgcGFnZSBjb250ZW50XG4gICAqL1xuICBwdWJsaWMgY3VzdG9tU3R5bGUgPSBtb2RlbDxEZWVwUGFydGlhbDxTaWRlYmFyUGFnZUNvbnRlbnRUaGVtZT4+KHt9KTtcbiAgLy9lbmRyZWdpb25cblxuICAvL3JlZ2lvbiBCYXNlQ29tcG9uZW50IGltcGxlbWVudGF0aW9uXG4gIHB1YmxpYyBvdmVycmlkZSBmZXRjaENsYXNzKCk6IFNpZGViYXJQYWdlQ29udGVudENsYXNzIHtcbiAgICByZXR1cm4gdGhpcy50aGVtZVNlcnZpY2UuZ2V0Q2xhc3Nlcyh7XG4gICAgICBpc09wZW46IGJvb2xlYW5Ub0Zsb3diaXRlQm9vbGVhbih0aGlzLnNpZGViYXJDb21wb25lbnQuaXNPcGVuKCkpLFxuICAgICAgZGlzcGxheU1vZGU6IHRoaXMuc2lkZWJhckNvbXBvbmVudC5kaXNwbGF5TW9kZSgpLFxuICAgICAgY3VzdG9tU3R5bGU6IHRoaXMuY3VzdG9tU3R5bGUoKSxcbiAgICB9KTtcbiAgfVxuICAvL2VuZHJlZ2lvblxufVxuIl19
55
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZWJhci1wYWdlLWNvbnRlbnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9mbG93Yml0ZS1hbmd1bGFyL3NpZGViYXIvc2lkZWJhci1wYWdlLWNvbnRlbnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlBLE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQ3RGLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBR3ZELE9BQU8sRUFBRSxhQUFhLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUUzRSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxNQUFNLEVBQ04sY0FBYyxFQUNkLHdCQUF3QixFQUN4QixLQUFLLEVBQ0wsaUJBQWlCLEdBQ2xCLE1BQU0sZUFBZSxDQUFDOztBQUV2QixNQUFNLENBQUMsTUFBTSx3REFBd0QsR0FBRyxJQUFJLGNBQWMsQ0FFeEYsMERBQTBELENBQUMsQ0FBQztBQUU5RCxNQUFNLENBQUMsTUFBTSxzQ0FBc0MsR0FBRyx3QkFBd0IsQ0FBQztJQUM3RTtRQUNFLE9BQU8sRUFBRSx3REFBd0Q7UUFDakUsUUFBUSxFQUFFLEVBQUU7S0FDYjtDQUNGLENBQUMsQ0FBQztBQUVIOztHQUVHO0FBUUgsTUFBTSxPQUFPLDJCQUE0QixTQUFRLGFBQXNDO0lBUHZGOztRQVFFOztXQUVHO1FBQ2EsaUJBQVksR0FBRyxNQUFNLENBQUMsOEJBQThCLENBQUMsQ0FBQztRQUN0RTs7V0FFRztRQUNhLHFCQUFnQixHQUFHLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBRTVELG9CQUFvQjtRQUNwQjs7V0FFRztRQUNJLGdCQUFXLEdBQUcsS0FBSyxDQUFDLE1BQU0sQ0FBQyx3REFBd0QsQ0FBQyxDQUFDLENBQUM7S0FZOUY7SUFYQyxXQUFXO0lBRVgscUNBQXFDO0lBQ3JCLFVBQVU7UUFDeEIsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLFVBQVUsQ0FBQztZQUNsQyxNQUFNLEVBQUUsd0JBQXdCLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sRUFBRSxDQUFDO1lBQ2hFLFdBQVcsRUFBRSxJQUFJLENBQUMsZ0JBQWdCLENBQUMsV0FBVyxFQUFFO1lBQ2hELFdBQVcsRUFBRSxJQUFJLENBQUMsV0FBVyxFQUFFO1NBQ2hDLENBQUMsQ0FBQztJQUNMLENBQUM7OEdBeEJVLDJCQUEyQjtrR0FBM0IsMkJBQTJCLHFUQUo1QixnQkFBZ0I7OzJGQUlmLDJCQUEyQjtrQkFQdkMsU0FBUzttQkFBQztvQkFDVCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFLCtCQUErQjtvQkFDekMsUUFBUSxFQUFFLGdCQUFnQjtvQkFDMUIsYUFBYSxFQUFFLGlCQUFpQixDQUFDLElBQUk7b0JBQ3JDLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO2lCQUNoRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHtcbiAgU2lkZWJhclBhZ2VDb250ZW50Q2xhc3MsXG4gIFNpZGViYXJQYWdlQ29udGVudFRoZW1lLFxufSBmcm9tICcuL3NpZGViYXItcGFnZS1jb250ZW50LnRoZW1lJztcbmltcG9ydCB7IFNpZGViYXJQYWdlQ29udGVudFRoZW1lU2VydmljZSB9IGZyb20gJy4vc2lkZWJhci1wYWdlLWNvbnRlbnQudGhlbWUuc2VydmljZSc7XG5pbXBvcnQgeyBTaWRlYmFyQ29tcG9uZW50IH0gZnJvbSAnLi9zaWRlYmFyLmNvbXBvbmVudCc7XG5cbmltcG9ydCB0eXBlIHsgRGVlcFBhcnRpYWwgfSBmcm9tICdmbG93Yml0ZS1hbmd1bGFyJztcbmltcG9ydCB7IEJhc2VDb21wb25lbnQsIGJvb2xlYW5Ub0Zsb3diaXRlQm9vbGVhbiB9IGZyb20gJ2Zsb3diaXRlLWFuZ3VsYXInO1xuXG5pbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBpbmplY3QsXG4gIEluamVjdGlvblRva2VuLFxuICBtYWtlRW52aXJvbm1lbnRQcm92aWRlcnMsXG4gIG1vZGVsLFxuICBWaWV3RW5jYXBzdWxhdGlvbixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBjb25zdCBGTE9XQklURV9TSURFQkFSX1BBR0VfQ09OVEVOVF9DVVNUT01fU1RZTEVfREVGQVVMVF9WQUxVRSA9IG5ldyBJbmplY3Rpb25Ub2tlbjxcbiAgRGVlcFBhcnRpYWw8U2lkZWJhclBhZ2VDb250ZW50VGhlbWU+XG4+KCdGTE9XQklURV9TSURFQkFSX1BBR0VfQ09OVEVOVF9DVVNUT01fU1RZTEVfREVGQVVMVF9WQUxVRScpO1xuXG5leHBvcnQgY29uc3Qgc2lkZWJhclBhZ2VDb250ZW50RGVmYXVsdFZhbHVlUHJvdmlkZXIgPSBtYWtlRW52aXJvbm1lbnRQcm92aWRlcnMoW1xuICB7XG4gICAgcHJvdmlkZTogRkxPV0JJVEVfU0lERUJBUl9QQUdFX0NPTlRFTlRfQ1VTVE9NX1NUWUxFX0RFRkFVTFRfVkFMVUUsXG4gICAgdXNlVmFsdWU6IHt9LFxuICB9LFxuXSk7XG5cbi8qKlxuICogQHNlZSBodHRwczovL2Zsb3diaXRlLmNvbS9kb2NzL2NvbXBvbmVudHMvc2lkZWJhci9cbiAqL1xuQENvbXBvbmVudCh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHNlbGVjdG9yOiAnZmxvd2JpdGUtc2lkZWJhci1wYWdlLWNvbnRlbnQnLFxuICB0ZW1wbGF0ZTogYDxuZy1jb250ZW50IC8+YCxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIFNpZGViYXJQYWdlQ29udGVudENvbXBvbmVudCBleHRlbmRzIEJhc2VDb21wb25lbnQ8U2lkZWJhclBhZ2VDb250ZW50Q2xhc3M+IHtcbiAgLyoqXG4gICAqIFNlcnZpY2UgaW5qZWN0ZWQgdXNlZCB0byBnZW5lcmF0ZSBjbGFzc1xuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IHRoZW1lU2VydmljZSA9IGluamVjdChTaWRlYmFyUGFnZUNvbnRlbnRUaGVtZVNlcnZpY2UpO1xuICAvKipcbiAgICogVGhlIHBhcmVudCBgU2lkZWJhckNvbXBvbmVudGBcbiAgICovXG4gIHB1YmxpYyByZWFkb25seSBzaWRlYmFyQ29tcG9uZW50ID0gaW5qZWN0KFNpZGViYXJDb21wb25lbnQpO1xuXG4gIC8vI3JlZ2lvbiBwcm9wZXJ0aWVzXG4gIC8qKlxuICAgKiBTZXQgdGhlIGN1c3RvbSBzdHlsZSBmb3IgdGhpcyBzaWRlYmFyIHBhZ2UgY29udGVudFxuICAgKi9cbiAgcHVibGljIGN1c3RvbVN0eWxlID0gbW9kZWwoaW5qZWN0KEZMT1dCSVRFX1NJREVCQVJfUEFHRV9DT05URU5UX0NVU1RPTV9TVFlMRV9ERUZBVUxUX1ZBTFVFKSk7XG4gIC8vZW5kcmVnaW9uXG5cbiAgLy9yZWdpb24gQmFzZUNvbXBvbmVudCBpbXBsZW1lbnRhdGlvblxuICBwdWJsaWMgb3ZlcnJpZGUgZmV0Y2hDbGFzcygpOiBTaWRlYmFyUGFnZUNvbnRlbnRDbGFzcyB7XG4gICAgcmV0dXJuIHRoaXMudGhlbWVTZXJ2aWNlLmdldENsYXNzZXMoe1xuICAgICAgaXNPcGVuOiBib29sZWFuVG9GbG93Yml0ZUJvb2xlYW4odGhpcy5zaWRlYmFyQ29tcG9uZW50LmlzT3BlbigpKSxcbiAgICAgIGRpc3BsYXlNb2RlOiB0aGlzLnNpZGViYXJDb21wb25lbnQuZGlzcGxheU1vZGUoKSxcbiAgICAgIGN1c3RvbVN0eWxlOiB0aGlzLmN1c3RvbVN0eWxlKCksXG4gICAgfSk7XG4gIH1cbiAgLy9lbmRyZWdpb25cbn1cbiJdfQ==
@@ -3,9 +3,26 @@ import { SidebarComponent } from './sidebar.component';
3
3
  import { BaseComponent } from 'flowbite-angular';
4
4
  import { IconComponent, IconRegistry } from 'flowbite-angular/icon';
5
5
  import { BARS_SVG_ICON } from 'flowbite-angular/utils';
6
- import { ChangeDetectionStrategy, Component, inject, model, ViewEncapsulation, } from '@angular/core';
6
+ import { ChangeDetectionStrategy, Component, inject, InjectionToken, makeEnvironmentProviders, model, ViewEncapsulation, } from '@angular/core';
7
7
  import { DomSanitizer } from '@angular/platform-browser';
8
8
  import * as i0 from "@angular/core";
9
+ export const FLOWBITE_SIDEBAR_TOGGLE_COLOR_DEFAULT_VALUE = new InjectionToken('FLOWBITE_SIDEBAR_TOGGLE_COLOR_DEFAULT_VALUE');
10
+ export const FLOWBITE_SIDEBAR_TOGGLE_SIZE_DEFAULT_VALUE = new InjectionToken('FLOWBITE_SIDEBAR_TOGGLE_SIZE_DEFAULT_VALUE');
11
+ export const FLOWBITE_SIDEBAR_TOGGLE_CUSTOM_STYLE_DEFAULT_VALUE = new InjectionToken('FLOWBITE_SIDEBAR_TOGGLE_CUSTOM_STYLE_DEFAULT_VALUE');
12
+ export const sidebarToggleDefaultValueProvider = makeEnvironmentProviders([
13
+ {
14
+ provide: FLOWBITE_SIDEBAR_TOGGLE_COLOR_DEFAULT_VALUE,
15
+ useValue: 'primary',
16
+ },
17
+ {
18
+ provide: FLOWBITE_SIDEBAR_TOGGLE_SIZE_DEFAULT_VALUE,
19
+ useValue: 'sm',
20
+ },
21
+ {
22
+ provide: FLOWBITE_SIDEBAR_TOGGLE_CUSTOM_STYLE_DEFAULT_VALUE,
23
+ useValue: {},
24
+ },
25
+ ]);
9
26
  /**
10
27
  * @see https://flowbite.com/docs/components/sidebar/
11
28
  */
@@ -36,17 +53,17 @@ export class SidebarToggleComponent extends BaseComponent {
36
53
  *
37
54
  * @default primary
38
55
  */
39
- this.color = model('primary');
56
+ this.color = model(inject(FLOWBITE_SIDEBAR_TOGGLE_COLOR_DEFAULT_VALUE));
40
57
  /**
41
58
  * Set the sidebar toggle size
42
59
  *
43
60
  * @default sm
44
61
  */
45
- this.size = model('sm');
62
+ this.size = model(inject(FLOWBITE_SIDEBAR_TOGGLE_SIZE_DEFAULT_VALUE));
46
63
  /**
47
64
  * Set the custom style for this sidebar toggle
48
65
  */
49
- this.customStyle = model({});
66
+ this.customStyle = model(inject(FLOWBITE_SIDEBAR_TOGGLE_CUSTOM_STYLE_DEFAULT_VALUE));
50
67
  }
51
68
  //#endregion
52
69
  //#region BaseComponent implementation
@@ -85,4 +102,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
85
102
  changeDetection: ChangeDetectionStrategy.OnPush,
86
103
  }]
87
104
  }] });
88
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZWJhci10b2dnbGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9mbG93Yml0ZS1hbmd1bGFyL3NpZGViYXIvc2lkZWJhci10b2dnbGUuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUtBLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQzNFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBSXZELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNqRCxPQUFPLEVBQUUsYUFBYSxFQUFFLFlBQVksRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3BFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUd2RCxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxNQUFNLEVBQ04sS0FBSyxFQUNMLGlCQUFpQixHQUNsQixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7O0FBRXpEOztHQUVHO0FBWUgsTUFBTSxPQUFPLHNCQUF1QixTQUFRLGFBQWlDO0lBWDdFOztRQVlFOztXQUVHO1FBQ2EsaUJBQVksR0FBRyxNQUFNLENBQUMseUJBQXlCLENBQUMsQ0FBQztRQUNqRTs7V0FFRztRQUNhLGlCQUFZLEdBQUcsTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQ3BEOztXQUVHO1FBQ2EsaUJBQVksR0FBRyxNQUFNLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDcEQ7Ozs7V0FJRztRQUNhLHFCQUFnQixHQUFHLEtBQUssQ0FBbUIsTUFBTSxDQUFDLGdCQUFnQixDQUFDLENBQUMsQ0FBQztRQUVyRixvQkFBb0I7UUFDcEI7Ozs7V0FJRztRQUNJLFVBQUssR0FBRyxLQUFLLENBQXNCLFNBQVMsQ0FBQyxDQUFDO1FBQ3JEOzs7O1dBSUc7UUFDSSxTQUFJLEdBQUcsS0FBSyxDQUEyQixJQUFJLENBQUMsQ0FBQztRQUNwRDs7V0FFRztRQUNJLGdCQUFXLEdBQUcsS0FBSyxDQUFrQyxFQUFFLENBQUMsQ0FBQztLQTZCakU7SUE1QkMsWUFBWTtJQUVaLHNDQUFzQztJQUN0QixVQUFVO1FBQ3hCLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQyxVQUFVLENBQUM7WUFDbEMsS0FBSyxFQUFFLElBQUksQ0FBQyxLQUFLLEVBQUU7WUFDbkIsSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJLEVBQUU7WUFDakIsV0FBVyxFQUFFLElBQUksQ0FBQyxXQUFXLEVBQUU7U0FDaEMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVlLElBQUk7UUFDbEIsSUFBSSxDQUFDLFlBQVksQ0FBQyx3QkFBd0IsQ0FDeEMsa0JBQWtCLEVBQ2xCLE1BQU0sRUFDTixJQUFJLENBQUMsWUFBWSxDQUFDLHVCQUF1QixDQUFDLGFBQWEsQ0FBQyxDQUN6RCxDQUFDO0lBQ0osQ0FBQztJQUNELFlBQVk7SUFFWjs7T0FFRztJQUNJLE9BQU87UUFDWixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUVoRCxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDOUMsQ0FBQzs4R0FoRVUsc0JBQXNCO2tHQUF0QixzQkFBc0IsMHpCQVB2QixtREFBbUQsNERBRm5ELGFBQWE7OzJGQVNaLHNCQUFzQjtrQkFYbEMsU0FBUzttQkFBQztvQkFDVCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsT0FBTyxFQUFFLENBQUMsYUFBYSxDQUFDO29CQUN4QixRQUFRLEVBQUUseUJBQXlCO29CQUNuQyxRQUFRLEVBQUUsbURBQW1EO29CQUM3RCxJQUFJLEVBQUU7d0JBQ0osU0FBUyxFQUFFLFdBQVc7cUJBQ3ZCO29CQUNELGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO29CQUNyQyxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDaEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7XG4gIFNpZGViYXJUb2dnbGVDbGFzcyxcbiAgU2lkZWJhclRvZ2dsZVNpemVzLFxuICBTaWRlYmFyVG9nZ2xlVGhlbWUsXG59IGZyb20gJy4vc2lkZWJhci10b2dnbGUudGhlbWUnO1xuaW1wb3J0IHsgU2lkZWJhclRvZ2dsZVRoZW1lU2VydmljZSB9IGZyb20gJy4vc2lkZWJhci10b2dnbGUudGhlbWUuc2VydmljZSc7XG5pbXBvcnQgeyBTaWRlYmFyQ29tcG9uZW50IH0gZnJvbSAnLi9zaWRlYmFyLmNvbXBvbmVudCc7XG5pbXBvcnQgdHlwZSB7IFNpZGViYXJDb2xvcnMgfSBmcm9tICcuL3NpZGViYXIudGhlbWUnO1xuXG5pbXBvcnQgdHlwZSB7IERlZXBQYXJ0aWFsIH0gZnJvbSAnZmxvd2JpdGUtYW5ndWxhcic7XG5pbXBvcnQgeyBCYXNlQ29tcG9uZW50IH0gZnJvbSAnZmxvd2JpdGUtYW5ndWxhcic7XG5pbXBvcnQgeyBJY29uQ29tcG9uZW50LCBJY29uUmVnaXN0cnkgfSBmcm9tICdmbG93Yml0ZS1hbmd1bGFyL2ljb24nO1xuaW1wb3J0IHsgQkFSU19TVkdfSUNPTiB9IGZyb20gJ2Zsb3diaXRlLWFuZ3VsYXIvdXRpbHMnO1xuXG5pbXBvcnQgdHlwZSB7IE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgaW5qZWN0LFxuICBtb2RlbCxcbiAgVmlld0VuY2Fwc3VsYXRpb24sXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRG9tU2FuaXRpemVyIH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XG5cbi8qKlxuICogQHNlZSBodHRwczovL2Zsb3diaXRlLmNvbS9kb2NzL2NvbXBvbmVudHMvc2lkZWJhci9cbiAqL1xuQENvbXBvbmVudCh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtJY29uQ29tcG9uZW50XSxcbiAgc2VsZWN0b3I6ICdmbG93Yml0ZS1zaWRlYmFyLXRvZ2dsZScsXG4gIHRlbXBsYXRlOiBgPGZsb3diaXRlLWljb24gc3ZnSWNvbj1cImZsb3diaXRlLWFuZ3VsYXI6YmFyc1wiIC8+YCxcbiAgaG9zdDoge1xuICAgICcoY2xpY2spJzogJ29uQ2xpY2soKScsXG4gIH0sXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBTaWRlYmFyVG9nZ2xlQ29tcG9uZW50IGV4dGVuZHMgQmFzZUNvbXBvbmVudDxTaWRlYmFyVG9nZ2xlQ2xhc3M+IGltcGxlbWVudHMgT25Jbml0IHtcbiAgLyoqXG4gICAqIFNlcnZpY2UgaW5qZWN0ZWQgdXNlZCB0byBnZW5lcmF0ZSBjbGFzc1xuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IHRoZW1lU2VydmljZSA9IGluamVjdChTaWRlYmFyVG9nZ2xlVGhlbWVTZXJ2aWNlKTtcbiAgLyoqXG4gICAqIGBJY29uUmVnaXN0cnlgIHNlcnZpY2VcbiAgICovXG4gIHB1YmxpYyByZWFkb25seSBpY29uUmVnaXN0cnkgPSBpbmplY3QoSWNvblJlZ2lzdHJ5KTtcbiAgLyoqXG4gICAqIGBEb21TYW5pdGl6ZXJgIHNlcnZpY2VcbiAgICovXG4gIHB1YmxpYyByZWFkb25seSBkb21TYW5pdGl6ZXIgPSBpbmplY3QoRG9tU2FuaXRpemVyKTtcbiAgLyoqXG4gICAqIFRoZSBgU2lkZWJhckNvbXBvbmVudGAgdG8gdXNlXG4gICAqXG4gICAqIEBkZWZhdWx0IFRoZSBpbmplY3RlZCBgU2lkZWJhckNvbXBvbmVudGBcbiAgICovXG4gIHB1YmxpYyByZWFkb25seSBzaWRlYmFyQ29tcG9uZW50ID0gbW9kZWw8U2lkZWJhckNvbXBvbmVudD4oaW5qZWN0KFNpZGViYXJDb21wb25lbnQpKTtcblxuICAvLyNyZWdpb24gcHJvcGVydGllc1xuICAvKipcbiAgICogU2V0IHRoZSBzaWRlYmFyIHRvZ2dsZSBjb2xvclxuICAgKlxuICAgKiBAZGVmYXVsdCBwcmltYXJ5XG4gICAqL1xuICBwdWJsaWMgY29sb3IgPSBtb2RlbDxrZXlvZiBTaWRlYmFyQ29sb3JzPigncHJpbWFyeScpO1xuICAvKipcbiAgICogU2V0IHRoZSBzaWRlYmFyIHRvZ2dsZSBzaXplXG4gICAqXG4gICAqIEBkZWZhdWx0IHNtXG4gICAqL1xuICBwdWJsaWMgc2l6ZSA9IG1vZGVsPGtleW9mIFNpZGViYXJUb2dnbGVTaXplcz4oJ3NtJyk7XG4gIC8qKlxuICAgKiBTZXQgdGhlIGN1c3RvbSBzdHlsZSBmb3IgdGhpcyBzaWRlYmFyIHRvZ2dsZVxuICAgKi9cbiAgcHVibGljIGN1c3RvbVN0eWxlID0gbW9kZWw8RGVlcFBhcnRpYWw8U2lkZWJhclRvZ2dsZVRoZW1lPj4oe30pO1xuICAvLyNlbmRyZWdpb25cblxuICAvLyNyZWdpb24gQmFzZUNvbXBvbmVudCBpbXBsZW1lbnRhdGlvblxuICBwdWJsaWMgb3ZlcnJpZGUgZmV0Y2hDbGFzcygpOiBTaWRlYmFyVG9nZ2xlQ2xhc3Mge1xuICAgIHJldHVybiB0aGlzLnRoZW1lU2VydmljZS5nZXRDbGFzc2VzKHtcbiAgICAgIGNvbG9yOiB0aGlzLmNvbG9yKCksXG4gICAgICBzaXplOiB0aGlzLnNpemUoKSxcbiAgICAgIGN1c3RvbVN0eWxlOiB0aGlzLmN1c3RvbVN0eWxlKCksXG4gICAgfSk7XG4gIH1cblxuICBwdWJsaWMgb3ZlcnJpZGUgaW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLmljb25SZWdpc3RyeS5hZGRSYXdTdmdJY29uSW5OYW1lcHNhY2UoXG4gICAgICAnZmxvd2JpdGUtYW5ndWxhcicsXG4gICAgICAndGFicycsXG4gICAgICB0aGlzLmRvbVNhbml0aXplci5ieXBhc3NTZWN1cml0eVRydXN0SHRtbChCQVJTX1NWR19JQ09OKVxuICAgICk7XG4gIH1cbiAgLy8jZW5kcmVnaW9uXG5cbiAgLyoqXG4gICAqIFRvZ2dsZSBzaWRlYmFyIHZpc2liaWxpdHlcbiAgICovXG4gIHB1YmxpYyBvbkNsaWNrKCk6IHZvaWQge1xuICAgIGNvbnN0IGlzT3BlbiA9IHRoaXMuc2lkZWJhckNvbXBvbmVudCgpLmlzT3BlbigpO1xuXG4gICAgdGhpcy5zaWRlYmFyQ29tcG9uZW50KCkuaXNPcGVuLnNldCghaXNPcGVuKTtcbiAgfVxufVxuIl19
105
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sidebar-toggle.component.js","sourceRoot":"","sources":["../../../../../libs/flowbite-angular/sidebar/sidebar-toggle.component.ts"],"names":[],"mappings":"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","sourcesContent":["import type {\n  SidebarToggleClass,\n  SidebarToggleSizes,\n  SidebarToggleTheme,\n} from './sidebar-toggle.theme';\nimport { SidebarToggleThemeService } from './sidebar-toggle.theme.service';\nimport { SidebarComponent } from './sidebar.component';\nimport type { SidebarColors } from './sidebar.theme';\n\nimport type { DeepPartial } from 'flowbite-angular';\nimport { BaseComponent } from 'flowbite-angular';\nimport { IconComponent, IconRegistry } from 'flowbite-angular/icon';\nimport { BARS_SVG_ICON } from 'flowbite-angular/utils';\n\nimport type { OnInit } from '@angular/core';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  inject,\n  InjectionToken,\n  makeEnvironmentProviders,\n  model,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\n\nexport const FLOWBITE_SIDEBAR_TOGGLE_COLOR_DEFAULT_VALUE = new InjectionToken<keyof SidebarColors>(\n  'FLOWBITE_SIDEBAR_TOGGLE_COLOR_DEFAULT_VALUE'\n);\n\nexport const FLOWBITE_SIDEBAR_TOGGLE_SIZE_DEFAULT_VALUE = new InjectionToken<\n  keyof SidebarToggleSizes\n>('FLOWBITE_SIDEBAR_TOGGLE_SIZE_DEFAULT_VALUE');\n\nexport const FLOWBITE_SIDEBAR_TOGGLE_CUSTOM_STYLE_DEFAULT_VALUE = new InjectionToken<\n  DeepPartial<SidebarToggleTheme>\n>('FLOWBITE_SIDEBAR_TOGGLE_CUSTOM_STYLE_DEFAULT_VALUE');\n\nexport const sidebarToggleDefaultValueProvider = makeEnvironmentProviders([\n  {\n    provide: FLOWBITE_SIDEBAR_TOGGLE_COLOR_DEFAULT_VALUE,\n    useValue: 'primary',\n  },\n  {\n    provide: FLOWBITE_SIDEBAR_TOGGLE_SIZE_DEFAULT_VALUE,\n    useValue: 'sm',\n  },\n  {\n    provide: FLOWBITE_SIDEBAR_TOGGLE_CUSTOM_STYLE_DEFAULT_VALUE,\n    useValue: {},\n  },\n]);\n\n/**\n * @see https://flowbite.com/docs/components/sidebar/\n */\n@Component({\n  standalone: true,\n  imports: [IconComponent],\n  selector: 'flowbite-sidebar-toggle',\n  template: `<flowbite-icon svgIcon=\"flowbite-angular:bars\" />`,\n  host: {\n    '(click)': 'onClick()',\n  },\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SidebarToggleComponent extends BaseComponent<SidebarToggleClass> implements OnInit {\n  /**\n   * Service injected used to generate class\n   */\n  public readonly themeService = inject(SidebarToggleThemeService);\n  /**\n   * `IconRegistry` service\n   */\n  public readonly iconRegistry = inject(IconRegistry);\n  /**\n   * `DomSanitizer` service\n   */\n  public readonly domSanitizer = inject(DomSanitizer);\n  /**\n   * The `SidebarComponent` to use\n   *\n   * @default The injected `SidebarComponent`\n   */\n  public readonly sidebarComponent = model(inject(SidebarComponent));\n\n  //#region properties\n  /**\n   * Set the sidebar toggle color\n   *\n   * @default primary\n   */\n  public color = model(inject(FLOWBITE_SIDEBAR_TOGGLE_COLOR_DEFAULT_VALUE));\n  /**\n   * Set the sidebar toggle size\n   *\n   * @default sm\n   */\n  public size = model(inject(FLOWBITE_SIDEBAR_TOGGLE_SIZE_DEFAULT_VALUE));\n  /**\n   * Set the custom style for this sidebar toggle\n   */\n  public customStyle = model(inject(FLOWBITE_SIDEBAR_TOGGLE_CUSTOM_STYLE_DEFAULT_VALUE));\n  //#endregion\n\n  //#region BaseComponent implementation\n  public override fetchClass(): SidebarToggleClass {\n    return this.themeService.getClasses({\n      color: this.color(),\n      size: this.size(),\n      customStyle: this.customStyle(),\n    });\n  }\n\n  public override init(): void {\n    this.iconRegistry.addRawSvgIconInNamepsace(\n      'flowbite-angular',\n      'tabs',\n      this.domSanitizer.bypassSecurityTrustHtml(BARS_SVG_ICON)\n    );\n  }\n  //#endregion\n\n  /**\n   * Toggle sidebar visibility\n   */\n  public onClick(): void {\n    const isOpen = this.sidebarComponent().isOpen();\n\n    this.sidebarComponent().isOpen.set(!isOpen);\n  }\n}\n"]}
@@ -2,9 +2,35 @@ import { SidebarMenuComponent } from './sidebar-menu.component';
2
2
  import { SidebarPageContentComponent } from './sidebar-page-content.component';
3
3
  import { SidebarThemeService } from './sidebar.theme.service';
4
4
  import { BaseComponent, booleanToFlowbiteBoolean } from 'flowbite-angular';
5
- import { NgClass } from '@angular/common';
6
- import { ChangeDetectionStrategy, Component, contentChild, inject, model, untracked, ViewEncapsulation, } from '@angular/core';
5
+ import { ChangeDetectionStrategy, Component, contentChild, inject, InjectionToken, makeEnvironmentProviders, model, untracked, ViewEncapsulation, } from '@angular/core';
7
6
  import * as i0 from "@angular/core";
7
+ export const FLOWBITE_SIDEBAR_COLOR_DEFAULT_VALUE = new InjectionToken('FLOWBITE_SIDEBAR_COLOR_DEFAULT_VALUE');
8
+ export const FLOWBITE_SIDEBAR_DISPLAY_MODE_DEFAULT_VALUE = new InjectionToken('FLOWBITE_SIDEBAR_DISPLAY_MODE_DEFAULT_VALUE');
9
+ export const FLOWBITE_SIDEBAR_IS_OPEN_DEFAULT_VALUE = new InjectionToken('FLOWBITE_SIDEBAR_IS_OPEN_DEFAULT_VALUE');
10
+ export const FLOWBITE_SIDEBAR_IS_ROUNDED_DEFAULT_VALUE = new InjectionToken('FLOWBITE_SIDEBAR_IS_ROUNDED_DEFAULT_VALUE');
11
+ export const FLOWBITE_SIDEBAR_CUSTOM_STYLE_DEFAULT_VALUE = new InjectionToken('FLOWBITE_SIDEBAR_CUSTOM_STYLE_DEFAULT_VALUE');
12
+ export const sidebarDefaultValueProvider = makeEnvironmentProviders([
13
+ {
14
+ provide: FLOWBITE_SIDEBAR_COLOR_DEFAULT_VALUE,
15
+ useValue: 'primary',
16
+ },
17
+ {
18
+ provide: FLOWBITE_SIDEBAR_DISPLAY_MODE_DEFAULT_VALUE,
19
+ useValue: 'push',
20
+ },
21
+ {
22
+ provide: FLOWBITE_SIDEBAR_IS_OPEN_DEFAULT_VALUE,
23
+ useValue: false,
24
+ },
25
+ {
26
+ provide: FLOWBITE_SIDEBAR_IS_ROUNDED_DEFAULT_VALUE,
27
+ useValue: false,
28
+ },
29
+ {
30
+ provide: FLOWBITE_SIDEBAR_CUSTOM_STYLE_DEFAULT_VALUE,
31
+ useValue: {},
32
+ },
33
+ ]);
8
34
  /**
9
35
  * @see https://flowbite.com/docs/components/sidebar/
10
36
  */
@@ -18,40 +44,40 @@ export class SidebarComponent extends BaseComponent {
18
44
  /**
19
45
  * The child `SidebarMenuComponent`
20
46
  */
21
- this.sidebarMenuChild = contentChild(SidebarMenuComponent);
47
+ this.sidebarMenuChild = contentChild.required(SidebarMenuComponent);
22
48
  /**
23
49
  * The child `SidebarPageContentComponent`
24
50
  */
25
- this.sidebarPageContentChild = contentChild(SidebarPageContentComponent);
51
+ this.sidebarPageContentChild = contentChild.required(SidebarPageContentComponent);
26
52
  //#region properties
27
53
  /**
28
54
  * Set the sidebar color
29
55
  *
30
56
  * @default primary
31
57
  */
32
- this.color = model('primary');
58
+ this.color = model(inject(FLOWBITE_SIDEBAR_COLOR_DEFAULT_VALUE));
33
59
  /**
34
60
  * Set the sidebar display mode
35
61
  *
36
62
  * @default push
37
63
  */
38
- this.displayMode = model('push');
64
+ this.displayMode = model(inject(FLOWBITE_SIDEBAR_DISPLAY_MODE_DEFAULT_VALUE));
39
65
  /**
40
66
  * Set is the sidebar is open
41
67
  *
42
68
  * @default false
43
69
  */
44
- this.isOpen = model(false);
70
+ this.isOpen = model(inject(FLOWBITE_SIDEBAR_IS_OPEN_DEFAULT_VALUE));
45
71
  /**
46
72
  * Set is the sidebar is rounded
47
73
  *
48
74
  * @default false
49
75
  */
50
- this.isRounded = model(false);
76
+ this.isRounded = model(inject(FLOWBITE_SIDEBAR_IS_ROUNDED_DEFAULT_VALUE));
51
77
  /**
52
78
  * Set the custom style for this sidebar
53
79
  */
54
- this.customStyle = model({});
80
+ this.customStyle = model(inject(FLOWBITE_SIDEBAR_CUSTOM_STYLE_DEFAULT_VALUE));
55
81
  }
56
82
  //#endregion
57
83
  //#region BaseComponent implementation
@@ -62,14 +88,6 @@ export class SidebarComponent extends BaseComponent {
62
88
  customStyle: this.customStyle(),
63
89
  });
64
90
  }
65
- verify() {
66
- if (this.sidebarMenuChild() === undefined) {
67
- throw new Error('No SidebarMenuComponent available');
68
- }
69
- if (this.sidebarPageContentChild() === undefined) {
70
- throw new Error('No SidebarPageContentComponent available');
71
- }
72
- }
73
91
  //#endregion
74
92
  /**
75
93
  * Toggle sidebar visibility
@@ -89,11 +107,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
89
107
  type: Component,
90
108
  args: [{
91
109
  standalone: true,
92
- imports: [NgClass],
93
110
  selector: 'flowbite-sidebar',
94
111
  template: `<ng-content />`,
95
112
  encapsulation: ViewEncapsulation.None,
96
113
  changeDetection: ChangeDetectionStrategy.OnPush,
97
114
  }]
98
115
  }] });
99
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZWJhci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2Zsb3diaXRlLWFuZ3VsYXIvc2lkZWJhci9zaWRlYmFyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNoRSxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQU8vRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUc5RCxPQUFPLEVBQUUsYUFBYSxFQUFFLHdCQUF3QixFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFFM0UsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRTFDLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFlBQVksRUFDWixNQUFNLEVBQ04sS0FBSyxFQUNMLFNBQVMsRUFDVCxpQkFBaUIsR0FDbEIsTUFBTSxlQUFlLENBQUM7O0FBRXZCOztHQUVHO0FBU0gsTUFBTSxPQUFPLGdCQUFpQixTQUFRLGFBQTJCO0lBUmpFOztRQVNFOztXQUVHO1FBQ2EsaUJBQVksR0FBRyxNQUFNLENBQUMsbUJBQW1CLENBQUMsQ0FBQztRQUMzRDs7V0FFRztRQUNhLHFCQUFnQixHQUFHLFlBQVksQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO1FBQ3RFOztXQUVHO1FBQ2EsNEJBQXVCLEdBQUcsWUFBWSxDQUFDLDJCQUEyQixDQUFDLENBQUM7UUFFcEYsb0JBQW9CO1FBQ3BCOzs7O1dBSUc7UUFDSSxVQUFLLEdBQUcsS0FBSyxDQUFzQixTQUFTLENBQUMsQ0FBQztRQUNyRDs7OztXQUlHO1FBQ0ksZ0JBQVcsR0FBRyxLQUFLLENBQTJCLE1BQU0sQ0FBQyxDQUFDO1FBQzdEOzs7O1dBSUc7UUFDSSxXQUFNLEdBQUcsS0FBSyxDQUFVLEtBQUssQ0FBQyxDQUFDO1FBQ3RDOzs7O1dBSUc7UUFDSSxjQUFTLEdBQUcsS0FBSyxDQUFVLEtBQUssQ0FBQyxDQUFDO1FBQ3pDOztXQUVHO1FBQ0ksZ0JBQVcsR0FBRyxLQUFLLENBQTRCLEVBQUUsQ0FBQyxDQUFDO0tBbUMzRDtJQWxDQyxZQUFZO0lBRVosc0NBQXNDO0lBQ3RCLFVBQVU7UUFDeEIsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLFVBQVUsQ0FBQztZQUNsQyxXQUFXLEVBQUUsSUFBSSxDQUFDLFdBQVcsRUFBRTtZQUMvQixTQUFTLEVBQUUsd0JBQXdCLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQ3JELFdBQVcsRUFBRSxJQUFJLENBQUMsV0FBVyxFQUFFO1NBQ2hDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFZSxNQUFNO1FBQ3BCLElBQUksSUFBSSxDQUFDLGdCQUFnQixFQUFFLEtBQUssU0FBUyxFQUFFLENBQUM7WUFDMUMsTUFBTSxJQUFJLEtBQUssQ0FBQyxtQ0FBbUMsQ0FBQyxDQUFDO1FBQ3ZELENBQUM7UUFFRCxJQUFJLElBQUksQ0FBQyx1QkFBdUIsRUFBRSxLQUFLLFNBQVMsRUFBRSxDQUFDO1lBQ2pELE1BQU0sSUFBSSxLQUFLLENBQUMsMENBQTBDLENBQUMsQ0FBQztRQUM5RCxDQUFDO0lBQ0gsQ0FBQztJQUNELFlBQVk7SUFFWjs7OztPQUlHO0lBQ0ksZ0JBQWdCLENBQUMsTUFBZ0I7UUFDdEMsSUFBSSxNQUFNLEtBQUssU0FBUyxFQUFFLENBQUM7WUFDekIsTUFBTSxHQUFHLFNBQVMsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDO1FBQzNDLENBQUM7UUFFRCxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUMxQixDQUFDOzhHQTVFVSxnQkFBZ0I7a0dBQWhCLGdCQUFnQiw4NkJBUXFCLG9CQUFvQiwwR0FJYiwyQkFBMkIsdUZBaEJ4RSxnQkFBZ0I7OzJGQUlmLGdCQUFnQjtrQkFSNUIsU0FBUzttQkFBQztvQkFDVCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsT0FBTyxFQUFFLENBQUMsT0FBTyxDQUFDO29CQUNsQixRQUFRLEVBQUUsa0JBQWtCO29CQUM1QixRQUFRLEVBQUUsZ0JBQWdCO29CQUMxQixhQUFhLEVBQUUsaUJBQWlCLENBQUMsSUFBSTtvQkFDckMsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07aUJBQ2hEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2lkZWJhck1lbnVDb21wb25lbnQgfSBmcm9tICcuL3NpZGViYXItbWVudS5jb21wb25lbnQnO1xuaW1wb3J0IHsgU2lkZWJhclBhZ2VDb250ZW50Q29tcG9uZW50IH0gZnJvbSAnLi9zaWRlYmFyLXBhZ2UtY29udGVudC5jb21wb25lbnQnO1xuaW1wb3J0IHR5cGUge1xuICBTaWRlYmFyQ2xhc3MsXG4gIFNpZGViYXJDb2xvcnMsXG4gIFNpZGViYXJEaXNwbGF5TW9kZSxcbiAgU2lkZWJhclRoZW1lLFxufSBmcm9tICcuL3NpZGViYXIudGhlbWUnO1xuaW1wb3J0IHsgU2lkZWJhclRoZW1lU2VydmljZSB9IGZyb20gJy4vc2lkZWJhci50aGVtZS5zZXJ2aWNlJztcblxuaW1wb3J0IHR5cGUgeyBEZWVwUGFydGlhbCB9IGZyb20gJ2Zsb3diaXRlLWFuZ3VsYXInO1xuaW1wb3J0IHsgQmFzZUNvbXBvbmVudCwgYm9vbGVhblRvRmxvd2JpdGVCb29sZWFuIH0gZnJvbSAnZmxvd2JpdGUtYW5ndWxhcic7XG5cbmltcG9ydCB7IE5nQ2xhc3MgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHR5cGUgeyBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIGNvbnRlbnRDaGlsZCxcbiAgaW5qZWN0LFxuICBtb2RlbCxcbiAgdW50cmFja2VkLFxuICBWaWV3RW5jYXBzdWxhdGlvbixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbi8qKlxuICogQHNlZSBodHRwczovL2Zsb3diaXRlLmNvbS9kb2NzL2NvbXBvbmVudHMvc2lkZWJhci9cbiAqL1xuQENvbXBvbmVudCh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtOZ0NsYXNzXSxcbiAgc2VsZWN0b3I6ICdmbG93Yml0ZS1zaWRlYmFyJyxcbiAgdGVtcGxhdGU6IGA8bmctY29udGVudCAvPmAsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBTaWRlYmFyQ29tcG9uZW50IGV4dGVuZHMgQmFzZUNvbXBvbmVudDxTaWRlYmFyQ2xhc3M+IGltcGxlbWVudHMgT25Jbml0IHtcbiAgLyoqXG4gICAqIFNlcnZpY2UgaW5qZWN0ZWQgdXNlZCB0byBnZW5lcmF0ZSBjbGFzc1xuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IHRoZW1lU2VydmljZSA9IGluamVjdChTaWRlYmFyVGhlbWVTZXJ2aWNlKTtcbiAgLyoqXG4gICAqIFRoZSBjaGlsZCBgU2lkZWJhck1lbnVDb21wb25lbnRgXG4gICAqL1xuICBwdWJsaWMgcmVhZG9ubHkgc2lkZWJhck1lbnVDaGlsZCA9IGNvbnRlbnRDaGlsZChTaWRlYmFyTWVudUNvbXBvbmVudCk7XG4gIC8qKlxuICAgKiBUaGUgY2hpbGQgYFNpZGViYXJQYWdlQ29udGVudENvbXBvbmVudGBcbiAgICovXG4gIHB1YmxpYyByZWFkb25seSBzaWRlYmFyUGFnZUNvbnRlbnRDaGlsZCA9IGNvbnRlbnRDaGlsZChTaWRlYmFyUGFnZUNvbnRlbnRDb21wb25lbnQpO1xuXG4gIC8vI3JlZ2lvbiBwcm9wZXJ0aWVzXG4gIC8qKlxuICAgKiBTZXQgdGhlIHNpZGViYXIgY29sb3JcbiAgICpcbiAgICogQGRlZmF1bHQgcHJpbWFyeVxuICAgKi9cbiAgcHVibGljIGNvbG9yID0gbW9kZWw8a2V5b2YgU2lkZWJhckNvbG9ycz4oJ3ByaW1hcnknKTtcbiAgLyoqXG4gICAqIFNldCB0aGUgc2lkZWJhciBkaXNwbGF5IG1vZGVcbiAgICpcbiAgICogQGRlZmF1bHQgcHVzaFxuICAgKi9cbiAgcHVibGljIGRpc3BsYXlNb2RlID0gbW9kZWw8a2V5b2YgU2lkZWJhckRpc3BsYXlNb2RlPigncHVzaCcpO1xuICAvKipcbiAgICogU2V0IGlzIHRoZSBzaWRlYmFyIGlzIG9wZW5cbiAgICpcbiAgICogQGRlZmF1bHQgZmFsc2VcbiAgICovXG4gIHB1YmxpYyBpc09wZW4gPSBtb2RlbDxib29sZWFuPihmYWxzZSk7XG4gIC8qKlxuICAgKiBTZXQgaXMgdGhlIHNpZGViYXIgaXMgcm91bmRlZFxuICAgKlxuICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgKi9cbiAgcHVibGljIGlzUm91bmRlZCA9IG1vZGVsPGJvb2xlYW4+KGZhbHNlKTtcbiAgLyoqXG4gICAqIFNldCB0aGUgY3VzdG9tIHN0eWxlIGZvciB0aGlzIHNpZGViYXJcbiAgICovXG4gIHB1YmxpYyBjdXN0b21TdHlsZSA9IG1vZGVsPERlZXBQYXJ0aWFsPFNpZGViYXJUaGVtZT4+KHt9KTtcbiAgLy8jZW5kcmVnaW9uXG5cbiAgLy8jcmVnaW9uIEJhc2VDb21wb25lbnQgaW1wbGVtZW50YXRpb25cbiAgcHVibGljIG92ZXJyaWRlIGZldGNoQ2xhc3MoKTogU2lkZWJhckNsYXNzIHtcbiAgICByZXR1cm4gdGhpcy50aGVtZVNlcnZpY2UuZ2V0Q2xhc3Nlcyh7XG4gICAgICBkaXNwbGF5TW9kZTogdGhpcy5kaXNwbGF5TW9kZSgpLFxuICAgICAgaXNSb3VuZGVkOiBib29sZWFuVG9GbG93Yml0ZUJvb2xlYW4odGhpcy5pc1JvdW5kZWQoKSksXG4gICAgICBjdXN0b21TdHlsZTogdGhpcy5jdXN0b21TdHlsZSgpLFxuICAgIH0pO1xuICB9XG5cbiAgcHVibGljIG92ZXJyaWRlIHZlcmlmeSgpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5zaWRlYmFyTWVudUNoaWxkKCkgPT09IHVuZGVmaW5lZCkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdObyBTaWRlYmFyTWVudUNvbXBvbmVudCBhdmFpbGFibGUnKTtcbiAgICB9XG5cbiAgICBpZiAodGhpcy5zaWRlYmFyUGFnZUNvbnRlbnRDaGlsZCgpID09PSB1bmRlZmluZWQpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignTm8gU2lkZWJhclBhZ2VDb250ZW50Q29tcG9uZW50IGF2YWlsYWJsZScpO1xuICAgIH1cbiAgfVxuICAvLyNlbmRyZWdpb25cblxuICAvKipcbiAgICogVG9nZ2xlIHNpZGViYXIgdmlzaWJpbGl0eVxuICAgKlxuICAgKiBAcGFyYW0gaXNPcGVuIElmIHByb3ZpZGVkIGZvcmNlIGlzT3BlbiB2YWx1ZVxuICAgKi9cbiAgcHVibGljIHRvZ2dsZVZpc2liaWxpdHkoaXNPcGVuPzogYm9vbGVhbik6IHZvaWQge1xuICAgIGlmIChpc09wZW4gPT09IHVuZGVmaW5lZCkge1xuICAgICAgaXNPcGVuID0gdW50cmFja2VkKCgpID0+ICF0aGlzLmlzT3BlbigpKTtcbiAgICB9XG5cbiAgICB0aGlzLmlzT3Blbi5zZXQoaXNPcGVuKTtcbiAgfVxufVxuIl19
116
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sidebar.component.js","sourceRoot":"","sources":["../../../../../libs/flowbite-angular/sidebar/sidebar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { SidebarMenuComponent } from './sidebar-menu.component';\nimport { SidebarPageContentComponent } from './sidebar-page-content.component';\nimport type {\n  SidebarClass,\n  SidebarColors,\n  SidebarDisplayMode,\n  SidebarTheme,\n} from './sidebar.theme';\nimport { SidebarThemeService } from './sidebar.theme.service';\n\nimport type { DeepPartial } from 'flowbite-angular';\nimport { BaseComponent, booleanToFlowbiteBoolean } from 'flowbite-angular';\n\nimport type { OnInit } from '@angular/core';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  contentChild,\n  inject,\n  InjectionToken,\n  makeEnvironmentProviders,\n  model,\n  untracked,\n  ViewEncapsulation,\n} from '@angular/core';\n\nexport const FLOWBITE_SIDEBAR_COLOR_DEFAULT_VALUE = new InjectionToken<keyof SidebarColors>(\n  'FLOWBITE_SIDEBAR_COLOR_DEFAULT_VALUE'\n);\n\nexport const FLOWBITE_SIDEBAR_DISPLAY_MODE_DEFAULT_VALUE = new InjectionToken<\n  keyof SidebarDisplayMode\n>('FLOWBITE_SIDEBAR_DISPLAY_MODE_DEFAULT_VALUE');\n\nexport const FLOWBITE_SIDEBAR_IS_OPEN_DEFAULT_VALUE = new InjectionToken<boolean>(\n  'FLOWBITE_SIDEBAR_IS_OPEN_DEFAULT_VALUE'\n);\n\nexport const FLOWBITE_SIDEBAR_IS_ROUNDED_DEFAULT_VALUE = new InjectionToken<boolean>(\n  'FLOWBITE_SIDEBAR_IS_ROUNDED_DEFAULT_VALUE'\n);\n\nexport const FLOWBITE_SIDEBAR_CUSTOM_STYLE_DEFAULT_VALUE = new InjectionToken<\n  DeepPartial<SidebarTheme>\n>('FLOWBITE_SIDEBAR_CUSTOM_STYLE_DEFAULT_VALUE');\n\nexport const sidebarDefaultValueProvider = makeEnvironmentProviders([\n  {\n    provide: FLOWBITE_SIDEBAR_COLOR_DEFAULT_VALUE,\n    useValue: 'primary',\n  },\n  {\n    provide: FLOWBITE_SIDEBAR_DISPLAY_MODE_DEFAULT_VALUE,\n    useValue: 'push',\n  },\n  {\n    provide: FLOWBITE_SIDEBAR_IS_OPEN_DEFAULT_VALUE,\n    useValue: false,\n  },\n  {\n    provide: FLOWBITE_SIDEBAR_IS_ROUNDED_DEFAULT_VALUE,\n    useValue: false,\n  },\n  {\n    provide: FLOWBITE_SIDEBAR_CUSTOM_STYLE_DEFAULT_VALUE,\n    useValue: {},\n  },\n]);\n\n/**\n * @see https://flowbite.com/docs/components/sidebar/\n */\n@Component({\n  standalone: true,\n  selector: 'flowbite-sidebar',\n  template: `<ng-content />`,\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SidebarComponent extends BaseComponent<SidebarClass> implements OnInit {\n  /**\n   * Service injected used to generate class\n   */\n  public readonly themeService = inject(SidebarThemeService);\n  /**\n   * The child `SidebarMenuComponent`\n   */\n  public readonly sidebarMenuChild = contentChild.required(SidebarMenuComponent);\n  /**\n   * The child `SidebarPageContentComponent`\n   */\n  public readonly sidebarPageContentChild = contentChild.required(SidebarPageContentComponent);\n\n  //#region properties\n  /**\n   * Set the sidebar color\n   *\n   * @default primary\n   */\n  public color = model(inject(FLOWBITE_SIDEBAR_COLOR_DEFAULT_VALUE));\n  /**\n   * Set the sidebar display mode\n   *\n   * @default push\n   */\n  public displayMode = model(inject(FLOWBITE_SIDEBAR_DISPLAY_MODE_DEFAULT_VALUE));\n  /**\n   * Set is the sidebar is open\n   *\n   * @default false\n   */\n  public isOpen = model(inject(FLOWBITE_SIDEBAR_IS_OPEN_DEFAULT_VALUE));\n  /**\n   * Set is the sidebar is rounded\n   *\n   * @default false\n   */\n  public isRounded = model(inject(FLOWBITE_SIDEBAR_IS_ROUNDED_DEFAULT_VALUE));\n  /**\n   * Set the custom style for this sidebar\n   */\n  public customStyle = model(inject(FLOWBITE_SIDEBAR_CUSTOM_STYLE_DEFAULT_VALUE));\n  //#endregion\n\n  //#region BaseComponent implementation\n  public override fetchClass(): SidebarClass {\n    return this.themeService.getClasses({\n      displayMode: this.displayMode(),\n      isRounded: booleanToFlowbiteBoolean(this.isRounded()),\n      customStyle: this.customStyle(),\n    });\n  }\n  //#endregion\n\n  /**\n   * Toggle sidebar visibility\n   *\n   * @param isOpen If provided force isOpen value\n   */\n  public toggleVisibility(isOpen?: boolean): void {\n    if (isOpen === undefined) {\n      isOpen = untracked(() => !this.isOpen());\n    }\n\n    this.isOpen.set(isOpen);\n  }\n}\n"]}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './index';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmxvd2JpdGUtYW5ndWxhci10aGVtZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvZmxvd2JpdGUtYW5ndWxhci90aGVtZS9mbG93Yml0ZS1hbmd1bGFyLXRoZW1lLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19
@@ -0,0 +1,71 @@
1
+ import { afterNextRender, Directive, inject, Injector, signal, untracked } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ /**
4
+ * Use to give a clean API on the current application theme
5
+ */
6
+ export class FlowbiteThemeDirective {
7
+ constructor() {
8
+ this.injector = inject(Injector);
9
+ this.localStorageKey = 'color-theme';
10
+ this._currentTheme = signal('light');
11
+ /**
12
+ * Get the application theme based on `signals`
13
+ */
14
+ this.currentTheme = this._currentTheme.asReadonly();
15
+ }
16
+ ngOnInit() {
17
+ afterNextRender(() => {
18
+ this.toggleTheme(this.getLocalStorageTheme());
19
+ }, { injector: this.injector });
20
+ }
21
+ /**
22
+ * Get theme from the `localStorage`
23
+ *
24
+ * @returns The current theme saved in the `localStorage` with the key `color-theme`
25
+ */
26
+ getLocalStorageTheme() {
27
+ return localStorage.getItem(this.localStorageKey) === 'dark' ? 'dark' : 'light';
28
+ }
29
+ /**
30
+ * Toggle the theme saved in the `localStorage` and available in `currentTheme`
31
+ *
32
+ * @param theme If provided, force the theme instead of toggling it between light and dark mode
33
+ */
34
+ toggleTheme(theme) {
35
+ if (!theme) {
36
+ const tmpTheme = untracked(() => this.currentTheme());
37
+ if (tmpTheme === 'dark')
38
+ theme = 'light';
39
+ else
40
+ theme = 'dark';
41
+ }
42
+ this.setTheme(theme);
43
+ }
44
+ /**
45
+ * Set the theme inside the page
46
+ *
47
+ * @param theme Theme to apply
48
+ */
49
+ setTheme(theme) {
50
+ try {
51
+ localStorage.setItem(this.localStorageKey, theme);
52
+ }
53
+ catch (error) {
54
+ console.warn('Failed to save theme to localStorage:', error);
55
+ }
56
+ this._currentTheme.set(theme);
57
+ theme === 'dark'
58
+ ? document.documentElement.classList.add('dark')
59
+ : document.documentElement.classList.remove('dark');
60
+ }
61
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: FlowbiteThemeDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
62
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.0", type: FlowbiteThemeDirective, isStandalone: true, selector: "[flowbiteTheme]", ngImport: i0 }); }
63
+ }
64
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: FlowbiteThemeDirective, decorators: [{
65
+ type: Directive,
66
+ args: [{
67
+ standalone: true,
68
+ selector: '[flowbiteTheme]',
69
+ }]
70
+ }] });
71
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmxvd2JpdGUtdGhlbWUuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9mbG93Yml0ZS1hbmd1bGFyL3RoZW1lL2Zsb3diaXRlLXRoZW1lLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQSxPQUFPLEVBQUUsZUFBZSxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRWhHOztHQUVHO0FBS0gsTUFBTSxPQUFPLHNCQUFzQjtJQUpuQztRQUttQixhQUFRLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBRTVCLG9CQUFlLEdBQUcsYUFBYSxDQUFDO1FBQ2hDLGtCQUFhLEdBQUcsTUFBTSxDQUFnQixPQUFPLENBQUMsQ0FBQztRQVdoRTs7V0FFRztRQUNhLGlCQUFZLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxVQUFVLEVBQUUsQ0FBQztLQTRDaEU7SUF4RFEsUUFBUTtRQUNiLGVBQWUsQ0FDYixHQUFHLEVBQUU7WUFDSCxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxvQkFBb0IsRUFBRSxDQUFDLENBQUM7UUFDaEQsQ0FBQyxFQUNELEVBQUUsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FDNUIsQ0FBQztJQUNKLENBQUM7SUFPRDs7OztPQUlHO0lBQ0ksb0JBQW9CO1FBQ3pCLE9BQU8sWUFBWSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLEtBQUssTUFBTSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQztJQUNsRixDQUFDO0lBRUQ7Ozs7T0FJRztJQUNJLFdBQVcsQ0FBQyxLQUFxQjtRQUN0QyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDWCxNQUFNLFFBQVEsR0FBRyxTQUFTLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDLENBQUM7WUFFdEQsSUFBSSxRQUFRLEtBQUssTUFBTTtnQkFBRSxLQUFLLEdBQUcsT0FBTyxDQUFDOztnQkFDcEMsS0FBSyxHQUFHLE1BQU0sQ0FBQztRQUN0QixDQUFDO1FBRUQsSUFBSSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN2QixDQUFDO0lBRUQ7Ozs7T0FJRztJQUNJLFFBQVEsQ0FBQyxLQUFvQjtRQUNsQyxJQUFJLENBQUM7WUFDSCxZQUFZLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxlQUFlLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDcEQsQ0FBQztRQUFDLE9BQU8sS0FBSyxFQUFFLENBQUM7WUFDZixPQUFPLENBQUMsSUFBSSxDQUFDLHVDQUF1QyxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQy9ELENBQUM7UUFDRCxJQUFJLENBQUMsYUFBYSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUU5QixLQUFLLEtBQUssTUFBTTtZQUNkLENBQUMsQ0FBQyxRQUFRLENBQUMsZUFBZSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDO1lBQ2hELENBQUMsQ0FBQyxRQUFRLENBQUMsZUFBZSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDeEQsQ0FBQzs4R0E3RFUsc0JBQXNCO2tHQUF0QixzQkFBc0I7OzJGQUF0QixzQkFBc0I7a0JBSmxDLFNBQVM7bUJBQUM7b0JBQ1QsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSxpQkFBaUI7aUJBQzVCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBGbG93Yml0ZVRoZW1lIH0gZnJvbSAnZmxvd2JpdGUtYW5ndWxhcic7XG5cbmltcG9ydCB0eXBlIHsgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBhZnRlck5leHRSZW5kZXIsIERpcmVjdGl2ZSwgaW5qZWN0LCBJbmplY3Rvciwgc2lnbmFsLCB1bnRyYWNrZWQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuLyoqXG4gKiBVc2UgdG8gZ2l2ZSBhIGNsZWFuIEFQSSBvbiB0aGUgY3VycmVudCBhcHBsaWNhdGlvbiB0aGVtZVxuICovXG5ARGlyZWN0aXZlKHtcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgc2VsZWN0b3I6ICdbZmxvd2JpdGVUaGVtZV0nLFxufSlcbmV4cG9ydCBjbGFzcyBGbG93Yml0ZVRoZW1lRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0IHtcbiAgcHJpdmF0ZSByZWFkb25seSBpbmplY3RvciA9IGluamVjdChJbmplY3Rvcik7XG5cbiAgcHJpdmF0ZSByZWFkb25seSBsb2NhbFN0b3JhZ2VLZXkgPSAnY29sb3ItdGhlbWUnO1xuICBwcml2YXRlIHJlYWRvbmx5IF9jdXJyZW50VGhlbWUgPSBzaWduYWw8Rmxvd2JpdGVUaGVtZT4oJ2xpZ2h0Jyk7XG5cbiAgcHVibGljIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIGFmdGVyTmV4dFJlbmRlcihcbiAgICAgICgpID0+IHtcbiAgICAgICAgdGhpcy50b2dnbGVUaGVtZSh0aGlzLmdldExvY2FsU3RvcmFnZVRoZW1lKCkpO1xuICAgICAgfSxcbiAgICAgIHsgaW5qZWN0b3I6IHRoaXMuaW5qZWN0b3IgfVxuICAgICk7XG4gIH1cblxuICAvKipcbiAgICogR2V0IHRoZSBhcHBsaWNhdGlvbiB0aGVtZSBiYXNlZCBvbiBgc2lnbmFsc2BcbiAgICovXG4gIHB1YmxpYyByZWFkb25seSBjdXJyZW50VGhlbWUgPSB0aGlzLl9jdXJyZW50VGhlbWUuYXNSZWFkb25seSgpO1xuXG4gIC8qKlxuICAgKiBHZXQgdGhlbWUgZnJvbSB0aGUgYGxvY2FsU3RvcmFnZWBcbiAgICpcbiAgICogQHJldHVybnMgVGhlIGN1cnJlbnQgdGhlbWUgc2F2ZWQgaW4gdGhlIGBsb2NhbFN0b3JhZ2VgIHdpdGggdGhlIGtleSBgY29sb3ItdGhlbWVgXG4gICAqL1xuICBwdWJsaWMgZ2V0TG9jYWxTdG9yYWdlVGhlbWUoKTogRmxvd2JpdGVUaGVtZSB7XG4gICAgcmV0dXJuIGxvY2FsU3RvcmFnZS5nZXRJdGVtKHRoaXMubG9jYWxTdG9yYWdlS2V5KSA9PT0gJ2RhcmsnID8gJ2RhcmsnIDogJ2xpZ2h0JztcbiAgfVxuXG4gIC8qKlxuICAgKiBUb2dnbGUgdGhlIHRoZW1lIHNhdmVkIGluIHRoZSBgbG9jYWxTdG9yYWdlYCBhbmQgYXZhaWxhYmxlIGluIGBjdXJyZW50VGhlbWVgXG4gICAqXG4gICAqIEBwYXJhbSB0aGVtZSBJZiBwcm92aWRlZCwgZm9yY2UgdGhlIHRoZW1lIGluc3RlYWQgb2YgdG9nZ2xpbmcgaXQgYmV0d2VlbiBsaWdodCBhbmQgZGFyayBtb2RlXG4gICAqL1xuICBwdWJsaWMgdG9nZ2xlVGhlbWUodGhlbWU/OiBGbG93Yml0ZVRoZW1lKTogdm9pZCB7XG4gICAgaWYgKCF0aGVtZSkge1xuICAgICAgY29uc3QgdG1wVGhlbWUgPSB1bnRyYWNrZWQoKCkgPT4gdGhpcy5jdXJyZW50VGhlbWUoKSk7XG5cbiAgICAgIGlmICh0bXBUaGVtZSA9PT0gJ2RhcmsnKSB0aGVtZSA9ICdsaWdodCc7XG4gICAgICBlbHNlIHRoZW1lID0gJ2RhcmsnO1xuICAgIH1cblxuICAgIHRoaXMuc2V0VGhlbWUodGhlbWUpO1xuICB9XG5cbiAgLyoqXG4gICAqIFNldCB0aGUgdGhlbWUgaW5zaWRlIHRoZSBwYWdlXG4gICAqXG4gICAqIEBwYXJhbSB0aGVtZSBUaGVtZSB0byBhcHBseVxuICAgKi9cbiAgcHVibGljIHNldFRoZW1lKHRoZW1lOiBGbG93Yml0ZVRoZW1lKTogdm9pZCB7XG4gICAgdHJ5IHtcbiAgICAgIGxvY2FsU3RvcmFnZS5zZXRJdGVtKHRoaXMubG9jYWxTdG9yYWdlS2V5LCB0aGVtZSk7XG4gICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgIGNvbnNvbGUud2FybignRmFpbGVkIHRvIHNhdmUgdGhlbWUgdG8gbG9jYWxTdG9yYWdlOicsIGVycm9yKTtcbiAgICB9XG4gICAgdGhpcy5fY3VycmVudFRoZW1lLnNldCh0aGVtZSk7XG5cbiAgICB0aGVtZSA9PT0gJ2RhcmsnXG4gICAgICA/IGRvY3VtZW50LmRvY3VtZW50RWxlbWVudC5jbGFzc0xpc3QuYWRkKCdkYXJrJylcbiAgICAgIDogZG9jdW1lbnQuZG9jdW1lbnRFbGVtZW50LmNsYXNzTGlzdC5yZW1vdmUoJ2RhcmsnKTtcbiAgfVxufVxuIl19
@@ -0,0 +1,2 @@
1
+ export { FlowbiteThemeDirective } from './flowbite-theme.directive';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2Zsb3diaXRlLWFuZ3VsYXIvdGhlbWUvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sNEJBQTRCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBGbG93Yml0ZVRoZW1lRGlyZWN0aXZlIH0gZnJvbSAnLi9mbG93Yml0ZS10aGVtZS5kaXJlY3RpdmUnO1xuIl19