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