@db-ux/wc-core-components 3.1.16 → 3.1.18

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 (233) hide show
  1. package/README.md +10 -0
  2. package/agent/Accordion.md +23 -0
  3. package/agent/AccordionItem.md +29 -0
  4. package/agent/Badge.md +32 -0
  5. package/agent/Brand.md +13 -0
  6. package/agent/Button.md +47 -0
  7. package/agent/Card.md +23 -0
  8. package/agent/Checkbox.md +41 -0
  9. package/agent/CustomSelect.md +54 -0
  10. package/agent/Divider.md +21 -0
  11. package/agent/Drawer.md +71 -0
  12. package/agent/Header.md +29 -0
  13. package/agent/Icon.md +20 -0
  14. package/agent/Infotext.md +25 -0
  15. package/agent/Input.md +48 -0
  16. package/agent/Link.md +52 -0
  17. package/agent/Navigation.md +19 -0
  18. package/agent/NavigationItem.md +29 -0
  19. package/agent/Notification.md +38 -0
  20. package/agent/Page.md +27 -0
  21. package/agent/Popover.md +52 -0
  22. package/agent/Radio.md +28 -0
  23. package/agent/Section.md +21 -0
  24. package/agent/Select.md +62 -0
  25. package/agent/Stack.md +35 -0
  26. package/agent/Switch.md +44 -0
  27. package/agent/TabItem.md +25 -0
  28. package/agent/Tabs.md +61 -0
  29. package/agent/Tag.md +41 -0
  30. package/agent/Textarea.md +44 -0
  31. package/agent/Tooltip.md +37 -0
  32. package/agent/_instructions.md +31 -0
  33. package/dist/cjs/db-accordion-item.cjs.entry.js +1 -1
  34. package/dist/cjs/db-accordion.cjs.entry.js +1 -1
  35. package/dist/cjs/db-badge.cjs.entry.js +1 -1
  36. package/dist/cjs/db-brand.cjs.entry.js +1 -1
  37. package/dist/cjs/db-button.cjs.entry.js +1 -1
  38. package/dist/cjs/db-card.cjs.entry.js +1 -1
  39. package/dist/cjs/db-checkbox.cjs.entry.js +1 -1
  40. package/dist/cjs/db-custom-select-dropdown_5.cjs.entry.js +1 -1
  41. package/dist/cjs/db-custom-select-form-field.cjs.entry.js +1 -1
  42. package/dist/cjs/db-custom-select.cjs.entry.js +1 -1
  43. package/dist/cjs/db-divider.cjs.entry.js +1 -1
  44. package/dist/cjs/db-drawer.cjs.entry.js +1 -1
  45. package/dist/cjs/db-header.cjs.entry.js +1 -1
  46. package/dist/cjs/db-icon.cjs.entry.js +1 -1
  47. package/dist/cjs/db-infotext.cjs.entry.js +1 -1
  48. package/dist/cjs/db-link.cjs.entry.js +1 -1
  49. package/dist/cjs/db-navigation-item.cjs.entry.js +1 -1
  50. package/dist/cjs/db-navigation.cjs.entry.js +1 -1
  51. package/dist/cjs/db-notification.cjs.entry.js +1 -1
  52. package/dist/cjs/db-page.cjs.entry.js +1 -1
  53. package/dist/cjs/db-popover.cjs.entry.js +1 -1
  54. package/dist/cjs/db-radio.cjs.entry.js +1 -1
  55. package/dist/cjs/db-section.cjs.entry.js +1 -1
  56. package/dist/cjs/db-select.cjs.entry.js +1 -1
  57. package/dist/cjs/db-stack.cjs.entry.js +1 -1
  58. package/dist/cjs/db-switch.cjs.entry.js +1 -1
  59. package/dist/cjs/db-tab-item_3.cjs.entry.js +1 -1
  60. package/dist/cjs/db-tabs.cjs.entry.js +17 -3
  61. package/dist/cjs/db-tabs.entry.cjs.js.map +1 -1
  62. package/dist/cjs/db-textarea.cjs.entry.js +1 -1
  63. package/dist/cjs/db-tooltip.cjs.entry.js +1 -1
  64. package/dist/cjs/db-ux.cjs.js +3 -3
  65. package/dist/cjs/db-ux.cjs.js.map +1 -1
  66. package/dist/cjs/{index-C9Rhca83.js → index-BKsFzv8w.js} +39 -17
  67. package/dist/cjs/index-BKsFzv8w.js.map +1 -0
  68. package/dist/cjs/index.cjs.js +1 -1
  69. package/dist/cjs/index.cjs.js.map +1 -1
  70. package/dist/cjs/loader.cjs.js +2 -2
  71. package/dist/collection/collection-manifest.json +1 -1
  72. package/dist/collection/components/accordion/accordion.js +12 -13
  73. package/dist/collection/components/accordion/accordion.js.map +1 -1
  74. package/dist/collection/components/accordion-item/accordion-item.js +14 -14
  75. package/dist/collection/components/badge/badge.js +16 -16
  76. package/dist/collection/components/brand/brand.js +12 -12
  77. package/dist/collection/components/button/button.js +36 -36
  78. package/dist/collection/components/card/card.js +10 -10
  79. package/dist/collection/components/checkbox/checkbox.js +38 -38
  80. package/dist/collection/components/custom-select/custom-select.js +82 -87
  81. package/dist/collection/components/custom-select/custom-select.js.map +1 -1
  82. package/dist/collection/components/custom-select-dropdown/custom-select-dropdown.js +5 -5
  83. package/dist/collection/components/custom-select-form-field/custom-select-form-field.js +4 -4
  84. package/dist/collection/components/custom-select-list/custom-select-list.js +8 -8
  85. package/dist/collection/components/custom-select-list-item/custom-select-list-item.js +26 -26
  86. package/dist/collection/components/divider/divider.js +12 -12
  87. package/dist/collection/components/drawer/drawer.js +24 -24
  88. package/dist/collection/components/header/header.js +12 -12
  89. package/dist/collection/components/icon/icon.js +12 -12
  90. package/dist/collection/components/infotext/infotext.js +14 -14
  91. package/dist/collection/components/input/input.js +94 -95
  92. package/dist/collection/components/input/input.js.map +1 -1
  93. package/dist/collection/components/link/link.js +28 -28
  94. package/dist/collection/components/navigation/navigation.js +4 -4
  95. package/dist/collection/components/navigation-item/navigation-item.js +24 -24
  96. package/dist/collection/components/notification/notification.js +32 -32
  97. package/dist/collection/components/page/page.js +12 -12
  98. package/dist/collection/components/popover/popover.js +18 -18
  99. package/dist/collection/components/radio/radio.js +24 -24
  100. package/dist/collection/components/section/section.js +8 -8
  101. package/dist/collection/components/select/select.js +46 -47
  102. package/dist/collection/components/select/select.js.map +1 -1
  103. package/dist/collection/components/stack/stack.js +16 -16
  104. package/dist/collection/components/switch/switch.js +34 -34
  105. package/dist/collection/components/tab-item/tab-item.js +28 -28
  106. package/dist/collection/components/tab-list/tab-list.js +4 -4
  107. package/dist/collection/components/tab-panel/tab-panel.js +6 -6
  108. package/dist/collection/components/tabs/model.js.map +1 -1
  109. package/dist/collection/components/tabs/tabs.js +40 -25
  110. package/dist/collection/components/tabs/tabs.js.map +1 -1
  111. package/dist/collection/components/tag/tag.js +24 -24
  112. package/dist/collection/components/textarea/textarea.js +66 -66
  113. package/dist/collection/components/tooltip/tooltip.js +18 -18
  114. package/dist/custom-elements.json +5 -0
  115. package/dist/db-ux/db-tabs.entry.esm.js.map +1 -1
  116. package/dist/db-ux/db-ux.esm.js +1 -1
  117. package/dist/db-ux/db-ux.esm.js.map +1 -1
  118. package/dist/db-ux/index.esm.js +1 -1
  119. package/dist/db-ux/index.esm.js.map +1 -1
  120. package/dist/db-ux/p-07a7eb33.entry.js +2 -0
  121. package/dist/db-ux/{p-8aee262b.entry.js → p-109fc276.entry.js} +2 -2
  122. package/dist/db-ux/{p-0f032718.entry.js → p-132ee89d.entry.js} +2 -2
  123. package/dist/db-ux/{p-8d5578c8.entry.js → p-1a7001bb.entry.js} +2 -2
  124. package/dist/db-ux/{p-9d814d7a.entry.js → p-1c50fd87.entry.js} +2 -2
  125. package/dist/db-ux/{p-f2455023.entry.js → p-1f490d67.entry.js} +2 -2
  126. package/dist/db-ux/{p-9b3c4d53.entry.js → p-26e115a8.entry.js} +2 -2
  127. package/dist/db-ux/p-2bc4be80.entry.js +2 -0
  128. package/dist/db-ux/p-2bc4be80.entry.js.map +1 -0
  129. package/dist/db-ux/{p-7781b021.entry.js → p-2c457e48.entry.js} +2 -2
  130. package/dist/db-ux/{p-dab91ef7.entry.js → p-31b7ea66.entry.js} +2 -2
  131. package/dist/db-ux/{p-ba53d150.entry.js → p-3390e528.entry.js} +2 -2
  132. package/dist/db-ux/{p-15203628.entry.js → p-364cc533.entry.js} +2 -2
  133. package/dist/db-ux/{p-5a727411.entry.js → p-43be6218.entry.js} +2 -2
  134. package/dist/db-ux/{p-5138e073.entry.js → p-53c419b0.entry.js} +2 -2
  135. package/dist/db-ux/{p-6839aee1.entry.js → p-56488bc3.entry.js} +2 -2
  136. package/dist/db-ux/p-69a7e5f9.entry.js +2 -0
  137. package/dist/db-ux/{p-daf5421b.entry.js → p-72bd1665.entry.js} +2 -2
  138. package/dist/db-ux/{p-97d43713.entry.js → p-75d3a947.entry.js} +2 -2
  139. package/dist/db-ux/{p-9d416e4d.entry.js → p-82083293.entry.js} +2 -2
  140. package/dist/db-ux/{p-d93d61bf.entry.js → p-90f21d44.entry.js} +2 -2
  141. package/dist/db-ux/{p-97249510.entry.js → p-950bf6ab.entry.js} +2 -2
  142. package/dist/db-ux/{p-af4b9154.entry.js → p-963fde68.entry.js} +2 -2
  143. package/dist/db-ux/p-Bxi-mtJ7.js +3 -0
  144. package/dist/db-ux/p-Bxi-mtJ7.js.map +1 -0
  145. package/dist/db-ux/p-a7a0c5a3.entry.js +2 -0
  146. package/dist/db-ux/{p-dc14db0e.entry.js.map → p-a7a0c5a3.entry.js.map} +1 -1
  147. package/dist/db-ux/{p-0cea77e9.entry.js → p-ad8ff0ae.entry.js} +2 -2
  148. package/dist/db-ux/{p-c3673bb2.entry.js → p-b3ccfc6a.entry.js} +2 -2
  149. package/dist/db-ux/{p-31d8532f.entry.js → p-c9b2b24e.entry.js} +2 -2
  150. package/dist/db-ux/{p-e80a85c6.entry.js → p-cd51d733.entry.js} +2 -2
  151. package/dist/db-ux/{p-97114cd9.entry.js → p-d0a2e1d4.entry.js} +2 -2
  152. package/dist/db-ux/{p-cad3a6ca.entry.js → p-da7e3ac7.entry.js} +2 -2
  153. package/dist/db-ux/{p-ec96cc5c.entry.js → p-fbf46ee6.entry.js} +2 -2
  154. package/dist/esm/db-accordion-item.entry.js +1 -1
  155. package/dist/esm/db-accordion.entry.js +1 -1
  156. package/dist/esm/db-badge.entry.js +1 -1
  157. package/dist/esm/db-brand.entry.js +1 -1
  158. package/dist/esm/db-button.entry.js +1 -1
  159. package/dist/esm/db-card.entry.js +1 -1
  160. package/dist/esm/db-checkbox.entry.js +1 -1
  161. package/dist/esm/db-custom-select-dropdown_5.entry.js +1 -1
  162. package/dist/esm/db-custom-select-form-field.entry.js +1 -1
  163. package/dist/esm/db-custom-select.entry.js +1 -1
  164. package/dist/esm/db-divider.entry.js +1 -1
  165. package/dist/esm/db-drawer.entry.js +1 -1
  166. package/dist/esm/db-header.entry.js +1 -1
  167. package/dist/esm/db-icon.entry.js +1 -1
  168. package/dist/esm/db-infotext.entry.js +1 -1
  169. package/dist/esm/db-link.entry.js +1 -1
  170. package/dist/esm/db-navigation-item.entry.js +1 -1
  171. package/dist/esm/db-navigation.entry.js +1 -1
  172. package/dist/esm/db-notification.entry.js +1 -1
  173. package/dist/esm/db-page.entry.js +1 -1
  174. package/dist/esm/db-popover.entry.js +1 -1
  175. package/dist/esm/db-radio.entry.js +1 -1
  176. package/dist/esm/db-section.entry.js +1 -1
  177. package/dist/esm/db-select.entry.js +1 -1
  178. package/dist/esm/db-stack.entry.js +1 -1
  179. package/dist/esm/db-switch.entry.js +1 -1
  180. package/dist/esm/db-tab-item_3.entry.js +1 -1
  181. package/dist/esm/db-tabs.entry.js +17 -3
  182. package/dist/esm/db-tabs.entry.js.map +1 -1
  183. package/dist/esm/db-textarea.entry.js +1 -1
  184. package/dist/esm/db-tooltip.entry.js +1 -1
  185. package/dist/esm/db-ux.js +4 -4
  186. package/dist/esm/db-ux.js.map +1 -1
  187. package/dist/esm/{index-DOqgruSb.js → index-Bxi-mtJ7.js} +39 -17
  188. package/dist/esm/index-Bxi-mtJ7.js.map +1 -0
  189. package/dist/esm/index.js +1 -1
  190. package/dist/esm/index.js.map +1 -1
  191. package/dist/esm/loader.js +3 -3
  192. package/dist/types/components/tabs/model.d.ts +1 -0
  193. package/dist/types/components/tabs/tabs.d.ts +2 -0
  194. package/dist/types/stencil-public-runtime.d.ts +16 -2
  195. package/dist/web-types.json +3 -2
  196. package/package.json +7 -5
  197. package/dist/cjs/index-C9Rhca83.js.map +0 -1
  198. package/dist/db-ux/p-7a6af508.entry.js +0 -2
  199. package/dist/db-ux/p-7a6af508.entry.js.map +0 -1
  200. package/dist/db-ux/p-DOqgruSb.js +0 -3
  201. package/dist/db-ux/p-DOqgruSb.js.map +0 -1
  202. package/dist/db-ux/p-cfd1fc80.entry.js +0 -2
  203. package/dist/db-ux/p-dc14db0e.entry.js +0 -2
  204. package/dist/db-ux/p-f1d86976.entry.js +0 -2
  205. package/dist/esm/index-DOqgruSb.js.map +0 -1
  206. /package/dist/db-ux/{p-cfd1fc80.entry.js.map → p-07a7eb33.entry.js.map} +0 -0
  207. /package/dist/db-ux/{p-8aee262b.entry.js.map → p-109fc276.entry.js.map} +0 -0
  208. /package/dist/db-ux/{p-0f032718.entry.js.map → p-132ee89d.entry.js.map} +0 -0
  209. /package/dist/db-ux/{p-8d5578c8.entry.js.map → p-1a7001bb.entry.js.map} +0 -0
  210. /package/dist/db-ux/{p-9d814d7a.entry.js.map → p-1c50fd87.entry.js.map} +0 -0
  211. /package/dist/db-ux/{p-f2455023.entry.js.map → p-1f490d67.entry.js.map} +0 -0
  212. /package/dist/db-ux/{p-9b3c4d53.entry.js.map → p-26e115a8.entry.js.map} +0 -0
  213. /package/dist/db-ux/{p-7781b021.entry.js.map → p-2c457e48.entry.js.map} +0 -0
  214. /package/dist/db-ux/{p-dab91ef7.entry.js.map → p-31b7ea66.entry.js.map} +0 -0
  215. /package/dist/db-ux/{p-ba53d150.entry.js.map → p-3390e528.entry.js.map} +0 -0
  216. /package/dist/db-ux/{p-15203628.entry.js.map → p-364cc533.entry.js.map} +0 -0
  217. /package/dist/db-ux/{p-5a727411.entry.js.map → p-43be6218.entry.js.map} +0 -0
  218. /package/dist/db-ux/{p-5138e073.entry.js.map → p-53c419b0.entry.js.map} +0 -0
  219. /package/dist/db-ux/{p-6839aee1.entry.js.map → p-56488bc3.entry.js.map} +0 -0
  220. /package/dist/db-ux/{p-f1d86976.entry.js.map → p-69a7e5f9.entry.js.map} +0 -0
  221. /package/dist/db-ux/{p-daf5421b.entry.js.map → p-72bd1665.entry.js.map} +0 -0
  222. /package/dist/db-ux/{p-97d43713.entry.js.map → p-75d3a947.entry.js.map} +0 -0
  223. /package/dist/db-ux/{p-9d416e4d.entry.js.map → p-82083293.entry.js.map} +0 -0
  224. /package/dist/db-ux/{p-d93d61bf.entry.js.map → p-90f21d44.entry.js.map} +0 -0
  225. /package/dist/db-ux/{p-97249510.entry.js.map → p-950bf6ab.entry.js.map} +0 -0
  226. /package/dist/db-ux/{p-af4b9154.entry.js.map → p-963fde68.entry.js.map} +0 -0
  227. /package/dist/db-ux/{p-0cea77e9.entry.js.map → p-ad8ff0ae.entry.js.map} +0 -0
  228. /package/dist/db-ux/{p-c3673bb2.entry.js.map → p-b3ccfc6a.entry.js.map} +0 -0
  229. /package/dist/db-ux/{p-31d8532f.entry.js.map → p-c9b2b24e.entry.js.map} +0 -0
  230. /package/dist/db-ux/{p-e80a85c6.entry.js.map → p-cd51d733.entry.js.map} +0 -0
  231. /package/dist/db-ux/{p-97114cd9.entry.js.map → p-d0a2e1d4.entry.js.map} +0 -0
  232. /package/dist/db-ux/{p-cad3a6ca.entry.js.map → p-da7e3ac7.entry.js.map} +0 -0
  233. /package/dist/db-ux/{p-ec96cc5c.entry.js.map → p-fbf46ee6.entry.js.map} +0 -0
