@nvidia-elements/core 0.0.3 → 0.0.4

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 (185) hide show
  1. package/CHANGELOG.md +20 -17
  2. package/NOTICE.md +119 -0
  3. package/dist/accordion/accordion2.js +4 -4
  4. package/dist/alert/alert-banner2.js +1 -1
  5. package/dist/alert/alert-group2.js +1 -1
  6. package/dist/alert/alert.examples.js.map +1 -1
  7. package/dist/alert/alert.examples.json +1 -1
  8. package/dist/alert/alert2.js +1 -1
  9. package/dist/avatar/avatar-group2.js +1 -1
  10. package/dist/avatar/avatar2.js +1 -1
  11. package/dist/badge/badge2.js +1 -1
  12. package/dist/breadcrumb/breadcrumb2.js +1 -1
  13. package/dist/bundle.d.ts +2 -0
  14. package/dist/bundles/index.d.ts +176 -1
  15. package/dist/bundles/index.js +3 -3
  16. package/dist/button/button.examples.js.map +1 -1
  17. package/dist/button/button.examples.json +3 -3
  18. package/dist/button/button2.js +1 -1
  19. package/dist/button-group/button-group2.js +1 -1
  20. package/dist/card/card2.js +4 -4
  21. package/dist/chat-message/chat-message2.js +1 -1
  22. package/dist/checkbox/checkbox-group2.js +1 -1
  23. package/dist/checkbox/checkbox2.js +1 -1
  24. package/dist/color/color2.js +1 -1
  25. package/dist/combobox/combobox.d.ts +4 -0
  26. package/dist/combobox/combobox.examples.js.map +1 -1
  27. package/dist/combobox/combobox.examples.json +12 -1
  28. package/dist/combobox/combobox.js +1 -1
  29. package/dist/combobox/combobox.js.map +1 -1
  30. package/dist/combobox/combobox2.js +90 -62
  31. package/dist/combobox/combobox2.js.map +1 -1
  32. package/dist/copy-button/copy-button2.js +1 -1
  33. package/dist/custom-elements-jsx.d.ts +117 -2
  34. package/dist/custom-elements-vue.d.ts +117 -2
  35. package/dist/custom-elements.json +1543 -51
  36. package/dist/data.html.json +202 -6
  37. package/dist/data.snippets.json +9 -0
  38. package/dist/date/date2.js +1 -1
  39. package/dist/datetime/datetime2.js +1 -1
  40. package/dist/dialog/dialog-footer2.js +1 -1
  41. package/dist/dialog/dialog-header2.js +1 -1
  42. package/dist/dialog/dialog2.js +1 -1
  43. package/dist/divider/divider2.js +1 -1
  44. package/dist/dot/dot2.js +1 -1
  45. package/dist/drawer/drawer-content2.js +1 -1
  46. package/dist/drawer/drawer-footer2.js +1 -1
  47. package/dist/drawer/drawer-header2.js +1 -1
  48. package/dist/drawer/drawer2.js +1 -1
  49. package/dist/dropdown/dropdown-footer2.js +1 -1
  50. package/dist/dropdown/dropdown-header2.js +1 -1
  51. package/dist/dropdown/dropdown2.js +1 -1
  52. package/dist/dropdown-group/dropdown-group.js +1 -1
  53. package/dist/dropzone/dropzone.examples.js.map +1 -1
  54. package/dist/dropzone/dropzone.examples.json +3 -1
  55. package/dist/dropzone/dropzone2.js +1 -1
  56. package/dist/file/file2.js +1 -1
  57. package/dist/format-datetime/define.d.ts +6 -0
  58. package/dist/format-datetime/define.js +7 -0
  59. package/dist/format-datetime/define.js.map +1 -0
  60. package/dist/format-datetime/format-datetime.d.ts +74 -0
  61. package/dist/format-datetime/format-datetime.examples.js +6 -0
  62. package/dist/format-datetime/format-datetime.examples.js.map +1 -0
  63. package/dist/format-datetime/format-datetime.examples.json +87 -0
  64. package/dist/format-datetime/format-datetime.js +6 -0
  65. package/dist/format-datetime/format-datetime.js.map +1 -0
  66. package/dist/format-datetime/format-datetime2.js +77 -0
  67. package/dist/format-datetime/format-datetime2.js.map +1 -0
  68. package/dist/format-datetime/index.d.ts +1 -0
  69. package/dist/format-datetime/index.js +2 -0
  70. package/dist/format-relative-time/define.d.ts +6 -0
  71. package/dist/format-relative-time/define.js +7 -0
  72. package/dist/format-relative-time/define.js.map +1 -0
  73. package/dist/format-relative-time/format-relative-time.d.ts +47 -0
  74. package/dist/format-relative-time/format-relative-time.examples.js +6 -0
  75. package/dist/format-relative-time/format-relative-time.examples.js.map +1 -0
  76. package/dist/format-relative-time/format-relative-time.examples.json +69 -0
  77. package/dist/format-relative-time/format-relative-time.js +6 -0
  78. package/dist/format-relative-time/format-relative-time.js.map +1 -0
  79. package/dist/format-relative-time/format-relative-time2.js +118 -0
  80. package/dist/format-relative-time/format-relative-time2.js.map +1 -0
  81. package/dist/format-relative-time/index.d.ts +1 -0
  82. package/dist/format-relative-time/index.js +2 -0
  83. package/dist/forms/control/control2.js +1 -1
  84. package/dist/forms/control-group/control-group2.js +1 -1
  85. package/dist/forms/control-message/control-message2.js +1 -1
  86. package/dist/forms/forms.examples.js.map +1 -1
  87. package/dist/forms/forms.examples.json +4 -2
  88. package/dist/grid/cell/cell2.js +1 -1
  89. package/dist/grid/column/column2.js +1 -1
  90. package/dist/grid/footer/footer2.js +1 -1
  91. package/dist/grid/grid.examples.js.map +1 -1
  92. package/dist/grid/grid.examples.json +1 -1
  93. package/dist/grid/grid2.js +1 -1
  94. package/dist/grid/header/header2.js +1 -1
  95. package/dist/grid/placeholder/placeholder2.js +1 -1
  96. package/dist/grid/row/row2.js +1 -1
  97. package/dist/icon/icon2.js +2 -2
  98. package/dist/icon-button/icon-button2.js +1 -1
  99. package/dist/index.js +1 -1
  100. package/dist/input/input-group2.js +1 -1
  101. package/dist/input/input2.js +1 -1
  102. package/dist/internal/index.js +40 -40
  103. package/dist/internal/services/global.service.js +1 -1
  104. package/dist/internal/services/i18n.service.d.ts +1 -0
  105. package/dist/internal/services/i18n.service.js +2 -1
  106. package/dist/internal/services/i18n.service.js.map +1 -1
  107. package/dist/internal/utils/dom.d.ts +8 -0
  108. package/dist/internal/utils/dom.js +7 -1
  109. package/dist/internal/utils/dom.js.map +1 -1
  110. package/dist/logo/logo2.js +1 -1
  111. package/dist/menu/menu-item2.js +1 -1
  112. package/dist/menu/menu2.js +1 -1
  113. package/dist/month/month2.js +1 -1
  114. package/dist/notification/notification-group2.js +1 -1
  115. package/dist/notification/notification2.js +1 -1
  116. package/dist/page/page-panel/page-panel-content2.js +1 -1
  117. package/dist/page/page-panel/page-panel-footer2.js +1 -1
  118. package/dist/page/page-panel/page-panel-header2.js +1 -1
  119. package/dist/page/page-panel/page-panel2.js +1 -1
  120. package/dist/page/page.examples.js.map +1 -1
  121. package/dist/page/page.examples.json +0 -11
  122. package/dist/page/page2.js +1 -1
  123. package/dist/page-header/page-header.examples.js.map +1 -1
  124. package/dist/page-header/page-header.examples.json +2 -2
  125. package/dist/page-header/page-header2.js +1 -1
  126. package/dist/page-loader/page-loader2.js +1 -1
  127. package/dist/pagination/pagination2.js +1 -1
  128. package/dist/panel/panel2.js +4 -4
  129. package/dist/password/password2.js +1 -1
  130. package/dist/preferences-input/preferences-input2.js +1 -1
  131. package/dist/progress-bar/progress-bar2.js +1 -1
  132. package/dist/progress-ring/progress-ring2.js +1 -1
  133. package/dist/progressive-filter-chip/progressive-filter-chip2.js +1 -1
  134. package/dist/pulse/pulse2.js +1 -1
  135. package/dist/radio/radio-group2.js +1 -1
  136. package/dist/radio/radio2.js +1 -1
  137. package/dist/range/range2.js +1 -1
  138. package/dist/resize-handle/resize-handle.examples.js.map +1 -1
  139. package/dist/resize-handle/resize-handle.examples.json +3 -1
  140. package/dist/resize-handle/resize-handle2.js +1 -1
  141. package/dist/search/search2.js +1 -1
  142. package/dist/select/select2.js +1 -1
  143. package/dist/skeleton/skeleton.examples.js.map +1 -1
  144. package/dist/skeleton/skeleton.examples.json +3 -1
  145. package/dist/skeleton/skeleton2.js +1 -1
  146. package/dist/sort-button/sort-button2.js +1 -1
  147. package/dist/sparkline/sparkline.examples.js.map +1 -1
  148. package/dist/sparkline/sparkline.examples.json +3 -1
  149. package/dist/sparkline/sparkline2.js +1 -1
  150. package/dist/star-rating/star-rating2.js +1 -1
  151. package/dist/steps/steps2.js +2 -2
  152. package/dist/switch/switch-group2.js +1 -1
  153. package/dist/switch/switch2.js +1 -1
  154. package/dist/tabs/define.d.ts +2 -1
  155. package/dist/tabs/define.js +2 -1
  156. package/dist/tabs/define.js.map +1 -1
  157. package/dist/tabs/index.d.ts +1 -0
  158. package/dist/tabs/index.js +2 -1
  159. package/dist/tabs/tabs-group.d.ts +51 -0
  160. package/dist/tabs/tabs-group.js +6 -0
  161. package/dist/tabs/tabs-group.js.map +1 -0
  162. package/dist/tabs/tabs-group2.js +144 -0
  163. package/dist/tabs/tabs-group2.js.map +1 -0
  164. package/dist/tabs/tabs.examples.js.map +1 -1
  165. package/dist/tabs/tabs.examples.json +38 -2
  166. package/dist/tabs/tabs2.js +2 -2
  167. package/dist/tag/tag2.js +1 -1
  168. package/dist/textarea/textarea2.js +1 -1
  169. package/dist/time/time2.js +1 -1
  170. package/dist/toast/toast2.js +1 -1
  171. package/dist/toggletip/toggletip-footer2.js +1 -1
  172. package/dist/toggletip/toggletip-header2.js +1 -1
  173. package/dist/toggletip/toggletip2.js +1 -1
  174. package/dist/toolbar/toolbar2.js +1 -1
  175. package/dist/tooltip/tooltip2.js +1 -1
  176. package/dist/tree/tree-node.d.ts +1 -1
  177. package/dist/tree/tree-node.js +1 -1
  178. package/dist/tree/tree-node.js.map +1 -1
  179. package/dist/tree/tree-node2.js +1 -1
  180. package/dist/tree/tree-node2.js.map +1 -1
  181. package/dist/tree/tree.examples.js.map +1 -1
  182. package/dist/tree/tree.examples.json +1 -10
  183. package/dist/tree/tree2.js +1 -1
  184. package/dist/week/week2.js +1 -1
  185. package/package.json +43 -15
