@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,181 @@
|
|
|
1
|
+
import { Output, EventEmitter, Component, ViewChild, Input, } from "@angular/core";
|
|
2
|
+
import { CommonModule } from "@angular/common";
|
|
3
|
+
import { DBButton } from "../button/button";
|
|
4
|
+
import { DEFAULT_CLOSE_BUTTON } from "../../shared/constants";
|
|
5
|
+
import { cls, getHideProp, stringPropVisible } from "../../utils";
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@angular/common";
|
|
8
|
+
const defaultProps = {};
|
|
9
|
+
export class DBNotification {
|
|
10
|
+
constructor() {
|
|
11
|
+
this.DEFAULT_CLOSE_BUTTON = DEFAULT_CLOSE_BUTTON;
|
|
12
|
+
this.cls = cls;
|
|
13
|
+
this.getHideProp = getHideProp;
|
|
14
|
+
this.stringPropVisible = stringPropVisible;
|
|
15
|
+
this.onClose = new EventEmitter();
|
|
16
|
+
}
|
|
17
|
+
handleClose(event) {
|
|
18
|
+
if (this.onClose) {
|
|
19
|
+
this.onClose.emit();
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.
|
|
24
|
+
* @param element the ref for the component
|
|
25
|
+
* @param customElementSelector the custom element like `my-component`
|
|
26
|
+
*/
|
|
27
|
+
enableAttributePassing(element, customElementSelector) {
|
|
28
|
+
const parent = element?.closest(customElementSelector);
|
|
29
|
+
if (element && parent) {
|
|
30
|
+
const attributes = parent.attributes;
|
|
31
|
+
for (let i = 0; i < attributes.length; i++) {
|
|
32
|
+
const attr = attributes.item(i);
|
|
33
|
+
if (attr &&
|
|
34
|
+
(attr.name.startsWith("data-") || attr.name.startsWith("aria-"))) {
|
|
35
|
+
element.setAttribute(attr.name, attr.value);
|
|
36
|
+
parent.removeAttribute(attr.name);
|
|
37
|
+
}
|
|
38
|
+
if (attr && attr.name === "class") {
|
|
39
|
+
const isWebComponent = attr.value.includes("hydrated");
|
|
40
|
+
const value = attr.value.replace("hydrated", "").trim();
|
|
41
|
+
const currentClass = element.getAttribute("class");
|
|
42
|
+
element.setAttribute(attr.name, `${currentClass ? `${currentClass} ` : ""}${value}`);
|
|
43
|
+
if (isWebComponent) {
|
|
44
|
+
// Stencil is using this class for lazy loading component
|
|
45
|
+
parent.setAttribute("class", "hydrated");
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
parent.removeAttribute(attr.name);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
ngAfterViewInit() {
|
|
55
|
+
const element = this._ref?.nativeElement;
|
|
56
|
+
this.enableAttributePassing(element, "db-notification");
|
|
57
|
+
}
|
|
58
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DBNotification, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
59
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DBNotification, isStandalone: true, selector: "db-notification", inputs: { id: "id", className: "className", ariaLive: "ariaLive", semantic: "semantic", variant: "variant", icon: "icon", showIcon: "showIcon", linkVariant: "linkVariant", headline: "headline", showHeadline: "showHeadline", text: "text", timestamp: "timestamp", showTimestamp: "showTimestamp", closeable: "closeable", closeButtonId: "closeButtonId", closeButtonText: "closeButtonText" }, outputs: { onClose: "onClose" }, viewQueries: [{ propertyName: "_ref", first: true, predicate: ["_ref"], descendants: true }], ngImport: i0, template: `
|
|
60
|
+
<article
|
|
61
|
+
#_ref
|
|
62
|
+
[attr.id]="id"
|
|
63
|
+
[class]="cls('db-notification', className)"
|
|
64
|
+
[attr.aria-live]="ariaLive"
|
|
65
|
+
[attr.data-semantic]="semantic"
|
|
66
|
+
[attr.data-variant]="variant"
|
|
67
|
+
[attr.data-icon]="icon"
|
|
68
|
+
[attr.data-hide-icon]="getHideProp(showIcon)"
|
|
69
|
+
[attr.data-link-variant]="linkVariant"
|
|
70
|
+
>
|
|
71
|
+
<ng-content select="[image]"></ng-content>
|
|
72
|
+
<ng-container *ngIf="stringPropVisible(headline, showHeadline)">
|
|
73
|
+
<header>{{headline}}</header>
|
|
74
|
+
</ng-container>
|
|
75
|
+
<p>
|
|
76
|
+
<ng-container *ngIf="text">{{text}}</ng-container>
|
|
77
|
+
<ng-container *ngIf="!(text)"><ng-content></ng-content></ng-container>
|
|
78
|
+
</p>
|
|
79
|
+
<ng-container *ngIf="stringPropVisible(timestamp, showTimestamp)">
|
|
80
|
+
<span>{{timestamp}}</span>
|
|
81
|
+
</ng-container>
|
|
82
|
+
<ng-content select="[link]"></ng-content>
|
|
83
|
+
<ng-container *ngIf="closeable">
|
|
84
|
+
<db-button
|
|
85
|
+
icon="cross"
|
|
86
|
+
variant="ghost"
|
|
87
|
+
size="small"
|
|
88
|
+
[id]="closeButtonId"
|
|
89
|
+
[noText]="true"
|
|
90
|
+
(click)="handleClose($event)"
|
|
91
|
+
>
|
|
92
|
+
{{closeButtonText ?? DEFAULT_CLOSE_BUTTON}}
|
|
93
|
+
</db-button>
|
|
94
|
+
</ng-container>
|
|
95
|
+
</article>
|
|
96
|
+
`, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { 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"] }] }); }
|
|
97
|
+
}
|
|
98
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DBNotification, decorators: [{
|
|
99
|
+
type: Component,
|
|
100
|
+
args: [{
|
|
101
|
+
selector: "db-notification",
|
|
102
|
+
template: `
|
|
103
|
+
<article
|
|
104
|
+
#_ref
|
|
105
|
+
[attr.id]="id"
|
|
106
|
+
[class]="cls('db-notification', className)"
|
|
107
|
+
[attr.aria-live]="ariaLive"
|
|
108
|
+
[attr.data-semantic]="semantic"
|
|
109
|
+
[attr.data-variant]="variant"
|
|
110
|
+
[attr.data-icon]="icon"
|
|
111
|
+
[attr.data-hide-icon]="getHideProp(showIcon)"
|
|
112
|
+
[attr.data-link-variant]="linkVariant"
|
|
113
|
+
>
|
|
114
|
+
<ng-content select="[image]"></ng-content>
|
|
115
|
+
<ng-container *ngIf="stringPropVisible(headline, showHeadline)">
|
|
116
|
+
<header>{{headline}}</header>
|
|
117
|
+
</ng-container>
|
|
118
|
+
<p>
|
|
119
|
+
<ng-container *ngIf="text">{{text}}</ng-container>
|
|
120
|
+
<ng-container *ngIf="!(text)"><ng-content></ng-content></ng-container>
|
|
121
|
+
</p>
|
|
122
|
+
<ng-container *ngIf="stringPropVisible(timestamp, showTimestamp)">
|
|
123
|
+
<span>{{timestamp}}</span>
|
|
124
|
+
</ng-container>
|
|
125
|
+
<ng-content select="[link]"></ng-content>
|
|
126
|
+
<ng-container *ngIf="closeable">
|
|
127
|
+
<db-button
|
|
128
|
+
icon="cross"
|
|
129
|
+
variant="ghost"
|
|
130
|
+
size="small"
|
|
131
|
+
[id]="closeButtonId"
|
|
132
|
+
[noText]="true"
|
|
133
|
+
(click)="handleClose($event)"
|
|
134
|
+
>
|
|
135
|
+
{{closeButtonText ?? DEFAULT_CLOSE_BUTTON}}
|
|
136
|
+
</db-button>
|
|
137
|
+
</ng-container>
|
|
138
|
+
</article>
|
|
139
|
+
`,
|
|
140
|
+
standalone: true,
|
|
141
|
+
imports: [CommonModule, DBButton],
|
|
142
|
+
}]
|
|
143
|
+
}], propDecorators: { id: [{
|
|
144
|
+
type: Input
|
|
145
|
+
}], className: [{
|
|
146
|
+
type: Input
|
|
147
|
+
}], ariaLive: [{
|
|
148
|
+
type: Input
|
|
149
|
+
}], semantic: [{
|
|
150
|
+
type: Input
|
|
151
|
+
}], variant: [{
|
|
152
|
+
type: Input
|
|
153
|
+
}], icon: [{
|
|
154
|
+
type: Input
|
|
155
|
+
}], showIcon: [{
|
|
156
|
+
type: Input
|
|
157
|
+
}], linkVariant: [{
|
|
158
|
+
type: Input
|
|
159
|
+
}], headline: [{
|
|
160
|
+
type: Input
|
|
161
|
+
}], showHeadline: [{
|
|
162
|
+
type: Input
|
|
163
|
+
}], text: [{
|
|
164
|
+
type: Input
|
|
165
|
+
}], timestamp: [{
|
|
166
|
+
type: Input
|
|
167
|
+
}], showTimestamp: [{
|
|
168
|
+
type: Input
|
|
169
|
+
}], closeable: [{
|
|
170
|
+
type: Input
|
|
171
|
+
}], closeButtonId: [{
|
|
172
|
+
type: Input
|
|
173
|
+
}], closeButtonText: [{
|
|
174
|
+
type: Input
|
|
175
|
+
}], onClose: [{
|
|
176
|
+
type: Output
|
|
177
|
+
}], _ref: [{
|
|
178
|
+
type: ViewChild,
|
|
179
|
+
args: ["_ref"]
|
|
180
|
+
}] } });
|
|
181
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notification.js","sourceRoot":"","sources":["../../../../../output/angular/src/components/notification/notification.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 { DBNotificationProps, DBNotificationState } from \"./model\";\nimport { DBButton } from \"../button/button\";\nimport { DEFAULT_CLOSE_BUTTON } from \"../../shared/constants\";\nimport { cls, getHideProp, stringPropVisible } from \"../../utils\";\nimport { ClickEvent } from \"../../shared/model\";\n\n@Component({\n  selector: \"db-notification\",\n  template: `\n    <article\n      #_ref\n      [attr.id]=\"id\"\n      [class]=\"cls('db-notification', className)\"\n      [attr.aria-live]=\"ariaLive\"\n      [attr.data-semantic]=\"semantic\"\n      [attr.data-variant]=\"variant\"\n      [attr.data-icon]=\"icon\"\n      [attr.data-hide-icon]=\"getHideProp(showIcon)\"\n      [attr.data-link-variant]=\"linkVariant\"\n    >\n      <ng-content select=\"[image]\"></ng-content>\n      <ng-container *ngIf=\"stringPropVisible(headline, showHeadline)\">\n        <header>{{headline}}</header>\n      </ng-container>\n      <p>\n        <ng-container *ngIf=\"text\">{{text}}</ng-container>\n        <ng-container *ngIf=\"!(text)\"><ng-content></ng-content></ng-container>\n      </p>\n      <ng-container *ngIf=\"stringPropVisible(timestamp, showTimestamp)\">\n        <span>{{timestamp}}</span>\n      </ng-container>\n      <ng-content select=\"[link]\"></ng-content>\n      <ng-container *ngIf=\"closeable\">\n        <db-button\n          icon=\"cross\"\n          variant=\"ghost\"\n          size=\"small\"\n          [id]=\"closeButtonId\"\n          [noText]=\"true\"\n          (click)=\"handleClose($event)\"\n        >\n          {{closeButtonText ?? DEFAULT_CLOSE_BUTTON}}\n        </db-button>\n      </ng-container>\n    </article>\n  `,\n  standalone: true,\n  imports: [CommonModule, DBButton],\n})\nexport class DBNotification {\n  DEFAULT_CLOSE_BUTTON = DEFAULT_CLOSE_BUTTON;\n  cls = cls;\n  getHideProp = getHideProp;\n  stringPropVisible = stringPropVisible;\n\n  @Input() id!: DBNotificationProps[\"id\"];\n  @Input() className!: DBNotificationProps[\"className\"];\n  @Input() ariaLive!: DBNotificationProps[\"ariaLive\"];\n  @Input() semantic!: DBNotificationProps[\"semantic\"];\n  @Input() variant!: DBNotificationProps[\"variant\"];\n  @Input() icon!: DBNotificationProps[\"icon\"];\n  @Input() showIcon!: DBNotificationProps[\"showIcon\"];\n  @Input() linkVariant!: DBNotificationProps[\"linkVariant\"];\n  @Input() headline!: DBNotificationProps[\"headline\"];\n  @Input() showHeadline!: DBNotificationProps[\"showHeadline\"];\n  @Input() text!: DBNotificationProps[\"text\"];\n  @Input() timestamp!: DBNotificationProps[\"timestamp\"];\n  @Input() showTimestamp!: DBNotificationProps[\"showTimestamp\"];\n  @Input() closeable!: DBNotificationProps[\"closeable\"];\n  @Input() closeButtonId!: DBNotificationProps[\"closeButtonId\"];\n  @Input() closeButtonText!: DBNotificationProps[\"closeButtonText\"];\n\n  @Output() onClose = new EventEmitter();\n\n  @ViewChild(\"_ref\") _ref!: ElementRef | undefined;\n\n  handleClose(\n    event: ClickEvent<HTMLButtonElement>\n  ): ReturnType<DBNotificationState[\"handleClose\"]> {\n    if (this.onClose) {\n      this.onClose.emit();\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-notification\");\n  }\n}\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export { DBPage } from './page';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9vdXRwdXQvYW5ndWxhci9zcmMvY29tcG9uZW50cy9wYWdlL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxRQUFRLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBEQlBhZ2UgfSBmcm9tICcuL3BhZ2UnIl19
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export const PageVariantList = ['auto', 'fixed'];
|
|
2
|
+
export const PageDocumentOverflowList = ['hidden', 'auto'];
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9vdXRwdXQvYW5ndWxhci9zcmMvY29tcG9uZW50cy9wYWdlL21vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBSSxDQUFDLE1BQU0sRUFBRSxPQUFPLENBQVcsQ0FBQztBQUU1RCxNQUFNLENBQUMsTUFBTSx3QkFBd0IsR0FBSSxDQUFDLFFBQVEsRUFBRSxNQUFNLENBQVcsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEdsb2JhbFByb3BzLCBHbG9iYWxTdGF0ZSB9IGZyb20gJy4uLy4uL3NoYXJlZC9tb2RlbCc7XG5leHBvcnQgY29uc3QgUGFnZVZhcmlhbnRMaXN0ID0gKFsnYXV0bycsICdmaXhlZCddIGFzIGNvbnN0KTtcbmV4cG9ydCB0eXBlIFBhZ2VWYXJpYW50VHlwZSA9ICh0eXBlb2YgUGFnZVZhcmlhbnRMaXN0KVtudW1iZXJdO1xuZXhwb3J0IGNvbnN0IFBhZ2VEb2N1bWVudE92ZXJmbG93TGlzdCA9IChbJ2hpZGRlbicsICdhdXRvJ10gYXMgY29uc3QpO1xuZXhwb3J0IHR5cGUgUGFnZURvY3VtZW50T3ZlcmZsb3dUeXBlID0gKHR5cGVvZiBQYWdlRG9jdW1lbnRPdmVyZmxvd0xpc3QpW251bWJlcl07XG5leHBvcnQgdHlwZSBEQlBhZ2VEZWZhdWx0UHJvcHMgPSB7XG4gIC8qKlxuICAgKiBUaGUgZG9jdW1lbnRPdmVyZmxvdyBzZXRzIHRoZSBvdmVyZmxvdzpoaWRkZW4vYXV0byB0byB0aGUgcm9vdCBkb2N1bWVudFxuICAgKi9cbiAgZG9jdW1lbnRPdmVyZmxvdz86IFBhZ2VEb2N1bWVudE92ZXJmbG93VHlwZTtcbiAgLyoqXG4gICAqIFNldCB0aGlzIHRvIGhhdmUgYSB0cmFuc2l0aW9uIHdpdGggb3BhY2l0eSB0byBhdm9pZCBsYXlvdXQtc2hpZnRzIGh0dHBzOi8vc2ltb25oZWFybmUuY29tLzIwMjEvbGF5b3V0LXNoaWZ0cy13ZWJmb250cy9cbiAgICovXG4gIGZhZGVJbj86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIFRoZSBzbG90IGNhbiBiZSB1c2VkIGZvciBSZWFjdCB0byBzZXQgYSBmb290ZXIuXG4gICAqL1xuICBmb290ZXI/OiBhbnk7XG4gIC8qKlxuICAgKiBUaGUgc2xvdCBjYW4gYmUgdXNlZCBmb3IgUmVhY3QgdG8gc2V0IGEgaGVhZGVyLlxuICAgKi9cbiAgaGVhZGVyPzogYW55O1xuXG4gIC8qKlxuICAgKiBUaGUgdmFyaWFudD1maXhlZCB1c2VzIGZsZXgtYm94IHRvIG1ha2UgaGVhZGVyIGFuZCBmb290ZXIgc3RhdGljXG4gICAqL1xuICB2YXJpYW50PzogUGFnZVZhcmlhbnRUeXBlO1xufTtcbmV4cG9ydCB0eXBlIERCUGFnZVByb3BzID0gREJQYWdlRGVmYXVsdFByb3BzICYgR2xvYmFsUHJvcHM7XG5leHBvcnQgdHlwZSBEQlBhZ2VEZWZhdWx0U3RhdGUgPSB7XG4gIGZvbnRzTG9hZGVkPzogYm9vbGVhbjtcbn07XG5leHBvcnQgdHlwZSBEQlBhZ2VTdGF0ZSA9IERCUGFnZURlZmF1bHRTdGF0ZSAmIEdsb2JhbFN0YXRlIl19
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
import { Component, ViewChild, Input } from "@angular/core";
|
|
2
|
+
import { CommonModule } from "@angular/common";
|
|
3
|
+
import { cls, getBooleanAsString } from "../../utils";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
const defaultProps = {};
|
|
6
|
+
export class DBPage {
|
|
7
|
+
constructor() {
|
|
8
|
+
this.cls = cls;
|
|
9
|
+
this.getBooleanAsString = getBooleanAsString;
|
|
10
|
+
this.fontsLoaded = false;
|
|
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
|
+
document &&
|
|
47
|
+
(this.documentOverflow === "hidden" ||
|
|
48
|
+
(this.variant === "fixed" && this.documentOverflow !== "auto"))) {
|
|
49
|
+
// We need to set this to `html` element that the flex-box solution works
|
|
50
|
+
// See https://stackoverflow.com/a/43710216 - Approach 1 - flexbox
|
|
51
|
+
document.documentElement.classList.add("db-page-document");
|
|
52
|
+
}
|
|
53
|
+
if (typeof window !== "undefined") {
|
|
54
|
+
this.fontsLoaded = !this.fadeIn;
|
|
55
|
+
if (document && this.fadeIn) {
|
|
56
|
+
document.fonts.ready.then(() => {
|
|
57
|
+
this.fontsLoaded = true;
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
else {
|
|
61
|
+
this.fontsLoaded = true;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
ngAfterViewInit() {
|
|
66
|
+
const element = this._ref?.nativeElement;
|
|
67
|
+
this.enableAttributePassing(element, "db-page");
|
|
68
|
+
}
|
|
69
|
+
ngOnDestroy() {
|
|
70
|
+
if (typeof window !== "undefined" &&
|
|
71
|
+
document.documentElement.classList.contains("db-page-document")) {
|
|
72
|
+
// remove document styles set by this
|
|
73
|
+
document.documentElement.classList.remove("db-page-document");
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DBPage, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
77
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DBPage, isStandalone: true, selector: "db-page", inputs: { fadeIn: "fadeIn", documentOverflow: "documentOverflow", variant: "variant", id: "id", className: "className" }, viewQueries: [{ propertyName: "_ref", first: true, predicate: ["_ref"], descendants: true }], ngImport: i0, template: `
|
|
78
|
+
<div
|
|
79
|
+
#_ref
|
|
80
|
+
[attr.id]="id"
|
|
81
|
+
[class]="cls('db-page', className)"
|
|
82
|
+
[attr.data-variant]="variant"
|
|
83
|
+
[attr.data-fade-in]="fadeIn"
|
|
84
|
+
[attr.data-fonts-loaded]="getBooleanAsString(fontsLoaded)"
|
|
85
|
+
>
|
|
86
|
+
<ng-content select="[header]"></ng-content>
|
|
87
|
+
<main class="db-main"><ng-content></ng-content></main>
|
|
88
|
+
<ng-content select="[footer]"></ng-content>
|
|
89
|
+
</div>
|
|
90
|
+
`, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }] }); }
|
|
91
|
+
}
|
|
92
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DBPage, decorators: [{
|
|
93
|
+
type: Component,
|
|
94
|
+
args: [{
|
|
95
|
+
selector: "db-page",
|
|
96
|
+
template: `
|
|
97
|
+
<div
|
|
98
|
+
#_ref
|
|
99
|
+
[attr.id]="id"
|
|
100
|
+
[class]="cls('db-page', className)"
|
|
101
|
+
[attr.data-variant]="variant"
|
|
102
|
+
[attr.data-fade-in]="fadeIn"
|
|
103
|
+
[attr.data-fonts-loaded]="getBooleanAsString(fontsLoaded)"
|
|
104
|
+
>
|
|
105
|
+
<ng-content select="[header]"></ng-content>
|
|
106
|
+
<main class="db-main"><ng-content></ng-content></main>
|
|
107
|
+
<ng-content select="[footer]"></ng-content>
|
|
108
|
+
</div>
|
|
109
|
+
`,
|
|
110
|
+
standalone: true,
|
|
111
|
+
imports: [CommonModule],
|
|
112
|
+
}]
|
|
113
|
+
}], propDecorators: { fadeIn: [{
|
|
114
|
+
type: Input
|
|
115
|
+
}], documentOverflow: [{
|
|
116
|
+
type: Input
|
|
117
|
+
}], variant: [{
|
|
118
|
+
type: Input
|
|
119
|
+
}], id: [{
|
|
120
|
+
type: Input
|
|
121
|
+
}], className: [{
|
|
122
|
+
type: Input
|
|
123
|
+
}], _ref: [{
|
|
124
|
+
type: ViewChild,
|
|
125
|
+
args: ["_ref"]
|
|
126
|
+
}] } });
|
|
127
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page.js","sourceRoot":"","sources":["../../../../../output/angular/src/components/page/page.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewChild, ElementRef, Input } from \"@angular/core\";\nimport { CommonModule } from \"@angular/common\";\n\nconst defaultProps = {};\n\nimport { DBPageProps, DBPageState } from \"./model\";\nimport { cls, getBooleanAsString } from \"../../utils\";\n\n@Component({\n  selector: \"db-page\",\n  template: `\n    <div\n      #_ref\n      [attr.id]=\"id\"\n      [class]=\"cls('db-page', className)\"\n      [attr.data-variant]=\"variant\"\n      [attr.data-fade-in]=\"fadeIn\"\n      [attr.data-fonts-loaded]=\"getBooleanAsString(fontsLoaded)\"\n    >\n      <ng-content select=\"[header]\"></ng-content>\n      <main class=\"db-main\"><ng-content></ng-content></main>\n      <ng-content select=\"[footer]\"></ng-content>\n    </div>\n  `,\n  standalone: true,\n  imports: [CommonModule],\n})\nexport class DBPage {\n  cls = cls;\n  getBooleanAsString = getBooleanAsString;\n\n  @Input() fadeIn!: DBPageProps[\"fadeIn\"];\n  @Input() documentOverflow!: DBPageProps[\"documentOverflow\"];\n  @Input() variant!: DBPageProps[\"variant\"];\n  @Input() id!: DBPageProps[\"id\"];\n  @Input() className!: DBPageProps[\"className\"];\n\n  @ViewChild(\"_ref\") _ref!: ElementRef | undefined;\n\n  fontsLoaded: DBPageState[\"fontsLoaded\"] = false;\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 (\n      typeof window !== \"undefined\" &&\n      document &&\n      (this.documentOverflow === \"hidden\" ||\n        (this.variant === \"fixed\" && this.documentOverflow !== \"auto\"))\n    ) {\n      // We need to set this to `html` element that the flex-box solution works\n      // See https://stackoverflow.com/a/43710216 - Approach 1 - flexbox\n      document.documentElement.classList.add(\"db-page-document\");\n    }\n\n    if (typeof window !== \"undefined\") {\n      this.fontsLoaded = !this.fadeIn;\n      if (document && this.fadeIn) {\n        document.fonts.ready.then(() => {\n          this.fontsLoaded = true;\n        });\n      } else {\n        this.fontsLoaded = true;\n      }\n    }\n  }\n\n  ngAfterViewInit() {\n    const element: HTMLElement | null = this._ref?.nativeElement;\n    this.enableAttributePassing(element, \"db-page\");\n  }\n\n  ngOnDestroy() {\n    if (\n      typeof window !== \"undefined\" &&\n      document.documentElement.classList.contains(\"db-page-document\")\n    ) {\n      // remove document styles set by this\n      document.documentElement.classList.remove(\"db-page-document\");\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export { DBPopover } from './popover';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9vdXRwdXQvYW5ndWxhci9zcmMvY29tcG9uZW50cy9wb3BvdmVyL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxXQUFXLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBEQlBvcG92ZXIgfSBmcm9tICcuL3BvcG92ZXInIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9vdXRwdXQvYW5ndWxhci9zcmMvY29tcG9uZW50cy9wb3BvdmVyL21vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBHYXBQcm9wcywgR2xvYmFsUHJvcHMsIEdsb2JhbFN0YXRlLCBJbml0aWFsaXplZFN0YXRlLCBQbGFjZW1lbnRQcm9wcywgUG9wb3ZlclByb3BzLCBQb3BvdmVyU3RhdGUsIFNwYWNpbmdQcm9wcyB9IGZyb20gJy4uLy4uL3NoYXJlZC9tb2RlbCc7XG5leHBvcnQgdHlwZSBEQlBvcG92ZXJEZWZhdWx0UHJvcHMgPSB7XG4gIC8qKlxuICAgKiBVc2Ugb3BlbiB0byBkaXNhYmxlIHRoZSBkZWZhdWx0IGhvdmVyL2ZvY3VzIGJlaGF2aW9yIHRvIHVzZSBpdCBvbiBjbGljayBvciBvdGhlciB0cmlnZ2VyLlxuICAgKi9cbiAgb3Blbj86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIFRoZSB0cmlnZ2VyIHRvIG9wZW4gdGhlIHBvcG92ZXIgZS5nLiBhIGJ1dHRvblxuICAgKi9cbiAgdHJpZ2dlcj86IGFueTtcbn07XG5leHBvcnQgdHlwZSBEQlBvcG92ZXJQcm9wcyA9IERCUG9wb3ZlckRlZmF1bHRQcm9wcyAmIEdsb2JhbFByb3BzICYgU3BhY2luZ1Byb3BzICYgUGxhY2VtZW50UHJvcHMgJiBHYXBQcm9wcyAmIFBvcG92ZXJQcm9wcztcbmV4cG9ydCB0eXBlIERCUG9wb3ZlckRlZmF1bHRTdGF0ZSA9IHtcbiAgaXNFeHBhbmRlZD86IGJvb2xlYW47XG4gIGdldFRyaWdnZXI6ICgpID0+IEVsZW1lbnQgfCBudWxsO1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueVxuICBoYW5kbGVMZWF2ZTogKGV2ZW50OiBhbnkpID0+IHZvaWQ7XG59O1xuZXhwb3J0IHR5cGUgREJQb3BvdmVyU3RhdGUgPSBEQlBvcG92ZXJEZWZhdWx0U3RhdGUgJiBHbG9iYWxTdGF0ZSAmIFBvcG92ZXJTdGF0ZSAmIEluaXRpYWxpemVkU3RhdGUiXX0=
|
|
@@ -0,0 +1,189 @@
|
|
|
1
|
+
import { Component, ViewChild, Input, } from "@angular/core";
|
|
2
|
+
import { CommonModule } from "@angular/common";
|
|
3
|
+
import { cls, getBooleanAsString, handleDataOutside } from "../../utils";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
const defaultProps = {};
|
|
6
|
+
export class DBPopover {
|
|
7
|
+
constructor() {
|
|
8
|
+
this.cls = cls;
|
|
9
|
+
this.getBooleanAsString = getBooleanAsString;
|
|
10
|
+
this.initialized = false;
|
|
11
|
+
this.isExpanded = false;
|
|
12
|
+
}
|
|
13
|
+
handleAutoPlacement() {
|
|
14
|
+
this.isExpanded = true;
|
|
15
|
+
if (!this._ref?.nativeElement)
|
|
16
|
+
return;
|
|
17
|
+
const article = this._ref.nativeElement.querySelector("article");
|
|
18
|
+
if (!article)
|
|
19
|
+
return;
|
|
20
|
+
handleDataOutside(article);
|
|
21
|
+
}
|
|
22
|
+
handleLeave(event) {
|
|
23
|
+
const element = event.target;
|
|
24
|
+
const parent = element.parentNode;
|
|
25
|
+
if (!parent ||
|
|
26
|
+
(element.parentNode.querySelector(":focus") !== element &&
|
|
27
|
+
element.parentNode.querySelector(":focus-within") !== element &&
|
|
28
|
+
element.parentNode.querySelector(":hover") !== element)) {
|
|
29
|
+
this.isExpanded = false;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
getTrigger() {
|
|
33
|
+
if (this._ref?.nativeElement) {
|
|
34
|
+
const children = Array.from(this._ref.nativeElement.children);
|
|
35
|
+
if (children.length >= 2) {
|
|
36
|
+
const firstChild = children[0];
|
|
37
|
+
if (firstChild.tagName.includes("-")) {
|
|
38
|
+
// this is a workaround for custom angular components
|
|
39
|
+
return firstChild.children?.length > 0
|
|
40
|
+
? firstChild.children[0]
|
|
41
|
+
: null;
|
|
42
|
+
}
|
|
43
|
+
else {
|
|
44
|
+
return firstChild;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
return null;
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.
|
|
52
|
+
* @param element the ref for the component
|
|
53
|
+
* @param customElementSelector the custom element like `my-component`
|
|
54
|
+
*/
|
|
55
|
+
enableAttributePassing(element, customElementSelector) {
|
|
56
|
+
const parent = element?.closest(customElementSelector);
|
|
57
|
+
if (element && parent) {
|
|
58
|
+
const attributes = parent.attributes;
|
|
59
|
+
for (let i = 0; i < attributes.length; i++) {
|
|
60
|
+
const attr = attributes.item(i);
|
|
61
|
+
if (attr &&
|
|
62
|
+
(attr.name.startsWith("data-") || attr.name.startsWith("aria-"))) {
|
|
63
|
+
element.setAttribute(attr.name, attr.value);
|
|
64
|
+
parent.removeAttribute(attr.name);
|
|
65
|
+
}
|
|
66
|
+
if (attr && attr.name === "class") {
|
|
67
|
+
const isWebComponent = attr.value.includes("hydrated");
|
|
68
|
+
const value = attr.value.replace("hydrated", "").trim();
|
|
69
|
+
const currentClass = element.getAttribute("class");
|
|
70
|
+
element.setAttribute(attr.name, `${currentClass ? `${currentClass} ` : ""}${value}`);
|
|
71
|
+
if (isWebComponent) {
|
|
72
|
+
// Stencil is using this class for lazy loading component
|
|
73
|
+
parent.setAttribute("class", "hydrated");
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
parent.removeAttribute(attr.name);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
ngOnInit() {
|
|
83
|
+
if (typeof window !== "undefined") {
|
|
84
|
+
this.initialized = true;
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
ngAfterViewInit() {
|
|
88
|
+
const element = this._ref?.nativeElement;
|
|
89
|
+
this.enableAttributePassing(element, "db-popover");
|
|
90
|
+
}
|
|
91
|
+
ngAfterContentChecked(changes) {
|
|
92
|
+
if (typeof window !== "undefined") {
|
|
93
|
+
if (this._ref?.nativeElement && this.initialized) {
|
|
94
|
+
const child = this.getTrigger();
|
|
95
|
+
if (child) {
|
|
96
|
+
child.ariaHasPopup = "true";
|
|
97
|
+
}
|
|
98
|
+
this.initialized = false;
|
|
99
|
+
}
|
|
100
|
+
if (this._ref?.nativeElement) {
|
|
101
|
+
const child = this.getTrigger();
|
|
102
|
+
if (child) {
|
|
103
|
+
child.ariaExpanded = Boolean(this.isExpanded).toString();
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DBPopover, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
109
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DBPopover, isStandalone: true, selector: "db-popover", inputs: { id: "id", className: "className", spacing: "spacing", gap: "gap", animation: "animation", open: "open", delay: "delay", width: "width", placement: "placement" }, viewQueries: [{ propertyName: "_ref", first: true, predicate: ["_ref"], descendants: true }], ngImport: i0, template: `
|
|
110
|
+
<div
|
|
111
|
+
#_ref
|
|
112
|
+
[attr.id]="id"
|
|
113
|
+
[class]="cls('db-popover', className)"
|
|
114
|
+
(focus)="handleAutoPlacement()"
|
|
115
|
+
(blur)="handleLeave($event)"
|
|
116
|
+
(mouseenter)="handleAutoPlacement()"
|
|
117
|
+
(mouseleave)="handleLeave($event)"
|
|
118
|
+
>
|
|
119
|
+
<ng-content select="[trigger]"></ng-content>
|
|
120
|
+
<article
|
|
121
|
+
class="db-popover-content"
|
|
122
|
+
[attr.data-spacing]="spacing"
|
|
123
|
+
[attr.data-gap]="getBooleanAsString(gap)"
|
|
124
|
+
[attr.data-animation]="getBooleanAsString(animation ?? true)"
|
|
125
|
+
[attr.data-open]="open"
|
|
126
|
+
[attr.data-delay]="delay"
|
|
127
|
+
[attr.data-width]="width"
|
|
128
|
+
[attr.data-placement]="placement"
|
|
129
|
+
>
|
|
130
|
+
<ng-content></ng-content>
|
|
131
|
+
</article>
|
|
132
|
+
</div>
|
|
133
|
+
`, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }] }); }
|
|
134
|
+
}
|
|
135
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DBPopover, decorators: [{
|
|
136
|
+
type: Component,
|
|
137
|
+
args: [{
|
|
138
|
+
selector: "db-popover",
|
|
139
|
+
template: `
|
|
140
|
+
<div
|
|
141
|
+
#_ref
|
|
142
|
+
[attr.id]="id"
|
|
143
|
+
[class]="cls('db-popover', className)"
|
|
144
|
+
(focus)="handleAutoPlacement()"
|
|
145
|
+
(blur)="handleLeave($event)"
|
|
146
|
+
(mouseenter)="handleAutoPlacement()"
|
|
147
|
+
(mouseleave)="handleLeave($event)"
|
|
148
|
+
>
|
|
149
|
+
<ng-content select="[trigger]"></ng-content>
|
|
150
|
+
<article
|
|
151
|
+
class="db-popover-content"
|
|
152
|
+
[attr.data-spacing]="spacing"
|
|
153
|
+
[attr.data-gap]="getBooleanAsString(gap)"
|
|
154
|
+
[attr.data-animation]="getBooleanAsString(animation ?? true)"
|
|
155
|
+
[attr.data-open]="open"
|
|
156
|
+
[attr.data-delay]="delay"
|
|
157
|
+
[attr.data-width]="width"
|
|
158
|
+
[attr.data-placement]="placement"
|
|
159
|
+
>
|
|
160
|
+
<ng-content></ng-content>
|
|
161
|
+
</article>
|
|
162
|
+
</div>
|
|
163
|
+
`,
|
|
164
|
+
standalone: true,
|
|
165
|
+
imports: [CommonModule],
|
|
166
|
+
}]
|
|
167
|
+
}], propDecorators: { id: [{
|
|
168
|
+
type: Input
|
|
169
|
+
}], className: [{
|
|
170
|
+
type: Input
|
|
171
|
+
}], spacing: [{
|
|
172
|
+
type: Input
|
|
173
|
+
}], gap: [{
|
|
174
|
+
type: Input
|
|
175
|
+
}], animation: [{
|
|
176
|
+
type: Input
|
|
177
|
+
}], open: [{
|
|
178
|
+
type: Input
|
|
179
|
+
}], delay: [{
|
|
180
|
+
type: Input
|
|
181
|
+
}], width: [{
|
|
182
|
+
type: Input
|
|
183
|
+
}], placement: [{
|
|
184
|
+
type: Input
|
|
185
|
+
}], _ref: [{
|
|
186
|
+
type: ViewChild,
|
|
187
|
+
args: ["_ref"]
|
|
188
|
+
}] } });
|
|
189
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.js","sourceRoot":"","sources":["../../../../../output/angular/src/components/popover/popover.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ViewChild,\n  ElementRef,\n  Input,\n  SimpleChanges,\n} from \"@angular/core\";\nimport { CommonModule } from \"@angular/common\";\n\nconst defaultProps = {};\n\nimport { DBPopoverProps, DBPopoverState } from \"./model\";\nimport { cls, getBooleanAsString, handleDataOutside } from \"../../utils\";\n\n@Component({\n  selector: \"db-popover\",\n  template: `\n    <div\n      #_ref\n      [attr.id]=\"id\"\n      [class]=\"cls('db-popover', className)\"\n      (focus)=\"handleAutoPlacement()\"\n      (blur)=\"handleLeave($event)\"\n      (mouseenter)=\"handleAutoPlacement()\"\n      (mouseleave)=\"handleLeave($event)\"\n    >\n      <ng-content select=\"[trigger]\"></ng-content>\n      <article\n        class=\"db-popover-content\"\n        [attr.data-spacing]=\"spacing\"\n        [attr.data-gap]=\"getBooleanAsString(gap)\"\n        [attr.data-animation]=\"getBooleanAsString(animation ?? true)\"\n        [attr.data-open]=\"open\"\n        [attr.data-delay]=\"delay\"\n        [attr.data-width]=\"width\"\n        [attr.data-placement]=\"placement\"\n      >\n        <ng-content></ng-content>\n      </article>\n    </div>\n  `,\n  standalone: true,\n  imports: [CommonModule],\n})\nexport class DBPopover {\n  cls = cls;\n  getBooleanAsString = getBooleanAsString;\n\n  @Input() id!: DBPopoverProps[\"id\"];\n  @Input() className!: DBPopoverProps[\"className\"];\n  @Input() spacing!: DBPopoverProps[\"spacing\"];\n  @Input() gap!: DBPopoverProps[\"gap\"];\n  @Input() animation!: DBPopoverProps[\"animation\"];\n  @Input() open!: DBPopoverProps[\"open\"];\n  @Input() delay!: DBPopoverProps[\"delay\"];\n  @Input() width!: DBPopoverProps[\"width\"];\n  @Input() placement!: DBPopoverProps[\"placement\"];\n\n  @ViewChild(\"_ref\") _ref!: ElementRef | undefined;\n\n  initialized: DBPopoverState[\"initialized\"] = false;\n  isExpanded: DBPopoverState[\"isExpanded\"] = false;\n  handleAutoPlacement(): ReturnType<DBPopoverState[\"handleAutoPlacement\"]> {\n    this.isExpanded = true;\n    if (!this._ref?.nativeElement) return;\n    const article = this._ref.nativeElement.querySelector(\"article\");\n    if (!article) return;\n    handleDataOutside(article);\n  }\n  handleLeave(event: any): ReturnType<DBPopoverState[\"handleLeave\"]> {\n    const element = event.target as HTMLElement;\n    const parent = element.parentNode;\n    if (\n      !parent ||\n      (element.parentNode.querySelector(\":focus\") !== element &&\n        element.parentNode.querySelector(\":focus-within\") !== element &&\n        element.parentNode.querySelector(\":hover\") !== element)\n    ) {\n      this.isExpanded = false;\n    }\n  }\n  getTrigger(): ReturnType<DBPopoverState[\"getTrigger\"]> {\n    if (this._ref?.nativeElement) {\n      const children: Element[] = Array.from(this._ref.nativeElement.children);\n      if (children.length >= 2) {\n        const firstChild = children[0];\n        if (firstChild.tagName.includes(\"-\")) {\n          // this is a workaround for custom angular components\n          return firstChild.children?.length > 0\n            ? firstChild.children[0]\n            : null;\n        } else {\n          return firstChild;\n        }\n      }\n    }\n    return null;\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-popover\");\n  }\n\n  ngAfterContentChecked(changes: SimpleChanges) {\n    if (typeof window !== \"undefined\") {\n      if (this._ref?.nativeElement && this.initialized) {\n        const child = this.getTrigger();\n        if (child) {\n          child.ariaHasPopup = \"true\";\n        }\n        this.initialized = false;\n      }\n      if (this._ref?.nativeElement) {\n        const child = this.getTrigger();\n        if (child) {\n          child.ariaExpanded = Boolean(this.isExpanded).toString();\n        }\n      }\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export { DBRadio } from './radio';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9vdXRwdXQvYW5ndWxhci9zcmMvY29tcG9uZW50cy9yYWRpby9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sU0FBUyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgREJSYWRpbyB9IGZyb20gJy4vcmFkaW8nIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9vdXRwdXQvYW5ndWxhci9zcmMvY29tcG9uZW50cy9yYWRpby9tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRXZlbnRQcm9wcywgQ2hhbmdlRXZlbnRTdGF0ZSwgRm9jdXNFdmVudFByb3BzLCBGb2N1c0V2ZW50U3RhdGUsIEZvcm1DaGVja1Byb3BzLCBGb3JtUHJvcHMsIEZvcm1TdGF0ZSwgR2xvYmFsUHJvcHMsIEdsb2JhbFN0YXRlLCBJbml0aWFsaXplZFN0YXRlLCBTaXplUHJvcHMgfSBmcm9tICcuLi8uLi9zaGFyZWQvbW9kZWwnO1xuZXhwb3J0IHR5cGUgREJSYWRpb0RlZmF1bHRQcm9wcyA9IHtcbiAgZGVzY3JpYmVkYnlpZD86IHN0cmluZztcbn07XG5leHBvcnQgdHlwZSBEQlJhZGlvUHJvcHMgPSBEQlJhZGlvRGVmYXVsdFByb3BzICYgR2xvYmFsUHJvcHMgJiBDaGFuZ2VFdmVudFByb3BzPEhUTUxJbnB1dEVsZW1lbnQ+ICYgRm9jdXNFdmVudFByb3BzPEhUTUxJbnB1dEVsZW1lbnQ+ICYgRm9ybVByb3BzICYgRm9ybUNoZWNrUHJvcHMgJiBTaXplUHJvcHM7XG5leHBvcnQgdHlwZSBEQlJhZGlvRGVmYXVsdFN0YXRlID0ge307XG5leHBvcnQgdHlwZSBEQlJhZGlvU3RhdGUgPSBEQlJhZGlvRGVmYXVsdFN0YXRlICYgR2xvYmFsU3RhdGUgJiBDaGFuZ2VFdmVudFN0YXRlPEhUTUxJbnB1dEVsZW1lbnQ+ICYgRm9jdXNFdmVudFN0YXRlPEhUTUxJbnB1dEVsZW1lbnQ+ICYgRm9ybVN0YXRlICYgSW5pdGlhbGl6ZWRTdGF0ZSJdfQ==
|