@warp-ds/elements 2.3.2 → 2.4.0-next.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/custom-elements.json +3851 -0
- package/dist/index.d.ts +859 -0
- package/dist/packages/checkbox/checkbox-group.d.ts +10 -0
- package/dist/packages/checkbox/checkbox-group.js +7 -0
- package/dist/packages/checkbox/checkbox-group.js.map +7 -0
- package/dist/packages/checkbox/checkbox.d.ts +66 -0
- package/dist/packages/checkbox/checkbox.js +2591 -0
- package/dist/packages/checkbox/checkbox.js.map +7 -0
- package/dist/packages/checkbox/checkbox.react.stories.d.ts +12 -0
- package/dist/packages/checkbox/checkbox.react.stories.js +10 -0
- package/dist/packages/checkbox/checkbox.stories.d.ts +11 -0
- package/dist/packages/checkbox/checkbox.stories.js +25 -0
- package/dist/packages/checkbox/index.d.ts +2 -0
- package/dist/packages/checkbox/index.js +2 -0
- package/dist/packages/checkbox/react.d.ts +7 -0
- package/dist/packages/checkbox/react.js +20 -0
- package/dist/packages/checkbox/styles.d.ts +0 -0
- package/dist/packages/checkbox/styles.js +0 -0
- package/dist/packages/combobox/combobox.react.stories.d.ts +28 -0
- package/dist/packages/combobox/combobox.react.stories.js +90 -0
- package/dist/packages/combobox/combobox.stories.d.ts +19 -0
- package/dist/packages/combobox/combobox.stories.js +143 -0
- package/dist/packages/combobox/index.d.ts +91 -0
- package/dist/packages/combobox/index.js +2493 -0
- package/dist/packages/combobox/index.js.map +7 -0
- package/dist/packages/combobox/locales/da/messages.d.mts +1 -0
- package/dist/packages/combobox/locales/da/messages.mjs +1 -0
- package/dist/packages/combobox/locales/en/messages.d.mts +1 -0
- package/dist/packages/combobox/locales/en/messages.mjs +1 -0
- package/dist/packages/combobox/locales/fi/messages.d.mts +1 -0
- package/dist/packages/combobox/locales/fi/messages.mjs +1 -0
- package/dist/packages/combobox/locales/nb/messages.d.mts +1 -0
- package/dist/packages/combobox/locales/nb/messages.mjs +1 -0
- package/dist/packages/combobox/locales/sv/messages.d.mts +1 -0
- package/dist/packages/combobox/locales/sv/messages.mjs +1 -0
- package/dist/packages/combobox/react.d.ts +7 -0
- package/dist/packages/combobox/react.js +17 -0
- package/dist/packages/combobox/styles.d.ts +1 -0
- package/dist/packages/combobox/styles.js +3 -0
- package/dist/packages/deadtoggle/dead-toggle.react.stories.d.ts +15 -0
- package/dist/packages/deadtoggle/dead-toggle.react.stories.js +34 -0
- package/dist/packages/deadtoggle/dead-toggle.stories.d.ts +14 -0
- package/dist/packages/deadtoggle/dead-toggle.stories.js +45 -0
- package/dist/packages/deadtoggle/dead-toggle.test.d.ts +1 -0
- package/dist/packages/deadtoggle/dead-toggle.test.js +9 -0
- package/dist/packages/deadtoggle/index.d.ts +17 -0
- package/dist/packages/deadtoggle/index.js +2547 -0
- package/dist/packages/deadtoggle/index.js.map +7 -0
- package/dist/packages/deadtoggle/react.d.ts +2 -0
- package/dist/packages/deadtoggle/react.js +11 -0
- package/dist/packages/pageindicator/index.d.ts +10 -0
- package/dist/packages/pageindicator/index.js +32 -0
- package/dist/packages/pageindicator/index.js.map +7 -0
- package/dist/packages/pageindicator/pageindicator.react.stories.d.ts +19 -0
- package/dist/packages/pageindicator/pageindicator.react.stories.js +20 -0
- package/dist/packages/pageindicator/pageindicator.stories.d.ts +32 -0
- package/dist/packages/pageindicator/pageindicator.stories.js +71 -0
- package/dist/packages/pageindicator/react.d.ts +2 -0
- package/dist/packages/pageindicator/react.js +11 -0
- package/dist/packages/pageindicator/style.d.ts +1 -0
- package/dist/packages/pageindicator/style.js +26 -0
- package/dist/packages/pagination/index.d.ts +32 -0
- package/dist/packages/pagination/index.js +2500 -0
- package/dist/packages/pagination/index.js.map +7 -0
- package/dist/packages/pagination/locales/da/messages.d.mts +1 -0
- package/dist/packages/pagination/locales/da/messages.mjs +1 -0
- package/dist/packages/pagination/locales/en/messages.d.mts +1 -0
- package/dist/packages/pagination/locales/en/messages.mjs +1 -0
- package/dist/packages/pagination/locales/fi/messages.d.mts +1 -0
- package/dist/packages/pagination/locales/fi/messages.mjs +1 -0
- package/dist/packages/pagination/locales/nb/messages.d.mts +1 -0
- package/dist/packages/pagination/locales/nb/messages.mjs +1 -0
- package/dist/packages/pagination/locales/sv/messages.d.mts +1 -0
- package/dist/packages/pagination/locales/sv/messages.mjs +1 -0
- package/dist/packages/pagination/pagination.react.stories.d.ts +21 -0
- package/dist/packages/pagination/pagination.react.stories.js +45 -0
- package/dist/packages/pagination/pagination.stories.d.ts +14 -0
- package/dist/packages/pagination/pagination.stories.js +56 -0
- package/dist/packages/pagination/pagination.test.d.ts +1 -0
- package/dist/packages/pagination/pagination.test.js +76 -0
- package/dist/packages/pagination/react.d.ts +5 -0
- package/dist/packages/pagination/react.js +15 -0
- package/dist/packages/pagination/styles.d.ts +1 -0
- package/dist/packages/pagination/styles.js +2 -0
- package/dist/packages/radio/base-element.d.ts +46 -0
- package/dist/packages/radio/base-element.js +100 -0
- package/dist/packages/radio/custom-error-validator.d.ts +6 -0
- package/dist/packages/radio/custom-error-validator.js +22 -0
- package/dist/packages/radio/form-associated-element.d.ts +103 -0
- package/dist/packages/radio/form-associated-element.js +282 -0
- package/dist/packages/radio/host-styles.d.ts +1 -0
- package/dist/packages/radio/host-styles.js +12 -0
- package/dist/packages/radio/index.d.ts +2 -0
- package/dist/packages/radio/index.js +2 -0
- package/dist/packages/radio/invalid.d.ts +8 -0
- package/dist/packages/radio/invalid.js +5 -0
- package/dist/packages/radio/math.d.ts +1 -0
- package/dist/packages/radio/math.js +4 -0
- package/dist/packages/radio/radio-group-styles.d.ts +1 -0
- package/dist/packages/radio/radio-group-styles.js +59 -0
- package/dist/packages/radio/radio-group-styles.js.map +7 -0
- package/dist/packages/radio/radio-group.d.ts +72 -0
- package/dist/packages/radio/radio-group.js +2648 -0
- package/dist/packages/radio/radio-group.js.map +7 -0
- package/dist/packages/radio/radio-styles.d.ts +0 -0
- package/dist/packages/radio/radio-styles.js +1 -0
- package/dist/packages/radio/radio-styles.js.map +7 -0
- package/dist/packages/radio/radio.d.ts +38 -0
- package/dist/packages/radio/radio.js +2562 -0
- package/dist/packages/radio/radio.js.map +7 -0
- package/dist/packages/radio/radio.react.stories.d.ts +9 -0
- package/dist/packages/radio/radio.react.stories.js +10 -0
- package/dist/packages/radio/radio.stories.d.ts +15 -0
- package/dist/packages/radio/radio.stories.js +3702 -0
- package/dist/packages/radio/radio.stories.js.map +7 -0
- package/dist/packages/radio/react.d.ts +9 -0
- package/dist/packages/radio/react.js +22 -0
- package/dist/packages/radio/required-validator.d.ts +11 -0
- package/dist/packages/radio/required-validator.js +34 -0
- package/dist/packages/radio/slot.d.ts +20 -0
- package/dist/packages/radio/slot.js +71 -0
- package/dist/packages/radio/watch.d.ts +26 -0
- package/dist/packages/radio/watch.js +39 -0
- package/dist/packages/slider/Slider.d.ts +2 -0
- package/dist/packages/slider/Slider.js +8 -0
- package/dist/packages/slider/SliderThumb.d.ts +2 -0
- package/dist/packages/slider/SliderThumb.js +8 -0
- package/dist/packages/slider/index.d.ts +2 -0
- package/dist/packages/slider/index.js +2 -0
- package/dist/packages/slider/locales/da/messages.d.mts +1 -0
- package/dist/packages/slider/locales/da/messages.mjs +1 -0
- package/dist/packages/slider/locales/en/messages.d.mts +1 -0
- package/dist/packages/slider/locales/en/messages.mjs +1 -0
- package/dist/packages/slider/locales/fi/messages.d.mts +1 -0
- package/dist/packages/slider/locales/fi/messages.mjs +1 -0
- package/dist/packages/slider/locales/nb/messages.d.mts +1 -0
- package/dist/packages/slider/locales/nb/messages.mjs +1 -0
- package/dist/packages/slider/locales/sv/messages.d.mts +1 -0
- package/dist/packages/slider/locales/sv/messages.mjs +1 -0
- package/dist/packages/slider/oddbird-css-anchor-positioning.d.ts +2 -0
- package/dist/packages/slider/oddbird-css-anchor-positioning.js +3 -0
- package/dist/packages/slider/react.d.ts +8 -0
- package/dist/packages/slider/react.js +20 -0
- package/dist/packages/slider/slider-thumb.d.ts +63 -0
- package/dist/packages/slider/slider-thumb.js +2748 -0
- package/dist/packages/slider/slider-thumb.js.map +7 -0
- package/dist/packages/slider/slider.d.ts +55 -0
- package/dist/packages/slider/slider.js +2632 -0
- package/dist/packages/slider/slider.js.map +7 -0
- package/dist/packages/slider/slider.react.stories.d.ts +19 -0
- package/dist/packages/slider/slider.react.stories.js +140 -0
- package/dist/packages/slider/slider.stories.d.ts +21 -0
- package/dist/packages/slider/slider.stories.js +404 -0
- package/dist/packages/slider/slider.test.d.ts +4 -0
- package/dist/packages/slider/slider.test.js +111 -0
- package/dist/packages/slider/styles/w-slider-thumb.styles.d.ts +1 -0
- package/dist/packages/slider/styles/w-slider-thumb.styles.js +175 -0
- package/dist/packages/slider/styles/w-slider.styles.d.ts +1 -0
- package/dist/packages/slider/styles/w-slider.styles.js +148 -0
- package/dist/packages/slider/styles.d.ts +1 -0
- package/dist/packages/slider/styles.js +2 -0
- package/dist/packages/stepindicator/index.d.ts +37 -0
- package/dist/packages/stepindicator/index.js +2465 -0
- package/dist/packages/stepindicator/index.js.map +7 -0
- package/dist/packages/stepindicator/locales/da/messages.d.mts +1 -0
- package/dist/packages/stepindicator/locales/da/messages.mjs +1 -0
- package/dist/packages/stepindicator/locales/en/messages.d.mts +1 -0
- package/dist/packages/stepindicator/locales/en/messages.mjs +1 -0
- package/dist/packages/stepindicator/locales/fi/messages.d.mts +1 -0
- package/dist/packages/stepindicator/locales/fi/messages.mjs +1 -0
- package/dist/packages/stepindicator/locales/nb/messages.d.mts +1 -0
- package/dist/packages/stepindicator/locales/nb/messages.mjs +1 -0
- package/dist/packages/stepindicator/locales/sv/messages.d.mts +1 -0
- package/dist/packages/stepindicator/locales/sv/messages.mjs +1 -0
- package/dist/packages/stepindicator/react.d.ts +3 -0
- package/dist/packages/stepindicator/react.js +16 -0
- package/dist/packages/stepindicator/stepindicator.react.stories.d.ts +15 -0
- package/dist/packages/stepindicator/stepindicator.react.stories.js +112 -0
- package/dist/packages/stepindicator/stepindicator.stories.d.ts +12 -0
- package/dist/packages/stepindicator/stepindicator.stories.js +172 -0
- package/dist/packages/stepindicator/styles.d.ts +1 -0
- package/dist/packages/stepindicator/styles.js +2 -0
- package/dist/packages/switch/index.d.ts +23 -0
- package/dist/packages/switch/index.js +2456 -0
- package/dist/packages/switch/index.js.map +7 -0
- package/dist/packages/switch/react.d.ts +5 -0
- package/dist/packages/switch/react.js +15 -0
- package/dist/packages/switch/styles.d.ts +1 -0
- package/dist/packages/switch/styles.js +2 -0
- package/dist/packages/switch/switch.react.stories.d.ts +15 -0
- package/dist/packages/switch/switch.react.stories.js +29 -0
- package/dist/packages/switch/switch.stories.d.ts +9 -0
- package/dist/packages/switch/switch.stories.js +35 -0
- package/dist/packages/switch/switch.test.d.ts +1 -0
- package/dist/packages/switch/switch.test.js +40 -0
- package/dist/packages/tabs/index.d.ts +4 -0
- package/dist/packages/tabs/index.js +3 -0
- package/dist/packages/tabs/react.d.ts +12 -0
- package/dist/packages/tabs/react.js +31 -0
- package/dist/packages/tabs/styles.d.ts +1 -0
- package/dist/packages/tabs/styles.js +2 -0
- package/dist/packages/tabs/tab-panel.d.ts +20 -0
- package/dist/packages/tabs/tab-panel.js +51 -0
- package/dist/packages/tabs/tab.d.ts +18 -0
- package/dist/packages/tabs/tab.js +2464 -0
- package/dist/packages/tabs/tab.js.map +7 -0
- package/dist/packages/tabs/tabs.d.ts +40 -0
- package/dist/packages/tabs/tabs.js +2448 -0
- package/dist/packages/tabs/tabs.js.map +7 -0
- package/dist/packages/tabs/tabs.react.stories.d.ts +15 -0
- package/dist/packages/tabs/tabs.react.stories.js +51 -0
- package/dist/packages/tabs/tabs.stories.d.ts +11 -0
- package/dist/packages/tabs/tabs.stories.js +93 -0
- package/dist/packages/textarea/index.d.ts +1 -0
- package/dist/packages/textarea/index.js +1 -0
- package/dist/packages/textarea/locales/da/messages.d.mts +1 -0
- package/dist/packages/textarea/locales/da/messages.mjs +1 -0
- package/dist/packages/textarea/locales/en/messages.d.mts +1 -0
- package/dist/packages/textarea/locales/en/messages.mjs +1 -0
- package/dist/packages/textarea/locales/fi/messages.d.mts +1 -0
- package/dist/packages/textarea/locales/fi/messages.mjs +1 -0
- package/dist/packages/textarea/locales/nb/messages.d.mts +1 -0
- package/dist/packages/textarea/locales/nb/messages.mjs +1 -0
- package/dist/packages/textarea/locales/sv/messages.d.mts +1 -0
- package/dist/packages/textarea/locales/sv/messages.mjs +1 -0
- package/dist/packages/textarea/react.d.ts +11 -0
- package/dist/packages/textarea/react.js +21 -0
- package/dist/packages/textarea/styles.d.ts +1 -0
- package/dist/packages/textarea/styles.js +2 -0
- package/dist/packages/textarea/textarea.d.ts +49 -0
- package/dist/packages/textarea/textarea.js +2475 -0
- package/dist/packages/textarea/textarea.js.map +7 -0
- package/dist/packages/textarea/textarea.react.stories.d.ts +33 -0
- package/dist/packages/textarea/textarea.react.stories.js +41 -0
- package/dist/packages/textarea/textarea.stories.d.ts +19 -0
- package/dist/packages/textarea/textarea.stories.js +85 -0
- package/dist/packages/textarea/textarea.test.d.ts +1 -0
- package/dist/packages/textarea/textarea.test.js +68 -0
- package/dist/packages/toggle-styles.d.ts +1 -0
- package/dist/packages/toggle-styles.js +108 -0
- package/dist/setup-tests.d.ts +1 -0
- package/dist/setup-tests.js +1 -0
- package/dist/web-types.json +984 -1
- package/package.json +78 -1
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { userEvent } from '@vitest/browser/context';
|
|
2
|
+
import { html } from 'lit';
|
|
3
|
+
import { expect, test, vi } from 'vitest';
|
|
4
|
+
import { render } from 'vitest-browser-lit';
|
|
5
|
+
import './index.js';
|
|
6
|
+
test('renders the textarea', async () => {
|
|
7
|
+
const component = html `<w-textarea label="Test label"></w-textarea>`;
|
|
8
|
+
const page = render(component);
|
|
9
|
+
await expect.element(page.getByText('Test label')).toBeVisible();
|
|
10
|
+
});
|
|
11
|
+
test('works as expected in forms', async () => {
|
|
12
|
+
const label = 'Test label';
|
|
13
|
+
const component = html `
|
|
14
|
+
<form data-testid="form">
|
|
15
|
+
<w-textarea label="${label}" name="message" value="Hola el Mundo"></w-textarea>
|
|
16
|
+
</form>
|
|
17
|
+
`;
|
|
18
|
+
const page = render(component);
|
|
19
|
+
await expect.element(page.getByLabelText(label)).toHaveValue('Hola el Mundo');
|
|
20
|
+
let formData = new FormData(page.getByTestId('form').element());
|
|
21
|
+
expect(formData.get('message')).toBe('Hola el Mundo');
|
|
22
|
+
const inputHandler = vi.fn();
|
|
23
|
+
const changeHandler = vi.fn();
|
|
24
|
+
page.getByLabelText(label).element().addEventListener('input', inputHandler);
|
|
25
|
+
page.getByLabelText(label).element().addEventListener('change', changeHandler);
|
|
26
|
+
await page.getByLabelText(label).fill('Hello, World');
|
|
27
|
+
expect(inputHandler).toHaveBeenCalled();
|
|
28
|
+
expect(changeHandler).not.toHaveBeenCalled();
|
|
29
|
+
await userEvent.tab(); // trigger a blur to fire the change event
|
|
30
|
+
expect(changeHandler).toHaveBeenCalled();
|
|
31
|
+
await expect.element(page.getByLabelText(label)).toHaveValue('Hello, World');
|
|
32
|
+
formData = new FormData(page.getByTestId('form').element());
|
|
33
|
+
expect(formData.get('message')).toBe('Hello, World');
|
|
34
|
+
});
|
|
35
|
+
test('renders help text if provided', async () => {
|
|
36
|
+
const component = html `<w-textarea label="Test label" help-text="Helpful help text"></w-textarea>`;
|
|
37
|
+
const page = render(component);
|
|
38
|
+
await expect.element(page.getByText('Helpful help text')).toBeVisible();
|
|
39
|
+
});
|
|
40
|
+
test('marks input field as aria-invalid if the invalid prop is true', async () => {
|
|
41
|
+
const component = html `<w-textarea label="Test label" invalid help-text="No, bad input!"></w-textarea>`;
|
|
42
|
+
const page = render(component);
|
|
43
|
+
await expect.element(page.getByLabelText('Test label')).toHaveAccessibleErrorMessage('No, bad input!');
|
|
44
|
+
});
|
|
45
|
+
test('marks input field as readonly if the readonly prop is true', async () => {
|
|
46
|
+
const component = html `<w-textarea label="Test label" readonly></w-textarea>`;
|
|
47
|
+
const page = render(component);
|
|
48
|
+
await expect.element(page.getByLabelText('Test label')).toHaveAttribute('readonly', '');
|
|
49
|
+
});
|
|
50
|
+
test('can reset textarea by resetting surrounding form', async () => {
|
|
51
|
+
render(html `
|
|
52
|
+
<form>
|
|
53
|
+
<w-textarea name="message" value="Hola el Mundo"></w-textarea>
|
|
54
|
+
</form>
|
|
55
|
+
`);
|
|
56
|
+
const form = document.querySelector('form');
|
|
57
|
+
const wTextArea = document.querySelector('w-textarea');
|
|
58
|
+
// sanity
|
|
59
|
+
expect(form).not.toBeNull();
|
|
60
|
+
expect(wTextArea).not.toBeNull();
|
|
61
|
+
expect(wTextArea.value).toBe('Hola el Mundo');
|
|
62
|
+
wTextArea.value = 'Definitely not Hola el Mundo';
|
|
63
|
+
await wTextArea.updateComplete;
|
|
64
|
+
// Reset the form
|
|
65
|
+
form.reset();
|
|
66
|
+
await wTextArea.updateComplete;
|
|
67
|
+
expect(wTextArea.value).toBe('Hola el Mundo');
|
|
68
|
+
});
|
|
@@ -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
|
+
`;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import 'vitest-browser-lit';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import 'vitest-browser-lit';
|