@vonage/vivid 3.37.0 → 3.39.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.
Files changed (157) hide show
  1. package/accordion/index.js +2 -2
  2. package/accordion-item/index.js +2 -2
  3. package/alert/index.js +4 -4
  4. package/avatar/index.js +1 -1
  5. package/badge/index.js +1 -1
  6. package/banner/index.js +3 -3
  7. package/breadcrumb-item/index.js +2 -2
  8. package/button/index.js +3 -3
  9. package/card/index.js +2 -2
  10. package/checkbox/index.js +2 -2
  11. package/combobox/index.js +6 -6
  12. package/custom-elements.json +4199 -3875
  13. package/data-grid/index.js +1 -1
  14. package/date-picker/index.js +9 -7
  15. package/date-range-picker/index.js +36 -0
  16. package/dialog/index.js +5 -5
  17. package/divider/index.js +1 -1
  18. package/elevation/index.js +1 -1
  19. package/empty-state/index.js +2 -2
  20. package/fab/index.js +3 -3
  21. package/file-picker/index.js +5 -4
  22. package/focus/index.js +1 -1
  23. package/header/index.js +2 -2
  24. package/icon/index.js +1 -1
  25. package/index.js +43 -40
  26. package/layout/index.js +1 -1
  27. package/lib/components.d.ts +1 -0
  28. package/lib/date-picker/date-picker.d.ts +4 -14
  29. package/lib/date-range-picker/date-range-picker.d.ts +15 -0
  30. package/lib/date-range-picker/definition.d.ts +3 -0
  31. package/lib/file-picker/file-picker.d.ts +8 -5
  32. package/lib/file-picker/file-picker.form-associated.d.ts +10 -0
  33. package/lib/file-picker/locale.d.ts +6 -0
  34. package/lib/menu-item/menu-item.d.ts +6 -0
  35. package/lib/tag-group/tag-group.d.ts +1 -0
  36. package/listbox/index.js +4 -4
  37. package/locales/en-GB.js +27 -3
  38. package/locales/en-US.js +27 -3
  39. package/locales/ja-JP.js +25 -1
  40. package/locales/zh-CN.js +25 -1
  41. package/menu/index.js +7 -7
  42. package/menu-item/index.js +3 -3
  43. package/nav/index.js +1 -1
  44. package/nav-disclosure/index.js +3 -3
  45. package/nav-item/index.js +3 -3
  46. package/note/index.js +2 -2
  47. package/number-field/index.js +5 -5
  48. package/option/index.js +3 -3
  49. package/package.json +1 -1
  50. package/pagination/index.js +4 -4
  51. package/popup/index.js +5 -5
  52. package/progress/index.js +1 -1
  53. package/progress-ring/index.js +1 -1
  54. package/radio/index.js +2 -2
  55. package/radio-group/index.js +1 -1
  56. package/select/index.js +7 -7
  57. package/shared/date-picker/calendar/dateRange.d.ts +5 -0
  58. package/shared/date-picker/calendar/presentationDateRange.d.ts +5 -0
  59. package/shared/date-picker/date-picker-base.d.ts +19 -0
  60. package/shared/date-picker/date-picker-base.form-associated.d.ts +10 -0
  61. package/shared/date-picker/date-picker-base.template.d.ts +4 -0
  62. package/{lib → shared}/date-picker/locale.d.ts +6 -0
  63. package/shared/definition.js +4 -4
  64. package/shared/definition10.js +9 -14
  65. package/shared/definition11.js +1 -1
  66. package/shared/definition12.js +1 -1
  67. package/shared/definition13.js +3 -3
  68. package/shared/definition14.js +3 -3
  69. package/shared/definition15.js +5 -5
  70. package/shared/definition16.js +3 -3
  71. package/shared/definition17.js +44 -6055
  72. package/shared/definition18.js +353 -213
  73. package/shared/definition19.js +251 -67
  74. package/shared/definition2.js +1 -1
  75. package/shared/definition20.js +66 -58
  76. package/shared/definition21.js +43 -84
  77. package/shared/definition22.js +75 -2298
  78. package/shared/definition23.js +2361 -45
  79. package/shared/definition24.js +63 -27
  80. package/shared/definition25.js +24 -51
  81. package/shared/definition26.js +36 -805
  82. package/shared/definition27.js +828 -49
  83. package/shared/definition28.js +52 -89
  84. package/shared/definition29.js +88 -24
  85. package/shared/definition3.js +1 -1
  86. package/shared/definition30.js +25 -12
  87. package/shared/definition31.js +12 -53
  88. package/shared/definition32.js +28 -487
  89. package/shared/definition33.js +427 -197
  90. package/shared/definition34.js +260 -174
  91. package/shared/definition35.js +187 -69
  92. package/shared/definition36.js +68 -55
  93. package/shared/definition37.js +61 -421
  94. package/shared/definition38.js +435 -35
  95. package/shared/definition39.js +30 -679
  96. package/shared/definition4.js +3 -3
  97. package/shared/definition40.js +661 -77
  98. package/shared/definition41.js +77 -557
  99. package/shared/definition42.js +559 -106
  100. package/shared/definition43.js +105 -136
  101. package/shared/definition44.js +153 -17
  102. package/shared/definition45.js +16 -79
  103. package/shared/definition46.js +53 -475
  104. package/shared/definition47.js +506 -20
  105. package/shared/definition48.js +22 -121
  106. package/shared/definition49.js +115 -262
  107. package/shared/definition5.js +2 -2
  108. package/shared/definition50.js +248 -120
  109. package/shared/definition51.js +139 -123
  110. package/shared/definition52.js +84 -74
  111. package/shared/definition53.js +114 -69
  112. package/shared/definition54.js +81 -292
  113. package/shared/definition55.js +302 -13
  114. package/shared/definition56.js +11 -41
  115. package/shared/definition57.js +20 -154
  116. package/shared/definition58.js +181 -0
  117. package/shared/definition6.js +2 -2
  118. package/shared/definition7.js +2 -2
  119. package/shared/definition8.js +3 -3
  120. package/shared/index2.js +1 -1
  121. package/shared/listbox.js +1 -1
  122. package/shared/localization/Locale.d.ts +3 -1
  123. package/shared/localized.js +9 -0
  124. package/shared/presentationDate.js +6133 -0
  125. package/shared/text-anchor.template.js +4 -4
  126. package/shared/text-field.js +1 -1
  127. package/side-drawer/index.js +1 -1
  128. package/slider/index.js +2 -2
  129. package/split-button/index.js +3 -3
  130. package/style.css +246 -183
  131. package/styles/core/all.css +1 -1
  132. package/styles/core/theme.css +1 -1
  133. package/styles/core/typography.css +1 -1
  134. package/styles/tokens/theme-dark.css +4 -4
  135. package/styles/tokens/theme-light.css +4 -4
  136. package/styles/tokens/vivid-2-compat.css +1 -1
  137. package/switch/index.js +3 -3
  138. package/tab/index.js +3 -3
  139. package/tab-panel/index.js +1 -1
  140. package/tabs/index.js +5 -5
  141. package/tag/index.js +3 -3
  142. package/tag-group/index.js +1 -1
  143. package/text-area/index.js +3 -3
  144. package/text-field/index.js +3 -3
  145. package/toggletip/index.js +6 -6
  146. package/tooltip/index.js +6 -6
  147. package/tree-item/index.js +3 -3
  148. package/tree-view/index.js +1 -1
  149. package/vivid.api.json +105 -0
  150. package/lib/date-picker/date-picker.form-associated.d.ts +0 -11
  151. package/lib/date-picker/date-picker.template.d.ts +0 -4
  152. /package/{lib → shared}/date-picker/calendar/calendarGrid.d.ts +0 -0
  153. /package/{lib → shared}/date-picker/calendar/dateStr.d.ts +0 -0
  154. /package/{lib → shared}/date-picker/calendar/month.d.ts +0 -0
  155. /package/{lib → shared}/date-picker/calendar/monthPickerGrid.d.ts +0 -0
  156. /package/{lib → shared}/date-picker/calendar/presentationDate.d.ts +0 -0
  157. /package/{lib → shared}/date-picker/calendar/year.d.ts +0 -0
