@warp-ds/elements 2.3.0-next.1 → 2.3.0-next.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (248) hide show
  1. package/dist/custom-elements.json +3551 -312
  2. package/dist/index.d.ts +571 -2
  3. package/dist/packages/affix/react.d.ts +1 -1
  4. package/dist/packages/alert/react.d.ts +1 -1
  5. package/dist/packages/attention/index.js +3 -3
  6. package/dist/packages/attention/index.js.map +1 -1
  7. package/dist/packages/attention/react.d.ts +1 -1
  8. package/dist/packages/badge/react.d.ts +1 -1
  9. package/dist/packages/box/react.d.ts +1 -1
  10. package/dist/packages/breadcrumbs/react.d.ts +1 -1
  11. package/dist/packages/button/index.js +3 -3
  12. package/dist/packages/button/index.js.map +1 -1
  13. package/dist/packages/button/react.d.ts +1 -1
  14. package/dist/packages/card/react.d.ts +1 -1
  15. package/dist/packages/combobox/combobox.react.stories.d.ts +28 -0
  16. package/dist/packages/combobox/combobox.react.stories.js +90 -0
  17. package/dist/packages/combobox/combobox.stories.d.ts +18 -0
  18. package/dist/packages/combobox/combobox.stories.js +117 -0
  19. package/dist/packages/combobox/index.d.ts +85 -0
  20. package/dist/packages/combobox/index.js +2492 -0
  21. package/dist/packages/combobox/index.js.map +7 -0
  22. package/dist/packages/combobox/locales/da/messages.d.mts +1 -0
  23. package/dist/packages/combobox/locales/da/messages.mjs +1 -0
  24. package/dist/packages/combobox/locales/en/messages.d.mts +1 -0
  25. package/dist/packages/combobox/locales/en/messages.mjs +1 -0
  26. package/dist/packages/combobox/locales/fi/messages.d.mts +1 -0
  27. package/dist/packages/combobox/locales/fi/messages.mjs +1 -0
  28. package/dist/packages/combobox/locales/nb/messages.d.mts +1 -0
  29. package/dist/packages/combobox/locales/nb/messages.mjs +1 -0
  30. package/dist/packages/combobox/locales/sv/messages.d.mts +1 -0
  31. package/dist/packages/combobox/locales/sv/messages.mjs +1 -0
  32. package/dist/packages/combobox/react.d.ts +7 -0
  33. package/dist/packages/combobox/react.js +17 -0
  34. package/dist/packages/combobox/styles.d.ts +1 -0
  35. package/dist/packages/combobox/styles.js +2 -0
  36. package/dist/packages/datepicker/DatePicker.test.d.ts +2 -0
  37. package/dist/packages/datepicker/DatePicker.test.js +69 -0
  38. package/dist/packages/datepicker/datepicker.d.ts +102 -0
  39. package/dist/packages/datepicker/datepicker.js +2785 -0
  40. package/dist/packages/datepicker/datepicker.js.map +7 -0
  41. package/dist/packages/datepicker/datepicker.react.stories.d.ts +18 -0
  42. package/dist/packages/datepicker/datepicker.react.stories.js +26 -0
  43. package/dist/packages/datepicker/datepicker.stories.d.ts +12 -0
  44. package/dist/packages/datepicker/datepicker.stories.js +51 -0
  45. package/dist/packages/datepicker/datepicker.test.d.ts +2 -0
  46. package/dist/packages/datepicker/datepicker.test.js +62 -0
  47. package/dist/packages/datepicker/index.d.ts +1 -0
  48. package/dist/packages/datepicker/index.js +1 -0
  49. package/dist/packages/datepicker/locales/da/messages.d.mts +1 -0
  50. package/dist/packages/datepicker/locales/da/messages.mjs +1 -0
  51. package/dist/packages/datepicker/locales/en/messages.d.mts +1 -0
  52. package/dist/packages/datepicker/locales/en/messages.mjs +1 -0
  53. package/dist/packages/datepicker/locales/fi/messages.d.mts +1 -0
  54. package/dist/packages/datepicker/locales/fi/messages.mjs +1 -0
  55. package/dist/packages/datepicker/locales/nb/messages.d.mts +1 -0
  56. package/dist/packages/datepicker/locales/nb/messages.mjs +1 -0
  57. package/dist/packages/datepicker/locales/sv/messages.d.mts +1 -0
  58. package/dist/packages/datepicker/locales/sv/messages.mjs +1 -0
  59. package/dist/packages/datepicker/react.d.ts +5 -0
  60. package/dist/packages/datepicker/react.js +15 -0
  61. package/dist/packages/datepicker/styles/w-datepicker-calendar.styles.d.ts +1 -0
  62. package/dist/packages/datepicker/styles/w-datepicker-calendar.styles.js +15 -0
  63. package/dist/packages/datepicker/styles/w-datepicker-day.styles.d.ts +1 -0
  64. package/dist/packages/datepicker/styles/w-datepicker-day.styles.js +64 -0
  65. package/dist/packages/datepicker/styles/w-datepicker-month.styles.d.ts +1 -0
  66. package/dist/packages/datepicker/styles/w-datepicker-month.styles.js +72 -0
  67. package/dist/packages/datepicker/styles/w-datepicker.styles.d.ts +1 -0
  68. package/dist/packages/datepicker/styles/w-datepicker.styles.js +101 -0
  69. package/dist/packages/datepicker/utils.d.ts +13 -0
  70. package/dist/packages/datepicker/utils.js +28 -0
  71. package/dist/packages/dead-toggle/dead-toggle.react.stories.d.ts +15 -0
  72. package/dist/packages/dead-toggle/dead-toggle.react.stories.js +34 -0
  73. package/dist/packages/dead-toggle/dead-toggle.stories.d.ts +14 -0
  74. package/dist/packages/dead-toggle/dead-toggle.stories.js +45 -0
  75. package/dist/packages/dead-toggle/dead-toggle.test.d.ts +1 -0
  76. package/dist/packages/dead-toggle/dead-toggle.test.js +9 -0
  77. package/dist/packages/dead-toggle/index.d.ts +17 -0
  78. package/dist/packages/dead-toggle/index.js +2547 -0
  79. package/dist/packages/dead-toggle/index.js.map +7 -0
  80. package/dist/packages/dead-toggle/react.d.ts +2 -0
  81. package/dist/packages/dead-toggle/react.js +11 -0
  82. package/dist/packages/expandable/react.d.ts +1 -1
  83. package/dist/packages/link/index.js +2640 -93
  84. package/dist/packages/link/index.js.map +7 -0
  85. package/dist/packages/link/link.react.stories.d.ts +21 -0
  86. package/dist/packages/link/link.react.stories.js +96 -0
  87. package/dist/packages/link/link.stories.d.ts +20 -0
  88. package/dist/packages/link/link.stories.js +110 -0
  89. package/dist/packages/link/link.test.d.ts +1 -0
  90. package/dist/packages/link/link.test.js +9 -0
  91. package/dist/packages/link/react.d.ts +2 -0
  92. package/dist/packages/link/react.js +11 -0
  93. package/dist/packages/link/styles.js +3 -3
  94. package/dist/packages/modal/react.d.ts +1 -1
  95. package/dist/packages/pageindicator/index.d.ts +10 -0
  96. package/dist/packages/pageindicator/index.js +32 -0
  97. package/dist/packages/pageindicator/index.js.map +7 -0
  98. package/dist/packages/pageindicator/pageindicator.react.stories.d.ts +19 -0
  99. package/dist/packages/pageindicator/pageindicator.react.stories.js +20 -0
  100. package/dist/packages/pageindicator/pageindicator.stories.d.ts +32 -0
  101. package/dist/packages/pageindicator/pageindicator.stories.js +71 -0
  102. package/dist/packages/pageindicator/react.d.ts +2 -0
  103. package/dist/packages/pageindicator/react.js +11 -0
  104. package/dist/packages/pageindicator/style.d.ts +1 -0
  105. package/dist/packages/pageindicator/style.js +26 -0
  106. package/dist/packages/pagination/react.d.ts +1 -1
  107. package/dist/packages/pill/react.d.ts +1 -1
  108. package/dist/packages/rip-and-tear-checkbox/checkbox-group.d.ts +10 -0
  109. package/dist/packages/rip-and-tear-checkbox/checkbox-group.js +7 -0
  110. package/dist/packages/rip-and-tear-checkbox/checkbox-group.js.map +7 -0
  111. package/dist/packages/rip-and-tear-checkbox/checkbox.d.ts +66 -0
  112. package/dist/packages/rip-and-tear-checkbox/checkbox.js +2591 -0
  113. package/dist/packages/rip-and-tear-checkbox/checkbox.js.map +7 -0
  114. package/dist/packages/rip-and-tear-checkbox/checkbox.stories.d.ts +11 -0
  115. package/dist/packages/rip-and-tear-checkbox/checkbox.stories.js +25 -0
  116. package/dist/packages/rip-and-tear-checkbox/index.d.ts +1 -0
  117. package/dist/packages/rip-and-tear-checkbox/index.js +6 -0
  118. package/dist/packages/rip-and-tear-checkbox/react.d.ts +7 -0
  119. package/dist/packages/rip-and-tear-checkbox/react.js +20 -0
  120. package/dist/packages/rip-and-tear-checkbox/rip-and-tear-checkbox.react.stories.d.ts +12 -0
  121. package/dist/packages/rip-and-tear-checkbox/rip-and-tear-checkbox.react.stories.js +10 -0
  122. package/dist/packages/rip-and-tear-checkbox/styles.d.ts +0 -0
  123. package/dist/packages/rip-and-tear-checkbox/styles.js +0 -0
  124. package/dist/packages/rip-and-tear-radio/base-element.d.ts +46 -0
  125. package/dist/packages/rip-and-tear-radio/base-element.js +100 -0
  126. package/dist/packages/rip-and-tear-radio/custom-error-validator.d.ts +6 -0
  127. package/dist/packages/rip-and-tear-radio/custom-error-validator.js +22 -0
  128. package/dist/packages/rip-and-tear-radio/form-associated-element.d.ts +103 -0
  129. package/dist/packages/rip-and-tear-radio/form-associated-element.js +282 -0
  130. package/dist/packages/rip-and-tear-radio/host-styles.d.ts +1 -0
  131. package/dist/packages/rip-and-tear-radio/host-styles.js +12 -0
  132. package/dist/packages/rip-and-tear-radio/index.d.ts +1 -0
  133. package/dist/packages/rip-and-tear-radio/index.js +6 -0
  134. package/dist/packages/rip-and-tear-radio/invalid.d.ts +8 -0
  135. package/dist/packages/rip-and-tear-radio/invalid.js +5 -0
  136. package/dist/packages/rip-and-tear-radio/math.d.ts +1 -0
  137. package/dist/packages/rip-and-tear-radio/math.js +4 -0
  138. package/dist/packages/rip-and-tear-radio/radio-group-styles.d.ts +1 -0
  139. package/dist/packages/rip-and-tear-radio/radio-group-styles.js +59 -0
  140. package/dist/packages/rip-and-tear-radio/radio-group-styles.js.map +7 -0
  141. package/dist/packages/rip-and-tear-radio/radio-group.d.ts +72 -0
  142. package/dist/packages/rip-and-tear-radio/radio-group.js +2648 -0
  143. package/dist/packages/rip-and-tear-radio/radio-group.js.map +7 -0
  144. package/dist/packages/rip-and-tear-radio/radio-styles.d.ts +0 -0
  145. package/dist/packages/rip-and-tear-radio/radio-styles.js +1 -0
  146. package/dist/packages/rip-and-tear-radio/radio-styles.js.map +7 -0
  147. package/dist/packages/rip-and-tear-radio/radio.d.ts +38 -0
  148. package/dist/packages/rip-and-tear-radio/radio.js +2562 -0
  149. package/dist/packages/rip-and-tear-radio/radio.js.map +7 -0
  150. package/dist/packages/rip-and-tear-radio/radio.stories.d.ts +8 -0
  151. package/dist/packages/rip-and-tear-radio/radio.stories.js +2653 -0
  152. package/dist/packages/rip-and-tear-radio/radio.stories.js.map +7 -0
  153. package/dist/packages/rip-and-tear-radio/react.d.ts +9 -0
  154. package/dist/packages/rip-and-tear-radio/react.js +22 -0
  155. package/dist/packages/rip-and-tear-radio/required-validator.d.ts +11 -0
  156. package/dist/packages/rip-and-tear-radio/required-validator.js +34 -0
  157. package/dist/packages/rip-and-tear-radio/rip-and-tear-radio.react.stories.d.ts +9 -0
  158. package/dist/packages/rip-and-tear-radio/rip-and-tear-radio.react.stories.js +10 -0
  159. package/dist/packages/rip-and-tear-radio/slot.d.ts +20 -0
  160. package/dist/packages/rip-and-tear-radio/slot.js +71 -0
  161. package/dist/packages/rip-and-tear-radio/watch.d.ts +26 -0
  162. package/dist/packages/rip-and-tear-radio/watch.js +39 -0
  163. package/dist/packages/select/react.d.ts +1 -1
  164. package/dist/packages/slider/react.d.ts +2 -2
  165. package/dist/packages/steps/index.d.ts +36 -0
  166. package/dist/packages/steps/index.js +2465 -0
  167. package/dist/packages/steps/index.js.map +7 -0
  168. package/dist/packages/steps/locales/da/messages.d.mts +1 -0
  169. package/dist/packages/steps/locales/da/messages.mjs +1 -0
  170. package/dist/packages/steps/locales/en/messages.d.mts +1 -0
  171. package/dist/packages/steps/locales/en/messages.mjs +1 -0
  172. package/dist/packages/steps/locales/fi/messages.d.mts +1 -0
  173. package/dist/packages/steps/locales/fi/messages.mjs +1 -0
  174. package/dist/packages/steps/locales/nb/messages.d.mts +1 -0
  175. package/dist/packages/steps/locales/nb/messages.mjs +1 -0
  176. package/dist/packages/steps/locales/sv/messages.d.mts +1 -0
  177. package/dist/packages/steps/locales/sv/messages.mjs +1 -0
  178. package/dist/packages/steps/react.d.ts +3 -0
  179. package/dist/packages/steps/react.js +16 -0
  180. package/dist/packages/steps/steps.react.stories.d.ts +15 -0
  181. package/dist/packages/steps/steps.react.stories.js +112 -0
  182. package/dist/packages/steps/steps.stories.d.ts +12 -0
  183. package/dist/packages/steps/steps.stories.js +172 -0
  184. package/dist/packages/steps/styles.d.ts +1 -0
  185. package/dist/packages/steps/styles.js +2 -0
  186. package/dist/packages/switch/index.d.ts +15 -0
  187. package/dist/packages/switch/index.js +2456 -0
  188. package/dist/packages/switch/index.js.map +7 -0
  189. package/dist/packages/switch/react.d.ts +5 -0
  190. package/dist/packages/switch/react.js +15 -0
  191. package/dist/packages/switch/styles.d.ts +1 -0
  192. package/dist/packages/switch/styles.js +2 -0
  193. package/dist/packages/switch/switch.react.stories.d.ts +15 -0
  194. package/dist/packages/switch/switch.react.stories.js +29 -0
  195. package/dist/packages/switch/switch.stories.d.ts +9 -0
  196. package/dist/packages/switch/switch.stories.js +34 -0
  197. package/dist/packages/tabs/index.d.ts +4 -0
  198. package/dist/packages/tabs/index.js +3 -0
  199. package/dist/packages/tabs/react.d.ts +12 -0
  200. package/dist/packages/tabs/react.js +31 -0
  201. package/dist/packages/tabs/styles.d.ts +1 -0
  202. package/dist/packages/tabs/styles.js +2 -0
  203. package/dist/packages/tabs/tab-panel.d.ts +20 -0
  204. package/dist/packages/tabs/tab-panel.js +51 -0
  205. package/dist/packages/tabs/tab.d.ts +18 -0
  206. package/dist/packages/tabs/tab.js +2464 -0
  207. package/dist/packages/tabs/tab.js.map +7 -0
  208. package/dist/packages/tabs/tabs.d.ts +40 -0
  209. package/dist/packages/tabs/tabs.js +2448 -0
  210. package/dist/packages/tabs/tabs.js.map +7 -0
  211. package/dist/packages/tabs/tabs.react.stories.d.ts +15 -0
  212. package/dist/packages/tabs/tabs.react.stories.js +51 -0
  213. package/dist/packages/tabs/tabs.stories.d.ts +11 -0
  214. package/dist/packages/tabs/tabs.stories.js +93 -0
  215. package/dist/packages/textarea/index.d.ts +1 -0
  216. package/dist/packages/textarea/index.js +1 -0
  217. package/dist/packages/textarea/locales/da/messages.d.mts +1 -0
  218. package/dist/packages/textarea/locales/da/messages.mjs +1 -0
  219. package/dist/packages/textarea/locales/en/messages.d.mts +1 -0
  220. package/dist/packages/textarea/locales/en/messages.mjs +1 -0
  221. package/dist/packages/textarea/locales/fi/messages.d.mts +1 -0
  222. package/dist/packages/textarea/locales/fi/messages.mjs +1 -0
  223. package/dist/packages/textarea/locales/nb/messages.d.mts +1 -0
  224. package/dist/packages/textarea/locales/nb/messages.mjs +1 -0
  225. package/dist/packages/textarea/locales/sv/messages.d.mts +1 -0
  226. package/dist/packages/textarea/locales/sv/messages.mjs +1 -0
  227. package/dist/packages/textarea/react.d.ts +11 -0
  228. package/dist/packages/textarea/react.js +21 -0
  229. package/dist/packages/textarea/styles.d.ts +1 -0
  230. package/dist/packages/textarea/styles.js +2 -0
  231. package/dist/packages/textarea/textarea.d.ts +48 -0
  232. package/dist/packages/textarea/textarea.js +2475 -0
  233. package/dist/packages/textarea/textarea.js.map +7 -0
  234. package/dist/packages/textarea/textarea.react.stories.d.ts +33 -0
  235. package/dist/packages/textarea/textarea.react.stories.js +41 -0
  236. package/dist/packages/textarea/textarea.stories.d.ts +19 -0
  237. package/dist/packages/textarea/textarea.stories.js +85 -0
  238. package/dist/packages/textarea/textarea.test.d.ts +1 -0
  239. package/dist/packages/textarea/textarea.test.js +49 -0
  240. package/dist/packages/textfield/index.d.ts +2 -0
  241. package/dist/packages/textfield/index.js +5 -5
  242. package/dist/packages/textfield/index.js.map +2 -2
  243. package/dist/packages/textfield/react.d.ts +1 -1
  244. package/dist/packages/textfield/textfield.react.stories.d.ts +1 -1
  245. package/dist/packages/toggle-styles.d.ts +1 -0
  246. package/dist/packages/toggle-styles.js +108 -0
  247. package/dist/web-types.json +539 -1
  248. package/package.json +191 -3
