carbon-components-svelte/src/StructuredList/StructuredList.svelte
2022-03-20 08:18:13 -07:00

48 lines
1.1 KiB
Svelte

<script>
/**
* Specify the selected structured list row value
* @type {string}
*/
export let selected = undefined;
/** Set to `true` to use the condensed variant */
export let condensed = false;
/** Set to `true` to flush the list */
export let flush = false;
/** Set to `true` to use the selection variant */
export let selection = false;
import { createEventDispatcher, setContext } from "svelte";
import { writable } from "svelte/store";
const dispatch = createEventDispatcher();
const selectedValue = writable(selected);
setContext("StructuredListWrapper", {
selectedValue,
update: (value) => {
selectedValue.set(value);
},
});
$: selected = $selectedValue;
$: dispatch("change", $selectedValue);
</script>
<!-- svelte-ignore a11y-mouse-events-have-key-events -->
<div
role="table"
class:bx--structured-list="{true}"
class:bx--structured-list--selection="{selection}"
class:bx--structured-list--condensed="{condensed}"
class:bx--structured-list--flush="{flush}"
{...$$restProps}
on:click
on:mouseover
on:mouseenter
on:mouseleave
>
<slot />
</div>