Skip to content

Commit

Permalink
Pass controlled ids as slot props to component roots (huntabyte#145)
Browse files Browse the repository at this point in the history
  • Loading branch information
huntabyte authored Oct 27, 2023
1 parent 57a5cde commit 84d3d82
Show file tree
Hide file tree
Showing 11 changed files with 50 additions and 50 deletions.
5 changes: 5 additions & 0 deletions .changeset/calm-rabbits-smell.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"bits-ui": patch
---

Pass controlled `ids` as slot props to each `Component.Root`
15 changes: 14 additions & 1 deletion src/components/demos/popover-demo.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -3,14 +3,27 @@
import * as Label from "@/components/ui/label";
import * as Button from "@/components/ui/button";
import * as Input from "@/components/ui/input";
import { tick } from "svelte";
let open = false;
</script>

<Popover.Root>
<Popover.Root bind:open let:ids>
<Popover.Trigger asChild let:builder>
<Button.Root builders={[builder]} variant="outline">Open</Button.Root>
</Popover.Trigger>
<Popover.Content class="w-80">
<div class="grid gap-4">
<button
on:click={() => {
open = false;
tick().then(() => {
document.getElementById(ids.trigger)?.focus();
});
}}
>
close me
</button>
<div class="space-y-2">
<h4 class="font-medium leading-none">Dimensions</h4>
<p class="text-sm text-muted-foreground">Set the dimensions for the layer.</p>
Expand Down
7 changes: 4 additions & 3 deletions src/lib/bits/accordion/components/Accordion.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,8 @@
const {
elements: { root },
states: { value: localValue },
updateOption
updateOption,
ids
} = setCtx({
multiple,
disabled,
Expand Down Expand Up @@ -43,9 +44,9 @@
</script>

{#if asChild}
<slot {builder} {attrs} />
<slot {builder} {attrs} {ids} />
{:else}
<div use:melt={builder} {...$$restProps} {...attrs}>
<slot {builder} {attrs} />
<slot {builder} {attrs} {ids} />
</div>
{/if}
5 changes: 3 additions & 2 deletions src/lib/bits/alert-dialog/components/AlertDialog.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,8 @@
const {
states: { open: localOpen },
updateOption
updateOption,
ids
} = setCtx({
closeOnEscape,
preventScroll,
Expand Down Expand Up @@ -73,4 +74,4 @@
$: updateOption("forceVisible", forceVisible);
</script>

<slot />
<slot {ids} />
5 changes: 3 additions & 2 deletions src/lib/bits/dialog/components/Dialog.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,8 @@
let timeout = 0;
const {
states: { open: localOpen },
updateOption
updateOption,
ids
} = setCtx({
closeOnEscape,
preventScroll,
Expand Down Expand Up @@ -80,4 +81,4 @@
$: updateOption("closeFocus", closeFocus);
</script>

<slot />
<slot {ids} />
5 changes: 3 additions & 2 deletions src/lib/bits/link-preview/components/LinkPreview.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,8 @@
const {
states: { open: localOpen },
updateOption
updateOption,
ids
} = setCtx({
defaultOpen: open,
positioning,
Expand Down Expand Up @@ -44,4 +45,4 @@
$: updateOption("portal", portal);
</script>

<slot />
<slot {ids} />
33 changes: 8 additions & 25 deletions src/lib/bits/popover/components/Popover.svelte
Original file line number Diff line number Diff line change
@@ -1,8 +1,6 @@
<script lang="ts">
import type { Props } from "../types.js";
import { setCtx } from "../ctx.js";
import { isBrowser } from "$lib/internal/is.js";
import { tick } from "svelte";
type $$Props = Props;
export let positioning: $$Props["positioning"] = undefined;
Expand All @@ -14,14 +12,13 @@
export let portal: $$Props["portal"] = undefined;
export let open: $$Props["open"] = undefined;
export let onOpenChange: $$Props["onOpenChange"] = undefined;
export let focusTriggerOnClose: $$Props["focusTriggerOnClose"] = false;
export let openFocus: $$Props["openFocus"] = undefined;
export let closeFocus: $$Props["closeFocus"] = undefined;
const {
updateOption,
states: { open: localOpen },
ids: { trigger }
ids
} = setCtx({
positioning,
arrowSize,
Expand All @@ -33,29 +30,15 @@
defaultOpen: open,
openFocus,
closeFocus,
onOpenChange: ({ next, curr }) => {
return customOnOpenChange({ next, curr });
onOpenChange: ({ next }) => {
if (open !== next) {
onOpenChange?.(next);
open = next;
}
return next;
}
});
type ChangeFn = ({ curr, next }: { curr: boolean; next: boolean }) => boolean;
const customOnOpenChange: ChangeFn = ({ next }) => {
if (open === next) return next;
if (next === false && focusTriggerOnClose && isBrowser) {
tick().then(() => {
const triggerEl = document.getElementById(trigger);
if (triggerEl) {
triggerEl.focus();
}
});
}
onOpenChange?.(next);
open = next;
return next;
};
$: open !== undefined && localOpen.set(open);
$: updateOption("positioning", positioning);
Expand All @@ -69,4 +52,4 @@
$: updateOption("closeFocus", closeFocus);
</script>

<slot />
<slot {ids} />
8 changes: 0 additions & 8 deletions src/lib/bits/popover/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,14 +15,6 @@ type Props = Expand<
OmitOpen<CreatePopoverProps> & {
open?: boolean;
onOpenChange?: OnChangeFn<boolean>;
/**
* Focus the trigger when `open` is programmatically set to false.
* This is in addition to the automatic focus that occurs when you
* don't programmatically set `open` to false.
*
* @default false;
*/
focusTriggerOnClose?: boolean;
}
>;

Expand Down
5 changes: 3 additions & 2 deletions src/lib/bits/select/components/Select.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,8 @@
const {
states: { open: localOpen, selected: localSelected },
updateOption
updateOption,
ids
} = setCtx({
required,
disabled,
Expand Down Expand Up @@ -72,4 +73,4 @@
$: updateOption("forceVisible", forceVisible);
</script>

<slot />
<slot {ids} />
7 changes: 4 additions & 3 deletions src/lib/bits/slider/components/Slider.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,8 @@
const {
elements: { root },
states: { value: localValue },
updateOption
updateOption,
ids
} = setCtx({
disabled,
min,
Expand Down Expand Up @@ -46,9 +47,9 @@
</script>

{#if asChild}
<slot {builder} {attrs} />
<slot {builder} {attrs} {ids} />
{:else}
<span use:melt={builder} {...$$restProps} {...attrs}>
<slot {builder} {attrs} />
<slot {builder} {attrs} {ids} />
</span>
{/if}
5 changes: 3 additions & 2 deletions src/lib/bits/tooltip/components/Tooltip.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,8 @@
const {
states: { open: localOpen },
updateOption
updateOption,
ids
} = setCtx({
positioning,
arrowSize,
Expand Down Expand Up @@ -53,4 +54,4 @@
$: updateOption("disableHoverableContent", disableHoverableContent);
</script>

<slot />
<slot {ids} />

0 comments on commit 84d3d82

Please sign in to comment.