@vonage/vivid 4.4.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.
Files changed (235) hide show
  1. package/custom-elements.json +7181 -6876
  2. package/elevation/index.cjs +1 -1
  3. package/elevation/index.js +1 -1
  4. package/index.cjs +80 -74
  5. package/index.js +23 -22
  6. package/lib/components.d.ts +1 -0
  7. package/lib/fab/fab.d.ts +1 -1
  8. package/lib/icon/icon.d.ts +1 -1
  9. package/lib/menu/menu.d.ts +2 -1
  10. package/lib/number-field/number-field.d.ts +3 -1
  11. package/lib/searchable-select/definition.d.ts +4 -0
  12. package/lib/searchable-select/locale.d.ts +6 -0
  13. package/lib/searchable-select/option-tag.d.ts +14 -0
  14. package/lib/searchable-select/option-tag.template.d.ts +4 -0
  15. package/lib/searchable-select/searchable-select.d.ts +29 -0
  16. package/lib/searchable-select/searchable-select.form-associated.d.ts +10 -0
  17. package/lib/searchable-select/searchable-select.template.d.ts +4 -0
  18. package/lib/select/select.d.ts +4 -1
  19. package/lib/tab/locale.d.ts +3 -0
  20. package/lib/tab/tab.d.ts +5 -1
  21. package/lib/tabs/tabs.d.ts +2 -0
  22. package/lib/tag/definition.d.ts +1 -0
  23. package/lib/text-field/text-field.d.ts +3 -1
  24. package/lib/video-player/video-player.d.ts +0 -1
  25. package/listbox/index.cjs +1 -1
  26. package/listbox/index.js +1 -1
  27. package/locales/de-DE.cjs +12 -0
  28. package/locales/de-DE.js +12 -0
  29. package/locales/en-GB.cjs +12 -0
  30. package/locales/en-GB.js +12 -0
  31. package/locales/en-US.cjs +12 -0
  32. package/locales/en-US.js +12 -0
  33. package/locales/ja-JP.cjs +12 -0
  34. package/locales/ja-JP.js +12 -0
  35. package/locales/zh-CN.cjs +12 -0
  36. package/locales/zh-CN.js +12 -0
  37. package/package.json +6 -1
  38. package/popup/index.cjs +1 -1
  39. package/popup/index.js +1 -1
  40. package/searchable-select/index.cjs +5 -0
  41. package/searchable-select/index.js +3 -0
  42. package/select/index.cjs +1 -1
  43. package/select/index.js +1 -1
  44. package/selectable-box/index.cjs +1 -1
  45. package/selectable-box/index.js +1 -1
  46. package/shared/anchored.js +1 -1
  47. package/shared/calendar-event.js +1 -1
  48. package/shared/definition.cjs +2 -2
  49. package/shared/definition.js +2 -2
  50. package/shared/definition11.cjs +1 -1
  51. package/shared/definition11.js +1 -1
  52. package/shared/definition12.cjs +1 -1
  53. package/shared/definition12.js +1 -1
  54. package/shared/definition13.js +1 -1
  55. package/shared/definition14.cjs +1 -1
  56. package/shared/definition14.js +1 -1
  57. package/shared/definition15.cjs +7 -8
  58. package/shared/definition15.js +2 -3
  59. package/shared/definition16.cjs +11 -7
  60. package/shared/definition16.js +10 -6
  61. package/shared/definition17.cjs +2 -2
  62. package/shared/definition17.js +2 -2
  63. package/shared/definition18.cjs +5 -6
  64. package/shared/definition18.js +3 -4
  65. package/shared/definition19.cjs +5 -6
  66. package/shared/definition19.js +3 -4
  67. package/shared/definition20.cjs +16 -38
  68. package/shared/definition20.js +17 -39
  69. package/shared/definition21.cjs +7 -6
  70. package/shared/definition21.js +8 -7
  71. package/shared/definition23.cjs +1 -1
  72. package/shared/definition23.js +2 -2
  73. package/shared/definition24.cjs +2 -2
  74. package/shared/definition24.js +2 -2
  75. package/shared/definition25.cjs +6 -7
  76. package/shared/definition25.js +2 -3
  77. package/shared/definition26.cjs +1 -1
  78. package/shared/definition26.js +2 -2
  79. package/shared/definition27.cjs +1 -1
  80. package/shared/definition27.js +1 -1
  81. package/shared/definition28.js +1 -1
  82. package/shared/definition29.cjs +8 -4
  83. package/shared/definition29.js +8 -4
  84. package/shared/definition3.cjs +1 -1
  85. package/shared/definition3.js +2 -2
  86. package/shared/definition30.cjs +4 -2
  87. package/shared/definition30.js +4 -2
  88. package/shared/definition31.cjs +1 -1
  89. package/shared/definition31.js +2 -2
  90. package/shared/definition32.cjs +1 -1
  91. package/shared/definition32.js +1 -1
  92. package/shared/definition34.cjs +2 -3
  93. package/shared/definition34.js +2 -3
  94. package/shared/definition35.cjs +21 -16
  95. package/shared/definition35.js +16 -11
  96. package/shared/definition36.cjs +50 -207
  97. package/shared/definition36.js +51 -207
  98. package/shared/definition37.js +1 -1
  99. package/shared/definition38.cjs +1 -1
  100. package/shared/definition38.js +1 -1
  101. package/shared/definition4.cjs +6 -4
  102. package/shared/definition4.js +7 -5
  103. package/shared/definition41.cjs +1 -1
  104. package/shared/definition41.js +1 -1
  105. package/shared/definition42.cjs +6 -7
  106. package/shared/definition42.js +6 -7
  107. package/shared/definition43.cjs +998 -643
  108. package/shared/definition43.js +992 -638
  109. package/shared/definition44.cjs +723 -112
  110. package/shared/definition44.js +722 -111
  111. package/shared/definition45.cjs +121 -79
  112. package/shared/definition45.js +120 -78
  113. package/shared/definition46.cjs +81 -616
  114. package/shared/definition46.js +80 -614
  115. package/shared/definition47.cjs +609 -116
  116. package/shared/definition47.js +607 -115
  117. package/shared/definition48.cjs +116 -134
  118. package/shared/definition48.js +115 -133
  119. package/shared/definition49.cjs +149 -19
  120. package/shared/definition49.js +148 -18
  121. package/shared/definition5.cjs +5 -6
  122. package/shared/definition5.js +5 -6
  123. package/shared/definition50.cjs +21 -82
  124. package/shared/definition50.js +20 -81
  125. package/shared/definition51.cjs +78 -494
  126. package/shared/definition51.js +77 -493
  127. package/shared/definition52.cjs +568 -28
  128. package/shared/definition52.js +567 -27
  129. package/shared/definition53.cjs +28 -123
  130. package/shared/definition53.js +27 -123
  131. package/shared/definition54.cjs +115 -296
  132. package/shared/definition54.js +114 -295
  133. package/shared/definition55.cjs +258 -318
  134. package/shared/definition55.js +252 -312
  135. package/shared/definition56.cjs +303 -784
  136. package/shared/definition56.js +298 -779
  137. package/shared/definition57.cjs +802 -95
  138. package/shared/definition57.js +801 -94
  139. package/shared/definition58.cjs +95 -60
  140. package/shared/definition58.js +94 -59
  141. package/shared/definition59.cjs +117 -75
  142. package/shared/definition59.js +116 -74
  143. package/shared/definition6.cjs +1 -1
  144. package/shared/definition6.js +1 -1
  145. package/shared/definition60.cjs +70 -285
  146. package/shared/definition60.js +71 -286
  147. package/shared/definition61.cjs +296 -325
  148. package/shared/definition61.js +295 -324
  149. package/shared/definition62.cjs +66160 -27
  150. package/shared/definition62.js +66159 -26
  151. package/shared/definition63.cjs +24 -1952
  152. package/shared/definition63.js +23 -1950
  153. package/shared/definition64.cjs +1976 -0
  154. package/shared/definition64.js +1971 -0
  155. package/shared/definition7.cjs +1 -1
  156. package/shared/definition7.js +1 -1
  157. package/shared/definition8.cjs +2 -3
  158. package/shared/definition8.js +3 -4
  159. package/shared/definition9.cjs +1 -1
  160. package/shared/definition9.js +1 -1
  161. package/shared/dialog/index.d.ts +1 -0
  162. package/shared/form-elements.cjs +236 -0
  163. package/shared/form-elements.js +229 -0
  164. package/shared/icon.js +1 -1
  165. package/shared/index2.cjs +6 -256
  166. package/shared/index2.js +6 -249
  167. package/shared/listbox-option.cjs +204 -0
  168. package/shared/listbox-option.js +201 -0
  169. package/shared/listbox.cjs +3 -3
  170. package/shared/listbox.js +1 -1
  171. package/shared/localization/Locale.d.ts +4 -0
  172. package/shared/localized.cjs +26 -2
  173. package/shared/localized.js +25 -2
  174. package/shared/playbackRates.cjs +13 -0
  175. package/shared/playbackRates.js +11 -0
  176. package/shared/presentationDate.cjs +11 -11
  177. package/shared/presentationDate.js +11 -11
  178. package/shared/scrollIntoView.cjs +51 -0
  179. package/shared/scrollIntoView.js +49 -0
  180. package/shared/slider.template.cjs +1 -1
  181. package/shared/slider.template.js +1 -1
  182. package/shared/text-anchor.cjs +1 -1
  183. package/shared/text-anchor.js +1 -1
  184. package/shared/text-field.cjs +1 -1
  185. package/shared/text-field.js +1 -1
  186. package/shared/utils/playbackRates.d.ts +1 -0
  187. package/shared/utils/scrollIntoView.d.ts +1 -0
  188. package/side-drawer/index.cjs +1 -1
  189. package/side-drawer/index.js +1 -1
  190. package/slider/index.cjs +1 -1
  191. package/slider/index.js +1 -1
  192. package/split-button/index.cjs +1 -1
  193. package/split-button/index.js +1 -1
  194. package/styles/core/all.css +1 -1
  195. package/styles/core/theme.css +1 -1
  196. package/styles/core/typography.css +1 -1
  197. package/styles/tokens/theme-dark.css +4 -4
  198. package/styles/tokens/theme-light.css +4 -4
  199. package/styles/tokens/vivid-2-compat.css +1 -1
  200. package/switch/index.cjs +1 -1
  201. package/switch/index.js +1 -1
  202. package/tab/index.cjs +1 -1
  203. package/tab/index.js +1 -1
  204. package/tab-panel/index.cjs +1 -1
  205. package/tab-panel/index.js +1 -1
  206. package/tabs/index.cjs +1 -1
  207. package/tabs/index.js +1 -1
  208. package/tag/index.cjs +1 -1
  209. package/tag/index.js +1 -1
  210. package/tag-group/index.cjs +1 -1
  211. package/tag-group/index.js +1 -1
  212. package/text-area/index.cjs +1 -1
  213. package/text-area/index.js +1 -1
  214. package/text-field/index.cjs +1 -1
  215. package/text-field/index.js +1 -1
  216. package/time-picker/index.cjs +1 -1
  217. package/time-picker/index.js +1 -1
  218. package/toggletip/index.cjs +1 -1
  219. package/toggletip/index.js +1 -1
  220. package/tooltip/index.cjs +1 -1
  221. package/tooltip/index.js +1 -1
  222. package/tree-item/index.cjs +1 -1
  223. package/tree-item/index.js +1 -1
  224. package/tree-view/index.cjs +1 -1
  225. package/tree-view/index.js +1 -1
  226. package/video-player/index.cjs +1 -1
  227. package/video-player/index.js +1 -1
  228. package/vivid.api.json +312 -8
  229. package/appearance-ui/index.cjs +0 -102
  230. package/appearance-ui/index.js +0 -100
  231. package/lib/appearance-ui/appearance-ui.d.ts +0 -12
  232. package/lib/appearance-ui/appearance-ui.template.d.ts +0 -4
  233. package/lib/appearance-ui/definition.d.ts +0 -3
  234. package/shared/video-player.cjs +0 -65860
  235. package/shared/video-player.js +0 -65857