@@ -1,399 +1,9 @@
1
- import { F as FoundationElement, _ as __decorate, a as attr, o as observable, h as html, r as registerFactory } from './index.js';
2
- import { D as Direction, g as getDirection } from './direction.js';
3
- import { h as keyArrowRight, i as keyArrowLeft, A as ArrowKeys, e as keyArrowUp, d as keyArrowDown, k as keyEnter } from './key-codes.js';
4
- import { O as Orientation } from './aria.js';
5
- import { R as Radio } from './radio.js';
6
- import { O as Orientation$1 } from './aria2.js';
7
- import { s as slotted, e as elements } from './slotted.js';
1
+ import { a as attr, h as html, r as registerFactory } from './index.js';
2
+ import { B as BaseProgress } from './base-progress.js';
8
3
  import { w as when } from './when.js';
4
+ import { c as classNames } from './class-names.js';
9
5
 
10
- /**
11
- * An Radio Group Custom HTML Element.
12
- * Implements the {@link https://www.w3.org/TR/wai-aria-1.1/#radiogroup | ARIA radiogroup }.
13
- *
14
- * @slot label - The slot for the label
15
- * @slot - The default slot for radio buttons
16
- * @csspart positioning-region - The positioning region for laying out the radios
17
- * @fires change - Fires a custom 'change' event when the value changes
18
- *
19
- * @public
20
- */
21
- let RadioGroup$1 = class RadioGroup extends FoundationElement {
22
- constructor() {
23
- super(...arguments);
24
- /**
25
- * The orientation of the group
26
- *
27
- * @public
28
- * @remarks
29
- * HTML Attribute: orientation
30
- */
31
- this.orientation = Orientation.horizontal;
32
- this.radioChangeHandler = (e) => {
33
- const changedRadio = e.target;
34
- if (changedRadio.checked) {
35
- this.slottedRadioButtons.forEach((radio) => {
36
- if (radio !== changedRadio) {
37
- radio.checked = false;
38
- if (!this.isInsideFoundationToolbar) {
39
- radio.setAttribute("tabindex", "-1");
40
- }
41
- }
42
- });
43
- this.selectedRadio = changedRadio;
44
- this.value = changedRadio.value;
45
- changedRadio.setAttribute("tabindex", "0");
46
- this.focusedRadio = changedRadio;
47
- }
48
- e.stopPropagation();
49
- };
50
- this.moveToRadioByIndex = (group, index) => {
51
- const radio = group[index];
52
- if (!this.isInsideToolbar) {
53
- radio.setAttribute("tabindex", "0");
54
- if (radio.readOnly) {
55
- this.slottedRadioButtons.forEach((nextRadio) => {
56
- if (nextRadio !== radio) {
57
- nextRadio.setAttribute("tabindex", "-1");
58
- }
59
- });
60
- }
61
- else {
62
- radio.checked = true;
63
- this.selectedRadio = radio;
64
- }
65
- }
66
- this.focusedRadio = radio;
67
- radio.focus();
68
- };
69
- this.moveRightOffGroup = () => {
70
- var _a;
71
- (_a = this.nextElementSibling) === null || _a === void 0 ? void 0 : _a.focus();
72
- };
73
- this.moveLeftOffGroup = () => {
74
- var _a;
75
- (_a = this.previousElementSibling) === null || _a === void 0 ? void 0 : _a.focus();
76
- };
77
- /**
78
- * @internal
79
- */
80
- this.focusOutHandler = (e) => {
81
- const group = this.slottedRadioButtons;
82
- const radio = e.target;
83
- const index = radio !== null ? group.indexOf(radio) : 0;
84
- const focusedIndex = this.focusedRadio
85
- ? group.indexOf(this.focusedRadio)
86
- : -1;
87
- if ((focusedIndex === 0 && index === focusedIndex) ||
88
- (focusedIndex === group.length - 1 && focusedIndex === index)) {
89
- if (!this.selectedRadio) {
90
- this.focusedRadio = group[0];
91
- this.focusedRadio.setAttribute("tabindex", "0");
92
- group.forEach((nextRadio) => {
93
- if (nextRadio !== this.focusedRadio) {
94
- nextRadio.setAttribute("tabindex", "-1");
95
- }
96
- });
97
- }
98
- else {
99
- this.focusedRadio = this.selectedRadio;
100
- if (!this.isInsideFoundationToolbar) {
101
- this.selectedRadio.setAttribute("tabindex", "0");
102
- group.forEach((nextRadio) => {
103
- if (nextRadio !== this.selectedRadio) {
104
- nextRadio.setAttribute("tabindex", "-1");
105
- }
106
- });
107
- }
108
- }
109
- }
110
- return true;
111
- };
112
- /**
113
- * @internal
114
- */
115
- this.clickHandler = (e) => {
116
- const radio = e.target;
117
- if (radio) {
118
- const group = this.slottedRadioButtons;
119
- if (radio.checked || group.indexOf(radio) === 0) {
120
- radio.setAttribute("tabindex", "0");
121
- this.selectedRadio = radio;
122
- }
123
- else {
124
- radio.setAttribute("tabindex", "-1");
125
- this.selectedRadio = null;
126
- }
127
- this.focusedRadio = radio;
128
- }
129
- e.preventDefault();
130
- };
131
- this.shouldMoveOffGroupToTheRight = (index, group, key) => {
132
- return index === group.length && this.isInsideToolbar && key === keyArrowRight;
133
- };
134
- this.shouldMoveOffGroupToTheLeft = (group, key) => {
135
- const index = this.focusedRadio ? group.indexOf(this.focusedRadio) - 1 : 0;
136
- return index < 0 && this.isInsideToolbar && key === keyArrowLeft;
137
- };
138
- this.checkFocusedRadio = () => {
139
- if (this.focusedRadio !== null &&
140
- !this.focusedRadio.readOnly &&
141
- !this.focusedRadio.checked) {
142
- this.focusedRadio.checked = true;
143
- this.focusedRadio.setAttribute("tabindex", "0");
144
- this.focusedRadio.focus();
145
- this.selectedRadio = this.focusedRadio;
146
- }
147
- };
148
- this.moveRight = (e) => {
149
- const group = this.slottedRadioButtons;
150
- let index = 0;
151
- index = this.focusedRadio ? group.indexOf(this.focusedRadio) + 1 : 1;
152
- if (this.shouldMoveOffGroupToTheRight(index, group, e.key)) {
153
- this.moveRightOffGroup();
154
- return;
155
- }
156
- else if (index === group.length) {
157
- index = 0;
158
- }
159
- /* looping to get to next radio that is not disabled */
160
- /* matching native radio/radiogroup which does not select an item if there is only 1 in the group */
161
- while (index < group.length && group.length > 1) {
162
- if (!group[index].disabled) {
163
- this.moveToRadioByIndex(group, index);
164
- break;
165
- }
166
- else if (this.focusedRadio && index === group.indexOf(this.focusedRadio)) {
167
- break;
168
- }
169
- else if (index + 1 >= group.length) {
170
- if (this.isInsideToolbar) {
171
- break;
172
- }
173
- else {
174
- index = 0;
175
- }
176
- }
177
- else {
178
- index += 1;
179
- }
180
- }
181
- };
182
- this.moveLeft = (e) => {
183
- const group = this.slottedRadioButtons;
184
- let index = 0;
185
- index = this.focusedRadio ? group.indexOf(this.focusedRadio) - 1 : 0;
186
- index = index < 0 ? group.length - 1 : index;
187
- if (this.shouldMoveOffGroupToTheLeft(group, e.key)) {
188
- this.moveLeftOffGroup();
189
- return;
190
- }
191
- /* looping to get to next radio that is not disabled */
192
- while (index >= 0 && group.length > 1) {
193
- if (!group[index].disabled) {
194
- this.moveToRadioByIndex(group, index);
195
- break;
196
- }
197
- else if (this.focusedRadio && index === group.indexOf(this.focusedRadio)) {
198
- break;
199
- }
200
- else if (index - 1 < 0) {
201
- index = group.length - 1;
202
- }
203
- else {
204
- index -= 1;
205
- }
206
- }
207
- };
208
- /**
209
- * keyboard handling per https://w3c.github.io/aria-practices/#for-radio-groups-not-contained-in-a-toolbar
210
- * navigation is different when there is an ancestor with role='toolbar'
211
- *
212
- * @internal
213
- */
214
- this.keydownHandler = (e) => {
215
- const key = e.key;
216
- if (key in ArrowKeys && this.isInsideFoundationToolbar) {
217
- return true;
218
- }
219
- switch (key) {
220
- case keyEnter: {
221
- this.checkFocusedRadio();
222
- break;
223
- }
224
- case keyArrowRight:
225
- case keyArrowDown: {
226
- if (this.direction === Direction.ltr) {
227
- this.moveRight(e);
228
- }
229
- else {
230
- this.moveLeft(e);
231
- }
232
- break;
233
- }
234
- case keyArrowLeft:
235
- case keyArrowUp: {
236
- if (this.direction === Direction.ltr) {
237
- this.moveLeft(e);
238
- }
239
- else {
240
- this.moveRight(e);
241
- }
242
- break;
243
- }
244
- default: {
245
- return true;
246
- }
247
- }
248
- };
249
- }
250
- readOnlyChanged() {
251
- if (this.slottedRadioButtons !== undefined) {
252
- this.slottedRadioButtons.forEach((radio) => {
253
- if (this.readOnly) {
254
- radio.readOnly = true;
255
- }
256
- else {
257
- radio.readOnly = false;
258
- }
259
- });
260
- }
261
- }
262
- disabledChanged() {
263
- if (this.slottedRadioButtons !== undefined) {
264
- this.slottedRadioButtons.forEach((radio) => {
265
- if (this.disabled) {
266
- radio.disabled = true;
267
- }
268
- else {
269
- radio.disabled = false;
270
- }
271
- });
272
- }
273
- }
274
- nameChanged() {
275
- if (this.slottedRadioButtons) {
276
- this.slottedRadioButtons.forEach((radio) => {
277
- radio.setAttribute("name", this.name);
278
- });
279
- }
280
- }
281
- valueChanged() {
282
- if (this.slottedRadioButtons) {
283
- this.slottedRadioButtons.forEach((radio) => {
284
- if (radio.value === this.value) {
285
- radio.checked = true;
286
- this.selectedRadio = radio;
287
- }
288
- });
289
- }
290
- this.$emit("change");
291
- }
292
- slottedRadioButtonsChanged(oldValue, newValue) {
293
- if (this.slottedRadioButtons && this.slottedRadioButtons.length > 0) {
294
- this.setupRadioButtons();
295
- }
296
- }
297
- get parentToolbar() {
298
- return this.closest('[role="toolbar"]');
299
- }
300
- get isInsideToolbar() {
301
- var _a;
302
- return ((_a = this.parentToolbar) !== null && _a !== void 0 ? _a : false);
303
- }
304
- get isInsideFoundationToolbar() {
305
- var _a;
306
- return !!((_a = this.parentToolbar) === null || _a === void 0 ? void 0 : _a["$fastController"]);
307
- }
308
- /**
309
- * @internal
310
- */
311
- connectedCallback() {
312
- super.connectedCallback();
313
- this.direction = getDirection(this);
314
- this.setupRadioButtons();
315
- }
316
- disconnectedCallback() {
317
- this.slottedRadioButtons.forEach((radio) => {
318
- radio.removeEventListener("change", this.radioChangeHandler);
319
- });
320
- }
321
- setupRadioButtons() {
322
- const checkedRadios = this.slottedRadioButtons.filter((radio) => {
323
- return radio.hasAttribute("checked");
324
- });
325
- const numberOfCheckedRadios = checkedRadios ? checkedRadios.length : 0;
326
- if (numberOfCheckedRadios > 1) {
327
- const lastCheckedRadio = checkedRadios[numberOfCheckedRadios - 1];
328
- lastCheckedRadio.checked = true;
329
- }
330
- let foundMatchingVal = false;
331
- this.slottedRadioButtons.forEach((radio) => {
332
- if (this.name !== undefined) {
333
- radio.setAttribute("name", this.name);
334
- }
335
- if (this.disabled) {
336
- radio.disabled = true;
337
- }
338
- if (this.readOnly) {
339
- radio.readOnly = true;
340
- }
341
- if (this.value && this.value === radio.value) {
342
- this.selectedRadio = radio;
343
- this.focusedRadio = radio;
344
- radio.checked = true;
345
- radio.setAttribute("tabindex", "0");
346
- foundMatchingVal = true;
347
- }
348
- else {
349
- if (!this.isInsideFoundationToolbar) {
350
- radio.setAttribute("tabindex", "-1");
351
- }
352
- radio.checked = false;
353
- }
354
- radio.addEventListener("change", this.radioChangeHandler);
355
- });
356
- if (this.value === undefined && this.slottedRadioButtons.length > 0) {
357
- const checkedRadios = this.slottedRadioButtons.filter((radio) => {
358
- return radio.hasAttribute("checked");
359
- });
360
- const numberOfCheckedRadios = checkedRadios !== null ? checkedRadios.length : 0;
361
- if (numberOfCheckedRadios > 0 && !foundMatchingVal) {
362
- const lastCheckedRadio = checkedRadios[numberOfCheckedRadios - 1];
363
- lastCheckedRadio.checked = true;
364
- this.focusedRadio = lastCheckedRadio;
365
- lastCheckedRadio.setAttribute("tabindex", "0");
366
- }
367
- else {
368
- this.slottedRadioButtons[0].setAttribute("tabindex", "0");
369
- this.focusedRadio = this.slottedRadioButtons[0];
370
- }
371
- }
372
- }
373
- };
374
- __decorate([
375
- attr({ attribute: "readonly", mode: "boolean" })
376
- ], RadioGroup$1.prototype, "readOnly", void 0);
377
- __decorate([
378
- attr({ attribute: "disabled", mode: "boolean" })
379
- ], RadioGroup$1.prototype, "disabled", void 0);
380
- __decorate([
381
- attr
382
- ], RadioGroup$1.prototype, "name", void 0);
383
- __decorate([
384
- attr
385
- ], RadioGroup$1.prototype, "value", void 0);
386
- __decorate([
387
- attr
388
- ], RadioGroup$1.prototype, "orientation", void 0);
389
- __decorate([
390
- observable
391
- ], RadioGroup$1.prototype, "childItems", void 0);
392
- __decorate([
393
- observable
394
- ], RadioGroup$1.prototype, "slottedRadioButtons", void 0);
395
-
396
- const styles = "/**\n * Do not edit directly\n * Generated on Tue, 26 Sep 2023 13:00:58 GMT\n */\n.positioning-region {\n display: flex;\n flex-wrap: wrap;\n gap: 8px;\n}\n.positioning-region.vertical {\n flex-direction: column;\n}\nlabel + .positioning-region {\n margin-block-start: 8px;\n}\n\nlabel {\n color: var(--vvd-color-canvas-text);\n font: var(--vvd-typography-base);\n}";
6
+ const styles = "/**\n * Do not edit directly\n * Generated on Tue, 17 Oct 2023 15:27:52 GMT\n */\n.base {\n height: 6px;\n align-items: center;\n margin: 0;\n outline: none;\n}\n.base:not(.connotation-pacific).connotation-cta {\n /* @cssprop [--vvd-progress-cta-primary=var(--vvd-color-cta-500)] */\n --_connotation-color-primary: var(--vvd-progress-cta-primary, var(--vvd-color-cta-500));\n /* @cssprop [--vvd-progress-cta-soft=var(--vvd-color-cta-100)] */\n --_connotation-color-soft: var(--vvd-progress-cta-soft, var(--vvd-color-cta-100));\n}\n.base:not(.connotation-pacific).connotation-alert {\n /* @cssprop [--vvd-progress-alert-primary=var(--vvd-color-alert-500)] */\n --_connotation-color-primary: var(--vvd-progress-alert-primary, var(--vvd-color-alert-500));\n /* @cssprop [--vvd-progress-alert-soft=var(--vvd-color-alert-100)] */\n --_connotation-color-soft: var(--vvd-progress-alert-soft, var(--vvd-color-alert-100));\n}\n.base:not(.connotation-pacific).connotation-success {\n /* @cssprop [--vvd-progress-success-primary=var(--vvd-color-success-500)] */\n --_connotation-color-primary: var(--vvd-progress-success-primary, var(--vvd-color-success-500));\n /* @cssprop [--vvd-progress-success-soft=var(--vvd-color-success-100)] */\n --_connotation-color-soft: var(--vvd-progress-success-soft, var(--vvd-color-success-100));\n}\n.base:not(.connotation-pacific):not(.connotation-cta, .connotation-alert, .connotation-success) {\n /* @cssprop [--vvd-progress-accent-primary=var(--vvd-color-canvas-text)] */\n --_connotation-color-primary: var(--vvd-progress-accent-primary, var(--vvd-color-canvas-text));\n /* @cssprop [--vvd-progress-accent-soft=var(--vvd-color-neutral-100)] */\n --_connotation-color-soft: var(--vvd-progress-accent-soft, var(--vvd-color-neutral-100));\n}\n.base:not(.connotation-pacific) {\n --_appearance-color-text: var(--_connotation-color-contrast);\n --_appearance-color-fill: var(--_connotation-color-soft);\n --_appearance-color-outline: transparent;\n}\n.base.connotation-pacific {\n --_connotation-color-primary: linear-gradient(to right, var(--vvd-color-information-200), var(--vvd-color-cta-600));\n}\n\n.progress {\n position: relative;\n display: flex;\n overflow: hidden;\n align-items: center;\n block-size: 100%;\n inline-size: 100%;\n /* Shape */\n}\n.base:not(.connotation-pacific) .progress {\n background-color: var(--_appearance-color-fill);\n}\n.base.connotation-pacific .progress {\n background-color: var(--vvd-color-neutral-100);\n}\n.base:not(.shape-sharp) .progress {\n border-radius: 3px;\n}\n\n.indeterminate {\n display: flex;\n background-color: var(--_connotation-color-primary);\n block-size: 100%;\n border-radius: inherit;\n inline-size: 100%;\n}\n\n.determinate {\n background-color: var(--_connotation-color-primary);\n block-size: 100%;\n border-radius: inherit;\n transition: all 0.2s ease-in-out;\n}\n.connotation-pacific .determinate {\n background-image: var(--_connotation-color-primary);\n}\n.reverse .determinate {\n position: absolute;\n right: 0;\n}\n.paused .determinate {\n background: var(--vvd-color-neutral-300);\n}\n\n.indicator-1 {\n animation: indeterminate-1 2s infinite;\n inline-size: 30%;\n}\n\n.indicator-2 {\n animation: indeterminate-2 2s infinite;\n inline-size: 60%;\n}\n\n.indicator-1,\n.indicator-2 {\n position: absolute;\n animation-timing-function: cubic-bezier(0.4, 0, 0.6, 1);\n background-color: var(--vvd-color-neutral-100);\n block-size: 100%;\n opacity: 0;\n}\n.connotation-pacific .indicator-1,\n.connotation-pacific .indicator-2 {\n background-image: var(--_connotation-color-primary);\n}\n.paused .indicator-1,\n.paused .indicator-2 {\n animation-play-state: paused;\n background-color: var(--_connotation-color-primary);\n}\n.reverse .indicator-1,\n.reverse .indicator-2 {\n animation-direction: reverse;\n}\n\n@keyframes indeterminate-1 {\n 0% {\n opacity: 1;\n transform: translateX(-100%);\n }\n 70% {\n opacity: 1;\n transform: translateX(300%);\n }\n 70.01% {\n opacity: 0;\n }\n 100% {\n opacity: 0;\n transform: translateX(300%);\n }\n}\n@keyframes indeterminate-2 {\n 0% {\n opacity: 0;\n transform: translateX(-150%);\n }\n 29.99% {\n opacity: 0;\n }\n 30% {\n opacity: 1;\n transform: translateX(-150%);\n }\n 100% {\n opacity: 1;\n transform: translateX(166.66%);\n }\n}";
397
7
 
