@vonage/vivid 4.5.0 → 4.6.0
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/custom-elements.json +1091 -187
- package/elevation/index.cjs +1 -1
- package/elevation/index.js +1 -1
- package/index.cjs +62 -56
- package/index.js +20 -19
- package/lib/components.d.ts +1 -0
- package/lib/menu/menu.d.ts +2 -1
- package/lib/number-field/number-field.d.ts +3 -1
- package/lib/searchable-select/definition.d.ts +4 -0
- package/lib/searchable-select/locale.d.ts +6 -0
- package/lib/searchable-select/option-tag.d.ts +14 -0
- package/lib/searchable-select/option-tag.template.d.ts +4 -0
- package/lib/searchable-select/searchable-select.d.ts +29 -0
- package/lib/searchable-select/searchable-select.form-associated.d.ts +10 -0
- package/lib/searchable-select/searchable-select.template.d.ts +4 -0
- package/lib/select/select.d.ts +3 -1
- package/lib/tab/locale.d.ts +3 -0
- package/lib/tab/tab.d.ts +5 -1
- package/lib/tag/definition.d.ts +1 -0
- package/lib/text-field/text-field.d.ts +3 -1
- package/locales/de-DE.cjs +12 -0
- package/locales/de-DE.js +12 -0
- package/locales/en-GB.cjs +12 -0
- package/locales/en-GB.js +12 -0
- package/locales/en-US.cjs +12 -0
- package/locales/en-US.js +12 -0
- package/locales/ja-JP.cjs +12 -0
- package/locales/ja-JP.js +12 -0
- package/locales/zh-CN.cjs +12 -0
- package/locales/zh-CN.js +12 -0
- package/package.json +1 -1
- package/popup/index.cjs +1 -1
- package/popup/index.js +1 -1
- package/searchable-select/index.cjs +5 -0
- package/searchable-select/index.js +3 -0
- package/select/index.cjs +1 -1
- package/select/index.js +1 -1
- package/selectable-box/index.cjs +1 -1
- package/selectable-box/index.js +1 -1
- package/shared/definition11.cjs +1 -1
- package/shared/definition11.js +1 -1
- package/shared/definition14.cjs +1 -1
- package/shared/definition14.js +1 -1
- package/shared/definition16.cjs +1 -1
- package/shared/definition16.js +1 -1
- package/shared/definition18.cjs +2 -2
- package/shared/definition18.js +2 -2
- package/shared/definition19.cjs +2 -2
- package/shared/definition19.js +2 -2
- package/shared/definition20.cjs +14 -34
- package/shared/definition20.js +14 -34
- package/shared/definition21.cjs +1 -1
- package/shared/definition21.js +1 -1
- package/shared/definition26.cjs +1 -1
- package/shared/definition26.js +1 -1
- package/shared/definition29.cjs +4 -0
- package/shared/definition29.js +4 -0
- package/shared/definition30.cjs +2 -1
- package/shared/definition30.js +2 -1
- package/shared/definition35.cjs +12 -7
- package/shared/definition35.js +12 -7
- package/shared/definition36.cjs +50 -207
- package/shared/definition36.js +51 -207
- package/shared/definition4.cjs +1 -1
- package/shared/definition4.js +1 -1
- package/shared/definition42.cjs +1 -1
- package/shared/definition42.js +1 -1
- package/shared/definition43.cjs +993 -645
- package/shared/definition43.js +989 -642
- package/shared/definition44.cjs +723 -112
- package/shared/definition44.js +722 -111
- package/shared/definition45.cjs +121 -80
- package/shared/definition45.js +119 -78
- package/shared/definition46.cjs +81 -614
- package/shared/definition46.js +80 -612
- package/shared/definition47.cjs +608 -114
- package/shared/definition47.js +606 -113
- package/shared/definition48.cjs +116 -134
- package/shared/definition48.js +115 -133
- package/shared/definition49.cjs +149 -19
- package/shared/definition49.js +148 -18
- package/shared/definition5.cjs +1 -1
- package/shared/definition5.js +1 -1
- package/shared/definition50.cjs +21 -82
- package/shared/definition50.js +20 -81
- package/shared/definition51.cjs +77 -539
- package/shared/definition51.js +76 -538
- package/shared/definition52.cjs +568 -28
- package/shared/definition52.js +567 -27
- package/shared/definition53.cjs +28 -123
- package/shared/definition53.js +26 -122
- package/shared/definition54.cjs +115 -295
- package/shared/definition54.js +114 -294
- package/shared/definition55.cjs +251 -311
- package/shared/definition55.js +251 -311
- package/shared/definition56.cjs +299 -780
- package/shared/definition56.js +298 -779
- package/shared/definition57.cjs +800 -102
- package/shared/definition57.js +799 -101
- package/shared/definition58.cjs +92 -63
- package/shared/definition58.js +91 -62
- package/shared/definition59.cjs +117 -75
- package/shared/definition59.js +116 -74
- package/shared/definition60.cjs +70 -285
- package/shared/definition60.js +71 -286
- package/shared/definition61.cjs +274 -66146
- package/shared/definition61.js +273 -66145
- package/shared/definition62.cjs +66160 -27
- package/shared/definition62.js +66158 -25
- package/shared/definition63.cjs +24 -1952
- package/shared/definition63.js +23 -1950
- package/shared/definition64.cjs +1976 -0
- package/shared/definition64.js +1971 -0
- package/shared/listbox-option.cjs +204 -0
- package/shared/listbox-option.js +201 -0
- package/shared/listbox.cjs +3 -3
- package/shared/listbox.js +1 -1
- package/shared/localization/Locale.d.ts +4 -0
- package/shared/presentationDate.cjs +2 -2
- package/shared/presentationDate.js +2 -2
- package/shared/scrollIntoView.cjs +51 -0
- package/shared/scrollIntoView.js +49 -0
- package/shared/slider.template.cjs +1 -1
- package/shared/slider.template.js +1 -1
- package/shared/text-field.cjs +1 -1
- package/shared/text-field.js +1 -1
- package/shared/utils/scrollIntoView.d.ts +1 -0
- package/side-drawer/index.cjs +1 -1
- package/side-drawer/index.js +1 -1
- package/slider/index.cjs +1 -1
- package/slider/index.js +1 -1
- package/split-button/index.cjs +1 -1
- package/split-button/index.js +1 -1
- package/styles/core/all.css +1 -1
- package/styles/core/theme.css +1 -1
- package/styles/core/typography.css +1 -1
- package/styles/tokens/theme-dark.css +4 -4
- package/styles/tokens/theme-light.css +4 -4
- package/styles/tokens/vivid-2-compat.css +1 -1
- package/switch/index.cjs +1 -1
- package/switch/index.js +1 -1
- package/tab/index.cjs +1 -1
- package/tab/index.js +1 -1
- package/tab-panel/index.cjs +1 -1
- package/tab-panel/index.js +1 -1
- package/tabs/index.cjs +1 -1
- package/tabs/index.js +1 -1
- package/tag/index.cjs +1 -1
- package/tag/index.js +1 -1
- package/tag-group/index.cjs +1 -1
- package/tag-group/index.js +1 -1
- package/text-area/index.cjs +1 -1
- package/text-area/index.js +1 -1
- package/text-field/index.cjs +1 -1
- package/text-field/index.js +1 -1
- package/time-picker/index.cjs +1 -1
- package/time-picker/index.js +1 -1
- package/toggletip/index.cjs +1 -1
- package/toggletip/index.js +1 -1
- package/tooltip/index.cjs +1 -1
- package/tooltip/index.js +1 -1
- package/tree-item/index.cjs +1 -1
- package/tree-item/index.js +1 -1
- package/tree-view/index.cjs +1 -1
- package/tree-view/index.js +1 -1
- package/video-player/index.cjs +1 -1
- package/video-player/index.js +1 -1
- package/vivid.api.json +295 -0
- package/api-extractor.json +0 -25
- package/tsdoc-metadata.json +0 -11
package/shared/definition53.cjs
CHANGED
|
@@ -1,13 +1,10 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
3
|
const index = require('./index.cjs');
|
|
4
|
-
const definition = require('./definition27.cjs');
|
|
5
|
-
const affix = require('./affix.cjs');
|
|
6
|
-
const applyMixins = require('./apply-mixins.cjs');
|
|
7
|
-
const icon = require('./icon.cjs');
|
|
8
|
-
const when = require('./when.cjs');
|
|
9
4
|
const classNames = require('./class-names.cjs');
|
|
10
5
|
|
|
6
|
+
const styles = ".base{display:flex;flex-wrap:wrap;gap:8px}";
|
|
7
|
+
|
|
11
8
|
var __defProp = Object.defineProperty;
|
|
12
9
|
var __decorateClass = (decorators, target, key, kind) => {
|
|
13
10
|
var result = void 0 ;
|
|
@@ -17,132 +14,40 @@ var __decorateClass = (decorators, target, key, kind) => {
|
|
|
17
14
|
if (result) __defProp(target, key, result);
|
|
18
15
|
return result;
|
|
19
16
|
};
|
|
20
|
-
class
|
|
17
|
+
class TagGroup extends index.FoundationElement {
|
|
21
18
|
constructor() {
|
|
22
19
|
super(...arguments);
|
|
23
|
-
this.
|
|
24
|
-
this.disabled = false;
|
|
25
|
-
this.selectable = false;
|
|
26
|
-
this.selected = false;
|
|
27
|
-
this.#select = () => {
|
|
28
|
-
if (!this.selectable || this.disabled) {
|
|
29
|
-
return;
|
|
30
|
-
}
|
|
31
|
-
this.selected = !this.selected;
|
|
32
|
-
this.$emit("selected-change");
|
|
33
|
-
};
|
|
34
|
-
}
|
|
35
|
-
remove() {
|
|
36
|
-
if (!this.removable || this.selectable) {
|
|
37
|
-
return;
|
|
38
|
-
}
|
|
39
|
-
this.$emit("removed");
|
|
40
|
-
this.parentElement && this.parentElement.removeChild(this);
|
|
41
|
-
}
|
|
42
|
-
#select;
|
|
43
|
-
handleKeydown(e) {
|
|
44
|
-
if (e.key === "Enter") {
|
|
45
|
-
this.#select();
|
|
46
|
-
}
|
|
47
|
-
if (e.key === "Delete" || e.key === "Backspace") {
|
|
48
|
-
this.remove();
|
|
49
|
-
}
|
|
50
|
-
return true;
|
|
51
|
-
}
|
|
52
|
-
handleClick() {
|
|
53
|
-
this.#select();
|
|
20
|
+
this.ariaLabel = null;
|
|
54
21
|
}
|
|
55
22
|
}
|
|
56
23
|
__decorateClass([
|
|
57
|
-
index.attr
|
|
58
|
-
],
|
|
59
|
-
__decorateClass([
|
|
60
|
-
index.attr
|
|
61
|
-
], Tag.prototype, "shape");
|
|
62
|
-
__decorateClass([
|
|
63
|
-
index.attr
|
|
64
|
-
], Tag.prototype, "appearance");
|
|
65
|
-
__decorateClass([
|
|
66
|
-
index.attr
|
|
67
|
-
], Tag.prototype, "label");
|
|
68
|
-
__decorateClass([
|
|
69
|
-
index.attr({ mode: "boolean" })
|
|
70
|
-
], Tag.prototype, "removable");
|
|
71
|
-
__decorateClass([
|
|
72
|
-
index.attr({ mode: "boolean" })
|
|
73
|
-
], Tag.prototype, "disabled");
|
|
74
|
-
__decorateClass([
|
|
75
|
-
index.attr({ mode: "boolean" })
|
|
76
|
-
], Tag.prototype, "selectable");
|
|
77
|
-
__decorateClass([
|
|
78
|
-
index.attr({ mode: "boolean" })
|
|
79
|
-
], Tag.prototype, "selected");
|
|
80
|
-
applyMixins.applyMixins(Tag, affix.AffixIcon);
|
|
81
|
-
|
|
82
|
-
const styles = ".base.connotation-cta{--_connotation-color-contrast: var(--vvd-tag-cta-contrast, var(--vvd-color-cta-800));--_connotation-color-soft: var(--vvd-tag-cta-soft, var(--vvd-color-cta-100));--_connotation-color-pale: var(--vvd-tag-cta-pale, var(--vvd-color-cta-300));--_connotation-color-fierce: var(--vvd-tag-cta-fierce, var(--vvd-color-cta-700));--_connotation-color-firm-all: var(--vvd-tag-cta-firm-all, var(--vvd-color-cta-600));--_connotation-color-faint: var(--vvd-tag-cta-faint, var(--vvd-color-cta-50));--_connotation-color-dim: var(--vvd-tag-cta-dim, var(--vvd-color-cta-200))}.base:not(.connotation-cta){--_connotation-color-contrast: var(--vvd-tag-accent-contrast, var(--vvd-color-neutral-800));--_connotation-color-soft: var(--vvd-tag-accent-soft, var(--vvd-color-neutral-100));--_connotation-color-pale: var(--vvd-tag-accent-pale, var(--vvd-color-neutral-300));--_connotation-color-fierce: var(--vvd-tag-accent-fierce, var(--vvd-color-neutral-700));--_connotation-color-firm-all: var(--vvd-tag-accent-firm-all, var(--vvd-color-neutral-600));--_connotation-color-faint: var(--vvd-tag-accent-faint, var(--vvd-color-neutral-50));--_connotation-color-dim: var(--vvd-tag-accent-dim, var(--vvd-color-neutral-200))}.base{--_appearance-color-text: var(--_connotation-color-contrast);--_appearance-color-fill: var(--_connotation-color-soft);--_appearance-color-outline: transparent}.base.appearance-duotone{--_appearance-color-text: var(--_connotation-color-firm-all);--_appearance-color-fill: transparent;--_appearance-color-outline: var(--_connotation-color-pale)}.base:where(.hover,:hover):where(:not(.disabled,:disabled,.readonly)){--_appearance-color-text: var(--_connotation-color-contrast);--_appearance-color-fill: var(--_connotation-color-faint);--_appearance-color-outline: transparent}.base:where(.hover,:hover):where(:not(.disabled,:disabled,.readonly)).appearance-duotone{--_appearance-color-text: var(--_connotation-color-firm-all);--_appearance-color-fill: transparent;--_appearance-color-outline: var(--_connotation-color-firm-all)}.base:where(.active,:active):where(:not(.disabled,:disabled)){--_appearance-color-text: var(--_connotation-color-contrast);--_appearance-color-fill: var(--_connotation-color-dim);--_appearance-color-outline: transparent}.base:where(.active,:active):where(:not(.disabled,:disabled)).appearance-duotone{--_appearance-color-text: var(--_connotation-color-firm-all);--_appearance-color-fill: var(--_connotation-color-faint);--_appearance-color-outline: var(--_connotation-color-pale)}.base:where(.disabled,:disabled){--_appearance-color-text: var(--vvd-color-neutral-300);--_appearance-color-fill: var(--vvd-color-neutral-100);--_appearance-color-outline: transparent}.base:where(.disabled,:disabled).appearance-duotone{--_appearance-color-text: var(--vvd-color-neutral-300);--_appearance-color-fill: transparent;--_appearance-color-outline: var(--vvd-color-neutral-100)}.base:where(.selected):where(:not(.disabled,:disabled)){--_appearance-color-text: var(--_connotation-color-contrast);--_appearance-color-fill: var(--_connotation-color-pale);--_appearance-color-outline: transparent}.base:where(.selected):where(:not(.disabled,:disabled)).appearance-duotone{--_appearance-color-text: var(--_connotation-color-firm-all);--_appearance-color-fill: var(--_connotation-color-soft);--_appearance-color-outline: var(--_connotation-color-pale)}.base{--tag-block-size: calc(1px*(24 + 4*clamp(-1, var(--vvd-size-density, 0), 2))) ;position:relative;display:inline-flex;box-sizing:border-box;align-items:center;background-color:var(--_appearance-color-fill);block-size:var(--tag-block-size);box-shadow:inset 0 0 0 1px var(--_appearance-color-outline);color:var(--_appearance-color-text);column-gap:8px;font:var(--vvd-typography-base-bold);max-inline-size:100%;padding-inline:8px;vertical-align:middle}.base:not(.shape-pill){border-radius:4px}.base.shape-pill{border-radius:16px}.base:focus-visible{--focus-stroke-gap-color: transparent;box-shadow:inset 0 0 0 3px var(--focus-stroke-gap-color, currentColor);outline:2px solid var(--focus-stroke-color, var(--vvd-color-canvas-text));outline-offset:calc(-2px - var(--focus-inset, 0px))}@supports (user-select: none){.base{user-select:none}}.base:not(.disabled){cursor:pointer}.base.disabled{cursor:not-allowed;pointer-events:none}.base.removable{cursor:auto}.label{overflow:hidden;max-inline-size:100%;text-overflow:ellipsis;white-space:nowrap}slot[name=icon]{font-size:calc(var(--tag-block-size) / 1.5);line-height:1}.dismiss-button{display:flex;align-items:center;border-radius:inherit;background-color:var(--_appearance-color-fill);cursor:pointer}";
|
|
24
|
+
index.attr({ attribute: "aria-label" })
|
|
25
|
+
], TagGroup.prototype, "ariaLabel");
|
|
83
26
|
|
|
84
|
-
const getClasses = (
|
|
85
|
-
|
|
86
|
-
appearance,
|
|
87
|
-
shape,
|
|
88
|
-
disabled,
|
|
89
|
-
selectable,
|
|
90
|
-
removable,
|
|
91
|
-
selected
|
|
92
|
-
}) => classNames.classNames(
|
|
93
|
-
"base",
|
|
94
|
-
["disabled", disabled],
|
|
95
|
-
["selectable", selectable],
|
|
96
|
-
["selected", selectable && selected],
|
|
97
|
-
["removable", removable && !selectable],
|
|
98
|
-
[`connotation-${connotation}`, Boolean(connotation)],
|
|
99
|
-
[`appearance-${appearance}`, Boolean(appearance)],
|
|
100
|
-
[`shape-${shape}`, Boolean(shape)]
|
|
101
|
-
);
|
|
102
|
-
function renderDismissButton(iconTag) {
|
|
27
|
+
const getClasses = (_) => classNames.classNames("base");
|
|
28
|
+
const TagGroupTemplate = () => {
|
|
103
29
|
return index.html`
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
const iconTag = context.tagFor(icon.Icon);
|
|
114
|
-
return index.html` <span
|
|
115
|
-
class="${getClasses}"
|
|
116
|
-
role="option"
|
|
117
|
-
aria-disabled="${(x) => x.disabled}"
|
|
118
|
-
aria-selected="${(x) => x.selectable}"
|
|
119
|
-
tabindex="${(x) => x.disabled ? null : 0}"
|
|
120
|
-
@keydown="${(x, c) => x.handleKeydown(c.event)}"
|
|
121
|
-
@click="${(x) => x.handleClick()}"
|
|
122
|
-
>
|
|
123
|
-
${(x) => affixIconTemplate(x.icon, affix.IconWrapper.Slot)}
|
|
124
|
-
${when.when(
|
|
125
|
-
(x) => x.label,
|
|
126
|
-
(x) => index.html`<span class="label">${x.label}</span>`
|
|
127
|
-
)}
|
|
128
|
-
${when.when((x) => x.removable && !x.selectable, renderDismissButton(iconTag))}
|
|
129
|
-
${when.when(
|
|
130
|
-
(x) => x.selectable && x.selected,
|
|
131
|
-
index.html`<${iconTag} class="selectable-icon" name="check-circle-solid"></${iconTag}>`
|
|
132
|
-
)}
|
|
133
|
-
</span>`;
|
|
30
|
+
<div
|
|
31
|
+
class="${getClasses}"
|
|
32
|
+
role="listbox"
|
|
33
|
+
aria-orientation="horizontal"
|
|
34
|
+
aria-label="${(x) => x.ariaLabel}"
|
|
35
|
+
>
|
|
36
|
+
<slot></slot>
|
|
37
|
+
</div>
|
|
38
|
+
`;
|
|
134
39
|
};
|
|
135
40
|
|
|
136
|
-
const
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
delegatesFocus: true
|
|
41
|
+
const tagGroupDefinition = TagGroup.compose(
|
|
42
|
+
{
|
|
43
|
+
baseName: "tag-group",
|
|
44
|
+
template: TagGroupTemplate,
|
|
45
|
+
styles
|
|
142
46
|
}
|
|
143
|
-
|
|
144
|
-
const
|
|
145
|
-
const
|
|
47
|
+
);
|
|
48
|
+
const tagGroupRegistries = [tagGroupDefinition()];
|
|
49
|
+
const registerTagGroup = index.registerFactory(tagGroupRegistries);
|
|
146
50
|
|
|
147
|
-
exports.
|
|
148
|
-
exports.
|
|
51
|
+
exports.registerTagGroup = registerTagGroup;
|
|
52
|
+
exports.tagGroupDefinition = tagGroupDefinition;
|
|
53
|
+
exports.tagGroupRegistries = tagGroupRegistries;
|
package/shared/definition53.js
CHANGED
|
@@ -1,11 +1,8 @@
|
|
|
1
1
|
import { F as FoundationElement, a as attr, h as html, r as registerFactory } from './index.js';
|
|
2
|
-
import { a as iconRegistries } from './definition27.js';
|
|
3
|
-
import { A as AffixIcon, a as affixIconTemplateFactory, I as IconWrapper } from './affix.js';
|
|
4
|
-
import { a as applyMixins } from './apply-mixins.js';
|
|
5
|
-
import { I as Icon } from './icon.js';
|
|
6
|
-
import { w as when } from './when.js';
|
|
7
2
|
import { c as classNames } from './class-names.js';
|
|
8
3
|
|
|
4
|
+
const styles = ".base{display:flex;flex-wrap:wrap;gap:8px}";
|
|
5
|
+
|
|
9
6
|
var __defProp = Object.defineProperty;
|
|
10
7
|
var __decorateClass = (decorators, target, key, kind) => {
|
|
11
8
|
var result = void 0 ;
|
|
@@ -15,131 +12,38 @@ var __decorateClass = (decorators, target, key, kind) => {
|
|
|
15
12
|
if (result) __defProp(target, key, result);
|
|
16
13
|
return result;
|
|
17
14
|
};
|
|
18
|
-
class
|
|
15
|
+
class TagGroup extends FoundationElement {
|
|
19
16
|
constructor() {
|
|
20
17
|
super(...arguments);
|
|
21
|
-
this.
|
|
22
|
-
this.disabled = false;
|
|
23
|
-
this.selectable = false;
|
|
24
|
-
this.selected = false;
|
|
25
|
-
this.#select = () => {
|
|
26
|
-
if (!this.selectable || this.disabled) {
|
|
27
|
-
return;
|
|
28
|
-
}
|
|
29
|
-
this.selected = !this.selected;
|
|
30
|
-
this.$emit("selected-change");
|
|
31
|
-
};
|
|
32
|
-
}
|
|
33
|
-
remove() {
|
|
34
|
-
if (!this.removable || this.selectable) {
|
|
35
|
-
return;
|
|
36
|
-
}
|
|
37
|
-
this.$emit("removed");
|
|
38
|
-
this.parentElement && this.parentElement.removeChild(this);
|
|
39
|
-
}
|
|
40
|
-
#select;
|
|
41
|
-
handleKeydown(e) {
|
|
42
|
-
if (e.key === "Enter") {
|
|
43
|
-
this.#select();
|
|
44
|
-
}
|
|
45
|
-
if (e.key === "Delete" || e.key === "Backspace") {
|
|
46
|
-
this.remove();
|
|
47
|
-
}
|
|
48
|
-
return true;
|
|
49
|
-
}
|
|
50
|
-
handleClick() {
|
|
51
|
-
this.#select();
|
|
18
|
+
this.ariaLabel = null;
|
|
52
19
|
}
|
|
53
20
|
}
|
|
54
21
|
__decorateClass([
|
|
55
|
-
attr
|
|
56
|
-
],
|
|
57
|
-
__decorateClass([
|
|
58
|
-
attr
|
|
59
|
-
], Tag.prototype, "shape");
|
|
60
|
-
__decorateClass([
|
|
61
|
-
attr
|
|
62
|
-
], Tag.prototype, "appearance");
|
|
63
|
-
__decorateClass([
|
|
64
|
-
attr
|
|
65
|
-
], Tag.prototype, "label");
|
|
66
|
-
__decorateClass([
|
|
67
|
-
attr({ mode: "boolean" })
|
|
68
|
-
], Tag.prototype, "removable");
|
|
69
|
-
__decorateClass([
|
|
70
|
-
attr({ mode: "boolean" })
|
|
71
|
-
], Tag.prototype, "disabled");
|
|
72
|
-
__decorateClass([
|
|
73
|
-
attr({ mode: "boolean" })
|
|
74
|
-
], Tag.prototype, "selectable");
|
|
75
|
-
__decorateClass([
|
|
76
|
-
attr({ mode: "boolean" })
|
|
77
|
-
], Tag.prototype, "selected");
|
|
78
|
-
applyMixins(Tag, AffixIcon);
|
|
79
|
-
|
|
80
|
-
const styles = ".base.connotation-cta{--_connotation-color-contrast: var(--vvd-tag-cta-contrast, var(--vvd-color-cta-800));--_connotation-color-soft: var(--vvd-tag-cta-soft, var(--vvd-color-cta-100));--_connotation-color-pale: var(--vvd-tag-cta-pale, var(--vvd-color-cta-300));--_connotation-color-fierce: var(--vvd-tag-cta-fierce, var(--vvd-color-cta-700));--_connotation-color-firm-all: var(--vvd-tag-cta-firm-all, var(--vvd-color-cta-600));--_connotation-color-faint: var(--vvd-tag-cta-faint, var(--vvd-color-cta-50));--_connotation-color-dim: var(--vvd-tag-cta-dim, var(--vvd-color-cta-200))}.base:not(.connotation-cta){--_connotation-color-contrast: var(--vvd-tag-accent-contrast, var(--vvd-color-neutral-800));--_connotation-color-soft: var(--vvd-tag-accent-soft, var(--vvd-color-neutral-100));--_connotation-color-pale: var(--vvd-tag-accent-pale, var(--vvd-color-neutral-300));--_connotation-color-fierce: var(--vvd-tag-accent-fierce, var(--vvd-color-neutral-700));--_connotation-color-firm-all: var(--vvd-tag-accent-firm-all, var(--vvd-color-neutral-600));--_connotation-color-faint: var(--vvd-tag-accent-faint, var(--vvd-color-neutral-50));--_connotation-color-dim: var(--vvd-tag-accent-dim, var(--vvd-color-neutral-200))}.base{--_appearance-color-text: var(--_connotation-color-contrast);--_appearance-color-fill: var(--_connotation-color-soft);--_appearance-color-outline: transparent}.base.appearance-duotone{--_appearance-color-text: var(--_connotation-color-firm-all);--_appearance-color-fill: transparent;--_appearance-color-outline: var(--_connotation-color-pale)}.base:where(.hover,:hover):where(:not(.disabled,:disabled,.readonly)){--_appearance-color-text: var(--_connotation-color-contrast);--_appearance-color-fill: var(--_connotation-color-faint);--_appearance-color-outline: transparent}.base:where(.hover,:hover):where(:not(.disabled,:disabled,.readonly)).appearance-duotone{--_appearance-color-text: var(--_connotation-color-firm-all);--_appearance-color-fill: transparent;--_appearance-color-outline: var(--_connotation-color-firm-all)}.base:where(.active,:active):where(:not(.disabled,:disabled)){--_appearance-color-text: var(--_connotation-color-contrast);--_appearance-color-fill: var(--_connotation-color-dim);--_appearance-color-outline: transparent}.base:where(.active,:active):where(:not(.disabled,:disabled)).appearance-duotone{--_appearance-color-text: var(--_connotation-color-firm-all);--_appearance-color-fill: var(--_connotation-color-faint);--_appearance-color-outline: var(--_connotation-color-pale)}.base:where(.disabled,:disabled){--_appearance-color-text: var(--vvd-color-neutral-300);--_appearance-color-fill: var(--vvd-color-neutral-100);--_appearance-color-outline: transparent}.base:where(.disabled,:disabled).appearance-duotone{--_appearance-color-text: var(--vvd-color-neutral-300);--_appearance-color-fill: transparent;--_appearance-color-outline: var(--vvd-color-neutral-100)}.base:where(.selected):where(:not(.disabled,:disabled)){--_appearance-color-text: var(--_connotation-color-contrast);--_appearance-color-fill: var(--_connotation-color-pale);--_appearance-color-outline: transparent}.base:where(.selected):where(:not(.disabled,:disabled)).appearance-duotone{--_appearance-color-text: var(--_connotation-color-firm-all);--_appearance-color-fill: var(--_connotation-color-soft);--_appearance-color-outline: var(--_connotation-color-pale)}.base{--tag-block-size: calc(1px*(24 + 4*clamp(-1, var(--vvd-size-density, 0), 2))) ;position:relative;display:inline-flex;box-sizing:border-box;align-items:center;background-color:var(--_appearance-color-fill);block-size:var(--tag-block-size);box-shadow:inset 0 0 0 1px var(--_appearance-color-outline);color:var(--_appearance-color-text);column-gap:8px;font:var(--vvd-typography-base-bold);max-inline-size:100%;padding-inline:8px;vertical-align:middle}.base:not(.shape-pill){border-radius:4px}.base.shape-pill{border-radius:16px}.base:focus-visible{--focus-stroke-gap-color: transparent;box-shadow:inset 0 0 0 3px var(--focus-stroke-gap-color, currentColor);outline:2px solid var(--focus-stroke-color, var(--vvd-color-canvas-text));outline-offset:calc(-2px - var(--focus-inset, 0px))}@supports (user-select: none){.base{user-select:none}}.base:not(.disabled){cursor:pointer}.base.disabled{cursor:not-allowed;pointer-events:none}.base.removable{cursor:auto}.label{overflow:hidden;max-inline-size:100%;text-overflow:ellipsis;white-space:nowrap}slot[name=icon]{font-size:calc(var(--tag-block-size) / 1.5);line-height:1}.dismiss-button{display:flex;align-items:center;border-radius:inherit;background-color:var(--_appearance-color-fill);cursor:pointer}";
|
|
22
|
+
attr({ attribute: "aria-label" })
|
|
23
|
+
], TagGroup.prototype, "ariaLabel");
|
|
81
24
|
|
|
82
|
-
const getClasses = (
|
|
83
|
-
|
|
84
|
-
appearance,
|
|
85
|
-
shape,
|
|
86
|
-
disabled,
|
|
87
|
-
selectable,
|
|
88
|
-
removable,
|
|
89
|
-
selected
|
|
90
|
-
}) => classNames(
|
|
91
|
-
"base",
|
|
92
|
-
["disabled", disabled],
|
|
93
|
-
["selectable", selectable],
|
|
94
|
-
["selected", selectable && selected],
|
|
95
|
-
["removable", removable && !selectable],
|
|
96
|
-
[`connotation-${connotation}`, Boolean(connotation)],
|
|
97
|
-
[`appearance-${appearance}`, Boolean(appearance)],
|
|
98
|
-
[`shape-${shape}`, Boolean(shape)]
|
|
99
|
-
);
|
|
100
|
-
function renderDismissButton(iconTag) {
|
|
25
|
+
const getClasses = (_) => classNames("base");
|
|
26
|
+
const TagGroupTemplate = () => {
|
|
101
27
|
return html`
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
const iconTag = context.tagFor(Icon);
|
|
112
|
-
return html` <span
|
|
113
|
-
class="${getClasses}"
|
|
114
|
-
role="option"
|
|
115
|
-
aria-disabled="${(x) => x.disabled}"
|
|
116
|
-
aria-selected="${(x) => x.selectable}"
|
|
117
|
-
tabindex="${(x) => x.disabled ? null : 0}"
|
|
118
|
-
@keydown="${(x, c) => x.handleKeydown(c.event)}"
|
|
119
|
-
@click="${(x) => x.handleClick()}"
|
|
120
|
-
>
|
|
121
|
-
${(x) => affixIconTemplate(x.icon, IconWrapper.Slot)}
|
|
122
|
-
${when(
|
|
123
|
-
(x) => x.label,
|
|
124
|
-
(x) => html`<span class="label">${x.label}</span>`
|
|
125
|
-
)}
|
|
126
|
-
${when((x) => x.removable && !x.selectable, renderDismissButton(iconTag))}
|
|
127
|
-
${when(
|
|
128
|
-
(x) => x.selectable && x.selected,
|
|
129
|
-
html`<${iconTag} class="selectable-icon" name="check-circle-solid"></${iconTag}>`
|
|
130
|
-
)}
|
|
131
|
-
</span>`;
|
|
28
|
+
<div
|
|
29
|
+
class="${getClasses}"
|
|
30
|
+
role="listbox"
|
|
31
|
+
aria-orientation="horizontal"
|
|
32
|
+
aria-label="${(x) => x.ariaLabel}"
|
|
33
|
+
>
|
|
34
|
+
<slot></slot>
|
|
35
|
+
</div>
|
|
36
|
+
`;
|
|
132
37
|
};
|
|
133
38
|
|
|
134
|
-
const
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
delegatesFocus: true
|
|
39
|
+
const tagGroupDefinition = TagGroup.compose(
|
|
40
|
+
{
|
|
41
|
+
baseName: "tag-group",
|
|
42
|
+
template: TagGroupTemplate,
|
|
43
|
+
styles
|
|
140
44
|
}
|
|
141
|
-
|
|
142
|
-
const
|
|
143
|
-
const
|
|
45
|
+
);
|
|
46
|
+
const tagGroupRegistries = [tagGroupDefinition()];
|
|
47
|
+
const registerTagGroup = registerFactory(tagGroupRegistries);
|
|
144
48
|
|
|
145
|
-
export {
|
|
49
|
+
export { tagGroupRegistries as a, registerTagGroup as r, tagGroupDefinition as t };
|