@@ -12,6 +12,7 @@ export class DBTabs {
12
12
  this.showScrollLeft = false;
13
13
  this.showScrollRight = false;
14
14
  this.scrollContainer = null;
15
+ this._resizeObserver = undefined;
15
16
  }
16
17
  convertTabs() {
17
18
  try {
@@ -56,6 +57,14 @@ export class DBTabs {
56
57
  container.addEventListener("scroll", () => {
57
58
  this.evaluateScrollButtons(container);
58
59
  });
60
+ // Use ResizeObserver to re-evaluate scroll buttons because it provides more accurate, container-specific resize detection than global window resize events.
61
+ if (!this._resizeObserver) {
62
+ const observer = new ResizeObserver(() => {
63
+ this.evaluateScrollButtons(container);
64
+ });
65
+ observer.observe(container);
66
+ this._resizeObserver = observer;
67
+ }
59
68
  }
60
69
  }
61
70
  }
@@ -188,19 +197,23 @@ export class DBTabs {
188
197
  this.initialized = true;
189
198
  this.watch0Fn();
190
199
  }
200
+ disconnectedCallback() {
201
+ var _a;
202
+ (_a = this._resizeObserver) === null || _a === void 0 ? void 0 : _a.disconnect();
203
+ this._resizeObserver = undefined;
204
+ }
191
205
  render() {
192
206
  var _a, _b, _c, _d;
193
- return (h("div", { key: 'dca04499038069635141cf10a14f96248d322f64', class: cls("db-tabs", this.className), ref: (el) => {
207
+ return (h("div", { key: '3cba7c0fba47a0cd323e5c772fc010c552a92740', class: cls("db-tabs", this.className), ref: (el) => {
194
208
  this._ref = el;
195
209
  }, id: this._id, "data-orientation": this.orientation, "data-scroll-behavior": this.behavior, "data-alignment": (_a = this.alignment) !== null && _a !== void 0 ? _a : "start", "data-width": (_b = this.width) !== null && _b !== void 0 ? _b : "auto", onInput: (event) => this.handleChange(event), onChange: (event) => this.handleChange(event) }, this.showScrollLeft ? (h("db-button", { class: "tabs-scroll-left", variant: "ghost", icon: "chevron_left", type: "button", noText: true, onClick: () => this.scroll(true) }, "Scroll left")) : null, this.tabs ? (h(Fragment, null, h("db-tab-list", null, (_c = this.convertTabs()) === null || _c === void 0 ? void 0 : _c.map((tab, index) => (h("db-tab-item", { key: this.name + "tab-item" + index, active: tab.active, label: tab.label, iconTrailing: tab.iconTrailing, icon: tab.icon, noText: tab.noText })))), (_d = this.convertTabs()) === null || _d === void 0 ? void 0 :
196
- _d.map((tab, index) => (h("db-tab-panel", { key: this.name + "tab-panel" + index, content: tab.content }, tab.children))))) : null, this.showScrollRight ? (h("db-button", { class: "tabs-scroll-right", variant: "ghost", icon: "chevron_right", type: "button", noText: true, onClick: () => this.scroll() }, "Scroll right")) : null, h("slot", { key: '1f12ff23fedea6e5dc3fb003b1e070e883b380d7' })));
210
+ _d.map((tab, index) => (h("db-tab-panel", { key: this.name + "tab-panel" + index, content: tab.content }, tab.children))))) : null, this.showScrollRight ? (h("db-button", { class: "tabs-scroll-right", variant: "ghost", icon: "chevron_right", type: "button", noText: true, onClick: () => this.scroll() }, "Scroll right")) : null, h("slot", { key: '34e23ae2f8dd9a30065895f99929a95c41ace4f8' })));
197
211
  }
