@nvidia-elements/core 0.0.8 → 0.0.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +15 -0
- package/dist/accordion/accordion2.js +4 -4
- package/dist/alert/alert-group2.js +1 -1
- package/dist/alert/alert2.js +1 -1
- package/dist/avatar/avatar-group2.js +1 -1
- package/dist/avatar/avatar2.js +1 -1
- package/dist/badge/badge.js +1 -1
- package/dist/badge/badge.js.map +1 -1
- package/dist/badge/badge2.js +1 -1
- package/dist/breadcrumb/breadcrumb.js +1 -1
- package/dist/breadcrumb/breadcrumb.js.map +1 -1
- package/dist/breadcrumb/breadcrumb2.js +1 -1
- package/dist/bundles/index.d.ts +3 -2
- package/dist/bundles/index.js +2 -2
- package/dist/button/button2.js +1 -1
- package/dist/button-group/button-group2.js +1 -1
- package/dist/card/card-content.js +1 -1
- package/dist/card/card-content.js.map +1 -1
- package/dist/card/card-header.js +1 -1
- package/dist/card/card-header.js.map +1 -1
- package/dist/card/card2.js +4 -4
- package/dist/chat-message/chat-message2.js +1 -1
- package/dist/checkbox/checkbox-group2.js +1 -1
- package/dist/checkbox/checkbox2.js +1 -1
- package/dist/color/color2.js +1 -1
- package/dist/combobox/combobox.examples.js.map +1 -1
- package/dist/combobox/combobox2.js +1 -1
- package/dist/copy-button/copy-button2.js +1 -1
- package/dist/copy-button/copy-button2.js.map +1 -1
- package/dist/custom-elements-jsx.d.ts +4 -2
- package/dist/custom-elements-vue.d.ts +4 -2
- package/dist/custom-elements.json +28 -12
- package/dist/data.html.json +6 -4
- package/dist/date/date2.js +1 -1
- package/dist/datetime/datetime2.js +1 -1
- package/dist/dialog/dialog-footer2.js +1 -1
- package/dist/dialog/dialog-header2.js +1 -1
- package/dist/dialog/dialog2.js +1 -1
- package/dist/divider/divider2.js +1 -1
- package/dist/dot/dot2.js +1 -1
- package/dist/drawer/drawer-content2.js +1 -1
- package/dist/drawer/drawer-footer2.js +1 -1
- package/dist/drawer/drawer-header2.js +1 -1
- package/dist/drawer/drawer2.js +1 -1
- package/dist/dropdown/dropdown-footer2.js +1 -1
- package/dist/dropdown/dropdown-header2.js +1 -1
- package/dist/dropdown/dropdown2.js +1 -1
- package/dist/dropdown-group/dropdown-group.js +1 -1
- package/dist/dropdown-group/dropdown-group.js.map +1 -1
- package/dist/dropzone/dropzone.util.js +4 -1
- package/dist/dropzone/dropzone.util.js.map +1 -1
- package/dist/dropzone/dropzone2.js +1 -1
- package/dist/file/file2.js +1 -1
- package/dist/format-datetime/format-datetime2.js +1 -1
- package/dist/format-relative-time/format-relative-time2.js +1 -1
- package/dist/forms/control/control2.js +1 -1
- package/dist/forms/control-group/control-group2.js +1 -1
- package/dist/forms/control-message/control-message2.js +1 -1
- package/dist/forms/utils/states.js.map +1 -1
- package/dist/grid/cell/cell2.js +1 -1
- package/dist/grid/column/column2.js +1 -1
- package/dist/grid/footer/footer2.js +1 -1
- package/dist/grid/grid.examples.js.map +1 -1
- package/dist/grid/grid.examples.json +2 -2
- package/dist/grid/grid2.js +1 -1
- package/dist/grid/header/header2.js +1 -1
- package/dist/grid/placeholder/placeholder2.js +1 -1
- package/dist/grid/row/row2.js +1 -1
- package/dist/icon/icon2.js +2 -2
- package/dist/icon/icons/stop.js +6 -0
- package/dist/icon/icons/stop.js.map +1 -0
- package/dist/icon/icons.d.ts +1 -0
- package/dist/icon/icons.js +1 -0
- package/dist/icon/icons.js.map +1 -1
- package/dist/icon/server.js +1 -0
- package/dist/icon/server.js.map +1 -1
- package/dist/icon-button/icon-button2.js +1 -1
- package/dist/index.js +1 -1
- package/dist/input/input-group2.js +1 -1
- package/dist/input/input2.js +1 -1
- package/dist/internal/controllers/audit.controller.js.map +1 -1
- package/dist/internal/controllers/type-native-popover.controller.js.map +1 -1
- package/dist/internal/controllers/type-ssr.controller.js.map +1 -1
- package/dist/internal/services/global.service.js +1 -1
- package/dist/internal/services/i18n.service.d.ts +1 -1
- package/dist/internal/services/i18n.service.js.map +1 -1
- package/dist/logo/logo2.js +1 -1
- package/dist/menu/menu-item2.js +1 -1
- package/dist/menu/menu2.js +1 -1
- package/dist/month/month2.js +1 -1
- package/dist/notification/notification-group2.js +1 -1
- package/dist/notification/notification2.js +1 -1
- package/dist/page/page-panel/page-panel-content2.js +1 -1
- package/dist/page/page-panel/page-panel-footer2.js +1 -1
- package/dist/page/page-panel/page-panel-header2.js +1 -1
- package/dist/page/page-panel/page-panel2.js +1 -1
- package/dist/page/page2.js +1 -1
- package/dist/page-header/page-header2.js +1 -1
- package/dist/page-loader/page-loader2.js +1 -1
- package/dist/pagination/pagination2.js +1 -1
- package/dist/panel/panel2.js +4 -4
- package/dist/password/password2.js +1 -1
- package/dist/polyfills/index.js +2 -1
- package/dist/polyfills/index.js.map +1 -1
- package/dist/preferences-input/preferences-input2.js +1 -1
- package/dist/preferences-input/preferences-input2.js.map +1 -1
- package/dist/progress-bar/progress-bar.examples.js.map +1 -1
- package/dist/progress-bar/progress-bar.examples.json +1 -1
- package/dist/progress-bar/progress-bar2.js +1 -1
- package/dist/progress-ring/progress-ring2.js +1 -1
- package/dist/progressive-filter-chip/progressive-filter-chip2.js +1 -1
- package/dist/pulse/pulse2.js +1 -1
- package/dist/radio/radio-group2.js +1 -1
- package/dist/radio/radio2.js +1 -1
- package/dist/range/range2.js +1 -1
- package/dist/resize-handle/resize-handle2.js +1 -1
- package/dist/search/search2.js +1 -1
- package/dist/select/select2.js +1 -1
- package/dist/skeleton/skeleton.d.ts +2 -2
- package/dist/skeleton/skeleton2.js +1 -1
- package/dist/skeleton/skeleton2.js.map +1 -1
- package/dist/sort-button/sort-button2.js +1 -1
- package/dist/sparkline/sparkline2.js +1 -1
- package/dist/star-rating/star-rating2.js +1 -1
- package/dist/steps/steps2.js +2 -2
- package/dist/switch/switch-group2.js +1 -1
- package/dist/switch/switch2.js +1 -1
- package/dist/tabs/tabs-group2.js +1 -1
- package/dist/tabs/tabs2.js +2 -2
- package/dist/tag/tag2.js +1 -1
- package/dist/textarea/textarea2.js +1 -1
- package/dist/time/time2.js +1 -1
- package/dist/toast/toast2.js +1 -1
- package/dist/toggletip/toggletip-footer2.js +1 -1
- package/dist/toggletip/toggletip-header2.js +1 -1
- package/dist/toggletip/toggletip2.js +1 -1
- package/dist/toolbar/toolbar.js +1 -1
- package/dist/toolbar/toolbar.js.map +1 -1
- package/dist/toolbar/toolbar2.js +1 -1
- package/dist/tooltip/tooltip2.js +1 -1
- package/dist/tree/tree-node.js +1 -1
- package/dist/tree/tree-node.js.map +1 -1
- package/dist/tree/tree-node2.js +1 -1
- package/dist/tree/tree2.js +1 -1
- package/dist/tree/utils.js.map +1 -1
- package/dist/week/week2.js +1 -1
- package/package.json +2 -2
package/dist/button/button2.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
//#region src/card/card-content.css?inline
|
|
2
|
-
var e = ":host{--padding: var(--nve-ref-size-
|
|
2
|
+
var e = ":host{--padding: var(--nve-ref-size-400);padding:var(--padding);color:var(--color);flex-grow:1;contain:initial}";
|
|
3
3
|
//#endregion
|
|
4
4
|
export { e as default };
|
|
5
5
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"card-content.js","names":[],"sources":["../../src/card/card-content.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-size-
|
|
1
|
+
{"version":3,"file":"card-content.js","names":[],"sources":["../../src/card/card-content.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-size-400);\n padding: var(--padding);\n color: var(--color);\n flex-grow: 1;\n contain: initial;\n}\n"],"mappings":""}
|
package/dist/card/card-header.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
//#region src/card/card-header.css?inline
|
|
2
|
-
var e = ":host{--padding: var(--nve-ref-size-
|
|
2
|
+
var e = ":host{--padding: var(--nve-ref-size-400);--border-bottom: var(--nve-ref-border-width-sm) solid var(--nve-ref-border-color-muted);--line-height: 1em;--gap: var(--nve-ref-space-xs);contain:none}[internal-host]{padding:var(--padding);border-bottom:var(--border-bottom);color:var(--color);display:flex;flex-direction:row;justify-content:space-between;align-items:center}.content{display:flex;flex-direction:column;gap:var(--gap);width:100%}::slotted([slot=\"title\"]){font-size:var(--nve-ref-font-size-200);font-weight:var(--nve-ref-font-weight-bold)}::slotted([slot=\"subtitle\"]){margin:0;font-size:var(--nve-ref-font-size-100);font-weight:var(--nve-ref-font-weight-regular)}::slotted(nve-tabs){margin-block-end:calc(-1 * var(--padding))}";
|
|
3
3
|
//#endregion
|
|
4
4
|
export { e as default };
|
|
5
5
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"card-header.js","names":[],"sources":["../../src/card/card-header.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-size-
|
|
1
|
+
{"version":3,"file":"card-header.js","names":[],"sources":["../../src/card/card-header.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-size-400);\n --border-bottom: var(--nve-ref-border-width-sm) solid var(--nve-ref-border-color-muted);\n --line-height: 1em;\n --gap: var(--nve-ref-space-xs);\n contain: none;\n}\n\n[internal-host] {\n padding: var(--padding);\n border-bottom: var(--border-bottom);\n color: var(--color);\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n align-items: center;\n}\n\n.content {\n display: flex;\n flex-direction: column;\n gap: var(--gap);\n width: 100%;\n}\n\n::slotted([slot='title']) {\n font-size: var(--nve-ref-font-size-200);\n font-weight: var(--nve-ref-font-weight-bold);\n}\n\n::slotted([slot='subtitle']) {\n margin: 0;\n font-size: var(--nve-ref-font-size-100);\n font-weight: var(--nve-ref-font-weight-regular);\n}\n\n::slotted(nve-tabs) {\n margin-block-end: calc(-1 * var(--padding));\n}\n"],"mappings":""}
|
package/dist/card/card2.js
CHANGED
|
@@ -16,7 +16,7 @@ var d = class extends c {
|
|
|
16
16
|
static {
|
|
17
17
|
this.metadata = {
|
|
18
18
|
tag: "nve-card",
|
|
19
|
-
version: "0.0.
|
|
19
|
+
version: "0.0.10"
|
|
20
20
|
};
|
|
21
21
|
}
|
|
22
22
|
render() {
|
|
@@ -37,7 +37,7 @@ var f = class extends c {
|
|
|
37
37
|
static {
|
|
38
38
|
this.metadata = {
|
|
39
39
|
tag: "nve-card-header",
|
|
40
|
-
version: "0.0.
|
|
40
|
+
version: "0.0.10",
|
|
41
41
|
parents: ["nve-card"]
|
|
42
42
|
};
|
|
43
43
|
}
|
|
@@ -53,7 +53,7 @@ var p = class extends c {
|
|
|
53
53
|
static {
|
|
54
54
|
this.metadata = {
|
|
55
55
|
tag: "nve-card-content",
|
|
56
|
-
version: "0.0.
|
|
56
|
+
version: "0.0.10",
|
|
57
57
|
parents: ["nve-card"]
|
|
58
58
|
};
|
|
59
59
|
}
|
|
@@ -72,7 +72,7 @@ var m = class extends c {
|
|
|
72
72
|
static {
|
|
73
73
|
this.metadata = {
|
|
74
74
|
tag: "nve-card-footer",
|
|
75
|
-
version: "0.0.
|
|
75
|
+
version: "0.0.10",
|
|
76
76
|
parents: ["nve-card"]
|
|
77
77
|
};
|
|
78
78
|
}
|
package/dist/color/color2.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"combobox.examples.js","names":["#unusedFilters","#removeFilter","#createfilter","#updateFilter","#addFilter","#valueChange"],"sources":["../../src/combobox/combobox.examples.ts"],"sourcesContent":["// SPDX-FileCopyrightText: Copyright (c) 2026 NVIDIA CORPORATION & AFFILIATES. All rights reserved.\n// SPDX-License-Identifier: Apache-2.0\n\nimport { html, LitElement, unsafeCSS } from 'lit';\nimport { property } from 'lit/decorators/property.js';\nimport { state } from 'lit/decorators/state.js';\nimport { choose } from 'lit/directives/choose.js';\nimport '@nvidia-elements/core/progressive-filter-chip/define.js';\nimport '@nvidia-elements/core/combobox/define.js';\nimport '@nvidia-elements/core/icon/define.js';\nimport '@nvidia-elements/core/tag/define.js';\nimport '@nvidia-elements/core/date/define.js';\nimport '@nvidia-elements/core/select/define.js';\nimport '@nvidia-elements/core/input/define.js';\nimport '@nvidia-elements/core/dropdown/define.js';\n\nexport default {\n title: 'Elements/Combobox',\n component: 'nve-combobox',\n};\n\n/**\n * @summary Basic combobox with search input and datalist options for filtering and selection.\n */\nexport const Default = () => {\n return html`\n <nve-combobox>\n <label>label</label>\n <input type=\"search\">\n <datalist>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </datalist>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n `\n};\n\n/**\n * @summary Vertical layout showing different combobox states (normal, disabled, success, error) stacked for comparison.\n * @tags test-case\n */\nexport const Vertical = () => {\n return html`\n<div nve-layout=\"column gap:lg full\">\n <nve-combobox>\n <label>label</label>\n <input type=\"search\" />\n <datalist>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </datalist>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n\n <nve-combobox>\n <label>disabled</label>\n <input type=\"search\" disabled />\n <datalist>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </datalist>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n\n <nve-combobox>\n <label>success</label>\n <input type=\"search\" />\n <datalist>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </datalist>\n <nve-control-message status=\"success\">message</nve-control-message>\n </nve-combobox>\n\n <nve-combobox>\n <label>error</label>\n <input type=\"search\" />\n <datalist>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </datalist>\n <nve-control-message status=\"error\">message</nve-control-message>\n </nve-combobox>\n</div>`\n};\n\n/**\n * @summary Horizontal layout showing different combobox states (normal, disabled, success, error) for inline form layouts.\n */\nexport const Horizontal = () => {\n return html`\n<div nve-layout=\"column gap:lg full\">\n <nve-combobox layout=\"horizontal\">\n <label>label</label>\n <input type=\"search\" />\n <datalist>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </datalist>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n\n <nve-combobox layout=\"horizontal\">\n <label>disabled</label>\n <input type=\"search\" disabled />\n <datalist>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </datalist>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n\n <nve-combobox layout=\"horizontal\">\n <label>success</label>\n <input type=\"search\" />\n <datalist>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </datalist>\n <nve-control-message status=\"success\">message</nve-control-message>\n </nve-combobox>\n\n <nve-combobox layout=\"horizontal\">\n <label>error</label>\n <input type=\"search\" />\n <datalist>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </datalist>\n <nve-control-message status=\"error\">message</nve-control-message>\n </nve-combobox>\n</div>`\n};\n\n/**\n * @summary Flat container style with prefix icon for compact inline filtering interfaces.\n */\nexport const Flat = () => {\n return html`\n <nve-combobox container=\"flat\">\n <nve-icon name=\"filter\" slot=\"prefix-icon\"></nve-icon>\n <input type=\"search\" aria-label=\"search\">\n <datalist>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </datalist>\n </nve-combobox>\n `\n};\n\n/**\n * @summary Single select allows users only to select from a predefined list\n * of options. Invalid input is automatically cleared. All options are visible\n * on focus until typing begins for filtering.\n */\nexport const Select = () => {\n return html`\n<nve-combobox>\n <label>label</label>\n <input type=\"search\">\n <select>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </select>\n <nve-control-message>message</nve-control-message>\n</nve-combobox>\n `\n};\n\n/**\n * @summary Multi select allows users to select many options from a\n * predefined list. The select `value` will only reflect the first selected value.\n * To get all selected options check the `selected` property on each `<option>`\n * or the select property `selectedOptions`.\n * On focus all options will show until the user starts typing. Select is the\n * selection value of the combobox. The input is the filter value.\n */\nexport const MultiSelect = () => {\n return html`\n <nve-combobox>\n <label>label</label>\n <input type=\"search\">\n <select multiple>\n <option selected value=\"status\"></option>\n <option selected value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </select>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n `\n};\n\n/**\n * @summary Combobox with an empty initial value using a disabled placeholder option. Use when no default selection exists and the user must make an explicit choice.\n */\nexport const EmptyDefault = () => {\n return html`\n<nve-combobox>\n <label>label</label>\n <input type=\"search\">\n <select>\n <option disabled selected></option>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </select>\n <nve-control-message>message</nve-control-message>\n</nve-combobox>\n `\n};\n\n/**\n * @summary Combobox options with display labels that differ from underlying values. Use when option values are IDs or codes but users need to see human-readable text in the input.\n */\nexport const Label = () => {\n return html`\n <nve-combobox>\n <label>label</label>\n <input type=\"search\">\n <select>\n <option value=\"1\">Status</option>\n <option value=\"2\">Priority</option>\n <option value=\"3\">Date</option>\n <option value=\"4\">Session</option>\n <option value=\"5\">Configuration</option>\n <option value=\"6\">Contains</option>\n </select>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n `\n};\n\n/**\n * @summary Multi-select with labeled options where display text differs from option values.\n */\nexport const LabelMultiSelect = () => {\n return html`\n <nve-combobox>\n <label>label</label>\n <input type=\"search\">\n <select multiple>\n <option value=\"1\">Status</option>\n <option value=\"2\">Priority</option>\n <option value=\"3\">Date</option>\n <option value=\"4\">Session</option>\n <option value=\"5\">Configuration</option>\n <option value=\"6\">Contains</option>\n </select>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n `\n};\n\n/**\n * @summary Overflow behavior where many tags collapse into a simple text label when the parent container is too narrow.\n * @tags test-case\n */\nexport const Overflow = () => {\n return html`\n <nve-combobox style=\"width: 250px\">\n <label>label</label>\n <input type=\"search\">\n <select multiple>\n <option selected value=\"status\"></option>\n <option selected value=\"priority\"></option>\n <option selected value=\"date\"></option>\n <option selected value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </select>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n `\n};\n\n/**\n * @summary Combobox handling of long option text in constrained width containers.\n * @tags test-case\n */\nexport const PopoverOverflow = () => {\n return html`\n <nve-combobox style=\"width: 100px\">\n <label>label</label>\n <input type=\"search\">\n <select>\n <option value=\"really-long-text-option-that-keeps-going\"></option> \n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </select>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n `\n};\n\n/**\n * @summary Multi-select with reset functionality via icon button and footer button to clear all selections.\n */\nexport const Reset = () => {\n return html`\n <nve-combobox id=\"combobox-reset\" style=\"width: 500px; --scroll-height: 220px\">\n <label>label</label>\n <input type=\"search\">\n <select multiple>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </select>\n <nve-icon-button aria-label=\"clear selection\" icon-name=\"cancel\" container=\"inline\"></nve-icon-button>\n <nve-button slot=\"footer\" aria-label=\"clear selection\" container=\"flat\">reset</nve-button>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n <script type=\"module\">\n document.querySelector('#combobox-reset nve-icon-button').addEventListener('click', e => e.target.parentElement.reset());\n document.querySelector('#combobox-reset nve-button').addEventListener('click', e => e.target.parentElement.reset());\n </script>\n `\n};\n\n/**\n * @summary Multi-select with footer action button for extra operations on selected items.\n */\nexport const Footer = () => {\n return html`\n <nve-combobox style=\"width: 500px; --scroll-height: 200px\">\n <label>label</label>\n <input type=\"search\">\n <select multiple>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n <option value=\"includes\"></option>\n <option value=\"user\"></option>\n <option value=\"progress\"></option>\n </select>\n <nve-button slot=\"footer\" container=\"flat\">action</nve-button>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n `\n};\n\n/**\n * @summary Multi-select with bulk selection controls (Select All/Deselect All) in footer for efficient mass operations.\n */\nexport const SelectAll = () => {\n return html`\n <nve-combobox id=\"combobox-select-all\" style=\"width: 500px; --scroll-height: 200px\">\n <label>label</label>\n <input type=\"search\">\n <select multiple>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n <option value=\"includes\"></option>\n <option value=\"user\"></option>\n <option value=\"progress\"></option>\n </select>\n <div slot=\"footer\" nve-layout=\"row align:stretch full\">\n <nve-button container=\"flat\">Select All</nve-button>\n <nve-button container=\"flat\">Deselect All</nve-button>\n </div>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n <script type=\"module\">\n const combobox = document.querySelector('#combobox-select-all');\n const [selectAll, deselectAll] = Array.from(combobox.querySelectorAll('nve-button'));\n\n selectAll.addEventListener('click', () => combobox.selectAll());\n deselectAll.addEventListener('click', () => combobox.reset());\n combobox.addEventListener('change', e => console.log(e.target.selectedOptions));\n </script>\n `\n};\n\n/**\n * @summary Multi-select with disabled options to show unavailable choices while maintaining visual context.\n */\nexport const DisabledOptions = () => {\n return html`\n <nve-combobox>\n <label>label</label>\n <input type=\"search\">\n <select multiple>\n <option value=\"status\" disabled></option>\n <option value=\"priority\" disabled></option>\n <option value=\"date\" disabled></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </select>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n `\n};\n\n/**\n * @summary Multi-select without built-in tags, using external tag management for custom selection display.\n */\nexport const NoTags = () => {\n return html`\n <form id=\"notags\" nve-layout=\"column gap:lg align:stretch\">\n <nve-combobox notags>\n <label>label</label>\n <input type=\"search\">\n <select multiple>\n <option selected value=\"status\"></option>\n <option selected value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </select>\n </nve-combobox>\n <div id=\"tags\" nve-layout=\"row gap:xs\">\n </div>\n </form>\n <script type=\"module\">\n const form = document.querySelector('#notags');\n const select = form.querySelector('select');\n const tags = form.querySelector('#tags');\n updateTags();\n select.addEventListener('change', e => updateTags());\n tags.addEventListener('close', e => {\n Array.from(select.options).find(o => o.value === e.target.value).selected = false;\n updateTags();\n });\n function updateTags() {\n tags.innerHTML = '';\n Array.from(select.selectedOptions).forEach(o => tags.innerHTML += '<nve-tag closable value=\"' + o.value + '\">' + o.value + '</nve-tag>');\n }\n </script>\n `\n};\n\n/**\n * @summary Combobox with create option behavior that allows users to add new options and tags on the fly. Use when the option list is not exhaustive and users need to enter values that don't yet exist.\n * @tags pattern\n */\nexport const CreateOptions = () => {\n return html`\n<nve-combobox id=\"creatable-combo\" behavior-create style=\"--scroll-height: 220px\">\n <label>Tags</label>\n <input type=\"search\" placeholder=\"Select or create a tag…\" />\n <select multiple>\n <option value=\"Go\">Go</option>\n <option value=\"Rust\">Rust</option>\n <option value=\"Python\">Python</option>\n <option value=\"JavaScript\">JavaScript</option>\n <option value=\"TypeScript\">TypeScript</option>\n <option value=\"Java\">Java</option>\n <option value=\"C#\">C#</option>\n <option value=\"C++\">C++</option>\n <option value=\"C\">C</option>\n <option value=\"PHP\">PHP</option>\n </select>\n <nve-control-message>Press Enter to create a tag that doesn't exist yet</nve-control-message>\n</nve-combobox>\n<script type=\"module\">\n const combobox = document.getElementById('creatable-combo');\n const select = combobox.querySelector('select');\n\n combobox.addEventListener('create', (e) => {\n const option = document.createElement('option');\n option.value = e.detail.value;\n option.textContent = e.detail.value;\n option.selected = true;\n select.appendChild(option);\n });\n</script>\n `\n};\n\n/**\n * @summary Complete form integration showing combobox with form submission, reset, and programmatic value setting.\n */\nexport const Form = () => {\n return html`\n<form nve-layout=\"column gap:lg align:stretch\">\n <nve-combobox style=\"--scroll-height: 220px\">\n <label>label</label>\n <input type=\"search\" name=\"input\">\n <select multiple name=\"select\" value=\"priority\">\n <option value=\"status\"></option>\n <option selected value=\"priority\"></option>\n <option selected value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </select>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n\n <div nve-layout=\"row gap:xs\">\n <nve-button type=\"button\">set</nve-button>\n <nve-button type=\"reset\">reset</nve-button>\n <nve-button type=\"submit\">submit</nve-button>\n </div>\n</form>\n\n<script type=\"module\">\n const form = document.querySelector('form');\n const select = document.querySelector('select');\n const input = document.querySelector('input');\n const btn = document.querySelector('[type=button]');\n\n form.addEventListener('submit', e => {\n e.preventDefault();\n const formData = new FormData(form);\n console.log('input: ', formData.get('input'));\n console.log('select: ', formData.get('select'));\n console.log('selectedOptions: ', Array.from(select.selectedOptions).map(o => o.value));\n });\n\n btn.addEventListener('click', () => {\n select.value = 'status';\n select.options[0].selected = true;\n input.value = 'test';\n });\n</script>\n `\n};\n\n/**\n * @summary Fetches options asynchronously as the user types, cancelling stale requests with AbortController. Use for server-backed search where the full option set is too large to load up front.\n * @tags pattern\n */\nexport const DynamicTypeaheadSearch = () => {\n return html`\n<nve-combobox id=\"combobox\">\n <label>GPU Search</label>\n <input type=\"search\" placeholder=\"Type to search…\" />\n <datalist>\n <option disabled selected></option>\n </datalist>\n</nve-combobox>\n\n<script type=\"module\">\n const combobox = document.getElementById('combobox');\n const input = combobox.querySelector('input');\n const datalist = combobox.querySelector('datalist');\n\n let controller = null;\n input.addEventListener('input', async () => {\n if (controller) controller.abort();\n controller = new AbortController();\n\n const query = input.value.trim();\n if (!query) {\n datalist.innerHTML = '';\n return;\n }\n try {\n const results = await mockFetch(query, controller.signal);\n datalist.innerHTML = results.map((v) => '<option value=\"' + v + '\">').join('');\n } catch (err) {\n if (err.name !== 'AbortError') datalist.innerHTML = '';\n }\n });\n\n function mockFetch(query, signal) {\n return new Promise((resolve, reject) => {\n const timer = setTimeout(() => {\n resolve(['A100 GPU', 'H100 GPU', 'H200 GPU', 'DGX A100', 'DGX H100', 'CUDA Toolkit'].filter((v) => v.toLowerCase().startsWith(query.toLowerCase())));\n }, 500);\n signal.addEventListener('abort', () => {\n clearTimeout(timer);\n reject(new DOMException('Aborted', 'AbortError'));\n });\n });\n }\n</script>\n `\n}\n\n/**\n * @summary Infinite scroll combobox loading, using the scroll event to append options as the user nears the end of the list. Use for server-backed datasets where loading all options up front is impractical.\n * @tags pattern\n */\nexport const InfiniteScroll = () => {\n return html`\n<nve-combobox id=\"infinite-scroll-combo\" style=\"--scroll-height: 200px\">\n <label>GPU Models</label>\n <input type=\"search\" placeholder=\"Scroll to load more…\" />\n <datalist id=\"infinite-scroll-list\"></datalist>\n</nve-combobox>\n\n<script type=\"module\">\n const combo = document.getElementById('infinite-scroll-combo');\n const datalist = document.getElementById('infinite-scroll-list');\n let loading = false;\n\n async function loadBatch() {\n if (loading) return;\n loading = true;\n const items = await new Promise(resolve => setTimeout(() => resolve(Array.from({ length: 100 }, (_, i) => 'GPU Model ' + (datalist.options.length + i + 1))), 300));\n datalist.append(...items.map(v => new Option(v)));\n loading = false;\n }\n\n loadBatch();\n\n combo.addEventListener('scroll', (e) => {\n if (e.detail.scrollHeight - e.detail.scrollTop - e.detail.clientHeight <= 128) {\n loadBatch();\n }\n });\n</script>\n `\n}\n\n/**\n * @summary Performance test with 1000 options to show filtering efficiency with large datasets.\n * @tags test-case performance\n */\nexport const Performance = () => {\n return html`\n<nve-combobox id=\"performance-combobox\">\n <input type=\"search\" aria-label=\"performance test\">\n <datalist></datalist>\n</nve-combobox>\n<script type=\"module\">\n const datalist = document.querySelector('#performance-combobox datalist');\n const options = new Array(1000).fill('').map((_, i) => {\n const option = document.createElement('option');\n option.value = i + ' item';\n return option;\n });\n datalist.append(...options);\n</script>`\n}\n\n/* eslint-disable @nvidia-elements/lint/no-missing-slotted-elements */\n/**\n * @summary Performance test with 1000 options to show filtering efficiency with large datasets.\n * @tags test-case performance\n */\nexport const PerformanceSelect = () => {\n return html`\n<div nve-layout=\"pad:lg\">\n <nve-combobox id=\"performance-combobox\">\n <input type=\"search\" aria-label=\"performance test\">\n <select multiple></select>\n </nve-combobox>\n</div>\n<script type=\"module\">\n const select = document.querySelector('#performance-combobox select');\n const options = new Array(1000).fill('').map((_, i) => {\n const option = document.createElement('option');\n option.value = i + ' item';\n return option;\n });\n select.append(...options);\n</script>`\n}\n\n/**\n * @summary Dynamic options with datalist and select variants of combobox.\n * @tags test-case\n */\nexport const DynamicOptions = () => {\n return html`\n<nve-combobox id=\"dynamic-options-combobox\">\n <input type=\"search\" aria-label=\"performance test\" />\n <datalist>\n <option>default</option>\n </datalist>\n</nve-combobox>\n<script type=\"module\">\n let i = 0;\n setInterval(function() {\n if (i > 100) clearInterval(interval);\n const datalist = document.querySelector(\"#dynamic-options-combobox datalist\");\n const option = document.createElement(\"option\");\n option.value = i + \" item\";\n datalist.append(option);\n i++;\n console.log('append');\n }, 1000);\n</script>\n `\n}\n\n/**\n * @summary Interactive demo showing progressive filter chips with dynamic combobox creation for complex filtering interfaces.\n * @tags test-case\n */\nexport const FilterDemo = {\n render: () => html`<combobox-demo></combobox-demo>`\n}\n\nconst schema = {\n status: {\n type: 'select',\n options: ['success', 'failure', 'processing'],\n initial: 'success'\n },\n priority: {\n type: 'select',\n options: ['high', 'medium', 'low'],\n initial: 'high'\n },\n created: {\n type: 'date',\n initial: new Date()\n },\n progress: {\n type: 'number',\n initial: 0\n },\n sessionId: {\n type: 'text',\n initial: ''\n }\n};\n\n\nclass ComboboxDemo extends LitElement {\n @state() private value = [{ name: '', value: '' }];\n\n // todo\n /* eslint-disable @nvidia-elements/lint/no-deprecated-popover-attributes */\n render() {\n return html`\n <nve-button id=\"filter-btn\" ?pressed=${!!this.value.filter(v => v.name.length).length}><nve-icon name=\"filter\"></nve-icon> </nve-icon>filters</nve-button>\n <nve-dropdown id=\"one\" hidden trigger=\"filter-btn\" anchor=\"filter-btn\" @open=${e => e.target.hidden = false} @close=${e => e.target.hidden = true} style=\"--min-width: 400px; --min-height: 500px;\">\n <progressive-filter-demo @change=${e => this.value = e.detail} .value=${this.value} .schema=${schema}></progressive-filter-demo>\n </nve-dropdown>\n <pre style=\"margin-top: 300px\">${JSON.stringify(this.value.filter(v => v.name.length), null, 2)}</pre>\n `;\n }\n}\n\ncustomElements.get('combobox-demo') || customElements.define('combobox-demo', ComboboxDemo);\n\nclass ProgressiveFilterDemo extends LitElement {\n static styles = [unsafeCSS(`\n :host {\n display: flex;\n flex-direction: column;\n gap: var(--nve-ref-space-xs);\n }\n\n nve-progressive-filter-chip {\n width: 100%;\n }\n `)];\n\n @property({ type: Object }) schema = {};\n\n @property({ type: Array }) value: { name: string, value: string }[] = [{ name: '', value: '' }];\n\n get #unusedFilters() {\n return Object.entries(this.schema).filter(([key]) => !this.value.find(f => f.name === key));\n }\n\n render() {\n return html`\n ${this.value.map(filter => html`\n <nve-progressive-filter-chip closable @close=${() => this.#removeFilter(filter)}>\n <nve-combobox>\n <span slot=\"prefix-icon\"></span>\n <input type=\"search\" placeholder=\"filter\" .value=${filter.name} @change=${e => this.#createfilter(e.target.value, filter)} aria-label=\"filter\" />\n <datalist>${this.#unusedFilters.map(([key]) => html`<option .value=${key}>${key}</option>`)}</datalist>\n </nve-combobox>\n ${choose(this.schema[filter.name]?.type, [\n ['text', () => html`<nve-combobox><input type=\"text\" @change=${e => this.#updateFilter(e.target.value, filter)} .value=${filter.value} placeholder=\"value\" aria-label=\"filter value\" /></nve-combobox>`],\n ['number', () => html`<nve-combobox><input type=\"number\" @change=${e => this.#updateFilter(e.target.value, filter)} .value=${filter.value} aria-label=\"filter value\" /></nve-combobox>`],\n ['date', () => html`<nve-date><input type=\"date\" @change=${e => this.#updateFilter(e.target.value, filter)} .value=${filter.value} aria-label=\"filter value\" /></nve-date>`],\n ['select', () => html`<nve-select><select @change=${e => this.#updateFilter(e.target.value, filter)} value=${filter.value} aria-label=\"filter value\">${this.schema[filter.name]?.options?.map(v => html`<option value=${v}>${v}</option>`)}</select></nve-select>`]\n ], () => html`<nve-combobox><input type=\"text\" placeholder=\"value\" disabled aria-label=\"filter value\" /></nve-combobox>`)}\n </nve-progressive-filter-chip>`)}\n <nve-button container=\"flat\" @click=${this.#addFilter} .disabled=${this.#unusedFilters.length === 0 || !!this.value.find(v => v.name === '')} style=\"align: center; margin-top: 12px;\">\n <nve-icon name=\"add\"></nve-icon> Add Filter\n </nve-button>\n `;\n }\n\n #addFilter() {\n this.value = [...this.value, { name: '', value: '' }];\n this.#valueChange();\n }\n\n #removeFilter(filter: { name: string, value: string }) {\n this.value = this.value.filter(o => o.name !== filter.name);\n this.#valueChange();\n }\n\n #updateFilter(value: string, filter: { name: string, value: string }) {\n this.value = this.value.map(v => v.name === filter.name ? { ...filter, value } : v);\n this.#valueChange();\n }\n\n #createfilter(name, filter: { name: string, value: string }) {\n this.value = this.value.map(v => v.name === filter.name ? { name, value: this.schema[name]?.initial ?? '' } : v);\n this.#valueChange();\n }\n\n #valueChange() {\n this.dispatchEvent(new CustomEvent('change', { detail: this.value }));\n }\n}\n\ncustomElements.get('progressive-filter-demo') || customElements.define('progressive-filter-demo', ProgressiveFilterDemo);\n"],"mappings":";AAGA,IAAA,IAAe"}
|
|
1
|
+
{"version":3,"file":"combobox.examples.js","names":["#unusedFilters","#removeFilter","#createfilter","#updateFilter","#addFilter","#valueChange"],"sources":["../../src/combobox/combobox.examples.ts"],"sourcesContent":["// SPDX-FileCopyrightText: Copyright (c) 2026 NVIDIA CORPORATION & AFFILIATES. All rights reserved.\n// SPDX-License-Identifier: Apache-2.0\n\nimport { html, LitElement, unsafeCSS } from 'lit';\nimport { property } from 'lit/decorators/property.js';\nimport { state } from 'lit/decorators/state.js';\nimport { choose } from 'lit/directives/choose.js';\nimport '@nvidia-elements/core/progressive-filter-chip/define.js';\nimport '@nvidia-elements/core/combobox/define.js';\nimport '@nvidia-elements/core/icon/define.js';\nimport '@nvidia-elements/core/tag/define.js';\nimport '@nvidia-elements/core/date/define.js';\nimport '@nvidia-elements/core/select/define.js';\nimport '@nvidia-elements/core/input/define.js';\nimport '@nvidia-elements/core/dropdown/define.js';\n\nexport default {\n title: 'Elements/Combobox',\n component: 'nve-combobox',\n};\n\n/**\n * @summary Basic combobox with search input and datalist options for filtering and selection.\n */\nexport const Default = () => {\n return html`\n <nve-combobox>\n <label>label</label>\n <input type=\"search\">\n <datalist>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </datalist>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n `\n};\n\n/**\n * @summary Vertical layout showing different combobox states (normal, disabled, success, error) stacked for comparison.\n * @tags test-case\n */\nexport const Vertical = () => {\n return html`\n<div nve-layout=\"column gap:lg full\">\n <nve-combobox>\n <label>label</label>\n <input type=\"search\" />\n <datalist>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </datalist>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n\n <nve-combobox>\n <label>disabled</label>\n <input type=\"search\" disabled />\n <datalist>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </datalist>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n\n <nve-combobox>\n <label>success</label>\n <input type=\"search\" />\n <datalist>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </datalist>\n <nve-control-message status=\"success\">message</nve-control-message>\n </nve-combobox>\n\n <nve-combobox>\n <label>error</label>\n <input type=\"search\" />\n <datalist>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </datalist>\n <nve-control-message status=\"error\">message</nve-control-message>\n </nve-combobox>\n</div>`\n};\n\n/**\n * @summary Horizontal layout showing different combobox states (normal, disabled, success, error) for inline form layouts.\n */\nexport const Horizontal = () => {\n return html`\n<div nve-layout=\"column gap:lg full\">\n <nve-combobox layout=\"horizontal\">\n <label>label</label>\n <input type=\"search\" />\n <datalist>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </datalist>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n\n <nve-combobox layout=\"horizontal\">\n <label>disabled</label>\n <input type=\"search\" disabled />\n <datalist>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </datalist>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n\n <nve-combobox layout=\"horizontal\">\n <label>success</label>\n <input type=\"search\" />\n <datalist>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </datalist>\n <nve-control-message status=\"success\">message</nve-control-message>\n </nve-combobox>\n\n <nve-combobox layout=\"horizontal\">\n <label>error</label>\n <input type=\"search\" />\n <datalist>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </datalist>\n <nve-control-message status=\"error\">message</nve-control-message>\n </nve-combobox>\n</div>`\n};\n\n/**\n * @summary Flat container style with prefix icon for compact inline filtering interfaces.\n */\nexport const Flat = () => {\n return html`\n <nve-combobox container=\"flat\">\n <nve-icon name=\"filter\" slot=\"prefix-icon\"></nve-icon>\n <input type=\"search\" aria-label=\"search\">\n <datalist>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </datalist>\n </nve-combobox>\n `\n};\n\n/**\n * @summary Single select allows users only to select from a predefined list\n * of options. Invalid input is automatically cleared. All options are visible\n * on focus until typing begins for filtering.\n */\nexport const Select = () => {\n return html`\n<nve-combobox>\n <label>label</label>\n <input type=\"search\">\n <select>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </select>\n <nve-control-message>message</nve-control-message>\n</nve-combobox>\n `\n};\n\n/**\n * @summary Multi select allows users to select many options from a\n * predefined list. The select `value` will only reflect the first selected value.\n * To get all selected options check the `selected` property on each `<option>`\n * or the select property `selectedOptions`.\n * On focus all options will show until the user starts typing. Select is the\n * selection value of the combobox. The input is the filter value.\n */\nexport const MultiSelect = () => {\n return html`\n <nve-combobox>\n <label>label</label>\n <input type=\"search\">\n <select multiple>\n <option selected value=\"status\"></option>\n <option selected value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </select>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n `\n};\n\n/**\n * @summary Combobox with an empty initial value using a disabled placeholder option. Use when no default selection exists and the user must make an explicit choice.\n */\nexport const EmptyDefault = () => {\n return html`\n<nve-combobox>\n <label>label</label>\n <input type=\"search\">\n <select>\n <option disabled selected></option>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </select>\n <nve-control-message>message</nve-control-message>\n</nve-combobox>\n `\n};\n\n/**\n * @summary Combobox options with display labels that differ from underlying values. Use when option values are IDs or codes but users need to see human-readable text in the input.\n */\nexport const Label = () => {\n return html`\n <nve-combobox>\n <label>label</label>\n <input type=\"search\">\n <select>\n <option value=\"1\">Status</option>\n <option value=\"2\">Priority</option>\n <option value=\"3\">Date</option>\n <option value=\"4\">Session</option>\n <option value=\"5\">Configuration</option>\n <option value=\"6\">Contains</option>\n </select>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n `\n};\n\n/**\n * @summary Multi-select with labeled options where display text differs from option values.\n */\nexport const LabelMultiSelect = () => {\n return html`\n <nve-combobox>\n <label>label</label>\n <input type=\"search\">\n <select multiple>\n <option value=\"1\">Status</option>\n <option value=\"2\">Priority</option>\n <option value=\"3\">Date</option>\n <option value=\"4\">Session</option>\n <option value=\"5\">Configuration</option>\n <option value=\"6\">Contains</option>\n </select>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n `\n};\n\n/**\n * @summary Overflow behavior where many tags collapse into a simple text label when the parent container is too narrow.\n * @tags test-case\n */\nexport const Overflow = () => {\n return html`\n <nve-combobox style=\"width: 250px\">\n <label>label</label>\n <input type=\"search\">\n <select multiple>\n <option selected value=\"status\"></option>\n <option selected value=\"priority\"></option>\n <option selected value=\"date\"></option>\n <option selected value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </select>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n `\n};\n\n/**\n * @summary Combobox handling of long option text in constrained width containers.\n * @tags test-case\n */\nexport const PopoverOverflow = () => {\n return html`\n <nve-combobox style=\"width: 100px\">\n <label>label</label>\n <input type=\"search\">\n <select>\n <option value=\"really-long-text-option-that-keeps-going\"></option> \n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </select>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n `\n};\n\n/**\n * @summary Multi-select with reset functionality via icon button and footer button to clear all selections.\n */\nexport const Reset = () => {\n return html`\n <nve-combobox id=\"combobox-reset\" style=\"width: 500px; --scroll-height: 220px\">\n <label>label</label>\n <input type=\"search\">\n <select multiple>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </select>\n <nve-icon-button aria-label=\"clear selection\" icon-name=\"cancel\" container=\"inline\"></nve-icon-button>\n <nve-button slot=\"footer\" aria-label=\"clear selection\" container=\"flat\">reset</nve-button>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n <script type=\"module\">\n document.querySelector('#combobox-reset nve-icon-button').addEventListener('click', e => e.target.parentElement.reset());\n document.querySelector('#combobox-reset nve-button').addEventListener('click', e => e.target.parentElement.reset());\n </script>\n `\n};\n\n/**\n * @summary Multi-select with footer action button for extra operations on selected items.\n */\nexport const Footer = () => {\n return html`\n <nve-combobox style=\"width: 500px; --scroll-height: 200px\">\n <label>label</label>\n <input type=\"search\">\n <select multiple>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n <option value=\"includes\"></option>\n <option value=\"user\"></option>\n <option value=\"progress\"></option>\n </select>\n <nve-button slot=\"footer\" container=\"flat\">action</nve-button>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n `\n};\n\n/**\n * @summary Multi-select with bulk selection controls (Select All/Deselect All) in footer for efficient mass operations.\n */\nexport const SelectAll = () => {\n return html`\n <nve-combobox id=\"combobox-select-all\" style=\"width: 500px; --scroll-height: 200px\">\n <label>label</label>\n <input type=\"search\">\n <select multiple>\n <option value=\"status\"></option>\n <option value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n <option value=\"includes\"></option>\n <option value=\"user\"></option>\n <option value=\"progress\"></option>\n </select>\n <div slot=\"footer\" nve-layout=\"row align:stretch full\">\n <nve-button container=\"flat\">Select All</nve-button>\n <nve-button container=\"flat\">Deselect All</nve-button>\n </div>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n <script type=\"module\">\n const combobox = document.querySelector('#combobox-select-all');\n const [selectAll, deselectAll] = Array.from(combobox.querySelectorAll('nve-button'));\n\n selectAll.addEventListener('click', () => combobox.selectAll());\n deselectAll.addEventListener('click', () => combobox.reset());\n combobox.addEventListener('change', e => console.log(e.target.selectedOptions));\n </script>\n `\n};\n\n/**\n * @summary Multi-select with disabled options to show unavailable choices while maintaining visual context.\n */\nexport const DisabledOptions = () => {\n return html`\n <nve-combobox>\n <label>label</label>\n <input type=\"search\">\n <select multiple>\n <option value=\"status\" disabled></option>\n <option value=\"priority\" disabled></option>\n <option value=\"date\" disabled></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </select>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n `\n};\n\n/**\n * @summary Multi-select without built-in tags, using external tag management for custom selection display.\n */\nexport const NoTags = () => {\n return html`\n <form id=\"notags\" nve-layout=\"column gap:lg align:stretch\">\n <nve-combobox notags>\n <label>label</label>\n <input type=\"search\">\n <select multiple>\n <option selected value=\"status\"></option>\n <option selected value=\"priority\"></option>\n <option value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </select>\n </nve-combobox>\n <div id=\"tags\" nve-layout=\"row gap:xs\">\n </div>\n </form>\n <script type=\"module\">\n const form = document.querySelector('#notags');\n const select = form.querySelector('select');\n const tags = form.querySelector('#tags');\n updateTags();\n select.addEventListener('change', e => updateTags());\n tags.addEventListener('close', e => {\n Array.from(select.options).find(o => o.value === e.target.value).selected = false;\n updateTags();\n });\n function updateTags() {\n tags.innerHTML = '';\n Array.from(select.selectedOptions).forEach(o => tags.innerHTML += '<nve-tag closable value=\"' + o.value + '\">' + o.value + '</nve-tag>');\n }\n </script>\n `\n};\n\n/**\n * @summary Combobox with create option behavior that allows users to add new options and tags on the fly. Use when the option list is not exhaustive and users need to enter values that don't yet exist.\n * @tags pattern\n */\nexport const CreateOptions = () => {\n return html`\n<nve-combobox id=\"creatable-combo\" behavior-create style=\"--scroll-height: 220px\">\n <label>Tags</label>\n <input type=\"search\" placeholder=\"Select or create a tag…\" />\n <select multiple>\n <option value=\"Go\">Go</option>\n <option value=\"Rust\">Rust</option>\n <option value=\"Python\">Python</option>\n <option value=\"JavaScript\">JavaScript</option>\n <option value=\"TypeScript\">TypeScript</option>\n <option value=\"Java\">Java</option>\n <option value=\"C#\">C#</option>\n <option value=\"C++\">C++</option>\n <option value=\"C\">C</option>\n <option value=\"PHP\">PHP</option>\n </select>\n <nve-control-message>Press Enter to create a tag that doesn't exist yet</nve-control-message>\n</nve-combobox>\n<script type=\"module\">\n const combobox = document.getElementById('creatable-combo');\n const select = combobox.querySelector('select');\n\n combobox.addEventListener('create', (e) => {\n const option = document.createElement('option');\n option.value = e.detail.value;\n option.textContent = e.detail.value;\n option.selected = true;\n select.appendChild(option);\n });\n</script>\n `\n};\n\n/**\n * @summary Complete form integration showing combobox with form submission, reset, and programmatic value setting.\n */\nexport const Form = () => {\n return html`\n<form nve-layout=\"column gap:lg align:stretch\">\n <nve-combobox style=\"--scroll-height: 220px\">\n <label>label</label>\n <input type=\"search\" name=\"input\">\n <select multiple name=\"select\" value=\"priority\">\n <option value=\"status\"></option>\n <option selected value=\"priority\"></option>\n <option selected value=\"date\"></option>\n <option value=\"session\"></option>\n <option value=\"configuration\"></option>\n <option value=\"contains\"></option>\n </select>\n <nve-control-message>message</nve-control-message>\n </nve-combobox>\n\n <div nve-layout=\"row gap:xs\">\n <nve-button type=\"button\">set</nve-button>\n <nve-button type=\"reset\">reset</nve-button>\n <nve-button type=\"submit\">submit</nve-button>\n </div>\n</form>\n\n<script type=\"module\">\n const form = document.querySelector('form');\n const select = document.querySelector('select');\n const input = document.querySelector('input');\n const btn = document.querySelector('[type=button]');\n\n form.addEventListener('submit', e => {\n e.preventDefault();\n const formData = new FormData(form);\n console.log('input: ', formData.get('input'));\n console.log('select: ', formData.get('select'));\n console.log('selectedOptions: ', Array.from(select.selectedOptions).map(o => o.value));\n });\n\n btn.addEventListener('click', () => {\n select.value = 'status';\n select.options[0].selected = true;\n input.value = 'test';\n });\n</script>\n `\n};\n\n/**\n * @summary Fetches options asynchronously as the user types, cancelling stale requests with AbortController. Use for server-backed search where the full option set is too large to load up front.\n * @tags pattern\n */\nexport const DynamicTypeaheadSearch = () => {\n return html`\n<nve-combobox id=\"combobox\">\n <label>GPU Search</label>\n <input type=\"search\" placeholder=\"Type to search…\" />\n <datalist>\n <option disabled selected></option>\n </datalist>\n</nve-combobox>\n\n<script type=\"module\">\n const combobox = document.getElementById('combobox');\n const input = combobox.querySelector('input');\n const datalist = combobox.querySelector('datalist');\n\n let controller = null;\n input.addEventListener('input', async () => {\n if (controller) controller.abort();\n controller = new AbortController();\n\n const query = input.value.trim();\n if (!query) {\n datalist.innerHTML = '';\n return;\n }\n try {\n const results = await mockFetch(query, controller.signal);\n datalist.innerHTML = results.map((v) => '<option value=\"' + v + '\">').join('');\n } catch (err) {\n if (err.name !== 'AbortError') datalist.innerHTML = '';\n }\n });\n\n function mockFetch(query, signal) {\n return new Promise((resolve, reject) => {\n const timer = setTimeout(() => {\n resolve(['A100 GPU', 'H100 GPU', 'H200 GPU', 'DGX A100', 'DGX H100', 'CUDA Toolkit'].filter((v) => v.toLowerCase().startsWith(query.toLowerCase())));\n }, 500);\n signal.addEventListener('abort', () => {\n clearTimeout(timer);\n reject(new DOMException('Aborted', 'AbortError'));\n });\n });\n }\n</script>\n `\n}\n\n/**\n * @summary Infinite scroll combobox loading, using the scroll event to append options as the user nears the end of the list. Use for server-backed datasets where loading all options up front is impractical.\n * @tags pattern\n */\nexport const InfiniteScroll = () => {\n return html`\n<nve-combobox id=\"infinite-scroll-combo\" style=\"--scroll-height: 200px\">\n <label>GPU Models</label>\n <input type=\"search\" placeholder=\"Scroll to load more…\" />\n <datalist id=\"infinite-scroll-list\"></datalist>\n</nve-combobox>\n\n<script type=\"module\">\n const combo = document.getElementById('infinite-scroll-combo');\n const datalist = document.getElementById('infinite-scroll-list');\n let loading = false;\n\n async function loadBatch() {\n if (loading) return;\n loading = true;\n const items = await new Promise(resolve => setTimeout(() => resolve(Array.from({ length: 100 }, (_, i) => 'GPU Model ' + (datalist.options.length + i + 1))), 300));\n datalist.append(...items.map(v => new Option(v)));\n loading = false;\n }\n\n loadBatch();\n\n combo.addEventListener('scroll', (e) => {\n if (e.detail.scrollHeight - e.detail.scrollTop - e.detail.clientHeight <= 128) {\n loadBatch();\n }\n });\n</script>\n `\n}\n\n/**\n * @summary Performance test with 1000 options to show filtering efficiency with large datasets.\n * @tags test-case performance\n */\nexport const Performance = () => {\n return html`\n<nve-combobox id=\"performance-combobox\">\n <input type=\"search\" aria-label=\"performance test\">\n <datalist></datalist>\n</nve-combobox>\n<script type=\"module\">\n const datalist = document.querySelector('#performance-combobox datalist');\n const options = new Array(1000).fill('').map((_, i) => {\n const option = document.createElement('option');\n option.value = i + ' item';\n return option;\n });\n datalist.append(...options);\n</script>`\n}\n\n/* eslint-disable @nvidia-elements/lint/no-missing-slotted-elements */\n/**\n * @summary Performance test with 1000 options to show filtering efficiency with large datasets.\n * @tags test-case performance\n */\nexport const PerformanceSelect = () => {\n return html`\n<div nve-layout=\"pad:lg\">\n <nve-combobox id=\"performance-combobox\">\n <input type=\"search\" aria-label=\"performance test\">\n <select multiple></select>\n </nve-combobox>\n</div>\n<script type=\"module\">\n const select = document.querySelector('#performance-combobox select');\n const options = new Array(1000).fill('').map((_, i) => {\n const option = document.createElement('option');\n option.value = i + ' item';\n return option;\n });\n select.append(...options);\n</script>`\n}\n\n/**\n * @summary Dynamic options with datalist and select variants of combobox.\n * @tags test-case\n */\nexport const DynamicOptions = () => {\n return html`\n<nve-combobox id=\"dynamic-options-combobox\">\n <input type=\"search\" aria-label=\"performance test\" />\n <datalist>\n <option>default</option>\n </datalist>\n</nve-combobox>\n<script type=\"module\">\n let i = 0;\n setInterval(function() {\n if (i > 100) clearInterval(interval);\n const datalist = document.querySelector(\"#dynamic-options-combobox datalist\");\n const option = document.createElement(\"option\");\n option.value = i + \" item\";\n datalist.append(option);\n i++;\n console.log('append');\n }, 1000);\n</script>\n `\n}\n\n/**\n * @summary Interactive demo showing progressive filter chips with dynamic combobox creation for complex filtering interfaces.\n * @tags test-case\n */\nexport const FilterDemo = {\n render: () => html`<combobox-demo></combobox-demo>`\n}\n\nconst schema = {\n status: {\n type: 'select',\n options: ['success', 'failure', 'processing'],\n initial: 'success'\n },\n priority: {\n type: 'select',\n options: ['high', 'medium', 'low'],\n initial: 'high'\n },\n created: {\n type: 'date',\n initial: new Date()\n },\n progress: {\n type: 'number',\n initial: 0\n },\n sessionId: {\n type: 'text',\n initial: ''\n }\n};\n\n\nclass ComboboxDemo extends LitElement {\n @state() private value = [{ name: '', value: '' }];\n\n /* eslint-disable @nvidia-elements/lint/no-deprecated-popover-attributes */\n render() {\n return html`\n <nve-button id=\"filter-btn\" ?pressed=${!!this.value.filter(v => v.name.length).length}><nve-icon name=\"filter\"></nve-icon> </nve-icon>filters</nve-button>\n <nve-dropdown id=\"one\" hidden trigger=\"filter-btn\" anchor=\"filter-btn\" @open=${e => e.target.hidden = false} @close=${e => e.target.hidden = true} style=\"--min-width: 400px; --min-height: 500px;\">\n <progressive-filter-demo @change=${e => this.value = e.detail} .value=${this.value} .schema=${schema}></progressive-filter-demo>\n </nve-dropdown>\n <pre style=\"margin-top: 300px\">${JSON.stringify(this.value.filter(v => v.name.length), null, 2)}</pre>\n `;\n }\n}\n\ncustomElements.get('combobox-demo') || customElements.define('combobox-demo', ComboboxDemo);\n\nclass ProgressiveFilterDemo extends LitElement {\n static styles = [unsafeCSS(`\n :host {\n display: flex;\n flex-direction: column;\n gap: var(--nve-ref-space-xs);\n }\n\n nve-progressive-filter-chip {\n width: 100%;\n }\n `)];\n\n @property({ type: Object }) schema = {};\n\n @property({ type: Array }) value: { name: string, value: string }[] = [{ name: '', value: '' }];\n\n get #unusedFilters() {\n return Object.entries(this.schema).filter(([key]) => !this.value.find(f => f.name === key));\n }\n\n render() {\n return html`\n ${this.value.map(filter => html`\n <nve-progressive-filter-chip closable @close=${() => this.#removeFilter(filter)}>\n <nve-combobox>\n <span slot=\"prefix-icon\"></span>\n <input type=\"search\" placeholder=\"filter\" .value=${filter.name} @change=${e => this.#createfilter(e.target.value, filter)} aria-label=\"filter\" />\n <datalist>${this.#unusedFilters.map(([key]) => html`<option .value=${key}>${key}</option>`)}</datalist>\n </nve-combobox>\n ${choose(this.schema[filter.name]?.type, [\n ['text', () => html`<nve-combobox><input type=\"text\" @change=${e => this.#updateFilter(e.target.value, filter)} .value=${filter.value} placeholder=\"value\" aria-label=\"filter value\" /></nve-combobox>`],\n ['number', () => html`<nve-combobox><input type=\"number\" @change=${e => this.#updateFilter(e.target.value, filter)} .value=${filter.value} aria-label=\"filter value\" /></nve-combobox>`],\n ['date', () => html`<nve-date><input type=\"date\" @change=${e => this.#updateFilter(e.target.value, filter)} .value=${filter.value} aria-label=\"filter value\" /></nve-date>`],\n ['select', () => html`<nve-select><select @change=${e => this.#updateFilter(e.target.value, filter)} value=${filter.value} aria-label=\"filter value\">${this.schema[filter.name]?.options?.map(v => html`<option value=${v}>${v}</option>`)}</select></nve-select>`]\n ], () => html`<nve-combobox><input type=\"text\" placeholder=\"value\" disabled aria-label=\"filter value\" /></nve-combobox>`)}\n </nve-progressive-filter-chip>`)}\n <nve-button container=\"flat\" @click=${this.#addFilter} .disabled=${this.#unusedFilters.length === 0 || !!this.value.find(v => v.name === '')} style=\"align: center; margin-top: 12px;\">\n <nve-icon name=\"add\"></nve-icon> Add Filter\n </nve-button>\n `;\n }\n\n #addFilter() {\n this.value = [...this.value, { name: '', value: '' }];\n this.#valueChange();\n }\n\n #removeFilter(filter: { name: string, value: string }) {\n this.value = this.value.filter(o => o.name !== filter.name);\n this.#valueChange();\n }\n\n #updateFilter(value: string, filter: { name: string, value: string }) {\n this.value = this.value.map(v => v.name === filter.name ? { ...filter, value } : v);\n this.#valueChange();\n }\n\n #createfilter(name, filter: { name: string, value: string }) {\n this.value = this.value.map(v => v.name === filter.name ? { name, value: this.schema[name]?.initial ?? '' } : v);\n this.#valueChange();\n }\n\n #valueChange() {\n this.dispatchEvent(new CustomEvent('change', { detail: this.value }));\n }\n}\n\ncustomElements.get('progressive-filter-demo') || customElements.define('progressive-filter-demo', ProgressiveFilterDemo);\n"],"mappings":";AAGA,IAAA,IAAe"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"copy-button2.js","names":["#i18nController","#close","#copy","#openTooltip","#closeTooltip"],"sources":["../../src/copy-button/copy-button.ts"],"sourcesContent":["// SPDX-FileCopyrightText: Copyright (c) 2026 NVIDIA CORPORATION & AFFILIATES. All rights reserved.\n// SPDX-License-Identifier: Apache-2.0\n\nimport { html, nothing } from 'lit';\nimport { property } from 'lit/decorators/property.js';\nimport { state } from 'lit/decorators/state.js';\nimport { useStyles, I18nController, scopedRegistry } from '@nvidia-elements/core/internal';\nimport { Button } from '@nvidia-elements/core/button';\nimport { Icon } from '@nvidia-elements/core/icon';\nimport { Toast } from '@nvidia-elements/core/toast';\nimport { Tooltip } from '@nvidia-elements/core/tooltip';\nimport styles from './copy-button.css?inline';\n\n/**\n * @element nve-copy-button\n * @description A copy button is a button that easily enables the copy to clipboard pattern.\n * @since 1.1.4\n * @entrypoint \\@nvidia-elements/core/copy-button\n * @slot - default\n * @slot icon - slot for custom icon\n * @cssprop --color\n * @cssprop --background\n * @cssprop --border-radius\n * @cssprop --padding\n * @cssprop --height\n * @cssprop --min-width\n * @cssprop --font-size\n * @cssprop --line-height\n * @csspart icon - The icon element\n * @csspart toast - The toast notification element\n * @csspart tooltip - The tooltip element\n * @aria https://www.w3.org/WAI/ARIA/apg/patterns/button/\n *\n */\n@scopedRegistry()\nexport class CopyButton extends Button {\n @state() private copied = false;\n\n @state() private showToast = false;\n\n @state() private showTooltip = false;\n\n #i18nController: I18nController<this> = new I18nController<this>(this);\n\n /**\n * Enables internal string values to update for internationalization.\n */\n @property({ type: Object }) i18n = this.#i18nController.i18n;\n\n /**\n * Determines if the copy button should auto write to clipboard by the trigger.\n */\n @property({ type: Boolean, reflect: true, attribute: 'behavior-copy' }) behaviorCopy: boolean;\n\n /**\n * Defines the value that copies to the user clipboard. Use `aria-label` to set the tooltip hint.\n */\n @property({ type: String }) value: string;\n\n static styles = useStyles([...Button.styles, styles]);\n\n static readonly metadata = {\n tag: 'nve-copy-button',\n version: '0.0.0'\n };\n\n static elementDefinitions = {\n [Icon.metadata.tag]: Icon,\n [Toast.metadata.tag]: Toast,\n [Tooltip.metadata.tag]: Tooltip\n };\n\n
|
|
1
|
+
{"version":3,"file":"copy-button2.js","names":["#i18nController","#close","#copy","#openTooltip","#closeTooltip"],"sources":["../../src/copy-button/copy-button.ts"],"sourcesContent":["// SPDX-FileCopyrightText: Copyright (c) 2026 NVIDIA CORPORATION & AFFILIATES. All rights reserved.\n// SPDX-License-Identifier: Apache-2.0\n\nimport { html, nothing } from 'lit';\nimport { property } from 'lit/decorators/property.js';\nimport { state } from 'lit/decorators/state.js';\nimport { useStyles, I18nController, scopedRegistry } from '@nvidia-elements/core/internal';\nimport { Button } from '@nvidia-elements/core/button';\nimport { Icon } from '@nvidia-elements/core/icon';\nimport { Toast } from '@nvidia-elements/core/toast';\nimport { Tooltip } from '@nvidia-elements/core/tooltip';\nimport styles from './copy-button.css?inline';\n\n/**\n * @element nve-copy-button\n * @description A copy button is a button that easily enables the copy to clipboard pattern.\n * @since 1.1.4\n * @entrypoint \\@nvidia-elements/core/copy-button\n * @slot - default\n * @slot icon - slot for custom icon\n * @cssprop --color\n * @cssprop --background\n * @cssprop --border-radius\n * @cssprop --padding\n * @cssprop --height\n * @cssprop --min-width\n * @cssprop --font-size\n * @cssprop --line-height\n * @csspart icon - The icon element\n * @csspart toast - The toast notification element\n * @csspart tooltip - The tooltip element\n * @aria https://www.w3.org/WAI/ARIA/apg/patterns/button/\n *\n */\n@scopedRegistry()\nexport class CopyButton extends Button {\n @state() private copied = false;\n\n @state() private showToast = false;\n\n @state() private showTooltip = false;\n\n #i18nController: I18nController<this> = new I18nController<this>(this);\n\n /**\n * Enables internal string values to update for internationalization.\n */\n @property({ type: Object }) i18n = this.#i18nController.i18n;\n\n /**\n * Determines if the copy button should auto write to clipboard by the trigger.\n */\n @property({ type: Boolean, reflect: true, attribute: 'behavior-copy' }) behaviorCopy: boolean;\n\n /**\n * Defines the value that copies to the user clipboard. Use `aria-label` to set the tooltip hint.\n */\n @property({ type: String }) value: string;\n\n static styles = useStyles([...Button.styles, styles]);\n\n static readonly metadata = {\n tag: 'nve-copy-button',\n version: '0.0.0'\n };\n\n static elementDefinitions = {\n [Icon.metadata.tag]: Icon,\n [Toast.metadata.tag]: Toast,\n [Tooltip.metadata.tag]: Tooltip\n };\n\n /* eslint-disable @nvidia-elements/lint/no-deprecated-popover-attributes */\n render() {\n return html`\n <div id=\"btn\" internal-host interaction-state focus-within>\n <slot></slot>\n ${\n this.copied\n ? html`<nve-icon part=\"icon\" name=\"check\" status=\"success\" .size=${this.size} aria-hidden=\"true\"></nve-icon>`\n : html`<slot name=\"icon\"><nve-icon part=\"icon\" name=\"copy\" .size=${this.size} aria-hidden=\"true\"></nve-icon></slot>`\n }\n </div>\n ${this.showToast ? html`<nve-toast part=\"toast\" @close=${this.#close} status=\"success\" anchor=\"btn\" trigger=\"btn\" position=\"top\" close-timeout=\"1500\">${this.i18n.copied}</nve-toast>` : nothing}\n ${this.showTooltip && !this.showToast ? html`<nve-tooltip part=\"tooltip\" exportparts=\"arrow:tooltip-arrow\" anchor=\"btn\" trigger=\"btn\">${this.ariaLabel ?? this.i18n.copy}</nve-tooltip>` : nothing}\n `;\n }\n\n connectedCallback() {\n super.connectedCallback();\n this.addEventListener('click', this.#copy);\n this.addEventListener('mouseenter', this.#openTooltip);\n this.addEventListener('mouseleave', this.#closeTooltip);\n }\n\n disconnectedCallback() {\n super.disconnectedCallback();\n this.removeEventListener('click', this.#copy);\n this.removeEventListener('mouseenter', this.#openTooltip);\n this.removeEventListener('mouseleave', this.#closeTooltip);\n }\n\n #copy = () => {\n if (this.behaviorCopy) {\n navigator.clipboard\n .writeText(this.value)\n .then(() => {\n this.showToast = true;\n this.copied = true;\n })\n .catch(err => {\n this.showToast = false;\n console.error(err);\n });\n }\n };\n\n #close() {\n this.showToast = false;\n this.copied = false;\n this.showTooltip = false;\n }\n\n #openTooltip = () => {\n this.showTooltip = true;\n };\n\n #closeTooltip = () => {\n this.showTooltip = false;\n };\n}\n"],"mappings":";;;;;;;;;;;;;AAmCO,IAAA,IAAA,cAAyB,EAAO;;6BACX,qBAEG,uBAEE,gBAOI,MAAA,EAAqB;;CALxD,KAAwC,IAAI,EAAqB,KAAK;;gBAiBtD,EAAU,CAAC,GAAG,EAAO,QAAQ,EAAO,CAAC;;;kBAE1B;GACzB,KAAK;GACL,SAAS;GACV;;;4BAE2B;IACzB,EAAK,SAAS,MAAM;IACpB,EAAM,SAAS,MAAM;IACrB,EAAQ,SAAS,MAAM;GACzB;;CAGD,SAAS;AACP,SAAO,CAAI,2EAIL,KAAK,SACD,CAAI,8DAA6D,KAAK,KAAK,oCAC3E,CAAI,8DAA6D,KAAK,KAAK,yCAChF,QAEF,KAAK,YAAY,CAAI,mCAAkC,MAAA,EAAY,oFAAmF,KAAK,KAAK,OAAO,gBAAgB,EAAQ,GAC/L,KAAK,eAAe,CAAC,KAAK,YAAY,CAAI,4FAA4F,KAAK,aAAa,KAAK,KAAK,KAAK,kBAAkB;;CAI9L,oBAAoB;AAIlB,EAHA,MAAM,mBAAmB,EACzB,KAAK,iBAAiB,SAAS,MAAA,EAAW,EAC1C,KAAK,iBAAiB,cAAc,MAAA,EAAkB,EACtD,KAAK,iBAAiB,cAAc,MAAA,EAAmB;;CAGzD,uBAAuB;AAIrB,EAHA,MAAM,sBAAsB,EAC5B,KAAK,oBAAoB,SAAS,MAAA,EAAW,EAC7C,KAAK,oBAAoB,cAAc,MAAA,EAAkB,EACzD,KAAK,oBAAoB,cAAc,MAAA,EAAmB;;CAG5D,WAAc;AACZ,EAAI,KAAK,gBACP,UAAU,UACP,UAAU,KAAK,MAAM,CACrB,WAAW;AAEV,GADA,KAAK,YAAY,IACjB,KAAK,SAAS;IACd,CACD,OAAM,MAAO;AAEZ,GADA,KAAK,YAAY,IACjB,QAAQ,MAAM,EAAI;IAClB;;CAIR,KAAS;AAGP,EAFA,KAAK,YAAY,IACjB,KAAK,SAAS,IACd,KAAK,cAAc;;CAGrB,WAAqB;AACnB,OAAK,cAAc;;CAGrB,WAAsB;AACpB,OAAK,cAAc;;;GA5FpB,GAAO,CAAA,EAAA,EAAA,WAAA,UAAA,KAAA,EAAA,KAEP,GAAO,CAAA,EAAA,EAAA,WAAA,aAAA,KAAA,EAAA,KAEP,GAAO,CAAA,EAAA,EAAA,WAAA,eAAA,KAAA,EAAA,KAOP,EAAS,EAAE,MAAM,QAAQ,CAAC,CAAA,EAAA,EAAA,WAAA,QAAA,KAAA,EAAA,KAK1B,EAAS;CAAE,MAAM;CAAS,SAAS;CAAM,WAAW;CAAiB,CAAC,CAAA,EAAA,EAAA,WAAA,gBAAA,KAAA,EAAA,KAKtE,EAAS,EAAE,MAAM,QAAQ,CAAC,CAAA,EAAA,EAAA,WAAA,SAAA,KAAA,EAAA,SAvB5B,GAAgB,CAAA,EAAA,EAAA"}
|
|
@@ -1670,6 +1670,7 @@ export type IconButtonProps = {
|
|
|
1670
1670
|
| "start"
|
|
1671
1671
|
| "status-offline"
|
|
1672
1672
|
| "status-online"
|
|
1673
|
+
| "stop"
|
|
1673
1674
|
| "stop-sign"
|
|
1674
1675
|
| "stopwatch"
|
|
1675
1676
|
| "strikethrough"
|
|
@@ -2056,6 +2057,7 @@ export type IconProps = {
|
|
|
2056
2057
|
| "start"
|
|
2057
2058
|
| "status-offline"
|
|
2058
2059
|
| "status-online"
|
|
2060
|
+
| "stop"
|
|
2059
2061
|
| "stop-sign"
|
|
2060
2062
|
| "stopwatch"
|
|
2061
2063
|
| "strikethrough"
|
|
@@ -2897,9 +2899,9 @@ export type SelectProps = {
|
|
|
2897
2899
|
};
|
|
2898
2900
|
|
|
2899
2901
|
export type SkeletonProps = {
|
|
2900
|
-
/**
|
|
2902
|
+
/** Visual animation style shown while content loads. */
|
|
2901
2903
|
effect?: "shimmer" | "pulse";
|
|
2902
|
-
/**
|
|
2904
|
+
/** Geometry of the placeholder — rounded corners or a full pill outline. */
|
|
2903
2905
|
shape?: "round" | "pill";
|
|
2904
2906
|
/** Whether the skeleton hides its content */
|
|
2905
2907
|
hidden?: boolean;
|
|
@@ -1597,6 +1597,7 @@ type IconButtonProps = {
|
|
|
1597
1597
|
| "start"
|
|
1598
1598
|
| "status-offline"
|
|
1599
1599
|
| "status-online"
|
|
1600
|
+
| "stop"
|
|
1600
1601
|
| "stop-sign"
|
|
1601
1602
|
| "stopwatch"
|
|
1602
1603
|
| "strikethrough"
|
|
@@ -1983,6 +1984,7 @@ type IconProps = {
|
|
|
1983
1984
|
| "start"
|
|
1984
1985
|
| "status-offline"
|
|
1985
1986
|
| "status-online"
|
|
1987
|
+
| "stop"
|
|
1986
1988
|
| "stop-sign"
|
|
1987
1989
|
| "stopwatch"
|
|
1988
1990
|
| "strikethrough"
|
|
@@ -2824,9 +2826,9 @@ type SelectProps = {
|
|
|
2824
2826
|
};
|
|
2825
2827
|
|
|
2826
2828
|
type SkeletonProps = {
|
|
2827
|
-
/**
|
|
2829
|
+
/** Visual animation style shown while content loads. */
|
|
2828
2830
|
effect?: "shimmer" | "pulse";
|
|
2829
|
-
/**
|
|
2831
|
+
/** Geometry of the placeholder — rounded corners or a full pill outline. */
|
|
2830
2832
|
shape?: "round" | "pill";
|
|
2831
2833
|
/** Whether the skeleton hides its content */
|
|
2832
2834
|
hidden?: boolean;
|