@ibis-design/svelte 0.5.0 → 0.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 (86) hide show
  1. package/README.md +12 -2
  2. package/dist/components/buttons/Button.svelte +106 -0
  3. package/dist/components/buttons/Button.svelte.d.ts +69 -0
  4. package/dist/components/buttons/DropdownButton.svelte +91 -0
  5. package/dist/components/buttons/DropdownButton.svelte.d.ts +33 -0
  6. package/dist/components/buttons/PillTab.svelte +84 -0
  7. package/dist/components/buttons/PillTab.svelte.d.ts +55 -0
  8. package/dist/components/buttons/button.css +193 -0
  9. package/dist/components/buttons/dropdownButton.css +82 -0
  10. package/dist/components/buttons/pillTab.css +59 -0
  11. package/dist/components/containers/Banner.svelte +73 -0
  12. package/dist/components/containers/Banner.svelte.d.ts +16 -0
  13. package/dist/components/containers/Card.svelte +34 -0
  14. package/dist/components/containers/Card.svelte.d.ts +14 -0
  15. package/dist/components/containers/PillTabs.svelte +22 -0
  16. package/dist/components/containers/PillTabs.svelte.d.ts +6 -0
  17. package/dist/components/containers/TipIndicator.svelte +78 -0
  18. package/dist/components/containers/TipIndicator.svelte.d.ts +28 -0
  19. package/dist/components/containers/Toaster.svelte +75 -0
  20. package/dist/components/containers/Toaster.svelte.d.ts +16 -0
  21. package/dist/components/containers/Tooltip.svelte.d.ts +26 -0
  22. package/dist/components/containers/banner.css +155 -0
  23. package/dist/components/containers/tipIndicator.css +79 -0
  24. package/dist/components/containers/toaster.css +137 -0
  25. package/dist/components/containers/tooltip.css +0 -0
  26. package/dist/components/inputs/.gitkeep +0 -0
  27. package/dist/components/inputs/Checkbox.svelte +95 -0
  28. package/dist/components/inputs/Checkbox.svelte.d.ts +33 -0
  29. package/dist/components/inputs/Chips.svelte +104 -0
  30. package/dist/components/inputs/Chips.svelte.d.ts +48 -0
  31. package/dist/components/inputs/Dropdown.svelte +83 -0
  32. package/dist/components/inputs/Dropdown.svelte.d.ts +15 -0
  33. package/dist/components/inputs/Radio.svelte +109 -0
  34. package/dist/components/inputs/Radio.svelte.d.ts +49 -0
  35. package/dist/components/inputs/Switch.svelte +45 -0
  36. package/dist/components/inputs/Switch.svelte.d.ts +21 -0
  37. package/dist/components/inputs/TextArea.svelte +65 -0
  38. package/dist/components/inputs/TextArea.svelte.d.ts +14 -0
  39. package/dist/components/inputs/TextInput.svelte +273 -0
  40. package/dist/components/inputs/TextInput.svelte.d.ts +140 -0
  41. package/dist/components/inputs/TextLink.svelte +102 -0
  42. package/dist/components/inputs/TextLink.svelte.d.ts +21 -0
  43. package/dist/components/inputs/checkbox.css +103 -0
  44. package/dist/components/inputs/chips.css +76 -0
  45. package/dist/components/inputs/dropdown.css +106 -0
  46. package/dist/components/inputs/radio.css +108 -0
  47. package/dist/components/inputs/switch.css +68 -0
  48. package/dist/components/inputs/textInput.css +152 -0
  49. package/dist/components/inputs/textarea.css +91 -0
  50. package/dist/components/inputs/textlink.css +163 -0
  51. package/dist/index.d.ts +21 -20
  52. package/dist/index.js +36 -3187
  53. package/dist/layouts/AppLayout.svelte +83 -0
  54. package/dist/layouts/AppLayout.svelte.d.ts +20 -0
  55. package/dist/layouts/AuthLayout.svelte +63 -0
  56. package/dist/layouts/AuthLayout.svelte.d.ts +18 -0
  57. package/dist/layouts/DashboardLayout.svelte +88 -0
  58. package/dist/layouts/DashboardLayout.svelte.d.ts +20 -0
  59. package/dist/types/button.js +5 -0
  60. package/dist/types/index.d.ts +2 -2
  61. package/dist/types/index.js +5 -0
  62. package/dist/types/layout.d.ts +1 -1
  63. package/dist/types/layout.js +1 -0
  64. package/package.json +14 -9
  65. package/dist/index.css +0 -1
  66. package/dist/index.js.map +0 -1
  67. package/dist/lib/components/buttons/Button.svelte.d.ts +0 -1
  68. package/dist/lib/components/buttons/DropdownButton.svelte.d.ts +0 -1
  69. package/dist/lib/components/buttons/PillTab.svelte.d.ts +0 -1
  70. package/dist/lib/components/containers/Banner.svelte.d.ts +0 -1
  71. package/dist/lib/components/containers/Card.svelte.d.ts +0 -1
  72. package/dist/lib/components/containers/Toaster.svelte.d.ts +0 -1
  73. package/dist/lib/components/inputs/Checkbox.svelte.d.ts +0 -1
  74. package/dist/lib/components/inputs/Chips.svelte.d.ts +0 -1
  75. package/dist/lib/components/inputs/DateInput.svelte.d.ts +0 -1
  76. package/dist/lib/components/inputs/DateInput2.svelte.d.ts +0 -1
  77. package/dist/lib/components/inputs/Dropdown.svelte.d.ts +0 -1
  78. package/dist/lib/components/inputs/Password.svelte.d.ts +0 -1
  79. package/dist/lib/components/inputs/Radio.svelte.d.ts +0 -1
  80. package/dist/lib/components/inputs/TextArea.svelte.d.ts +0 -1
  81. package/dist/lib/components/inputs/TextInput.svelte.d.ts +0 -1
  82. package/dist/lib/components/inputs/TextLink.svelte.d.ts +0 -1
  83. package/dist/lib/layouts/AppLayout.svelte.d.ts +0 -1
  84. package/dist/lib/layouts/AuthLayout.svelte.d.ts +0 -1
  85. package/dist/lib/layouts/DashboardLayout.svelte.d.ts +0 -1
  86. /package/dist/{types/input.d.ts → components/containers/Tooltip.svelte} +0 -0