398
8
  var __defProp = Object.defineProperty;
399
9
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
@@ -406,39 +16,69 @@ var __decorateClass = (decorators, target, key, kind) => {
406
16
  __defProp(target, key, result);
407
17
  return result;
408
18
  };
409
- class RadioGroup extends RadioGroup$1 {
19
+ class Progress extends BaseProgress {
20
+ constructor() {
21
+ super(...arguments);
22
+ this.reverse = false;
23
+ }
410
24
  }
411
25
  __decorateClass([
412
- attr
413
- ], RadioGroup.prototype, "label", 2);
26
+ attr()
27
+ ], Progress.prototype, "shape", 2);
28
+ __decorateClass([
29
+ attr()
30
+ ], Progress.prototype, "connotation", 2);
31
+ __decorateClass([
32
+ attr({ mode: "boolean" })
33
+ ], Progress.prototype, "reverse", 2);
414
34
 
415
- const RadioGroupTemplate = (context) => {
35
+ const getClasses = ({
36
+ connotation,
37
+ shape,
38
+ reverse,
39
+ paused
40
+ }) => classNames(
41
+ "base",
42
+ [`connotation-${connotation}`, Boolean(connotation)],
43
+ [`shape-${shape}`, Boolean(shape)],
44
+ ["reverse", Boolean(reverse)],
45
+ ["paused", Boolean(paused)]
46
+ );
47
+ function determinate() {
416
48
  return html`
417
- <template
418
- role="radiogroup"
419
- aria-disabled="${(x) => x.disabled}"
420
- aria-readonly="${(x) => x.readOnly}"
421
- aria-orientation="${(x) => x.orientation}"
422
- @click="${(x, c) => x.clickHandler(c.event)}"
423
- @keydown="${(x, c) => x.keydownHandler(c.event)}"
424
- @focusout="${(x, c) => x.focusOutHandler(c.event)}"
425
- >
426
-
427
- ${when((x) => x.label, html`<label>${(x) => x.label}</label>`)}
428
-
429
- <div class="positioning-region ${(x) => x.orientation === Orientation$1.horizontal ? "horizontal" : "vertical"}">
430
- <slot ${slotted({ property: "slottedRadioButtons", filter: elements(context.tagFor(Radio)) })}></slot>
431
- </div>
432
- </template>
433
- `;
49
+ <span class="determinate" style="width: ${(x) => x.percentComplete}%"></span>`;
50
+ }
51
+ function indeterminate() {
52
+ return html`
53
+ <span class="indeterminate" name="indeterminate">
54
+ <span class="indicator-1"></span>
55
+ <span class="indicator-2"></span>
56
+ </span>`;
57
+ }
58
+ const ProgressTemplate = (_) => {
59
+ return html`
60
+ <div
61
+ role="progressbar"
62
+ aria-label="${(x) => x.ariaLabel}"
63
+ aria-valuenow="${(x) => x.value}"
64
+ aria-valuemin="${(x) => x.min}"
65
+ aria-valuemax="${(x) => x.max}"
66
+ class="${getClasses}"
67
+ >
68
+ <div class="progress">
69
+ ${when((x) => typeof x.value === "number", determinate())}
70
+ ${when((x) => typeof x.value !== "number", indeterminate())}
71
+ </div>
72
+ </div>
73
+ `;
434
74
  };
435
75
 
436
- const radioGroupDefinition = RadioGroup.compose({
437
- baseName: "radio-group",
438
- template: RadioGroupTemplate,
76
+ const progressDefinition = Progress.compose({
77
+ baseName: "progress",
78
+ template: ProgressTemplate,
439
79
  styles
440
80
  });
441
- const radioGroupRegistries = [radioGroupDefinition()];
442
- const registerRadioGroup = registerFactory(radioGroupRegistries);
81
+ const progressRegistries = [progressDefinition()];
82
+ const registerProgress = registerFactory(progressRegistries);
443
83
 
444
- export { radioGroupRegistries as a, registerRadioGroup as b, radioGroupDefinition as r };
84
+ export { progressRegistries as a, progressDefinition as p, registerProgress as r };