@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,196 @@
1
+ import { Component, ViewChild, Input, } from "@angular/core";
2
+ import { CommonModule } from "@angular/common";
3
+ import { cls, uuid } from "../../utils";
4
+ import { DBAccordionItem } from "../accordion-item/accordion-item";
5
+ import { DEFAULT_ID } from "../../shared/constants";
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@angular/common";
8
+ const defaultProps = {};
9
+ export class DBAccordion {
10
+ constructor() {
11
+ this.cls = cls;
12
+ this._id = DEFAULT_ID;
13
+ this._name = "";
14
+ this.initialized = false;
15
+ this._initOpenIndexDone = false;
16
+ }
17
+ convertItems(items) {
18
+ try {
19
+ if (typeof items === "string") {
20
+ return JSON.parse(items);
21
+ }
22
+ return items;
23
+ }
24
+ catch (error) {
25
+ console.error(error);
26
+ }
27
+ return [];
28
+ }
29
+ trackByItem0(index, item) {
30
+ return `accordion-item-${index}`;
31
+ }
32
+ /**
33
+ * Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.
34
+ * @param element the ref for the component
35
+ * @param customElementSelector the custom element like `my-component`
36
+ */
37
+ enableAttributePassing(element, customElementSelector) {
38
+ const parent = element?.closest(customElementSelector);
39
+ if (element && parent) {
40
+ const attributes = parent.attributes;
41
+ for (let i = 0; i < attributes.length; i++) {
42
+ const attr = attributes.item(i);
43
+ if (attr &&
44
+ (attr.name.startsWith("data-") || attr.name.startsWith("aria-"))) {
45
+ element.setAttribute(attr.name, attr.value);
46
+ parent.removeAttribute(attr.name);
47
+ }
48
+ if (attr && attr.name === "class") {
49
+ const isWebComponent = attr.value.includes("hydrated");
50
+ const value = attr.value.replace("hydrated", "").trim();
51
+ const currentClass = element.getAttribute("class");
52
+ element.setAttribute(attr.name, `${currentClass ? `${currentClass} ` : ""}${value}`);
53
+ if (isWebComponent) {
54
+ // Stencil is using this class for lazy loading component
55
+ parent.setAttribute("class", "hydrated");
56
+ }
57
+ else {
58
+ parent.removeAttribute(attr.name);
59
+ }
60
+ }
61
+ }
62
+ }
63
+ }
64
+ ngOnInit() {
65
+ if (typeof window !== "undefined") {
66
+ this._id = this.id || "accordion-" + uuid();
67
+ this.initialized = true;
68
+ this._initOpenIndexDone = true;
69
+ }
70
+ }
71
+ ngAfterViewInit() {
72
+ const element = this._ref?.nativeElement;
73
+ this.enableAttributePassing(element, "db-accordion");
74
+ }
75
+ ngAfterContentChecked(changes) {
76
+ if (typeof window !== "undefined") {
77
+ // If we have a single behavior we first check for
78
+ // props.name otherwise for state_id
79
+ if (this.initialized) {
80
+ if (this.behavior === "single") {
81
+ if (this.name) {
82
+ if (this._name !== this.name) {
83
+ this._name = this.name;
84
+ }
85
+ }
86
+ else {
87
+ if (this._name !== this._id && this._id) {
88
+ this._name = this._id;
89
+ }
90
+ }
91
+ }
92
+ else {
93
+ this._name = "";
94
+ }
95
+ }
96
+ if (this._ref?.nativeElement) {
97
+ const childDetails = this._ref?.nativeElement.getElementsByTagName("details");
98
+ if (childDetails) {
99
+ for (const details of Array.from(childDetails)) {
100
+ if (this._name === "") {
101
+ details.removeAttribute("name");
102
+ }
103
+ else {
104
+ details.name = this._name;
105
+ }
106
+ }
107
+ }
108
+ }
109
+ if (this._ref?.nativeElement && this._initOpenIndexDone) {
110
+ if (this.initOpenIndex && this.initOpenIndex?.length > 0) {
111
+ const childDetails = this._ref?.nativeElement.getElementsByTagName("details");
112
+ if (childDetails) {
113
+ const initOpenIndex = this.behavior === "single" && this.initOpenIndex.length > 1
114
+ ? [this.initOpenIndex[0]] // use only one index for behavior=single
115
+ : this.initOpenIndex;
116
+ Array.from(childDetails).forEach((details, index) => {
117
+ if (initOpenIndex.includes(index)) {
118
+ details.open = true;
119
+ }
120
+ });
121
+ }
122
+ }
123
+ this._initOpenIndexDone = false;
124
+ }
125
+ }
126
+ }
127
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DBAccordion, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
128
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DBAccordion, isStandalone: true, selector: "db-accordion", inputs: { id: "id", name: "name", behavior: "behavior", initOpenIndex: "initOpenIndex", className: "className", variant: "variant", items: "items" }, viewQueries: [{ propertyName: "_ref", first: true, predicate: ["_ref"], descendants: true }], ngImport: i0, template: `
129
+ <ul
130
+ #_ref
131
+ [attr.id]="_id"
132
+ [class]="cls('db-accordion', className)"
133
+ [attr.data-variant]="variant"
134
+ >
135
+ <ng-container *ngIf="!items"><ng-content></ng-content></ng-container>
136
+ <ng-container *ngIf="items">
137
+ <ng-container
138
+ *ngFor="let item of convertItems(items); index as index; trackBy: trackByItem0"
139
+ >
140
+ <db-accordion-item
141
+ [headlinePlain]="item.headlinePlain"
142
+ [disabled]="item.disabled"
143
+ [text]="item.text"
144
+ ></db-accordion-item>
145
+ </ng-container>
146
+ </ng-container>
147
+ </ul>
148
+ `, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: DBAccordionItem, selector: "db-accordion-item", inputs: ["id", "defaultOpen", "className", "disabled", "headlinePlain", "text"], outputs: ["onToggle"] }] }); }
149
+ }
150
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DBAccordion, decorators: [{
151
+ type: Component,
152
+ args: [{
153
+ selector: "db-accordion",
154
+ template: `
155
+ <ul
156
+ #_ref
157
+ [attr.id]="_id"
158
+ [class]="cls('db-accordion', className)"
159
+ [attr.data-variant]="variant"
160
+ >
161
+ <ng-container *ngIf="!items"><ng-content></ng-content></ng-container>
162
+ <ng-container *ngIf="items">
163
+ <ng-container
164
+ *ngFor="let item of convertItems(items); index as index; trackBy: trackByItem0"
165
+ >
166
+ <db-accordion-item
167
+ [headlinePlain]="item.headlinePlain"
168
+ [disabled]="item.disabled"
169
+ [text]="item.text"
170
+ ></db-accordion-item>
171
+ </ng-container>
172
+ </ng-container>
173
+ </ul>
174
+ `,
175
+ standalone: true,
176
+ imports: [CommonModule, DBAccordionItem],
177
+ }]
178
+ }], propDecorators: { id: [{
179
+ type: Input
180
+ }], name: [{
181
+ type: Input
182
+ }], behavior: [{
183
+ type: Input
184
+ }], initOpenIndex: [{
185
+ type: Input
186
+ }], className: [{
187
+ type: Input
188
+ }], variant: [{
189
+ type: Input
190
+ }], items: [{
191
+ type: Input
192
+ }], _ref: [{
193
+ type: ViewChild,
194
+ args: ["_ref"]
195
+ }] } });
196
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"accordion.js","sourceRoot":"","sources":["../../../../../output/angular/src/components/accordion/accordion.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 { DBAccordionItemDefaultProps } from \"../accordion-item/model\";\nimport { DBAccordionProps, DBAccordionState } from \"./model\";\nimport { cls, uuid } from \"../../utils\";\nimport { DBAccordionItem } from \"../accordion-item/accordion-item\";\nimport { DEFAULT_ID } from \"../../shared/constants\";\n\n@Component({\n  selector: \"db-accordion\",\n  template: `\n    <ul\n      #_ref\n      [attr.id]=\"_id\"\n      [class]=\"cls('db-accordion', className)\"\n      [attr.data-variant]=\"variant\"\n    >\n      <ng-container *ngIf=\"!items\"><ng-content></ng-content></ng-container>\n      <ng-container *ngIf=\"items\">\n        <ng-container\n          *ngFor=\"let item of convertItems(items); index as index; trackBy: trackByItem0\"\n        >\n          <db-accordion-item\n            [headlinePlain]=\"item.headlinePlain\"\n            [disabled]=\"item.disabled\"\n            [text]=\"item.text\"\n          ></db-accordion-item>\n        </ng-container>\n      </ng-container>\n    </ul>\n  `,\n  standalone: true,\n  imports: [CommonModule, DBAccordionItem],\n})\nexport class DBAccordion {\n  cls = cls;\n\n  @Input() id!: DBAccordionProps[\"id\"];\n  @Input() name!: DBAccordionProps[\"name\"];\n  @Input() behavior!: DBAccordionProps[\"behavior\"];\n  @Input() initOpenIndex!: DBAccordionProps[\"initOpenIndex\"];\n  @Input() className!: DBAccordionProps[\"className\"];\n  @Input() variant!: DBAccordionProps[\"variant\"];\n  @Input() items!: DBAccordionProps[\"items\"];\n\n  @ViewChild(\"_ref\") _ref!: ElementRef | undefined;\n\n  _id: DBAccordionState[\"_id\"] = DEFAULT_ID;\n  _name: DBAccordionState[\"_name\"] = \"\";\n  initialized: DBAccordionState[\"initialized\"] = false;\n  _initOpenIndexDone: DBAccordionState[\"_initOpenIndexDone\"] = false;\n  convertItems(\n    items: unknown[] | string | undefined\n  ): ReturnType<DBAccordionState[\"convertItems\"]> {\n    try {\n      if (typeof items === \"string\") {\n        return JSON.parse(items);\n      }\n      return items as DBAccordionItemDefaultProps[];\n    } catch (error) {\n      console.error(error);\n    }\n    return [];\n  }\n  trackByItem0(index, item) {\n    return `accordion-item-${index}`;\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._id = this.id || \"accordion-\" + uuid();\n      this.initialized = true;\n      this._initOpenIndexDone = true;\n    }\n  }\n\n  ngAfterViewInit() {\n    const element: HTMLElement | null = this._ref?.nativeElement;\n    this.enableAttributePassing(element, \"db-accordion\");\n  }\n\n  ngAfterContentChecked(changes: SimpleChanges) {\n    if (typeof window !== \"undefined\") {\n      // If we have a single behavior we first check for\n      // props.name otherwise for state_id\n      if (this.initialized) {\n        if (this.behavior === \"single\") {\n          if (this.name) {\n            if (this._name !== this.name) {\n              this._name = this.name;\n            }\n          } else {\n            if (this._name !== this._id && this._id) {\n              this._name = this._id;\n            }\n          }\n        } else {\n          this._name = \"\";\n        }\n      }\n      if (this._ref?.nativeElement) {\n        const childDetails =\n          this._ref?.nativeElement.getElementsByTagName(\"details\");\n        if (childDetails) {\n          for (const details of Array.from<HTMLDetailsElement>(childDetails)) {\n            if (this._name === \"\") {\n              details.removeAttribute(\"name\");\n            } else {\n              details.name = this._name;\n            }\n          }\n        }\n      }\n      if (this._ref?.nativeElement && this._initOpenIndexDone) {\n        if (this.initOpenIndex && this.initOpenIndex?.length > 0) {\n          const childDetails =\n            this._ref?.nativeElement.getElementsByTagName(\"details\");\n          if (childDetails) {\n            const initOpenIndex =\n              this.behavior === \"single\" && this.initOpenIndex.length > 1\n                ? [this.initOpenIndex[0]] // use only one index for behavior=single\n                : this.initOpenIndex;\n            Array.from<HTMLDetailsElement>(childDetails).forEach(\n              (details: HTMLDetailsElement, index: number) => {\n                if (initOpenIndex.includes(index)) {\n                  details.open = true;\n                }\n              }\n            );\n          }\n        }\n        this._initOpenIndexDone = false;\n      }\n    }\n  }\n}\n"]}
@@ -0,0 +1,2 @@
1
+ export { DBAccordion } from './accordion';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9vdXRwdXQvYW5ndWxhci9zcmMvY29tcG9uZW50cy9hY2NvcmRpb24vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGFBQWEsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IERCQWNjb3JkaW9uIH0gZnJvbSAnLi9hY2NvcmRpb24nIl19
@@ -0,0 +1,3 @@
1
+ export const AccordionVariantList = ['divider', 'card'];
2
+ export const AccordionBehaviorList = ['multiple', 'single'];
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9vdXRwdXQvYW5ndWxhci9zcmMvY29tcG9uZW50cy9hY2NvcmRpb24vbW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxDQUFDLE1BQU0sb0JBQW9CLEdBQUksQ0FBQyxTQUFTLEVBQUUsTUFBTSxDQUFXLENBQUM7QUFFbkUsTUFBTSxDQUFDLE1BQU0scUJBQXFCLEdBQUksQ0FBQyxVQUFVLEVBQUUsUUFBUSxDQUFXLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBHbG9iYWxQcm9wcywgR2xvYmFsU3RhdGUsIEluaXRpYWxpemVkU3RhdGUgfSBmcm9tICcuLi8uLi9zaGFyZWQvbW9kZWwnO1xuaW1wb3J0IHsgREJBY2NvcmRpb25JdGVtRGVmYXVsdFByb3BzIH0gZnJvbSAnLi4vYWNjb3JkaW9uLWl0ZW0vbW9kZWwnO1xuZXhwb3J0IGNvbnN0IEFjY29yZGlvblZhcmlhbnRMaXN0ID0gKFsnZGl2aWRlcicsICdjYXJkJ10gYXMgY29uc3QpO1xuZXhwb3J0IHR5cGUgQWNjb3JkaW9uVmFyaWFudFR5cGUgPSAodHlwZW9mIEFjY29yZGlvblZhcmlhbnRMaXN0KVtudW1iZXJdO1xuZXhwb3J0IGNvbnN0IEFjY29yZGlvbkJlaGF2aW9yTGlzdCA9IChbJ211bHRpcGxlJywgJ3NpbmdsZSddIGFzIGNvbnN0KTtcbmV4cG9ydCB0eXBlIEFjY29yZGlvbkJlaGF2aW9yVHlwZSA9ICh0eXBlb2YgQWNjb3JkaW9uQmVoYXZpb3JMaXN0KVtudW1iZXJdO1xuZXhwb3J0IHR5cGUgREJBY2NvcmRpb25EZWZhdWx0UHJvcHMgPSB7XG4gIC8qKlxuICAgKiBUbyBhbGxvdyBtdWx0aXBsZSBpdGVtcyBvcGVuIGF0IHRoZSBzYW1lIHRpbWUgb3Igb25seSAxIGl0ZW1cbiAgICovXG4gIGJlaGF2aW9yPzogQWNjb3JkaW9uQmVoYXZpb3JUeXBlO1xuICAvKipcbiAgICogVGhlIGluZGV4IG9mIGl0ZW1zIHdoaWNoIHNob3VsZCBiZSBvcGVuIHdoZW4gbG9hZGluZyB0aGUgYWNjb3JkaW9uXG4gICAqL1xuICBpbml0T3BlbkluZGV4PzogbnVtYmVyW107XG5cbiAgLyoqXG4gICAqIEFsdGVybmF0aXZlIHRvIHBhc3MgaW4gYSBzaW1wbGUgcmVwcmVzZW50YXRpb24gb2YgYWNjb3JkaW9uIGl0ZW1zXG4gICAqL1xuICBpdGVtcz86IERCQWNjb3JkaW9uSXRlbURlZmF1bHRQcm9wc1tdIHwgc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBTZXQgZGV0YWlscyBuYW1lIGZvciBleGNsdXNpdmUgYWNjb3JkaW9ucywgc2VlIGh0dHBzOi8vZGV2ZWxvcGVyLm1vemlsbGEub3JnL2VuLVVTL2RvY3MvV2ViL0hUTUwvRWxlbWVudC9kZXRhaWxzI25hbWVcbiAgICovXG4gIG5hbWU/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEluZm9ybXMgYWJvdXQgdGhlIGNoYW5nZXMgaW4gdGhlIGludGVybmFsIHN0YXRlLCB3aGljaCBpdGVtIGlzIG9wZW5cbiAgICovXG4gIG9uQ2hhbmdlPzogKG9wZW5BY2NvcmRpb25JdGVtSWRzOiBzdHJpbmdbXSkgPT4gdm9pZDtcblxuICAvKipcbiAgICogRGVmaW5lcyB0aGUgZGlzcGxheSBvZiB0aGUgYWNjb3JkaW9uIGFuZCB0aGUgaXRlbXM6XG4gICAqIFwiZGl2aWRlclwiOiB3aXRoIGEgZGl2aWRpbmcgbGluZSBiZXR3ZWVuIHRoZSBpdGVtc1xuICAgKiBcImNhcmRcIjogdy9vIGRpdmlkaW5nIGxpbmUsIGJ1dCBpdGVtcyBhcmUgc2hvd24gaW4gdGhlIGNhcmQgdmFyaWFudFxuICAgKi9cbiAgdmFyaWFudD86IEFjY29yZGlvblZhcmlhbnRUeXBlO1xufTtcbmV4cG9ydCB0eXBlIERCQWNjb3JkaW9uUHJvcHMgPSBEQkFjY29yZGlvbkRlZmF1bHRQcm9wcyAmIEdsb2JhbFByb3BzO1xuZXhwb3J0IHR5cGUgREJBY2NvcmRpb25EZWZhdWx0U3RhdGUgPSB7XG4gIF9pbml0T3BlbkluZGV4RG9uZTogYm9vbGVhbjtcbiAgX25hbWU6IHN0cmluZztcbiAgY29udmVydEl0ZW1zOiAoaXRlbXM/OiB1bmtub3duW10gfCBzdHJpbmcpID0+IERCQWNjb3JkaW9uSXRlbURlZmF1bHRQcm9wc1tdO1xufTtcbmV4cG9ydCB0eXBlIERCQWNjb3JkaW9uU3RhdGUgPSBEQkFjY29yZGlvbkRlZmF1bHRTdGF0ZSAmIEdsb2JhbFN0YXRlICYgSW5pdGlhbGl6ZWRTdGF0ZSJdfQ==
@@ -0,0 +1,136 @@
1
+ import { Output, EventEmitter, Component, ViewChild, Input, } from "@angular/core";
2
+ import { CommonModule } from "@angular/common";
3
+ import { cls, getBooleanAsString, uuid } from "../../utils";
4
+ import { DEFAULT_ID } from "../../shared/constants";
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/common";
7
+ const defaultProps = {};
8
+ export class DBAccordionItem {
9
+ constructor() {
10
+ this.cls = cls;
11
+ this.getBooleanAsString = getBooleanAsString;
12
+ this.onToggle = new EventEmitter();
13
+ this._id = DEFAULT_ID;
14
+ this._open = false;
15
+ }
16
+ toggle(event) {
17
+ // We need this for react https://github.com/facebook/react/issues/15486#issuecomment-488028431
18
+ event?.preventDefault();
19
+ const newStateOpen = !this._open;
20
+ if (this.onToggle) {
21
+ this.onToggle.emit(newStateOpen);
22
+ }
23
+ this._open = newStateOpen;
24
+ }
25
+ /**
26
+ * Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.
27
+ * @param element the ref for the component
28
+ * @param customElementSelector the custom element like `my-component`
29
+ */
30
+ enableAttributePassing(element, customElementSelector) {
31
+ const parent = element?.closest(customElementSelector);
32
+ if (element && parent) {
33
+ const attributes = parent.attributes;
34
+ for (let i = 0; i < attributes.length; i++) {
35
+ const attr = attributes.item(i);
36
+ if (attr &&
37
+ (attr.name.startsWith("data-") || attr.name.startsWith("aria-"))) {
38
+ element.setAttribute(attr.name, attr.value);
39
+ parent.removeAttribute(attr.name);
40
+ }
41
+ if (attr && attr.name === "class") {
42
+ const isWebComponent = attr.value.includes("hydrated");
43
+ const value = attr.value.replace("hydrated", "").trim();
44
+ const currentClass = element.getAttribute("class");
45
+ element.setAttribute(attr.name, `${currentClass ? `${currentClass} ` : ""}${value}`);
46
+ if (isWebComponent) {
47
+ // Stencil is using this class for lazy loading component
48
+ parent.setAttribute("class", "hydrated");
49
+ }
50
+ else {
51
+ parent.removeAttribute(attr.name);
52
+ }
53
+ }
54
+ }
55
+ }
56
+ }
57
+ ngOnInit() {
58
+ if (typeof window !== "undefined") {
59
+ this._id = this.id || "accordion-item-" + uuid();
60
+ if (this.defaultOpen) {
61
+ this._open = this.defaultOpen;
62
+ }
63
+ }
64
+ }
65
+ ngAfterViewInit() {
66
+ const element = this._ref?.nativeElement;
67
+ this.enableAttributePassing(element, "db-accordion-item");
68
+ }
69
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DBAccordionItem, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
70
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DBAccordionItem, isStandalone: true, selector: "db-accordion-item", inputs: { id: "id", defaultOpen: "defaultOpen", className: "className", disabled: "disabled", headlinePlain: "headlinePlain", text: "text" }, outputs: { onToggle: "onToggle" }, viewQueries: [{ propertyName: "_ref", first: true, predicate: ["_ref"], descendants: true }], ngImport: i0, template: `
71
+ <li [attr.id]="_id" [class]="cls('db-accordion-item', className)">
72
+ <details
73
+ [attr.aria-disabled]="getBooleanAsString(disabled)"
74
+ #_ref
75
+ [open]="_open"
76
+ >
77
+ <summary (click)="toggle($event)">
78
+ <ng-container *ngIf="headlinePlain">{{headlinePlain}}</ng-container>
79
+ <ng-container *ngIf="!headlinePlain">
80
+ <ng-content select="[headline]"></ng-content>
81
+ </ng-container>
82
+ </summary>
83
+ <div>
84
+ <ng-container *ngIf="text">{{text}}</ng-container>
85
+ <ng-container *ngIf="!(text)"><ng-content></ng-content></ng-container>
86
+ </div>
87
+ </details>
88
+ </li>
89
+ `, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
90
+ }
91
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DBAccordionItem, decorators: [{
92
+ type: Component,
93
+ args: [{
94
+ selector: "db-accordion-item",
95
+ template: `
96
+ <li [attr.id]="_id" [class]="cls('db-accordion-item', className)">
97
+ <details
98
+ [attr.aria-disabled]="getBooleanAsString(disabled)"
99
+ #_ref
100
+ [open]="_open"
101
+ >
102
+ <summary (click)="toggle($event)">
103
+ <ng-container *ngIf="headlinePlain">{{headlinePlain}}</ng-container>
104
+ <ng-container *ngIf="!headlinePlain">
105
+ <ng-content select="[headline]"></ng-content>
106
+ </ng-container>
107
+ </summary>
108
+ <div>
109
+ <ng-container *ngIf="text">{{text}}</ng-container>
110
+ <ng-container *ngIf="!(text)"><ng-content></ng-content></ng-container>
111
+ </div>
112
+ </details>
113
+ </li>
114
+ `,
115
+ standalone: true,
116
+ imports: [CommonModule],
117
+ }]
118
+ }], propDecorators: { id: [{
119
+ type: Input
120
+ }], defaultOpen: [{
121
+ type: Input
122
+ }], className: [{
123
+ type: Input
124
+ }], disabled: [{
125
+ type: Input
126
+ }], headlinePlain: [{
127
+ type: Input
128
+ }], text: [{
129
+ type: Input
130
+ }], onToggle: [{
131
+ type: Output
132
+ }], _ref: [{
133
+ type: ViewChild,
134
+ args: ["_ref"]
135
+ }] } });
136
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"accordion-item.js","sourceRoot":"","sources":["../../../../../output/angular/src/components/accordion-item/accordion-item.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 { DBAccordionItemProps, DBAccordionItemState } from \"./model\";\nimport { cls, getBooleanAsString, uuid } from \"../../utils\";\nimport { ClickEvent } from \"../../shared/model\";\nimport { DEFAULT_ID } from \"../../shared/constants\";\n\n@Component({\n  selector: \"db-accordion-item\",\n  template: `\n    <li [attr.id]=\"_id\" [class]=\"cls('db-accordion-item', className)\">\n      <details\n        [attr.aria-disabled]=\"getBooleanAsString(disabled)\"\n        #_ref\n        [open]=\"_open\"\n      >\n        <summary (click)=\"toggle($event)\">\n          <ng-container *ngIf=\"headlinePlain\">{{headlinePlain}}</ng-container>\n          <ng-container *ngIf=\"!headlinePlain\">\n            <ng-content select=\"[headline]\"></ng-content>\n          </ng-container>\n        </summary>\n        <div>\n          <ng-container *ngIf=\"text\">{{text}}</ng-container>\n          <ng-container *ngIf=\"!(text)\"><ng-content></ng-content></ng-container>\n        </div>\n      </details>\n    </li>\n  `,\n  standalone: true,\n  imports: [CommonModule],\n})\nexport class DBAccordionItem {\n  cls = cls;\n  getBooleanAsString = getBooleanAsString;\n\n  @Input() id!: DBAccordionItemProps[\"id\"];\n  @Input() defaultOpen!: DBAccordionItemProps[\"defaultOpen\"];\n  @Input() className!: DBAccordionItemProps[\"className\"];\n  @Input() disabled!: DBAccordionItemProps[\"disabled\"];\n  @Input() headlinePlain!: DBAccordionItemProps[\"headlinePlain\"];\n  @Input() text!: DBAccordionItemProps[\"text\"];\n\n  @Output() onToggle = new EventEmitter();\n\n  @ViewChild(\"_ref\") _ref!: ElementRef | undefined;\n\n  _id: DBAccordionItemState[\"_id\"] = DEFAULT_ID;\n  _open: DBAccordionItemState[\"_open\"] = false;\n  toggle(\n    event: ClickEvent<HTMLElement>\n  ): ReturnType<DBAccordionItemState[\"toggle\"]> {\n    // We need this for react https://github.com/facebook/react/issues/15486#issuecomment-488028431\n    event?.preventDefault();\n    const newStateOpen = !this._open;\n    if (this.onToggle) {\n      this.onToggle.emit(newStateOpen);\n    }\n    this._open = newStateOpen;\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._id = this.id || \"accordion-item-\" + uuid();\n      if (this.defaultOpen) {\n        this._open = this.defaultOpen;\n      }\n    }\n  }\n\n  ngAfterViewInit() {\n    const element: HTMLElement | null = this._ref?.nativeElement;\n    this.enableAttributePassing(element, \"db-accordion-item\");\n  }\n}\n"]}
@@ -0,0 +1,2 @@
1
+ export { DBAccordionItem } from './accordion-item';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9vdXRwdXQvYW5ndWxhci9zcmMvY29tcG9uZW50cy9hY2NvcmRpb24taXRlbS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sa0JBQWtCLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBEQkFjY29yZGlvbkl0ZW0gfSBmcm9tICcuL2FjY29yZGlvbi1pdGVtJyJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9vdXRwdXQvYW5ndWxhci9zcmMvY29tcG9uZW50cy9hY2NvcmRpb24taXRlbS9tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgR2xvYmFsUHJvcHMsIEdsb2JhbFN0YXRlLCBUZXh0UHJvcHMsIFRvZ2dsZUV2ZW50UHJvcHMsIFRvZ2dsZUV2ZW50U3RhdGUgfSBmcm9tICcuLi8uLi9zaGFyZWQvbW9kZWwnO1xuZXhwb3J0IHR5cGUgREJBY2NvcmRpb25JdGVtRGVmYXVsdFByb3BzID0ge1xuICAvKipcbiAgICogSW5pdGlhbCBzdGF0ZSBmb3IgdGhlIGFjY29yZGlvbiBpdGVtXG4gICAqL1xuICBkZWZhdWx0T3Blbj86IGJvb2xlYW47XG4gIC8qKlxuICAgKiBUaGUgZGlzYWJsZWQgYXR0cmlidXRlIGNhbiBiZSBzZXQgdG8ga2VlcCBhIHVzZXIgZnJvbSBjbGlja2luZyBvbiB0aGUgZWxlbWVudC5cbiAgICovXG4gIGRpc2FibGVkPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIFRpdGxlIG9mIHRoZSBhY2NvcmRpb24taXRlbSBhcyBzbG90XG4gICAqL1xuICBoZWFkbGluZT86IGFueTtcbiAgLyoqXG4gICAqIFRpdGxlIG9mIHRoZSBhY2NvcmRpb24taXRlbSBhcyBwbGFpbiB0ZXh0XG4gICAqL1xuICBoZWFkbGluZVBsYWluPzogc3RyaW5nO1xufSAmIFRleHRQcm9wcztcbmV4cG9ydCB0eXBlIERCQWNjb3JkaW9uSXRlbVByb3BzID0gREJBY2NvcmRpb25JdGVtRGVmYXVsdFByb3BzICYgR2xvYmFsUHJvcHMgJiBUb2dnbGVFdmVudFByb3BzO1xuZXhwb3J0IHR5cGUgREJBY2NvcmRpb25JdGVtRGVmYXVsdFN0YXRlID0ge1xuICBfb3BlbjogYm9vbGVhbjtcbn07XG5leHBvcnQgdHlwZSBEQkFjY29yZGlvbkl0ZW1TdGF0ZSA9IERCQWNjb3JkaW9uSXRlbURlZmF1bHRTdGF0ZSAmIEdsb2JhbFN0YXRlICYgVG9nZ2xlRXZlbnRTdGF0ZTxIVE1MRWxlbWVudD4iXX0=
@@ -0,0 +1,130 @@
1
+ import { Component, ViewChild, Input, } from "@angular/core";
2
+ import { CommonModule } from "@angular/common";
3
+ import { cls } from "../../utils";
4
+ import { DEFAULT_LABEL } from "../../shared/constants";
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/common";
7
+ const defaultProps = {};
8
+ export class DBBadge {
9
+ constructor() {
10
+ this.cls = cls;
11
+ this.DEFAULT_LABEL = DEFAULT_LABEL;
12
+ this.initialized = false;
13
+ }
14
+ /**
15
+ * Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.
16
+ * @param element the ref for the component
17
+ * @param customElementSelector the custom element like `my-component`
18
+ */
19
+ enableAttributePassing(element, customElementSelector) {
20
+ const parent = element?.closest(customElementSelector);
21
+ if (element && parent) {
22
+ const attributes = parent.attributes;
23
+ for (let i = 0; i < attributes.length; i++) {
24
+ const attr = attributes.item(i);
25
+ if (attr &&
26
+ (attr.name.startsWith("data-") || attr.name.startsWith("aria-"))) {
27
+ element.setAttribute(attr.name, attr.value);
28
+ parent.removeAttribute(attr.name);
29
+ }
30
+ if (attr && attr.name === "class") {
31
+ const isWebComponent = attr.value.includes("hydrated");
32
+ const value = attr.value.replace("hydrated", "").trim();
33
+ const currentClass = element.getAttribute("class");
34
+ element.setAttribute(attr.name, `${currentClass ? `${currentClass} ` : ""}${value}`);
35
+ if (isWebComponent) {
36
+ // Stencil is using this class for lazy loading component
37
+ parent.setAttribute("class", "hydrated");
38
+ }
39
+ else {
40
+ parent.removeAttribute(attr.name);
41
+ }
42
+ }
43
+ }
44
+ }
45
+ }
46
+ ngOnInit() {
47
+ if (typeof window !== "undefined") {
48
+ this.initialized = true;
49
+ }
50
+ }
51
+ ngAfterViewInit() {
52
+ const element = this._ref?.nativeElement;
53
+ this.enableAttributePassing(element, "db-badge");
54
+ }
55
+ ngAfterContentChecked(changes) {
56
+ if (typeof window !== "undefined") {
57
+ if (this._ref?.nativeElement && this.initialized) {
58
+ if (this.placement?.startsWith("corner")) {
59
+ let parent = this._ref.nativeElement.parentElement;
60
+ if (parent && parent.localName.includes("badge")) {
61
+ // Angular workaround
62
+ parent = parent.parentElement;
63
+ }
64
+ if (parent) {
65
+ parent.setAttribute("data-has-badge", "true");
66
+ }
67
+ }
68
+ }
69
+ }
70
+ }
71
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DBBadge, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
72
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DBBadge, isStandalone: true, selector: "db-badge", inputs: { placement: "placement", id: "id", className: "className", semantic: "semantic", size: "size", emphasis: "emphasis", label: "label", text: "text" }, viewQueries: [{ propertyName: "_ref", first: true, predicate: ["_ref"], descendants: true }], ngImport: i0, template: `
73
+ <span
74
+ #_ref
75
+ [attr.id]="id"
76
+ [class]="cls('db-badge', className)"
77
+ [attr.data-semantic]="semantic"
78
+ [attr.data-size]="size"
79
+ [attr.data-emphasis]="emphasis"
80
+ [attr.data-placement]="placement"
81
+ [attr.data-label]="placement?.startsWith('corner') && (label ?? DEFAULT_LABEL)"
82
+ >
83
+ <ng-container *ngIf="text">{{text}}</ng-container>
84
+ <ng-container *ngIf="!(text)"><ng-content></ng-content></ng-container>
85
+ </span>
86
+ `, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
87
+ }
88
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DBBadge, decorators: [{
89
+ type: Component,
90
+ args: [{
91
+ selector: "db-badge",
92
+ template: `
93
+ <span
94
+ #_ref
95
+ [attr.id]="id"
96
+ [class]="cls('db-badge', className)"
97
+ [attr.data-semantic]="semantic"
98
+ [attr.data-size]="size"
99
+ [attr.data-emphasis]="emphasis"
100
+ [attr.data-placement]="placement"
101
+ [attr.data-label]="placement?.startsWith('corner') && (label ?? DEFAULT_LABEL)"
102
+ >
103
+ <ng-container *ngIf="text">{{text}}</ng-container>
104
+ <ng-container *ngIf="!(text)"><ng-content></ng-content></ng-container>
105
+ </span>
106
+ `,
107
+ standalone: true,
108
+ imports: [CommonModule],
109
+ }]
110
+ }], propDecorators: { placement: [{
111
+ type: Input
112
+ }], id: [{
113
+ type: Input
114
+ }], className: [{
115
+ type: Input
116
+ }], semantic: [{
117
+ type: Input
118
+ }], size: [{
119
+ type: Input
120
+ }], emphasis: [{
121
+ type: Input
122
+ }], label: [{
123
+ type: Input
124
+ }], text: [{
125
+ type: Input
126
+ }], _ref: [{
127
+ type: ViewChild,
128
+ args: ["_ref"]
129
+ }] } });
130
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"badge.js","sourceRoot":"","sources":["../../../../../output/angular/src/components/badge/badge.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 { DBBadgeProps, DBBadgeState } from \"./model\";\nimport { cls } from \"../../utils\";\nimport { DEFAULT_LABEL } from \"../../shared/constants\";\n\n@Component({\n  selector: \"db-badge\",\n  template: `\n    <span\n      #_ref\n      [attr.id]=\"id\"\n      [class]=\"cls('db-badge', className)\"\n      [attr.data-semantic]=\"semantic\"\n      [attr.data-size]=\"size\"\n      [attr.data-emphasis]=\"emphasis\"\n      [attr.data-placement]=\"placement\"\n      [attr.data-label]=\"placement?.startsWith('corner') && (label ?? DEFAULT_LABEL)\"\n    >\n      <ng-container *ngIf=\"text\">{{text}}</ng-container>\n      <ng-container *ngIf=\"!(text)\"><ng-content></ng-content></ng-container>\n    </span>\n  `,\n  standalone: true,\n  imports: [CommonModule],\n})\nexport class DBBadge {\n  cls = cls;\n  DEFAULT_LABEL = DEFAULT_LABEL;\n\n  @Input() placement!: DBBadgeProps[\"placement\"];\n  @Input() id!: DBBadgeProps[\"id\"];\n  @Input() className!: DBBadgeProps[\"className\"];\n  @Input() semantic!: DBBadgeProps[\"semantic\"];\n  @Input() size!: DBBadgeProps[\"size\"];\n  @Input() emphasis!: DBBadgeProps[\"emphasis\"];\n  @Input() label!: DBBadgeProps[\"label\"];\n  @Input() text!: DBBadgeProps[\"text\"];\n\n  @ViewChild(\"_ref\") _ref!: ElementRef | undefined;\n\n  initialized: DBBadgeState[\"initialized\"] = 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 (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-badge\");\n  }\n\n  ngAfterContentChecked(changes: SimpleChanges) {\n    if (typeof window !== \"undefined\") {\n      if (this._ref?.nativeElement && this.initialized) {\n        if (this.placement?.startsWith(\"corner\")) {\n          let parent = this._ref.nativeElement.parentElement;\n          if (parent && parent.localName.includes(\"badge\")) {\n            // Angular workaround\n            parent = parent.parentElement;\n          }\n          if (parent) {\n            parent.setAttribute(\"data-has-badge\", \"true\");\n          }\n        }\n      }\n    }\n  }\n}\n"]}
@@ -0,0 +1,2 @@
1
+ export { DBBadge } from './badge';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9vdXRwdXQvYW5ndWxhci9zcmMvY29tcG9uZW50cy9iYWRnZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sU0FBUyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgREJCYWRnZSB9IGZyb20gJy4vYmFkZ2UnIl19
@@ -0,0 +1,2 @@
1
+ export const BadgePlacementList = ['inline', 'corner-top-left', 'corner-top-right', 'corner-center-left', 'corner-center-right', 'corner-bottom-left', 'corner-bottom-right'];
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9vdXRwdXQvYW5ndWxhci9zcmMvY29tcG9uZW50cy9iYWRnZS9tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBSSxDQUFDLFFBQVEsRUFBRSxpQkFBaUIsRUFBRSxrQkFBa0IsRUFBRSxvQkFBb0IsRUFBRSxxQkFBcUIsRUFBRSxvQkFBb0IsRUFBRSxxQkFBcUIsQ0FBVyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgR2xvYmFsUHJvcHMsIEdsb2JhbFN0YXRlLCBJbml0aWFsaXplZFN0YXRlLCBTZW1hbnRpY1Byb3BzLCBTaXplUHJvcHMsIFRhZ0VtcGhhc2lzUHJvcHMsIFRleHRQcm9wcyB9IGZyb20gJy4uLy4uL3NoYXJlZC9tb2RlbCc7XG5leHBvcnQgY29uc3QgQmFkZ2VQbGFjZW1lbnRMaXN0ID0gKFsnaW5saW5lJywgJ2Nvcm5lci10b3AtbGVmdCcsICdjb3JuZXItdG9wLXJpZ2h0JywgJ2Nvcm5lci1jZW50ZXItbGVmdCcsICdjb3JuZXItY2VudGVyLXJpZ2h0JywgJ2Nvcm5lci1ib3R0b20tbGVmdCcsICdjb3JuZXItYm90dG9tLXJpZ2h0J10gYXMgY29uc3QpO1xuZXhwb3J0IHR5cGUgQmFkZ2VQbGFjZW1lbnRUeXBlID0gKHR5cGVvZiBCYWRnZVBsYWNlbWVudExpc3QpW251bWJlcl07XG5leHBvcnQgdHlwZSBEQkJhZGdlRGVmYXVsdFByb3BzID0ge1xuICAvKipcbiAgICogVGhlIGBwbGFjZW1lbnRgIGF0dHJpYnV0ZXMgYGNvcm5lci0qYCB2YWx1ZXMgY2hhbmdlIHRoZSBwb3NpdGlvbiB0byBhYnNvbHV0ZSBhbmQgYWRkcyBhIHRyYW5zZm9ybSBiYXNlZCBvbiB0aGUgcGxhY2VtZW50LlxuICAgKi9cbiAgcGxhY2VtZW50PzogQmFkZ2VQbGFjZW1lbnRUeXBlO1xuXG4gIC8qKlxuICAgKiBEZXNjcmliZXMgdGhlIGJhZGdlIGZvciBhMTF5IGlmIHlvdSB1c2UgcGxhY2VtZW50IGF0dHJpYnV0ZSB3aXRoIGBjb3JuZXItKmBcbiAgICovXG4gIGxhYmVsPzogc3RyaW5nO1xufTtcbmV4cG9ydCB0eXBlIERCQmFkZ2VQcm9wcyA9IERCQmFkZ2VEZWZhdWx0UHJvcHMgJiBHbG9iYWxQcm9wcyAmIFNlbWFudGljUHJvcHMgJiBTaXplUHJvcHMgJiBUYWdFbXBoYXNpc1Byb3BzICYgVGV4dFByb3BzO1xuZXhwb3J0IHR5cGUgREJCYWRnZURlZmF1bHRTdGF0ZSA9IHt9O1xuZXhwb3J0IHR5cGUgREJCYWRnZVN0YXRlID0gREJCYWRnZURlZmF1bHRTdGF0ZSAmIEdsb2JhbFN0YXRlICYgSW5pdGlhbGl6ZWRTdGF0ZSJdfQ==