mirror of
https://github.com/carbon-design-system/carbon-components-svelte.git
synced 2025-09-15 18:31:06 +00:00
- add ref prop for applicable components (#196) - add slot to Content Switcher `Switch` component (#183) - remove fillArray, css utilities
33 lines
842 B
Svelte
33 lines
842 B
Svelte
<script>
|
|
export let size = undefined; // "sm" | "xl"
|
|
export let type = "default"; // "default" | "inline"
|
|
export let disabled = false;
|
|
export let invalid = false;
|
|
export let invalidText = "";
|
|
export let light = false;
|
|
export let open = false;
|
|
</script>
|
|
|
|
<div
|
|
role="listbox"
|
|
tabindex="-1"
|
|
data-invalid={invalid || undefined}
|
|
class:bx--list-box={true}
|
|
class:bx--list-box--inline={type === 'inline'}
|
|
class:bx--list-box--disabled={disabled}
|
|
class:bx--list-box--expanded={open}
|
|
class:bx--list-box--light={light}
|
|
class={size && `bx--list-box--${size}`}
|
|
{...$$restProps}
|
|
on:keydown
|
|
on:keydown={e => {
|
|
if (e.key === 'Escape') {
|
|
e.stopPropagation();
|
|
}
|
|
}}
|
|
on:click|preventDefault|stopPropagation>
|
|
<slot />
|
|
</div>
|
|
{#if invalid}
|
|
<div class:bx--form-requirement={true}>{invalidText}</div>
|
|
{/if}
|