198
212
  static get is() { return "db-tabs"; }
199
213
  static get properties() {
200
214
  return {
201
215
  "id": {
202
216
  "type": "string",
203
- "attribute": "id",
204
217
  "mutable": false,
205
218
  "complexType": {
206
219
  "original": "DBTabsProps[\"id\"]",
@@ -221,11 +234,11 @@ export class DBTabs {
221
234
  },
222
235
  "getter": false,
223
236
  "setter": false,
224
- "reflect": false
237
+ "reflect": false,
238
+ "attribute": "id"
225
239
  },
226
240
  "name": {
227
241
  "type": "string",
228
- "attribute": "name",
229
242
  "mutable": false,
230
243
  "complexType": {
231
244
  "original": "DBTabsProps[\"name\"]",
@@ -246,11 +259,11 @@ export class DBTabs {
246
259
  },
247
260
  "getter": false,
248
261
  "setter": false,
249
- "reflect": false
262
+ "reflect": false,
263
+ "attribute": "name"
250
264
  },
251
265
  "tabs": {
252
266
  "type": "string",
253
- "attribute": "tabs",
254
267
  "mutable": false,
255
268
  "complexType": {
256
269
  "original": "DBTabsProps[\"tabs\"]",
@@ -271,11 +284,11 @@ export class DBTabs {
271
284
  },
272
285
  "getter": false,
273
286
  "setter": false,
274
- "reflect": false
287
+ "reflect": false,
288
+ "attribute": "tabs"
275
289
  },
276
290
  "arrowScrollDistance": {
277
291
  "type": "any",
278
- "attribute": "arrow-scroll-distance",
279
292
  "mutable": false,
280
293
  "complexType": {
281
294
  "original": "DBTabsProps[\"arrowScrollDistance\"]",
@@ -296,11 +309,11 @@ export class DBTabs {
296
309
  },
297
310
  "getter": false,
298
311
  "setter": false,
299
- "reflect": false
312
+ "reflect": false,
313
+ "attribute": "arrow-scroll-distance"
300
314
  },
301
315
  "orientation": {
302
316
  "type": "string",
303
- "attribute": "orientation",
304
317
  "mutable": false,
305
318
  "complexType": {
306
319
  "original": "DBTabsProps[\"orientation\"]",
@@ -321,11 +334,11 @@ export class DBTabs {
321
334
  },
322
335
  "getter": false,
323
336
  "setter": false,
324
- "reflect": false
337
+ "reflect": false,
338
+ "attribute": "orientation"
325
339
  },
326
340
  "behavior": {
327
341
  "type": "string",
328
- "attribute": "behavior",
329
342
  "mutable": false,
330
343
  "complexType": {
331
344
  "original": "DBTabsProps[\"behavior\"]",
@@ -346,11 +359,11 @@ export class DBTabs {
346
359
  },
347
360
  "getter": false,
348
361
  "setter": false,
349
- "reflect": false
362
+ "reflect": false,
363
+ "attribute": "behavior"
350
364
  },
351
365
  "initialSelectedMode": {
352
366
  "type": "string",
353
- "attribute": "initial-selected-mode",
354
367
  "mutable": false,
355
368
  "complexType": {
356
369
  "original": "DBTabsProps[\"initialSelectedMode\"]",
@@ -371,11 +384,11 @@ export class DBTabs {
371
384
  },
372
385
  "getter": false,
373
386
  "setter": false,
374
- "reflect": false
387
+ "reflect": false,
388
+ "attribute": "initial-selected-mode"
375
389
  },
376
390
  "initialSelectedIndex": {
377
391
  "type": "any",
378
- "attribute": "initial-selected-index",
379
392
  "mutable": false,
380
393
  "complexType": {
381
394
  "original": "DBTabsProps[\"initialSelectedIndex\"]",
@@ -396,11 +409,11 @@ export class DBTabs {
396
409
  },
397
410
  "getter": false,
398
411
  "setter": false,
399
- "reflect": false
412
+ "reflect": false,
413
+ "attribute": "initial-selected-index"
400
414
  },
401
415
  "className": {
402
416
  "type": "string",
403
- "attribute": "classname",
404
417
  "mutable": false,
405
418
  "complexType": {
406
419
  "original": "DBTabsProps[\"className\"]",
@@ -421,11 +434,11 @@ export class DBTabs {
421
434
  },
422
435
  "getter": false,
423
436
  "setter": false,
424
- "reflect": false
437
+ "reflect": false,
438
+ "attribute": "classname"
425
439
  },
426
440
  "alignment": {
427
441
  "type": "string",
428
- "attribute": "alignment",
429
442
  "mutable": false,
430
443
  "complexType": {
431
444
  "original": "DBTabsProps[\"alignment\"]",
@@ -446,11 +459,11 @@ export class DBTabs {
446
459
  },
447
460
  "getter": false,
448
461
  "setter": false,
449
- "reflect": false
462
+ "reflect": false,
463
+ "attribute": "alignment"
450
464
  },
451
465
  "width": {
452
466
  "type": "string",
453
- "attribute": "width",
454
467
  "mutable": false,
455
468
  "complexType": {
456
469
  "original": "DBTabsProps[\"width\"]",
@@ -471,7 +484,8 @@ export class DBTabs {
471
484
  },
472
485
  "getter": false,
473
486
  "setter": false,
474
- "reflect": false
487
+ "reflect": false,
488
+ "attribute": "width"
475
489
  }
476
490
  };
477
491
  }
@@ -482,7 +496,8 @@ export class DBTabs {
482
496
  "initialized": {},
483
497
  "showScrollLeft": {},
484
498
  "showScrollRight": {},
485
- "scrollContainer": {}
499
+ "scrollContainer": {},
500
+ "_resizeObserver": {}
486
501
  };
487
502
  }
488
503
  static get events() {
@@ -1 +1 @@
1
- {"version":3,"file":"tabs.js","sourceRoot":"","sources":["../../../src/components/tabs/tabs.tsx"],"names":[],"mappings":"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","sourcesContent":["import { InputEvent } from \"../../shared/model\";\nimport { cls, uuid } from \"../../utils\";\nimport { DBButton } from \"../button/button\";\nimport { DBTabItem } from \"../tab-item/tab-item\";\nimport { DBTabList } from \"../tab-list/tab-list\";\nimport { DBTabPanel } from \"../tab-panel/tab-panel\";\nimport { DBSimpleTabProps, DBTabsProps, DBTabsState } from \"./model\";\n\nimport {\n Component,\n h,\n Fragment,\n Watch,\n Event,\n EventEmitter,\n Prop,\n State,\n} from \"@stencil/core\";\n\n\n/**\n * @slot children - This is a default/unnamed slot\n\n */\n @Component({\n tag: \"db-tabs\",\n})\nexport class DBTabs {\n private _ref!: HTMLDivElement | any;\n @Prop() id: DBTabsProps[\"id\"];\n @Prop() name: DBTabsProps[\"name\"];\n @Prop() tabs: DBTabsProps[\"tabs\"];\n @Prop() arrowScrollDistance: DBTabsProps[\"arrowScrollDistance\"];\n @Prop() orientation: DBTabsProps[\"orientation\"];\n @Prop() behavior: DBTabsProps[\"behavior\"];\n @Prop() initialSelectedMode: DBTabsProps[\"initialSelectedMode\"];\n @Prop() initialSelectedIndex: DBTabsProps[\"initialSelectedIndex\"];\n @Event() indexChange: EventEmitter<\n Parameters<Required<DBTabsProps>[\"onIndexChange\"]>[number]\n > | void;\n @Event() tabSelect: EventEmitter<\n Parameters<Required<DBTabsProps>[\"onTabSelect\"]>[number]\n > | void;\n @Prop({attribute: \"classname\"}) className: DBTabsProps[\"className\"];\n @Prop() alignment: DBTabsProps[\"alignment\"];\n @Prop() width: DBTabsProps[\"width\"];\n @State() _id = \"tabs-\" + uuid();\n @State() _name = \"\";\n @State() initialized = false;\n @State() showScrollLeft = false;\n @State() showScrollRight = false;\n @State() scrollContainer = null;\n\n convertTabs() {\n try {\n if (typeof this.tabs === \"string\") {\n return JSON.parse(this.tabs as string);\n }\n return this.tabs as DBSimpleTabProps[];\n } catch (error) {\n console.error(error);\n }\n return [];\n }\n evaluateScrollButtons(tList: Element) {\n const needsScroll = tList.scrollWidth > tList.clientWidth;\n this.showScrollLeft = needsScroll && tList.scrollLeft > 1;\n this.showScrollRight =\n needsScroll && tList.scrollLeft < tList.scrollWidth - tList.clientWidth;\n }\n scroll(left?: boolean) {\n let step = Number(this.arrowScrollDistance) || 100;\n if (left) {\n step *= -1;\n }\n this.scrollContainer?.scrollBy({\n top: 0,\n left: step,\n behavior: \"smooth\",\n });\n }\n initTabList() {\n if (this._ref) {\n const tabList = this._ref.querySelector(\".db-tab-list\");\n if (tabList) {\n const container: HTMLElement | null =\n tabList.querySelector('[role=\"tablist\"]');\n if (container) {\n container.setAttribute(\n \"aria-orientation\",\n this.orientation || \"horizontal\"\n );\n if (this.behavior === \"arrows\") {\n this.scrollContainer = container;\n this.evaluateScrollButtons(container);\n container.addEventListener(\"scroll\", () => {\n this.evaluateScrollButtons(container);\n });\n }\n }\n }\n }\n }\n initTabs(init?: boolean) {\n if (this._ref) {\n const tabItems = Array.from<Element>(\n this._ref.getElementsByClassName(\"db-tab-item\")\n );\n const tabPanels = Array.from<Element>(\n this._ref.querySelectorAll(\n \":is(:scope > .db-tab-panel, :scope > db-tab-panel > .db-tab-panel)\"\n )\n );\n for (const tabItem of tabItems) {\n const index: number = tabItems.indexOf(tabItem);\n const label = tabItem.querySelector(\"label\");\n const input = tabItem.querySelector(\"input\");\n if (input && label) {\n if (!input.id) {\n const tabId = `${this._name}-tab-${index}`;\n label.setAttribute(\"for\", tabId);\n input.id = tabId;\n input.setAttribute(\"name\", this._name);\n if (tabPanels.length > index) {\n input.setAttribute(\n \"aria-controls\",\n `${this._name}-tab-panel-${index}`\n );\n }\n }\n if (init) {\n // Auto select\n const autoSelect =\n !this.initialSelectedMode || this.initialSelectedMode === \"auto\";\n const shouldAutoSelect =\n (this.initialSelectedIndex == null && index === 0) ||\n Number(this.initialSelectedIndex) === index;\n if (autoSelect && shouldAutoSelect) {\n input.click();\n }\n }\n }\n }\n for (const panel of tabPanels) {\n if (panel.id) continue;\n const index: number = tabPanels.indexOf(panel);\n panel.id = `${this._name}-tab-panel-${index}`;\n panel.setAttribute(\"aria-labelledby\", `${this._name}-tab-${index}`);\n }\n }\n }\n handleChange(event: InputEvent<HTMLElement>) {\n event.stopPropagation();\n if (event.target) {\n const target = event.target as HTMLElement;\n const parent = target.parentElement;\n if (\n parent &&\n parent.parentElement &&\n parent.parentElement?.nodeName === \"LI\"\n ) {\n const tabItem = parent.parentElement.parentElement;\n if (tabItem) {\n const list = tabItem.parentElement;\n if (list) {\n const indices = Array.from(list.childNodes).indexOf(tabItem);\n if (this.indexChange) {\n this.indexChange.emit(indices);\n }\n if (this.tabSelect) {\n this.tabSelect.emit(event);\n }\n }\n }\n }\n }\n }\n\n /**\n * Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.\n * @param element the ref for the component\n * @param customElementSelector the custom element like `my-component`\n */\n private enableAttributePassing(\n element: HTMLElement | null,\n customElementSelector: string\n ) {\n const parent = element?.closest(customElementSelector);\n if (element && parent) {\n const attributes = parent.attributes;\n for (let i = 0; i < attributes.length; i++) {\n const attr = attributes.item(i);\n if (\n attr &&\n (attr.name.startsWith(\"data-\") || attr.name.startsWith(\"aria-\"))\n ) {\n element.setAttribute(attr.name, attr.value);\n parent.removeAttribute(attr.name);\n }\n if (attr && attr.name === \"class\") {\n const isWebComponent = attr.value.includes(\"hydrated\");\n const value = attr.value.replace(\"hydrated\", \"\").trim();\n const currentClass = element.getAttribute(\"class\");\n element.setAttribute(\n attr.name,\n `${currentClass ? `${currentClass} ` : \"\"}${value}`\n );\n if (isWebComponent) {\n // Stencil is using this class for lazy loading component\n parent.setAttribute(\"class\", \"hydrated\");\n } else {\n parent.removeAttribute(attr.name);\n }\n }\n }\n }\n }\n\n watch0Fn() {\n if (this._ref && this.initialized) {\n this.initTabList();\n this.initTabs(true);\n const tabList = this._ref.querySelector(\".db-tab-list\");\n if (tabList) {\n const observer = new MutationObserver((mutations) => {\n mutations.forEach((mutation) => {\n if (mutation.removedNodes.length || mutation.addedNodes.length) {\n this.initTabList();\n this.initTabs();\n }\n });\n });\n observer.observe(tabList, {\n childList: true,\n subtree: true,\n });\n }\n this.initialized = false;\n }\n }\n\n @Watch(\"_ref\")\n @Watch(\"initialized\")\n watch0() {\n this.watch0Fn();\n }\n\n componentDidLoad() {\n this.enableAttributePassing(this._ref, \"db-tabs\");\n this._id = this.id || this._id;\n this._name = `tabs-${this.name || uuid()}`;\n this.initialized = true;\n this.watch0Fn();\n }\n\n render() {\n return (\n <div\n class={cls(\"db-tabs\", this.className)}\n ref={(el: any) => {\n this._ref = el;\n }}\n id={this._id}\n data-orientation={this.orientation}\n data-scroll-behavior={this.behavior}\n data-alignment={this.alignment ?? \"start\"}\n data-width={this.width ?? \"auto\"}\n onInput={(event) => this.handleChange(event)}\n onChange={(event) => this.handleChange(event)}\n >\n {this.showScrollLeft ? (\n <db-button\n class=\"tabs-scroll-left\"\n variant=\"ghost\"\n icon=\"chevron_left\"\n type=\"button\"\n noText={true}\n onClick={() => this.scroll(true)}\n >\n Scroll left\n </db-button>\n ) : null}\n {this.tabs ? (\n <Fragment>\n <db-tab-list>\n {this.convertTabs()?.map((tab, index) => (\n <db-tab-item\n key={this.name + \"tab-item\" + index}\n active={tab.active}\n label={tab.label}\n iconTrailing={tab.iconTrailing}\n icon={tab.icon}\n noText={tab.noText}\n ></db-tab-item>\n ))}\n </db-tab-list>\n {this.convertTabs()?.map((tab, index) => (\n <db-tab-panel\n key={this.name + \"tab-panel\" + index}\n content={tab.content}\n >\n {tab.children}\n </db-tab-panel>\n ))}\n </Fragment>\n ) : null}\n {this.showScrollRight ? (\n <db-button\n class=\"tabs-scroll-right\"\n variant=\"ghost\"\n icon=\"chevron_right\"\n type=\"button\"\n noText={true}\n onClick={() => this.scroll()}\n >\n Scroll right\n </db-button>\n ) : null}\n <slot></slot>\n </div>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"tabs.js","sourceRoot":"","sources":["../../../src/components/tabs/tabs.tsx"],"names":[],"mappings":"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","sourcesContent":["import { InputEvent } from \"../../shared/model\";\nimport { cls, uuid } from \"../../utils\";\nimport { DBButton } from \"../button/button\";\nimport { DBTabItem } from \"../tab-item/tab-item\";\nimport { DBTabList } from \"../tab-list/tab-list\";\nimport { DBTabPanel } from \"../tab-panel/tab-panel\";\nimport { DBSimpleTabProps, DBTabsProps, DBTabsState } from \"./model\";\n\nimport {\n Component,\n h,\n Fragment,\n Watch,\n Event,\n EventEmitter,\n Prop,\n State,\n} from \"@stencil/core\";\n\n\n/**\n * @slot children - This is a default/unnamed slot\n\n */\n @Component({\n tag: \"db-tabs\",\n})\nexport class DBTabs {\n private _ref!: HTMLDivElement | any;\n @Prop() id: DBTabsProps[\"id\"];\n @Prop() name: DBTabsProps[\"name\"];\n @Prop() tabs: DBTabsProps[\"tabs\"];\n @Prop() arrowScrollDistance: DBTabsProps[\"arrowScrollDistance\"];\n @Prop() orientation: DBTabsProps[\"orientation\"];\n @Prop() behavior: DBTabsProps[\"behavior\"];\n @Prop() initialSelectedMode: DBTabsProps[\"initialSelectedMode\"];\n @Prop() initialSelectedIndex: DBTabsProps[\"initialSelectedIndex\"];\n @Event() indexChange: EventEmitter<\n Parameters<Required<DBTabsProps>[\"onIndexChange\"]>[number]\n > | void;\n @Event() tabSelect: EventEmitter<\n Parameters<Required<DBTabsProps>[\"onTabSelect\"]>[number]\n > | void;\n @Prop({attribute: \"classname\"}) className: DBTabsProps[\"className\"];\n @Prop() alignment: DBTabsProps[\"alignment\"];\n @Prop() width: DBTabsProps[\"width\"];\n @State() _id = \"tabs-\" + uuid();\n @State() _name = \"\";\n @State() initialized = false;\n @State() showScrollLeft = false;\n @State() showScrollRight = false;\n @State() scrollContainer = null;\n @State() _resizeObserver = undefined;\n\n convertTabs() {\n try {\n if (typeof this.tabs === \"string\") {\n return JSON.parse(this.tabs as string);\n }\n return this.tabs as DBSimpleTabProps[];\n } catch (error) {\n console.error(error);\n }\n return [];\n }\n evaluateScrollButtons(tList: Element) {\n const needsScroll = tList.scrollWidth > tList.clientWidth;\n this.showScrollLeft = needsScroll && tList.scrollLeft > 1;\n this.showScrollRight =\n needsScroll && tList.scrollLeft < tList.scrollWidth - tList.clientWidth;\n }\n scroll(left?: boolean) {\n let step = Number(this.arrowScrollDistance) || 100;\n if (left) {\n step *= -1;\n }\n this.scrollContainer?.scrollBy({\n top: 0,\n left: step,\n behavior: \"smooth\",\n });\n }\n initTabList() {\n if (this._ref) {\n const tabList = this._ref.querySelector(\".db-tab-list\");\n if (tabList) {\n const container: HTMLElement | null =\n tabList.querySelector('[role=\"tablist\"]');\n if (container) {\n container.setAttribute(\n \"aria-orientation\",\n this.orientation || \"horizontal\"\n );\n if (this.behavior === \"arrows\") {\n this.scrollContainer = container;\n this.evaluateScrollButtons(container);\n container.addEventListener(\"scroll\", () => {\n this.evaluateScrollButtons(container);\n });\n // Use ResizeObserver to re-evaluate scroll buttons because it provides more accurate, container-specific resize detection than global window resize events.\n if (!this._resizeObserver) {\n const observer = new ResizeObserver(() => {\n this.evaluateScrollButtons(container);\n });\n observer.observe(container);\n this._resizeObserver = observer;\n }\n }\n }\n }\n }\n }\n initTabs(init?: boolean) {\n if (this._ref) {\n const tabItems = Array.from<Element>(\n this._ref.getElementsByClassName(\"db-tab-item\")\n );\n const tabPanels = Array.from<Element>(\n this._ref.querySelectorAll(\n \":is(:scope > .db-tab-panel, :scope > db-tab-panel > .db-tab-panel)\"\n )\n );\n for (const tabItem of tabItems) {\n const index: number = tabItems.indexOf(tabItem);\n const label = tabItem.querySelector(\"label\");\n const input = tabItem.querySelector(\"input\");\n if (input && label) {\n if (!input.id) {\n const tabId = `${this._name}-tab-${index}`;\n label.setAttribute(\"for\", tabId);\n input.id = tabId;\n input.setAttribute(\"name\", this._name);\n if (tabPanels.length > index) {\n input.setAttribute(\n \"aria-controls\",\n `${this._name}-tab-panel-${index}`\n );\n }\n }\n if (init) {\n // Auto select\n const autoSelect =\n !this.initialSelectedMode || this.initialSelectedMode === \"auto\";\n const shouldAutoSelect =\n (this.initialSelectedIndex == null && index === 0) ||\n Number(this.initialSelectedIndex) === index;\n if (autoSelect && shouldAutoSelect) {\n input.click();\n }\n }\n }\n }\n for (const panel of tabPanels) {\n if (panel.id) continue;\n const index: number = tabPanels.indexOf(panel);\n panel.id = `${this._name}-tab-panel-${index}`;\n panel.setAttribute(\"aria-labelledby\", `${this._name}-tab-${index}`);\n }\n }\n }\n handleChange(event: InputEvent<HTMLElement>) {\n event.stopPropagation();\n if (event.target) {\n const target = event.target as HTMLElement;\n const parent = target.parentElement;\n if (\n parent &&\n parent.parentElement &&\n parent.parentElement?.nodeName === \"LI\"\n ) {\n const tabItem = parent.parentElement.parentElement;\n if (tabItem) {\n const list = tabItem.parentElement;\n if (list) {\n const indices = Array.from(list.childNodes).indexOf(tabItem);\n if (this.indexChange) {\n this.indexChange.emit(indices);\n }\n if (this.tabSelect) {\n this.tabSelect.emit(event);\n }\n }\n }\n }\n }\n }\n\n /**\n * Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.\n * @param element the ref for the component\n * @param customElementSelector the custom element like `my-component`\n */\n private enableAttributePassing(\n element: HTMLElement | null,\n customElementSelector: string\n ) {\n const parent = element?.closest(customElementSelector);\n if (element && parent) {\n const attributes = parent.attributes;\n for (let i = 0; i < attributes.length; i++) {\n const attr = attributes.item(i);\n if (\n attr &&\n (attr.name.startsWith(\"data-\") || attr.name.startsWith(\"aria-\"))\n ) {\n element.setAttribute(attr.name, attr.value);\n parent.removeAttribute(attr.name);\n }\n if (attr && attr.name === \"class\") {\n const isWebComponent = attr.value.includes(\"hydrated\");\n const value = attr.value.replace(\"hydrated\", \"\").trim();\n const currentClass = element.getAttribute(\"class\");\n element.setAttribute(\n attr.name,\n `${currentClass ? `${currentClass} ` : \"\"}${value}`\n );\n if (isWebComponent) {\n // Stencil is using this class for lazy loading component\n parent.setAttribute(\"class\", \"hydrated\");\n } else {\n parent.removeAttribute(attr.name);\n }\n }\n }\n }\n }\n\n watch0Fn() {\n if (this._ref && this.initialized) {\n this.initTabList();\n this.initTabs(true);\n const tabList = this._ref.querySelector(\".db-tab-list\");\n if (tabList) {\n const observer = new MutationObserver((mutations) => {\n mutations.forEach((mutation) => {\n if (mutation.removedNodes.length || mutation.addedNodes.length) {\n this.initTabList();\n this.initTabs();\n }\n });\n });\n observer.observe(tabList, {\n childList: true,\n subtree: true,\n });\n }\n this.initialized = false;\n }\n }\n\n @Watch(\"_ref\")\n @Watch(\"initialized\")\n watch0() {\n this.watch0Fn();\n }\n\n componentDidLoad() {\n this.enableAttributePassing(this._ref, \"db-tabs\");\n this._id = this.id || this._id;\n this._name = `tabs-${this.name || uuid()}`;\n this.initialized = true;\n this.watch0Fn();\n }\n disconnectedCallback() {\n this._resizeObserver?.disconnect();\n this._resizeObserver = undefined;\n }\n\n render() {\n return (\n <div\n class={cls(\"db-tabs\", this.className)}\n ref={(el: any) => {\n this._ref = el;\n }}\n id={this._id}\n data-orientation={this.orientation}\n data-scroll-behavior={this.behavior}\n data-alignment={this.alignment ?? \"start\"}\n data-width={this.width ?? \"auto\"}\n onInput={(event) => this.handleChange(event)}\n onChange={(event) => this.handleChange(event)}\n >\n {this.showScrollLeft ? (\n <db-button\n class=\"tabs-scroll-left\"\n variant=\"ghost\"\n icon=\"chevron_left\"\n type=\"button\"\n noText={true}\n onClick={() => this.scroll(true)}\n >\n Scroll left\n </db-button>\n ) : null}\n {this.tabs ? (\n <Fragment>\n <db-tab-list>\n {this.convertTabs()?.map((tab, index) => (\n <db-tab-item\n key={this.name + \"tab-item\" + index}\n active={tab.active}\n label={tab.label}\n iconTrailing={tab.iconTrailing}\n icon={tab.icon}\n noText={tab.noText}\n ></db-tab-item>\n ))}\n </db-tab-list>\n {this.convertTabs()?.map((tab, index) => (\n <db-tab-panel\n key={this.name + \"tab-panel\" + index}\n content={tab.content}\n >\n {tab.children}\n </db-tab-panel>\n ))}\n </Fragment>\n ) : null}\n {this.showScrollRight ? (\n <db-button\n class=\"tabs-scroll-right\"\n variant=\"ghost\"\n icon=\"chevron_right\"\n type=\"button\"\n noText={true}\n onClick={() => this.scroll()}\n >\n Scroll right\n </db-button>\n ) : null}\n <slot></slot>\n </div>\n );\n }\n}\n"]}
@@ -67,7 +67,6 @@ export class DBTag {
67
67
  return {
68
68
  "removeButton": {
69
69
  "type": "string",
70
- "attribute": "remove-button",
71
70
  "mutable": false,
72
71
  "complexType": {
73
72
  "original": "DBTagProps[\"removeButton\"]",
@@ -88,11 +87,11 @@ export class DBTag {
88
87
  },
89
88
  "getter": false,
90
89
  "setter": false,
91
- "reflect": false
90
+ "reflect": false,
91
+ "attribute": "remove-button"
92
92
  },
93
93
  "id": {
94
94
  "type": "string",
95
- "attribute": "id",
96
95
  "mutable": false,
97
96
  "complexType": {
98
97
  "original": "DBTagProps[\"id\"]",
@@ -113,11 +112,11 @@ export class DBTag {
113
112
  },
114
113
  "getter": false,
115
114
  "setter": false,
116
- "reflect": false
115
+ "reflect": false,
116
+ "attribute": "id"
117
117
  },
118
118
  "className": {
119
119
  "type": "string",
120
- "attribute": "classname",
121
120
  "mutable": false,
122
121
  "complexType": {
123
122
  "original": "DBTagProps[\"className\"]",
@@ -138,11 +137,11 @@ export class DBTag {
138
137
  },
139
138
  "getter": false,
140
139
  "setter": false,
141
- "reflect": false
140
+ "reflect": false,
141
+ "attribute": "classname"
142
142
  },
143
143
  "semantic": {
144
144
  "type": "string",
145
- "attribute": "semantic",
146
145
  "mutable": false,
147
146
  "complexType": {
148
147
  "original": "DBTagProps[\"semantic\"]",
@@ -163,11 +162,11 @@ export class DBTag {
163
162
  },
164
163
  "getter": false,
165
164
  "setter": false,
166
- "reflect": false
165
+ "reflect": false,
166
+ "attribute": "semantic"
167
167
  },
168
168
  "emphasis": {
169
169
  "type": "string",
170
- "attribute": "emphasis",
171
170
  "mutable": false,
172
171
  "complexType": {
173
172
  "original": "DBTagProps[\"emphasis\"]",
@@ -188,11 +187,11 @@ export class DBTag {
188
187
  },
189
188
  "getter": false,
190
189
  "setter": false,
191
- "reflect": false
190
+ "reflect": false,
191
+ "attribute": "emphasis"
192
192
  },
193
193
  "icon": {
194
194
  "type": "string",
195
- "attribute": "icon",
196
195
  "mutable": false,
197
196
  "complexType": {
198
197
  "original": "DBTagProps[\"icon\"]",
@@ -213,11 +212,11 @@ export class DBTag {
213
212
  },
214
213
  "getter": false,
215
214
  "setter": false,
216
- "reflect": false
215
+ "reflect": false,
216
+ "attribute": "icon"
217
217
  },
218
218
  "showCheckState": {
219
219
  "type": "any",
220
- "attribute": "show-check-state",
221
220
  "mutable": false,
222
221
  "complexType": {
223
222
  "original": "DBTagProps[\"showCheckState\"]",
@@ -238,11 +237,11 @@ export class DBTag {
238
237
  },
239
238
  "getter": false,
240
239
  "setter": false,
241
- "reflect": false
240
+ "reflect": false,
241
+ "attribute": "show-check-state"
242
242
  },
243
243
  "showIcon": {
244
244
  "type": "any",
245
- "attribute": "show-icon",
246
245
  "mutable": false,
247
246
  "complexType": {
248
247
  "original": "DBTagProps[\"showIcon\"]",
@@ -263,11 +262,11 @@ export class DBTag {
263
262
  },
264
263
  "getter": false,
265
264
  "setter": false,
266
- "reflect": false
265
+ "reflect": false,
266
+ "attribute": "show-icon"
267
267
  },
268
268
  "noText": {
269
269
  "type": "any",
270
- "attribute": "no-text",
271
270
  "mutable": false,
272
271
  "complexType": {
273
272
  "original": "DBTagProps[\"noText\"]",
@@ -288,11 +287,11 @@ export class DBTag {
288
287
  },
289
288
  "getter": false,
290
289
  "setter": false,
291
- "reflect": false
290
+ "reflect": false,
291
+ "attribute": "no-text"
292
292
  },
293
293
  "overflow": {
294
294
  "type": "any",
295
- "attribute": "overflow",
296
295
  "mutable": false,
297
296
  "complexType": {
298
297
  "original": "DBTagProps[\"overflow\"]",
@@ -313,11 +312,11 @@ export class DBTag {
313
312
  },
314
313
  "getter": false,
315
314
  "setter": false,
316
- "reflect": false
315
+ "reflect": false,
316
+ "attribute": "overflow"
317
317
  },
318
318
  "text": {
319
319
  "type": "string",
320
- "attribute": "text",
321
320
  "mutable": false,
322
321
  "complexType": {
323
322
  "original": "DBTagProps[\"text\"]",
@@ -338,11 +337,11 @@ export class DBTag {
338
337
  },
339
338
  "getter": false,
340
339
  "setter": false,
341
- "reflect": false
340
+ "reflect": false,
341
+ "attribute": "text"
342
342
  },
343
343
  "behavior": {
344
344
  "type": "string",
345
- "attribute": "behavior",
346
345
  "mutable": false,
347
346
  "complexType": {
348
347
  "original": "DBTagProps[\"behavior\"]",
@@ -363,7 +362,8 @@ export class DBTag {
363
362
  },
364
363
  "getter": false,
365
364
  "setter": false,
366
- "reflect": false
365
+ "reflect": false,
366
+ "attribute": "behavior"
367
367
  }
368
368
  };
369
369
  }