@@ -1,4 +1,4 @@
1
- import { WarpTextField } from '.';
1
+ import { WarpTextField } from './index.js';
2
2
  export declare const TextField: import("@lit/react").ReactWebComponent<WarpTextField, {
3
3
  onBlur: string;
4
4
  onblur: string;
@@ -3,7 +3,7 @@ import { StoryObj } from '@storybook/react';
3
3
  import { TextField } from './react';
4
4
  declare const _default: {
5
5
  title: string;
6
- render(args: Omit<React.HTMLAttributes<import(".").WarpTextField>, "label" | "onblur" | "onchange" | "onfocus" | "oninput" | "onFocus" | "onBlur" | "onChange" | "onInput" | "render" | "renderOptions" | "connectedCallback" | "disconnectedCallback" | "renderRoot" | "isUpdatePending" | "hasUpdated" | "addController" | "removeController" | "attributeChangedCallback" | "requestUpdate" | "updateComplete" | "form" | "mask" | "pattern" | "disabled" | "name" | "type" | "value" | "updated" | "validationTarget" | "internals" | "showError" | "validationMessage" | "validity" | "validationComplete" | "checkValidity" | "formResetCallback" | "resetFormControl" | "valueChangedCallback" | "validityCallback" | "validationMessageCallback" | "setValue" | "shouldFormValueUpdate" | "invalid" | "readOnly" | "helpText" | "size" | "max" | "min" | "minLength" | "maxLength" | "placeholder" | "required" | "formatter" | "_hasPrefix" | "_hasSuffix" | "_inputstyles" | "_helptextstyles" | "_label" | "_helpId" | "_id" | "_error" | "handler" | "prefixSlotChange" | "suffixSlotChange"> & {
6
+ render(args: Omit<React.HTMLAttributes<import(".").WarpTextField>, "label" | "onblur" | "onchange" | "onfocus" | "oninput" | "onFocus" | "onBlur" | "onChange" | "onInput" | "render" | "renderOptions" | "connectedCallback" | "disconnectedCallback" | "renderRoot" | "isUpdatePending" | "hasUpdated" | "addController" | "removeController" | "attributeChangedCallback" | "requestUpdate" | "updateComplete" | "form" | "mask" | "pattern" | "disabled" | "name" | "type" | "value" | "updated" | "validationTarget" | "internals" | "showError" | "validationMessage" | "validity" | "validationComplete" | "checkValidity" | "formResetCallback" | "resetFormControl" | "valueChangedCallback" | "validityCallback" | "validationMessageCallback" | "setValue" | "shouldFormValueUpdate" | "invalid" | "readOnly" | "helpText" | "size" | "max" | "min" | "minLength" | "maxLength" | "placeholder" | "readonly" | "required" | "formatter" | "_hasPrefix" | "_hasSuffix" | "_inputstyles" | "_helptextstyles" | "_label" | "_helpId" | "_id" | "_error" | "handler" | "prefixSlotChange" | "suffixSlotChange"> & {
7
7
  onBlur?: (e: Event) => void;
8
8
  onblur?: (e: Event) => void;
9
9
  onChange?: (e: Event) => void;
@@ -0,0 +1 @@
1
+ export declare const toggleStyles: import("lit").CSSResult;
@@ -0,0 +1,108 @@
1
+ import { css } from 'lit';
2
+ export const toggleStyles = css `
3
+ [part~='label'] {
4
+ display: block;
5
+ font-size: var(--w-font-size-m);
6
+ line-height: var(--w-line-height-m);
7
+ user-select: none;
8
+ cursor: pointer;
9
+ }
10
+ .wrapper {
11
+ display: grid;
12
+ grid-template-columns: 2rem max-content;
13
+ gap: 8px;
14
+ }
15
+ .hide-toggle {
16
+ position: absolute;
17
+ padding: 0;
18
+ margin: 0;
19
+ opacity: 0;
20
+ pointer-events: none;
21
+ inset: 0;
22
+ }
23
+ .control {
24
+ display: block;
25
+ border-width: 1px;
26
+ transition-property: all;
27
+ transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
28
+ transition-duration: 150ms;
29
+ cursor: pointer;
30
+ appearance: none;
31
+ user-select: none;
32
+ flex-shrink: 0;
33
+ height: 2rem;
34
+ width: 2rem;
35
+ background-color: var(--w-s-color-background);
36
+ border-color: var(--w-s-color-border-strong);
37
+ color: var(--w-s-color-icon-inverted);
38
+ font-weight: 700;
39
+ text-align: center;
40
+ line-height: var(--w-line-height-xs);
41
+ font-size: var(--w-font-size-m);
42
+ }
43
+ .checkbox {
44
+ position: relative;
45
+ }
46
+ :host([type='checkbox']) .control {
47
+ border-radius: 4px;
48
+ }
49
+ .checkbox:has(:checked, :indeterminate),
50
+ :host([type='checkbox'][checked]) .control,
51
+ :host([type='checkbox'][indeterminate]) .control {
52
+ background-color: var(--w-s-color-background-primary);
53
+ border-color: var(--w-s-color-border-primary);
54
+ }
55
+ .checkbox:has(:checked),
56
+ :host([type='checkbox'][checked]) .control {
57
+ background-image: var(--w-icon-toggle-checked);
58
+ background-position: center;
59
+ }
60
+ :host([type='radio']) .control,
61
+ :host([role='radio']) .control {
62
+ border-radius: 50%;
63
+ }
64
+ :host([type='radio'][checked]) .control,
65
+ /* :state is newly available, so we set an attribute in radio for compat */
66
+ :host([role='radio'][checked-ui]) .control,
67
+ :host([role='radio']:state(checked)) .control {
68
+ border-color: var(--w-s-color-border-selected);
69
+ border-width: 0.6rem;
70
+ }
71
+ .checkbox:has(:invalid),
72
+ :host([invalid]) .control {
73
+ border-color: var(--w-s-color-border-negative) !important;
74
+ }
75
+ /* handles invalid checkbox state inside w-checkbox */
76
+ .checkbox:has(:checked, :indeterminate):has(:invalid),
77
+ /* allows invalid to be set on the w-checkbox element */
78
+ :host([invalid]) .checkbox:has(:checked, :indeterminate),
79
+ :host([type='checkbox'][invalid][checked]) .control,
80
+ :host([type='checkbox'][invalid][indeterminate]) .control {
81
+ background-color: var(--w-s-color-background-negative);
82
+ }
83
+
84
+ :host(:focus-visible) {
85
+ outline: none;
86
+ }
87
+ .checkbox:has(> input:focus-visible:not(:disabled)),
88
+ :host(:focus-visible) .control {
89
+ outline: 2px solid var(--w-s-color-border-focus);
90
+ outline-offset: var(--w-outline-offset, 1px);
91
+ }
92
+
93
+ :host([type='radio'][disabled]) .control,
94
+ /* :state is newly available, so we set an attribute in radio for compat */
95
+ :host([role='radio'][disabled-ui]) .control,
96
+ :host([role='radio']:state(disabled)) .control,
97
+ :host([type='checkbox'][disabled]) .control,
98
+ .checkbox:has(> input:disabled) {
99
+ border-color: var(--w-s-color-border-disabled);
100
+ background-color: var(--w-s-color-background-disabled-subtle);
101
+ }
102
+
103
+ :host([type='checkbox'][disabled][checked]) .control,
104
+ :host([type='checkbox'][disabled][indeterminate]) .control,
105
+ .checkbox:has(:checked, :indeterminate):has(> input:disabled) {
106
+ background-color: var(--w-s-color-background-disabled);
107
+ }
108
+ `;