@db-ux/ngx-core-components 1.0.0-test-13b991d
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 +130 -0
- package/components/accordion/accordion.d.ts +31 -0
- package/components/accordion/index.d.ts +1 -0
- package/components/accordion/model.d.ts +41 -0
- package/components/accordion-item/accordion-item.d.ts +29 -0
- package/components/accordion-item/index.d.ts +1 -0
- package/components/accordion-item/model.d.ts +24 -0
- package/components/badge/badge.d.ts +28 -0
- package/components/badge/index.d.ts +1 -0
- package/components/badge/model.d.ts +16 -0
- package/components/brand/brand.d.ts +24 -0
- package/components/brand/index.d.ts +1 -0
- package/components/brand/model.d.ts +10 -0
- package/components/button/button.d.ts +39 -0
- package/components/button/index.d.ts +1 -0
- package/components/button/model.d.ts +52 -0
- package/components/card/card.d.ts +24 -0
- package/components/card/index.d.ts +1 -0
- package/components/card/model.d.ts +18 -0
- package/components/checkbox/checkbox.d.ts +64 -0
- package/components/checkbox/index.d.ts +1 -0
- package/components/checkbox/model.d.ts +10 -0
- package/components/divider/divider.d.ts +22 -0
- package/components/divider/index.d.ts +1 -0
- package/components/divider/model.d.ts +18 -0
- package/components/drawer/drawer.d.ts +34 -0
- package/components/drawer/index.d.ts +1 -0
- package/components/drawer/model.d.ts +41 -0
- package/components/header/MetaNavigation.directive.d.ts +5 -0
- package/components/header/Navigation.directive.d.ts +5 -0
- package/components/header/SecondaryAction.directive.d.ts +5 -0
- package/components/header/header.d.ts +34 -0
- package/components/header/index.d.ts +1 -0
- package/components/header/model.d.ts +44 -0
- package/components/icon/icon.d.ts +22 -0
- package/components/icon/index.d.ts +1 -0
- package/components/icon/model.d.ts +12 -0
- package/components/infotext/index.d.ts +1 -0
- package/components/infotext/infotext.d.ts +24 -0
- package/components/infotext/model.d.ts +5 -0
- package/components/input/index.d.ts +1 -0
- package/components/input/input.d.ts +87 -0
- package/components/input/model.d.ts +39 -0
- package/components/link/index.d.ts +1 -0
- package/components/link/link.d.ts +37 -0
- package/components/link/model.d.ts +24 -0
- package/components/navigation/index.d.ts +1 -0
- package/components/navigation/model.d.ts +5 -0
- package/components/navigation/navigation.d.ts +21 -0
- package/components/navigation-item/NavigationContent.directive.d.ts +5 -0
- package/components/navigation-item/index.d.ts +1 -0
- package/components/navigation-item/model.d.ts +34 -0
- package/components/navigation-item/navigation-item.d.ts +44 -0
- package/components/notification/index.d.ts +1 -0
- package/components/notification/model.d.ts +57 -0
- package/components/notification/notification.d.ts +38 -0
- package/components/page/index.d.ts +1 -0
- package/components/page/model.d.ts +32 -0
- package/components/page/page.d.ts +25 -0
- package/components/popover/index.d.ts +1 -0
- package/components/popover/model.d.ts +18 -0
- package/components/popover/popover.d.ts +33 -0
- package/components/radio/index.d.ts +1 -0
- package/components/radio/model.d.ts +7 -0
- package/components/radio/radio.d.ts +51 -0
- package/components/section/index.d.ts +1 -0
- package/components/section/model.d.ts +5 -0
- package/components/section/section.d.ts +22 -0
- package/components/select/index.d.ts +1 -0
- package/components/select/model.d.ts +43 -0
- package/components/select/select.d.ts +77 -0
- package/components/stack/index.d.ts +1 -0
- package/components/stack/model.d.ts +34 -0
- package/components/stack/stack.d.ts +25 -0
- package/components/switch/index.d.ts +1 -0
- package/components/switch/model.d.ts +12 -0
- package/components/switch/switch.d.ts +55 -0
- package/components/tab-item/index.d.ts +1 -0
- package/components/tab-item/model.d.ts +24 -0
- package/components/tab-item/tab-item.d.ts +44 -0
- package/components/tab-list/index.d.ts +1 -0
- package/components/tab-list/model.d.ts +5 -0
- package/components/tab-list/tab-list.d.ts +20 -0
- package/components/tab-panel/index.d.ts +1 -0
- package/components/tab-panel/model.d.ts +10 -0
- package/components/tab-panel/tab-panel.d.ts +21 -0
- package/components/tabs/index.d.ts +1 -0
- package/components/tabs/model.d.ts +47 -0
- package/components/tabs/tabs.d.ts +42 -0
- package/components/tag/index.d.ts +1 -0
- package/components/tag/model.d.ts +45 -0
- package/components/tag/tag.d.ts +37 -0
- package/components/textarea/index.d.ts +1 -0
- package/components/textarea/model.d.ts +30 -0
- package/components/textarea/textarea.d.ts +79 -0
- package/components/tooltip/index.d.ts +1 -0
- package/components/tooltip/model.d.ts +7 -0
- package/components/tooltip/tooltip.d.ts +32 -0
- package/esm2022/components/accordion/accordion.mjs +196 -0
- package/esm2022/components/accordion/index.mjs +2 -0
- package/esm2022/components/accordion/model.mjs +3 -0
- package/esm2022/components/accordion-item/accordion-item.mjs +136 -0
- package/esm2022/components/accordion-item/index.mjs +2 -0
- package/esm2022/components/accordion-item/model.mjs +2 -0
- package/esm2022/components/badge/badge.mjs +130 -0
- package/esm2022/components/badge/index.mjs +2 -0
- package/esm2022/components/badge/model.mjs +2 -0
- package/esm2022/components/brand/brand.mjs +99 -0
- package/esm2022/components/brand/index.mjs +2 -0
- package/esm2022/components/brand/model.mjs +2 -0
- package/esm2022/components/button/button.mjs +158 -0
- package/esm2022/components/button/index.mjs +2 -0
- package/esm2022/components/button/model.mjs +4 -0
- package/esm2022/components/card/card.mjs +107 -0
- package/esm2022/components/card/index.mjs +2 -0
- package/esm2022/components/card/model.mjs +3 -0
- package/esm2022/components/checkbox/checkbox.mjs +328 -0
- package/esm2022/components/checkbox/index.mjs +2 -0
- package/esm2022/components/checkbox/model.mjs +2 -0
- package/esm2022/components/divider/divider.mjs +93 -0
- package/esm2022/components/divider/index.mjs +2 -0
- package/esm2022/components/divider/model.mjs +3 -0
- package/esm2022/components/drawer/drawer.mjs +218 -0
- package/esm2022/components/drawer/index.mjs +2 -0
- package/esm2022/components/drawer/model.mjs +4 -0
- package/esm2022/components/header/MetaNavigation.directive.mjs +15 -0
- package/esm2022/components/header/Navigation.directive.mjs +15 -0
- package/esm2022/components/header/SecondaryAction.directive.mjs +15 -0
- package/esm2022/components/header/header.mjs +251 -0
- package/esm2022/components/header/index.mjs +2 -0
- package/esm2022/components/header/model.mjs +2 -0
- package/esm2022/components/icon/icon.mjs +100 -0
- package/esm2022/components/icon/index.mjs +2 -0
- package/esm2022/components/icon/model.mjs +3 -0
- package/esm2022/components/infotext/index.mjs +2 -0
- package/esm2022/components/infotext/infotext.mjs +103 -0
- package/esm2022/components/infotext/model.mjs +2 -0
- package/esm2022/components/input/index.mjs +2 -0
- package/esm2022/components/input/input.mjs +421 -0
- package/esm2022/components/input/model.mjs +6 -0
- package/esm2022/components/link/index.mjs +2 -0
- package/esm2022/components/link/link.mjs +152 -0
- package/esm2022/components/link/model.mjs +4 -0
- package/esm2022/components/navigation/index.mjs +2 -0
- package/esm2022/components/navigation/model.mjs +2 -0
- package/esm2022/components/navigation/navigation.mjs +92 -0
- package/esm2022/components/navigation-item/NavigationContent.directive.mjs +15 -0
- package/esm2022/components/navigation-item/index.mjs +2 -0
- package/esm2022/components/navigation-item/model.mjs +2 -0
- package/esm2022/components/navigation-item/navigation-item.mjs +236 -0
- package/esm2022/components/notification/index.mjs +2 -0
- package/esm2022/components/notification/model.mjs +4 -0
- package/esm2022/components/notification/notification.mjs +181 -0
- package/esm2022/components/page/index.mjs +2 -0
- package/esm2022/components/page/model.mjs +3 -0
- package/esm2022/components/page/page.mjs +127 -0
- package/esm2022/components/popover/index.mjs +2 -0
- package/esm2022/components/popover/model.mjs +2 -0
- package/esm2022/components/popover/popover.mjs +189 -0
- package/esm2022/components/radio/index.mjs +2 -0
- package/esm2022/components/radio/model.mjs +2 -0
- package/esm2022/components/radio/radio.mjs +230 -0
- package/esm2022/components/section/index.mjs +2 -0
- package/esm2022/components/section/model.mjs +2 -0
- package/esm2022/components/section/section.mjs +96 -0
- package/esm2022/components/select/index.mjs +2 -0
- package/esm2022/components/select/model.mjs +2 -0
- package/esm2022/components/select/select.mjs +426 -0
- package/esm2022/components/stack/index.mjs +2 -0
- package/esm2022/components/stack/model.mjs +5 -0
- package/esm2022/components/stack/stack.mjs +106 -0
- package/esm2022/components/switch/index.mjs +2 -0
- package/esm2022/components/switch/model.mjs +2 -0
- package/esm2022/components/switch/switch.mjs +237 -0
- package/esm2022/components/tab-item/index.mjs +2 -0
- package/esm2022/components/tab-item/model.mjs +2 -0
- package/esm2022/components/tab-item/tab-item.mjs +195 -0
- package/esm2022/components/tab-list/index.mjs +2 -0
- package/esm2022/components/tab-list/model.mjs +2 -0
- package/esm2022/components/tab-list/tab-list.mjs +84 -0
- package/esm2022/components/tab-panel/index.mjs +2 -0
- package/esm2022/components/tab-panel/model.mjs +2 -0
- package/esm2022/components/tab-panel/tab-panel.mjs +96 -0
- package/esm2022/components/tabs/index.mjs +2 -0
- package/esm2022/components/tabs/model.mjs +3 -0
- package/esm2022/components/tabs/tabs.mjs +322 -0
- package/esm2022/components/tag/index.mjs +2 -0
- package/esm2022/components/tag/model.mjs +2 -0
- package/esm2022/components/tag/tag.mjs +186 -0
- package/esm2022/components/textarea/index.mjs +2 -0
- package/esm2022/components/textarea/model.mjs +3 -0
- package/esm2022/components/textarea/textarea.mjs +363 -0
- package/esm2022/components/tooltip/index.mjs +2 -0
- package/esm2022/components/tooltip/model.mjs +2 -0
- package/esm2022/components/tooltip/tooltip.mjs +149 -0
- package/esm2022/db-ux-ngx-core-components.mjs +5 -0
- package/esm2022/index.mjs +41 -0
- package/esm2022/shared/constants.mjs +94 -0
- package/esm2022/shared/model.mjs +22 -0
- package/esm2022/utils/form-components.mjs +11 -0
- package/esm2022/utils/index.mjs +174 -0
- package/esm2022/utils/navigation.mjs +133 -0
- package/fesm2022/db-ux-ngx-core-components.mjs +6109 -0
- package/fesm2022/db-ux-ngx-core-components.mjs.map +1 -0
- package/index.d.ts +40 -0
- package/package.json +35 -0
- package/shared/constants.d.ts +83 -0
- package/shared/model.d.ts +445 -0
- package/utils/form-components.d.ts +2 -0
- package/utils/index.d.ts +61 -0
- package/utils/navigation.d.ts +32 -0
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
import { Output, EventEmitter, Component, ViewChild, Input, } from "@angular/core";
|
|
2
|
+
import { CommonModule } from "@angular/common";
|
|
3
|
+
import { cls, getBooleanAsString, getHideProp } from "../../utils";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
const defaultProps = {};
|
|
7
|
+
export class DBLink {
|
|
8
|
+
constructor() {
|
|
9
|
+
this.cls = cls;
|
|
10
|
+
this.getBooleanAsString = getBooleanAsString;
|
|
11
|
+
this.getHideProp = getHideProp;
|
|
12
|
+
this.onClick = new EventEmitter();
|
|
13
|
+
}
|
|
14
|
+
handleClick(event) {
|
|
15
|
+
if (this.onClick) {
|
|
16
|
+
this.onClick.emit(event);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.
|
|
21
|
+
* @param element the ref for the component
|
|
22
|
+
* @param customElementSelector the custom element like `my-component`
|
|
23
|
+
*/
|
|
24
|
+
enableAttributePassing(element, customElementSelector) {
|
|
25
|
+
const parent = element?.closest(customElementSelector);
|
|
26
|
+
if (element && parent) {
|
|
27
|
+
const attributes = parent.attributes;
|
|
28
|
+
for (let i = 0; i < attributes.length; i++) {
|
|
29
|
+
const attr = attributes.item(i);
|
|
30
|
+
if (attr &&
|
|
31
|
+
(attr.name.startsWith("data-") || attr.name.startsWith("aria-"))) {
|
|
32
|
+
element.setAttribute(attr.name, attr.value);
|
|
33
|
+
parent.removeAttribute(attr.name);
|
|
34
|
+
}
|
|
35
|
+
if (attr && attr.name === "class") {
|
|
36
|
+
const isWebComponent = attr.value.includes("hydrated");
|
|
37
|
+
const value = attr.value.replace("hydrated", "").trim();
|
|
38
|
+
const currentClass = element.getAttribute("class");
|
|
39
|
+
element.setAttribute(attr.name, `${currentClass ? `${currentClass} ` : ""}${value}`);
|
|
40
|
+
if (isWebComponent) {
|
|
41
|
+
// Stencil is using this class for lazy loading component
|
|
42
|
+
parent.setAttribute("class", "hydrated");
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
parent.removeAttribute(attr.name);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
ngAfterViewInit() {
|
|
52
|
+
const element = this._ref?.nativeElement;
|
|
53
|
+
this.enableAttributePassing(element, "db-link");
|
|
54
|
+
}
|
|
55
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DBLink, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
56
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DBLink, isStandalone: true, selector: "db-link", inputs: { id: "id", className: "className", href: "href", target: "target", rel: "rel", role: "role", hreflang: "hreflang", disabled: "disabled", selected: "selected", label: "label", current: "current", size: "size", showIcon: "showIcon", variant: "variant", content: "content", text: "text" }, outputs: { onClick: "onClick" }, viewQueries: [{ propertyName: "_ref", first: true, predicate: ["_ref"], descendants: true }], ngImport: i0, template: `
|
|
57
|
+
<a
|
|
58
|
+
#_ref
|
|
59
|
+
[attr.id]="id"
|
|
60
|
+
[class]="cls('db-link', className)"
|
|
61
|
+
[attr.href]="href"
|
|
62
|
+
[attr.target]="target"
|
|
63
|
+
[attr.rel]="rel"
|
|
64
|
+
[attr.role]="role"
|
|
65
|
+
[attr.hrefLang]="hreflang"
|
|
66
|
+
[attr.aria-disabled]="getBooleanAsString(disabled)"
|
|
67
|
+
[attr.tabIndex]="disabled ? -1 : 0"
|
|
68
|
+
[attr.aria-selected]="selected"
|
|
69
|
+
[attr.aria-label]="label"
|
|
70
|
+
[attr.aria-current]="current"
|
|
71
|
+
[attr.data-size]="size"
|
|
72
|
+
[attr.data-hide-icon-after]="getHideProp(showIcon ?? true)"
|
|
73
|
+
[attr.data-variant]="variant"
|
|
74
|
+
[attr.data-content]="content || 'internal'"
|
|
75
|
+
(click)="handleClick($event)"
|
|
76
|
+
>
|
|
77
|
+
<ng-container *ngIf="text">{{text}}</ng-container>
|
|
78
|
+
<ng-container *ngIf="!(text)"><ng-content></ng-content></ng-container>
|
|
79
|
+
</a>
|
|
80
|
+
`, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
|
|
81
|
+
}
|
|
82
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DBLink, decorators: [{
|
|
83
|
+
type: Component,
|
|
84
|
+
args: [{
|
|
85
|
+
selector: "db-link",
|
|
86
|
+
template: `
|
|
87
|
+
<a
|
|
88
|
+
#_ref
|
|
89
|
+
[attr.id]="id"
|
|
90
|
+
[class]="cls('db-link', className)"
|
|
91
|
+
[attr.href]="href"
|
|
92
|
+
[attr.target]="target"
|
|
93
|
+
[attr.rel]="rel"
|
|
94
|
+
[attr.role]="role"
|
|
95
|
+
[attr.hrefLang]="hreflang"
|
|
96
|
+
[attr.aria-disabled]="getBooleanAsString(disabled)"
|
|
97
|
+
[attr.tabIndex]="disabled ? -1 : 0"
|
|
98
|
+
[attr.aria-selected]="selected"
|
|
99
|
+
[attr.aria-label]="label"
|
|
100
|
+
[attr.aria-current]="current"
|
|
101
|
+
[attr.data-size]="size"
|
|
102
|
+
[attr.data-hide-icon-after]="getHideProp(showIcon ?? true)"
|
|
103
|
+
[attr.data-variant]="variant"
|
|
104
|
+
[attr.data-content]="content || 'internal'"
|
|
105
|
+
(click)="handleClick($event)"
|
|
106
|
+
>
|
|
107
|
+
<ng-container *ngIf="text">{{text}}</ng-container>
|
|
108
|
+
<ng-container *ngIf="!(text)"><ng-content></ng-content></ng-container>
|
|
109
|
+
</a>
|
|
110
|
+
`,
|
|
111
|
+
standalone: true,
|
|
112
|
+
imports: [CommonModule],
|
|
113
|
+
}]
|
|
114
|
+
}], propDecorators: { id: [{
|
|
115
|
+
type: Input
|
|
116
|
+
}], className: [{
|
|
117
|
+
type: Input
|
|
118
|
+
}], href: [{
|
|
119
|
+
type: Input
|
|
120
|
+
}], target: [{
|
|
121
|
+
type: Input
|
|
122
|
+
}], rel: [{
|
|
123
|
+
type: Input
|
|
124
|
+
}], role: [{
|
|
125
|
+
type: Input
|
|
126
|
+
}], hreflang: [{
|
|
127
|
+
type: Input
|
|
128
|
+
}], disabled: [{
|
|
129
|
+
type: Input
|
|
130
|
+
}], selected: [{
|
|
131
|
+
type: Input
|
|
132
|
+
}], label: [{
|
|
133
|
+
type: Input
|
|
134
|
+
}], current: [{
|
|
135
|
+
type: Input
|
|
136
|
+
}], size: [{
|
|
137
|
+
type: Input
|
|
138
|
+
}], showIcon: [{
|
|
139
|
+
type: Input
|
|
140
|
+
}], variant: [{
|
|
141
|
+
type: Input
|
|
142
|
+
}], content: [{
|
|
143
|
+
type: Input
|
|
144
|
+
}], text: [{
|
|
145
|
+
type: Input
|
|
146
|
+
}], onClick: [{
|
|
147
|
+
type: Output
|
|
148
|
+
}], _ref: [{
|
|
149
|
+
type: ViewChild,
|
|
150
|
+
args: ["_ref"]
|
|
151
|
+
}] } });
|
|
152
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"link.js","sourceRoot":"","sources":["../../../../../output/angular/src/components/link/link.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Output,\n  EventEmitter,\n  Component,\n  ViewChild,\n  ElementRef,\n  Input,\n} from \"@angular/core\";\nimport { CommonModule } from \"@angular/common\";\n\nconst defaultProps = {};\n\nimport { DBLinkProps, DBLinkState } from \"./model\";\nimport { cls, getBooleanAsString, getHideProp } from \"../../utils\";\nimport { ClickEvent } from \"../../shared/model\";\n\n@Component({\n  selector: \"db-link\",\n  template: `\n    <a\n      #_ref\n      [attr.id]=\"id\"\n      [class]=\"cls('db-link', className)\"\n      [attr.href]=\"href\"\n      [attr.target]=\"target\"\n      [attr.rel]=\"rel\"\n      [attr.role]=\"role\"\n      [attr.hrefLang]=\"hreflang\"\n      [attr.aria-disabled]=\"getBooleanAsString(disabled)\"\n      [attr.tabIndex]=\"disabled ? -1 : 0\"\n      [attr.aria-selected]=\"selected\"\n      [attr.aria-label]=\"label\"\n      [attr.aria-current]=\"current\"\n      [attr.data-size]=\"size\"\n      [attr.data-hide-icon-after]=\"getHideProp(showIcon ?? true)\"\n      [attr.data-variant]=\"variant\"\n      [attr.data-content]=\"content || 'internal'\"\n      (click)=\"handleClick($event)\"\n    >\n      <ng-container *ngIf=\"text\">{{text}}</ng-container>\n      <ng-container *ngIf=\"!(text)\"><ng-content></ng-content></ng-container>\n    </a>\n  `,\n  standalone: true,\n  imports: [CommonModule],\n})\nexport class DBLink {\n  cls = cls;\n  getBooleanAsString = getBooleanAsString;\n  getHideProp = getHideProp;\n\n  @Input() id!: DBLinkProps[\"id\"];\n  @Input() className!: DBLinkProps[\"className\"];\n  @Input() href!: DBLinkProps[\"href\"];\n  @Input() target!: DBLinkProps[\"target\"];\n  @Input() rel!: DBLinkProps[\"rel\"];\n  @Input() role!: DBLinkProps[\"role\"];\n  @Input() hreflang!: DBLinkProps[\"hreflang\"];\n  @Input() disabled!: DBLinkProps[\"disabled\"];\n  @Input() selected!: DBLinkProps[\"selected\"];\n  @Input() label!: DBLinkProps[\"label\"];\n  @Input() current!: DBLinkProps[\"current\"];\n  @Input() size!: DBLinkProps[\"size\"];\n  @Input() showIcon!: DBLinkProps[\"showIcon\"];\n  @Input() variant!: DBLinkProps[\"variant\"];\n  @Input() content!: DBLinkProps[\"content\"];\n  @Input() text!: DBLinkProps[\"text\"];\n\n  @Output() onClick = new EventEmitter();\n\n  @ViewChild(\"_ref\") _ref!: ElementRef | undefined;\n\n  handleClick(\n    event: ClickEvent<HTMLAnchorElement>\n  ): ReturnType<DBLinkState[\"handleClick\"]> {\n    if (this.onClick) {\n      this.onClick.emit(event);\n    }\n  }\n\n  /**\n   * Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.\n   * @param element  the ref for the component\n   * @param customElementSelector  the custom element like `my-component`\n   */\n  private enableAttributePassing(\n    element: HTMLElement | null,\n    customElementSelector: string\n  ) {\n    const parent = element?.closest(customElementSelector);\n    if (element && parent) {\n      const attributes = parent.attributes;\n      for (let i = 0; i < attributes.length; i++) {\n        const attr = attributes.item(i);\n        if (\n          attr &&\n          (attr.name.startsWith(\"data-\") || attr.name.startsWith(\"aria-\"))\n        ) {\n          element.setAttribute(attr.name, attr.value);\n          parent.removeAttribute(attr.name);\n        }\n        if (attr && attr.name === \"class\") {\n          const isWebComponent = attr.value.includes(\"hydrated\");\n          const value = attr.value.replace(\"hydrated\", \"\").trim();\n          const currentClass = element.getAttribute(\"class\");\n          element.setAttribute(\n            attr.name,\n            `${currentClass ? `${currentClass} ` : \"\"}${value}`\n          );\n          if (isWebComponent) {\n            // Stencil is using this class for lazy loading component\n            parent.setAttribute(\"class\", \"hydrated\");\n          } else {\n            parent.removeAttribute(attr.name);\n          }\n        }\n      }\n    }\n  }\n\n  ngAfterViewInit() {\n    const element: HTMLElement | null = this._ref?.nativeElement;\n    this.enableAttributePassing(element, \"db-link\");\n  }\n}\n"]}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export const LinkVariantList = ['adaptive', 'brand'];
|
|
2
|
+
export const LinkSizeList = ['medium', 'small'];
|
|
3
|
+
export const LinkContentList = ['external', 'internal'];
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9vdXRwdXQvYW5ndWxhci9zcmMvY29tcG9uZW50cy9saW5rL21vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBSSxDQUFDLFVBQVUsRUFBRSxPQUFPLENBQVcsQ0FBQztBQUVoRSxNQUFNLENBQUMsTUFBTSxZQUFZLEdBQUksQ0FBQyxRQUFRLEVBQUUsT0FBTyxDQUFXLENBQUM7QUFFM0QsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUFJLENBQUMsVUFBVSxFQUFFLFVBQVUsQ0FBVyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2xpY2tFdmVudFByb3BzLCBDbGlja0V2ZW50U3RhdGUsIEdsb2JhbFByb3BzLCBHbG9iYWxTdGF0ZSwgTGlua1Byb3BzLCBTaG93SWNvblByb3BzLCBUZXh0UHJvcHMgfSBmcm9tICcuLi8uLi9zaGFyZWQvbW9kZWwnO1xuZXhwb3J0IGNvbnN0IExpbmtWYXJpYW50TGlzdCA9IChbJ2FkYXB0aXZlJywgJ2JyYW5kJ10gYXMgY29uc3QpO1xuZXhwb3J0IHR5cGUgTGlua1ZhcmlhbnRUeXBlID0gKHR5cGVvZiBMaW5rVmFyaWFudExpc3QpW251bWJlcl07XG5leHBvcnQgY29uc3QgTGlua1NpemVMaXN0ID0gKFsnbWVkaXVtJywgJ3NtYWxsJ10gYXMgY29uc3QpO1xuZXhwb3J0IHR5cGUgTGlua1NpemVUeXBlID0gKHR5cGVvZiBMaW5rU2l6ZUxpc3QpW251bWJlcl07XG5leHBvcnQgY29uc3QgTGlua0NvbnRlbnRMaXN0ID0gKFsnZXh0ZXJuYWwnLCAnaW50ZXJuYWwnXSBhcyBjb25zdCk7XG5leHBvcnQgdHlwZSBMaW5rQ29udGVudFR5cGUgPSAodHlwZW9mIExpbmtDb250ZW50TGlzdClbbnVtYmVyXTtcbmV4cG9ydCB0eXBlIERCTGlua0RlZmF1bHRQcm9wcyA9IHtcbiAgLyoqXG4gICAqIEFkZHMgYSBkaWZmZXJlbnQgYXJyb3cgYWZ0ZXIgdGhlIGxpbmsgdG8gaW5kaWNhdGUgZXh0ZXJuYWwgb3IgaW50ZXJuYWwgbGlua1xuICAgKi9cbiAgY29udGVudD86IExpbmtDb250ZW50VHlwZTtcbiAgLyoqXG4gICAqIENoYW5nZSB0aGUgc2l6ZSBvZiB0aGUgbGlua1xuICAgKi9cbiAgc2l6ZT86IExpbmtTaXplVHlwZTtcbiAgLyoqXG4gICAqIENoYW5nZSB0aGUgc3R5bGluZyBvZiB0aGUgbGluay4gYGlubGluZWAgd2lsbCByZW1vdmUgdGhlIGFycm93LiBEZWZhdWx0cyB0byBhZGFwdGl2ZS5cbiAgICovXG4gIHZhcmlhbnQ/OiBMaW5rVmFyaWFudFR5cGU7XG59O1xuZXhwb3J0IHR5cGUgREJMaW5rUHJvcHMgPSBEQkxpbmtEZWZhdWx0UHJvcHMgJiBHbG9iYWxQcm9wcyAmIENsaWNrRXZlbnRQcm9wczxIVE1MQW5jaG9yRWxlbWVudD4gJiBMaW5rUHJvcHMgJiBTaG93SWNvblByb3BzICYgVGV4dFByb3BzO1xuZXhwb3J0IHR5cGUgREJMaW5rRGVmYXVsdFN0YXRlID0ge307XG5leHBvcnQgdHlwZSBEQkxpbmtTdGF0ZSA9IERCTGlua0RlZmF1bHRTdGF0ZSAmIEdsb2JhbFN0YXRlICYgQ2xpY2tFdmVudFN0YXRlPEhUTUxBbmNob3JFbGVtZW50PiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export { DBNavigation } from './navigation';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9vdXRwdXQvYW5ndWxhci9zcmMvY29tcG9uZW50cy9uYXZpZ2F0aW9uL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxjQUFjLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBEQk5hdmlnYXRpb24gfSBmcm9tICcuL25hdmlnYXRpb24nIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9vdXRwdXQvYW5ndWxhci9zcmMvY29tcG9uZW50cy9uYXZpZ2F0aW9uL21vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBcmlhTGFiZWxsZWRCeVByb3BzLCBHbG9iYWxQcm9wcywgR2xvYmFsU3RhdGUgfSBmcm9tICcuLi8uLi9zaGFyZWQvbW9kZWwnO1xuZXhwb3J0IHR5cGUgREJOYXZpZ2F0aW9uRGVmYXVsdFByb3BzID0ge307XG5leHBvcnQgdHlwZSBEQk5hdmlnYXRpb25Qcm9wcyA9IERCTmF2aWdhdGlvbkRlZmF1bHRQcm9wcyAmIEdsb2JhbFByb3BzICYgQXJpYUxhYmVsbGVkQnlQcm9wcztcbmV4cG9ydCB0eXBlIERCTmF2aWdhdGlvbkRlZmF1bHRTdGF0ZSA9IHt9O1xuZXhwb3J0IHR5cGUgREJOYXZpZ2F0aW9uU3RhdGUgPSBEQk5hdmlnYXRpb25EZWZhdWx0U3RhdGUgJiBHbG9iYWxTdGF0ZSJdfQ==
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
import { Component, ViewChild, Input } from "@angular/core";
|
|
2
|
+
import { CommonModule } from "@angular/common";
|
|
3
|
+
import { cls, uuid } from "../../utils";
|
|
4
|
+
import { DEFAULT_ID } from "../../shared/constants";
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
const defaultProps = {};
|
|
7
|
+
export class DBNavigation {
|
|
8
|
+
constructor() {
|
|
9
|
+
this.cls = cls;
|
|
10
|
+
this._id = DEFAULT_ID;
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.
|
|
14
|
+
* @param element the ref for the component
|
|
15
|
+
* @param customElementSelector the custom element like `my-component`
|
|
16
|
+
*/
|
|
17
|
+
enableAttributePassing(element, customElementSelector) {
|
|
18
|
+
const parent = element?.closest(customElementSelector);
|
|
19
|
+
if (element && parent) {
|
|
20
|
+
const attributes = parent.attributes;
|
|
21
|
+
for (let i = 0; i < attributes.length; i++) {
|
|
22
|
+
const attr = attributes.item(i);
|
|
23
|
+
if (attr &&
|
|
24
|
+
(attr.name.startsWith("data-") || attr.name.startsWith("aria-"))) {
|
|
25
|
+
element.setAttribute(attr.name, attr.value);
|
|
26
|
+
parent.removeAttribute(attr.name);
|
|
27
|
+
}
|
|
28
|
+
if (attr && attr.name === "class") {
|
|
29
|
+
const isWebComponent = attr.value.includes("hydrated");
|
|
30
|
+
const value = attr.value.replace("hydrated", "").trim();
|
|
31
|
+
const currentClass = element.getAttribute("class");
|
|
32
|
+
element.setAttribute(attr.name, `${currentClass ? `${currentClass} ` : ""}${value}`);
|
|
33
|
+
if (isWebComponent) {
|
|
34
|
+
// Stencil is using this class for lazy loading component
|
|
35
|
+
parent.setAttribute("class", "hydrated");
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
parent.removeAttribute(attr.name);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
ngOnInit() {
|
|
45
|
+
if (typeof window !== "undefined") {
|
|
46
|
+
this._id = this.id || "navigation-" + uuid();
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
ngAfterViewInit() {
|
|
50
|
+
const element = this._ref?.nativeElement;
|
|
51
|
+
this.enableAttributePassing(element, "db-navigation");
|
|
52
|
+
}
|
|
53
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DBNavigation, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
54
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DBNavigation, isStandalone: true, selector: "db-navigation", inputs: { id: "id", labelledBy: "labelledBy", className: "className" }, viewQueries: [{ propertyName: "_ref", first: true, predicate: ["_ref"], descendants: true }], ngImport: i0, template: `
|
|
55
|
+
<nav
|
|
56
|
+
#_ref
|
|
57
|
+
[attr.id]="_id"
|
|
58
|
+
[attr.aria-labelledby]="labelledBy"
|
|
59
|
+
[class]="cls('db-navigation', className)"
|
|
60
|
+
>
|
|
61
|
+
<menu><ng-content></ng-content></menu>
|
|
62
|
+
</nav>
|
|
63
|
+
`, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }] }); }
|
|
64
|
+
}
|
|
65
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DBNavigation, decorators: [{
|
|
66
|
+
type: Component,
|
|
67
|
+
args: [{
|
|
68
|
+
selector: "db-navigation",
|
|
69
|
+
template: `
|
|
70
|
+
<nav
|
|
71
|
+
#_ref
|
|
72
|
+
[attr.id]="_id"
|
|
73
|
+
[attr.aria-labelledby]="labelledBy"
|
|
74
|
+
[class]="cls('db-navigation', className)"
|
|
75
|
+
>
|
|
76
|
+
<menu><ng-content></ng-content></menu>
|
|
77
|
+
</nav>
|
|
78
|
+
`,
|
|
79
|
+
standalone: true,
|
|
80
|
+
imports: [CommonModule],
|
|
81
|
+
}]
|
|
82
|
+
}], propDecorators: { id: [{
|
|
83
|
+
type: Input
|
|
84
|
+
}], labelledBy: [{
|
|
85
|
+
type: Input
|
|
86
|
+
}], className: [{
|
|
87
|
+
type: Input
|
|
88
|
+
}], _ref: [{
|
|
89
|
+
type: ViewChild,
|
|
90
|
+
args: ["_ref"]
|
|
91
|
+
}] } });
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2aWdhdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL291dHB1dC9hbmd1bGFyL3NyYy9jb21wb25lbnRzL25hdmlnYXRpb24vbmF2aWdhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFNBQVMsRUFBYyxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDeEUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBSy9DLE9BQU8sRUFBRSxHQUFHLEVBQUUsSUFBSSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQ3hDLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7QUFKcEQsTUFBTSxZQUFZLEdBQUcsRUFBRSxDQUFDO0FBcUJ4QixNQUFNLE9BQU8sWUFBWTtJQWZ6QjtRQWdCRSxRQUFHLEdBQUcsR0FBRyxDQUFDO1FBUVYsUUFBRyxHQUE2QixVQUFVLENBQUM7S0FvRDVDO0lBbERDOzs7O09BSUc7SUFDSyxzQkFBc0IsQ0FDNUIsT0FBMkIsRUFDM0IscUJBQTZCO1FBRTdCLE1BQU0sTUFBTSxHQUFHLE9BQU8sRUFBRSxPQUFPLENBQUMscUJBQXFCLENBQUMsQ0FBQztRQUN2RCxJQUFJLE9BQU8sSUFBSSxNQUFNLEVBQUUsQ0FBQztZQUN0QixNQUFNLFVBQVUsR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDO1lBQ3JDLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxVQUFVLENBQUMsTUFBTSxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUM7Z0JBQzNDLE1BQU0sSUFBSSxHQUFHLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQ2hDLElBQ0UsSUFBSTtvQkFDSixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxDQUFDLEVBQ2hFLENBQUM7b0JBQ0QsT0FBTyxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztvQkFDNUMsTUFBTSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7Z0JBQ3BDLENBQUM7Z0JBQ0QsSUFBSSxJQUFJLElBQUksSUFBSSxDQUFDLElBQUksS0FBSyxPQUFPLEVBQUUsQ0FBQztvQkFDbEMsTUFBTSxjQUFjLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsVUFBVSxDQUFDLENBQUM7b0JBQ3ZELE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLFVBQVUsRUFBRSxFQUFFLENBQUMsQ0FBQyxJQUFJLEVBQUUsQ0FBQztvQkFDeEQsTUFBTSxZQUFZLEdBQUcsT0FBTyxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsQ0FBQztvQkFDbkQsT0FBTyxDQUFDLFlBQVksQ0FDbEIsSUFBSSxDQUFDLElBQUksRUFDVCxHQUFHLFlBQVksQ0FBQyxDQUFDLENBQUMsR0FBRyxZQUFZLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxHQUFHLEtBQUssRUFBRSxDQUNwRCxDQUFDO29CQUNGLElBQUksY0FBYyxFQUFFLENBQUM7d0JBQ25CLHlEQUF5RDt3QkFDekQsTUFBTSxDQUFDLFlBQVksQ0FBQyxPQUFPLEVBQUUsVUFBVSxDQUFDLENBQUM7b0JBQzNDLENBQUM7eUJBQU0sQ0FBQzt3QkFDTixNQUFNLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztvQkFDcEMsQ0FBQztnQkFDSCxDQUFDO1lBQ0gsQ0FBQztRQUNILENBQUM7SUFDSCxDQUFDO0lBRUQsUUFBUTtRQUNOLElBQUksT0FBTyxNQUFNLEtBQUssV0FBVyxFQUFFLENBQUM7WUFDbEMsSUFBSSxDQUFDLEdBQUcsR0FBRyxJQUFJLENBQUMsRUFBRSxJQUFJLGFBQWEsR0FBRyxJQUFJLEVBQUUsQ0FBQztRQUMvQyxDQUFDO0lBQ0gsQ0FBQztJQUVELGVBQWU7UUFDYixNQUFNLE9BQU8sR0FBdUIsSUFBSSxDQUFDLElBQUksRUFBRSxhQUFhLENBQUM7UUFDN0QsSUFBSSxDQUFDLHNCQUFzQixDQUFDLE9BQU8sRUFBRSxlQUFlLENBQUMsQ0FBQztJQUN4RCxDQUFDOytHQTVEVSxZQUFZO21HQUFaLFlBQVksK09BYmI7Ozs7Ozs7OztHQVNULDJEQUVTLFlBQVk7OzRGQUVYLFlBQVk7a0JBZnhCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGVBQWU7b0JBQ3pCLFFBQVEsRUFBRTs7Ozs7Ozs7O0dBU1Q7b0JBQ0QsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztpQkFDeEI7OEJBSVUsRUFBRTtzQkFBVixLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFFYSxJQUFJO3NCQUF0QixTQUFTO3VCQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIFZpZXdDaGlsZCwgRWxlbWVudFJlZiwgSW5wdXQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xuXG5jb25zdCBkZWZhdWx0UHJvcHMgPSB7fTtcblxuaW1wb3J0IHsgREJOYXZpZ2F0aW9uUHJvcHMsIERCTmF2aWdhdGlvblN0YXRlIH0gZnJvbSBcIi4vbW9kZWxcIjtcbmltcG9ydCB7IGNscywgdXVpZCB9IGZyb20gXCIuLi8uLi91dGlsc1wiO1xuaW1wb3J0IHsgREVGQVVMVF9JRCB9IGZyb20gXCIuLi8uLi9zaGFyZWQvY29uc3RhbnRzXCI7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogXCJkYi1uYXZpZ2F0aW9uXCIsXG4gIHRlbXBsYXRlOiBgXG4gICAgPG5hdlxuICAgICAgI19yZWZcbiAgICAgIFthdHRyLmlkXT1cIl9pZFwiXG4gICAgICBbYXR0ci5hcmlhLWxhYmVsbGVkYnldPVwibGFiZWxsZWRCeVwiXG4gICAgICBbY2xhc3NdPVwiY2xzKCdkYi1uYXZpZ2F0aW9uJywgY2xhc3NOYW1lKVwiXG4gICAgPlxuICAgICAgPG1lbnU+PG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PjwvbWVudT5cbiAgICA8L25hdj5cbiAgYCxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG59KVxuZXhwb3J0IGNsYXNzIERCTmF2aWdhdGlvbiB7XG4gIGNscyA9IGNscztcblxuICBASW5wdXQoKSBpZCE6IERCTmF2aWdhdGlvblByb3BzW1wiaWRcIl07XG4gIEBJbnB1dCgpIGxhYmVsbGVkQnkhOiBEQk5hdmlnYXRpb25Qcm9wc1tcImxhYmVsbGVkQnlcIl07XG4gIEBJbnB1dCgpIGNsYXNzTmFtZSE6IERCTmF2aWdhdGlvblByb3BzW1wiY2xhc3NOYW1lXCJdO1xuXG4gIEBWaWV3Q2hpbGQoXCJfcmVmXCIpIF9yZWYhOiBFbGVtZW50UmVmIHwgdW5kZWZpbmVkO1xuXG4gIF9pZDogREJOYXZpZ2F0aW9uU3RhdGVbXCJfaWRcIl0gPSBERUZBVUxUX0lEO1xuXG4gIC8qKlxuICAgKiBQYXNzZXMgYGFyaWEtKmAsIGBkYXRhLSpgICYgYGNsYXNzYCBhdHRyaWJ1dGVzIHRvIGNvcnJlY3QgY2hpbGQuIFVzZWQgaW4gYW5ndWxhciBhbmQgc3RlbmNpbC5cbiAgICogQHBhcmFtIGVsZW1lbnQgIHRoZSByZWYgZm9yIHRoZSBjb21wb25lbnRcbiAgICogQHBhcmFtIGN1c3RvbUVsZW1lbnRTZWxlY3RvciAgdGhlIGN1c3RvbSBlbGVtZW50IGxpa2UgYG15LWNvbXBvbmVudGBcbiAgICovXG4gIHByaXZhdGUgZW5hYmxlQXR0cmlidXRlUGFzc2luZyhcbiAgICBlbGVtZW50OiBIVE1MRWxlbWVudCB8IG51bGwsXG4gICAgY3VzdG9tRWxlbWVudFNlbGVjdG9yOiBzdHJpbmdcbiAgKSB7XG4gICAgY29uc3QgcGFyZW50ID0gZWxlbWVudD8uY2xvc2VzdChjdXN0b21FbGVtZW50U2VsZWN0b3IpO1xuICAgIGlmIChlbGVtZW50ICYmIHBhcmVudCkge1xuICAgICAgY29uc3QgYXR0cmlidXRlcyA9IHBhcmVudC5hdHRyaWJ1dGVzO1xuICAgICAgZm9yIChsZXQgaSA9IDA7IGkgPCBhdHRyaWJ1dGVzLmxlbmd0aDsgaSsrKSB7XG4gICAgICAgIGNvbnN0IGF0dHIgPSBhdHRyaWJ1dGVzLml0ZW0oaSk7XG4gICAgICAgIGlmIChcbiAgICAgICAgICBhdHRyICYmXG4gICAgICAgICAgKGF0dHIubmFtZS5zdGFydHNXaXRoKFwiZGF0YS1cIikgfHwgYXR0ci5uYW1lLnN0YXJ0c1dpdGgoXCJhcmlhLVwiKSlcbiAgICAgICAgKSB7XG4gICAgICAgICAgZWxlbWVudC5zZXRBdHRyaWJ1dGUoYXR0ci5uYW1lLCBhdHRyLnZhbHVlKTtcbiAgICAgICAgICBwYXJlbnQucmVtb3ZlQXR0cmlidXRlKGF0dHIubmFtZSk7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKGF0dHIgJiYgYXR0ci5uYW1lID09PSBcImNsYXNzXCIpIHtcbiAgICAgICAgICBjb25zdCBpc1dlYkNvbXBvbmVudCA9IGF0dHIudmFsdWUuaW5jbHVkZXMoXCJoeWRyYXRlZFwiKTtcbiAgICAgICAgICBjb25zdCB2YWx1ZSA9IGF0dHIudmFsdWUucmVwbGFjZShcImh5ZHJhdGVkXCIsIFwiXCIpLnRyaW0oKTtcbiAgICAgICAgICBjb25zdCBjdXJyZW50Q2xhc3MgPSBlbGVtZW50LmdldEF0dHJpYnV0ZShcImNsYXNzXCIpO1xuICAgICAgICAgIGVsZW1lbnQuc2V0QXR0cmlidXRlKFxuICAgICAgICAgICAgYXR0ci5uYW1lLFxuICAgICAgICAgICAgYCR7Y3VycmVudENsYXNzID8gYCR7Y3VycmVudENsYXNzfSBgIDogXCJcIn0ke3ZhbHVlfWBcbiAgICAgICAgICApO1xuICAgICAgICAgIGlmIChpc1dlYkNvbXBvbmVudCkge1xuICAgICAgICAgICAgLy8gU3RlbmNpbCBpcyB1c2luZyB0aGlzIGNsYXNzIGZvciBsYXp5IGxvYWRpbmcgY29tcG9uZW50XG4gICAgICAgICAgICBwYXJlbnQuc2V0QXR0cmlidXRlKFwiY2xhc3NcIiwgXCJoeWRyYXRlZFwiKTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgcGFyZW50LnJlbW92ZUF0dHJpYnV0ZShhdHRyLm5hbWUpO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIG5nT25Jbml0KCkge1xuICAgIGlmICh0eXBlb2Ygd2luZG93ICE9PSBcInVuZGVmaW5lZFwiKSB7XG4gICAgICB0aGlzLl9pZCA9IHRoaXMuaWQgfHwgXCJuYXZpZ2F0aW9uLVwiICsgdXVpZCgpO1xuICAgIH1cbiAgfVxuXG4gIG5nQWZ0ZXJWaWV3SW5pdCgpIHtcbiAgICBjb25zdCBlbGVtZW50OiBIVE1MRWxlbWVudCB8IG51bGwgPSB0aGlzLl9yZWY/Lm5hdGl2ZUVsZW1lbnQ7XG4gICAgdGhpcy5lbmFibGVBdHRyaWJ1dGVQYXNzaW5nKGVsZW1lbnQsIFwiZGItbmF2aWdhdGlvblwiKTtcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/* Angular cannot handle multiple slots with the same name, we need to use Directives for this. */
|
|
2
|
+
import { Directive } from '@angular/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class NavigationContentDirective {
|
|
5
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NavigationContentDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
6
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: NavigationContentDirective, isStandalone: true, selector: "[dbNavigationContent]", ngImport: i0 }); }
|
|
7
|
+
}
|
|
8
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NavigationContentDirective, decorators: [{
|
|
9
|
+
type: Directive,
|
|
10
|
+
args: [{
|
|
11
|
+
selector: '[dbNavigationContent]',
|
|
12
|
+
standalone: true
|
|
13
|
+
}]
|
|
14
|
+
}] });
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTmF2aWdhdGlvbkNvbnRlbnQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vb3V0cHV0L2FuZ3VsYXIvc3JjL2NvbXBvbmVudHMvbmF2aWdhdGlvbi1pdGVtL05hdmlnYXRpb25Db250ZW50LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxrR0FBa0c7QUFDbEcsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFLMUMsTUFBTSxPQUFPLDBCQUEwQjsrR0FBMUIsMEJBQTBCO21HQUExQiwwQkFBMEI7OzRGQUExQiwwQkFBMEI7a0JBSnRDLFNBQVM7bUJBQUM7b0JBQ1YsUUFBUSxFQUFFLHVCQUF1QjtvQkFDakMsVUFBVSxFQUFFLElBQUk7aUJBQ2hCIiwic291cmNlc0NvbnRlbnQiOlsiLyogQW5ndWxhciBjYW5ub3QgaGFuZGxlIG11bHRpcGxlIHNsb3RzIHdpdGggdGhlIHNhbWUgbmFtZSwgd2UgbmVlZCB0byB1c2UgRGlyZWN0aXZlcyBmb3IgdGhpcy4gKi9cbmltcG9ydCB7IERpcmVjdGl2ZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuQERpcmVjdGl2ZSh7XG5cdHNlbGVjdG9yOiAnW2RiTmF2aWdhdGlvbkNvbnRlbnRdJyxcblx0c3RhbmRhbG9uZTogdHJ1ZVxufSlcbmV4cG9ydCBjbGFzcyBOYXZpZ2F0aW9uQ29udGVudERpcmVjdGl2ZSB7fVxuIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export { DBNavigationItem } from './navigation-item';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9vdXRwdXQvYW5ndWxhci9zcmMvY29tcG9uZW50cy9uYXZpZ2F0aW9uLWl0ZW0vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sbUJBQW1CLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBEQk5hdmlnYXRpb25JdGVtIH0gZnJvbSAnLi9uYXZpZ2F0aW9uLWl0ZW0nIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9vdXRwdXQvYW5ndWxhci9zcmMvY29tcG9uZW50cy9uYXZpZ2F0aW9uLWl0ZW0vbW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENsaWNrRXZlbnQsIENsaWNrRXZlbnRQcm9wcywgQ2xpY2tFdmVudFN0YXRlLCBHbG9iYWxQcm9wcywgR2xvYmFsU3RhdGUsIEljb25Qcm9wcywgSW5pdGlhbGl6ZWRTdGF0ZSwgTmF2aWdhdGlvbkJhY2tCdXR0b25Qcm9wcywgU2hvd0ljb25Qcm9wcywgVGV4dFByb3BzLCBXaWR0aFByb3BzIH0gZnJvbSAnLi4vLi4vc2hhcmVkL21vZGVsJztcbmltcG9ydCB7IE5hdmlnYXRpb25JdGVtU2FmZVRyaWFuZ2xlIH0gZnJvbSAnLi4vLi4vdXRpbHMvbmF2aWdhdGlvbic7XG5leHBvcnQgdHlwZSBEQk5hdmlnYXRpb25JdGVtRGVmYXVsdFByb3BzID0ge1xuICAvKipcbiAgICogQWx0ZXJuYXRpdmUgaW5kaWNhdG9yIGZvciBhY3RpdmUgbmF2aWdhdGlvbiBpdGVtIChib2xkIGZvbnQpLiBJbiBjb250cmFzdCB0byB0aGUgdXNlIG9mIGFyaWEtY3VycmVudD1cInBhZ2VcIiBvbiB0aGUgY29udGFpbmVkIGFuY2hvciwgdGhpcyBkb2VzIG5vdCBndWFyYW50ZWUgY29ycmVjdCBhMTF5LlxuICAgKi9cbiAgYWN0aXZlPzogYm9vbGVhbjtcblxuICAvKipcbiAgICogVGhlIGRpc2FibGVkIGF0dHJpYnV0ZSBjYW4gYmUgc2V0IHRvIFtrZWVwIGEgdXNlciBmcm9tIGNsaWNraW5nIG9uIHRoZSBpdGVtXShodHRwczovL2RldmVsb3Blci5tb3ppbGxhLm9yZy9lbi1VUy9kb2NzL1dlYi9IVE1ML0VsZW1lbnQvYnV0dG9uI2Rpc2FibGVkKS5cbiAgICovXG4gIGRpc2FibGVkPzogYm9vbGVhbjtcblxuICAvKipcbiAgICogUmVhY3Qtc3BlY2lmaWMgcHJvcGVydHkgdG8gcGFzcyBpbiBhIHNsb3QgZm9yIHN1Yi1uYXZpZ2F0aW9uXG4gICAqL1xuICBzdWJOYXZpZ2F0aW9uPzogYW55O1xuXG4gIC8qKlxuICAgKiBUaGlzIGlzIGZvciBtb2JpbGUgbmF2aWdhdGlvbiBvbmx5LCBpZiBpdCBpcyBzZXQgdGhlIHN1Yi1uYXZpZ2F0aW9uIGlzIGEgc3RhdGljIG92ZXJsYXlcbiAgICovXG4gIHN1Yk5hdmlnYXRpb25FeHBhbmRlZD86IGJvb2xlYW47XG59O1xuZXhwb3J0IHR5cGUgREJOYXZpZ2F0aW9uSXRlbVByb3BzID0gREJOYXZpZ2F0aW9uSXRlbURlZmF1bHRQcm9wcyAmIEdsb2JhbFByb3BzICYgQ2xpY2tFdmVudFByb3BzPEhUTUxCdXR0b25FbGVtZW50PiAmIEljb25Qcm9wcyAmIFdpZHRoUHJvcHMgJiBOYXZpZ2F0aW9uQmFja0J1dHRvblByb3BzICYgU2hvd0ljb25Qcm9wcyAmIFRleHRQcm9wcztcbmV4cG9ydCB0eXBlIERCTmF2aWdhdGlvbkl0ZW1EZWZhdWx0U3RhdGUgPSB7XG4gIGhhbmRsZUJhY2tDbGljazogKGV2ZW50OiBDbGlja0V2ZW50PEhUTUxCdXR0b25FbGVtZW50PikgPT4gdm9pZDtcbiAgaGFzQXJlYVBvcHVwOiBib29sZWFuO1xuICBpc1N1Yk5hdmlnYXRpb25FeHBhbmRlZDogYm9vbGVhbjtcbiAgc3ViTmF2aWdhdGlvbklkOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEludGVybmFsIHN0YXRlIHByb3BlcnR5IHRvIHNob3cvaGlkZSBzdWItbmF2aWdhdGlvbiBidXR0b25cbiAgICovXG4gIGhhc1N1Yk5hdmlnYXRpb24/OiBib29sZWFuO1xuICB1cGRhdGVTdWJOYXZpZ2F0aW9uU3RhdGU6ICgpID0+IHZvaWQ7XG4gIG5hdmlnYXRpb25JdGVtU2FmZVRyaWFuZ2xlPzogTmF2aWdhdGlvbkl0ZW1TYWZlVHJpYW5nbGU7XG59O1xuZXhwb3J0IHR5cGUgREJOYXZpZ2F0aW9uSXRlbVN0YXRlID0gREJOYXZpZ2F0aW9uSXRlbURlZmF1bHRTdGF0ZSAmIENsaWNrRXZlbnRTdGF0ZTxIVE1MQnV0dG9uRWxlbWVudD4gJiBHbG9iYWxTdGF0ZSAmIEluaXRpYWxpemVkU3RhdGUiXX0=
|
|
@@ -0,0 +1,236 @@
|
|
|
1
|
+
import { Output, EventEmitter, Component, ViewChild, Input, ContentChild, TemplateRef } from "@angular/core";
|
|
2
|
+
import { CommonModule } from "@angular/common";
|
|
3
|
+
import { DBButton } from "../button/button";
|
|
4
|
+
import { cls, getBooleanAsString, getHideProp, uuid } from "../../utils";
|
|
5
|
+
import { NavigationItemSafeTriangle } from "../../utils/navigation";
|
|
6
|
+
import { DEFAULT_BACK } from "../../shared/constants";
|
|
7
|
+
import { NavigationContentDirective } from './NavigationContent.directive';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "@angular/common";
|
|
10
|
+
const defaultProps = {};
|
|
11
|
+
export class DBNavigationItem {
|
|
12
|
+
constructor() {
|
|
13
|
+
this.cls = cls;
|
|
14
|
+
this.getBooleanAsString = getBooleanAsString;
|
|
15
|
+
this.getHideProp = getHideProp;
|
|
16
|
+
this.DEFAULT_BACK = DEFAULT_BACK;
|
|
17
|
+
this.onClick = new EventEmitter();
|
|
18
|
+
this.initialized = false;
|
|
19
|
+
this.hasAreaPopup = false;
|
|
20
|
+
this.hasSubNavigation = true;
|
|
21
|
+
this.isSubNavigationExpanded = false;
|
|
22
|
+
this.subNavigationId = "sub-navigation-" + uuid();
|
|
23
|
+
this.navigationItemSafeTriangle = undefined;
|
|
24
|
+
}
|
|
25
|
+
handleClick(event) {
|
|
26
|
+
if (this.onClick) {
|
|
27
|
+
this.onClick.emit(event);
|
|
28
|
+
}
|
|
29
|
+
if (this.hasAreaPopup) {
|
|
30
|
+
this.isSubNavigationExpanded = true;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
handleBackClick(event) {
|
|
34
|
+
event.stopPropagation();
|
|
35
|
+
this.isSubNavigationExpanded = false;
|
|
36
|
+
}
|
|
37
|
+
updateSubNavigationState() {
|
|
38
|
+
if (this.initialized && document && this.subNavigationId) {
|
|
39
|
+
const subNavigationSlot = document?.getElementById(this.subNavigationId);
|
|
40
|
+
if (subNavigationSlot) {
|
|
41
|
+
if (subNavigationSlot.children?.length > 0) {
|
|
42
|
+
this.hasAreaPopup = true;
|
|
43
|
+
if (!this.navigationItemSafeTriangle) {
|
|
44
|
+
this.navigationItemSafeTriangle = new NavigationItemSafeTriangle(this._ref?.nativeElement, subNavigationSlot);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
this.hasSubNavigation = false;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.
|
|
55
|
+
* @param element the ref for the component
|
|
56
|
+
* @param customElementSelector the custom element like `my-component`
|
|
57
|
+
*/
|
|
58
|
+
enableAttributePassing(element, customElementSelector) {
|
|
59
|
+
const parent = element?.closest(customElementSelector);
|
|
60
|
+
if (element && parent) {
|
|
61
|
+
const attributes = parent.attributes;
|
|
62
|
+
for (let i = 0; i < attributes.length; i++) {
|
|
63
|
+
const attr = attributes.item(i);
|
|
64
|
+
if (attr &&
|
|
65
|
+
(attr.name.startsWith("data-") || attr.name.startsWith("aria-"))) {
|
|
66
|
+
element.setAttribute(attr.name, attr.value);
|
|
67
|
+
parent.removeAttribute(attr.name);
|
|
68
|
+
}
|
|
69
|
+
if (attr && attr.name === "class") {
|
|
70
|
+
const isWebComponent = attr.value.includes("hydrated");
|
|
71
|
+
const value = attr.value.replace("hydrated", "").trim();
|
|
72
|
+
const currentClass = element.getAttribute("class");
|
|
73
|
+
element.setAttribute(attr.name, `${currentClass ? `${currentClass} ` : ""}${value}`);
|
|
74
|
+
if (isWebComponent) {
|
|
75
|
+
// Stencil is using this class for lazy loading component
|
|
76
|
+
parent.setAttribute("class", "hydrated");
|
|
77
|
+
}
|
|
78
|
+
else {
|
|
79
|
+
parent.removeAttribute(attr.name);
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
ngOnInit() {
|
|
86
|
+
if (typeof window !== "undefined") {
|
|
87
|
+
this.initialized = true;
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
ngAfterViewInit() {
|
|
91
|
+
const element = this._ref?.nativeElement;
|
|
92
|
+
this.enableAttributePassing(element, "db-navigation-item");
|
|
93
|
+
}
|
|
94
|
+
ngAfterContentChecked(changes) {
|
|
95
|
+
if (typeof window !== "undefined") {
|
|
96
|
+
if (this.subNavigationExpanded !== undefined) {
|
|
97
|
+
this.isSubNavigationExpanded = !!this.subNavigationExpanded;
|
|
98
|
+
}
|
|
99
|
+
this.updateSubNavigationState();
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DBNavigationItem, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
103
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DBNavigationItem, isStandalone: true, selector: "db-navigation-item", inputs: { subNavigationExpanded: "subNavigationExpanded", id: "id", className: "className", width: "width", icon: "icon", showIcon: "showIcon", active: "active", disabled: "disabled", text: "text", backButtonId: "backButtonId", backButtonText: "backButtonText" }, outputs: { onClick: "onClick" }, queries: [{ propertyName: "dbNavigationContent", first: true, predicate: NavigationContentDirective, descendants: true, read: TemplateRef }], viewQueries: [{ propertyName: "_ref", first: true, predicate: ["_ref"], descendants: true }], ngImport: i0, template: `
|
|
104
|
+
<li
|
|
105
|
+
#_ref
|
|
106
|
+
[attr.id]="id"
|
|
107
|
+
(mouseover)="navigationItemSafeTriangle?.enableFollow()"
|
|
108
|
+
(mouseleave)="navigationItemSafeTriangle?.disableFollow()"
|
|
109
|
+
(mousemove)="navigationItemSafeTriangle?.followByMouseEvent($event)"
|
|
110
|
+
[class]="cls('db-navigation-item', className)"
|
|
111
|
+
[attr.data-width]="width"
|
|
112
|
+
[attr.data-icon]="icon"
|
|
113
|
+
[attr.data-hide-icon]="getHideProp(showIcon)"
|
|
114
|
+
[attr.data-active]="active"
|
|
115
|
+
[attr.aria-disabled]="getBooleanAsString(disabled)"
|
|
116
|
+
>
|
|
117
|
+
<ng-container *ngIf="!hasSubNavigation">
|
|
118
|
+
<ng-container *ngIf="text">{{text}}</ng-container>
|
|
119
|
+
<ng-container *ngIf="!(text)"><ng-content *ngTemplateOutlet="dbNavigationContent"></ng-content></ng-container>
|
|
120
|
+
</ng-container>
|
|
121
|
+
<ng-container *ngIf="hasSubNavigation">
|
|
122
|
+
<button
|
|
123
|
+
class="db-navigation-item-expand-button"
|
|
124
|
+
[attr.aria-haspopup]="hasAreaPopup"
|
|
125
|
+
[attr.aria-expanded]="isSubNavigationExpanded"
|
|
126
|
+
[attr.disabled]="disabled"
|
|
127
|
+
(click)="handleClick($event)"
|
|
128
|
+
>
|
|
129
|
+
<ng-container *ngIf="text">{{text}}</ng-container>
|
|
130
|
+
<ng-container *ngIf="!(text)"><ng-content *ngTemplateOutlet="dbNavigationContent"></ng-content></ng-container>
|
|
131
|
+
</button>
|
|
132
|
+
<menu class="db-sub-navigation" [attr.id]="subNavigationId">
|
|
133
|
+
<ng-container *ngIf="hasAreaPopup">
|
|
134
|
+
<div class="db-mobile-navigation-back">
|
|
135
|
+
<db-button
|
|
136
|
+
icon="arrow_left"
|
|
137
|
+
variant="ghost"
|
|
138
|
+
[id]="backButtonId"
|
|
139
|
+
(click)="handleBackClick($event)"
|
|
140
|
+
>
|
|
141
|
+
{{backButtonText ?? DEFAULT_BACK}}
|
|
142
|
+
</db-button>
|
|
143
|
+
</div>
|
|
144
|
+
</ng-container>
|
|
145
|
+
<ng-content select="[sub-navigation]"></ng-content>
|
|
146
|
+
</menu>
|
|
147
|
+
</ng-container>
|
|
148
|
+
</li>
|
|
149
|
+
`, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: DBButton, selector: "db-button", inputs: ["id", "className", "type", "disabled", "label", "icon", "showIcon", "size", "state", "width", "variant", "noText", "name", "value", "describedbyid", "ariaexpanded", "ariapressed", "text"], outputs: ["onClick"] }] }); }
|
|
150
|
+
}
|
|
151
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DBNavigationItem, decorators: [{
|
|
152
|
+
type: Component,
|
|
153
|
+
args: [{
|
|
154
|
+
selector: "db-navigation-item",
|
|
155
|
+
template: `
|
|
156
|
+
<li
|
|
157
|
+
#_ref
|
|
158
|
+
[attr.id]="id"
|
|
159
|
+
(mouseover)="navigationItemSafeTriangle?.enableFollow()"
|
|
160
|
+
(mouseleave)="navigationItemSafeTriangle?.disableFollow()"
|
|
161
|
+
(mousemove)="navigationItemSafeTriangle?.followByMouseEvent($event)"
|
|
162
|
+
[class]="cls('db-navigation-item', className)"
|
|
163
|
+
[attr.data-width]="width"
|
|
164
|
+
[attr.data-icon]="icon"
|
|
165
|
+
[attr.data-hide-icon]="getHideProp(showIcon)"
|
|
166
|
+
[attr.data-active]="active"
|
|
167
|
+
[attr.aria-disabled]="getBooleanAsString(disabled)"
|
|
168
|
+
>
|
|
169
|
+
<ng-container *ngIf="!hasSubNavigation">
|
|
170
|
+
<ng-container *ngIf="text">{{text}}</ng-container>
|
|
171
|
+
<ng-container *ngIf="!(text)"><ng-content *ngTemplateOutlet="dbNavigationContent"></ng-content></ng-container>
|
|
172
|
+
</ng-container>
|
|
173
|
+
<ng-container *ngIf="hasSubNavigation">
|
|
174
|
+
<button
|
|
175
|
+
class="db-navigation-item-expand-button"
|
|
176
|
+
[attr.aria-haspopup]="hasAreaPopup"
|
|
177
|
+
[attr.aria-expanded]="isSubNavigationExpanded"
|
|
178
|
+
[attr.disabled]="disabled"
|
|
179
|
+
(click)="handleClick($event)"
|
|
180
|
+
>
|
|
181
|
+
<ng-container *ngIf="text">{{text}}</ng-container>
|
|
182
|
+
<ng-container *ngIf="!(text)"><ng-content *ngTemplateOutlet="dbNavigationContent"></ng-content></ng-container>
|
|
183
|
+
</button>
|
|
184
|
+
<menu class="db-sub-navigation" [attr.id]="subNavigationId">
|
|
185
|
+
<ng-container *ngIf="hasAreaPopup">
|
|
186
|
+
<div class="db-mobile-navigation-back">
|
|
187
|
+
<db-button
|
|
188
|
+
icon="arrow_left"
|
|
189
|
+
variant="ghost"
|
|
190
|
+
[id]="backButtonId"
|
|
191
|
+
(click)="handleBackClick($event)"
|
|
192
|
+
>
|
|
193
|
+
{{backButtonText ?? DEFAULT_BACK}}
|
|
194
|
+
</db-button>
|
|
195
|
+
</div>
|
|
196
|
+
</ng-container>
|
|
197
|
+
<ng-content select="[sub-navigation]"></ng-content>
|
|
198
|
+
</menu>
|
|
199
|
+
</ng-container>
|
|
200
|
+
</li>
|
|
201
|
+
`,
|
|
202
|
+
standalone: true,
|
|
203
|
+
imports: [CommonModule, DBButton],
|
|
204
|
+
}]
|
|
205
|
+
}], propDecorators: { dbNavigationContent: [{
|
|
206
|
+
type: ContentChild,
|
|
207
|
+
args: [NavigationContentDirective, { read: TemplateRef }]
|
|
208
|
+
}], subNavigationExpanded: [{
|
|
209
|
+
type: Input
|
|
210
|
+
}], id: [{
|
|
211
|
+
type: Input
|
|
212
|
+
}], className: [{
|
|
213
|
+
type: Input
|
|
214
|
+
}], width: [{
|
|
215
|
+
type: Input
|
|
216
|
+
}], icon: [{
|
|
217
|
+
type: Input
|
|
218
|
+
}], showIcon: [{
|
|
219
|
+
type: Input
|
|
220
|
+
}], active: [{
|
|
221
|
+
type: Input
|
|
222
|
+
}], disabled: [{
|
|
223
|
+
type: Input
|
|
224
|
+
}], text: [{
|
|
225
|
+
type: Input
|
|
226
|
+
}], backButtonId: [{
|
|
227
|
+
type: Input
|
|
228
|
+
}], backButtonText: [{
|
|
229
|
+
type: Input
|
|
230
|
+
}], onClick: [{
|
|
231
|
+
type: Output
|
|
232
|
+
}], _ref: [{
|
|
233
|
+
type: ViewChild,
|
|
234
|
+
args: ["_ref"]
|
|
235
|
+
}] } });
|
|
236
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navigation-item.js","sourceRoot":"","sources":["../../../../../output/angular/src/components/navigation-item/navigation-item.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Output,\n  EventEmitter,\n  Component,\n  ViewChild,\n  ElementRef,\n  Input,\n  SimpleChanges,\nContentChild, TemplateRef } from  \"@angular/core\";\nimport { CommonModule } from \"@angular/common\";\n\nconst defaultProps = {};\n\nimport { DBNavigationItemProps, DBNavigationItemState } from \"./model\";\nimport { DBButton } from \"../button/button\";\nimport { cls, getBooleanAsString, getHideProp, uuid } from \"../../utils\";\nimport { NavigationItemSafeTriangle } from \"../../utils/navigation\";\nimport { DEFAULT_BACK } from \"../../shared/constants\";\nimport { ClickEvent } from \"../../shared/model\";\n\nimport { NavigationContentDirective } from './NavigationContent.directive';\n\n@Component({\n  selector: \"db-navigation-item\",\n  template: `\n    <li\n      #_ref\n      [attr.id]=\"id\"\n      (mouseover)=\"navigationItemSafeTriangle?.enableFollow()\"\n      (mouseleave)=\"navigationItemSafeTriangle?.disableFollow()\"\n      (mousemove)=\"navigationItemSafeTriangle?.followByMouseEvent($event)\"\n      [class]=\"cls('db-navigation-item', className)\"\n      [attr.data-width]=\"width\"\n      [attr.data-icon]=\"icon\"\n      [attr.data-hide-icon]=\"getHideProp(showIcon)\"\n      [attr.data-active]=\"active\"\n      [attr.aria-disabled]=\"getBooleanAsString(disabled)\"\n    >\n      <ng-container *ngIf=\"!hasSubNavigation\">\n        <ng-container *ngIf=\"text\">{{text}}</ng-container>\n        <ng-container *ngIf=\"!(text)\"><ng-content *ngTemplateOutlet=\"dbNavigationContent\"></ng-content></ng-container>\n      </ng-container>\n      <ng-container *ngIf=\"hasSubNavigation\">\n        <button\n          class=\"db-navigation-item-expand-button\"\n          [attr.aria-haspopup]=\"hasAreaPopup\"\n          [attr.aria-expanded]=\"isSubNavigationExpanded\"\n          [attr.disabled]=\"disabled\"\n          (click)=\"handleClick($event)\"\n        >\n          <ng-container *ngIf=\"text\">{{text}}</ng-container>\n          <ng-container *ngIf=\"!(text)\"><ng-content *ngTemplateOutlet=\"dbNavigationContent\"></ng-content></ng-container>\n        </button>\n        <menu class=\"db-sub-navigation\" [attr.id]=\"subNavigationId\">\n          <ng-container *ngIf=\"hasAreaPopup\">\n            <div class=\"db-mobile-navigation-back\">\n              <db-button\n                icon=\"arrow_left\"\n                variant=\"ghost\"\n                [id]=\"backButtonId\"\n                (click)=\"handleBackClick($event)\"\n              >\n                {{backButtonText ?? DEFAULT_BACK}}\n              </db-button>\n            </div>\n          </ng-container>\n          <ng-content select=\"[sub-navigation]\"></ng-content>\n        </menu>\n      </ng-container>\n    </li>\n  `,\n  standalone: true,\n  imports: [CommonModule, DBButton],\n})\nexport class DBNavigationItem {\n\t@ContentChild(NavigationContentDirective, { read: TemplateRef }) dbNavigationContent: any;\n  cls = cls;\n  getBooleanAsString = getBooleanAsString;\n  getHideProp = getHideProp;\n  DEFAULT_BACK = DEFAULT_BACK;\n\n  @Input()\n  subNavigationExpanded!: DBNavigationItemProps[\"subNavigationExpanded\"];\n  @Input() id!: DBNavigationItemProps[\"id\"];\n  @Input() className!: DBNavigationItemProps[\"className\"];\n  @Input() width!: DBNavigationItemProps[\"width\"];\n  @Input() icon!: DBNavigationItemProps[\"icon\"];\n  @Input() showIcon!: DBNavigationItemProps[\"showIcon\"];\n  @Input() active!: DBNavigationItemProps[\"active\"];\n  @Input() disabled!: DBNavigationItemProps[\"disabled\"];\n  @Input() text!: DBNavigationItemProps[\"text\"];\n  @Input() backButtonId!: DBNavigationItemProps[\"backButtonId\"];\n  @Input() backButtonText!: DBNavigationItemProps[\"backButtonText\"];\n\n  @Output() onClick = new EventEmitter();\n\n  @ViewChild(\"_ref\") _ref!: ElementRef | undefined;\n\n  initialized: DBNavigationItemState[\"initialized\"] = false;\n  hasAreaPopup: DBNavigationItemState[\"hasAreaPopup\"] = false;\n  hasSubNavigation: DBNavigationItemState[\"hasSubNavigation\"] = true;\n  isSubNavigationExpanded: DBNavigationItemState[\"isSubNavigationExpanded\"] =\n    false;\n  subNavigationId: DBNavigationItemState[\"subNavigationId\"] =\n    \"sub-navigation-\" + uuid();\n  navigationItemSafeTriangle: DBNavigationItemState[\"navigationItemSafeTriangle\"] =\n    undefined;\n  handleClick(\n    event: ClickEvent<HTMLButtonElement>\n  ): ReturnType<DBNavigationItemState[\"handleClick\"]> {\n    if (this.onClick) {\n      this.onClick.emit(event);\n    }\n    if (this.hasAreaPopup) {\n      this.isSubNavigationExpanded = true;\n    }\n  }\n  handleBackClick(\n    event: ClickEvent<HTMLButtonElement>\n  ): ReturnType<DBNavigationItemState[\"handleBackClick\"]> {\n    event.stopPropagation();\n    this.isSubNavigationExpanded = false;\n  }\n  updateSubNavigationState(): ReturnType<\n    DBNavigationItemState[\"updateSubNavigationState\"]\n  > {\n    if (this.initialized && document && this.subNavigationId) {\n      const subNavigationSlot = document?.getElementById(\n        this.subNavigationId\n      ) as HTMLMenuElement;\n      if (subNavigationSlot) {\n        if (subNavigationSlot.children?.length > 0) {\n          this.hasAreaPopup = true;\n          if (!this.navigationItemSafeTriangle) {\n            this.navigationItemSafeTriangle = new NavigationItemSafeTriangle(\n              this._ref?.nativeElement,\n              subNavigationSlot\n            );\n          }\n        } else {\n          this.hasSubNavigation = false;\n        }\n      }\n    }\n  }\n\n  /**\n   * Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.\n   * @param element  the ref for the component\n   * @param customElementSelector  the custom element like `my-component`\n   */\n  private enableAttributePassing(\n    element: HTMLElement | null,\n    customElementSelector: string\n  ) {\n    const parent = element?.closest(customElementSelector);\n    if (element && parent) {\n      const attributes = parent.attributes;\n      for (let i = 0; i < attributes.length; i++) {\n        const attr = attributes.item(i);\n        if (\n          attr &&\n          (attr.name.startsWith(\"data-\") || attr.name.startsWith(\"aria-\"))\n        ) {\n          element.setAttribute(attr.name, attr.value);\n          parent.removeAttribute(attr.name);\n        }\n        if (attr && attr.name === \"class\") {\n          const isWebComponent = attr.value.includes(\"hydrated\");\n          const value = attr.value.replace(\"hydrated\", \"\").trim();\n          const currentClass = element.getAttribute(\"class\");\n          element.setAttribute(\n            attr.name,\n            `${currentClass ? `${currentClass} ` : \"\"}${value}`\n          );\n          if (isWebComponent) {\n            // Stencil is using this class for lazy loading component\n            parent.setAttribute(\"class\", \"hydrated\");\n          } else {\n            parent.removeAttribute(attr.name);\n          }\n        }\n      }\n    }\n  }\n\n  ngOnInit() {\n    if (typeof window !== \"undefined\") {\n      this.initialized = true;\n    }\n  }\n\n  ngAfterViewInit() {\n    const element: HTMLElement | null = this._ref?.nativeElement;\n    this.enableAttributePassing(element, \"db-navigation-item\");\n  }\n\n  ngAfterContentChecked(changes: SimpleChanges) {\n    if (typeof window !== \"undefined\") {\n      if (this.subNavigationExpanded !== undefined) {\n        this.isSubNavigationExpanded = !!this.subNavigationExpanded;\n      }\n      this.updateSubNavigationState();\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export { DBNotification } from './notification';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9vdXRwdXQvYW5ndWxhci9zcmMvY29tcG9uZW50cy9ub3RpZmljYXRpb24vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGdCQUFnQixDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgREJOb3RpZmljYXRpb24gfSBmcm9tICcuL25vdGlmaWNhdGlvbiciXX0=
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export const NotificationVariantList = ['docked', 'standalone', 'overlay'];
|
|
2
|
+
export const NotificationLinkVariantList = ['block', 'inline'];
|
|
3
|
+
export const NotificationAriaLiveList = ['assertive', 'polite', 'off'];
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9vdXRwdXQvYW5ndWxhci9zcmMvY29tcG9uZW50cy9ub3RpZmljYXRpb24vbW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsTUFBTSxDQUFDLE1BQU0sdUJBQXVCLEdBQUksQ0FBQyxRQUFRLEVBQUUsWUFBWSxFQUFFLFNBQVMsQ0FBVyxDQUFDO0FBRXRGLE1BQU0sQ0FBQyxNQUFNLDJCQUEyQixHQUFJLENBQUMsT0FBTyxFQUFFLFFBQVEsQ0FBVyxDQUFDO0FBRTFFLE1BQU0sQ0FBQyxNQUFNLHdCQUF3QixHQUFJLENBQUMsV0FBVyxFQUFFLFFBQVEsRUFBRSxLQUFLLENBQVcsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENsb3NlRXZlbnRQcm9wcywgQ2xvc2VFdmVudFN0YXRlLCBHbG9iYWxQcm9wcywgR2xvYmFsU3RhdGUsIEljb25Qcm9wcywgSW5uZXJDbG9zZUJ1dHRvblByb3BzLCBQb3BvdmVyUHJvcHMsIFNlbWFudGljUHJvcHMsIFNob3dJY29uUHJvcHMsIFRleHRQcm9wcyB9IGZyb20gJy4uLy4uL3NoYXJlZC9tb2RlbCc7XG5leHBvcnQgY29uc3QgTm90aWZpY2F0aW9uVmFyaWFudExpc3QgPSAoWydkb2NrZWQnLCAnc3RhbmRhbG9uZScsICdvdmVybGF5J10gYXMgY29uc3QpO1xuZXhwb3J0IHR5cGUgTm90aWZpY2F0aW9uVmFyaWFudFR5cGUgPSAodHlwZW9mIE5vdGlmaWNhdGlvblZhcmlhbnRMaXN0KVtudW1iZXJdO1xuZXhwb3J0IGNvbnN0IE5vdGlmaWNhdGlvbkxpbmtWYXJpYW50TGlzdCA9IChbJ2Jsb2NrJywgJ2lubGluZSddIGFzIGNvbnN0KTtcbmV4cG9ydCB0eXBlIE5vdGlmaWNhdGlvbkxpbmtWYXJpYW50VHlwZSA9ICh0eXBlb2YgTm90aWZpY2F0aW9uTGlua1ZhcmlhbnRMaXN0KVtudW1iZXJdO1xuZXhwb3J0IGNvbnN0IE5vdGlmaWNhdGlvbkFyaWFMaXZlTGlzdCA9IChbJ2Fzc2VydGl2ZScsICdwb2xpdGUnLCAnb2ZmJ10gYXMgY29uc3QpO1xuZXhwb3J0IHR5cGUgTm90aWZpY2F0aW9uQXJpYUxpdmVUeXBlID0gKHR5cGVvZiBOb3RpZmljYXRpb25BcmlhTGl2ZUxpc3QpW251bWJlcl07XG5leHBvcnQgdHlwZSBEQk5vdGlmaWNhdGlvbkRlZmF1bHRQcm9wcyA9IHtcbiAgLyoqXG4gICAqIFRoZSBhcmlhbGl2ZSBhdHRyaWJ1dGUgd2lsbCBsZWFkIHRvIHRoYXQgdGhlIHNjcmVlbnJlYWRlciBpbnRlcnJ1cHRzIGltbWVkaWF0ZWx5XG4gICAqIGFuZCByZWFkcyBvdXQgdGhlIG5vdGlmaWNhdGlvbiBpZiBzZXQgdG8gXCJhc3NlcnRpdmVcIiwgd2hpbGUgaXQgd2lsbCB3YWl0IGZvciB0aGVcbiAgICogdXNlcidzIGlkbGVuZXNzIHdoZW4gc2V0IHRvIFwicG9saXRlXCIsIGNvbXBhcmUgdG8gW2FyaWEtbGl2ZV0oaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQWNjZXNzaWJpbGl0eS9BUklBL0F0dHJpYnV0ZXMvYXJpYS1saXZlKVxuICAgKi9cbiAgYXJpYUxpdmU/OiBOb3RpZmljYXRpb25BcmlhTGl2ZVR5cGU7XG5cbiAgLyoqXG4gICAqIFRoZSBjbG9zZWFibGUgYXR0cmlidXRlIHNob3dzL2hpZGVzIHRoZSBjbG9zZSBidXR0b24gb24gdGhlIHRvcCByaWdodC5cbiAgICovXG4gIGNsb3NlYWJsZT86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIFRoZSBoZWFkbGluZSBhdHRyaWJ1dGUgY2hhbmdlcyB0aGUgdGV4dCBvZiB0aGUgYm9sZCBoZWFkbGluZS5cbiAgICovXG4gIGhlYWRsaW5lPzogc3RyaW5nIHwgYW55O1xuXG4gIC8qKlxuICAgKiBUaGUgc2xvdEltYWdlIGNhbiBiZSBzZXQgaW5zdGVhZCBvZiBhbiBpY29uLlxuICAgKi9cbiAgaW1hZ2U/OiBhbnk7XG5cbiAgLyoqXG4gICAqIFRoZSBzbG90TGluayBjYW4gYmUgc2V0IGZvciBub24gb3ZlcmxheS1ub3RpZmljYXRpb25zXG4gICAqL1xuICBsaW5rPzogYW55O1xuXG4gIC8qKlxuICAgKiBUaGUgbGlua1ZhcmlhbnQgd2lsbCBiZSB1c2VkIGlmIHNsb3RMaW5rIGlzIHNldC5cbiAgICovXG4gIGxpbmtWYXJpYW50PzogTm90aWZpY2F0aW9uTGlua1ZhcmlhbnRUeXBlO1xuXG4gIC8qKlxuICAgKiBFbmFibGVzIG9yIGRpc2FibGVzIHRoZSB2aXNpYmlsaXR5IG9mIHRoZSBoZWFkbGluZS5cbiAgICovXG4gIHNob3dIZWFkbGluZT86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIFRoZSB0aW1lc3RhbXAgYXR0cmlidXRlIGNhbiBiZSBzZXQgZm9yIG92ZXJsYXkgbm90aWZpY2F0aW9uc1xuICAgKi9cbiAgdGltZXN0YW1wPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBFbmFibGVzIG9yIGRpc2FibGVzIHRoZSB2aXNpYmlsaXR5IG9mIHRoZSB0aW1lc3RhbXAuXG4gICAqL1xuICBzaG93VGltZXN0YW1wPzogYm9vbGVhbjtcblxuICAvKipcbiAgICogVGhlIHZhcmlhbnQgYXR0cmlidXRlIGNoYW5nZXMgdGhlIHN0eWxpbmcgb2YgdGhlIG5vdGlmaWNhdGlvbi5cbiAgICogVGhlIGRvY2tlZCBub3RpZmljYXRpb25zIGFyZSB1c2VkIGUuZy4gYmV0d2VlbiBoZWFkZXIgYW5kIG1haW4gY29udGVudCB0byBzaG93IGEgZ2xvYmFsIGFsZXJ0LlxuICAgKiBUaGUgc3RhbmRhbG9uZSBub3RpZmljYXRpb25zIGFyZSB1c2VkICBlLmcuIGluc2lkZSBhIGZvcm0gdG8gc2hvdyBhbiBhbGVydCBmb3IgYSBzcGVjaWZpYyBmaWVsZC5cbiAgICogVGhlIG92ZXJsYXkgbm90aWZpY2F0aW9ucyBhcmUgdXNlZCBmb3IgYWJzb2x1dGUgYW5kIGZsb2F0aW5nIG5vdGlmaWNhdGlvbnMgbGlrZSBzbmFja2JhcnMgZXRjLlxuICAgKi9cbiAgdmFyaWFudD86IE5vdGlmaWNhdGlvblZhcmlhbnRUeXBlO1xufTtcbmV4cG9ydCB0eXBlIERCTm90aWZpY2F0aW9uUHJvcHMgPSBEQk5vdGlmaWNhdGlvbkRlZmF1bHRQcm9wcyAmIEdsb2JhbFByb3BzICYgQ2xvc2VFdmVudFByb3BzICYgSWNvblByb3BzICYgU2VtYW50aWNQcm9wcyAmIElubmVyQ2xvc2VCdXR0b25Qcm9wcyAmIFBvcG92ZXJQcm9wcyAmIFNob3dJY29uUHJvcHMgJiBUZXh0UHJvcHM7XG5leHBvcnQgdHlwZSBEQk5vdGlmaWNhdGlvbkRlZmF1bHRTdGF0ZSA9IHt9O1xuZXhwb3J0IHR5cGUgREJOb3RpZmljYXRpb25TdGF0ZSA9IERCTm90aWZpY2F0aW9uRGVmYXVsdFN0YXRlICYgR2xvYmFsU3RhdGUgJiBDbG9zZUV2ZW50U3RhdGUiXX0=
|