@@ -0,0 +1,102 @@
1
+ <script lang="ts">
2
+ import "./textlink.css";
3
+ import type { HTMLAnchorAttributes } from "svelte/elements";
4
+ import type { Snippet } from "svelte";
5
+
6
+ interface Props extends HTMLAnchorAttributes {
7
+ href?: string;
8
+ target?: "_self" | "_blank" | "_parent" | "_top";
9
+ underline?: "always" | "hover" | "none";
10
+ linkSize?: "sm" | "md" | "lg";
11
+ disabled?: boolean;
12
+ loading?: boolean;
13
+ skeleton?: boolean;
14
+ label?: string;
15
+ children?: Snippet;
16
+ iconPrefix?: Snippet;
17
+ iconSuffix?: Snippet;
18
+ iconPrefixText?: string;
19
+ iconSuffixText?: string;
20
+ }
21
+
22
+ let {
23
+ href,
24
+ target,
25
+ underline = "hover",
26
+ linkSize = "md",
27
+ disabled = false,
28
+ loading = false,
29
+ skeleton = false,
30
+ rel,
31
+ label,
32
+ children,
33
+ iconPrefix,
34
+ iconSuffix,
35
+ iconPrefixText,
36
+ iconSuffixText,
37
+ ...rest
38
+ }: Props = $props();
39
+
40
+ const computedRel = $derived(target === "_blank" ? (rel ?? "noopener noreferrer") : rel);
41
+
42
+ $effect(() => {
43
+ if (disabled && href) {
44
+ console.warn("Disabled links should not have an href");
45
+ }
46
+ if (iconPrefix && iconPrefixText) {
47
+ console.warn("iconPrefix snippet takes priority over iconPrefixText when both are provided.");
48
+ }
49
+ if (iconSuffix && iconSuffixText) {
50
+ console.warn("iconSuffix snippet takes priority over iconSuffixText when both are provided.");
51
+ }
52
+ });
53
+ </script>
54
+
55
+ <a
56
+ {...rest}
57
+ // href={disabled || skeleton ? undefined : href}
58
+ {target}
59
+ rel={computedRel}
60
+ aria-disabled={disabled || skeleton}
61
+ aria-busy={loading}
62
+ class=" ibis-link
63
+ ibis-link--{linkSize}
64
+ ibis-link--underline-{underline}
65
+ {disabled ? 'ibis-link--disabled' : ''}
66
+ {loading ? 'ibis-link--loading' : ''}
67
+ {skeleton ? 'ibis-link--skeleton' : ''}">
68
+ {#if iconPrefix || iconPrefixText}
69
+ <span class="ibis-link__icon ibis-link--prefix">
70
+ {#if iconPrefix}
71
+ {@render iconPrefix()}
72
+ {:else}
73
+ {iconPrefixText}
74
+ {/if}
75
+ </span>
76
+ {/if}
77
+
78
+ <span
79
+ class="ibis-link__content
80
+ {loading ? 'ibis-link__content--hidden' : ''}
81
+ {skeleton ? 'ibis-link__content--skeleton' : ''}">
82
+ {#if children}
83
+ {@render children?.()}
84
+ {:else if label}
85
+ {label}
86
+ {/if}
87
+ </span>
88
+
89
+ {#if iconSuffix || iconSuffixText}
90
+ <span class="ibis-link__icon ibis-link--suffix">
91
+ {#if iconSuffix}
92
+ {@render iconSuffix()}
93
+ {:else}
94
+ {iconSuffixText}
95
+ {/if}
96
+ </span>
97
+ {/if}
98
+
99
+ {#if loading}
100
+ <span class="ibis-link__loader" aria-hidden="true"></span>
101
+ {/if}
102
+ </a>
@@ -0,0 +1,21 @@
1
+ import "./textlink.css";
2
+ import type { HTMLAnchorAttributes } from "svelte/elements";
3
+ import type { Snippet } from "svelte";
4
+ interface Props extends HTMLAnchorAttributes {
5
+ href?: string;
6
+ target?: "_self" | "_blank" | "_parent" | "_top";
7
+ underline?: "always" | "hover" | "none";
8
+ linkSize?: "sm" | "md" | "lg";
9
+ disabled?: boolean;
10
+ loading?: boolean;
11
+ skeleton?: boolean;
12
+ label?: string;
13
+ children?: Snippet;
14
+ iconPrefix?: Snippet;
15
+ iconSuffix?: Snippet;
16
+ iconPrefixText?: string;
17
+ iconSuffixText?: string;
18
+ }
19
+ declare const TextLink: import("svelte").Component<Props, {}, "">;
20
+ type TextLink = ReturnType<typeof TextLink>;
21
+ export default TextLink;
@@ -0,0 +1,103 @@
1
+ .ibis-checkbox {
2
+ display: flex;
3
+ flex-direction: column;
4
+ gap: var(--spacing-1);
5
+ }
6
+
7
+ .ibis-checkbox__label-wrapper {
8
+ display: flex;
9
+ flex-direction: column;
10
+ gap: 2px;
11
+ }
12
+
13
+ .ibis-checkbox__label {
14
+ font-size: var(--font-size-normal-text-default);
15
+ color: var(--color-neutral-700);
16
+ }
17
+
18
+ .ibis-checkbox__description {
19
+ font-size: var(--font-size-normal-text-sm);
20
+ color: var(--color-neutral-500);
21
+ }
22
+
23
+ .ibis-checkbox__wrapper {
24
+ display: flex;
25
+ }
26
+
27
+ .ibis-checkbox__control {
28
+ display: inline-flex;
29
+ align-items: center;
30
+ gap: var(--spacing-2);
31
+ cursor: pointer;
32
+ user-select: none;
33
+ }
34
+
35
+ .ibis-checkbox__input {
36
+ display: none;
37
+ }
38
+
39
+ .ibis-checkbox__box {
40
+ width: 18px;
41
+ height: 18px;
42
+ border: var(--border-width-default) solid var(--color-neutral-300);
43
+ border-radius: var(--border-radius-sm);
44
+ display: flex;
45
+ align-items: center;
46
+ justify-content: center;
47
+ background: var(--color-neutral-100);
48
+ transition:
49
+ box-shadow var(--transition-duration-normal) var(--transition-timing-default),
50
+ border-color var(--transition-duration-normal) var(--transition-timing-default),
51
+ background var(--transition-duration-normal) var(--transition-timing-default);
52
+ }
53
+
54
+ .ibis-checkbox__control:hover .ibis-checkbox__input:not(:checked) + .ibis-checkbox__box {
55
+ border-color: var(--color-neutral-700);
56
+ box-shadow: 0 0 0 4px var(--color-neutral-200);
57
+ }
58
+
59
+ .ibis-checkbox__input:checked + .ibis-checkbox__box {
60
+ background: var(--color-primary-200);
61
+ border-color: var(--color-primary-800);
62
+ }
63
+
64
+ .ibis-checkbox__control:hover .ibis-checkbox__input:checked + .ibis-checkbox__box {
65
+ box-shadow: 0 0 0 4px var(--color-primary-200);
66
+ }
67
+
68
+ .ibis-checkbox__text {
69
+ font-size: var(--font-size-normal-text-default);
70
+ color: var(--color-text-default);
71
+ }
72
+
73
+ .ibis-checkbox__help {
74
+ font-size: var(--font-size-normal-text-sm);
75
+ color: var(--color-neutral-500);
76
+ }
77
+
78
+ .ibis-checkbox__error {
79
+ font-size: var(--font-size-normal-text-sm);
80
+ color: var(--color-status-error);
81
+ }
82
+
83
+ .ibis-checkbox--disabled {
84
+ opacity: 0.5;
85
+ cursor: not-allowed;
86
+ }
87
+
88
+ .ibis-checkbox--invalid .ibis-checkbox__box {
89
+ border-color: var(--color-status-error);
90
+ }
91
+
92
+ .ibis-checkbox--invalid .ibis-checkbox__text {
93
+ font-size: var(--font-size-normal-text-default);
94
+ color: var(--color-status-error);
95
+ }
96
+
97
+ .ibis-checkbox--invalid
98
+ .ibis-checkbox__control:hover
99
+ .ibis-checkbox__input:not(:checked)
100
+ + .ibis-checkbox__box {
101
+ box-shadow: 0 0 0 4px #ffb3ad;
102
+ border-color: var(--color-status-error);
103
+ }
@@ -0,0 +1,76 @@
1
+ .ibis-chips {
2
+ font-family: var(--font-family-sans);
3
+ font-weight: var(--font-weight-normal);
4
+ border-radius: var(--component-button-size-sm-border-radius);
5
+ padding: var(--spacing-1) var(--spacing-3);
6
+ background-color: var(--color-white);
7
+ color: var(--color-text-primary);
8
+ border: var(--border-width-thin) solid var(--color-neutral-200);
9
+ cursor: pointer;
10
+ }
11
+
12
+ .ibis-chips__content {
13
+ display: inline-flex;
14
+ align-items: center;
15
+ justify-content: center;
16
+ gap: var(--spacing-2);
17
+ }
18
+
19
+ .ibis-chips__icon {
20
+ display: inline-flex;
21
+ align-items: center;
22
+ justify-content: center;
23
+ }
24
+
25
+ .ibis-chips__label {
26
+ display: inline-flex;
27
+ }
28
+
29
+ .ibis-chips :global(svg) {
30
+ width: 1rem;
31
+ height: 1rem;
32
+ display: inline-block;
33
+ vertical-align: middle;
34
+ gap: var(--spacing-2);
35
+ }
36
+
37
+ .ibis-chips--sm {
38
+ font-size: var(--font-size-body-sm);
39
+ }
40
+
41
+ .ibis-chips--md {
42
+ font-size: var(--font-size-body-md);
43
+ }
44
+
45
+ .ibis-chips--lg {
46
+ font-size: var(--font-size-body-lg);
47
+ }
48
+
49
+ .ibis-chips--skeleton {
50
+ background-color: var(--color-neutral-200);
51
+ color: transparent;
52
+ pointer-events: none;
53
+ }
54
+
55
+ .ibis-chips__content--hidden {
56
+ visibility: hidden;
57
+ }
58
+
59
+ .ibis-chips:disabled {
60
+ opacity: var(--opacity-disabled);
61
+ cursor: not-allowed;
62
+ }
63
+
64
+ .ibis-chips:not(:disabled):hover {
65
+ background-color: var(--color-neutral-200);
66
+ }
67
+
68
+ .ibis-chips--selected {
69
+ background-color: var(--color-primary-100);
70
+ color: var(--color-primary-800);
71
+ border-color: var(--color-primary-800);
72
+ }
73
+
74
+ .ibis-chips--selected:not(:disabled):hover {
75
+ background-color: var(--color-primary-200);
76
+ }
@@ -0,0 +1,106 @@
1
+ .ibis-dropdown {
2
+ position: relative;
3
+ display: inline-block;
4
+ width: fit-content;
5
+ }
6
+
7
+ .ibis-dropdown__trigger {
8
+ all: unset;
9
+ display: block;
10
+ width: 100%;
11
+ cursor: pointer;
12
+ }
13
+
14
+ /* Override TextInput styles inside trigger */
15
+ .ibis-dropdown__trigger .ibis-input {
16
+ gap: 0;
17
+ }
18
+
19
+ .ibis-dropdown__trigger .ibis-input__label-wrapper {
20
+ display: none;
21
+ }
22
+
23
+ .ibis-dropdown__trigger .ibis-input__help,
24
+ .ibis-dropdown__trigger .ibis-input__error {
25
+ display: none;
26
+ }
27
+
28
+ /* Default field wrapper radius */
29
+ .ibis-dropdown__trigger .ibis-input__field-wrapper {
30
+ border-radius: var(--border-radius-lg);
31
+ transition: border-radius var(--transition-duration-fast) var(--transition-timing-default);
32
+ }
33
+
34
+ /* ↓ ADDED — remove bottom radius on input when open so it connects to menu */
35
+ .ibis-dropdown--open .ibis-dropdown__trigger .ibis-input__field-wrapper {
36
+ border-bottom-left-radius: 0;
37
+ border-bottom-right-radius: 0;
38
+ border-bottom-color: transparent;
39
+ }
40
+
41
+ /* Menu */
42
+ .ibis-dropdown__menu {
43
+ position: absolute;
44
+ width: 100%;
45
+ background-color: var(--color-white);
46
+ border: 2px solid var(--color-primary-950);
47
+ /* ↓ CHANGED — removed top-left and top-right radius to connect with input */
48
+ border-radius: 0 0 var(--border-radius-lg) var(--border-radius-lg);
49
+ border-top: none; /* ↓ ADDED — removes double border between input and menu */
50
+ margin-top: 0; /* ↓ CHANGED — removed gap so menu connects to input */
51
+ z-index: 10;
52
+ list-style: none;
53
+ padding: 0;
54
+ overflow: hidden;
55
+ }
56
+
57
+ /* Dividers between items */
58
+ .ibis-dropdown__menu li + li {
59
+ border-top: 1px solid var(--color-neutral-200);
60
+ }
61
+
62
+ /* Menu items */
63
+ .ibis-dropdown__item {
64
+ all: unset;
65
+ display: flex;
66
+ align-items: center;
67
+ justify-content: center;
68
+ width: 100%;
69
+ box-sizing: border-box;
70
+ padding: var(--spacing-3) var(--spacing-4);
71
+ cursor: pointer;
72
+ font-family: var(--font-family-sans);
73
+ font-size: var(--font-size-normal-text-default);
74
+ font-weight: var(--font-weight-medium);
75
+ color: var(--color-neutral-900);
76
+ text-align: center;
77
+ transition: background-color var(--transition-duration-fast) var(--transition-timing-default);
78
+ }
79
+
80
+ .ibis-dropdown__item:hover {
81
+ background-color: var(--color-primary-400);
82
+ color: var(--color-white);
83
+ }
84
+
85
+ /* ↓ CHANGED — scoped to li aria-selected for correct specificity */
86
+ li[aria-selected='true'] .ibis-dropdown__item {
87
+ background-color: var(--color-primary-500);
88
+ color: var(--color-white);
89
+ font-weight: var(--font-weight-bold);
90
+ }
91
+
92
+ li[aria-selected='true'] .ibis-dropdown__item:hover {
93
+ background-color: var(--color-primary-700);
94
+ color: var(--color-white);
95
+ }
96
+
97
+ .ibis-dropdown__item:focus {
98
+ outline: none;
99
+ background-color: var(--color-neutral-200);
100
+ }
101
+
102
+ /* Disabled */
103
+ .ibis-dropdown__trigger:disabled {
104
+ cursor: not-allowed;
105
+ opacity: 0.5;
106
+ }
@@ -0,0 +1,108 @@
1
+ .ibis-radio {
2
+ display: flex;
3
+ flex-direction: column;
4
+ gap: var(--spacing-1);
5
+ }
6
+
7
+ .ibis-radio__label-wrapper {
8
+ display: flex;
9
+ flex-direction: column;
10
+ gap: 2px;
11
+ }
12
+
13
+ .ibis-radio__label {
14
+ font-size: var(--font-size-normal-text-default);
15
+ color: var(--color-neutral-700);
16
+ }
17
+
18
+ .ibis-radio__description {
19
+ font-size: var(--font-size-normal-text-sm);
20
+ color: var(--color-neutral-500);
21
+ }
22
+
23
+ .ibis-radio__control {
24
+ display: inline-flex;
25
+ align-items: center;
26
+ gap: var(--spacing-2);
27
+ cursor: pointer;
28
+ }
29
+
30
+ .ibis-radio__input {
31
+ display: none;
32
+ }
33
+
34
+ .ibis-radio__circle {
35
+ width: 20px;
36
+ height: 20px;
37
+ border-radius: 999px;
38
+ border: var(--border-width-default) solid var(--color-neutral-300);
39
+ display: flex;
40
+ align-items: center;
41
+ justify-content: center;
42
+ transition:
43
+ box-shadow var(--transition-duration-normal) var(--transition-timing-default),
44
+ border-color var(--transition-duration-normal) var(--transition-timing-default),
45
+ background var(--transition-duration-normal) var(--transition-timing-default);
46
+ }
47
+
48
+ .ibis-radio__dot {
49
+ width: 8px;
50
+ height: 8px;
51
+ border-radius: 999px;
52
+ background: transparent;
53
+ }
54
+
55
+ .ibis-radio__dot--active {
56
+ background: var(--color-primary-900);
57
+ }
58
+
59
+ .ibis-radio__text {
60
+ font-size: var(--font-size-normal-text-default);
61
+ color: var(--color-text-default);
62
+ }
63
+
64
+ .ibis-radio__help {
65
+ font-size: var(--font-size-normal-text-sm);
66
+ color: var(--color-neutral-500);
67
+ }
68
+
69
+ .ibis-radio__error {
70
+ font-size: var(--font-size-normal-text-sm);
71
+ color: var(--color-status-error);
72
+ }
73
+
74
+ .ibis-radio--disabled {
75
+ opacity: var(--opacity-9);
76
+ cursor: not-allowed;
77
+ }
78
+ .ibis-radio--disabled .ibis-radio__circle {
79
+ border-color: var(--color-neutral-200);
80
+ background-color: var(--color-neutral-160);
81
+ }
82
+
83
+ .ibis-radio__input:checked + .ibis-radio__circle {
84
+ border-color: var(--color-primary-900);
85
+ }
86
+
87
+ .ibis-radio:not(.ibis-radio--disabled) .ibis-radio__control:hover .ibis-radio__circle {
88
+ box-shadow: 0 0 0 4px var(--color-neutral-200);
89
+ border-color: var(--color-neutral-700);
90
+ transform: scale(1.05);
91
+ }
92
+
93
+ .ibis-radio:not(.ibis-radio--disabled)
94
+ .ibis-radio__control:hover
95
+ .ibis-radio__input:checked
96
+ + .ibis-radio__circle {
97
+ box-shadow: 0 0 0 4px var(--color-primary-200);
98
+ border-color: var(--color-primary-900);
99
+ }
100
+
101
+ .ibis-radio--invalid .ibis-radio__circle {
102
+ border-color: var(--color-status-error);
103
+ }
104
+
105
+ .ibis-radio--invalid .ibis-radio__control:hover .ibis-radio__circle {
106
+ box-shadow: 0 0 0 4px #ffb3ad;
107
+ border-color: var(--color-status-error);
108
+ }
@@ -0,0 +1,68 @@
1
+ .ibis-switch {
2
+ display: inline-flex;
3
+ align-items: center;
4
+ }
5
+
6
+ .ibis-switch__control {
7
+ display: inline-flex;
8
+ align-items: center;
9
+ cursor: pointer;
10
+ gap: var(--spacing-1);
11
+ user-select: none;
12
+ }
13
+
14
+ .ibis-switch__input {
15
+ display: none;
16
+ }
17
+
18
+ /* Track */
19
+ .ibis-switch__track {
20
+ width: 32px;
21
+ height: 20px;
22
+ background: var(--color-neutral-200);
23
+ border-radius: 999px;
24
+ position: relative;
25
+ transition:
26
+ background var(--transition-duration-normal) var(--transition-timing-default),
27
+ box-shadow var(--transition-duration-normal) var(--transition-timing-default);
28
+ }
29
+
30
+ /* Thumb */
31
+ .ibis-switch__thumb {
32
+ width: 16px;
33
+ height: 16px;
34
+ background: var(--color-white);
35
+ border-radius: 999px;
36
+ position: absolute;
37
+ top: 2px;
38
+ left: 2px;
39
+ transition:
40
+ transform var(--transition-duration-normal) var(--transition-timing-default),
41
+ background var(--transition-duration-normal) var(--transition-timing-default);
42
+ }
43
+
44
+ .ibis-switch__input:checked + .ibis-switch__track {
45
+ background: var(--color-primary-700);
46
+ }
47
+
48
+ .ibis-switch__input:checked + .ibis-switch__track .ibis-switch__thumb {
49
+ transform: translateX(12px);
50
+ }
51
+
52
+ /* Disabled state */
53
+ .ibis-switch--disabled {
54
+ opacity: var(--opacity-7);
55
+ cursor: not-allowed;
56
+ }
57
+
58
+ .ibis-switch--disabled .ibis-switch__track {
59
+ background: var(--color-neutral-200);
60
+ }
61
+
62
+ .ibis-switch--disabled .ibis-switch__thumb {
63
+ background: var(--color-neutral-100);
64
+ }
65
+
66
+ .ibis-switch--disabled .ibis-switch__control {
67
+ cursor: not-allowed;
68
+ }