@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.
Files changed (211) hide show
  1. package/README.md +130 -0
  2. package/components/accordion/accordion.d.ts +31 -0
  3. package/components/accordion/index.d.ts +1 -0
  4. package/components/accordion/model.d.ts +41 -0
  5. package/components/accordion-item/accordion-item.d.ts +29 -0
  6. package/components/accordion-item/index.d.ts +1 -0
  7. package/components/accordion-item/model.d.ts +24 -0
  8. package/components/badge/badge.d.ts +28 -0
  9. package/components/badge/index.d.ts +1 -0
  10. package/components/badge/model.d.ts +16 -0
  11. package/components/brand/brand.d.ts +24 -0
  12. package/components/brand/index.d.ts +1 -0
  13. package/components/brand/model.d.ts +10 -0
  14. package/components/button/button.d.ts +39 -0
  15. package/components/button/index.d.ts +1 -0
  16. package/components/button/model.d.ts +52 -0
  17. package/components/card/card.d.ts +24 -0
  18. package/components/card/index.d.ts +1 -0
  19. package/components/card/model.d.ts +18 -0
  20. package/components/checkbox/checkbox.d.ts +64 -0
  21. package/components/checkbox/index.d.ts +1 -0
  22. package/components/checkbox/model.d.ts +10 -0
  23. package/components/divider/divider.d.ts +22 -0
  24. package/components/divider/index.d.ts +1 -0
  25. package/components/divider/model.d.ts +18 -0
  26. package/components/drawer/drawer.d.ts +34 -0
  27. package/components/drawer/index.d.ts +1 -0
  28. package/components/drawer/model.d.ts +41 -0
  29. package/components/header/MetaNavigation.directive.d.ts +5 -0
  30. package/components/header/Navigation.directive.d.ts +5 -0
  31. package/components/header/SecondaryAction.directive.d.ts +5 -0
  32. package/components/header/header.d.ts +34 -0
  33. package/components/header/index.d.ts +1 -0
  34. package/components/header/model.d.ts +44 -0
  35. package/components/icon/icon.d.ts +22 -0
  36. package/components/icon/index.d.ts +1 -0
  37. package/components/icon/model.d.ts +12 -0
  38. package/components/infotext/index.d.ts +1 -0
  39. package/components/infotext/infotext.d.ts +24 -0
  40. package/components/infotext/model.d.ts +5 -0
  41. package/components/input/index.d.ts +1 -0
  42. package/components/input/input.d.ts +87 -0
  43. package/components/input/model.d.ts +39 -0
  44. package/components/link/index.d.ts +1 -0
  45. package/components/link/link.d.ts +37 -0
  46. package/components/link/model.d.ts +24 -0
  47. package/components/navigation/index.d.ts +1 -0
  48. package/components/navigation/model.d.ts +5 -0
  49. package/components/navigation/navigation.d.ts +21 -0
  50. package/components/navigation-item/NavigationContent.directive.d.ts +5 -0
  51. package/components/navigation-item/index.d.ts +1 -0
  52. package/components/navigation-item/model.d.ts +34 -0
  53. package/components/navigation-item/navigation-item.d.ts +44 -0
  54. package/components/notification/index.d.ts +1 -0
  55. package/components/notification/model.d.ts +57 -0
  56. package/components/notification/notification.d.ts +38 -0
  57. package/components/page/index.d.ts +1 -0
  58. package/components/page/model.d.ts +32 -0
  59. package/components/page/page.d.ts +25 -0
  60. package/components/popover/index.d.ts +1 -0
  61. package/components/popover/model.d.ts +18 -0
  62. package/components/popover/popover.d.ts +33 -0
  63. package/components/radio/index.d.ts +1 -0
  64. package/components/radio/model.d.ts +7 -0
  65. package/components/radio/radio.d.ts +51 -0
  66. package/components/section/index.d.ts +1 -0
  67. package/components/section/model.d.ts +5 -0
  68. package/components/section/section.d.ts +22 -0
  69. package/components/select/index.d.ts +1 -0
  70. package/components/select/model.d.ts +43 -0
  71. package/components/select/select.d.ts +77 -0
  72. package/components/stack/index.d.ts +1 -0
  73. package/components/stack/model.d.ts +34 -0
  74. package/components/stack/stack.d.ts +25 -0
  75. package/components/switch/index.d.ts +1 -0
  76. package/components/switch/model.d.ts +12 -0
  77. package/components/switch/switch.d.ts +55 -0
  78. package/components/tab-item/index.d.ts +1 -0
  79. package/components/tab-item/model.d.ts +24 -0
  80. package/components/tab-item/tab-item.d.ts +44 -0
  81. package/components/tab-list/index.d.ts +1 -0
  82. package/components/tab-list/model.d.ts +5 -0
  83. package/components/tab-list/tab-list.d.ts +20 -0
  84. package/components/tab-panel/index.d.ts +1 -0
  85. package/components/tab-panel/model.d.ts +10 -0
  86. package/components/tab-panel/tab-panel.d.ts +21 -0
  87. package/components/tabs/index.d.ts +1 -0
  88. package/components/tabs/model.d.ts +47 -0
  89. package/components/tabs/tabs.d.ts +42 -0
  90. package/components/tag/index.d.ts +1 -0
  91. package/components/tag/model.d.ts +45 -0
  92. package/components/tag/tag.d.ts +37 -0
  93. package/components/textarea/index.d.ts +1 -0
  94. package/components/textarea/model.d.ts +30 -0
  95. package/components/textarea/textarea.d.ts +79 -0
  96. package/components/tooltip/index.d.ts +1 -0
  97. package/components/tooltip/model.d.ts +7 -0
  98. package/components/tooltip/tooltip.d.ts +32 -0
  99. package/esm2022/components/accordion/accordion.mjs +196 -0
  100. package/esm2022/components/accordion/index.mjs +2 -0
  101. package/esm2022/components/accordion/model.mjs +3 -0
  102. package/esm2022/components/accordion-item/accordion-item.mjs +136 -0
  103. package/esm2022/components/accordion-item/index.mjs +2 -0
  104. package/esm2022/components/accordion-item/model.mjs +2 -0
  105. package/esm2022/components/badge/badge.mjs +130 -0
  106. package/esm2022/components/badge/index.mjs +2 -0
  107. package/esm2022/components/badge/model.mjs +2 -0
  108. package/esm2022/components/brand/brand.mjs +99 -0
  109. package/esm2022/components/brand/index.mjs +2 -0
  110. package/esm2022/components/brand/model.mjs +2 -0
  111. package/esm2022/components/button/button.mjs +158 -0
  112. package/esm2022/components/button/index.mjs +2 -0
  113. package/esm2022/components/button/model.mjs +4 -0
  114. package/esm2022/components/card/card.mjs +107 -0
  115. package/esm2022/components/card/index.mjs +2 -0
  116. package/esm2022/components/card/model.mjs +3 -0
  117. package/esm2022/components/checkbox/checkbox.mjs +328 -0
  118. package/esm2022/components/checkbox/index.mjs +2 -0
  119. package/esm2022/components/checkbox/model.mjs +2 -0
  120. package/esm2022/components/divider/divider.mjs +93 -0
  121. package/esm2022/components/divider/index.mjs +2 -0
  122. package/esm2022/components/divider/model.mjs +3 -0
  123. package/esm2022/components/drawer/drawer.mjs +218 -0
  124. package/esm2022/components/drawer/index.mjs +2 -0
  125. package/esm2022/components/drawer/model.mjs +4 -0
  126. package/esm2022/components/header/MetaNavigation.directive.mjs +15 -0
  127. package/esm2022/components/header/Navigation.directive.mjs +15 -0
  128. package/esm2022/components/header/SecondaryAction.directive.mjs +15 -0
  129. package/esm2022/components/header/header.mjs +251 -0
  130. package/esm2022/components/header/index.mjs +2 -0
  131. package/esm2022/components/header/model.mjs +2 -0
  132. package/esm2022/components/icon/icon.mjs +100 -0
  133. package/esm2022/components/icon/index.mjs +2 -0
  134. package/esm2022/components/icon/model.mjs +3 -0
  135. package/esm2022/components/infotext/index.mjs +2 -0
  136. package/esm2022/components/infotext/infotext.mjs +103 -0
  137. package/esm2022/components/infotext/model.mjs +2 -0
  138. package/esm2022/components/input/index.mjs +2 -0
  139. package/esm2022/components/input/input.mjs +421 -0
  140. package/esm2022/components/input/model.mjs +6 -0
  141. package/esm2022/components/link/index.mjs +2 -0
  142. package/esm2022/components/link/link.mjs +152 -0
  143. package/esm2022/components/link/model.mjs +4 -0
  144. package/esm2022/components/navigation/index.mjs +2 -0
  145. package/esm2022/components/navigation/model.mjs +2 -0
  146. package/esm2022/components/navigation/navigation.mjs +92 -0
  147. package/esm2022/components/navigation-item/NavigationContent.directive.mjs +15 -0
  148. package/esm2022/components/navigation-item/index.mjs +2 -0
  149. package/esm2022/components/navigation-item/model.mjs +2 -0
  150. package/esm2022/components/navigation-item/navigation-item.mjs +236 -0
  151. package/esm2022/components/notification/index.mjs +2 -0
  152. package/esm2022/components/notification/model.mjs +4 -0
  153. package/esm2022/components/notification/notification.mjs +181 -0
  154. package/esm2022/components/page/index.mjs +2 -0
  155. package/esm2022/components/page/model.mjs +3 -0
  156. package/esm2022/components/page/page.mjs +127 -0
  157. package/esm2022/components/popover/index.mjs +2 -0
  158. package/esm2022/components/popover/model.mjs +2 -0
  159. package/esm2022/components/popover/popover.mjs +189 -0
  160. package/esm2022/components/radio/index.mjs +2 -0
  161. package/esm2022/components/radio/model.mjs +2 -0
  162. package/esm2022/components/radio/radio.mjs +230 -0
  163. package/esm2022/components/section/index.mjs +2 -0
  164. package/esm2022/components/section/model.mjs +2 -0
  165. package/esm2022/components/section/section.mjs +96 -0
  166. package/esm2022/components/select/index.mjs +2 -0
  167. package/esm2022/components/select/model.mjs +2 -0
  168. package/esm2022/components/select/select.mjs +426 -0
  169. package/esm2022/components/stack/index.mjs +2 -0
  170. package/esm2022/components/stack/model.mjs +5 -0
  171. package/esm2022/components/stack/stack.mjs +106 -0
  172. package/esm2022/components/switch/index.mjs +2 -0
  173. package/esm2022/components/switch/model.mjs +2 -0
  174. package/esm2022/components/switch/switch.mjs +237 -0
  175. package/esm2022/components/tab-item/index.mjs +2 -0
  176. package/esm2022/components/tab-item/model.mjs +2 -0
  177. package/esm2022/components/tab-item/tab-item.mjs +195 -0
  178. package/esm2022/components/tab-list/index.mjs +2 -0
  179. package/esm2022/components/tab-list/model.mjs +2 -0
  180. package/esm2022/components/tab-list/tab-list.mjs +84 -0
  181. package/esm2022/components/tab-panel/index.mjs +2 -0
  182. package/esm2022/components/tab-panel/model.mjs +2 -0
  183. package/esm2022/components/tab-panel/tab-panel.mjs +96 -0
  184. package/esm2022/components/tabs/index.mjs +2 -0
  185. package/esm2022/components/tabs/model.mjs +3 -0
  186. package/esm2022/components/tabs/tabs.mjs +322 -0
  187. package/esm2022/components/tag/index.mjs +2 -0
  188. package/esm2022/components/tag/model.mjs +2 -0
  189. package/esm2022/components/tag/tag.mjs +186 -0
  190. package/esm2022/components/textarea/index.mjs +2 -0
  191. package/esm2022/components/textarea/model.mjs +3 -0
  192. package/esm2022/components/textarea/textarea.mjs +363 -0
  193. package/esm2022/components/tooltip/index.mjs +2 -0
  194. package/esm2022/components/tooltip/model.mjs +2 -0
  195. package/esm2022/components/tooltip/tooltip.mjs +149 -0
  196. package/esm2022/db-ux-ngx-core-components.mjs +5 -0
  197. package/esm2022/index.mjs +41 -0
  198. package/esm2022/shared/constants.mjs +94 -0
  199. package/esm2022/shared/model.mjs +22 -0
  200. package/esm2022/utils/form-components.mjs +11 -0
  201. package/esm2022/utils/index.mjs +174 -0
  202. package/esm2022/utils/navigation.mjs +133 -0
  203. package/fesm2022/db-ux-ngx-core-components.mjs +6109 -0
  204. package/fesm2022/db-ux-ngx-core-components.mjs.map +1 -0
  205. package/index.d.ts +40 -0
  206. package/package.json +35 -0
  207. package/shared/constants.d.ts +83 -0
  208. package/shared/model.d.ts +445 -0
  209. package/utils/form-components.d.ts +2 -0
  210. package/utils/index.d.ts +61 -0
  211. 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==