@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.
- package/README.md +12 -2
- package/dist/components/buttons/Button.svelte +106 -0
- package/dist/components/buttons/Button.svelte.d.ts +69 -0
- package/dist/components/buttons/DropdownButton.svelte +91 -0
- package/dist/components/buttons/DropdownButton.svelte.d.ts +33 -0
- package/dist/components/buttons/PillTab.svelte +84 -0
- package/dist/components/buttons/PillTab.svelte.d.ts +55 -0
- package/dist/components/buttons/button.css +193 -0
- package/dist/components/buttons/dropdownButton.css +82 -0
- package/dist/components/buttons/pillTab.css +59 -0
- package/dist/components/containers/Banner.svelte +73 -0
- package/dist/components/containers/Banner.svelte.d.ts +16 -0
- package/dist/components/containers/Card.svelte +34 -0
- package/dist/components/containers/Card.svelte.d.ts +14 -0
- package/dist/components/containers/PillTabs.svelte +22 -0
- package/dist/components/containers/PillTabs.svelte.d.ts +6 -0
- package/dist/components/containers/TipIndicator.svelte +78 -0
- package/dist/components/containers/TipIndicator.svelte.d.ts +28 -0
- package/dist/components/containers/Toaster.svelte +75 -0
- package/dist/components/containers/Toaster.svelte.d.ts +16 -0
- package/dist/components/containers/Tooltip.svelte.d.ts +26 -0
- package/dist/components/containers/banner.css +155 -0
- package/dist/components/containers/tipIndicator.css +79 -0
- package/dist/components/containers/toaster.css +137 -0
- package/dist/components/containers/tooltip.css +0 -0
- package/dist/components/inputs/.gitkeep +0 -0
- package/dist/components/inputs/Checkbox.svelte +95 -0
- package/dist/components/inputs/Checkbox.svelte.d.ts +33 -0
- package/dist/components/inputs/Chips.svelte +104 -0
- package/dist/components/inputs/Chips.svelte.d.ts +48 -0
- package/dist/components/inputs/Dropdown.svelte +83 -0
- package/dist/components/inputs/Dropdown.svelte.d.ts +15 -0
- package/dist/components/inputs/Radio.svelte +109 -0
- package/dist/components/inputs/Radio.svelte.d.ts +49 -0
- package/dist/components/inputs/Switch.svelte +45 -0
- package/dist/components/inputs/Switch.svelte.d.ts +21 -0
- package/dist/components/inputs/TextArea.svelte +65 -0
- package/dist/components/inputs/TextArea.svelte.d.ts +14 -0
- package/dist/components/inputs/TextInput.svelte +273 -0
- package/dist/components/inputs/TextInput.svelte.d.ts +140 -0
- package/dist/components/inputs/TextLink.svelte +102 -0
- package/dist/components/inputs/TextLink.svelte.d.ts +21 -0
- package/dist/components/inputs/checkbox.css +103 -0
- package/dist/components/inputs/chips.css +76 -0
- package/dist/components/inputs/dropdown.css +106 -0
- package/dist/components/inputs/radio.css +108 -0
- package/dist/components/inputs/switch.css +68 -0
- package/dist/components/inputs/textInput.css +152 -0
- package/dist/components/inputs/textarea.css +91 -0
- package/dist/components/inputs/textlink.css +163 -0
- package/dist/index.d.ts +21 -20
- package/dist/index.js +36 -3187
- package/dist/layouts/AppLayout.svelte +83 -0
- package/dist/layouts/AppLayout.svelte.d.ts +20 -0
- package/dist/layouts/AuthLayout.svelte +63 -0
- package/dist/layouts/AuthLayout.svelte.d.ts +18 -0
- package/dist/layouts/DashboardLayout.svelte +88 -0
- package/dist/layouts/DashboardLayout.svelte.d.ts +20 -0
- package/dist/types/button.js +5 -0
- package/dist/types/index.d.ts +2 -2
- package/dist/types/index.js +5 -0
- package/dist/types/layout.d.ts +1 -1
- package/dist/types/layout.js +1 -0
- package/package.json +14 -9
- package/dist/index.css +0 -1
- package/dist/index.js.map +0 -1
- package/dist/lib/components/buttons/Button.svelte.d.ts +0 -1
- package/dist/lib/components/buttons/DropdownButton.svelte.d.ts +0 -1
- package/dist/lib/components/buttons/PillTab.svelte.d.ts +0 -1
- package/dist/lib/components/containers/Banner.svelte.d.ts +0 -1
- package/dist/lib/components/containers/Card.svelte.d.ts +0 -1
- package/dist/lib/components/containers/Toaster.svelte.d.ts +0 -1
- package/dist/lib/components/inputs/Checkbox.svelte.d.ts +0 -1
- package/dist/lib/components/inputs/Chips.svelte.d.ts +0 -1
- package/dist/lib/components/inputs/DateInput.svelte.d.ts +0 -1
- package/dist/lib/components/inputs/DateInput2.svelte.d.ts +0 -1
- package/dist/lib/components/inputs/Dropdown.svelte.d.ts +0 -1
- package/dist/lib/components/inputs/Password.svelte.d.ts +0 -1
- package/dist/lib/components/inputs/Radio.svelte.d.ts +0 -1
- package/dist/lib/components/inputs/TextArea.svelte.d.ts +0 -1
- package/dist/lib/components/inputs/TextInput.svelte.d.ts +0 -1
- package/dist/lib/components/inputs/TextLink.svelte.d.ts +0 -1
- package/dist/lib/layouts/AppLayout.svelte.d.ts +0 -1
- package/dist/lib/layouts/AuthLayout.svelte.d.ts +0 -1
- package/dist/lib/layouts/DashboardLayout.svelte.d.ts +0 -1
- /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
|
+
}
|