@@ -1,37 +1,167 @@
1
1
  'use strict';
2
2
 
3
3
  const index = require('./index.cjs');
4
+ const definition = require('./definition27.cjs');
5
+ const formAssociated = require('./form-associated.cjs');
6
+ const keyCodes = require('./key-codes.cjs');
7
+ const when = require('./when.cjs');
8
+ const classNames = require('./class-names.cjs');
9
+
10
+ class _Switch extends index.FoundationElement {
11
+ }
12
+ /**
13
+ * A form-associated base class for the {@link @microsoft/fast-foundation#(Switch:class)} component.
14
+ *
15
+ * @internal
16
+ */
17
+ class FormAssociatedSwitch extends formAssociated.CheckableFormAssociated(_Switch) {
18
+ constructor() {
19
+ super(...arguments);
20
+ this.proxy = document.createElement("input");
21
+ }
22
+ }
4
23
 
5
24
  /**
6
- * A TabPanel Component to be used with {@link @microsoft/fast-foundation#(Tabs:class)}
25
+ * A Switch Custom HTML Element.
26
+ * Implements the {@link https://www.w3.org/TR/wai-aria-1.1/#switch | ARIA switch }.
7
27
  *
8
- * @slot - The default slot for the tabpanel content
28
+ * @slot - The deafult slot for the label
29
+ * @slot checked-message - The message when in a checked state
30
+ * @slot unchecked-message - The message when in an unchecked state
31
+ * @csspart label - The label
32
+ * @csspart switch - The element representing the switch, which wraps the indicator
33
+ * @csspart status-message - The wrapper for the status messages
34
+ * @csspart checked-message - The checked message
35
+ * @csspart unchecked-message - The unchecked message
36
+ * @fires change - Emits a custom change event when the checked state changes
9
37
  *
10
38
  * @public
11
39
  */
