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.
- package/README.md +15 -15
- package/accordion/accordion-content.component.d.ts +20 -4
- package/accordion/accordion-content.theme.d.ts +0 -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 -1
- 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 +29 -16
- package/esm2022/accordion/accordion-content.theme.mjs +2 -6
- 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.component.mjs +28 -13
- 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/navbar/navbar.theme.mjs +2 -2
- 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 +85 -50
- 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 +110 -44
- 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,11 +3,37 @@ import { ModalFooterComponent } from './modal-footer.component';
|
|
|
3
3
|
import { ModalHeaderComponent } from './modal-header.component';
|
|
4
4
|
import { ModalThemeService } from './modal.theme.service';
|
|
5
5
|
import { BaseComponent, booleanToFlowbiteBoolean } from 'flowbite-angular';
|
|
6
|
-
import {
|
|
7
|
-
import { ChangeDetectionStrategy, Component, contentChild, inject, model, TemplateRef, viewChild, ViewContainerRef, ViewEncapsulation, } from '@angular/core';
|
|
6
|
+
import { ChangeDetectionStrategy, Component, contentChild, inject, InjectionToken, makeEnvironmentProviders, model, TemplateRef, viewChild, ViewContainerRef, ViewEncapsulation, } from '@angular/core';
|
|
8
7
|
import { NavigationStart, Router } from '@angular/router';
|
|
9
8
|
import { filter, Subject, takeUntil } from 'rxjs';
|
|
10
9
|
import * as i0 from "@angular/core";
|
|
10
|
+
export const FLOWBITE_MODAL_SIZE_DEFAULT_VALUE = new InjectionToken('FLOWBITE_MODAL_SIZE_DEFAULT_VALUE');
|
|
11
|
+
export const FLOWBITE_MODAL_POSITION_DEFAULT_VALUE = new InjectionToken('FLOWBITE_MODAL_POSITION_DEFAULT_VALUE');
|
|
12
|
+
export const FLOWBITE_MODAL_IS_DISMISSABLE_DEFAULT_VALUE = new InjectionToken('FLOWBITE_MODAL_IS_DISMISSABLE_DEFAULT_VALUE');
|
|
13
|
+
export const FLOWBITE_MODAL_IS_OPEN_DEFAULT_VALUE = new InjectionToken('FLOWBITE_MODAL_IS_OPEN_DEFAULT_VALUE');
|
|
14
|
+
export const FLOWBITE_MODAL_CUSTOM_STYLE_DEFAULT_VALUE = new InjectionToken('FLOWBITE_MODAL_CUSTOM_STYLE_DEFAULT_VALUE');
|
|
15
|
+
export const modalDefaultValueProvider = makeEnvironmentProviders([
|
|
16
|
+
{
|
|
17
|
+
provide: FLOWBITE_MODAL_SIZE_DEFAULT_VALUE,
|
|
18
|
+
useValue: 'md',
|
|
19
|
+
},
|
|
20
|
+
{
|
|
21
|
+
provide: FLOWBITE_MODAL_POSITION_DEFAULT_VALUE,
|
|
22
|
+
useValue: 'center',
|
|
23
|
+
},
|
|
24
|
+
{
|
|
25
|
+
provide: FLOWBITE_MODAL_IS_DISMISSABLE_DEFAULT_VALUE,
|
|
26
|
+
useValue: false,
|
|
27
|
+
},
|
|
28
|
+
{
|
|
29
|
+
provide: FLOWBITE_MODAL_IS_OPEN_DEFAULT_VALUE,
|
|
30
|
+
useValue: false,
|
|
31
|
+
},
|
|
32
|
+
{
|
|
33
|
+
provide: FLOWBITE_MODAL_CUSTOM_STYLE_DEFAULT_VALUE,
|
|
34
|
+
useValue: {},
|
|
35
|
+
},
|
|
36
|
+
]);
|
|
11
37
|
/**
|
|
12
38
|
* @see https://flowbite.com/docs/components/modal/
|
|
13
39
|
*/
|
|
@@ -26,7 +52,7 @@ export class ModalComponent extends BaseComponent {
|
|
|
26
52
|
/**
|
|
27
53
|
* The child `ModalBodyComponent`
|
|
28
54
|
*/
|
|
29
|
-
this.modalBodyChild = contentChild(ModalBodyComponent);
|
|
55
|
+
this.modalBodyChild = contentChild.required(ModalBodyComponent);
|
|
30
56
|
/**
|
|
31
57
|
* The child `ModalFooterComponent`
|
|
32
58
|
*/
|
|
@@ -42,29 +68,29 @@ export class ModalComponent extends BaseComponent {
|
|
|
42
68
|
*
|
|
43
69
|
* @default md
|
|
44
70
|
*/
|
|
45
|
-
this.size = model(
|
|
71
|
+
this.size = model(inject(FLOWBITE_MODAL_SIZE_DEFAULT_VALUE));
|
|
46
72
|
/**
|
|
47
73
|
* Set the modal position
|
|
48
74
|
*
|
|
49
75
|
* @default center
|
|
50
76
|
*/
|
|
51
|
-
this.position = model(
|
|
77
|
+
this.position = model(inject(FLOWBITE_MODAL_POSITION_DEFAULT_VALUE));
|
|
52
78
|
/**
|
|
53
79
|
* Set if the modal is dismissable
|
|
54
80
|
*
|
|
55
81
|
* @default false
|
|
56
82
|
*/
|
|
57
|
-
this.isDismissable = model(
|
|
83
|
+
this.isDismissable = model(inject(FLOWBITE_MODAL_IS_DISMISSABLE_DEFAULT_VALUE));
|
|
58
84
|
/**
|
|
59
85
|
* Set if the modal is open
|
|
60
86
|
*
|
|
61
87
|
* @default false
|
|
62
88
|
*/
|
|
63
|
-
this.isOpen = model(
|
|
89
|
+
this.isOpen = model(inject(FLOWBITE_MODAL_IS_OPEN_DEFAULT_VALUE));
|
|
64
90
|
/**
|
|
65
91
|
* Set the custom style for this modal
|
|
66
92
|
*/
|
|
67
|
-
this.customStyle = model(
|
|
93
|
+
this.customStyle = model(inject(FLOWBITE_MODAL_CUSTOM_STYLE_DEFAULT_VALUE));
|
|
68
94
|
}
|
|
69
95
|
//#endregion
|
|
70
96
|
//#region BaseComponent implementation
|
|
@@ -82,11 +108,6 @@ export class ModalComponent extends BaseComponent {
|
|
|
82
108
|
.pipe(takeUntil(this.destroyed), filter(() => this.isOpen()), filter((event) => event instanceof NavigationStart))
|
|
83
109
|
.subscribe(() => this.close());
|
|
84
110
|
}
|
|
85
|
-
verify() {
|
|
86
|
-
if (this.modalBodyChild() === undefined) {
|
|
87
|
-
throw new Error('No ModalBodyComponent available');
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
111
|
//#endregion
|
|
91
112
|
ngOnDestroy() {
|
|
92
113
|
this.destroyed.next();
|
|
@@ -123,7 +144,6 @@ export class ModalComponent extends BaseComponent {
|
|
|
123
144
|
this.embeddedView?.destroy();
|
|
124
145
|
}
|
|
125
146
|
onKeydownHandler(event) {
|
|
126
|
-
console.log('hello');
|
|
127
147
|
if (event.key === 'Escape') {
|
|
128
148
|
this.close();
|
|
129
149
|
}
|
|
@@ -139,32 +159,31 @@ export class ModalComponent extends BaseComponent {
|
|
|
139
159
|
<div class="bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-[99]"></div>
|
|
140
160
|
|
|
141
161
|
<div
|
|
142
|
-
[
|
|
162
|
+
[class]="contentClasses().modalWrapperClass"
|
|
143
163
|
(click)="onBackdropClick($event)">
|
|
144
|
-
<div [
|
|
145
|
-
<div [
|
|
164
|
+
<div [class]="contentClasses().modalContainerClass">
|
|
165
|
+
<div [class]="contentClasses().modalContentClass">
|
|
146
166
|
<ng-content />
|
|
147
167
|
</div>
|
|
148
168
|
</div>
|
|
149
169
|
</div>
|
|
150
170
|
</ng-template>
|
|
151
|
-
`, isInline: true,
|
|
171
|
+
`, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
152
172
|
}
|
|
153
173
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ModalComponent, decorators: [{
|
|
154
174
|
type: Component,
|
|
155
175
|
args: [{
|
|
156
176
|
standalone: true,
|
|
157
|
-
imports: [NgClass],
|
|
158
177
|
selector: 'flowbite-modal',
|
|
159
178
|
template: `
|
|
160
179
|
<ng-template #modal>
|
|
161
180
|
<div class="bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-[99]"></div>
|
|
162
181
|
|
|
163
182
|
<div
|
|
164
|
-
[
|
|
183
|
+
[class]="contentClasses().modalWrapperClass"
|
|
165
184
|
(click)="onBackdropClick($event)">
|
|
166
|
-
<div [
|
|
167
|
-
<div [
|
|
185
|
+
<div [class]="contentClasses().modalContainerClass">
|
|
186
|
+
<div [class]="contentClasses().modalContentClass">
|
|
168
187
|
<ng-content />
|
|
169
188
|
</div>
|
|
170
189
|
</div>
|
|
@@ -179,4 +198,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
|
|
|
179
198
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
180
199
|
}]
|
|
181
200
|
}] });
|
|
182
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../../libs/flowbite-angular/modal/modal.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ModalBodyComponent } from './modal-body.component';\nimport { ModalFooterComponent } from './modal-footer.component';\nimport { ModalHeaderComponent } from './modal-header.component';\nimport type { ModalClass, ModalPositions, ModalSizes, ModalTheme } from './modal.theme';\nimport { ModalThemeService } from './modal.theme.service';\n\nimport type { DeepPartial } from 'flowbite-angular';\nimport { BaseComponent, booleanToFlowbiteBoolean } from 'flowbite-angular';\n\nimport { NgClass } from '@angular/common';\nimport type { EmbeddedViewRef, OnDestroy } from '@angular/core';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  contentChild,\n  inject,\n  model,\n  TemplateRef,\n  viewChild,\n  ViewContainerRef,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { NavigationStart, Router } from '@angular/router';\nimport { filter, Subject, takeUntil } from 'rxjs';\n\n/**\n * @see https://flowbite.com/docs/components/modal/\n */\n@Component({\n  standalone: true,\n  imports: [NgClass],\n  selector: 'flowbite-modal',\n  template: `\n    <ng-template #modal>\n      <div class=\"bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-[99]\"></div>\n\n      <div\n        [ngClass]=\"contentClasses().modalWrapperClass\"\n        (click)=\"onBackdropClick($event)\">\n        <div [ngClass]=\"contentClasses().modalContainerClass\">\n          <div [ngClass]=\"contentClasses().modalContentClass\">\n            <ng-content />\n          </div>\n        </div>\n      </div>\n    </ng-template>\n  `,\n  host: {\n    tabindex: '-1',\n    '(document:keydown)': 'onKeydownHandler($event)',\n  },\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ModalComponent extends BaseComponent<ModalClass> implements OnDestroy {\n  private readonly destroyed = new Subject<void>();\n\n  /**\n   * Service injected used to generate class\n   */\n  public readonly themeService = inject(ModalThemeService);\n  /**\n   * The child `ModalHeaderComponent`\n   */\n  public readonly modalHeaderChild = contentChild(ModalHeaderComponent);\n  /**\n   * The child `ModalBodyComponent`\n   */\n  public readonly modalBodyChild = contentChild(ModalBodyComponent);\n  /**\n   * The child `ModalFooterComponent`\n   */\n  public readonly modalFooterChild = contentChild(ModalFooterComponent);\n\n  //#region template properties\n  private readonly template = viewChild.required('modal', { read: TemplateRef });\n\n  private readonly viewContainer = inject(ViewContainerRef);\n  private readonly router = inject(Router);\n\n  private embeddedView?: EmbeddedViewRef<unknown>;\n  //#endregion\n\n  //#region properties\n  /**\n   * Set the modal size\n   *\n   * @default md\n   */\n  public size = model<keyof ModalSizes>('md');\n  /**\n   * Set the modal position\n   *\n   * @default center\n   */\n  public position = model<keyof ModalPositions>('center');\n  /**\n   * Set if the modal is dismissable\n   *\n   * @default false\n   */\n  public isDismissable = model<boolean>(false);\n  /**\n   * Set if the modal is open\n   *\n   * @default false\n   */\n  public isOpen = model<boolean>(false);\n  /**\n   * Set the custom style for this modal\n   */\n  public customStyle = model<DeepPartial<ModalTheme>>({});\n  //#endregion\n\n  //#region BaseComponent implementation\n  public override fetchClass(): ModalClass {\n    return this.themeService.getClasses({\n      isOpen: booleanToFlowbiteBoolean(this.isOpen()),\n      size: this.size(),\n      position: this.position(),\n      customStyle: this.customStyle(),\n    });\n  }\n\n  public override init(): void {\n    // close modal if it's not destroyed on route change\n    this.router.events\n      .pipe(\n        takeUntil(this.destroyed),\n        filter(() => this.isOpen()),\n        filter((event) => event instanceof NavigationStart)\n      )\n      .subscribe(() => this.close());\n  }\n\n  public override verify(): void {\n    if (this.modalBodyChild() === undefined) {\n      throw new Error('No ModalBodyComponent available');\n    }\n  }\n  //#endregion\n\n  ngOnDestroy(): void {\n    this.destroyed.next();\n    this.destroyed.complete();\n  }\n\n  open() {\n    this.isOpen.set(true);\n    this.changeBackdrop();\n  }\n\n  close() {\n    this.isOpen.set(false);\n    this.changeBackdrop();\n  }\n\n  toggle() {\n    this.isOpen.set(!this.isOpen());\n    this.changeBackdrop();\n  }\n\n  // If isOpen changes, add or remove template\n  changeBackdrop() {\n    if (this.isOpen()) {\n      this.createTemplate();\n    } else {\n      this.destroyTemplate();\n    }\n  }\n\n  private createTemplate() {\n    if (this.embeddedView) {\n      this.destroyTemplate();\n    }\n\n    this.embeddedView = this.viewContainer.createEmbeddedView(this.template());\n  }\n\n  private destroyTemplate() {\n    this.embeddedView?.destroy();\n  }\n\n  onKeydownHandler(event: KeyboardEvent) {\n    console.log('hello');\n    if (event.key === 'Escape') {\n      this.close();\n    }\n  }\n\n  onBackdropClick(event: MouseEvent) {\n    if (event.target == event.currentTarget && this.isDismissable()) {\n      this.close();\n    }\n  }\n}\n"]}
|
|
201
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../../libs/flowbite-angular/modal/modal.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ModalBodyComponent } from './modal-body.component';\nimport { ModalFooterComponent } from './modal-footer.component';\nimport { ModalHeaderComponent } from './modal-header.component';\nimport type { ModalClass, ModalPositions, ModalSizes, ModalTheme } from './modal.theme';\nimport { ModalThemeService } from './modal.theme.service';\n\nimport type { DeepPartial } from 'flowbite-angular';\nimport { BaseComponent, booleanToFlowbiteBoolean } from 'flowbite-angular';\n\nimport type { EmbeddedViewRef, OnDestroy } from '@angular/core';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  contentChild,\n  inject,\n  InjectionToken,\n  makeEnvironmentProviders,\n  model,\n  TemplateRef,\n  viewChild,\n  ViewContainerRef,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { NavigationStart, Router } from '@angular/router';\nimport { filter, Subject, takeUntil } from 'rxjs';\n\nexport const FLOWBITE_MODAL_SIZE_DEFAULT_VALUE = new InjectionToken<keyof ModalSizes>(\n  'FLOWBITE_MODAL_SIZE_DEFAULT_VALUE'\n);\n\nexport const FLOWBITE_MODAL_POSITION_DEFAULT_VALUE = new InjectionToken<keyof ModalPositions>(\n  'FLOWBITE_MODAL_POSITION_DEFAULT_VALUE'\n);\n\nexport const FLOWBITE_MODAL_IS_DISMISSABLE_DEFAULT_VALUE = new InjectionToken<boolean>(\n  'FLOWBITE_MODAL_IS_DISMISSABLE_DEFAULT_VALUE'\n);\n\nexport const FLOWBITE_MODAL_IS_OPEN_DEFAULT_VALUE = new InjectionToken<boolean>(\n  'FLOWBITE_MODAL_IS_OPEN_DEFAULT_VALUE'\n);\n\nexport const FLOWBITE_MODAL_CUSTOM_STYLE_DEFAULT_VALUE = new InjectionToken<\n  DeepPartial<ModalTheme>\n>('FLOWBITE_MODAL_CUSTOM_STYLE_DEFAULT_VALUE');\n\nexport const modalDefaultValueProvider = makeEnvironmentProviders([\n  {\n    provide: FLOWBITE_MODAL_SIZE_DEFAULT_VALUE,\n    useValue: 'md',\n  },\n  {\n    provide: FLOWBITE_MODAL_POSITION_DEFAULT_VALUE,\n    useValue: 'center',\n  },\n  {\n    provide: FLOWBITE_MODAL_IS_DISMISSABLE_DEFAULT_VALUE,\n    useValue: false,\n  },\n  {\n    provide: FLOWBITE_MODAL_IS_OPEN_DEFAULT_VALUE,\n    useValue: false,\n  },\n  {\n    provide: FLOWBITE_MODAL_CUSTOM_STYLE_DEFAULT_VALUE,\n    useValue: {},\n  },\n]);\n\n/**\n * @see https://flowbite.com/docs/components/modal/\n */\n@Component({\n  standalone: true,\n  selector: 'flowbite-modal',\n  template: `\n    <ng-template #modal>\n      <div class=\"bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-[99]\"></div>\n\n      <div\n        [class]=\"contentClasses().modalWrapperClass\"\n        (click)=\"onBackdropClick($event)\">\n        <div [class]=\"contentClasses().modalContainerClass\">\n          <div [class]=\"contentClasses().modalContentClass\">\n            <ng-content />\n          </div>\n        </div>\n      </div>\n    </ng-template>\n  `,\n  host: {\n    tabindex: '-1',\n    '(document:keydown)': 'onKeydownHandler($event)',\n  },\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ModalComponent extends BaseComponent<ModalClass> implements OnDestroy {\n  private readonly destroyed = new Subject<void>();\n\n  /**\n   * Service injected used to generate class\n   */\n  public readonly themeService = inject(ModalThemeService);\n  /**\n   * The child `ModalHeaderComponent`\n   */\n  public readonly modalHeaderChild = contentChild(ModalHeaderComponent);\n  /**\n   * The child `ModalBodyComponent`\n   */\n  public readonly modalBodyChild = contentChild.required(ModalBodyComponent);\n  /**\n   * The child `ModalFooterComponent`\n   */\n  public readonly modalFooterChild = contentChild(ModalFooterComponent);\n\n  //#region template properties\n  private readonly template = viewChild.required('modal', { read: TemplateRef });\n\n  private readonly viewContainer = inject(ViewContainerRef);\n  private readonly router = inject(Router);\n\n  private embeddedView?: EmbeddedViewRef<unknown>;\n  //#endregion\n\n  //#region properties\n  /**\n   * Set the modal size\n   *\n   * @default md\n   */\n  public size = model(inject(FLOWBITE_MODAL_SIZE_DEFAULT_VALUE));\n  /**\n   * Set the modal position\n   *\n   * @default center\n   */\n  public position = model(inject(FLOWBITE_MODAL_POSITION_DEFAULT_VALUE));\n  /**\n   * Set if the modal is dismissable\n   *\n   * @default false\n   */\n  public isDismissable = model(inject(FLOWBITE_MODAL_IS_DISMISSABLE_DEFAULT_VALUE));\n  /**\n   * Set if the modal is open\n   *\n   * @default false\n   */\n  public isOpen = model(inject(FLOWBITE_MODAL_IS_OPEN_DEFAULT_VALUE));\n  /**\n   * Set the custom style for this modal\n   */\n  public customStyle = model(inject(FLOWBITE_MODAL_CUSTOM_STYLE_DEFAULT_VALUE));\n  //#endregion\n\n  //#region BaseComponent implementation\n  public override fetchClass(): ModalClass {\n    return this.themeService.getClasses({\n      isOpen: booleanToFlowbiteBoolean(this.isOpen()),\n      size: this.size(),\n      position: this.position(),\n      customStyle: this.customStyle(),\n    });\n  }\n\n  public override init(): void {\n    // close modal if it's not destroyed on route change\n    this.router.events\n      .pipe(\n        takeUntil(this.destroyed),\n        filter(() => this.isOpen()),\n        filter((event) => event instanceof NavigationStart)\n      )\n      .subscribe(() => this.close());\n  }\n  //#endregion\n\n  ngOnDestroy(): void {\n    this.destroyed.next();\n    this.destroyed.complete();\n  }\n\n  open() {\n    this.isOpen.set(true);\n    this.changeBackdrop();\n  }\n\n  close() {\n    this.isOpen.set(false);\n    this.changeBackdrop();\n  }\n\n  toggle() {\n    this.isOpen.set(!this.isOpen());\n    this.changeBackdrop();\n  }\n\n  // If isOpen changes, add or remove template\n  changeBackdrop() {\n    if (this.isOpen()) {\n      this.createTemplate();\n    } else {\n      this.destroyTemplate();\n    }\n  }\n\n  private createTemplate() {\n    if (this.embeddedView) {\n      this.destroyTemplate();\n    }\n\n    this.embeddedView = this.viewContainer.createEmbeddedView(this.template());\n  }\n\n  private destroyTemplate() {\n    this.embeddedView?.destroy();\n  }\n\n  onKeydownHandler(event: KeyboardEvent) {\n    if (event.key === 'Escape') {\n      this.close();\n    }\n  }\n\n  onBackdropClick(event: MouseEvent) {\n    if (event.target == event.currentTarget && this.isDismissable()) {\n      this.close();\n    }\n  }\n}\n"]}
|
package/esm2022/navbar/index.mjs
CHANGED
|
@@ -1,19 +1,19 @@
|
|
|
1
|
-
export { NavbarComponent } from './navbar.component';
|
|
1
|
+
export { NavbarComponent, FLOWBITE_NAVBAR_COLOR_DEFAULT_VALUE, FLOWBITE_NAVBAR_CUSTOM_STYLE_DEFAULT_VALUE, FLOWBITE_NAVBAR_HAS_BORDER_DEFAULT_VALUE, FLOWBITE_NAVBAR_IS_FIXED_DEFAULT_VALUE, FLOWBITE_NAVBAR_IS_OPEN_DEFAULT_VALUE, FLOWBITE_NAVBAR_IS_ROUNDED_DEFAULT_VALUE, navbarDefaultValueProvider, } from './navbar.component';
|
|
2
2
|
export { navbarTheme } from './navbar.theme';
|
|
3
3
|
export { FLOWBITE_NAVBAR_THEME_TOKEN, NavbarThemeService } from './navbar.theme.service';
|
|
4
|
-
export { NavbarBrandComponent } from './navbar-brand.component';
|
|
4
|
+
export { NavbarBrandComponent, FLOWBITE_NAVBAR_BRAND_CUSTOM_STYLE_DEFAULT_VALUE, navbarBrandDefaultThemeProvider, } from './navbar-brand.component';
|
|
5
5
|
export { navbarBrandTheme } from './navbar-brand.theme';
|
|
6
6
|
export { FLOWBITE_NAVBAR_BRAND_THEME_TOKEN, NavbarBrandThemeService, } from './navbar-brand.theme.service';
|
|
7
|
-
export { NavbarContentComponent } from './navbar-content.component';
|
|
7
|
+
export { NavbarContentComponent, FLOWBITE_NAVBAR_CONTENT_CUSTOM_STYLE_DEFAULT_VALUE, navbarContentDefaultValueProvider, } from './navbar-content.component';
|
|
8
8
|
export { navbarContentTheme } from './navbar-content.theme';
|
|
9
9
|
export { FLOWBITE_NAVBAR_CONTENT_THEME_TOKEN, NavbarContentThemeService, } from './navbar-content.theme.service';
|
|
10
|
-
export { NavbarItemComponent } from './navbar-item.component';
|
|
10
|
+
export { NavbarItemComponent, FLOWBITE_NAVBAR_ITEM_CUSTOM_STYLE_DEFAULT_VALUE, navbarItemDefaultValueProvider, } from './navbar-item.component';
|
|
11
11
|
export { navbarItemTheme } from './navbar-item.theme';
|
|
12
12
|
export { FLOWBITE_NAVBAR_ITEM_THEME_TOKEN, NavbarItemThemeService, } from './navbar-item.theme.service';
|
|
13
|
-
export { NavbarToggleComponent } from './navbar-toggle.component';
|
|
13
|
+
export { NavbarToggleComponent, FLOWBITE_NAVBAR_TOGGLE_CUSTOM_STYLE_DEFAULT_VALUE, navbarToggleDefaultValueProvider, } from './navbar-toggle.component';
|
|
14
14
|
export { navbarToggleTheme } from './navbar-toggle.theme';
|
|
15
15
|
export { FLOWBITE_NAVBAR_TOGGLE_THEME_TOKEN, NavbarToggleThemeService, } from './navbar-toggle.theme.service';
|
|
16
|
-
export { NavbarIconButtonComponent } from './navbar-icon-button.component';
|
|
16
|
+
export { NavbarIconButtonComponent, FLOWBITE_NAVBAR_ICON_BUTTON_CUSTOM_STYLE_DEFAULT_VALUE, navbarIconButtonDefaultValueProvider, } from './navbar-icon-button.component';
|
|
17
17
|
export { navbarIconButtonTheme } from './navbar-icon-button.theme';
|
|
18
18
|
export { FLOWBITE_NAVBAR_ICON_BUTTON_THEME_TOKEN, NavbarIconButtonThemeService, } from './navbar-icon-button.theme.service';
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2Zsb3diaXRlLWFuZ3VsYXIvbmF2YmFyL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxlQUFlLEVBQ2YsbUNBQW1DLEVBQ25DLDBDQUEwQyxFQUMxQyx3Q0FBd0MsRUFDeEMsc0NBQXNDLEVBQ3RDLHFDQUFxQyxFQUNyQyx3Q0FBd0MsRUFDeEMsMEJBQTBCLEdBQzNCLE1BQU0sb0JBQW9CLENBQUM7QUFFNUIsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBRXpGLE9BQU8sRUFDTCxvQkFBb0IsRUFDcEIsZ0RBQWdELEVBQ2hELCtCQUErQixHQUNoQyxNQUFNLDBCQUEwQixDQUFDO0FBTWxDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3hELE9BQU8sRUFDTCxpQ0FBaUMsRUFDakMsdUJBQXVCLEdBQ3hCLE1BQU0sOEJBQThCLENBQUM7QUFFdEMsT0FBTyxFQUNMLHNCQUFzQixFQUN0QixrREFBa0QsRUFDbEQsaUNBQWlDLEdBQ2xDLE1BQU0sNEJBQTRCLENBQUM7QUFNcEMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDNUQsT0FBTyxFQUNMLG1DQUFtQyxFQUNuQyx5QkFBeUIsR0FDMUIsTUFBTSxnQ0FBZ0MsQ0FBQztBQUV4QyxPQUFPLEVBQ0wsbUJBQW1CLEVBQ25CLCtDQUErQyxFQUMvQyw4QkFBOEIsR0FDL0IsTUFBTSx5QkFBeUIsQ0FBQztBQUVqQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDdEQsT0FBTyxFQUNMLGdDQUFnQyxFQUNoQyxzQkFBc0IsR0FDdkIsTUFBTSw2QkFBNkIsQ0FBQztBQUVyQyxPQUFPLEVBQ0wscUJBQXFCLEVBQ3JCLGlEQUFpRCxFQUNqRCxnQ0FBZ0MsR0FDakMsTUFBTSwyQkFBMkIsQ0FBQztBQU1uQyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUMxRCxPQUFPLEVBQ0wsa0NBQWtDLEVBQ2xDLHdCQUF3QixHQUN6QixNQUFNLCtCQUErQixDQUFDO0FBRXZDLE9BQU8sRUFDTCx5QkFBeUIsRUFDekIsc0RBQXNELEVBQ3RELG9DQUFvQyxHQUNyQyxNQUFNLGdDQUFnQyxDQUFDO0FBTXhDLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ25FLE9BQU8sRUFDTCx1Q0FBdUMsRUFDdkMsNEJBQTRCLEdBQzdCLE1BQU0sb0NBQW9DLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQge1xuICBOYXZiYXJDb21wb25lbnQsXG4gIEZMT1dCSVRFX05BVkJBUl9DT0xPUl9ERUZBVUxUX1ZBTFVFLFxuICBGTE9XQklURV9OQVZCQVJfQ1VTVE9NX1NUWUxFX0RFRkFVTFRfVkFMVUUsXG4gIEZMT1dCSVRFX05BVkJBUl9IQVNfQk9SREVSX0RFRkFVTFRfVkFMVUUsXG4gIEZMT1dCSVRFX05BVkJBUl9JU19GSVhFRF9ERUZBVUxUX1ZBTFVFLFxuICBGTE9XQklURV9OQVZCQVJfSVNfT1BFTl9ERUZBVUxUX1ZBTFVFLFxuICBGTE9XQklURV9OQVZCQVJfSVNfUk9VTkRFRF9ERUZBVUxUX1ZBTFVFLFxuICBuYXZiYXJEZWZhdWx0VmFsdWVQcm92aWRlcixcbn0gZnJvbSAnLi9uYXZiYXIuY29tcG9uZW50JztcbmV4cG9ydCB0eXBlIHsgTmF2YmFyUHJvcGVydGllcywgTmF2YmFyQ2xhc3MsIE5hdmJhckNvbG9ycywgTmF2YmFyVGhlbWUgfSBmcm9tICcuL25hdmJhci50aGVtZSc7XG5leHBvcnQgeyBuYXZiYXJUaGVtZSB9IGZyb20gJy4vbmF2YmFyLnRoZW1lJztcbmV4cG9ydCB7IEZMT1dCSVRFX05BVkJBUl9USEVNRV9UT0tFTiwgTmF2YmFyVGhlbWVTZXJ2aWNlIH0gZnJvbSAnLi9uYXZiYXIudGhlbWUuc2VydmljZSc7XG5cbmV4cG9ydCB7XG4gIE5hdmJhckJyYW5kQ29tcG9uZW50LFxuICBGTE9XQklURV9OQVZCQVJfQlJBTkRfQ1VTVE9NX1NUWUxFX0RFRkFVTFRfVkFMVUUsXG4gIG5hdmJhckJyYW5kRGVmYXVsdFRoZW1lUHJvdmlkZXIsXG59IGZyb20gJy4vbmF2YmFyLWJyYW5kLmNvbXBvbmVudCc7XG5leHBvcnQgdHlwZSB7XG4gIE5hdmJhckJyYW5kUHJvcGVydGllcyxcbiAgTmF2YmFyQnJhbmRDbGFzcyxcbiAgTmF2YmFyQnJhbmRUaGVtZSxcbn0gZnJvbSAnLi9uYXZiYXItYnJhbmQudGhlbWUnO1xuZXhwb3J0IHsgbmF2YmFyQnJhbmRUaGVtZSB9IGZyb20gJy4vbmF2YmFyLWJyYW5kLnRoZW1lJztcbmV4cG9ydCB7XG4gIEZMT1dCSVRFX05BVkJBUl9CUkFORF9USEVNRV9UT0tFTixcbiAgTmF2YmFyQnJhbmRUaGVtZVNlcnZpY2UsXG59IGZyb20gJy4vbmF2YmFyLWJyYW5kLnRoZW1lLnNlcnZpY2UnO1xuXG5leHBvcnQge1xuICBOYXZiYXJDb250ZW50Q29tcG9uZW50LFxuICBGTE9XQklURV9OQVZCQVJfQ09OVEVOVF9DVVNUT01fU1RZTEVfREVGQVVMVF9WQUxVRSxcbiAgbmF2YmFyQ29udGVudERlZmF1bHRWYWx1ZVByb3ZpZGVyLFxufSBmcm9tICcuL25hdmJhci1jb250ZW50LmNvbXBvbmVudCc7XG5leHBvcnQgdHlwZSB7XG4gIE5hdmJhckNvbnRlbnRQcm9wZXJ0aWVzLFxuICBOYXZiYXJDb250ZW50Q2xhc3MsXG4gIE5hdmJhckNvbnRlbnRUaGVtZSxcbn0gZnJvbSAnLi9uYXZiYXItY29udGVudC50aGVtZSc7XG5leHBvcnQgeyBuYXZiYXJDb250ZW50VGhlbWUgfSBmcm9tICcuL25hdmJhci1jb250ZW50LnRoZW1lJztcbmV4cG9ydCB7XG4gIEZMT1dCSVRFX05BVkJBUl9DT05URU5UX1RIRU1FX1RPS0VOLFxuICBOYXZiYXJDb250ZW50VGhlbWVTZXJ2aWNlLFxufSBmcm9tICcuL25hdmJhci1jb250ZW50LnRoZW1lLnNlcnZpY2UnO1xuXG5leHBvcnQge1xuICBOYXZiYXJJdGVtQ29tcG9uZW50LFxuICBGTE9XQklURV9OQVZCQVJfSVRFTV9DVVNUT01fU1RZTEVfREVGQVVMVF9WQUxVRSxcbiAgbmF2YmFySXRlbURlZmF1bHRWYWx1ZVByb3ZpZGVyLFxufSBmcm9tICcuL25hdmJhci1pdGVtLmNvbXBvbmVudCc7XG5leHBvcnQgdHlwZSB7IE5hYnZhckl0ZW1Qcm9wZXJ0aWVzLCBOYXZiYXJJdGVtQ2xhc3MsIE5hdmJhckl0ZW1UaGVtZSB9IGZyb20gJy4vbmF2YmFyLWl0ZW0udGhlbWUnO1xuZXhwb3J0IHsgbmF2YmFySXRlbVRoZW1lIH0gZnJvbSAnLi9uYXZiYXItaXRlbS50aGVtZSc7XG5leHBvcnQge1xuICBGTE9XQklURV9OQVZCQVJfSVRFTV9USEVNRV9UT0tFTixcbiAgTmF2YmFySXRlbVRoZW1lU2VydmljZSxcbn0gZnJvbSAnLi9uYXZiYXItaXRlbS50aGVtZS5zZXJ2aWNlJztcblxuZXhwb3J0IHtcbiAgTmF2YmFyVG9nZ2xlQ29tcG9uZW50LFxuICBGTE9XQklURV9OQVZCQVJfVE9HR0xFX0NVU1RPTV9TVFlMRV9ERUZBVUxUX1ZBTFVFLFxuICBuYXZiYXJUb2dnbGVEZWZhdWx0VmFsdWVQcm92aWRlcixcbn0gZnJvbSAnLi9uYXZiYXItdG9nZ2xlLmNvbXBvbmVudCc7XG5leHBvcnQgdHlwZSB7XG4gIE5hdmJhclRvZ2dsZVRoZW1lLFxuICBOYXZiYXJUb2dnbGVDbGFzcyxcbiAgTmF2YmFyVG9nZ2xlUHJvcGVydGllcyxcbn0gZnJvbSAnLi9uYXZiYXItdG9nZ2xlLnRoZW1lJztcbmV4cG9ydCB7IG5hdmJhclRvZ2dsZVRoZW1lIH0gZnJvbSAnLi9uYXZiYXItdG9nZ2xlLnRoZW1lJztcbmV4cG9ydCB7XG4gIEZMT1dCSVRFX05BVkJBUl9UT0dHTEVfVEhFTUVfVE9LRU4sXG4gIE5hdmJhclRvZ2dsZVRoZW1lU2VydmljZSxcbn0gZnJvbSAnLi9uYXZiYXItdG9nZ2xlLnRoZW1lLnNlcnZpY2UnO1xuXG5leHBvcnQge1xuICBOYXZiYXJJY29uQnV0dG9uQ29tcG9uZW50LFxuICBGTE9XQklURV9OQVZCQVJfSUNPTl9CVVRUT05fQ1VTVE9NX1NUWUxFX0RFRkFVTFRfVkFMVUUsXG4gIG5hdmJhckljb25CdXR0b25EZWZhdWx0VmFsdWVQcm92aWRlcixcbn0gZnJvbSAnLi9uYXZiYXItaWNvbi1idXR0b24uY29tcG9uZW50JztcbmV4cG9ydCB0eXBlIHtcbiAgTmF2YmFySWNvbkJ1dHRvblByb3BlcnRpZXMsXG4gIE5hdmJhckljb25CdXR0b25DbGFzcyxcbiAgTmF2YmFySWNvbkJ1dHRvblRoZW1lLFxufSBmcm9tICcuL25hdmJhci1pY29uLWJ1dHRvbi50aGVtZSc7XG5leHBvcnQgeyBuYXZiYXJJY29uQnV0dG9uVGhlbWUgfSBmcm9tICcuL25hdmJhci1pY29uLWJ1dHRvbi50aGVtZSc7XG5leHBvcnQge1xuICBGTE9XQklURV9OQVZCQVJfSUNPTl9CVVRUT05fVEhFTUVfVE9LRU4sXG4gIE5hdmJhckljb25CdXR0b25UaGVtZVNlcnZpY2UsXG59IGZyb20gJy4vbmF2YmFyLWljb24tYnV0dG9uLnRoZW1lLnNlcnZpY2UnO1xuIl19
|
|
@@ -1,9 +1,15 @@
|
|
|
1
1
|
import { NavbarBrandThemeService } from './navbar-brand.theme.service';
|
|
2
2
|
import { NavbarComponent } from './navbar.component';
|
|
3
3
|
import { BaseComponent } from 'flowbite-angular';
|
|
4
|
-
import {
|
|
5
|
-
import { ChangeDetectionStrategy, Component, inject, model, ViewEncapsulation, } from '@angular/core';
|
|
4
|
+
import { ChangeDetectionStrategy, Component, inject, InjectionToken, makeEnvironmentProviders, model, ViewEncapsulation, } from '@angular/core';
|
|
6
5
|
import * as i0 from "@angular/core";
|
|
6
|
+
export const FLOWBITE_NAVBAR_BRAND_CUSTOM_STYLE_DEFAULT_VALUE = new InjectionToken('FLOWBITE_NAVBAR_BRAND_CUSTOM_STYLE_DEFAULT_VALUE');
|
|
7
|
+
export const navbarBrandDefaultThemeProvider = makeEnvironmentProviders([
|
|
8
|
+
{
|
|
9
|
+
provide: FLOWBITE_NAVBAR_BRAND_CUSTOM_STYLE_DEFAULT_VALUE,
|
|
10
|
+
useValue: {},
|
|
11
|
+
},
|
|
12
|
+
]);
|
|
7
13
|
/**
|
|
8
14
|
* @see https://flowbite.com/docs/components/navbar/
|
|
9
15
|
*/
|
|
@@ -22,7 +28,7 @@ export class NavbarBrandComponent extends BaseComponent {
|
|
|
22
28
|
/**
|
|
23
29
|
* Set the custom style for this navbar brand
|
|
24
30
|
*/
|
|
25
|
-
this.customStyle = model(
|
|
31
|
+
this.customStyle = model(inject(FLOWBITE_NAVBAR_BRAND_CUSTOM_STYLE_DEFAULT_VALUE));
|
|
26
32
|
}
|
|
27
33
|
//#endregion
|
|
28
34
|
//#region BaseComponent implementation
|
|
@@ -39,10 +45,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
|
|
|
39
45
|
args: [{
|
|
40
46
|
selector: 'flowbite-navbar-brand',
|
|
41
47
|
standalone: true,
|
|
42
|
-
imports: [NgClass],
|
|
43
48
|
template: `<ng-content />`,
|
|
44
49
|
encapsulation: ViewEncapsulation.None,
|
|
45
50
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
46
51
|
}]
|
|
47
52
|
}] });
|
|
48
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2YmFyLWJyYW5kLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvZmxvd2JpdGUtYW5ndWxhci9uYXZiYXIvbmF2YmFyLWJyYW5kLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUN2RSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFHckQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBRWpELE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULE1BQU0sRUFDTixjQUFjLEVBQ2Qsd0JBQXdCLEVBQ3hCLEtBQUssRUFDTCxpQkFBaUIsR0FDbEIsTUFBTSxlQUFlLENBQUM7O0FBRXZCLE1BQU0sQ0FBQyxNQUFNLGdEQUFnRCxHQUFHLElBQUksY0FBYyxDQUVoRixrREFBa0QsQ0FBQyxDQUFDO0FBRXRELE1BQU0sQ0FBQyxNQUFNLCtCQUErQixHQUFHLHdCQUF3QixDQUFDO0lBQ3RFO1FBQ0UsT0FBTyxFQUFFLGdEQUFnRDtRQUN6RCxRQUFRLEVBQUUsRUFBRTtLQUNiO0NBQ0YsQ0FBQyxDQUFDO0FBRUg7O0dBRUc7QUFRSCxNQUFNLE9BQU8sb0JBQXFCLFNBQVEsYUFBK0I7SUFQekU7O1FBUUU7O1dBRUc7UUFDYSxpQkFBWSxHQUFHLE1BQU0sQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDO1FBQy9EOztXQUVHO1FBQ2Esb0JBQWUsR0FBRyxNQUFNLENBQUMsZUFBZSxDQUFDLENBQUM7UUFFMUQsb0JBQW9CO1FBQ3BCOztXQUVHO1FBQ0ksZ0JBQVcsR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDLGdEQUFnRCxDQUFDLENBQUMsQ0FBQztLQVV0RjtJQVRDLFlBQVk7SUFFWixzQ0FBc0M7SUFDdEIsVUFBVTtRQUN4QixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsVUFBVSxDQUFDO1lBQ2xDLFdBQVcsRUFBRSxJQUFJLENBQUMsV0FBVyxFQUFFO1NBQ2hDLENBQUMsQ0FBQztJQUNMLENBQUM7OEdBdEJVLG9CQUFvQjtrR0FBcEIsb0JBQW9CLDZTQUpyQixnQkFBZ0I7OzJGQUlmLG9CQUFvQjtrQkFQaEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsdUJBQXVCO29CQUNqQyxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFLGdCQUFnQjtvQkFDMUIsYUFBYSxFQUFFLGlCQUFpQixDQUFDLElBQUk7b0JBQ3JDLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO2lCQUNoRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgTmF2YmFyQnJhbmRDbGFzcywgTmF2YmFyQnJhbmRUaGVtZSB9IGZyb20gJy4vbmF2YmFyLWJyYW5kLnRoZW1lJztcbmltcG9ydCB7IE5hdmJhckJyYW5kVGhlbWVTZXJ2aWNlIH0gZnJvbSAnLi9uYXZiYXItYnJhbmQudGhlbWUuc2VydmljZSc7XG5pbXBvcnQgeyBOYXZiYXJDb21wb25lbnQgfSBmcm9tICcuL25hdmJhci5jb21wb25lbnQnO1xuXG5pbXBvcnQgdHlwZSB7IERlZXBQYXJ0aWFsIH0gZnJvbSAnZmxvd2JpdGUtYW5ndWxhcic7XG5pbXBvcnQgeyBCYXNlQ29tcG9uZW50IH0gZnJvbSAnZmxvd2JpdGUtYW5ndWxhcic7XG5cbmltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIGluamVjdCxcbiAgSW5qZWN0aW9uVG9rZW4sXG4gIG1ha2VFbnZpcm9ubWVudFByb3ZpZGVycyxcbiAgbW9kZWwsXG4gIFZpZXdFbmNhcHN1bGF0aW9uLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuZXhwb3J0IGNvbnN0IEZMT1dCSVRFX05BVkJBUl9CUkFORF9DVVNUT01fU1RZTEVfREVGQVVMVF9WQUxVRSA9IG5ldyBJbmplY3Rpb25Ub2tlbjxcbiAgRGVlcFBhcnRpYWw8TmF2YmFyQnJhbmRUaGVtZT5cbj4oJ0ZMT1dCSVRFX05BVkJBUl9CUkFORF9DVVNUT01fU1RZTEVfREVGQVVMVF9WQUxVRScpO1xuXG5leHBvcnQgY29uc3QgbmF2YmFyQnJhbmREZWZhdWx0VGhlbWVQcm92aWRlciA9IG1ha2VFbnZpcm9ubWVudFByb3ZpZGVycyhbXG4gIHtcbiAgICBwcm92aWRlOiBGTE9XQklURV9OQVZCQVJfQlJBTkRfQ1VTVE9NX1NUWUxFX0RFRkFVTFRfVkFMVUUsXG4gICAgdXNlVmFsdWU6IHt9LFxuICB9LFxuXSk7XG5cbi8qKlxuICogQHNlZSBodHRwczovL2Zsb3diaXRlLmNvbS9kb2NzL2NvbXBvbmVudHMvbmF2YmFyL1xuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdmbG93Yml0ZS1uYXZiYXItYnJhbmQnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICB0ZW1wbGF0ZTogYDxuZy1jb250ZW50IC8+YCxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIE5hdmJhckJyYW5kQ29tcG9uZW50IGV4dGVuZHMgQmFzZUNvbXBvbmVudDxOYXZiYXJCcmFuZENsYXNzPiB7XG4gIC8qKlxuICAgKiBTZXJ2aWNlIGluamVjdGVkIHVzZWQgdG8gZ2VuZXJhdGUgY2xhc3NcbiAgICovXG4gIHB1YmxpYyByZWFkb25seSB0aGVtZVNlcnZpY2UgPSBpbmplY3QoTmF2YmFyQnJhbmRUaGVtZVNlcnZpY2UpO1xuICAvKipcbiAgICogVGhlIHBhcmVudCBgTmF2YmFyQ29tcG9uZW50YFxuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IG5hdmJhckNvbXBvbmVudCA9IGluamVjdChOYXZiYXJDb21wb25lbnQpO1xuXG4gIC8vI3JlZ2lvbiBwcm9wZXJ0aWVzXG4gIC8qKlxuICAgKiBTZXQgdGhlIGN1c3RvbSBzdHlsZSBmb3IgdGhpcyBuYXZiYXIgYnJhbmRcbiAgICovXG4gIHB1YmxpYyBjdXN0b21TdHlsZSA9IG1vZGVsKGluamVjdChGTE9XQklURV9OQVZCQVJfQlJBTkRfQ1VTVE9NX1NUWUxFX0RFRkFVTFRfVkFMVUUpKTtcbiAgLy8jZW5kcmVnaW9uXG5cbiAgLy8jcmVnaW9uIEJhc2VDb21wb25lbnQgaW1wbGVtZW50YXRpb25cbiAgcHVibGljIG92ZXJyaWRlIGZldGNoQ2xhc3MoKTogTmF2YmFyQnJhbmRDbGFzcyB7XG4gICAgcmV0dXJuIHRoaXMudGhlbWVTZXJ2aWNlLmdldENsYXNzZXMoe1xuICAgICAgY3VzdG9tU3R5bGU6IHRoaXMuY3VzdG9tU3R5bGUoKSxcbiAgICB9KTtcbiAgfVxuICAvLyNlbmRyZWdpb25cbn1cbiJdfQ==
|
|
@@ -1,9 +1,16 @@
|
|
|
1
1
|
import { NavbarContentThemeService } from './navbar-content.theme.service';
|
|
2
2
|
import { NavbarComponent } from './navbar.component';
|
|
3
|
-
import { BaseComponent
|
|
4
|
-
import {
|
|
5
|
-
import { ChangeDetectionStrategy, Component, inject, model, ViewEncapsulation, } from '@angular/core';
|
|
3
|
+
import { BaseComponent } from 'flowbite-angular';
|
|
4
|
+
import { animate, state, style, transition, trigger } from '@angular/animations';
|
|
5
|
+
import { ChangeDetectionStrategy, Component, inject, InjectionToken, makeEnvironmentProviders, model, ViewEncapsulation, } from '@angular/core';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
|
+
export const FLOWBITE_NAVBAR_CONTENT_CUSTOM_STYLE_DEFAULT_VALUE = new InjectionToken('FLOWBITE_NAVBAR_CONTENT_CUSTOM_STYLE_DEFAULT_VALUE');
|
|
8
|
+
export const navbarContentDefaultValueProvider = makeEnvironmentProviders([
|
|
9
|
+
{
|
|
10
|
+
provide: FLOWBITE_NAVBAR_CONTENT_CUSTOM_STYLE_DEFAULT_VALUE,
|
|
11
|
+
useValue: {},
|
|
12
|
+
},
|
|
13
|
+
]);
|
|
7
14
|
/**
|
|
8
15
|
* @see https://flowbite.com/docs/components/navbar/
|
|
9
16
|
*/
|
|
@@ -25,36 +32,53 @@ export class NavbarContentComponent extends BaseComponent {
|
|
|
25
32
|
* @default `NavbarComponent`'s color
|
|
26
33
|
*/
|
|
27
34
|
this.color = model(this.navbarComponent().color());
|
|
28
|
-
|
|
35
|
+
/**
|
|
36
|
+
* Set the custom style for this navbar content
|
|
37
|
+
*/
|
|
38
|
+
this.customStyle = model(inject(FLOWBITE_NAVBAR_CONTENT_CUSTOM_STYLE_DEFAULT_VALUE));
|
|
29
39
|
}
|
|
30
40
|
//#endregion
|
|
31
41
|
//#region BaseComponent implementation
|
|
32
42
|
fetchClass() {
|
|
33
43
|
return this.themeService.getClasses({
|
|
34
|
-
isOpen: booleanToFlowbiteBoolean(this.navbarComponent().isOpen()),
|
|
35
44
|
customStyle: this.customStyle(),
|
|
36
45
|
});
|
|
37
46
|
}
|
|
38
47
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: NavbarContentComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
39
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.0.0", type: NavbarContentComponent, isStandalone: true, selector: "flowbite-navbar-content", inputs: { navbarComponent: { classPropertyName: "navbarComponent", publicName: "navbarComponent", isSignal: true, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, customStyle: { classPropertyName: "customStyle", publicName: "customStyle", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { navbarComponent: "navbarComponentChange", color: "colorChange", customStyle: "customStyleChange" }, usesInheritance: true, ngImport: i0, template: `
|
|
40
|
-
<div [
|
|
48
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.0.0", type: NavbarContentComponent, isStandalone: true, selector: "flowbite-navbar-content", inputs: { navbarComponent: { classPropertyName: "navbarComponent", publicName: "navbarComponent", isSignal: true, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, customStyle: { classPropertyName: "customStyle", publicName: "customStyle", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { navbarComponent: "navbarComponentChange", color: "colorChange", customStyle: "customStyleChange" }, host: { properties: { "@isOpenAnimation": "navbarComponent().isOpen()" } }, usesInheritance: true, ngImport: i0, template: `
|
|
49
|
+
<div [class]="contentClasses().navbarContentListClass">
|
|
41
50
|
<ng-content />
|
|
42
51
|
</div>
|
|
43
|
-
`, isInline: true,
|
|
52
|
+
`, isInline: true, animations: [
|
|
53
|
+
trigger('isOpenAnimation', [
|
|
54
|
+
state('true', style({ height: '*' })),
|
|
55
|
+
state('false', style({ height: '0px' })),
|
|
56
|
+
transition('true <=> false', animate('300ms')),
|
|
57
|
+
]),
|
|
58
|
+
], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
44
59
|
}
|
|
45
60
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: NavbarContentComponent, decorators: [{
|
|
46
61
|
type: Component,
|
|
47
62
|
args: [{
|
|
48
63
|
selector: 'flowbite-navbar-content',
|
|
49
64
|
standalone: true,
|
|
50
|
-
imports: [NgClass],
|
|
51
65
|
template: `
|
|
52
|
-
<div [
|
|
66
|
+
<div [class]="contentClasses().navbarContentListClass">
|
|
53
67
|
<ng-content />
|
|
54
68
|
</div>
|
|
55
69
|
`,
|
|
70
|
+
host: {
|
|
71
|
+
'[@isOpenAnimation]': 'navbarComponent().isOpen()',
|
|
72
|
+
},
|
|
73
|
+
animations: [
|
|
74
|
+
trigger('isOpenAnimation', [
|
|
75
|
+
state('true', style({ height: '*' })),
|
|
76
|
+
state('false', style({ height: '0px' })),
|
|
77
|
+
transition('true <=> false', animate('300ms')),
|
|
78
|
+
]),
|
|
79
|
+
],
|
|
56
80
|
encapsulation: ViewEncapsulation.None,
|
|
57
81
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
58
82
|
}]
|
|
59
83
|
}] });
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2YmFyLWNvbnRlbnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9mbG93Yml0ZS1hbmd1bGFyL25hdmJhci9uYXZiYXItY29udGVudC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDM0UsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBSXJELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUVqRCxPQUFPLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsVUFBVSxFQUFFLE9BQU8sRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBRWpGLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULE1BQU0sRUFDTixjQUFjLEVBQ2Qsd0JBQXdCLEVBQ3hCLEtBQUssRUFDTCxpQkFBaUIsR0FDbEIsTUFBTSxlQUFlLENBQUM7O0FBRXZCLE1BQU0sQ0FBQyxNQUFNLGtEQUFrRCxHQUFHLElBQUksY0FBYyxDQUVsRixvREFBb0QsQ0FBQyxDQUFDO0FBRXhELE1BQU0sQ0FBQyxNQUFNLGlDQUFpQyxHQUFHLHdCQUF3QixDQUFDO0lBQ3hFO1FBQ0UsT0FBTyxFQUFFLGtEQUFrRDtRQUMzRCxRQUFRLEVBQUUsRUFBRTtLQUNiO0NBQ0YsQ0FBQyxDQUFDO0FBRUg7O0dBRUc7QUFzQkgsTUFBTSxPQUFPLHNCQUF1QixTQUFRLGFBQWlDO0lBckI3RTs7UUFzQkU7O1dBRUc7UUFDYSxpQkFBWSxHQUFHLE1BQU0sQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO1FBQ2pFOztXQUVHO1FBQ2Esb0JBQWUsR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDLGVBQWUsQ0FBQyxDQUFDLENBQUM7UUFFakUsb0JBQW9CO1FBQ3BCOzs7O1dBSUc7UUFDSSxVQUFLLEdBQUcsS0FBSyxDQUFxQixJQUFJLENBQUMsZUFBZSxFQUFFLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztRQUN6RTs7V0FFRztRQUNJLGdCQUFXLEdBQUcsS0FBSyxDQUFDLE1BQU0sQ0FBQyxrREFBa0QsQ0FBQyxDQUFDLENBQUM7S0FVeEY7SUFUQyxZQUFZO0lBRVosc0NBQXNDO0lBQ3RCLFVBQVU7UUFDeEIsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLFVBQVUsQ0FBQztZQUNsQyxXQUFXLEVBQUUsSUFBSSxDQUFDLFdBQVcsRUFBRTtTQUNoQyxDQUFDLENBQUM7SUFDTCxDQUFDOzhHQTVCVSxzQkFBc0I7a0dBQXRCLHNCQUFzQix5c0JBbEJ2Qjs7OztHQUlULDhCQUlXO1lBQ1YsT0FBTyxDQUFDLGlCQUFpQixFQUFFO2dCQUN6QixLQUFLLENBQUMsTUFBTSxFQUFFLEtBQUssQ0FBQyxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDO2dCQUNyQyxLQUFLLENBQUMsT0FBTyxFQUFFLEtBQUssQ0FBQyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDO2dCQUN4QyxVQUFVLENBQUMsZ0JBQWdCLEVBQUUsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDO2FBQy9DLENBQUM7U0FDSDs7MkZBSVUsc0JBQXNCO2tCQXJCbEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUseUJBQXlCO29CQUNuQyxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFOzs7O0dBSVQ7b0JBQ0QsSUFBSSxFQUFFO3dCQUNKLG9CQUFvQixFQUFFLDRCQUE0QjtxQkFDbkQ7b0JBQ0QsVUFBVSxFQUFFO3dCQUNWLE9BQU8sQ0FBQyxpQkFBaUIsRUFBRTs0QkFDekIsS0FBSyxDQUFDLE1BQU0sRUFBRSxLQUFLLENBQUMsRUFBRSxNQUFNLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQzs0QkFDckMsS0FBSyxDQUFDLE9BQU8sRUFBRSxLQUFLLENBQUMsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQzs0QkFDeEMsVUFBVSxDQUFDLGdCQUFnQixFQUFFLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQzt5QkFDL0MsQ0FBQztxQkFDSDtvQkFDRCxhQUFhLEVBQUUsaUJBQWlCLENBQUMsSUFBSTtvQkFDckMsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07aUJBQ2hEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBOYXZiYXJDb250ZW50Q2xhc3MsIE5hdmJhckNvbnRlbnRUaGVtZSB9IGZyb20gJy4vbmF2YmFyLWNvbnRlbnQudGhlbWUnO1xuaW1wb3J0IHsgTmF2YmFyQ29udGVudFRoZW1lU2VydmljZSB9IGZyb20gJy4vbmF2YmFyLWNvbnRlbnQudGhlbWUuc2VydmljZSc7XG5pbXBvcnQgeyBOYXZiYXJDb21wb25lbnQgfSBmcm9tICcuL25hdmJhci5jb21wb25lbnQnO1xuaW1wb3J0IHR5cGUgeyBOYXZiYXJDb2xvcnMgfSBmcm9tICcuL25hdmJhci50aGVtZSc7XG5cbmltcG9ydCB0eXBlIHsgRGVlcFBhcnRpYWwgfSBmcm9tICdmbG93Yml0ZS1hbmd1bGFyJztcbmltcG9ydCB7IEJhc2VDb21wb25lbnQgfSBmcm9tICdmbG93Yml0ZS1hbmd1bGFyJztcblxuaW1wb3J0IHsgYW5pbWF0ZSwgc3RhdGUsIHN0eWxlLCB0cmFuc2l0aW9uLCB0cmlnZ2VyIH0gZnJvbSAnQGFuZ3VsYXIvYW5pbWF0aW9ucyc7XG5pbXBvcnQgdHlwZSB7IE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgaW5qZWN0LFxuICBJbmplY3Rpb25Ub2tlbixcbiAgbWFrZUVudmlyb25tZW50UHJvdmlkZXJzLFxuICBtb2RlbCxcbiAgVmlld0VuY2Fwc3VsYXRpb24sXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgY29uc3QgRkxPV0JJVEVfTkFWQkFSX0NPTlRFTlRfQ1VTVE9NX1NUWUxFX0RFRkFVTFRfVkFMVUUgPSBuZXcgSW5qZWN0aW9uVG9rZW48XG4gIERlZXBQYXJ0aWFsPE5hdmJhckNvbnRlbnRUaGVtZT5cbj4oJ0ZMT1dCSVRFX05BVkJBUl9DT05URU5UX0NVU1RPTV9TVFlMRV9ERUZBVUxUX1ZBTFVFJyk7XG5cbmV4cG9ydCBjb25zdCBuYXZiYXJDb250ZW50RGVmYXVsdFZhbHVlUHJvdmlkZXIgPSBtYWtlRW52aXJvbm1lbnRQcm92aWRlcnMoW1xuICB7XG4gICAgcHJvdmlkZTogRkxPV0JJVEVfTkFWQkFSX0NPTlRFTlRfQ1VTVE9NX1NUWUxFX0RFRkFVTFRfVkFMVUUsXG4gICAgdXNlVmFsdWU6IHt9LFxuICB9LFxuXSk7XG5cbi8qKlxuICogQHNlZSBodHRwczovL2Zsb3diaXRlLmNvbS9kb2NzL2NvbXBvbmVudHMvbmF2YmFyL1xuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdmbG93Yml0ZS1uYXZiYXItY29udGVudCcsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHRlbXBsYXRlOiBgXG4gICAgPGRpdiBbY2xhc3NdPVwiY29udGVudENsYXNzZXMoKS5uYXZiYXJDb250ZW50TGlzdENsYXNzXCI+XG4gICAgICA8bmctY29udGVudCAvPlxuICAgIDwvZGl2PlxuICBgLFxuICBob3N0OiB7XG4gICAgJ1tAaXNPcGVuQW5pbWF0aW9uXSc6ICduYXZiYXJDb21wb25lbnQoKS5pc09wZW4oKScsXG4gIH0sXG4gIGFuaW1hdGlvbnM6IFtcbiAgICB0cmlnZ2VyKCdpc09wZW5BbmltYXRpb24nLCBbXG4gICAgICBzdGF0ZSgndHJ1ZScsIHN0eWxlKHsgaGVpZ2h0OiAnKicgfSkpLFxuICAgICAgc3RhdGUoJ2ZhbHNlJywgc3R5bGUoeyBoZWlnaHQ6ICcwcHgnIH0pKSxcbiAgICAgIHRyYW5zaXRpb24oJ3RydWUgPD0+IGZhbHNlJywgYW5pbWF0ZSgnMzAwbXMnKSksXG4gICAgXSksXG4gIF0sXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBOYXZiYXJDb250ZW50Q29tcG9uZW50IGV4dGVuZHMgQmFzZUNvbXBvbmVudDxOYXZiYXJDb250ZW50Q2xhc3M+IGltcGxlbWVudHMgT25Jbml0IHtcbiAgLyoqXG4gICAqIFNlcnZpY2UgaW5qZWN0ZWQgdXNlZCB0byBnZW5lcmF0ZSBjbGFzc1xuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IHRoZW1lU2VydmljZSA9IGluamVjdChOYXZiYXJDb250ZW50VGhlbWVTZXJ2aWNlKTtcbiAgLyoqXG4gICAqIFRoZSBwYXJlbnQgYE5hdmJhckNvbXBvbmVudGBcbiAgICovXG4gIHB1YmxpYyByZWFkb25seSBuYXZiYXJDb21wb25lbnQgPSBtb2RlbChpbmplY3QoTmF2YmFyQ29tcG9uZW50KSk7XG5cbiAgLy8jcmVnaW9uIHByb3BlcnRpZXNcbiAgLyoqXG4gICAqIFNldCB0aGUgbmF2YmFyIGNvbnRlbnQgY29sb3JcbiAgICpcbiAgICogQGRlZmF1bHQgYE5hdmJhckNvbXBvbmVudGAncyBjb2xvclxuICAgKi9cbiAgcHVibGljIGNvbG9yID0gbW9kZWw8a2V5b2YgTmF2YmFyQ29sb3JzPih0aGlzLm5hdmJhckNvbXBvbmVudCgpLmNvbG9yKCkpO1xuICAvKipcbiAgICogU2V0IHRoZSBjdXN0b20gc3R5bGUgZm9yIHRoaXMgbmF2YmFyIGNvbnRlbnRcbiAgICovXG4gIHB1YmxpYyBjdXN0b21TdHlsZSA9IG1vZGVsKGluamVjdChGTE9XQklURV9OQVZCQVJfQ09OVEVOVF9DVVNUT01fU1RZTEVfREVGQVVMVF9WQUxVRSkpO1xuICAvLyNlbmRyZWdpb25cblxuICAvLyNyZWdpb24gQmFzZUNvbXBvbmVudCBpbXBsZW1lbnRhdGlvblxuICBwdWJsaWMgb3ZlcnJpZGUgZmV0Y2hDbGFzcygpOiBOYXZiYXJDb250ZW50Q2xhc3Mge1xuICAgIHJldHVybiB0aGlzLnRoZW1lU2VydmljZS5nZXRDbGFzc2VzKHtcbiAgICAgIGN1c3RvbVN0eWxlOiB0aGlzLmN1c3RvbVN0eWxlKCksXG4gICAgfSk7XG4gIH1cbiAgLy8jZW5kcmVnaW9uXG59XG4iXX0=
|
|
@@ -4,14 +4,10 @@ import { createTheme } from 'flowbite-angular/utils';
|
|
|
4
4
|
*/
|
|
5
5
|
export const navbarContentTheme = createTheme({
|
|
6
6
|
root: {
|
|
7
|
-
base: 'w-full md
|
|
8
|
-
isOpen: {
|
|
9
|
-
enabled: '',
|
|
10
|
-
disabled: 'hidden',
|
|
11
|
-
},
|
|
7
|
+
base: 'w-full md:!h-fit md:w-auto order-last md:order-none overflow-hidden',
|
|
12
8
|
},
|
|
13
9
|
list: {
|
|
14
10
|
base: 'font-medium flex flex-col p-4 md:p-0 mt-4 items-center border border-gray-100 rounded-lg bg-gray-50 md:flex-row md:space-x-8 rtl:space-x-reverse md:mt-0 md:border-0 md:bg-white dark:bg-gray-900 md:dark:bg-gray-800 dark:border-gray-700',
|
|
15
11
|
},
|
|
16
12
|
});
|
|
17
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2YmFyLWNvbnRlbnQudGhlbWUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2Zsb3diaXRlLWFuZ3VsYXIvbmF2YmFyL25hdmJhci1jb250ZW50LnRoZW1lLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQXFCckQ7O0dBRUc7QUFDSCxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBdUIsV0FBVyxDQUFDO0lBQ2hFLElBQUksRUFBRTtRQUNKLElBQUksRUFBRSxxRUFBcUU7S0FDNUU7SUFDRCxJQUFJLEVBQUU7UUFDSixJQUFJLEVBQUUsNE9BQTRPO0tBQ25QO0NBQ0YsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBEZWVwUGFydGlhbCwgRmxvd2JpdGVDbGFzcyB9IGZyb20gJ2Zsb3diaXRlLWFuZ3VsYXInO1xuaW1wb3J0IHsgY3JlYXRlVGhlbWUgfSBmcm9tICdmbG93Yml0ZS1hbmd1bGFyL3V0aWxzJztcblxuLyoqXG4gKiBSZXF1aXJlZCBwcm9wZXJ0aWVzIGZvciB0aGUgY2xhc3MgZ2VuZXJhdGlvbiBvZiBgTmF2YmFyQ29udGVudENvbXBvbmVudGBcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBOYXZiYXJDb250ZW50UHJvcGVydGllcyB7XG4gIGN1c3RvbVN0eWxlOiBEZWVwUGFydGlhbDxOYXZiYXJDb250ZW50VGhlbWU+O1xufVxuXG4vKipcbiAqIFRoZW1lIGRlZmluaXRpb24gZm9yIGBOYXZiYXJDb250ZW50Q29tcG9uZW50YFxuICovXG5leHBvcnQgaW50ZXJmYWNlIE5hdmJhckNvbnRlbnRUaGVtZSB7XG4gIHJvb3Q6IHtcbiAgICBiYXNlOiBzdHJpbmc7XG4gIH07XG4gIGxpc3Q6IHtcbiAgICBiYXNlOiBzdHJpbmc7XG4gIH07XG59XG5cbi8qKlxuICogRGVmYXVsdCB0aGVtZSBmb3IgYE5hdmJhckNvbnRlbnRDb21wb25lbnRgXG4gKi9cbmV4cG9ydCBjb25zdCBuYXZiYXJDb250ZW50VGhlbWU6IE5hdmJhckNvbnRlbnRUaGVtZSA9IGNyZWF0ZVRoZW1lKHtcbiAgcm9vdDoge1xuICAgIGJhc2U6ICd3LWZ1bGwgbWQ6IWgtZml0IG1kOnctYXV0byBvcmRlci1sYXN0IG1kOm9yZGVyLW5vbmUgb3ZlcmZsb3ctaGlkZGVuJyxcbiAgfSxcbiAgbGlzdDoge1xuICAgIGJhc2U6ICdmb250LW1lZGl1bSBmbGV4IGZsZXgtY29sIHAtNCBtZDpwLTAgbXQtNCBpdGVtcy1jZW50ZXIgYm9yZGVyIGJvcmRlci1ncmF5LTEwMCByb3VuZGVkLWxnIGJnLWdyYXktNTAgbWQ6ZmxleC1yb3cgbWQ6c3BhY2UteC04IHJ0bDpzcGFjZS14LXJldmVyc2UgbWQ6bXQtMCBtZDpib3JkZXItMCBtZDpiZy13aGl0ZSBkYXJrOmJnLWdyYXktOTAwIG1kOmRhcms6YmctZ3JheS04MDAgZGFyazpib3JkZXItZ3JheS03MDAnLFxuICB9LFxufSk7XG5cbi8qKlxuICogR2VuZXJhdGVkIGNsYXNzIGRlZmluaXRpb24gZm9yIGBOYXZiYXJDb250ZW50Q29tcG9uZW50YFxuICovXG5leHBvcnQgaW50ZXJmYWNlIE5hdmJhckNvbnRlbnRDbGFzcyBleHRlbmRzIEZsb3diaXRlQ2xhc3Mge1xuICBuYXZiYXJDb250ZW50TGlzdENsYXNzOiBzdHJpbmc7XG59XG4iXX0=
|
|
@@ -18,7 +18,7 @@ export class NavbarContentThemeService {
|
|
|
18
18
|
getClasses(properties) {
|
|
19
19
|
const theme = mergeTheme(this.baseTheme, properties.customStyle);
|
|
20
20
|
const output = {
|
|
21
|
-
rootClass: twMerge(theme.root.base
|
|
21
|
+
rootClass: twMerge(theme.root.base),
|
|
22
22
|
navbarContentListClass: twMerge(theme.list.base),
|
|
23
23
|
};
|
|
24
24
|
return output;
|
|
@@ -32,4 +32,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
|
|
|
32
32
|
providedIn: 'root',
|
|
33
33
|
}]
|
|
34
34
|
}] });
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2YmFyLWNvbnRlbnQudGhlbWUuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvZmxvd2JpdGUtYW5ndWxhci9uYXZiYXIvbmF2YmFyLWNvbnRlbnQudGhlbWUuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFPQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFFcEQsT0FBTyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25FLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7QUFFekM7Ozs7Ozs7R0FPRztBQUNILE1BQU0sQ0FBQyxNQUFNLG1DQUFtQyxHQUFHLElBQUksY0FBYyxDQUNuRSxxQ0FBcUMsQ0FDdEMsQ0FBQztBQUtGLE1BQU0sT0FBTyx5QkFBeUI7SUFIdEM7UUFJbUIsY0FBUyxHQUFHLE1BQU0sQ0FBQyxtQ0FBbUMsQ0FBQyxDQUFDO0tBWTFFO0lBVlEsVUFBVSxDQUFDLFVBQW1DO1FBQ25ELE1BQU0sS0FBSyxHQUF1QixVQUFVLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxVQUFVLENBQUMsV0FBVyxDQUFDLENBQUM7UUFFckYsTUFBTSxNQUFNLEdBQXVCO1lBQ2pDLFNBQVMsRUFBRSxPQUFPLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUM7WUFDbkMsc0JBQXNCLEVBQUUsT0FBTyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDO1NBQ2pELENBQUM7UUFFRixPQUFPLE1BQU0sQ0FBQztJQUNoQixDQUFDOzhHQVpVLHlCQUF5QjtrSEFBekIseUJBQXlCLGNBRnhCLE1BQU07OzJGQUVQLHlCQUF5QjtrQkFIckMsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7XG4gIE5hdmJhckNvbnRlbnRDbGFzcyxcbiAgTmF2YmFyQ29udGVudFByb3BlcnRpZXMsXG4gIE5hdmJhckNvbnRlbnRUaGVtZSxcbn0gZnJvbSAnLi9uYXZiYXItY29udGVudC50aGVtZSc7XG5cbmltcG9ydCB0eXBlIHsgRmxvd2JpdGVUaGVtZVNlcnZpY2UgfSBmcm9tICdmbG93Yml0ZS1hbmd1bGFyJztcbmltcG9ydCB7IG1lcmdlVGhlbWUgfSBmcm9tICdmbG93Yml0ZS1hbmd1bGFyL3V0aWxzJztcblxuaW1wb3J0IHsgaW5qZWN0LCBJbmplY3RhYmxlLCBJbmplY3Rpb25Ub2tlbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgdHdNZXJnZSB9IGZyb20gJ3RhaWx3aW5kLW1lcmdlJztcblxuLyoqXG4gKiBgSW5qZWN0aW9uVG9rZW5gIHVzZWQgdG8gaW1wb3J0IGBOYXZiYXJDb250ZW50VGhlbWVgIHZhbHVlXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYFxuICogdmFyIHRoZW1lID0gaW5qZWN0KEZMT1dCSVRFX05BVkJBUl9DT05URU5UX1RIRU1FX1RPS0VOKVxuICogYGBgXG4gKi9cbmV4cG9ydCBjb25zdCBGTE9XQklURV9OQVZCQVJfQ09OVEVOVF9USEVNRV9UT0tFTiA9IG5ldyBJbmplY3Rpb25Ub2tlbjxOYXZiYXJDb250ZW50VGhlbWU+KFxuICAnRkxPV0JJVEVfTkFWQkFSX0NPTlRFTlRfVEhFTUVfVE9LRU4nXG4pO1xuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5leHBvcnQgY2xhc3MgTmF2YmFyQ29udGVudFRoZW1lU2VydmljZSBpbXBsZW1lbnRzIEZsb3diaXRlVGhlbWVTZXJ2aWNlPE5hdmJhckNvbnRlbnRQcm9wZXJ0aWVzPiB7XG4gIHByaXZhdGUgcmVhZG9ubHkgYmFzZVRoZW1lID0gaW5qZWN0KEZMT1dCSVRFX05BVkJBUl9DT05URU5UX1RIRU1FX1RPS0VOKTtcblxuICBwdWJsaWMgZ2V0Q2xhc3Nlcyhwcm9wZXJ0aWVzOiBOYXZiYXJDb250ZW50UHJvcGVydGllcyk6IE5hdmJhckNvbnRlbnRDbGFzcyB7XG4gICAgY29uc3QgdGhlbWU6IE5hdmJhckNvbnRlbnRUaGVtZSA9IG1lcmdlVGhlbWUodGhpcy5iYXNlVGhlbWUsIHByb3BlcnRpZXMuY3VzdG9tU3R5bGUpO1xuXG4gICAgY29uc3Qgb3V0cHV0OiBOYXZiYXJDb250ZW50Q2xhc3MgPSB7XG4gICAgICByb290Q2xhc3M6IHR3TWVyZ2UodGhlbWUucm9vdC5iYXNlKSxcbiAgICAgIG5hdmJhckNvbnRlbnRMaXN0Q2xhc3M6IHR3TWVyZ2UodGhlbWUubGlzdC5iYXNlKSxcbiAgICB9O1xuXG4gICAgcmV0dXJuIG91dHB1dDtcbiAgfVxufVxuIl19
|
|
@@ -2,8 +2,15 @@ import { NavbarContentComponent } from './navbar-content.component';
|
|
|
2
2
|
import { NavbarIconButtonThemeService } from './navbar-icon-button.theme.service';
|
|
3
3
|
import { NavbarComponent } from './navbar.component';
|
|
4
4
|
import { BaseComponent } from 'flowbite-angular';
|
|
5
|
-
import { ChangeDetectionStrategy, Component, inject, model, ViewEncapsulation, } from '@angular/core';
|
|
5
|
+
import { ChangeDetectionStrategy, Component, inject, InjectionToken, makeEnvironmentProviders, model, ViewEncapsulation, } from '@angular/core';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
|
+
export const FLOWBITE_NAVBAR_ICON_BUTTON_CUSTOM_STYLE_DEFAULT_VALUE = new InjectionToken('FLOWBITE_NAVBAR_ICON_BUTTON_CUSTOM_STYLE_DEFAULT_VALUE');
|
|
8
|
+
export const navbarIconButtonDefaultValueProvider = makeEnvironmentProviders([
|
|
9
|
+
{
|
|
10
|
+
provide: FLOWBITE_NAVBAR_ICON_BUTTON_CUSTOM_STYLE_DEFAULT_VALUE,
|
|
11
|
+
useValue: {},
|
|
12
|
+
},
|
|
13
|
+
]);
|
|
7
14
|
/**
|
|
8
15
|
* @see https://flowbite.com/docs/components/navbar/
|
|
9
16
|
*/
|
|
@@ -33,7 +40,7 @@ export class NavbarIconButtonComponent extends BaseComponent {
|
|
|
33
40
|
/**
|
|
34
41
|
* Set the custom style for this navbar icon button
|
|
35
42
|
*/
|
|
36
|
-
this.customStyle = model(
|
|
43
|
+
this.customStyle = model(inject(FLOWBITE_NAVBAR_ICON_BUTTON_CUSTOM_STYLE_DEFAULT_VALUE));
|
|
37
44
|
}
|
|
38
45
|
//#endregion
|
|
39
46
|
//#region BaseComponent implementation
|
|
@@ -43,11 +50,6 @@ export class NavbarIconButtonComponent extends BaseComponent {
|
|
|
43
50
|
customStyle: this.customStyle(),
|
|
44
51
|
});
|
|
45
52
|
}
|
|
46
|
-
verify() {
|
|
47
|
-
if (this.navbarComponent === null && this.navbarContentComponent === null) {
|
|
48
|
-
throw new Error('No NavbarComponent/NavbarContentComponent available');
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
53
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: NavbarIconButtonComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
52
54
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.0.0", type: NavbarIconButtonComponent, isStandalone: true, selector: "flowbite-navbar-icon-button", inputs: { color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, customStyle: { classPropertyName: "customStyle", publicName: "customStyle", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { color: "colorChange", customStyle: "customStyleChange" }, usesInheritance: true, ngImport: i0, template: `<ng-content />`, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
53
55
|
}
|
|
@@ -56,10 +58,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
|
|
|
56
58
|
args: [{
|
|
57
59
|
selector: 'flowbite-navbar-icon-button',
|
|
58
60
|
standalone: true,
|
|
59
|
-
imports: [],
|
|
60
61
|
template: `<ng-content />`,
|
|
61
62
|
encapsulation: ViewEncapsulation.None,
|
|
62
63
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
63
64
|
}]
|
|
64
65
|
}] });
|
|
65
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2YmFyLWljb24tYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvZmxvd2JpdGUtYW5ndWxhci9uYXZiYXIvbmF2YmFyLWljb24tYnV0dG9uLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUVwRSxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUNsRixPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFJckQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBRWpELE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULE1BQU0sRUFDTixjQUFjLEVBQ2Qsd0JBQXdCLEVBQ3hCLEtBQUssRUFDTCxpQkFBaUIsR0FDbEIsTUFBTSxlQUFlLENBQUM7O0FBRXZCLE1BQU0sQ0FBQyxNQUFNLHNEQUFzRCxHQUFHLElBQUksY0FBYyxDQUV0Rix3REFBd0QsQ0FBQyxDQUFDO0FBRTVELE1BQU0sQ0FBQyxNQUFNLG9DQUFvQyxHQUFHLHdCQUF3QixDQUFDO0lBQzNFO1FBQ0UsT0FBTyxFQUFFLHNEQUFzRDtRQUMvRCxRQUFRLEVBQUUsRUFBRTtLQUNiO0NBQ0YsQ0FBQyxDQUFDO0FBRUg7O0dBRUc7QUFRSCxNQUFNLE9BQU8seUJBQTBCLFNBQVEsYUFBb0M7SUFQbkY7O1FBUUU7O1dBRUc7UUFDYSxpQkFBWSxHQUFHLE1BQU0sQ0FBQyw0QkFBNEIsQ0FBQyxDQUFDO1FBQ3BFOztXQUVHO1FBQ2Esb0JBQWUsR0FBRyxNQUFNLENBQUMsZUFBZSxFQUFFLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7UUFDOUU7O1dBRUc7UUFDYSwyQkFBc0IsR0FBRyxNQUFNLENBQUMsc0JBQXNCLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztRQUU1RixvQkFBb0I7UUFDcEI7Ozs7O1dBS0c7UUFDSSxVQUFLLEdBQUcsS0FBSyxDQUNsQixJQUFJLENBQUMsc0JBQXNCLEVBQUUsS0FBSyxFQUFFLElBQUksSUFBSSxDQUFDLGVBQWdCLENBQUMsS0FBSyxFQUFFLENBQ3RFLENBQUM7UUFDRjs7V0FFRztRQUNJLGdCQUFXLEdBQUcsS0FBSyxDQUFDLE1BQU0sQ0FBQyxzREFBc0QsQ0FBQyxDQUFDLENBQUM7S0FVNUY7SUFUQyxZQUFZO0lBRVosc0NBQXNDO0lBQ3RCLFVBQVU7UUFDeEIsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLFVBQVUsQ0FBQztZQUNsQyxLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUssRUFBRTtZQUNuQixXQUFXLEVBQUUsSUFBSSxDQUFDLFdBQVcsRUFBRTtTQUNoQyxDQUFDLENBQUM7SUFDTCxDQUFDOzhHQXBDVSx5QkFBeUI7a0dBQXpCLHlCQUF5QixpY0FKMUIsZ0JBQWdCOzsyRkFJZix5QkFBeUI7a0JBUHJDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLDZCQUE2QjtvQkFDdkMsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSxnQkFBZ0I7b0JBQzFCLGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO29CQUNyQyxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDaEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOYXZiYXJDb250ZW50Q29tcG9uZW50IH0gZnJvbSAnLi9uYXZiYXItY29udGVudC5jb21wb25lbnQnO1xuaW1wb3J0IHR5cGUgeyBOYXZiYXJJY29uQnV0dG9uQ2xhc3MsIE5hdmJhckljb25CdXR0b25UaGVtZSB9IGZyb20gJy4vbmF2YmFyLWljb24tYnV0dG9uLnRoZW1lJztcbmltcG9ydCB7IE5hdmJhckljb25CdXR0b25UaGVtZVNlcnZpY2UgfSBmcm9tICcuL25hdmJhci1pY29uLWJ1dHRvbi50aGVtZS5zZXJ2aWNlJztcbmltcG9ydCB7IE5hdmJhckNvbXBvbmVudCB9IGZyb20gJy4vbmF2YmFyLmNvbXBvbmVudCc7XG5pbXBvcnQgdHlwZSB7IE5hdmJhckNvbG9ycyB9IGZyb20gJy4vbmF2YmFyLnRoZW1lJztcblxuaW1wb3J0IHR5cGUgeyBEZWVwUGFydGlhbCB9IGZyb20gJ2Zsb3diaXRlLWFuZ3VsYXInO1xuaW1wb3J0IHsgQmFzZUNvbXBvbmVudCB9IGZyb20gJ2Zsb3diaXRlLWFuZ3VsYXInO1xuXG5pbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBpbmplY3QsXG4gIEluamVjdGlvblRva2VuLFxuICBtYWtlRW52aXJvbm1lbnRQcm92aWRlcnMsXG4gIG1vZGVsLFxuICBWaWV3RW5jYXBzdWxhdGlvbixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBjb25zdCBGTE9XQklURV9OQVZCQVJfSUNPTl9CVVRUT05fQ1VTVE9NX1NUWUxFX0RFRkFVTFRfVkFMVUUgPSBuZXcgSW5qZWN0aW9uVG9rZW48XG4gIERlZXBQYXJ0aWFsPE5hdmJhckljb25CdXR0b25UaGVtZT5cbj4oJ0ZMT1dCSVRFX05BVkJBUl9JQ09OX0JVVFRPTl9DVVNUT01fU1RZTEVfREVGQVVMVF9WQUxVRScpO1xuXG5leHBvcnQgY29uc3QgbmF2YmFySWNvbkJ1dHRvbkRlZmF1bHRWYWx1ZVByb3ZpZGVyID0gbWFrZUVudmlyb25tZW50UHJvdmlkZXJzKFtcbiAge1xuICAgIHByb3ZpZGU6IEZMT1dCSVRFX05BVkJBUl9JQ09OX0JVVFRPTl9DVVNUT01fU1RZTEVfREVGQVVMVF9WQUxVRSxcbiAgICB1c2VWYWx1ZToge30sXG4gIH0sXG5dKTtcblxuLyoqXG4gKiBAc2VlIGh0dHBzOi8vZmxvd2JpdGUuY29tL2RvY3MvY29tcG9uZW50cy9uYXZiYXIvXG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2Zsb3diaXRlLW5hdmJhci1pY29uLWJ1dHRvbicsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHRlbXBsYXRlOiBgPG5nLWNvbnRlbnQgLz5gLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgTmF2YmFySWNvbkJ1dHRvbkNvbXBvbmVudCBleHRlbmRzIEJhc2VDb21wb25lbnQ8TmF2YmFySWNvbkJ1dHRvbkNsYXNzPiB7XG4gIC8qKlxuICAgKiBTZXJ2aWNlIGluamVjdGVkIHVzZWQgdG8gZ2VuZXJhdGUgY2xhc3NcbiAgICovXG4gIHB1YmxpYyByZWFkb25seSB0aGVtZVNlcnZpY2UgPSBpbmplY3QoTmF2YmFySWNvbkJ1dHRvblRoZW1lU2VydmljZSk7XG4gIC8qKlxuICAgKiBUaGUgb3B0aW9uYWwgcGFyZW50IGBOYXZiYXJDb21wb25lbnRgXG4gICAqL1xuICBwdWJsaWMgcmVhZG9ubHkgbmF2YmFyQ29tcG9uZW50ID0gaW5qZWN0KE5hdmJhckNvbXBvbmVudCwgeyBvcHRpb25hbDogdHJ1ZSB9KTtcbiAgLyoqXG4gICAqIFRoZSBvcHRpb25hbCBwYXJlbnQgYE5hdmJhckNvbnRlbnRDb21wb25lbnRgXG4gICAqL1xuICBwdWJsaWMgcmVhZG9ubHkgbmF2YmFyQ29udGVudENvbXBvbmVudCA9IGluamVjdChOYXZiYXJDb250ZW50Q29tcG9uZW50LCB7IG9wdGlvbmFsOiB0cnVlIH0pO1xuXG4gIC8vI3JlZ2lvbiBwcm9wZXJ0aWVzXG4gIC8qKlxuICAgKiBTZXQgdGhlIG5hdmJhciBpY29uIGJ1dHRvbiBjb2xvclxuICAgKlxuICAgKiBAZGVmYXVsdCBgTmF2YmFyQ29udGVudENvbXBvbmVudGAncyBjb2xvclxuICAgKiBAZGVmYXVsdCBgTmF2YmFyQ29tcG9uZW50YCdzIGNvbG9yXG4gICAqL1xuICBwdWJsaWMgY29sb3IgPSBtb2RlbDxrZXlvZiBOYXZiYXJDb2xvcnM+KFxuICAgIHRoaXMubmF2YmFyQ29udGVudENvbXBvbmVudD8uY29sb3IoKSB8fCB0aGlzLm5hdmJhckNvbXBvbmVudCEuY29sb3IoKVxuICApO1xuICAvKipcbiAgICogU2V0IHRoZSBjdXN0b20gc3R5bGUgZm9yIHRoaXMgbmF2YmFyIGljb24gYnV0dG9uXG4gICAqL1xuICBwdWJsaWMgY3VzdG9tU3R5bGUgPSBtb2RlbChpbmplY3QoRkxPV0JJVEVfTkFWQkFSX0lDT05fQlVUVE9OX0NVU1RPTV9TVFlMRV9ERUZBVUxUX1ZBTFVFKSk7XG4gIC8vI2VuZHJlZ2lvblxuXG4gIC8vI3JlZ2lvbiBCYXNlQ29tcG9uZW50IGltcGxlbWVudGF0aW9uXG4gIHB1YmxpYyBvdmVycmlkZSBmZXRjaENsYXNzKCk6IE5hdmJhckljb25CdXR0b25DbGFzcyB7XG4gICAgcmV0dXJuIHRoaXMudGhlbWVTZXJ2aWNlLmdldENsYXNzZXMoe1xuICAgICAgY29sb3I6IHRoaXMuY29sb3IoKSxcbiAgICAgIGN1c3RvbVN0eWxlOiB0aGlzLmN1c3RvbVN0eWxlKCksXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -3,9 +3,15 @@ import { NavbarItemThemeService } from './navbar-item.theme.service';
|
|
|
3
3
|
import { BaseComponent } from 'flowbite-angular';
|
|
4
4
|
import { FlowbiteRouterLinkDirective } from 'flowbite-angular/router-link';
|
|
5
5
|
import { FlowbiteRouterLinkActiveDirective } from 'flowbite-angular/router-link-active';
|
|
6
|
-
import {
|
|
7
|
-
import { ChangeDetectionStrategy, Component, inject, model, ViewEncapsulation, } from '@angular/core';
|
|
6
|
+
import { ChangeDetectionStrategy, Component, inject, InjectionToken, makeEnvironmentProviders, model, ViewEncapsulation, } from '@angular/core';
|
|
8
7
|
import * as i0 from "@angular/core";
|
|
8
|
+
export const FLOWBITE_NAVBAR_ITEM_CUSTOM_STYLE_DEFAULT_VALUE = new InjectionToken('FLOWBITE_NAVBAR_ITEM_CUSTOM_STYLE_DEFAULT_VALUE');
|
|
9
|
+
export const navbarItemDefaultValueProvider = makeEnvironmentProviders([
|
|
10
|
+
{
|
|
11
|
+
provide: FLOWBITE_NAVBAR_ITEM_CUSTOM_STYLE_DEFAULT_VALUE,
|
|
12
|
+
useValue: {},
|
|
13
|
+
},
|
|
14
|
+
]);
|
|
9
15
|
/**
|
|
10
16
|
* @see https://flowbite.com/docs/components/navbar/
|
|
11
17
|
*/
|
|
@@ -40,7 +46,7 @@ export class NavbarItemComponent extends BaseComponent {
|
|
|
40
46
|
/**
|
|
41
47
|
* Set the custom style for this navbar item
|
|
42
48
|
*/
|
|
43
|
-
this.customStyle = model(
|
|
49
|
+
this.customStyle = model(inject(FLOWBITE_NAVBAR_ITEM_CUSTOM_STYLE_DEFAULT_VALUE));
|
|
44
50
|
}
|
|
45
51
|
//#endregion
|
|
46
52
|
//#region BaseComponent implementation
|
|
@@ -65,7 +71,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
|
|
|
65
71
|
args: [{
|
|
66
72
|
selector: 'flowbite-navbar-item',
|
|
67
73
|
standalone: true,
|
|
68
|
-
imports: [NgClass],
|
|
69
74
|
template: `<ng-content />`,
|
|
70
75
|
host: {
|
|
71
76
|
'(click)': 'onClick()',
|
|
@@ -74,4 +79,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
|
|
|
74
79
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
75
80
|
}]
|
|
76
81
|
}] });
|
|
77
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
82
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2YmFyLWl0ZW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9mbG93Yml0ZS1hbmd1bGFyL25hdmJhci9uYXZiYXItaXRlbS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFFcEUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFJckUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ2pELE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQzNFLE9BQU8sRUFBRSxpQ0FBaUMsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBRXhGLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULE1BQU0sRUFDTixjQUFjLEVBQ2Qsd0JBQXdCLEVBQ3hCLEtBQUssRUFDTCxpQkFBaUIsR0FDbEIsTUFBTSxlQUFlLENBQUM7O0FBRXZCLE1BQU0sQ0FBQyxNQUFNLCtDQUErQyxHQUFHLElBQUksY0FBYyxDQUUvRSxpREFBaUQsQ0FBQyxDQUFDO0FBRXJELE1BQU0sQ0FBQyxNQUFNLDhCQUE4QixHQUFHLHdCQUF3QixDQUFDO0lBQ3JFO1FBQ0UsT0FBTyxFQUFFLCtDQUErQztRQUN4RCxRQUFRLEVBQUUsRUFBRTtLQUNiO0NBQ0YsQ0FBQyxDQUFDO0FBRUg7O0dBRUc7QUFXSCxNQUFNLE9BQU8sbUJBQW9CLFNBQVEsYUFBOEI7SUFWdkU7O1FBV0U7O1dBRUc7UUFDYSx1QkFBa0IsR0FBRyxNQUFNLENBQUMsMkJBQTJCLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztRQUM3Rjs7V0FFRztRQUNhLDZCQUF3QixHQUFHLE1BQU0sQ0FBQyxpQ0FBaUMsRUFBRTtZQUNuRixRQUFRLEVBQUUsSUFBSTtTQUNmLENBQUMsQ0FBQztRQUNIOztXQUVHO1FBQ2EsaUJBQVksR0FBRyxNQUFNLENBQUMsc0JBQXNCLENBQUMsQ0FBQztRQUM5RDs7V0FFRztRQUNhLDJCQUFzQixHQUFHLE1BQU0sQ0FBQyxzQkFBc0IsQ0FBQyxDQUFDO1FBRXhFLG9CQUFvQjtRQUNwQjs7OztXQUlHO1FBQ0ksVUFBSyxHQUFHLEtBQUssQ0FBcUIsSUFBSSxDQUFDLHNCQUFzQixDQUFDLEtBQUssRUFBRSxDQUFDLENBQUM7UUFDOUU7O1dBRUc7UUFDSSxnQkFBVyxHQUFHLEtBQUssQ0FBQyxNQUFNLENBQUMsK0NBQStDLENBQUMsQ0FBQyxDQUFDO0tBa0JyRjtJQWpCQyxZQUFZO0lBRVosc0NBQXNDO0lBQ3RCLFVBQVU7UUFDeEIsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLFVBQVUsQ0FBQztZQUNsQyxLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUssRUFBRTtZQUNuQixXQUFXLEVBQUUsSUFBSSxDQUFDLFdBQVcsRUFBRTtTQUNoQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBQ0QsWUFBWTtJQUVaOztPQUVHO0lBQ0ksT0FBTztRQUNaLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxlQUFlLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN4RSxDQUFDOzhHQS9DVSxtQkFBbUI7a0dBQW5CLG1CQUFtQix5ZUFQcEIsZ0JBQWdCOzsyRkFPZixtQkFBbUI7a0JBVi9CLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHNCQUFzQjtvQkFDaEMsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSxnQkFBZ0I7b0JBQzFCLElBQUksRUFBRTt3QkFDSixTQUFTLEVBQUUsV0FBVztxQkFDdkI7b0JBQ0QsYUFBYSxFQUFFLGlCQUFpQixDQUFDLElBQUk7b0JBQ3JDLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO2lCQUNoRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5hdmJhckNvbnRlbnRDb21wb25lbnQgfSBmcm9tICcuL25hdmJhci1jb250ZW50LmNvbXBvbmVudCc7XG5pbXBvcnQgdHlwZSB7IE5hdmJhckl0ZW1DbGFzcywgTmF2YmFySXRlbVRoZW1lIH0gZnJvbSAnLi9uYXZiYXItaXRlbS50aGVtZSc7XG5pbXBvcnQgeyBOYXZiYXJJdGVtVGhlbWVTZXJ2aWNlIH0gZnJvbSAnLi9uYXZiYXItaXRlbS50aGVtZS5zZXJ2aWNlJztcbmltcG9ydCB0eXBlIHsgTmF2YmFyQ29sb3JzIH0gZnJvbSAnLi9uYXZiYXIudGhlbWUnO1xuXG5pbXBvcnQgdHlwZSB7IERlZXBQYXJ0aWFsIH0gZnJvbSAnZmxvd2JpdGUtYW5ndWxhcic7XG5pbXBvcnQgeyBCYXNlQ29tcG9uZW50IH0gZnJvbSAnZmxvd2JpdGUtYW5ndWxhcic7XG5pbXBvcnQgeyBGbG93Yml0ZVJvdXRlckxpbmtEaXJlY3RpdmUgfSBmcm9tICdmbG93Yml0ZS1hbmd1bGFyL3JvdXRlci1saW5rJztcbmltcG9ydCB7IEZsb3diaXRlUm91dGVyTGlua0FjdGl2ZURpcmVjdGl2ZSB9IGZyb20gJ2Zsb3diaXRlLWFuZ3VsYXIvcm91dGVyLWxpbmstYWN0aXZlJztcblxuaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgaW5qZWN0LFxuICBJbmplY3Rpb25Ub2tlbixcbiAgbWFrZUVudmlyb25tZW50UHJvdmlkZXJzLFxuICBtb2RlbCxcbiAgVmlld0VuY2Fwc3VsYXRpb24sXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgY29uc3QgRkxPV0JJVEVfTkFWQkFSX0lURU1fQ1VTVE9NX1NUWUxFX0RFRkFVTFRfVkFMVUUgPSBuZXcgSW5qZWN0aW9uVG9rZW48XG4gIERlZXBQYXJ0aWFsPE5hdmJhckl0ZW1UaGVtZT5cbj4oJ0ZMT1dCSVRFX05BVkJBUl9JVEVNX0NVU1RPTV9TVFlMRV9ERUZBVUxUX1ZBTFVFJyk7XG5cbmV4cG9ydCBjb25zdCBuYXZiYXJJdGVtRGVmYXVsdFZhbHVlUHJvdmlkZXIgPSBtYWtlRW52aXJvbm1lbnRQcm92aWRlcnMoW1xuICB7XG4gICAgcHJvdmlkZTogRkxPV0JJVEVfTkFWQkFSX0lURU1fQ1VTVE9NX1NUWUxFX0RFRkFVTFRfVkFMVUUsXG4gICAgdXNlVmFsdWU6IHt9LFxuICB9LFxuXSk7XG5cbi8qKlxuICogQHNlZSBodHRwczovL2Zsb3diaXRlLmNvbS9kb2NzL2NvbXBvbmVudHMvbmF2YmFyL1xuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdmbG93Yml0ZS1uYXZiYXItaXRlbScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHRlbXBsYXRlOiBgPG5nLWNvbnRlbnQgLz5gLFxuICBob3N0OiB7XG4gICAgJyhjbGljayknOiAnb25DbGljaygpJyxcbiAgfSxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIE5hdmJhckl0ZW1Db21wb25lbnQgZXh0ZW5kcyBCYXNlQ29tcG9uZW50PE5hdmJhckl0ZW1DbGFzcz4ge1xuICAvKipcbiAgICogT3B0aW9uYWwgYEZsb3diaXRlUm91dGVyTGlua0RpcmVjdGl2ZWAgaW5qZWN0ZWRcbiAgICovXG4gIHB1YmxpYyByZWFkb25seSBmbG93Yml0ZVJvdXRlckxpbmsgPSBpbmplY3QoRmxvd2JpdGVSb3V0ZXJMaW5rRGlyZWN0aXZlLCB7IG9wdGlvbmFsOiB0cnVlIH0pO1xuICAvKipcbiAgICogT3B0aW9uYWwgYEZsb3diaXRlUm91dGVyTGlua0FjdGl2ZURpcmVjdGl2ZWAgaW5qZWN0ZWRcbiAgICovXG4gIHB1YmxpYyByZWFkb25seSBmbG93Yml0ZVJvdXRlckxpbmtBY3RpdmUgPSBpbmplY3QoRmxvd2JpdGVSb3V0ZXJMaW5rQWN0aXZlRGlyZWN0aXZlLCB7XG4gICAgb3B0aW9uYWw6IHRydWUsXG4gIH0pO1xuICAvKipcbiAgICogU2VydmljZSBpbmplY3RlZCB1c2VkIHRvIGdlbmVyYXRlIGNsYXNzXG4gICAqL1xuICBwdWJsaWMgcmVhZG9ubHkgdGhlbWVTZXJ2aWNlID0gaW5qZWN0KE5hdmJhckl0ZW1UaGVtZVNlcnZpY2UpO1xuICAvKipcbiAgICogVGhlIHBhcmVudCBgTmF2YmFyQ29udGVudENvbXBvbmVudGBcbiAgICovXG4gIHB1YmxpYyByZWFkb25seSBuYXZiYXJDb250ZW50Q29tcG9uZW50ID0gaW5qZWN0KE5hdmJhckNvbnRlbnRDb21wb25lbnQpO1xuXG4gIC8vI3JlZ2lvbiBwcm9wZXJ0aWVzXG4gIC8qKlxuICAgKiBTZXQgdGhlIG5hdmJhciBpdGVtIGNvbG9yXG4gICAqXG4gICAqIEBkZWZhdWx0IGBOYXZiYXJDb250ZW50Q29tcG9uZW50YCdzIGNvbG9yXG4gICAqL1xuICBwdWJsaWMgY29sb3IgPSBtb2RlbDxrZXlvZiBOYXZiYXJDb2xvcnM+KHRoaXMubmF2YmFyQ29udGVudENvbXBvbmVudC5jb2xvcigpKTtcbiAgLyoqXG4gICAqIFNldCB0aGUgY3VzdG9tIHN0eWxlIGZvciB0aGlzIG5hdmJhciBpdGVtXG4gICAqL1xuICBwdWJsaWMgY3VzdG9tU3R5bGUgPSBtb2RlbChpbmplY3QoRkxPV0JJVEVfTkFWQkFSX0lURU1fQ1VTVE9NX1NUWUxFX0RFRkFVTFRfVkFMVUUpKTtcbiAgLy8jZW5kcmVnaW9uXG5cbiAgLy8jcmVnaW9uIEJhc2VDb21wb25lbnQgaW1wbGVtZW50YXRpb25cbiAgcHVibGljIG92ZXJyaWRlIGZldGNoQ2xhc3MoKTogTmF2YmFySXRlbUNsYXNzIHtcbiAgICByZXR1cm4gdGhpcy50aGVtZVNlcnZpY2UuZ2V0Q2xhc3Nlcyh7XG4gICAgICBjb2xvcjogdGhpcy5jb2xvcigpLFxuICAgICAgY3VzdG9tU3R5bGU6IHRoaXMuY3VzdG9tU3R5bGUoKSxcbiAgICB9KTtcbiAgfVxuICAvLyNlbmRyZWdpb25cblxuICAvKipcbiAgICogVG9nZ2xlIHRoZSBubmF2YmFyIHZpc2liaWxpdHkgKGF1dG8gY2xvc2Ugd2hlbiBvbiBtb2JpbGUgZGV2aWNlKVxuICAgKi9cbiAgcHVibGljIG9uQ2xpY2soKTogdm9pZCB7XG4gICAgdGhpcy5uYXZiYXJDb250ZW50Q29tcG9uZW50Lm5hdmJhckNvbXBvbmVudCgpLnRvZ2dsZVZpc2liaWxpdHkoZmFsc2UpO1xuICB9XG59XG4iXX0=
|