flowbite-angular 1.0.0-beta.1 → 1.1.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.
- package/README.md +15 -15
- package/accordion/accordion-content.component.d.ts +21 -1
- package/accordion/accordion-content.theme.d.ts +2 -2
- package/accordion/accordion-panel.component.d.ts +10 -3
- package/accordion/accordion-title.component.d.ts +27 -0
- package/accordion/accordion.component.d.ts +10 -14
- package/accordion/accordion.theme.d.ts +1 -5
- package/accordion/index.d.ts +4 -4
- package/alert/alert.component.d.ts +42 -1
- package/alert/index.d.ts +1 -1
- package/badge/badge.component.d.ts +40 -0
- package/badge/index.d.ts +1 -1
- package/base-component.directive.d.ts +0 -4
- package/breadcrumb/breadcrumb-item.component.d.ts +19 -0
- package/breadcrumb/breadcrumb.component.d.ts +8 -1
- package/breadcrumb/index.d.ts +2 -2
- package/button/button.component.d.ts +100 -1
- package/button/index.d.ts +1 -1
- package/dark-theme-toggle/dark-theme-toggle.component.d.ts +12 -17
- package/dark-theme-toggle/index.d.ts +1 -1
- package/dropdown/dropdown-divider.component.d.ts +13 -2
- package/dropdown/dropdown-divider.theme.d.ts +2 -2
- package/dropdown/dropdown-header.component.d.ts +19 -2
- package/dropdown/dropdown-item.component.d.ts +7 -0
- package/dropdown/dropdown.component.d.ts +39 -13
- package/dropdown/index.d.ts +4 -4
- package/esm2022/accordion/accordion-content.component.mjs +30 -16
- package/esm2022/accordion/accordion-content.theme.mjs +5 -5
- package/esm2022/accordion/accordion-content.theme.service.mjs +2 -2
- package/esm2022/accordion/accordion-panel.component.mjs +18 -15
- package/esm2022/accordion/accordion-title.component.mjs +14 -8
- package/esm2022/accordion/accordion-title.theme.mjs +3 -3
- package/esm2022/accordion/accordion.component.mjs +29 -16
- package/esm2022/accordion/accordion.theme.mjs +1 -13
- package/esm2022/accordion/accordion.theme.service.mjs +2 -2
- package/esm2022/accordion/index.mjs +5 -5
- package/esm2022/alert/alert.component.mjs +93 -37
- package/esm2022/alert/index.mjs +2 -2
- package/esm2022/badge/badge.component.mjs +34 -9
- package/esm2022/badge/index.mjs +2 -2
- package/esm2022/base-component.directive.mjs +1 -7
- package/esm2022/breadcrumb/breadcrumb-item.component.mjs +14 -8
- package/esm2022/breadcrumb/breadcrumb.component.mjs +16 -11
- package/esm2022/breadcrumb/index.mjs +3 -3
- package/esm2022/button/button.component.mjs +72 -34
- package/esm2022/button/index.mjs +2 -2
- package/esm2022/core/flowbite.theme.init.mjs +48 -14
- package/esm2022/dark-theme-toggle/dark-theme-toggle.component.mjs +17 -42
- package/esm2022/dark-theme-toggle/index.mjs +2 -2
- package/esm2022/dropdown/dropdown-divider.component.mjs +10 -5
- package/esm2022/dropdown/dropdown-divider.theme.mjs +1 -1
- package/esm2022/dropdown/dropdown-header.component.mjs +13 -10
- package/esm2022/dropdown/dropdown-item.component.mjs +10 -5
- package/esm2022/dropdown/dropdown.component.mjs +51 -72
- package/esm2022/dropdown/dropdown.theme.mjs +6 -6
- package/esm2022/dropdown/index.mjs +5 -5
- package/esm2022/indicator/index.mjs +2 -2
- package/esm2022/indicator/indicators.component.mjs +64 -14
- package/esm2022/modal/index.mjs +5 -5
- package/esm2022/modal/modal-body.component.mjs +10 -5
- package/esm2022/modal/modal-footer.component.mjs +10 -5
- package/esm2022/modal/modal-header.component.mjs +16 -10
- package/esm2022/modal/modal.component.mjs +42 -23
- package/esm2022/navbar/index.mjs +7 -7
- package/esm2022/navbar/navbar-brand.component.mjs +10 -5
- package/esm2022/navbar/navbar-content.component.mjs +35 -11
- package/esm2022/navbar/navbar-content.theme.mjs +2 -6
- package/esm2022/navbar/navbar-content.theme.service.mjs +2 -2
- package/esm2022/navbar/navbar-icon-button.component.mjs +10 -9
- package/esm2022/navbar/navbar-item.component.mjs +10 -5
- package/esm2022/navbar/navbar-toggle.component.mjs +12 -6
- package/esm2022/navbar/navbar.component.mjs +41 -16
- package/esm2022/scroll-top/index.mjs +2 -2
- package/esm2022/scroll-top/scroll-top.component.mjs +22 -5
- package/esm2022/sidebar/index.mjs +7 -7
- package/esm2022/sidebar/sidebar-item-group.component.mjs +19 -14
- package/esm2022/sidebar/sidebar-item.component.mjs +45 -26
- package/esm2022/sidebar/sidebar-menu.component.mjs +10 -9
- package/esm2022/sidebar/sidebar-page-content.component.mjs +10 -4
- package/esm2022/sidebar/sidebar-toggle.component.mjs +22 -5
- package/esm2022/sidebar/sidebar.component.mjs +36 -19
- package/esm2022/theme/flowbite-angular-theme.mjs +5 -0
- package/esm2022/theme/flowbite-theme.directive.mjs +71 -0
- package/esm2022/theme/index.mjs +2 -0
- package/fesm2022/flowbite-angular-accordion.mjs +92 -66
- package/fesm2022/flowbite-angular-accordion.mjs.map +1 -1
- package/fesm2022/flowbite-angular-alert.mjs +93 -37
- package/fesm2022/flowbite-angular-alert.mjs.map +1 -1
- package/fesm2022/flowbite-angular-badge.mjs +34 -9
- package/fesm2022/flowbite-angular-badge.mjs.map +1 -1
- package/fesm2022/flowbite-angular-breadcrumb.mjs +28 -16
- package/fesm2022/flowbite-angular-breadcrumb.mjs.map +1 -1
- package/fesm2022/flowbite-angular-button.mjs +72 -34
- package/fesm2022/flowbite-angular-button.mjs.map +1 -1
- package/fesm2022/flowbite-angular-core.mjs +47 -13
- package/fesm2022/flowbite-angular-core.mjs.map +1 -1
- package/fesm2022/flowbite-angular-dark-theme-toggle.mjs +17 -42
- package/fesm2022/flowbite-angular-dark-theme-toggle.mjs.map +1 -1
- package/fesm2022/flowbite-angular-dropdown.mjs +83 -88
- package/fesm2022/flowbite-angular-dropdown.mjs.map +1 -1
- package/fesm2022/flowbite-angular-indicator.mjs +64 -14
- package/fesm2022/flowbite-angular-indicator.mjs.map +1 -1
- package/fesm2022/flowbite-angular-modal.mjs +72 -34
- package/fesm2022/flowbite-angular-modal.mjs.map +1 -1
- package/fesm2022/flowbite-angular-navbar.mjs +109 -43
- package/fesm2022/flowbite-angular-navbar.mjs.map +1 -1
- package/fesm2022/flowbite-angular-scroll-top.mjs +22 -5
- package/fesm2022/flowbite-angular-scroll-top.mjs.map +1 -1
- package/fesm2022/flowbite-angular-sidebar.mjs +132 -65
- package/fesm2022/flowbite-angular-sidebar.mjs.map +1 -1
- package/fesm2022/flowbite-angular-theme.mjs +78 -0
- package/fesm2022/flowbite-angular-theme.mjs.map +1 -0
- package/fesm2022/flowbite-angular.mjs +0 -6
- package/fesm2022/flowbite-angular.mjs.map +1 -1
- package/indicator/index.d.ts +1 -1
- package/indicator/indicators.component.d.ts +81 -0
- package/modal/index.d.ts +4 -4
- package/modal/modal-body.component.d.ts +7 -0
- package/modal/modal-footer.component.d.ts +7 -0
- package/modal/modal-header.component.d.ts +13 -0
- package/modal/modal.component.d.ts +40 -2
- package/navbar/index.d.ts +6 -6
- package/navbar/navbar-brand.component.d.ts +7 -0
- package/navbar/navbar-content.component.d.ts +13 -4
- package/navbar/navbar-content.theme.d.ts +1 -3
- package/navbar/navbar-icon-button.component.d.ts +12 -1
- package/navbar/navbar-item.component.d.ts +12 -0
- package/navbar/navbar-toggle.component.d.ts +7 -0
- package/navbar/navbar.component.d.ts +30 -2
- package/package.json +7 -2
- package/scroll-top/index.d.ts +1 -1
- package/scroll-top/scroll-top.component.d.ts +31 -0
- package/sidebar/index.d.ts +6 -6
- package/sidebar/sidebar-item-group.component.d.ts +19 -1
- package/sidebar/sidebar-item.component.d.ts +21 -1
- package/sidebar/sidebar-menu.component.d.ts +25 -1
- package/sidebar/sidebar-page-content.component.d.ts +12 -0
- package/sidebar/sidebar-toggle.component.d.ts +22 -0
- package/sidebar/sidebar.component.d.ts +17 -3
- package/theme/README.md +4 -0
- package/theme/flowbite-theme.directive.d.ts +36 -0
- package/theme/index.d.ts +1 -0
|
@@ -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(
|
|
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(
|
|
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,
|
|
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 {
|
|
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(
|
|
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(
|
|
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(
|
|
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(
|
|
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,
|
|
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
|