@@ -23,7 +23,7 @@ var b = class extends h {
23
23
  static {
24
24
  this.metadata = {
25
25
  tag: "nve-progressive-filter-chip",
26
- version: "0.0.3"
26
+ version: "0.0.4"
27
27
  };
28
28
  }
29
29
  static {
@@ -13,7 +13,7 @@ var c = class extends a {
13
13
  static {
14
14
  this.metadata = {
15
15
  tag: "nve-pulse",
16
- version: "0.0.3"
16
+ version: "0.0.4"
17
17
  };
18
18
  }
19
19
  static {
@@ -12,7 +12,7 @@ var o = class extends i {
12
12
  static {
13
13
  this.metadata = {
14
14
  tag: "nve-radio-group",
15
- version: "0.0.3",
15
+ version: "0.0.4",
16
16
  children: [
17
17
  "label",
18
18
  "nve-control-message",
@@ -15,7 +15,7 @@ var o = class extends i {
15
15
  static {
16
16
  this.metadata = {
17
17
  tag: "nve-radio",
18
- version: "0.0.3",
18
+ version: "0.0.4",
19
19
  children: [
20
20
  "label",
21
21
  "input",
@@ -17,7 +17,7 @@ var d = class extends i {
17
17
  static {
18
18
  this.metadata = {
19
19
  tag: "nve-range",
20
- version: "0.0.3"
20
+ version: "0.0.4"
21
21
  };
22
22
  }
23
23
  connectedCallback() {
@@ -1 +1 @@
1
- {"version":3,"file":"resize-handle.examples.js","names":[],"sources":["../../src/resize-handle/resize-handle.examples.ts"],"sourcesContent":["// SPDX-FileCopyrightText: Copyright (c) 2026 NVIDIA CORPORATION & AFFILIATES. All rights reserved.\n// SPDX-License-Identifier: Apache-2.0\n\nimport { html } from 'lit';\nimport '@nvidia-elements/core/forms/define.js';\nimport '@nvidia-elements/core/resize-handle/define.js';\n\nexport default {\n title: 'Elements/Resize Handle',\n component: 'nve-resize-handle',\n};\n\n/**\n * @summary Basic horizontal resize handle for draggable panel dividers and split pane interfaces.\n */\nexport const Default = {\n render: () => html`\n<nve-resize-handle></nve-resize-handle>`\n};\n\n/**\n * @summary Vertical resize handle for side-by-side panel layouts and horizontal split panes.\n */\nexport const Vertical = {\n render: () => html`\n<div style=\"height: 200px;\">\n <nve-resize-handle orientation=\"vertical\"></nve-resize-handle>\n</div>\n`\n};\n\n/**\n * @summary Horizontal split pane with draggable divider that adjusts top and bottom panel heights.\n */\nexport const SplitHorizontal = {\n render: () => html`\n<section id=\"split-horizontal-demo\" style=\"display: grid; width: 250px; height: 250px; grid-template-rows: 1fr auto 1fr; border: 1px solid var(--nve-ref-border-color)\">\n <div style=\"background: hsla(0, 0%, 65%, 0.1)\"></div>\n <nve-resize-handle min=\"20\" max=\"230\" value=\"125\" step=\"20\"></nve-resize-handle>\n <div></div>\n</section>\n<script type=\"module\">\n const handle = document.querySelector('#split-horizontal-demo nve-resize-handle');\n const split = document.querySelector('#split-horizontal-demo');\n handle.addEventListener('input', e => split.style.gridTemplateRows = '1fr auto ' + e.target.value + 'px');\n</script>\n`\n};\n\n/**\n * @summary Vertical split pane with draggable divider that adjusts left and right panel widths.\n */\nexport const SplitVertical = {\n render: () => html`\n<section id=\"split-vertical-demo\" style=\"display: grid; width: 250px; height: 250px; grid-template-columns: 1fr auto 1fr; border: 1px solid var(--nve-ref-border-color)\">\n <div style=\"background: hsla(0, 0%, 65%, 0.1)\"></div>\n <nve-resize-handle orientation=\"vertical\" min=\"20\" max=\"230\" value=\"125\" step=\"20\"></nve-resize-handle>\n <div></div>\n</section>\n<script type=\"module\">\n const handle = document.querySelector('#split-vertical-demo nve-resize-handle');\n const split = document.querySelector('#split-vertical-demo');\n handle.addEventListener('input', e => split.style.gridTemplateColumns = e.target.value + 'px auto 1fr');\n</script>\n`\n};\n\n/**\n * @summary Resize handle as a form control with name attribute for submitting resize values.\n */\nexport const Form = {\n render: () => html`\n<form id=\"form-demo\" nve-layout=\"column gap:lg\">\n <section style=\"display: grid; width: 250px; height: 250px; grid-template-rows: 1fr auto 1fr; border: 1px solid var(--nve-ref-border-color)\">\n <div></div>\n <nve-resize-handle name=\"resize\" min=\"20\" max=\"230\" value=\"125\" step=\"20\"></nve-resize-handle>\n <div style=\"background: hsla(0, 0%, 65%, 0.1)\"></div>\n </section>\n <nve-button>submit</nve-button>\n</form>\n<script type=\"module\">\n const form = document.querySelector('#form-demo');\n const split = document.querySelector('#form-demo section');\n const handle = document.querySelector('#form-demo nve-resize-handle');\n\n form.addEventListener('submit', e => {\n e.preventDefault();\n console.log(Object.fromEntries(new FormData(form)));\n console.log(handle.form)\n });\n\n handle.addEventListener('change', e => {\n console.log('change', e.target.value);\n });\n\n handle.addEventListener('input', e => {\n console.log('input', e.target.value);\n split.style.gridTemplateRows = '1fr auto ' + e.target.value + 'px';\n });\n</script>\n`\n};\n\n/**\n * @summary Resize handle with prevented default toggle to disable snap-to-boundary on double-click. Use when the default collapse/expand behavior conflicts with custom resize constraints or when you need full control over toggle logic.\n */\nexport const PreventDefault = {\n render: () => html`\n<form id=\"prevent-default-demo\" nve-layout=\"column gap:lg\">\n <section style=\"display: grid; width: 250px; height: 250px; grid-template-rows: 1fr auto 1fr; border: 1px solid var(--nve-ref-border-color)\">\n <div></div>\n <nve-resize-handle name=\"resize\" min=\"20\" max=\"230\" value=\"125\" step=\"20\"></nve-resize-handle>\n <div style=\"background: hsla(0, 0%, 65%, 0.1)\"></div>\n </section>\n</form>\n<script type=\"module\">\n const split = document.querySelector('#prevent-default-demo section');\n const handle = document.querySelector('#prevent-default-demo nve-resize-handle');\n\n handle.addEventListener('toggle', e => {\n e.preventDefault();\n console.log('toggle defaultPrevented:', e.defaultPrevented);\n });\n\n handle.addEventListener('input', e => {\n split.style.gridTemplateRows = '1fr auto ' + e.target.value + 'px';\n });\n</script>\n`\n};\n\n/**\n * @summary Custom line width styling for resize handle visibility using CSS custom property.\n */\nexport const LineWidth = {\n render: () => html`\n<div style=\"height: 200px;\">\n <nve-resize-handle orientation=\"vertical\" style=\"--line-width: 6px\"></nve-resize-handle>\n</div>\n`\n};\n"],"mappings":";AAGA,IAAA,IAAS"}
1
+ {"version":3,"file":"resize-handle.examples.js","names":[],"sources":["../../src/resize-handle/resize-handle.examples.ts"],"sourcesContent":["// SPDX-FileCopyrightText: Copyright (c) 2026 NVIDIA CORPORATION & AFFILIATES. All rights reserved.\n// SPDX-License-Identifier: Apache-2.0\n\n/* eslint-disable local-typescript/example-css-quality */\n/* eslint-disable local-typescript/example-metadata */\nimport { html } from 'lit';\nimport '@nvidia-elements/core/forms/define.js';\nimport '@nvidia-elements/core/resize-handle/define.js';\n\nexport default {\n title: 'Elements/Resize Handle',\n component: 'nve-resize-handle',\n};\n\n/**\n * @summary Basic horizontal resize handle for draggable panel dividers and split pane interfaces.\n */\nexport const Default = {\n render: () => html`\n<nve-resize-handle></nve-resize-handle>`\n};\n\n/**\n * @summary Vertical resize handle for side-by-side panel layouts and horizontal split panes.\n */\nexport const Vertical = {\n render: () => html`\n<div style=\"height: 200px;\">\n <nve-resize-handle orientation=\"vertical\"></nve-resize-handle>\n</div>\n`\n};\n\n/**\n * @summary Horizontal split pane with draggable divider that adjusts top and bottom panel heights.\n */\nexport const SplitHorizontal = {\n render: () => html`\n<section id=\"split-horizontal-demo\" style=\"display: grid; width: 250px; height: 250px; grid-template-rows: 1fr auto 1fr; border: 1px solid var(--nve-ref-border-color)\">\n <div style=\"background: hsla(0, 0%, 65%, 0.1)\"></div>\n <nve-resize-handle min=\"20\" max=\"230\" value=\"125\" step=\"20\"></nve-resize-handle>\n <div></div>\n</section>\n<script type=\"module\">\n const handle = document.querySelector('#split-horizontal-demo nve-resize-handle');\n const split = document.querySelector('#split-horizontal-demo');\n handle.addEventListener('input', e => split.style.gridTemplateRows = '1fr auto ' + e.target.value + 'px');\n</script>\n`\n};\n\n/**\n * @summary Vertical split pane with draggable divider that adjusts left and right panel widths.\n */\nexport const SplitVertical = {\n render: () => html`\n<section id=\"split-vertical-demo\" style=\"display: grid; width: 250px; height: 250px; grid-template-columns: 1fr auto 1fr; border: 1px solid var(--nve-ref-border-color)\">\n <div style=\"background: hsla(0, 0%, 65%, 0.1)\"></div>\n <nve-resize-handle orientation=\"vertical\" min=\"20\" max=\"230\" value=\"125\" step=\"20\"></nve-resize-handle>\n <div></div>\n</section>\n<script type=\"module\">\n const handle = document.querySelector('#split-vertical-demo nve-resize-handle');\n const split = document.querySelector('#split-vertical-demo');\n handle.addEventListener('input', e => split.style.gridTemplateColumns = e.target.value + 'px auto 1fr');\n</script>\n`\n};\n\n/**\n * @summary Resize handle as a form control with name attribute for submitting resize values.\n */\nexport const Form = {\n render: () => html`\n<form id=\"form-demo\" nve-layout=\"column gap:lg\">\n <section style=\"display: grid; width: 250px; height: 250px; grid-template-rows: 1fr auto 1fr; border: 1px solid var(--nve-ref-border-color)\">\n <div></div>\n <nve-resize-handle name=\"resize\" min=\"20\" max=\"230\" value=\"125\" step=\"20\"></nve-resize-handle>\n <div style=\"background: hsla(0, 0%, 65%, 0.1)\"></div>\n </section>\n <nve-button>submit</nve-button>\n</form>\n<script type=\"module\">\n const form = document.querySelector('#form-demo');\n const split = document.querySelector('#form-demo section');\n const handle = document.querySelector('#form-demo nve-resize-handle');\n\n form.addEventListener('submit', e => {\n e.preventDefault();\n console.log(Object.fromEntries(new FormData(form)));\n console.log(handle.form)\n });\n\n handle.addEventListener('change', e => {\n console.log('change', e.target.value);\n });\n\n handle.addEventListener('input', e => {\n console.log('input', e.target.value);\n split.style.gridTemplateRows = '1fr auto ' + e.target.value + 'px';\n });\n</script>\n`\n};\n\n/**\n * @summary Resize handle with prevented default toggle to disable snap-to-boundary on double-click. Use when the default collapse/expand behavior conflicts with custom resize constraints or when you need full control over toggle logic.\n */\nexport const PreventDefault = {\n render: () => html`\n<form id=\"prevent-default-demo\" nve-layout=\"column gap:lg\">\n <section style=\"display: grid; width: 250px; height: 250px; grid-template-rows: 1fr auto 1fr; border: 1px solid var(--nve-ref-border-color)\">\n <div></div>\n <nve-resize-handle name=\"resize\" min=\"20\" max=\"230\" value=\"125\" step=\"20\"></nve-resize-handle>\n <div style=\"background: hsla(0, 0%, 65%, 0.1)\"></div>\n </section>\n</form>\n<script type=\"module\">\n const split = document.querySelector('#prevent-default-demo section');\n const handle = document.querySelector('#prevent-default-demo nve-resize-handle');\n\n handle.addEventListener('toggle', e => {\n e.preventDefault();\n console.log('toggle defaultPrevented:', e.defaultPrevented);\n });\n\n handle.addEventListener('input', e => {\n split.style.gridTemplateRows = '1fr auto ' + e.target.value + 'px';\n });\n</script>\n`\n};\n\n/**\n * @summary Custom line width styling for resize handle visibility using CSS custom property.\n * @tags theme\n */\nexport const LineWidth = {\n render: () => html`\n<div style=\"height: 200px;\">\n <nve-resize-handle orientation=\"vertical\" style=\"--line-width: 6px\"></nve-resize-handle>\n</div>\n`\n};\n"],"mappings":";AAKA,IAAA,IAAS"}
@@ -63,7 +63,9 @@
63
63
  "summary": "Custom line width styling for resize handle visibility using CSS custom property.",
64
64
  "description": "",
65
65
  "composition": false,
66
- "tags": []
66
+ "tags": [
67
+ "theme"
68
+ ]
67
69
  }
68
70
  ]
69
71
  }
@@ -18,7 +18,7 @@ var u = class extends l(a) {
18
18
  static {
19
19
  this.metadata = {
20
20
  tag: "nve-resize-handle",
21
- version: "0.0.3",
21
+ version: "0.0.4",
22
22
  valueSchema: { type: "number" }
23
23
  };
24
24
  }
@@ -22,7 +22,7 @@ var l = class extends r {
22
22
  static {
23
23
  this.metadata = {
24
24
  tag: "nve-search",
25
- version: "0.0.3"
25
+ version: "0.0.4"
26
26
  };
27
27
  }
28
28
  static {
@@ -26,7 +26,7 @@ var b = class extends u {
26
26
  static {
27
27
  this.metadata = {
28
28
  tag: "nve-select",
29
- version: "0.0.3"
29
+ version: "0.0.4"
30
30
  };
31
31
  }
32
32
  static {
@@ -1 +1 @@
1
- {"version":3,"file":"skeleton.examples.js","names":[],"sources":["../../src/skeleton/skeleton.examples.ts"],"sourcesContent":["// SPDX-FileCopyrightText: Copyright (c) 2026 NVIDIA CORPORATION & AFFILIATES. All rights reserved.\n// SPDX-License-Identifier: Apache-2.0\n\nimport { html } from 'lit';\nimport '@nvidia-elements/core/skeleton/define.js';\n\nexport default {\n title: 'Elements/Skeleton',\n component: 'nve-skeleton',\n};\n\n/**\n * @summary Basic skeleton component for text content. Placeholder lines appear while content loads.\n */\nexport const Default = {\n render: () => html`\n<div nve-layout=\"column gap:xs align:stretch\">\n <nve-skeleton></nve-skeleton>\n <nve-skeleton style=\"width: 90%\"></nve-skeleton>\n <nve-skeleton style=\"width: 80%\"></nve-skeleton>\n</div>`\n};\n\n/**\n * @summary Skeleton loading effects including pulse and shimmer animations. Use pulse for subtle breathing motion or shimmer for a scanning highlight that conveys active content loading.\n */\nexport const Effect = {\n render: () => html`\n<div nve-layout=\"column gap:xs align:stretch\">\n <nve-skeleton></nve-skeleton>\n <nve-skeleton effect=\"pulse\"></nve-skeleton>\n <nve-skeleton effect=\"shimmer\"></nve-skeleton>\n</div>`\n}\n\n/**\n * @summary Skeleton shape variants including default rectangle, pill, and round. Use pill for button or tag placeholders and round for avatar or icon placeholders to match the final content shape.\n */\nexport const Shape = {\n render: () => html`\n<div nve-layout=\"column gap:xs align:stretch\">\n <nve-skeleton></nve-skeleton>\n <nve-skeleton shape=\"pill\"></nve-skeleton>\n <nve-skeleton shape=\"round\" style=\"width: 40px; height: 40px;\"></nve-skeleton>\n</div>`\n}\n\n/**\n * @summary Skeleton with slotted content that automatically hides the placeholder when real content arrives. Use to wrap lazy-loaded content so the skeleton disappears once data loads without manual state management.\n */\nexport const Slotted = {\n render: () => html`\n<div nve-layout=\"column gap:xs align:stretch\">\n <nve-skeleton></nve-skeleton>\n <nve-skeleton effect=\"shimmer\">slotting content will hide the skeleton</nve-skeleton>\n <nve-skeleton effect=\"shimmer\"> </nve-skeleton>\n</div>`\n}\n"],"mappings":";AAGA,IAAA,IAAS"}
1
+ {"version":3,"file":"skeleton.examples.js","names":[],"sources":["../../src/skeleton/skeleton.examples.ts"],"sourcesContent":["// SPDX-FileCopyrightText: Copyright (c) 2026 NVIDIA CORPORATION & AFFILIATES. All rights reserved.\n// SPDX-License-Identifier: Apache-2.0\n\nimport { html } from 'lit';\nimport '@nvidia-elements/core/skeleton/define.js';\n\nexport default {\n title: 'Elements/Skeleton',\n component: 'nve-skeleton',\n};\n\n/**\n * @summary Basic skeleton component for text content. Placeholder lines appear while content loads.\n */\nexport const Default = {\n render: () => html`\n<div nve-layout=\"column gap:xs align:stretch\">\n <nve-skeleton></nve-skeleton>\n <nve-skeleton style=\"width: 90%\"></nve-skeleton>\n <nve-skeleton style=\"width: 80%\"></nve-skeleton>\n</div>`\n};\n\n/**\n * @summary Skeleton loading effects including pulse and shimmer animations. Use pulse for subtle breathing motion or shimmer for a scanning highlight that conveys active content loading.\n */\nexport const Effect = {\n render: () => html`\n<div nve-layout=\"column gap:xs align:stretch\">\n <nve-skeleton></nve-skeleton>\n <nve-skeleton effect=\"pulse\"></nve-skeleton>\n <nve-skeleton effect=\"shimmer\"></nve-skeleton>\n</div>`\n}\n\n/**\n * @summary Skeleton shape variants including default rectangle, pill, and round. Use pill for button or tag placeholders and round for avatar or icon placeholders to match the final content shape.\n * @tags theme\n */\nexport const Shape = {\n render: () => html`\n<div nve-layout=\"column gap:xs align:stretch\">\n <nve-skeleton></nve-skeleton>\n <nve-skeleton shape=\"pill\"></nve-skeleton>\n <nve-skeleton shape=\"round\" style=\"width: 40px; height: 40px;\"></nve-skeleton>\n</div>`\n}\n\n/**\n * @summary Skeleton with slotted content that automatically hides the placeholder when real content arrives. Use to wrap lazy-loaded content so the skeleton disappears once data loads without manual state management.\n */\nexport const Slotted = {\n render: () => html`\n<div nve-layout=\"column gap:xs align:stretch\">\n <nve-skeleton></nve-skeleton>\n <nve-skeleton effect=\"shimmer\">slotting content will hide the skeleton</nve-skeleton>\n <nve-skeleton effect=\"shimmer\"> </nve-skeleton>\n</div>`\n}\n"],"mappings":";AAGA,IAAA,IAAS"}
@@ -27,7 +27,9 @@
27
27
  "summary": "Skeleton shape variants including default rectangle, pill, and round. Use pill for button or tag placeholders and round for avatar or icon placeholders to match the final content shape.",
28
28
  "description": "",
29
29
  "composition": false,
30
- "tags": []
30
+ "tags": [
31
+ "theme"
32
+ ]
31
33
  },
32
34
  {
33
35
  "id": "core-skeleton_slotted",
@@ -15,7 +15,7 @@ var s = class extends i {
15
15
  static {
16
16
  this.metadata = {
17
17
  tag: "nve-skeleton",
18
- version: "0.0.3"
18
+ version: "0.0.4"
19
19
  };
20
20
  }
21
21
  render() {
@@ -19,7 +19,7 @@ var l = {
19
19
  static {
20
20
  this.metadata = {
21
21
  tag: "nve-sort-button",
22
- version: "0.0.3"
22
+ version: "0.0.4"
23
23
  };
24
24
  }
25
25
  static {
@@ -1 +1 @@
1
- {"version":3,"file":"sparkline.examples.js","names":[],"sources":["../../src/sparkline/sparkline.examples.ts"],"sourcesContent":["// SPDX-FileCopyrightText: Copyright (c) 2026 NVIDIA CORPORATION & AFFILIATES. All rights reserved.\n// SPDX-License-Identifier: Apache-2.0\n\nimport { html } from 'lit';\nimport '@nvidia-elements/core/sparkline/define.js';\nimport '@nvidia-elements/core/grid/define.js';\nimport '@nvidia-elements/core/range/define.js';\n\nexport default {\n title: 'Elements/Sparkline',\n component: 'nve-sparkline',\n};\n\n/**\n * @summary Basic sparkline from numeric array values. Use as a compact trend indicator.\n */\nexport const Default = {\n render: () => html`\n <nve-sparkline id=\"default\"></nve-sparkline>\n <script type=\"module\">\n const sparkline = document.querySelector('nve-sparkline#default');\n sparkline.data = [18, 22, 20, 24, 19, 28, 25, 30];\n </script>\n `\n};\n\n/**\n * @summary Mark variants include line, area, gradient, column, and winloss to support trend and outcome signals.\n */\nexport const Marks = {\n render: () => html`\n <div nve-layout=\"row gap:md\">\n <nve-sparkline data=\"[14, 18, 17, 20, 19, 24, 21]\"></nve-sparkline>\n <nve-sparkline mark=\"area\" data=\"[14, 18, 17, 20, 19, 24, 21]\"></nve-sparkline>\n <nve-sparkline mark=\"gradient\" data=\"[14, 18, 17, 20, 19, 24, 21]\"></nve-sparkline>\n <nve-sparkline mark=\"column\" data=\"[6, 10, 8, 16, 13, 18, 15]\"></nve-sparkline>\n <nve-sparkline mark=\"winloss\" data=\"[5, -3, 2, -1, 4, 0, 3]\"></nve-sparkline>\n </div>\n `\n};\n\n/**\n * @summary Semantic statuses apply task, support, and trend color mappings.\n */\nexport const Status = {\n render: () => html`\n <div nve-layout=\"row gap:md\">\n <nve-sparkline status=\"accent\" mark=\"area\" data=\"[3, 2, 10, 8, 4, 6, 9]\"></nve-sparkline>\n <nve-sparkline status=\"danger\" mark=\"area\" data=\"[15, 14, 12, 9, 8, 7, 5]\"></nve-sparkline>\n <nve-sparkline status=\"warning\" mark=\"area\" data=\"[8, 9, 7, 10, 9, 8, 9]\"></nve-sparkline>\n <nve-sparkline status=\"success\" mark=\"area\" data=\"[5, 7, 8, 9, 12, 14, 15]\"></nve-sparkline>\n </div>\n `\n};\n\n/**\n * @summary Sparklines inherit font size and flow inline with surrounding text and metrics.\n */\nexport const InlineWithText = {\n render: () => html`\n <div nve-layout=\"column gap:lg\">\n <p nve-text=\"body loose\">\n This week's lane keeping safety score trend \n <nve-sparkline\n mark=\"area\"\n status=\"success\"\n data=\"[86, 87, 86, 88, 89, 90, 92, 93]\"\n aria-label=\"lane keeping safety score trend\"></nve-sparkline>\n shows a steady rise after an early dip, with decreasing interventions per shift: \n <nve-sparkline\n mark=\"column\"\n status=\"accent\"\n data=\"[16, 14, 15, 13, 12, 11, 10]\"\n aria-label=\"lane keeping interventions per shift\"></nve-sparkline>, \n and predominantly successful route outcomes: \n <nve-sparkline\n mark=\"winloss\"\n status=\"success\"\n data=\"[1, 1, -1, 1, 0, 1, 1]\"\n aria-label=\"lane keeping route outcomes\"></nve-sparkline>.\n </p>\n </div>\n `\n};\n\n/**\n * @summary Embed sparklines in grid cells to add compact trend context to tabular data.\n */\nexport const DataGrid = {\n render: () => html`\n <nve-grid>\n <nve-grid-header>\n <nve-grid-column>Autonomy Service</nve-grid-column>\n <nve-grid-column>Safety Score</nve-grid-column>\n <nve-grid-column>Interventions / Shift</nve-grid-column>\n <nve-grid-column>Route Outcome</nve-grid-column>\n </nve-grid-header>\n <nve-grid-row>\n <nve-grid-cell>Lane Keeping</nve-grid-cell>\n <nve-grid-cell>\n <nve-sparkline\n aria-label=\"Lane Keeping 30 day safety score trend\"\n mark=\"area\"\n status=\"success\"\n min=\"0\"\n max=\"100\"\n data=\"[86, 87, 86, 88, 89, 90, 92, 93]\"\n size=\"md\"></nve-sparkline>\n </nve-grid-cell>\n <nve-grid-cell>\n <nve-sparkline\n aria-label=\"Lane Keeping interventions per shift\"\n mark=\"column\"\n status=\"success\"\n min=\"0\"\n max=\"50\"\n data=\"[12, 11, 12, 10, 9, 8, 7, 6]\"\n size=\"md\"></nve-sparkline>\n </nve-grid-cell>\n <nve-grid-cell>\n <nve-sparkline\n aria-label=\"Lane Keeping route outcomes\"\n mark=\"winloss\"\n data=\"[1, 1, 1, 0, 1, 0, 1, 1]\"\n size=\"md\"></nve-sparkline>\n </nve-grid-cell>\n </nve-grid-row>\n <nve-grid-row>\n <nve-grid-cell>Object Detection</nve-grid-cell>\n <nve-grid-cell>\n <nve-sparkline\n aria-label=\"Object Detection 30 day safety score trend\"\n mark=\"area\"\n status=\"warning\"\n min=\"0\"\n max=\"100\"\n data=\"[76, 88, 72, 79, 85, 70, 83, 74]\"\n size=\"md\"></nve-sparkline>\n </nve-grid-cell>\n <nve-grid-cell>\n <nve-sparkline\n aria-label=\"Object Detection interventions per shift\"\n mark=\"column\"\n status=\"warning\"\n min=\"0\"\n max=\"50\"\n data=\"[18, 20, 17, 19, 20, 21, 19, 22]\"\n size=\"md\"></nve-sparkline>\n </nve-grid-cell>\n <nve-grid-cell>\n <nve-sparkline\n aria-label=\"Object Detection route outcomes\"\n mark=\"winloss\"\n data=\"[1, 0, -1, 1, 0, -1, 0, 1]\"\n size=\"md\"></nve-sparkline>\n </nve-grid-cell>\n </nve-grid-row>\n <nve-grid-row>\n <nve-grid-cell>Path Planning</nve-grid-cell>\n <nve-grid-cell>\n <nve-sparkline\n aria-label=\"Path Planning 30 day safety score trend\"\n mark=\"area\"\n status=\"danger\"\n min=\"0\"\n max=\"100\"\n data=\"[58, 54, 49, 45, 40, 36, 31, 27]\"\n size=\"md\"></nve-sparkline>\n </nve-grid-cell>\n <nve-grid-cell>\n <nve-sparkline\n aria-label=\"Path Planning interventions per shift\"\n mark=\"column\"\n status=\"danger\"\n min=\"0\"\n max=\"50\"\n data=\"[24, 26, 29, 31, 34, 36, 39, 42]\"\n size=\"md\"></nve-sparkline>\n </nve-grid-cell>\n <nve-grid-cell>\n <nve-sparkline\n aria-label=\"Path Planning route outcomes\"\n mark=\"winloss\"\n data=\"[1, -1, 0, -1, -1, -1, 0, -1]\"\n size=\"md\"></nve-sparkline>\n </nve-grid-cell>\n </nve-grid-row>\n </nve-grid>\n `\n};\n\n/**\n * @summary Explicit size tokens set fixed sparkline height independent of text context.\n */\nexport const ExplicitSize = {\n render: () => html`\n <div id=\"sparkline-sizes\" nve-layout=\"row gap:md\">\n <nve-sparkline size=\"xs\"></nve-sparkline>\n <nve-sparkline size=\"sm\"></nve-sparkline>\n <nve-sparkline size=\"md\"></nve-sparkline>\n <nve-sparkline size=\"lg\"></nve-sparkline>\n <nve-sparkline size=\"xl\"></nve-sparkline>\n </div>\n <script type=\"module\">\n const sparklines = document.querySelectorAll('#sparkline-sizes > nve-sparkline');\n for (const sparkline of sparklines) {\n sparkline.data = [9, 12, 11, 13, 15, 14, 16];\n }\n </script>\n `\n};\n\n/**\n * @summary Without a size attribute, height scales with the parent text size for typographic alignment.\n */\nexport const DefaultSize = {\n render: () => html`\n <div id=\"inline-sparkline-sizes\" nve-layout=\"column gap:md\">\n <div nve-layout=\"row gap:sm\" nve-text=\"heading\">\n <span>heading</span>\n <nve-sparkline></nve-sparkline>\n </div>\n <div nve-layout=\"row gap:sm\" nve-text=\"body\">\n <span>body</span>\n <nve-sparkline></nve-sparkline>\n </div>\n <div nve-layout=\"row gap:sm\" nve-text=\"label sm\">\n <span>label sm</span>\n <nve-sparkline></nve-sparkline>\n </div>\n </div>\n <script type=\"module\">\n const sparklines = document.querySelectorAll('#inline-sparkline-sizes > div[nve-text] > nve-sparkline');\n for (const sparkline of sparklines) {\n sparkline.data = [9, 12, 11, 13, 15, 14, 16];\n }\n </script>\n `\n};\n\n/**\n * @summary Interpolation controls linear, smooth, or step transitions between points.\n */\nexport const Interpolation = {\n render: () => html`\n <div id=\"sparkline-interpolations\" nve-layout=\"row gap:md\">\n <nve-sparkline mark=\"area\" interpolation=\"linear\"></nve-sparkline>\n <nve-sparkline mark=\"area\" interpolation=\"smooth\"></nve-sparkline>\n <nve-sparkline mark=\"area\" interpolation=\"step\"></nve-sparkline>\n </div>\n <script type=\"module\">\n const sparklines = document.querySelectorAll('#sparkline-interpolations > nve-sparkline');\n for (const sparkline of sparklines) {\n sparkline.data = [6, 10, 8, 16, 13, 18, 15];\n }\n </script>\n `\n};\n\n/**\n * @summary Symbols denote specific data points in line, area, and gradient marks.\n */\nexport const Symbols = {\n render: () => html`\n <div id=\"sparkline-symbols\" nve-layout=\"row gap:md\">\n <nve-sparkline denote-last></nve-sparkline>\n <nve-sparkline denote-first denote-last></nve-sparkline>\n <nve-sparkline denote-min denote-max></nve-sparkline>\n </div>\n <script type=\"module\">\n const sparklines = document.querySelectorAll('#sparkline-symbols > nve-sparkline');\n for (const sparkline of sparklines) {\n sparkline.data = [12, 8, 15, 10, 18, 14, 11];\n }\n </script>\n `\n};\n\n/**\n * @summary Fixed min and max values define a shared vertical domain to ensure comparability across adjacent sparklines.\n */\nexport const FixedDataDomain = {\n render: () => html`\n <div nve-layout=\"column gap:md align:left\" nve-text=\"body lg\">\n <nve-sparkline min=\"0\" max=\"100\" mark=\"area\" status=\"accent\" data=\"[80, 85, 90, 95, 100]\"></nve-sparkline>\n <nve-sparkline min=\"0\" max=\"100\" mark=\"area\" status=\"accent\" data=\"[40, 45, 50, 55, 60]\"></nve-sparkline>\n <nve-sparkline min=\"0\" max=\"100\" mark=\"area\" status=\"accent\" data=\"[0, 5, 10, 15, 20]\"></nve-sparkline>\n </div>\n `\n};\n\n/**\n * @summary The chart renders a zero baseline when the data includes both positive and negative values.\n */\nexport const ZeroLine = {\n render: () => html`\n <div nve-layout=\"row gap:md\">\n <nve-sparkline aria-label=\"mixed values\" mark=\"area\" data=\"[-3, 2, 5, -1, 3, -2, 4]\"></nve-sparkline>\n <nve-sparkline aria-label=\"mostly negative values\" mark=\"gradient\" data=\"[-8, -5, -2, 1, -3, -6, -4]\"></nve-sparkline>\n <nve-sparkline aria-label=\"mixed values column\" mark=\"column\" data=\"[-3, 2, 5, -1, 3, -2, 4]\"></nve-sparkline>\n </div>\n `\n};\n\n/**\n * @summary Interval length adjusts spacing between points for line marks, from compact to spacious.\n */\nexport const IntervalLength = {\n render: () => html`\n <div id=\"sparkline-intervals\" nve-layout=\"row gap:md\">\n <nve-sparkline interval-length=\"0.3\"></nve-sparkline>\n <nve-sparkline interval-length=\"0.6\"></nve-sparkline>\n <nve-sparkline interval-length=\"2.0\"></nve-sparkline>\n </div>\n <script type=\"module\">\n const sparklines = document.querySelectorAll('#sparkline-intervals > nve-sparkline');\n for (const sparkline of sparklines) {\n sparkline.data = [10, 20, 15, 25, 18];\n }\n </script>\n `\n};\n\n/**\n * @summary CSS custom properties are available to adjust dimensions and visual styling.\n */\nexport const CustomStyling = {\n render: () => html`\n <nve-sparkline\n aria-label=\"custom sparkline\"\n mark=\"gradient\"\n interpolation=\"smooth\"\n data=\"[8, 14, 9, 17, 13, 21, 16]\"\n denote-last\n style=\"\n --height: 120px;\n --accent-color: var(--nve-sys-layer-canvas-background);\n --accent-radius: 5px;\n --accent-border-width: 3px;\n --line-width: 2.5px;\n --line-color: var(--nve-ref-color-blue-cobalt-1100);\n --gradient-max-color: color-mix(in oklab, var(--nve-ref-color-blue-cobalt-1100) 45%, transparent);\n --gradient-min-color: color-mix(in oklab, var(--nve-ref-color-blue-cobalt-1100), transparent 90%);\n \"\n ></nve-sparkline>\n `\n};\n"],"mappings":";AAGA,IAAA,IAAS"}
1
+ {"version":3,"file":"sparkline.examples.js","names":[],"sources":["../../src/sparkline/sparkline.examples.ts"],"sourcesContent":["// SPDX-FileCopyrightText: Copyright (c) 2026 NVIDIA CORPORATION & AFFILIATES. All rights reserved.\n// SPDX-License-Identifier: Apache-2.0\n\nimport { html } from 'lit';\nimport '@nvidia-elements/core/sparkline/define.js';\nimport '@nvidia-elements/core/grid/define.js';\nimport '@nvidia-elements/core/range/define.js';\n\nexport default {\n title: 'Elements/Sparkline',\n component: 'nve-sparkline',\n};\n\n/**\n * @summary Basic sparkline from numeric array values. Use as a compact trend indicator.\n */\nexport const Default = {\n render: () => html`\n <nve-sparkline id=\"default\"></nve-sparkline>\n <script type=\"module\">\n const sparkline = document.querySelector('nve-sparkline#default');\n sparkline.data = [18, 22, 20, 24, 19, 28, 25, 30];\n </script>\n `\n};\n\n/**\n * @summary Mark variants include line, area, gradient, column, and winloss to support trend and outcome signals.\n */\nexport const Marks = {\n render: () => html`\n <div nve-layout=\"row gap:md\">\n <nve-sparkline data=\"[14, 18, 17, 20, 19, 24, 21]\"></nve-sparkline>\n <nve-sparkline mark=\"area\" data=\"[14, 18, 17, 20, 19, 24, 21]\"></nve-sparkline>\n <nve-sparkline mark=\"gradient\" data=\"[14, 18, 17, 20, 19, 24, 21]\"></nve-sparkline>\n <nve-sparkline mark=\"column\" data=\"[6, 10, 8, 16, 13, 18, 15]\"></nve-sparkline>\n <nve-sparkline mark=\"winloss\" data=\"[5, -3, 2, -1, 4, 0, 3]\"></nve-sparkline>\n </div>\n `\n};\n\n/**\n * @summary Semantic statuses apply task, support, and trend color mappings.\n */\nexport const Status = {\n render: () => html`\n <div nve-layout=\"row gap:md\">\n <nve-sparkline status=\"accent\" mark=\"area\" data=\"[3, 2, 10, 8, 4, 6, 9]\"></nve-sparkline>\n <nve-sparkline status=\"danger\" mark=\"area\" data=\"[15, 14, 12, 9, 8, 7, 5]\"></nve-sparkline>\n <nve-sparkline status=\"warning\" mark=\"area\" data=\"[8, 9, 7, 10, 9, 8, 9]\"></nve-sparkline>\n <nve-sparkline status=\"success\" mark=\"area\" data=\"[5, 7, 8, 9, 12, 14, 15]\"></nve-sparkline>\n </div>\n `\n};\n\n/**\n * @summary Sparklines inherit font size and flow inline with surrounding text and metrics.\n */\nexport const InlineWithText = {\n render: () => html`\n <div nve-layout=\"column gap:lg\">\n <p nve-text=\"body loose\">\n This week's lane keeping safety score trend \n <nve-sparkline\n mark=\"area\"\n status=\"success\"\n data=\"[86, 87, 86, 88, 89, 90, 92, 93]\"\n aria-label=\"lane keeping safety score trend\"></nve-sparkline>\n shows a steady rise after an early dip, with decreasing interventions per shift: \n <nve-sparkline\n mark=\"column\"\n status=\"accent\"\n data=\"[16, 14, 15, 13, 12, 11, 10]\"\n aria-label=\"lane keeping interventions per shift\"></nve-sparkline>, \n and predominantly successful route outcomes: \n <nve-sparkline\n mark=\"winloss\"\n status=\"success\"\n data=\"[1, 1, -1, 1, 0, 1, 1]\"\n aria-label=\"lane keeping route outcomes\"></nve-sparkline>.\n </p>\n </div>\n `\n};\n\n/**\n * @summary Embed sparklines in grid cells to add compact trend context to tabular data.\n */\nexport const DataGrid = {\n render: () => html`\n <nve-grid>\n <nve-grid-header>\n <nve-grid-column>Autonomy Service</nve-grid-column>\n <nve-grid-column>Safety Score</nve-grid-column>\n <nve-grid-column>Interventions / Shift</nve-grid-column>\n <nve-grid-column>Route Outcome</nve-grid-column>\n </nve-grid-header>\n <nve-grid-row>\n <nve-grid-cell>Lane Keeping</nve-grid-cell>\n <nve-grid-cell>\n <nve-sparkline\n aria-label=\"Lane Keeping 30 day safety score trend\"\n mark=\"area\"\n status=\"success\"\n min=\"0\"\n max=\"100\"\n data=\"[86, 87, 86, 88, 89, 90, 92, 93]\"\n size=\"md\"></nve-sparkline>\n </nve-grid-cell>\n <nve-grid-cell>\n <nve-sparkline\n aria-label=\"Lane Keeping interventions per shift\"\n mark=\"column\"\n status=\"success\"\n min=\"0\"\n max=\"50\"\n data=\"[12, 11, 12, 10, 9, 8, 7, 6]\"\n size=\"md\"></nve-sparkline>\n </nve-grid-cell>\n <nve-grid-cell>\n <nve-sparkline\n aria-label=\"Lane Keeping route outcomes\"\n mark=\"winloss\"\n data=\"[1, 1, 1, 0, 1, 0, 1, 1]\"\n size=\"md\"></nve-sparkline>\n </nve-grid-cell>\n </nve-grid-row>\n <nve-grid-row>\n <nve-grid-cell>Object Detection</nve-grid-cell>\n <nve-grid-cell>\n <nve-sparkline\n aria-label=\"Object Detection 30 day safety score trend\"\n mark=\"area\"\n status=\"warning\"\n min=\"0\"\n max=\"100\"\n data=\"[76, 88, 72, 79, 85, 70, 83, 74]\"\n size=\"md\"></nve-sparkline>\n </nve-grid-cell>\n <nve-grid-cell>\n <nve-sparkline\n aria-label=\"Object Detection interventions per shift\"\n mark=\"column\"\n status=\"warning\"\n min=\"0\"\n max=\"50\"\n data=\"[18, 20, 17, 19, 20, 21, 19, 22]\"\n size=\"md\"></nve-sparkline>\n </nve-grid-cell>\n <nve-grid-cell>\n <nve-sparkline\n aria-label=\"Object Detection route outcomes\"\n mark=\"winloss\"\n data=\"[1, 0, -1, 1, 0, -1, 0, 1]\"\n size=\"md\"></nve-sparkline>\n </nve-grid-cell>\n </nve-grid-row>\n <nve-grid-row>\n <nve-grid-cell>Path Planning</nve-grid-cell>\n <nve-grid-cell>\n <nve-sparkline\n aria-label=\"Path Planning 30 day safety score trend\"\n mark=\"area\"\n status=\"danger\"\n min=\"0\"\n max=\"100\"\n data=\"[58, 54, 49, 45, 40, 36, 31, 27]\"\n size=\"md\"></nve-sparkline>\n </nve-grid-cell>\n <nve-grid-cell>\n <nve-sparkline\n aria-label=\"Path Planning interventions per shift\"\n mark=\"column\"\n status=\"danger\"\n min=\"0\"\n max=\"50\"\n data=\"[24, 26, 29, 31, 34, 36, 39, 42]\"\n size=\"md\"></nve-sparkline>\n </nve-grid-cell>\n <nve-grid-cell>\n <nve-sparkline\n aria-label=\"Path Planning route outcomes\"\n mark=\"winloss\"\n data=\"[1, -1, 0, -1, -1, -1, 0, -1]\"\n size=\"md\"></nve-sparkline>\n </nve-grid-cell>\n </nve-grid-row>\n </nve-grid>\n `\n};\n\n/**\n * @summary Explicit size tokens set fixed sparkline height independent of text context.\n */\nexport const ExplicitSize = {\n render: () => html`\n <div id=\"sparkline-sizes\" nve-layout=\"row gap:md\">\n <nve-sparkline size=\"xs\"></nve-sparkline>\n <nve-sparkline size=\"sm\"></nve-sparkline>\n <nve-sparkline size=\"md\"></nve-sparkline>\n <nve-sparkline size=\"lg\"></nve-sparkline>\n <nve-sparkline size=\"xl\"></nve-sparkline>\n </div>\n <script type=\"module\">\n const sparklines = document.querySelectorAll('#sparkline-sizes > nve-sparkline');\n for (const sparkline of sparklines) {\n sparkline.data = [9, 12, 11, 13, 15, 14, 16];\n }\n </script>\n `\n};\n\n/**\n * @summary Without a size attribute, height scales with the parent text size for typographic alignment.\n */\nexport const DefaultSize = {\n render: () => html`\n <div id=\"inline-sparkline-sizes\" nve-layout=\"column gap:md\">\n <div nve-layout=\"row gap:sm\" nve-text=\"heading\">\n <span>heading</span>\n <nve-sparkline></nve-sparkline>\n </div>\n <div nve-layout=\"row gap:sm\" nve-text=\"body\">\n <span>body</span>\n <nve-sparkline></nve-sparkline>\n </div>\n <div nve-layout=\"row gap:sm\" nve-text=\"label sm\">\n <span>label sm</span>\n <nve-sparkline></nve-sparkline>\n </div>\n </div>\n <script type=\"module\">\n const sparklines = document.querySelectorAll('#inline-sparkline-sizes > div[nve-text] > nve-sparkline');\n for (const sparkline of sparklines) {\n sparkline.data = [9, 12, 11, 13, 15, 14, 16];\n }\n </script>\n `\n};\n\n/**\n * @summary Interpolation controls linear, smooth, or step transitions between points.\n */\nexport const Interpolation = {\n render: () => html`\n <div id=\"sparkline-interpolations\" nve-layout=\"row gap:md\">\n <nve-sparkline mark=\"area\" interpolation=\"linear\"></nve-sparkline>\n <nve-sparkline mark=\"area\" interpolation=\"smooth\"></nve-sparkline>\n <nve-sparkline mark=\"area\" interpolation=\"step\"></nve-sparkline>\n </div>\n <script type=\"module\">\n const sparklines = document.querySelectorAll('#sparkline-interpolations > nve-sparkline');\n for (const sparkline of sparklines) {\n sparkline.data = [6, 10, 8, 16, 13, 18, 15];\n }\n </script>\n `\n};\n\n/**\n * @summary Symbols denote specific data points in line, area, and gradient marks.\n */\nexport const Symbols = {\n render: () => html`\n <div id=\"sparkline-symbols\" nve-layout=\"row gap:md\">\n <nve-sparkline denote-last></nve-sparkline>\n <nve-sparkline denote-first denote-last></nve-sparkline>\n <nve-sparkline denote-min denote-max></nve-sparkline>\n </div>\n <script type=\"module\">\n const sparklines = document.querySelectorAll('#sparkline-symbols > nve-sparkline');\n for (const sparkline of sparklines) {\n sparkline.data = [12, 8, 15, 10, 18, 14, 11];\n }\n </script>\n `\n};\n\n/**\n * @summary Fixed min and max values define a shared vertical domain to ensure comparability across adjacent sparklines.\n */\nexport const FixedDataDomain = {\n render: () => html`\n <div nve-layout=\"column gap:md align:left\" nve-text=\"body lg\">\n <nve-sparkline min=\"0\" max=\"100\" mark=\"area\" status=\"accent\" data=\"[80, 85, 90, 95, 100]\"></nve-sparkline>\n <nve-sparkline min=\"0\" max=\"100\" mark=\"area\" status=\"accent\" data=\"[40, 45, 50, 55, 60]\"></nve-sparkline>\n <nve-sparkline min=\"0\" max=\"100\" mark=\"area\" status=\"accent\" data=\"[0, 5, 10, 15, 20]\"></nve-sparkline>\n </div>\n `\n};\n\n/**\n * @summary The chart renders a zero baseline when the data includes both positive and negative values.\n */\nexport const ZeroLine = {\n render: () => html`\n <div nve-layout=\"row gap:md\">\n <nve-sparkline aria-label=\"mixed values\" mark=\"area\" data=\"[-3, 2, 5, -1, 3, -2, 4]\"></nve-sparkline>\n <nve-sparkline aria-label=\"mostly negative values\" mark=\"gradient\" data=\"[-8, -5, -2, 1, -3, -6, -4]\"></nve-sparkline>\n <nve-sparkline aria-label=\"mixed values column\" mark=\"column\" data=\"[-3, 2, 5, -1, 3, -2, 4]\"></nve-sparkline>\n </div>\n `\n};\n\n/**\n * @summary Interval length adjusts spacing between points for line marks, from compact to spacious.\n */\nexport const IntervalLength = {\n render: () => html`\n <div id=\"sparkline-intervals\" nve-layout=\"row gap:md\">\n <nve-sparkline interval-length=\"0.3\"></nve-sparkline>\n <nve-sparkline interval-length=\"0.6\"></nve-sparkline>\n <nve-sparkline interval-length=\"2.0\"></nve-sparkline>\n </div>\n <script type=\"module\">\n const sparklines = document.querySelectorAll('#sparkline-intervals > nve-sparkline');\n for (const sparkline of sparklines) {\n sparkline.data = [10, 20, 15, 25, 18];\n }\n </script>\n `\n};\n\n/**\n * @summary CSS custom properties are available to adjust dimensions and visual styling.\n * @tags theme\n */\nexport const CustomStyling = {\n render: () => html`\n <nve-sparkline\n aria-label=\"custom sparkline\"\n mark=\"gradient\"\n interpolation=\"smooth\"\n data=\"[8, 14, 9, 17, 13, 21, 16]\"\n denote-last\n style=\"\n --height: 120px;\n --accent-color: var(--nve-sys-layer-canvas-background);\n --accent-radius: 5px;\n --accent-border-width: 3px;\n --line-width: 2.5px;\n --line-color: var(--nve-ref-color-blue-cobalt-1100);\n --gradient-max-color: color-mix(in oklab, var(--nve-ref-color-blue-cobalt-1100) 45%, transparent);\n --gradient-min-color: color-mix(in oklab, var(--nve-ref-color-blue-cobalt-1100), transparent 90%);\n \"\n ></nve-sparkline>\n `\n};\n"],"mappings":";AAGA,IAAA,IAAS"}
@@ -117,7 +117,9 @@
117
117
  "summary": "CSS custom properties are available to adjust dimensions and visual styling.",
118
118
  "description": "",
119
119
  "composition": false,
120
- "tags": []
120
+ "tags": [
121
+ "theme"
122
+ ]
121
123
  }
122
124
  ]
123
125
  }
@@ -21,7 +21,7 @@ var C = class extends _ {
21
21
  static {
22
22
  this.metadata = {
23
23
  tag: "nve-sparkline",
24
- version: "0.0.3"
24
+ version: "0.0.4"
25
25
  };
26
26
  }
27
27
  render() {
@@ -18,7 +18,7 @@ var l = class extends a {
18
18
  static {
19
19
  this.metadata = {
20
20
  tag: "nve-star-rating",
21
- version: "0.0.3"
21
+ version: "0.0.4"
22
22
  };
23
23
  }
24
24
  static {
@@ -23,7 +23,7 @@ var v = class extends r {
23
23
  static {
24
24
  this.metadata = {
25
25
  tag: "nve-steps-item",
26
- version: "0.0.3",
26
+ version: "0.0.4",
27
27
  parents: ["nve-steps"]
28
28
  };
29
29
  }
@@ -67,7 +67,7 @@ var y = class extends f {
67
67
  static {
68
68
  this.metadata = {
69
69
  tag: "nve-steps",
70
- version: "0.0.3",
70
+ version: "0.0.4",
71
71
  children: ["nve-steps-item"]
72
72
  };
73
73
  }
@@ -11,7 +11,7 @@ var a = class extends r {
11
11
  static {
12
12
  this.metadata = {
13
13
  tag: "nve-switch-group",
14
- version: "0.0.3",
14
+ version: "0.0.4",
15
15
  children: [
16
16
  "label",
17
17
  "nve-control-message",
@@ -15,7 +15,7 @@ var o = class extends i {
15
15
  static {
16
16
  this.metadata = {
17
17
  tag: "nve-switch",
18
- version: "0.0.3",
18
+ version: "0.0.4",
19
19
  children: [
20
20
  "label",
21
21
  "input",
@@ -1,7 +1,8 @@
1
- import { TabsItem, Tabs } from '.';
1
+ import { TabsGroup, TabsItem, Tabs } from '.';
2
2
  declare global {
3
3
  interface HTMLElementTagNameMap {
4
4
  'nve-tabs-item': TabsItem;
5
5
  'nve-tabs': Tabs;
6
+ 'nve-tabs-group': TabsGroup;
6
7
  }
7
8
  }
@@ -1,6 +1,7 @@
1
1
  import { define as e } from "../internal/utils/dom.js";
2
2
  import { Tabs as t, TabsItem as n } from "./tabs2.js";
3
- e(n), e(t);
3
+ import { TabsGroup as r } from "./tabs-group2.js";
4
+ e(n), e(t), e(r);
4
5
  //#endregion
5
6
 
6
7
  //# sourceMappingURL=define.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"define.js","names":[],"sources":["../../src/tabs/define.ts"],"sourcesContent":["// SPDX-FileCopyrightText: Copyright (c) 2026 NVIDIA CORPORATION & AFFILIATES. All rights reserved.\n// SPDX-License-Identifier: Apache-2.0\n\nimport { define } from '@nvidia-elements/core/internal';\nimport { TabsItem, Tabs } from '@nvidia-elements/core/tabs';\n\ndefine(TabsItem);\ndefine(Tabs);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'nve-tabs-item': TabsItem;\n 'nve-tabs': Tabs;\n }\n}\n"],"mappings":";;AAMA,EAAO,EAAS,EAChB,EAAO,EAAK"}
1
+ {"version":3,"file":"define.js","names":[],"sources":["../../src/tabs/define.ts"],"sourcesContent":["// SPDX-FileCopyrightText: Copyright (c) 2026 NVIDIA CORPORATION & AFFILIATES. All rights reserved.\n// SPDX-License-Identifier: Apache-2.0\n\nimport { define } from '@nvidia-elements/core/internal';\nimport { TabsGroup, TabsItem, Tabs } from '@nvidia-elements/core/tabs';\n\ndefine(TabsItem);\ndefine(Tabs);\ndefine(TabsGroup);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'nve-tabs-item': TabsItem;\n 'nve-tabs': Tabs;\n 'nve-tabs-group': TabsGroup;\n }\n}\n"],"mappings":";;;AAMA,EAAO,EAAS,EAChB,EAAO,EAAK,EACZ,EAAO,EAAU"}
@@ -1 +1,2 @@
1
1
  export * from './tabs.js';
2
+ export * from './tabs-group.js';
@@ -1,2 +1,3 @@
1
1
  import { Tabs as e, TabsItem as t } from "./tabs2.js";
2
- export { e as Tabs, t as TabsItem };
2
+ import { TabsGroup as n } from "./tabs-group2.js";
3
+ export { e as Tabs, n as TabsGroup, t as TabsItem };
@@ -0,0 +1,51 @@
1
+ import { PropertyValues, LitElement } from 'lit';
2
+ /** Arranges the tab strip and slot-matched panels: stacked column (`top`), or sidebar row with tabs at inline-start (`start`) or inline-end (`end`). */
3
+ export type TabsGroupAlignment = 'top' | 'start' | 'end';
4
+ /**
5
+ * @element nve-tabs-group
6
+ * @description Coordinates tabs with matching panel content using Invoker Commands and slot-matched panels.
7
+ * @since 1.67.0
8
+ * @entrypoint \@nvidia-elements/core/tabs
9
+ * @command --toggle - Select the matching tab and reveal the panel whose slot matches the invoker value.
10
+ * @event select - Dispatched when the selected tab value changes after an invoker `--toggle` updates selection
11
+ * @slot - Default slot for a single nve-tabs element. Do not use behavior-select on nve-tabs when using this group.
12
+ * @slot {value} - Named panel content where the slot name matches a nve-tabs-item value.
13
+ * @cssprop --padding
14
+ * @aria https://www.w3.org/WAI/ARIA/apg/patterns/tabs/
15
+ * @responsive false
16
+ */
17
+ export declare class TabsGroup extends LitElement {
18
+ #private;
19
+ static styles: import('lit').CSSResult[];
20
+ static readonly metadata: {
21
+ tag: string;
22
+ version: string;
23
+ children: string[];
24
+ };
25
+ /** Options for observing the slotted `nve-tabs` subtree (tab list / item attribute changes). */
26
+ protected static readonly subtreeObserverInit: {
27
+ readonly childList: true;
28
+ readonly subtree: true;
29
+ readonly attributes: true;
30
+ readonly attributeFilter: ["disabled", "id", "selected", "value"];
31
+ };
32
+ private defaultSlotElements;
33
+ /**
34
+ * Arranges the tab strip relative to slot-matched panels: stacked column (`top`), or sidebar row with tabs at
35
+ * inline-start (`start`) or inline-end (`end`) beside the panel region.
36
+ */
37
+ alignment: TabsGroupAlignment;
38
+ private panelValues;
39
+ private selectedValue;
40
+ /** @private */
41
+ _internals: ElementInternals;
42
+ /**
43
+ * Renders the default slot (single `nve-tabs`) plus one named `<slot name={value}>` per distinct selectable
44
+ * `nve-tabs-item` value. `#syncPanelSlot` applies panel visibility and ARIA from `selectedValue`.
45
+ */
46
+ render(): import('lit-html').TemplateResult<1>;
47
+ connectedCallback(): void;
48
+ firstUpdated(): void;
49
+ disconnectedCallback(): void;
50
+ updated(changedProperties: PropertyValues<this>): void;
51
+ }
@@ -0,0 +1,6 @@
1
+ //#region src/tabs/tabs-group.css?inline
2
+ var e = ":host{--padding: var(--nve-ref-space-sm) 0 0 0;display:block}:host(:is([alignment=\"start\"],[alignment=\"end\"])){--padding: 0}[internal-host]{display:flex;flex-direction:column}:host(:is([alignment=\"start\"],[alignment=\"end\"])) [internal-host]{flex-direction:row;align-items:flex-start;gap:var(--nve-ref-space-lg)}:host([alignment=\"end\"]) [internal-host]{flex-direction:row-reverse}:host(:is([alignment=\"start\"],[alignment=\"end\"])) [internal-host]>slot:not([name]){flex-shrink:0}:host(:is([alignment=\"start\"],[alignment=\"end\"])) [internal-host]>slot[name]{flex:1;min-width:0}::slotted([slot]){display:block;padding:var(--padding)}::slotted([slot][hidden]){display:none!important}";
3
+ //#endregion
4
+ export { e as default };
5
+
6
+ //# sourceMappingURL=tabs-group.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tabs-group.js","names":[],"sources":["../../src/tabs/tabs-group.css?inline"],"sourcesContent":["/* SPDX-FileCopyrightText: Copyright (c) 2026 NVIDIA CORPORATION & AFFILIATES. All rights reserved. */\n/* SPDX-License-Identifier: Apache-2.0 */\n\n:host {\n --padding: var(--nve-ref-space-sm) 0 0 0;\n display: block;\n}\n\n:host(:is([alignment='start'], [alignment='end'])) {\n --padding: 0;\n}\n\n[internal-host] {\n display: flex;\n flex-direction: column;\n}\n\n:host(:is([alignment='start'], [alignment='end'])) [internal-host] {\n flex-direction: row;\n align-items: flex-start;\n gap: var(--nve-ref-space-lg);\n}\n\n:host([alignment='end']) [internal-host] {\n flex-direction: row-reverse;\n}\n\n:host(:is([alignment='start'], [alignment='end'])) [internal-host] > slot:not([name]) {\n flex-shrink: 0;\n}\n\n:host(:is([alignment='start'], [alignment='end'])) [internal-host] > slot[name] {\n flex: 1;\n min-width: 0;\n}\n\n::slotted([slot]) {\n display: block;\n padding: var(--padding);\n}\n\n::slotted([slot][hidden]) {\n display: none !important;\n}\n"],"mappings":""}
@@ -0,0 +1,144 @@
1
+ import { generateId as e, sameOrderedStringArray as t, uniqueNonEmptyStrings as n } from "../internal/utils/dom.js";
2
+ import { attachInternals as r } from "../internal/utils/a11y.js";
3
+ import { __decorate as i } from "../_virtual/_@oxc-project_runtime@0.123.0/helpers/decorate.js";
4
+ import { audit as a } from "../internal/controllers/audit.controller.js";
5
+ import { useStyles as o } from "../internal/styles/index.js";
6
+ import { Tabs as s } from "./tabs2.js";
7
+ import c from "./tabs-group.js";
8
+ import { LitElement as l, html as u } from "lit";
9
+ import { property as d } from "lit/decorators/property.js";
10
+ import { state as f } from "lit/decorators/state.js";
11
+ import { queryAssignedElements as p } from "lit/decorators/query-assigned-elements.js";
12
+ //#region src/tabs/tabs-group.ts
13
+ var m, h = class extends l {
14
+ static {
15
+ m = this;
16
+ }
17
+ constructor(...e) {
18
+ super(...e), this.alignment = "top", this.panelValues = [], this.selectedValue = "";
19
+ }
20
+ static {
21
+ this.styles = o([c]);
22
+ }
23
+ static {
24
+ this.metadata = {
25
+ tag: "nve-tabs-group",
26
+ version: "0.0.4",
27
+ children: ["nve-tabs"]
28
+ };
29
+ }
30
+ static {
31
+ this.subtreeObserverInit = {
32
+ childList: !0,
33
+ subtree: !0,
34
+ attributes: !0,
35
+ attributeFilter: [
36
+ "disabled",
37
+ "id",
38
+ "selected",
39
+ "value"
40
+ ]
41
+ };
42
+ }
43
+ #e;
44
+ render() {
45
+ return u`<div internal-host><slot @slotchange="${this.#t}"></slot>${this.panelValues.map((e) => u`<slot name="${e}" @slotchange="${this.#n}"></slot>`)}</div>`;
46
+ }
47
+ connectedCallback() {
48
+ super.connectedCallback(), r(this), this._internals.role = "group", this.addEventListener("command", this.#r);
49
+ }
50
+ firstUpdated() {
51
+ this.updateComplete.then(() => {
52
+ this.isConnected && this.#a();
53
+ });
54
+ }
55
+ disconnectedCallback() {
56
+ super.disconnectedCallback(), this.removeEventListener("command", this.#r), this.#e?.disconnect();
57
+ }
58
+ updated(e) {
59
+ super.updated(e), this.#e || this.#i();
60
+ let t = e;
61
+ (t.has("panelValues") || t.has("selectedValue")) && this.#c();
62
+ }
63
+ #t = () => {
64
+ this.#i(), this.#a();
65
+ };
66
+ #n = () => {
67
+ this.#c();
68
+ };
69
+ #r = (e) => {
70
+ if (e.command !== "--toggle") return;
71
+ let t = e.source?.value;
72
+ if (typeof t != "string" || !t.length) return;
73
+ let n = this.#d(), r = n.find((e) => this.#p(e) && e.value === t);
74
+ r && this.#o(n, r, !0);
75
+ };
76
+ #i() {
77
+ this.#e?.disconnect();
78
+ let e = this.#u();
79
+ e && (this.#e = new MutationObserver(() => this.#a()), this.#e.observe(e, m.subtreeObserverInit));
80
+ }
81
+ #a() {
82
+ let e = this.#d(), t = n(e.map((e) => e.value)), r = this.#m(e);
83
+ if (!r) {
84
+ e.forEach((e) => e.selected = !1), this.#s(t, "");
85
+ return;
86
+ }
87
+ this.#o(e, r, !1, t);
88
+ }
89
+ #o(e, t, r, i = n(e.map((e) => e.value))) {
90
+ let a = this.selectedValue !== t.value || !t.selected || e.some((e) => e !== t && e.selected);
91
+ e.forEach((e) => {
92
+ e.selected = e === t;
93
+ }), this.#s(i, t.value), r && a && this.dispatchEvent(new CustomEvent("select", {
94
+ bubbles: !0,
95
+ composed: !0,
96
+ detail: { value: t.value }
97
+ }));
98
+ }
99
+ #s(e, n) {
100
+ t(this.panelValues, e) || (this.panelValues = e), this.selectedValue !== n && (this.selectedValue = n);
101
+ }
102
+ #c() {
103
+ let e = this.#d(), t = new Map(e.filter((e) => this.#p(e)).map((e) => [e.value, e]));
104
+ this.#f().forEach((e) => {
105
+ this.#l(e, t);
106
+ });
107
+ }
108
+ #l(t, n) {
109
+ let r = n.get(t.name), i = t.assignedElements({ flatten: !0 });
110
+ if (!r) {
111
+ i.forEach((e) => {
112
+ e.hidden = !0;
113
+ });
114
+ return;
115
+ }
116
+ r.id ||= e(), i.forEach((n, i) => {
117
+ n.id ||= e(), !r.hasAttribute("aria-controls") && i === 0 && r.setAttribute("aria-controls", n.id), n.hasAttribute("aria-labelledby") || n.setAttribute("aria-labelledby", r.id), n.hasAttribute("role") || n.setAttribute("role", "tabpanel"), n.hidden = t.name !== this.selectedValue;
118
+ });
119
+ }
120
+ #u() {
121
+ let e = this.defaultSlotElements.find((e) => e.localName === s.metadata.tag) ?? this.querySelector(s.metadata.tag);
122
+ return e instanceof s ? e : void 0;
123
+ }
124
+ #d() {
125
+ return Array.from(this.#u()?.querySelectorAll("nve-tabs-item") ?? []);
126
+ }
127
+ #f() {
128
+ return Array.from(this.renderRoot.querySelectorAll("slot[name]"));
129
+ }
130
+ #p(e) {
131
+ return typeof e.value == "string" && e.value.length > 0 && !e.disabled;
132
+ }
133
+ #m(e) {
134
+ return e.find((e) => this.#p(e) && e.selected) ?? e.find((e) => this.#p(e));
135
+ }
136
+ };
137
+ i([p({ flatten: !0 })], h.prototype, "defaultSlotElements", void 0), i([d({
138
+ type: String,
139
+ reflect: !0
140
+ })], h.prototype, "alignment", void 0), i([f()], h.prototype, "panelValues", void 0), i([f()], h.prototype, "selectedValue", void 0), h = m = i([a()], h);
141
+ //#endregion
142
+ export { h as TabsGroup };
143
+
144
+ //# sourceMappingURL=tabs-group2.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tabs-group2.js","names":["#handleDefaultSlotChange","#handlePanelSlotChange","#handleCommand","#syncFromTabs","#tabsObserver","#observeTabs","#syncPanels","#getTabItems","#isSelectableTab","#setActiveTab","#getTabsElement","#resolveSelectedTab","#commitState","#getPanelSlots","#syncPanelSlot"],"sources":["../../src/tabs/tabs-group.ts"],"sourcesContent":["// SPDX-FileCopyrightText: Copyright (c) 2026 NVIDIA CORPORATION & AFFILIATES. All rights reserved.\n// SPDX-License-Identifier: Apache-2.0\n\nimport type { PropertyValues } from 'lit';\nimport { html, LitElement } from 'lit';\nimport { property } from 'lit/decorators/property.js';\nimport { queryAssignedElements } from 'lit/decorators/query-assigned-elements.js';\nimport { state } from 'lit/decorators/state.js';\nimport {\n attachInternals,\n audit,\n generateId,\n sameOrderedStringArray,\n uniqueNonEmptyStrings,\n useStyles\n} from '@nvidia-elements/core/internal';\nimport { Tabs, type TabsItem } from './tabs.js';\nimport styles from './tabs-group.css?inline';\n\n/** Invoker command source for `--toggle` (e.g. `nve-tabs-item` with `value`). */\ntype TabsGroupCommandSource = HTMLElement & {\n disabled?: boolean;\n value?: string | null;\n};\n\n/** `command` event from Invoker Commands; `source` is the control that fired. */\ntype TabsGroupCommandEvent = Event & {\n command?: string;\n source?: TabsGroupCommandSource | null;\n};\n\n/** Payload for the composed `select` event when the active tab value changes via command. */\ntype TabsGroupSelectDetail = { value: string };\n\n/** Arranges the tab strip and slot-matched panels: stacked column (`top`), or sidebar row with tabs at inline-start (`start`) or inline-end (`end`). */\nexport type TabsGroupAlignment = 'top' | 'start' | 'end';\n\n/**\n * @element nve-tabs-group\n * @description Coordinates tabs with matching panel content using Invoker Commands and slot-matched panels.\n * @since 1.67.0\n * @entrypoint \\@nvidia-elements/core/tabs\n * @command --toggle - Select the matching tab and reveal the panel whose slot matches the invoker value.\n * @event select - Dispatched when the selected tab value changes after an invoker `--toggle` updates selection\n * @slot - Default slot for a single nve-tabs element. Do not use behavior-select on nve-tabs when using this group.\n * @slot {value} - Named panel content where the slot name matches a nve-tabs-item value.\n * @cssprop --padding\n * @aria https://www.w3.org/WAI/ARIA/apg/patterns/tabs/\n * @responsive false\n */\n@audit()\nexport class TabsGroup extends LitElement {\n static styles = useStyles([styles]);\n\n static readonly metadata = {\n tag: 'nve-tabs-group',\n version: '0.0.0',\n children: ['nve-tabs']\n };\n\n /** Options for observing the slotted `nve-tabs` subtree (tab list / item attribute changes). */\n protected static readonly subtreeObserverInit = {\n childList: true,\n subtree: true,\n attributes: true,\n attributeFilter: ['disabled', 'id', 'selected', 'value']\n } as const satisfies MutationObserverInit;\n\n @queryAssignedElements({ flatten: true }) private defaultSlotElements!: HTMLElement[];\n\n /**\n * Arranges the tab strip relative to slot-matched panels: stacked column (`top`), or sidebar row with tabs at\n * inline-start (`start`) or inline-end (`end`) beside the panel region.\n */\n @property({ type: String, reflect: true }) alignment: TabsGroupAlignment = 'top';\n\n @state() private panelValues: string[] = [];\n\n @state() private selectedValue = '';\n\n /** @private */\n declare _internals: ElementInternals;\n\n #tabsObserver?: MutationObserver;\n\n /**\n * Renders the default slot (single `nve-tabs`) plus one named `<slot name={value}>` per distinct selectable\n * `nve-tabs-item` value. `#syncPanelSlot` applies panel visibility and ARIA from `selectedValue`.\n */\n render() {\n return html`\n <div internal-host>\n <slot @slotchange=${this.#handleDefaultSlotChange}></slot>\n ${this.panelValues.map(value => html`<slot name=${value} @slotchange=${this.#handlePanelSlotChange}></slot>`)}\n </div>\n `;\n }\n\n // --- Lifecycle & command ---\n\n connectedCallback() {\n super.connectedCallback();\n attachInternals(this);\n this._internals.role = 'group';\n this.addEventListener('command', this.#handleCommand as EventListener);\n }\n\n firstUpdated() {\n void this.updateComplete.then(() => {\n if (!this.isConnected) {\n return;\n }\n\n this.#syncFromTabs();\n });\n }\n\n disconnectedCallback() {\n super.disconnectedCallback();\n this.removeEventListener('command', this.#handleCommand as EventListener);\n this.#tabsObserver?.disconnect();\n }\n\n updated(changedProperties: PropertyValues<this>) {\n super.updated(changedProperties);\n\n if (!this.#tabsObserver) {\n this.#observeTabs();\n }\n\n // `@state()` fields are not in `PropertyValues<this>` keys; cast for membership checks.\n const props = changedProperties as ReadonlyMap<PropertyKey, unknown>;\n if (props.has('panelValues') || props.has('selectedValue')) {\n this.#syncPanels();\n }\n }\n\n #handleDefaultSlotChange = (): void => {\n this.#observeTabs();\n this.#syncFromTabs();\n };\n\n #handlePanelSlotChange = (): void => {\n this.#syncPanels();\n };\n\n /**\n * Handles Invoker `--toggle` on a tab item: selects the matching `nve-tabs-item` and syncs panels.\n * Ignores non-toggle commands and invokers without a non-empty string `value`.\n */\n #handleCommand = (event: TabsGroupCommandEvent): void => {\n if (event.command !== '--toggle') {\n return;\n }\n\n const value = event.source?.value;\n if (typeof value !== 'string' || !value.length) {\n return;\n }\n\n const tabItems = this.#getTabItems();\n const tabItem = tabItems.find(item => this.#isSelectableTab(item) && item.value === value);\n if (!tabItem) {\n return;\n }\n\n this.#setActiveTab(tabItems, tabItem, true);\n };\n\n // --- Tab strip sync (tabs → state) ---\n\n /** Attaches a single `MutationObserver` on the slotted `nve-tabs` element to mirror tab list changes into state. */\n #observeTabs(): void {\n this.#tabsObserver?.disconnect();\n\n const tabs = this.#getTabsElement();\n if (!tabs) {\n return;\n }\n\n this.#tabsObserver = new MutationObserver(() => this.#syncFromTabs());\n this.#tabsObserver.observe(tabs, TabsGroup.subtreeObserverInit);\n }\n\n /**\n * Reads the current tab items: derives ordered `panelValues` for render, resolves which tab should be active,\n * and commits selection. Called on slot change, subtree mutations, and after mount.\n */\n #syncFromTabs(): void {\n const tabItems = this.#getTabItems();\n const nextPanelValues = uniqueNonEmptyStrings(tabItems.map(item => item.value));\n\n const selectedTab = this.#resolveSelectedTab(tabItems);\n\n if (!selectedTab) {\n tabItems.forEach(item => (item.selected = false));\n this.#commitState(nextPanelValues, '');\n return;\n }\n\n this.#setActiveTab(tabItems, selectedTab, false, nextPanelValues);\n }\n\n /**\n * Sets exactly one selected tab, updates `panelValues` / `selectedValue`, and optionally dispatches `select`.\n *\n * @param emitEvent - When true (command path), dispatches `select` if selection actually changed.\n */\n #setActiveTab(\n tabItems: TabsItem[],\n nextTab: TabsItem,\n emitEvent: boolean,\n nextPanelValues: string[] = uniqueNonEmptyStrings(tabItems.map(item => item.value))\n ): void {\n // True when the effective selection differs from the prior committed state (value, flags, or multi-select).\n // `select` is only dispatched when both `emitEvent` (invoker/command path) and `changed` are true.\n const changed =\n this.selectedValue !== nextTab.value ||\n !nextTab.selected ||\n tabItems.some(item => item !== nextTab && item.selected);\n\n tabItems.forEach(item => {\n item.selected = item === nextTab;\n });\n\n this.#commitState(nextPanelValues, nextTab.value);\n\n if (emitEvent && changed) {\n this.dispatchEvent(\n new CustomEvent<TabsGroupSelectDetail>('select', {\n bubbles: true,\n composed: true,\n detail: { value: nextTab.value }\n })\n );\n }\n }\n\n /** Updates reactive state for panel slot names and the active tab value without touching the tab items. */\n #commitState(nextPanelValues: string[], nextSelectedValue: string): void {\n if (!sameOrderedStringArray(this.panelValues, nextPanelValues)) {\n this.panelValues = nextPanelValues;\n }\n\n if (this.selectedValue !== nextSelectedValue) {\n this.selectedValue = nextSelectedValue;\n }\n }\n\n // --- Panel sync (state → panels & ARIA) ---\n\n /** For each named panel slot, wires `hidden` and tab↔panel ARIA ids to match `selectedValue`. */\n #syncPanels(): void {\n const tabItems = this.#getTabItems();\n const tabMap = new Map(\n tabItems.filter(item => this.#isSelectableTab(item)).map(item => [item.value, item] satisfies [string, TabsItem])\n );\n\n this.#getPanelSlots().forEach(slot => {\n this.#syncPanelSlot(slot, tabMap);\n });\n }\n\n /**\n * If no selectable tab exists for `slot.name`, hides all assigned nodes. Otherwise shows only the panel(s)\n * for the active value and assigns `role=\"tabpanel\"` / `aria-labelledby` when missing.\n */\n #syncPanelSlot(slot: HTMLSlotElement, tabMap: ReadonlyMap<string, TabsItem>): void {\n const tabItem = tabMap.get(slot.name);\n const panels = slot.assignedElements({ flatten: true }) as HTMLElement[];\n\n if (!tabItem) {\n panels.forEach(panel => {\n panel.hidden = true;\n });\n return;\n }\n\n tabItem.id ||= generateId();\n\n panels.forEach((panel, index) => {\n panel.id ||= generateId();\n\n if (!tabItem.hasAttribute('aria-controls') && index === 0) {\n tabItem.setAttribute('aria-controls', panel.id);\n }\n\n if (!panel.hasAttribute('aria-labelledby')) {\n panel.setAttribute('aria-labelledby', tabItem.id);\n }\n\n if (!panel.hasAttribute('role')) {\n panel.setAttribute('role', 'tabpanel');\n }\n\n const isActive = slot.name === this.selectedValue;\n panel.hidden = !isActive;\n });\n }\n\n // --- DOM queries ---\n\n /** Resolves the single slotted `nve-tabs` (default slot), with a light-DOM fallback for edge timing. */\n #getTabsElement(): Tabs | undefined {\n const el =\n this.defaultSlotElements.find(element => element.localName === Tabs.metadata.tag) ??\n this.querySelector(Tabs.metadata.tag);\n return el instanceof Tabs ? el : undefined;\n }\n\n #getTabItems(): TabsItem[] {\n return Array.from(this.#getTabsElement()?.querySelectorAll<TabsItem>('nve-tabs-item') ?? []);\n }\n\n #getPanelSlots(): HTMLSlotElement[] {\n return Array.from(this.renderRoot.querySelectorAll<HTMLSlotElement>('slot[name]'));\n }\n\n /** Selectable tabs have a non-empty `value` and are not `disabled`. */\n #isSelectableTab(tabItem: TabsItem): tabItem is TabsItem & { value: string } {\n return typeof tabItem.value === 'string' && tabItem.value.length > 0 && !tabItem.disabled;\n }\n\n /** Prefer the selectable tab that is already selected; otherwise the first selectable tab. */\n #resolveSelectedTab(tabItems: readonly TabsItem[]): TabsItem | undefined {\n return (\n tabItems.find(item => this.#isSelectableTab(item) && item.selected) ??\n tabItems.find(item => this.#isSelectableTab(item))\n );\n }\n}\n"],"mappings":"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"}