12
- let TabPanel$1 = class TabPanel extends index.FoundationElement {
40
+ let Switch$1 = class Switch extends FormAssociatedSwitch {
41
+ constructor() {
42
+ super();
43
+ /**
44
+ * The element's value to be included in form submission when checked.
45
+ * Default to "on" to reach parity with input[type="checkbox"]
46
+ *
47
+ * @internal
48
+ */
49
+ this.initialValue = "on";
50
+ /**
51
+ * @internal
52
+ */
53
+ this.keypressHandler = (e) => {
54
+ if (this.readOnly) {
55
+ return;
56
+ }
57
+ switch (e.key) {
58
+ case keyCodes.keyEnter:
59
+ case keyCodes.keySpace:
60
+ this.checked = !this.checked;
61
+ break;
62
+ }
63
+ };
64
+ /**
65
+ * @internal
66
+ */
67
+ this.clickHandler = (e) => {
68
+ if (!this.disabled && !this.readOnly) {
69
+ this.checked = !this.checked;
70
+ }
71
+ };
72
+ this.proxy.setAttribute("type", "checkbox");
73
+ }
74
+ readOnlyChanged() {
75
+ if (this.proxy instanceof HTMLInputElement) {
76
+ this.proxy.readOnly = this.readOnly;
77
+ }
78
+ this.readOnly
79
+ ? this.classList.add("readonly")
80
+ : this.classList.remove("readonly");
81
+ }
82
+ /**
83
+ * @internal
84
+ */
85
+ checkedChanged(prev, next) {
86
+ super.checkedChanged(prev, next);
87
+ /**
88
+ * @deprecated - this behavior already exists in the template and should not exist in the class.
89
+ */
90
+ this.checked ? this.classList.add("checked") : this.classList.remove("checked");
91
+ }
13
92
  };
93
+ index.__decorate([
94
+ index.attr({ attribute: "readonly", mode: "boolean" })
95
+ ], Switch$1.prototype, "readOnly", void 0);
96
+ index.__decorate([
97
+ index.observable
98
+ ], Switch$1.prototype, "defaultSlottedNodes", void 0);
14
99
 
15
- class TabPanel extends TabPanel$1 {
100
+ const styles = ":host(.disabled){cursor:not-allowed}.control.connotation-cta{--_connotation-color-primary-text: var(--vvd-switch-cta-primary-text, var(--vvd-color-canvas));--_connotation-color-primary: var(--vvd-switch-cta-primary, var(--vvd-color-cta-500));--_connotation-color-primary-increment: var(--vvd-switch-cta-primary-increment, var(--vvd-color-cta-600));--_connotation-color-firm: var(--vvd-switch-cta-firm, var(--vvd-color-cta-600));--_connotation-color-intermediate: var(--vvd-switch-cta-intermediate, var(--vvd-color-cta-500));--_connotation-color-fierce: var(--vvd-switch-cta-fierce, var(--vvd-color-cta-700))}.control.connotation-alert{--_connotation-color-primary-text: var(--vvd-switch-alert-primary-text, var(--vvd-color-canvas));--_connotation-color-primary: var(--vvd-switch-alert-primary, var(--vvd-color-alert-500));--_connotation-color-primary-increment: var(--vvd-switch-alert-primary-increment, var(--vvd-color-alert-600));--_connotation-color-firm: var(--vvd-switch-alert-firm, var(--vvd-color-alert-600));--_connotation-color-intermediate: var(--vvd-switch-alert-intermediate, var(--vvd-color-alert-500));--_connotation-color-fierce: var(--vvd-switch-alert-fierce, var(--vvd-color-alert-700))}.control.connotation-success{--_connotation-color-primary-text: var(--vvd-switch-success-primary-text, var(--vvd-color-canvas));--_connotation-color-primary: var(--vvd-switch-success-primary, var(--vvd-color-success-500));--_connotation-color-primary-increment: var(--vvd-switch-success-primary-increment, var(--vvd-color-success-600));--_connotation-color-firm: var(--vvd-switch-success-firm, var(--vvd-color-success-600));--_connotation-color-intermediate: var(--vvd-switch-success-intermediate, var(--vvd-color-success-500));--_connotation-color-fierce: var(--vvd-switch-success-fierce, var(--vvd-color-success-700))}.control.connotation-announcement{--_connotation-color-primary-text: var(--vvd-switch-announcement-primary-text, var(--vvd-color-canvas));--_connotation-color-primary: var(--vvd-switch-announcement-primary, var(--vvd-color-announcement-500));--_connotation-color-primary-increment: var(--vvd-switch-announcement-primary-increment, var(--vvd-color-announcement-600));--_connotation-color-firm: var(--vvd-switch-announcement-firm, var(--vvd-color-announcement-600));--_connotation-color-intermediate: var(--vvd-switch-announcement-intermediate, var(--vvd-color-announcement-500));--_connotation-color-fierce: var(--vvd-switch-announcement-fierce, var(--vvd-color-announcement-700))}.control:not(.connotation-cta,.connotation-alert,.connotation-success,.connotation-announcement){--_connotation-color-primary-text: var(--vvd-switch-accent-primary-text, var(--vvd-color-canvas));--_connotation-color-primary: var(--vvd-switch-accent-primary, var(--vvd-color-canvas-text));--_connotation-color-primary-increment: var(--vvd-switch-accent-primary-increment, var(--vvd-color-neutral-800));--_connotation-color-firm: var(--vvd-switch-accent-firm, var(--vvd-color-canvas-text));--_connotation-color-intermediate: var(--vvd-switch-accent-intermediate, var(--vvd-color-neutral-500));--_connotation-color-fierce: var(--vvd-switch-accent-fierce, var(--vvd-color-neutral-700))}.control{--_appearance-color-text: var(--vvd-color-canvas-text);--_appearance-color-fill: var(--vvd-color-canvas);--_appearance-color-outline: var(--_connotation-color-intermediate)}.control.appearance-filled{--_appearance-color-text: var(--_connotation-color-primary-text);--_appearance-color-fill: var(--_connotation-color-primary);--_appearance-color-outline: transparent}.control:where(.hover,:hover):where(:not(.disabled,:disabled,.readonly)){--_appearance-color-text: var(--vvd-color-canvas-text);--_appearance-color-fill: var(--vvd-color-canvas);--_appearance-color-outline: var(--_connotation-color-fierce)}.control:where(.hover,:hover):where(:not(.disabled,:disabled,.readonly)).appearance-filled{--_appearance-color-text: var(--_connotation-color-primary-text);--_appearance-color-fill: var(--_connotation-color-primary-increment);--_appearance-color-outline: transparent}.control:where(.disabled,:disabled){--_appearance-color-text: var(--vvd-color-neutral-300);--_appearance-color-fill: var(--vvd-color-neutral-100);--_appearance-color-outline: var(--vvd-color-neutral-300)}.control:where(.disabled,:disabled).appearance-filled{--_appearance-color-text: var(--vvd-color-neutral-300);--_appearance-color-fill: var(--vvd-color-neutral-100);--_appearance-color-outline: transparent}.control:where(.readonly):where(:not(.disabled,:disabled)){--_appearance-color-text: var(--vvd-color-canvas-text);--_appearance-color-fill: var(--vvd-color-neutral-200);--_appearance-color-outline: var(--vvd-color-neutral-400)}.control:where(.readonly):where(:not(.disabled,:disabled)).appearance-filled{--_appearance-color-text: var(--vvd-color-neutral-800);--_appearance-color-fill: var(--vvd-color-neutral-500);--_appearance-color-outline: transparent}.control{display:inline-flex;border-radius:16px;gap:8px;--focus-inset: -4px;--focus-stroke-gap-color: transparent}.control:focus-visible{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){.control{user-select:none}}.control:not(.disabled){cursor:pointer}.control.disabled{pointer-events:none}.switch{--_switch-inline-size: calc(1px*(20 + 4*clamp(-1, var(--vvd-size-density, 0), 2))*1.8) ;display:flex;box-sizing:border-box;align-items:center;border-radius:40px;background-color:var(--_appearance-color-fill);block-size:calc(1px*(20 + 4*clamp(-1,var(--vvd-size-density, 0),2)));box-shadow:inset 0 0 0 1px var(--_appearance-color-outline);inline-size:var(--_switch-inline-size);transition:all .2s ease-in-out 0s}.checked-indicator{--_switch-checked-indicator-size: calc( calc(1px*(20 + 4*clamp(-1, var(--vvd-size-density, 0), 2))) / 1.6667);--_switch-gutter: calc(var(--_switch-checked-indicator-size) / 3);border-radius:inherit;block-size:var(--_switch-checked-indicator-size);inline-size:var(--_switch-checked-indicator-size);margin-inline-start:auto;transition:all .2s ease-in-out 0s}.control:not(.appearance-filled) .checked-indicator{background-color:var(--_appearance-color-outline)}.control:not(.appearance-filled):where(.readonly) .checked-indicator{background-color:var(--vvd-color-neutral-600)}.control.appearance-filled .checked-indicator{background-color:var(--vvd-color-neutral-100)}.control:not(.checked) .checked-indicator{transform:translate(calc(-1 * var(--_switch-inline-size) + var(--_switch-checked-indicator-size) + var(--_switch-gutter)))}.control.checked .checked-indicator{transform:translate(calc(-1 * var(--_switch-gutter)))}.control.appearance-filled.disabled .checked-indicator{background-color:var(--_appearance-color-text)}.control.appearance-filled.readonly .checked-indicator{background-color:var(--vvd-color-neutral-50)}.label{color:var(--vvd-color-canvas-text);cursor:pointer;font:var(--vvd-typography-base)}";
101
+
102
+ var __defProp = Object.defineProperty;
103
+ var __decorateClass = (decorators, target, key, kind) => {
104
+ var result = void 0 ;
105
+ for (var i = decorators.length - 1, decorator; i >= 0; i--)
106
+ if (decorator = decorators[i])
107
+ result = (decorator(target, key, result) ) || result;
108
+ if (result) __defProp(target, key, result);
109
+ return result;
110
+ };
111
+ class Switch extends Switch$1 {
16
112
  }
113
+ __decorateClass([
114
+ index.attr
115
+ ], Switch.prototype, "label");
116
+ __decorateClass([
117
+ index.attr
118
+ ], Switch.prototype, "connotation");
17
119
 
18
- function TabPanelTemplate() {
120
+ const getClasses = (_) => classNames.classNames(
121
+ "control",
122
+ ["appearance-filled", _.checked],
123
+ ["checked", _.checked],
124
+ ["disabled", _.disabled],
125
+ ["readonly", _.readOnly],
126
+ [
127
+ `connotation-${_.connotation}`,
128
+ Boolean(_.checked) && Boolean(_.connotation)
129
+ ]
130
+ );
131
+ const SwitchTemplate = () => {
19
132
  return index.html`
20
- <template slot="tabpanel" role="tabpanel">
21
- <slot></slot>
22
- </template>
133
+ <div
134
+ class="${getClasses}"
135
+ role="switch"
136
+ aria-checked="${(x) => x.checked}"
137
+ aria-disabled="${(x) => x.disabled}"
138
+ aria-readonly="${(x) => x.readOnly}"
139
+ tabindex="${(x) => x.disabled ? null : 0}"
140
+ @keypress="${(x, c) => x.keypressHandler(c.event)}"
141
+ @click="${(x, c) => x.clickHandler(c.event)}"
142
+ >
143
+ <div class="switch">
144
+ <span class="checked-indicator"></span>
145
+ </div>
146
+ ${when.when(
147
+ (x) => x.label,
148
+ index.html`<div class="label">${(x) => x.label}</div>`
149
+ )}
150
+ </div>
23
151
  `;
24
- }
152
+ };
25
153
 
26
- const tabPanelDefinition = TabPanel.compose(
27
- {
28
- baseName: "tab-panel",
29
- template: TabPanelTemplate
154
+ const switchDefinition = Switch.compose({
155
+ baseName: "switch",
156
+ template: SwitchTemplate,
157
+ styles,
158
+ shadowOptions: {
159
+ delegatesFocus: true
30
160
  }
31
- );
32
- const tabPanelRegistries = [tabPanelDefinition()];
33
- const registerTabPanel = index.registerFactory(tabPanelRegistries);
161
+ });
162
+ const switchRegistries = [switchDefinition(), ...definition.iconRegistries];
163
+ const registerSwitch = index.registerFactory(switchRegistries);
34
164
 
35
- exports.registerTabPanel = registerTabPanel;
36
- exports.tabPanelDefinition = tabPanelDefinition;
37
- exports.tabPanelRegistries = tabPanelRegistries;
165
+ exports.registerSwitch = registerSwitch;
166
+ exports.switchDefinition = switchDefinition;
167
+ exports.switchRegistries = switchRegistries;
@@ -1,33 +1,163 @@
1
- import { F as FoundationElement, h as html, r as registerFactory } from './index.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 { a as iconRegistries } from './definition27.js';
3
+ import { C as CheckableFormAssociated } from './form-associated.js';
4
+ import { a as keySpace, k as keyEnter } from './key-codes.js';
5
+ import { w as when } from './when.js';
6
+ import { c as classNames } from './class-names.js';
7
+
8
+ class _Switch extends FoundationElement {
9
+ }
10
+ /**
11
+ * A form-associated base class for the {@link @microsoft/fast-foundation#(Switch:class)} component.
12
+ *
13
+ * @internal
14
+ */
15
+ class FormAssociatedSwitch extends CheckableFormAssociated(_Switch) {
16
+ constructor() {
17
+ super(...arguments);
18
+ this.proxy = document.createElement("input");
19
+ }
20
+ }
2
21
 
3
22
  /**
4
- * A TabPanel Component to be used with {@link @microsoft/fast-foundation#(Tabs:class)}
23
+ * A Switch Custom HTML Element.
24
+ * Implements the {@link https://www.w3.org/TR/wai-aria-1.1/#switch | ARIA switch }.
5
25
  *
6
- * @slot - The default slot for the tabpanel content
26
+ * @slot - The deafult slot for the label
27
+ * @slot checked-message - The message when in a checked state
28
+ * @slot unchecked-message - The message when in an unchecked state
29
+ * @csspart label - The label
30
+ * @csspart switch - The element representing the switch, which wraps the indicator
31
+ * @csspart status-message - The wrapper for the status messages
32
+ * @csspart checked-message - The checked message
33
+ * @csspart unchecked-message - The unchecked message
34
+ * @fires change - Emits a custom change event when the checked state changes
7
35
  *
8
36
  * @public
9
37
  */
10
- let TabPanel$1 = class TabPanel extends FoundationElement {
38
+ let Switch$1 = class Switch extends FormAssociatedSwitch {
39
+ constructor() {
40
+ super();
41
+ /**
42
+ * The element's value to be included in form submission when checked.
43
+ * Default to "on" to reach parity with input[type="checkbox"]
44
+ *
45
+ * @internal
46
+ */
47
+ this.initialValue = "on";
48
+ /**
49
+ * @internal
50
+ */
51
+ this.keypressHandler = (e) => {
52
+ if (this.readOnly) {
53
+ return;
54
+ }
55
+ switch (e.key) {
56
+ case keyEnter:
57
+ case keySpace:
58
+ this.checked = !this.checked;
59
+ break;
60
+ }
61
+ };
62
+ /**
63
+ * @internal
64
+ */
65
+ this.clickHandler = (e) => {
66
+ if (!this.disabled && !this.readOnly) {
67
+ this.checked = !this.checked;
68
+ }
69
+ };
70
+ this.proxy.setAttribute("type", "checkbox");
71
+ }
72
+ readOnlyChanged() {
73
+ if (this.proxy instanceof HTMLInputElement) {
74
+ this.proxy.readOnly = this.readOnly;
75
+ }
76
+ this.readOnly
77
+ ? this.classList.add("readonly")
78
+ : this.classList.remove("readonly");
79
+ }
80
+ /**
81
+ * @internal
82
+ */
83
+ checkedChanged(prev, next) {
84
+ super.checkedChanged(prev, next);
85
+ /**
86
+ * @deprecated - this behavior already exists in the template and should not exist in the class.
87
+ */
88
+ this.checked ? this.classList.add("checked") : this.classList.remove("checked");
89
+ }
11
90
  };
91
+ __decorate([
92
+ attr({ attribute: "readonly", mode: "boolean" })
93
+ ], Switch$1.prototype, "readOnly", void 0);
94
+ __decorate([
95
+ observable
96
+ ], Switch$1.prototype, "defaultSlottedNodes", void 0);
12
97
 
13
- class TabPanel extends TabPanel$1 {
98
+ const styles = ":host(.disabled){cursor:not-allowed}.control.connotation-cta{--_connotation-color-primary-text: var(--vvd-switch-cta-primary-text, var(--vvd-color-canvas));--_connotation-color-primary: var(--vvd-switch-cta-primary, var(--vvd-color-cta-500));--_connotation-color-primary-increment: var(--vvd-switch-cta-primary-increment, var(--vvd-color-cta-600));--_connotation-color-firm: var(--vvd-switch-cta-firm, var(--vvd-color-cta-600));--_connotation-color-intermediate: var(--vvd-switch-cta-intermediate, var(--vvd-color-cta-500));--_connotation-color-fierce: var(--vvd-switch-cta-fierce, var(--vvd-color-cta-700))}.control.connotation-alert{--_connotation-color-primary-text: var(--vvd-switch-alert-primary-text, var(--vvd-color-canvas));--_connotation-color-primary: var(--vvd-switch-alert-primary, var(--vvd-color-alert-500));--_connotation-color-primary-increment: var(--vvd-switch-alert-primary-increment, var(--vvd-color-alert-600));--_connotation-color-firm: var(--vvd-switch-alert-firm, var(--vvd-color-alert-600));--_connotation-color-intermediate: var(--vvd-switch-alert-intermediate, var(--vvd-color-alert-500));--_connotation-color-fierce: var(--vvd-switch-alert-fierce, var(--vvd-color-alert-700))}.control.connotation-success{--_connotation-color-primary-text: var(--vvd-switch-success-primary-text, var(--vvd-color-canvas));--_connotation-color-primary: var(--vvd-switch-success-primary, var(--vvd-color-success-500));--_connotation-color-primary-increment: var(--vvd-switch-success-primary-increment, var(--vvd-color-success-600));--_connotation-color-firm: var(--vvd-switch-success-firm, var(--vvd-color-success-600));--_connotation-color-intermediate: var(--vvd-switch-success-intermediate, var(--vvd-color-success-500));--_connotation-color-fierce: var(--vvd-switch-success-fierce, var(--vvd-color-success-700))}.control.connotation-announcement{--_connotation-color-primary-text: var(--vvd-switch-announcement-primary-text, var(--vvd-color-canvas));--_connotation-color-primary: var(--vvd-switch-announcement-primary, var(--vvd-color-announcement-500));--_connotation-color-primary-increment: var(--vvd-switch-announcement-primary-increment, var(--vvd-color-announcement-600));--_connotation-color-firm: var(--vvd-switch-announcement-firm, var(--vvd-color-announcement-600));--_connotation-color-intermediate: var(--vvd-switch-announcement-intermediate, var(--vvd-color-announcement-500));--_connotation-color-fierce: var(--vvd-switch-announcement-fierce, var(--vvd-color-announcement-700))}.control:not(.connotation-cta,.connotation-alert,.connotation-success,.connotation-announcement){--_connotation-color-primary-text: var(--vvd-switch-accent-primary-text, var(--vvd-color-canvas));--_connotation-color-primary: var(--vvd-switch-accent-primary, var(--vvd-color-canvas-text));--_connotation-color-primary-increment: var(--vvd-switch-accent-primary-increment, var(--vvd-color-neutral-800));--_connotation-color-firm: var(--vvd-switch-accent-firm, var(--vvd-color-canvas-text));--_connotation-color-intermediate: var(--vvd-switch-accent-intermediate, var(--vvd-color-neutral-500));--_connotation-color-fierce: var(--vvd-switch-accent-fierce, var(--vvd-color-neutral-700))}.control{--_appearance-color-text: var(--vvd-color-canvas-text);--_appearance-color-fill: var(--vvd-color-canvas);--_appearance-color-outline: var(--_connotation-color-intermediate)}.control.appearance-filled{--_appearance-color-text: var(--_connotation-color-primary-text);--_appearance-color-fill: var(--_connotation-color-primary);--_appearance-color-outline: transparent}.control:where(.hover,:hover):where(:not(.disabled,:disabled,.readonly)){--_appearance-color-text: var(--vvd-color-canvas-text);--_appearance-color-fill: var(--vvd-color-canvas);--_appearance-color-outline: var(--_connotation-color-fierce)}.control:where(.hover,:hover):where(:not(.disabled,:disabled,.readonly)).appearance-filled{--_appearance-color-text: var(--_connotation-color-primary-text);--_appearance-color-fill: var(--_connotation-color-primary-increment);--_appearance-color-outline: transparent}.control:where(.disabled,:disabled){--_appearance-color-text: var(--vvd-color-neutral-300);--_appearance-color-fill: var(--vvd-color-neutral-100);--_appearance-color-outline: var(--vvd-color-neutral-300)}.control:where(.disabled,:disabled).appearance-filled{--_appearance-color-text: var(--vvd-color-neutral-300);--_appearance-color-fill: var(--vvd-color-neutral-100);--_appearance-color-outline: transparent}.control:where(.readonly):where(:not(.disabled,:disabled)){--_appearance-color-text: var(--vvd-color-canvas-text);--_appearance-color-fill: var(--vvd-color-neutral-200);--_appearance-color-outline: var(--vvd-color-neutral-400)}.control:where(.readonly):where(:not(.disabled,:disabled)).appearance-filled{--_appearance-color-text: var(--vvd-color-neutral-800);--_appearance-color-fill: var(--vvd-color-neutral-500);--_appearance-color-outline: transparent}.control{display:inline-flex;border-radius:16px;gap:8px;--focus-inset: -4px;--focus-stroke-gap-color: transparent}.control:focus-visible{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){.control{user-select:none}}.control:not(.disabled){cursor:pointer}.control.disabled{pointer-events:none}.switch{--_switch-inline-size: calc(1px*(20 + 4*clamp(-1, var(--vvd-size-density, 0), 2))*1.8) ;display:flex;box-sizing:border-box;align-items:center;border-radius:40px;background-color:var(--_appearance-color-fill);block-size:calc(1px*(20 + 4*clamp(-1,var(--vvd-size-density, 0),2)));box-shadow:inset 0 0 0 1px var(--_appearance-color-outline);inline-size:var(--_switch-inline-size);transition:all .2s ease-in-out 0s}.checked-indicator{--_switch-checked-indicator-size: calc( calc(1px*(20 + 4*clamp(-1, var(--vvd-size-density, 0), 2))) / 1.6667);--_switch-gutter: calc(var(--_switch-checked-indicator-size) / 3);border-radius:inherit;block-size:var(--_switch-checked-indicator-size);inline-size:var(--_switch-checked-indicator-size);margin-inline-start:auto;transition:all .2s ease-in-out 0s}.control:not(.appearance-filled) .checked-indicator{background-color:var(--_appearance-color-outline)}.control:not(.appearance-filled):where(.readonly) .checked-indicator{background-color:var(--vvd-color-neutral-600)}.control.appearance-filled .checked-indicator{background-color:var(--vvd-color-neutral-100)}.control:not(.checked) .checked-indicator{transform:translate(calc(-1 * var(--_switch-inline-size) + var(--_switch-checked-indicator-size) + var(--_switch-gutter)))}.control.checked .checked-indicator{transform:translate(calc(-1 * var(--_switch-gutter)))}.control.appearance-filled.disabled .checked-indicator{background-color:var(--_appearance-color-text)}.control.appearance-filled.readonly .checked-indicator{background-color:var(--vvd-color-neutral-50)}.label{color:var(--vvd-color-canvas-text);cursor:pointer;font:var(--vvd-typography-base)}";
99
+
100
+ var __defProp = Object.defineProperty;
101
+ var __decorateClass = (decorators, target, key, kind) => {
102
+ var result = void 0 ;
103
+ for (var i = decorators.length - 1, decorator; i >= 0; i--)
104
+ if (decorator = decorators[i])
105
+ result = (decorator(target, key, result) ) || result;
106
+ if (result) __defProp(target, key, result);
107
+ return result;
108
+ };
109
+ class Switch extends Switch$1 {
14
110
  }
111
+ __decorateClass([
112
+ attr
113
+ ], Switch.prototype, "label");
114
+ __decorateClass([
115
+ attr
116
+ ], Switch.prototype, "connotation");
15
117
 
16
- function TabPanelTemplate() {
118
+ const getClasses = (_) => classNames(
119
+ "control",
120
+ ["appearance-filled", _.checked],
121
+ ["checked", _.checked],
122
+ ["disabled", _.disabled],
123
+ ["readonly", _.readOnly],
124
+ [
125
+ `connotation-${_.connotation}`,
126
+ Boolean(_.checked) && Boolean(_.connotation)
127
+ ]
128
+ );
129
+ const SwitchTemplate = () => {
17
130
  return html`
18
- <template slot="tabpanel" role="tabpanel">
19
- <slot></slot>
20
- </template>
131
+ <div
132
+ class="${getClasses}"
133
+ role="switch"
134
+ aria-checked="${(x) => x.checked}"
135
+ aria-disabled="${(x) => x.disabled}"
136
+ aria-readonly="${(x) => x.readOnly}"
137
+ tabindex="${(x) => x.disabled ? null : 0}"
138
+ @keypress="${(x, c) => x.keypressHandler(c.event)}"
139
+ @click="${(x, c) => x.clickHandler(c.event)}"
140
+ >
141
+ <div class="switch">
142
+ <span class="checked-indicator"></span>
143
+ </div>
144
+ ${when(
145
+ (x) => x.label,
146
+ html`<div class="label">${(x) => x.label}</div>`
147
+ )}
148
+ </div>
21
149
  `;
22
- }
150
+ };
23
151
 
24
- const tabPanelDefinition = TabPanel.compose(
25
- {
26
- baseName: "tab-panel",
27
- template: TabPanelTemplate
152
+ const switchDefinition = Switch.compose({
153
+ baseName: "switch",
154
+ template: SwitchTemplate,
155
+ styles,
156
+ shadowOptions: {
157
+ delegatesFocus: true
28
158
  }
29
- );
30
- const tabPanelRegistries = [tabPanelDefinition()];
31
- const registerTabPanel = registerFactory(tabPanelRegistries);
159
+ });
160
+ const switchRegistries = [switchDefinition(), ...iconRegistries];
161
+ const registerSwitch = registerFactory(switchRegistries);
32
162
 
33
- export { tabPanelRegistries as a, registerTabPanel as r, tabPanelDefinition as t };
163
+ export { switchRegistries as a, registerSwitch as r, switchDefinition as s };
@@ -2,15 +2,13 @@
2
2
 
3
3
  const index = require('./index.cjs');
4
4
  const definition$1 = require('./definition11.cjs');
5
- const definition$2 = require('./definition46.cjs');
5
+ const definition$2 = require('./definition47.cjs');
6
6
  const definition$3 = require('./definition30.cjs');
7
7
  const enums = require('./enums.cjs');
8
- require('./affix.cjs');
9
- require('./index2.cjs');
10
- const localized = require('./localized.cjs');
11
8
  const applyMixins = require('./apply-mixins.cjs');
12
- const videoPlayer = require('./video-player.cjs');
9
+ const localized = require('./localized.cjs');
13
10
  const definition = require('./definition29.cjs');
11
+ const playbackRates = require('./playbackRates.cjs');
14
12
  const when = require('./when.cjs');
15
13
  const repeat = require('./repeat.cjs');
16
14
  const classNames = require('./class-names.cjs');
@@ -153,6 +151,7 @@ class AudioPlayer extends index.FoundationElement {
153
151
  disconnectedCallback() {
154
152
  super.disconnectedCallback();
155
153
  this.#setSliderInteractionListeners(false);
154
+ this.pause();
156
155
  }
157
156
  play() {
158
157
  this.#pausedChanged(PLAY);
@@ -332,7 +331,7 @@ const AudioPlayerTemplate = (context) => {
332
331
  ></${buttonTag}>
333
332
 
334
333
  ${repeat.repeat(
335
- (x) => videoPlayer.getPlaybackRatesArray(x.playbackRates),
334
+ (x) => playbackRates.getPlaybackRatesArray(x.playbackRates),
336
335
  index.html`<${menuItemTag} @click="${handlePlaybackRateClick}"
337
336
  role="menuitemradio"
338
337
  class="playback-rate"
@@ -1,14 +1,12 @@
1
- import { a as attr, F as FoundationElement, O as Observable, h as html, r as registerFactory } from './index.js';
1
+ import { F as FoundationElement, O as Observable, a as attr, h as html, r as registerFactory } from './index.js';
2
2
  import { B as Button, a as buttonRegistries } from './definition11.js';
3
- import { S as Slider, a as sliderRegistries } from './definition46.js';
3
+ import { S as Slider, a as sliderRegistries } from './definition47.js';
4
4
  import { a as menuRegistries } from './definition30.js';
5
5
  import { M as MediaSkipBy } from './enums.js';
6
- import './affix.js';
7
- import './index2.js';
8
- import { L as Localized } from './localized.js';
9
6
  import { a as applyMixins } from './apply-mixins.js';
10
- import { g as getPlaybackRatesArray } from './video-player.js';
7
+ import { L as Localized } from './localized.js';
11
8
  import { b as Menu, c as MenuItem } from './definition29.js';
9
+ import { g as getPlaybackRatesArray } from './playbackRates.js';
12
10
  import { w as when } from './when.js';
13
11
  import { r as repeat } from './repeat.js';
14
12
  import { c as classNames } from './class-names.js';
@@ -151,6 +149,7 @@ class AudioPlayer extends FoundationElement {
151
149
  disconnectedCallback() {
152
150
  super.disconnectedCallback();
153
151
  this.#setSliderInteractionListeners(false);
152
+ this.pause();
154
153
  }
155
154
  play() {
156
155
  this.#pausedChanged(PLAY);
@@ -1,98 +1,37 @@
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 classNames = require('./class-names.cjs');
8
4
 
9
5
  /**
10
- * A Tab Component to be used with {@link @microsoft/fast-foundation#(Tabs:class)}
6
+ * A TabPanel Component to be used with {@link @microsoft/fast-foundation#(Tabs:class)}
11
7
  *
12
- * @slot - The default slot for the tab content
8
+ * @slot - The default slot for the tabpanel content
13
9
  *
14
10
  * @public
15
11
  */
16
- let Tab$1 = class Tab extends index.FoundationElement {
12
+ let TabPanel$1 = class TabPanel extends index.FoundationElement {
17
13
  };
18
- index.__decorate([
19
- index.attr({ mode: "boolean" })
20
- ], Tab$1.prototype, "disabled", void 0);
21
14
 
22
- const styles = ":host{--_vvd-tab-accent-firm-wrapper: var( --vvd-tab-accent-firm );--_vvd-tab-cta-firm-wrapper: var( --vvd-tab-cta-firm )}.base{--vvd-tab-accent-firm: var( --_vvd-tab-accent-firm-wrapper, var(--vvd-tab-accent-primary) );--vvd-tab-cta-firm: var( --_vvd-tab-cta-firm-wrapper, var(--vvd-tab-cta-primary) )}:host(.vertical){justify-content:end;grid-column:1/auto}:host([disabled]){cursor:not-allowed}:host(:focus-visible){outline:none}.base{position:relative;display:flex;box-sizing:border-box;align-items:center;padding:var(--_tabs-tablist-gutter);background-color:var(--_appearance-color-fill);box-shadow:inset 0 0 0 1px var(--_appearance-color-outline);color:var(--_appearance-color-text);font:var(--vvd-typography-base-bold);gap:var(--_tabs-tablist-gutter);min-block-size:40px;vertical-align:middle;white-space:nowrap}.base{--_appearance-color-text: var(--_connotation-color-firm);--_appearance-color-fill: transparent;--_appearance-color-outline: transparent}.base:where(.hover,:hover):where(:not(.disabled,:disabled,.readonly)){--_appearance-color-text: var(--_connotation-color-firm);--_appearance-color-fill: var(--_connotation-color-faint);--_appearance-color-outline: transparent}.base:where(.disabled,:disabled){--_appearance-color-text: var(--vvd-color-neutral-300);--_appearance-color-fill: transparent;--_appearance-color-outline: transparent}.base:where(.active,:active):where(:not(.disabled,:disabled)){--_appearance-color-text: var(--_connotation-color-firm);--_appearance-color-fill: var(--_connotation-color-soft);--_appearance-color-outline: transparent}.base.connotation-cta{--_connotation-color-primary-text: var(--vvd-tab-cta-primary-text, var(--vvd-color-canvas));--_connotation-color-firm: var(--vvd-tab-cta-firm, var(--vvd-color-cta-600));--_connotation-color-faint: var(--vvd-tab-cta-faint, var(--vvd-color-cta-50));--_connotation-color-fierce: var(--vvd-tab-cta-fierce, var(--vvd-color-cta-700));--_connotation-color-pale: var(--vvd-tab-cta-pale, var(--vvd-color-cta-300));--_connotation-color-soft: var(--vvd-tab-cta-soft, var(--vvd-color-cta-100))}.base:not(.connotation-cta){--_connotation-color-primary-text: var(--vvd-tab-accent-primary-text, var(--vvd-color-canvas));--_connotation-color-firm: var(--vvd-tab-accent-firm, var(--vvd-color-canvas-text));--_connotation-color-faint: var(--vvd-tab-accent-faint, var(--vvd-color-neutral-50));--_connotation-color-fierce: var(--vvd-tab-accent-fierce, var(--vvd-color-neutral-700));--_connotation-color-pale: var(--vvd-tab-accent-pale, var(--vvd-color-neutral-300));--_connotation-color-soft: var(--vvd-tab-accent-soft, var(--vvd-color-neutral-100))}@supports (user-select: none){.base{user-select:none}}.base:not(.shape-sharp){border-radius:8px}.base:not(.disabled){cursor:pointer}.base.disabled{pointer-events:none}:host(:focus-visible) .base{--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))}:host(.vertical) .base{margin-inline-start:var(--_tabs-active-indicator-stroke-width)}slot[name=icon]{font-size:20px;line-height:1}.icon-trailing slot[name=icon]{display:inline-block;order:1;margin-inline-start:auto}:host(:not(.vertical)) .base:after{position:absolute;border-radius:2px;background:currentColor;block-size:2px;content:\"\";inline-size:100%;inset-block-end:0;inset-inline-start:0;pointer-events:none;transition-property:opacity}:host(:not(.vertical)):host([aria-selected=true]) .base:after{transition-delay:.2s}:host(:not(.vertical)):host(:not([aria-selected=true])) .base:after{opacity:0}";
23
-
24
- var __defProp = Object.defineProperty;
25
- var __decorateClass = (decorators, target, key, kind) => {
26
- var result = void 0 ;
27
- for (var i = decorators.length - 1, decorator; i >= 0; i--)
28
- if (decorator = decorators[i])
29
- result = (decorator(target, key, result) ) || result;
30
- if (result) __defProp(target, key, result);
31
- return result;
32
- };
33
- class Tab extends Tab$1 {
34
- constructor() {
35
- super(...arguments);
36
- this.tabIndex = "-1";
37
- this.ariaSelected = null;
38
- }
15
+ class TabPanel extends TabPanel$1 {
39
16
  }
40
- __decorateClass([
41
- index.attr
42
- ], Tab.prototype, "connotation");
43
- __decorateClass([
44
- index.attr
45
- ], Tab.prototype, "shape");
46
- __decorateClass([
47
- index.attr
48
- ], Tab.prototype, "label");
49
- __decorateClass([
50
- index.attr({ mode: "fromView" })
51
- ], Tab.prototype, "tabIndex");
52
- __decorateClass([
53
- index.attr({ attribute: "aria-selected" })
54
- ], Tab.prototype, "ariaSelected");
55
- applyMixins.applyMixins(Tab, affix.AffixIconWithTrailing);
56
17
 
57
- const getClasses = ({
58
- connotation,
59
- disabled,
60
- ariaSelected,
61
- iconTrailing,
62
- shape
63
- }) => classNames.classNames(
64
- "base",
65
- [
66
- `connotation-${connotation}`,
67
- Boolean(connotation) && ariaSelected === "true"
68
- ],
69
- [`shape-${shape}`, Boolean(shape)],
70
- ["disabled", Boolean(disabled)],
71
- ["selected", ariaSelected === "true"],
72
- ["icon-trailing", iconTrailing]
73
- );
74
- function TabTemplate(context) {
75
- const affixIconTemplate = affix.affixIconTemplateFactory(context);
76
- return index.html` <template
77
- slot="tab"
78
- role="tab"
79
- aria-disabled="${(x) => x.disabled}"
80
- aria-selected="${(x) => x.ariaSelected}"
81
- >
82
- <div class="${getClasses}">
83
- ${(x) => affixIconTemplate(x.icon, affix.IconWrapper.Slot)} ${(x) => x.label}
84
- </div>
85
- </template>`;
18
+ function TabPanelTemplate() {
19
+ return index.html`
20
+ <template slot="tabpanel" role="tabpanel">
21
+ <slot></slot>
22
+ </template>
23
+ `;
86
24
  }
87
25
 
88
- const tabDefinition = Tab.compose({
89
- baseName: "tab",
90
- template: TabTemplate,
91
- styles
92
- });
93
- const tabRegistries = [tabDefinition(), ...definition.iconRegistries];
94
- const registerTab = index.registerFactory(tabRegistries);
26
+ const tabPanelDefinition = TabPanel.compose(
27
+ {
28
+ baseName: "tab-panel",
29
+ template: TabPanelTemplate
30
+ }
31
+ );
32
+ const tabPanelRegistries = [tabPanelDefinition()];
33
+ const registerTabPanel = index.registerFactory(tabPanelRegistries);
95
34
 
96
- exports.registerTab = registerTab;
97
- exports.tabDefinition = tabDefinition;
98
- exports.tabRegistries = tabRegistries;
35
+ exports.registerTabPanel = registerTabPanel;
36
+ exports.tabPanelDefinition = tabPanelDefinition;
37
+ exports.tabPanelRegistries = tabPanelRegistries;