ui-ingredients 0.0.25 → 0.0.27
Sign up to get free protection for your applications and to get access to all the features.
- package/README.md +80 -80
- package/dist/accordion/item-content.svelte +13 -7
- package/dist/accordion/item-indicator.svelte +13 -7
- package/dist/accordion/item-trigger.svelte +13 -7
- package/dist/accordion/item.svelte +11 -6
- package/dist/accordion/root.svelte +11 -5
- package/dist/avatar/fallback.svelte +13 -7
- package/dist/avatar/image.svelte +11 -5
- package/dist/avatar/root.svelte +11 -13
- package/dist/carousel/indicator-group.svelte +13 -7
- package/dist/carousel/indicator.svelte +13 -7
- package/dist/carousel/item-group.svelte +13 -7
- package/dist/carousel/item.svelte +12 -8
- package/dist/carousel/next-trigger.svelte +13 -7
- package/dist/carousel/prev-trigger.svelte +13 -7
- package/dist/carousel/root.svelte +11 -5
- package/dist/carousel/viewport.svelte +13 -7
- package/dist/checkbox/control.svelte +13 -7
- package/dist/checkbox/hidden-input.svelte +1 -1
- package/dist/checkbox/indicator.svelte +13 -7
- package/dist/checkbox/label.svelte +13 -7
- package/dist/checkbox/root.svelte +11 -5
- package/dist/clipboard/control.svelte +13 -7
- package/dist/clipboard/indicator.svelte +13 -7
- package/dist/clipboard/input.svelte +11 -5
- package/dist/clipboard/label.svelte +13 -7
- package/dist/clipboard/root.svelte +11 -5
- package/dist/clipboard/trigger.svelte +13 -7
- package/dist/collapsible/content.svelte +13 -7
- package/dist/collapsible/root.svelte +12 -6
- package/dist/collapsible/trigger.svelte +13 -7
- package/dist/color-picker/area-background.svelte +21 -0
- package/dist/color-picker/area-background.svelte.d.ts +18 -0
- package/dist/color-picker/area-thumb.svelte +21 -0
- package/dist/color-picker/area-thumb.svelte.d.ts +18 -0
- package/dist/color-picker/area.svelte +27 -0
- package/dist/color-picker/area.svelte.d.ts +18 -0
- package/dist/color-picker/channel-input.svelte +28 -0
- package/dist/color-picker/channel-input.svelte.d.ts +18 -0
- package/dist/color-picker/channel-slider-label.svelte +25 -0
- package/dist/color-picker/channel-slider-label.svelte.d.ts +18 -0
- package/dist/color-picker/channel-slider-thumb.svelte +23 -0
- package/dist/color-picker/channel-slider-thumb.svelte.d.ts +18 -0
- package/dist/color-picker/channel-slider-track.svelte +23 -0
- package/dist/color-picker/channel-slider-track.svelte.d.ts +18 -0
- package/dist/color-picker/channel-slider-value-text.svelte +29 -0
- package/dist/color-picker/channel-slider-value-text.svelte.d.ts +18 -0
- package/dist/color-picker/channel-slider.svelte +29 -0
- package/dist/color-picker/channel-slider.svelte.d.ts +18 -0
- package/dist/color-picker/color-picker.d.ts +26 -0
- package/dist/color-picker/color-picker.js +26 -0
- package/dist/color-picker/content.svelte +20 -0
- package/dist/color-picker/content.svelte.d.ts +18 -0
- package/dist/color-picker/context.svelte.d.ts +8 -0
- package/dist/color-picker/context.svelte.js +6 -0
- package/dist/color-picker/control.svelte +20 -0
- package/dist/color-picker/control.svelte.d.ts +18 -0
- package/dist/color-picker/create-color-picker.svelte.d.ts +9 -0
- package/dist/color-picker/create-color-picker.svelte.js +20 -0
- package/dist/color-picker/eye-dropper-trigger.svelte +20 -0
- package/dist/color-picker/eye-dropper-trigger.svelte.d.ts +18 -0
- package/dist/color-picker/format-select.svelte +28 -0
- package/dist/color-picker/format-select.svelte.d.ts +18 -0
- package/dist/color-picker/format-trigger.svelte +20 -0
- package/dist/color-picker/format-trigger.svelte.d.ts +18 -0
- package/dist/color-picker/hidden-input.svelte +18 -0
- package/dist/color-picker/hidden-input.svelte.d.ts +18 -0
- package/dist/color-picker/index.d.ts +26 -0
- package/dist/color-picker/index.js +1 -0
- package/dist/color-picker/label.svelte +20 -0
- package/dist/color-picker/label.svelte.d.ts +18 -0
- package/dist/color-picker/positioner.svelte +20 -0
- package/dist/color-picker/positioner.svelte.d.ts +18 -0
- package/dist/color-picker/root.svelte +75 -0
- package/dist/color-picker/root.svelte.d.ts +18 -0
- package/dist/color-picker/swatch-group.svelte +20 -0
- package/dist/color-picker/swatch-group.svelte.d.ts +18 -0
- package/dist/color-picker/swatch-indicator.svelte +21 -0
- package/dist/color-picker/swatch-indicator.svelte.d.ts +18 -0
- package/dist/color-picker/swatch-trigger.svelte +31 -0
- package/dist/color-picker/swatch-trigger.svelte.d.ts +18 -0
- package/dist/color-picker/swatch.svelte +27 -0
- package/dist/color-picker/swatch.svelte.d.ts +18 -0
- package/dist/color-picker/transparency-grid.svelte +29 -0
- package/dist/color-picker/transparency-grid.svelte.d.ts +18 -0
- package/dist/color-picker/trigger.svelte +20 -0
- package/dist/color-picker/trigger.svelte.d.ts +18 -0
- package/dist/color-picker/value-text.svelte +24 -0
- package/dist/color-picker/value-text.svelte.d.ts +18 -0
- package/dist/combobox/clear-trigger.svelte +13 -7
- package/dist/combobox/content.svelte +13 -7
- package/dist/combobox/control.svelte +13 -7
- package/dist/combobox/input.svelte +11 -5
- package/dist/combobox/item-group-label.svelte +13 -7
- package/dist/combobox/item-group.svelte +13 -8
- package/dist/combobox/item-indicator.svelte +13 -7
- package/dist/combobox/item-text.svelte +17 -11
- package/dist/combobox/item.svelte +11 -6
- package/dist/combobox/label.svelte +13 -7
- package/dist/combobox/list.svelte +13 -7
- package/dist/combobox/positioner.svelte +13 -7
- package/dist/combobox/root.svelte +11 -5
- package/dist/combobox/trigger.svelte +13 -7
- package/dist/date-picker/clear-trigger.svelte +13 -7
- package/dist/date-picker/content.svelte +13 -7
- package/dist/date-picker/control.svelte +13 -7
- package/dist/date-picker/create-date-picker.svelte.d.ts +2 -0
- package/dist/date-picker/create-date-picker.svelte.js +11 -1
- package/dist/date-picker/day-table-cell-trigger.svelte +13 -7
- package/dist/date-picker/day-table-cell.svelte +13 -14
- package/dist/date-picker/input.svelte +11 -5
- package/dist/date-picker/label.svelte +13 -7
- package/dist/date-picker/month-select.svelte +19 -13
- package/dist/date-picker/month-table-cell-trigger.svelte +13 -7
- package/dist/date-picker/month-table-cell.svelte +13 -14
- package/dist/date-picker/next-trigger.svelte +13 -7
- package/dist/date-picker/positioner.svelte +13 -7
- package/dist/date-picker/preset-trigger.svelte +13 -7
- package/dist/date-picker/prev-trigger.svelte +13 -7
- package/dist/date-picker/range-text.svelte +17 -11
- package/dist/date-picker/root.svelte +11 -5
- package/dist/date-picker/table-body.svelte +13 -7
- package/dist/date-picker/table-head.svelte +13 -7
- package/dist/date-picker/table-header.svelte +13 -7
- package/dist/date-picker/table-row.svelte +13 -7
- package/dist/date-picker/table.svelte +13 -7
- package/dist/date-picker/trigger.svelte +13 -7
- package/dist/date-picker/view-control.svelte +13 -7
- package/dist/date-picker/view-trigger.svelte +13 -7
- package/dist/date-picker/view.svelte +21 -9
- package/dist/date-picker/year-select.svelte +19 -13
- package/dist/date-picker/year-table-cell-trigger.svelte +13 -7
- package/dist/date-picker/year-table-cell.svelte +13 -14
- package/dist/dialog/backdrop.svelte +13 -7
- package/dist/dialog/close-trigger.svelte +13 -7
- package/dist/dialog/content.svelte +13 -7
- package/dist/dialog/description.svelte +13 -7
- package/dist/dialog/positioner.svelte +14 -7
- package/dist/dialog/title.svelte +13 -7
- package/dist/dialog/trigger.svelte +13 -7
- package/dist/editable/area.svelte +13 -7
- package/dist/editable/cancel-trigger.svelte +13 -7
- package/dist/editable/control.svelte +13 -7
- package/dist/editable/edit-trigger.svelte +13 -7
- package/dist/editable/input.svelte +11 -5
- package/dist/editable/label.svelte +13 -7
- package/dist/editable/preview.svelte +17 -11
- package/dist/editable/root.svelte +73 -4
- package/dist/editable/submit-trigger.svelte +13 -7
- package/dist/file-upload/dropzone.svelte +13 -7
- package/dist/file-upload/hidden-input.svelte +1 -1
- package/dist/file-upload/item-delete-trigger.svelte +13 -7
- package/dist/file-upload/item-group.svelte +13 -7
- package/dist/file-upload/item-name.svelte +17 -11
- package/dist/file-upload/item-preview-image.svelte +11 -5
- package/dist/file-upload/item-preview.svelte +13 -7
- package/dist/file-upload/item-size-text.svelte +17 -11
- package/dist/file-upload/item.svelte +13 -7
- package/dist/file-upload/label.svelte +13 -7
- package/dist/file-upload/root.svelte +11 -5
- package/dist/file-upload/trigger.svelte +13 -7
- package/dist/hover-card/arrow-tip.svelte +13 -7
- package/dist/hover-card/arrow.svelte +13 -7
- package/dist/hover-card/content.svelte +13 -7
- package/dist/hover-card/positioner.svelte +13 -7
- package/dist/hover-card/trigger.svelte +13 -7
- package/dist/index.d.ts +2 -0
- package/dist/index.js +2 -0
- package/dist/menu/arrow-tip.svelte +13 -7
- package/dist/menu/arrow.svelte +13 -7
- package/dist/menu/content.svelte +13 -7
- package/dist/menu/context-trigger.svelte +13 -7
- package/dist/menu/indicator.svelte +13 -7
- package/dist/menu/item-group-label.svelte +13 -7
- package/dist/menu/item-group.svelte +13 -9
- package/dist/menu/item.svelte +12 -6
- package/dist/menu/option-item-indicator.svelte +13 -7
- package/dist/menu/option-item-text.svelte +17 -11
- package/dist/menu/option-item.svelte +11 -5
- package/dist/menu/positioner.svelte +13 -7
- package/dist/menu/separator.svelte +13 -7
- package/dist/menu/trigger-item.svelte +13 -7
- package/dist/menu/trigger.svelte +13 -7
- package/dist/number-input/control.svelte +13 -7
- package/dist/number-input/decrement-trigger.svelte +13 -7
- package/dist/number-input/increment-trigger.svelte +13 -7
- package/dist/number-input/input.svelte +11 -5
- package/dist/number-input/label.svelte +13 -7
- package/dist/number-input/root.svelte +11 -5
- package/dist/number-input/scrubber.svelte +13 -7
- package/dist/pagination/ellipsis.svelte +13 -7
- package/dist/pagination/item.svelte +13 -7
- package/dist/pagination/next-trigger.svelte +13 -7
- package/dist/pagination/prev-trigger.svelte +13 -7
- package/dist/pagination/root.svelte +11 -5
- package/dist/pin-input/anatomy.js +3 -0
- package/dist/pin-input/clear-trigger.svelte +18 -13
- package/dist/pin-input/create-pin-input.svelte.d.ts +2 -0
- package/dist/pin-input/create-pin-input.svelte.js +13 -1
- package/dist/pin-input/hidden-input.svelte +1 -1
- package/dist/pin-input/input.svelte +11 -5
- package/dist/pin-input/label.svelte +13 -7
- package/dist/pin-input/pin-input.d.ts +1 -1
- package/dist/pin-input/pin-input.js +1 -1
- package/dist/pin-input/root.svelte +11 -5
- package/dist/popover/arrow-tip.svelte +13 -7
- package/dist/popover/arrow.svelte +13 -7
- package/dist/popover/close-trigger.svelte +13 -7
- package/dist/popover/content.svelte +13 -7
- package/dist/popover/description.svelte +13 -7
- package/dist/popover/positioner.svelte +13 -7
- package/dist/popover/title.svelte +13 -7
- package/dist/popover/trigger.svelte +13 -7
- package/dist/presence/context.svelte.d.ts +3 -0
- package/dist/presence/context.svelte.js +2 -0
- package/dist/presence/create-presence.svelte.d.ts +11 -4
- package/dist/presence/create-presence.svelte.js +19 -3
- package/dist/presence/root.svelte +9 -9
- package/dist/presence/root.svelte.d.ts +1 -1
- package/dist/progress/circle-range.svelte +13 -7
- package/dist/progress/circle-track.svelte +13 -7
- package/dist/progress/circle.svelte +13 -7
- package/dist/progress/label.svelte +13 -7
- package/dist/progress/range.svelte +13 -7
- package/dist/progress/root.svelte +11 -5
- package/dist/progress/track.svelte +13 -7
- package/dist/progress/value-text.svelte +17 -11
- package/dist/progress/view.svelte +13 -7
- package/dist/qr-code/frame.svelte +13 -7
- package/dist/qr-code/overlay.svelte +13 -7
- package/dist/qr-code/pattern.svelte +13 -7
- package/dist/qr-code/root.svelte +11 -5
- package/dist/radio-group/indicator.svelte +13 -7
- package/dist/radio-group/item-control.svelte +13 -7
- package/dist/radio-group/item-hidden-input.svelte +1 -1
- package/dist/radio-group/item-text.svelte +13 -7
- package/dist/radio-group/item.svelte +11 -13
- package/dist/radio-group/label.svelte +13 -7
- package/dist/radio-group/root.svelte +11 -5
- package/dist/rating-group/control.svelte +15 -9
- package/dist/rating-group/hidden-input.svelte +1 -1
- package/dist/rating-group/item.svelte +14 -9
- package/dist/rating-group/label.svelte +15 -9
- package/dist/rating-group/root.svelte +15 -9
- package/dist/segment-group/indicator.svelte +13 -8
- package/dist/segment-group/item-control.svelte +13 -8
- package/dist/segment-group/item-hidden-input.svelte +1 -1
- package/dist/segment-group/item-text.svelte +13 -8
- package/dist/segment-group/item.svelte +11 -6
- package/dist/segment-group/label.svelte +13 -8
- package/dist/segment-group/root.svelte +11 -6
- package/dist/select/clear-trigger.svelte +13 -7
- package/dist/select/content.svelte +13 -7
- package/dist/select/control.svelte +13 -7
- package/dist/select/hidden-select.svelte +1 -1
- package/dist/select/indicator.svelte +13 -7
- package/dist/select/item-group-label.svelte +13 -7
- package/dist/select/item-group.svelte +13 -8
- package/dist/select/item-indicator.svelte +13 -7
- package/dist/select/item-text.svelte +17 -11
- package/dist/select/item.svelte +11 -6
- package/dist/select/label.svelte +13 -7
- package/dist/select/list.svelte +13 -7
- package/dist/select/positioner.svelte +13 -7
- package/dist/select/root.svelte +12 -6
- package/dist/select/trigger.svelte +13 -7
- package/dist/select/value-text.svelte +19 -13
- package/dist/signature-pad/clear-trigger.svelte +13 -7
- package/dist/signature-pad/control.svelte +13 -7
- package/dist/signature-pad/current-segment-path.svelte +13 -7
- package/dist/signature-pad/guide.svelte +13 -7
- package/dist/signature-pad/hidden-input.svelte +1 -1
- package/dist/signature-pad/label.svelte +13 -7
- package/dist/signature-pad/root.svelte +11 -5
- package/dist/signature-pad/segment-path.svelte +13 -7
- package/dist/signature-pad/segment.svelte +13 -7
- package/dist/slider/control.svelte +13 -7
- package/dist/slider/hidden-input.svelte +1 -1
- package/dist/slider/label.svelte +13 -7
- package/dist/slider/marker-group.svelte +13 -7
- package/dist/slider/marker.svelte +13 -7
- package/dist/slider/range.svelte +13 -7
- package/dist/slider/root.svelte +11 -5
- package/dist/slider/thumb.svelte +13 -7
- package/dist/slider/track.svelte +13 -7
- package/dist/slider/value-text.svelte +17 -11
- package/dist/splitter/panel.svelte +13 -7
- package/dist/splitter/resize-trigger.svelte +11 -6
- package/dist/splitter/root.svelte +11 -5
- package/dist/steps/completed-content.svelte +13 -7
- package/dist/steps/content.svelte +13 -7
- package/dist/steps/indicator.svelte +13 -7
- package/dist/steps/item.svelte +11 -6
- package/dist/steps/list.svelte +13 -7
- package/dist/steps/next-trigger.svelte +13 -7
- package/dist/steps/prev-trigger.svelte +13 -7
- package/dist/steps/progress.svelte +13 -7
- package/dist/steps/root.svelte +12 -6
- package/dist/steps/separator.svelte +13 -7
- package/dist/steps/trigger.svelte +13 -7
- package/dist/switch/control.svelte +13 -7
- package/dist/switch/hidden-input.svelte +1 -1
- package/dist/switch/label.svelte +13 -7
- package/dist/switch/root.svelte +11 -5
- package/dist/switch/thumb.svelte +13 -7
- package/dist/tabs/content.svelte +13 -7
- package/dist/tabs/list.svelte +13 -7
- package/dist/tabs/root.svelte +12 -6
- package/dist/tabs/trigger.svelte +13 -7
- package/dist/tags-input/clear-trigger.svelte +13 -7
- package/dist/tags-input/control.svelte +13 -7
- package/dist/tags-input/hidden-input.svelte +1 -1
- package/dist/tags-input/input.svelte +11 -5
- package/dist/tags-input/item-delete-trigger.svelte +13 -7
- package/dist/tags-input/item-input.svelte +11 -5
- package/dist/tags-input/item-preview.svelte +13 -7
- package/dist/tags-input/item-text.svelte +13 -7
- package/dist/tags-input/item.svelte +11 -13
- package/dist/tags-input/label.svelte +13 -7
- package/dist/tags-input/root.svelte +12 -6
- package/dist/time-picker/clear-trigger.svelte +13 -7
- package/dist/time-picker/column.svelte +13 -7
- package/dist/time-picker/content.svelte +13 -7
- package/dist/time-picker/control.svelte +13 -7
- package/dist/time-picker/hour-cell.svelte +13 -7
- package/dist/time-picker/input.svelte +11 -5
- package/dist/time-picker/label.svelte +13 -7
- package/dist/time-picker/minute-cell.svelte +13 -7
- package/dist/time-picker/period-cell.svelte +13 -7
- package/dist/time-picker/positioner.svelte +13 -7
- package/dist/time-picker/root.svelte +11 -5
- package/dist/time-picker/second-cell.svelte +13 -7
- package/dist/time-picker/spacer.svelte +13 -7
- package/dist/time-picker/trigger.svelte +13 -7
- package/dist/timer/action-trigger.svelte +13 -8
- package/dist/timer/item-label.svelte +13 -7
- package/dist/timer/item-value.svelte +17 -11
- package/dist/timer/item.svelte +13 -7
- package/dist/timer/root.svelte +11 -5
- package/dist/timer/separator.svelte +13 -7
- package/dist/toast/action-trigger.svelte +13 -7
- package/dist/toast/actor.svelte +6 -6
- package/dist/toast/actor.svelte.d.ts +3 -3
- package/dist/toast/close-trigger.svelte +13 -7
- package/dist/toast/description.svelte +17 -11
- package/dist/toast/ghost-after.svelte +18 -0
- package/dist/toast/ghost-after.svelte.d.ts +18 -0
- package/dist/toast/ghost-before.svelte +18 -0
- package/dist/toast/ghost-before.svelte.d.ts +18 -0
- package/dist/toast/index.d.ts +2 -0
- package/dist/toast/root.svelte +16 -14
- package/dist/toast/title.svelte +17 -11
- package/dist/toast/toast.d.ts +2 -0
- package/dist/toast/toast.js +2 -0
- package/dist/toast/toaster.svelte +6 -5
- package/dist/toggle-group/item.svelte +11 -6
- package/dist/toggle-group/root.svelte +12 -6
- package/dist/tooltip/arrow-tip.svelte +13 -7
- package/dist/tooltip/arrow.svelte +13 -7
- package/dist/tooltip/content.svelte +13 -7
- package/dist/tooltip/positioner.svelte +13 -7
- package/dist/tooltip/trigger.svelte +13 -7
- package/dist/tree-view/branch-content.svelte +13 -7
- package/dist/tree-view/branch-control.svelte +13 -7
- package/dist/tree-view/branch-indicator.svelte +13 -7
- package/dist/tree-view/branch-text.svelte +13 -7
- package/dist/tree-view/branch-trigger.svelte +13 -7
- package/dist/tree-view/branch.svelte +11 -13
- package/dist/tree-view/item-indicator.svelte +13 -7
- package/dist/tree-view/item-text.svelte +13 -7
- package/dist/tree-view/item.svelte +11 -13
- package/dist/tree-view/label.svelte +13 -7
- package/dist/tree-view/root.svelte +12 -6
- package/dist/tree-view/tree.svelte +13 -7
- package/dist/types.d.ts +8 -1
- package/dist/utils.svelte.d.ts +2 -5
- package/dist/utils.svelte.js +9 -9
- package/package.json +4 -3
- package/dist/color-picker/.gitkeep +0 -0
@@ -1,20 +1,26 @@
|
|
1
1
|
<script lang="ts" module>
|
2
|
-
import type {HtmlProps} from '../types.js';
|
2
|
+
import type {AsChild, HtmlProps} from '../types.js';
|
3
3
|
|
4
|
-
export interface ComboboxControlProps extends HtmlProps<'div'> {
|
4
|
+
export interface ComboboxControlProps extends HtmlProps<'div'> {
|
5
|
+
asChild?: AsChild;
|
6
|
+
}
|
5
7
|
</script>
|
6
8
|
|
7
9
|
<script lang="ts">
|
8
|
-
import {mergeProps} from '
|
10
|
+
import {mergeProps} from '../utils.svelte.js';
|
9
11
|
import {comboboxContext} from './context.svelte.js';
|
10
12
|
|
11
|
-
let {children, ...props}: ComboboxControlProps = $props();
|
13
|
+
let {asChild, children, ...props}: ComboboxControlProps = $props();
|
12
14
|
|
13
15
|
let combobox = comboboxContext.get();
|
14
16
|
|
15
17
|
let attrs = $derived(mergeProps(props, combobox.getControlProps()));
|
16
18
|
</script>
|
17
19
|
|
18
|
-
|
19
|
-
{@render
|
20
|
-
|
20
|
+
{#if asChild}
|
21
|
+
{@render asChild(attrs)}
|
22
|
+
{:else}
|
23
|
+
<div {...attrs}>
|
24
|
+
{@render children?.()}
|
25
|
+
</div>
|
26
|
+
{/if}
|
@@ -1,18 +1,24 @@
|
|
1
1
|
<script lang="ts" module>
|
2
|
-
import type {HtmlProps} from '../types.js';
|
2
|
+
import type {AsChild, HtmlProps} from '../types.js';
|
3
3
|
|
4
|
-
export interface ComboboxInputProps extends HtmlProps<'input'> {
|
4
|
+
export interface ComboboxInputProps extends HtmlProps<'input'> {
|
5
|
+
asChild?: AsChild<HtmlProps<'input'>>;
|
6
|
+
}
|
5
7
|
</script>
|
6
8
|
|
7
9
|
<script lang="ts">
|
8
|
-
import {mergeProps} from '
|
10
|
+
import {mergeProps} from '../utils.svelte.js';
|
9
11
|
import {comboboxContext} from './context.svelte.js';
|
10
12
|
|
11
|
-
let {...props}: ComboboxInputProps = $props();
|
13
|
+
let {asChild, ...props}: ComboboxInputProps = $props();
|
12
14
|
|
13
15
|
let combobox = comboboxContext.get();
|
14
16
|
|
15
17
|
let attrs = $derived(mergeProps(props, combobox.getInputProps()));
|
16
18
|
</script>
|
17
19
|
|
18
|
-
|
20
|
+
{#if asChild}
|
21
|
+
{@render asChild(attrs)}
|
22
|
+
{:else}
|
23
|
+
<input {...attrs} />
|
24
|
+
{/if}
|
@@ -1,14 +1,16 @@
|
|
1
1
|
<script lang="ts" module>
|
2
|
-
import type {HtmlProps} from '../types.js';
|
2
|
+
import type {AsChild, HtmlProps} from '../types.js';
|
3
3
|
|
4
|
-
export interface ComboboxItemGroupLabelProps extends HtmlProps<'span'> {
|
4
|
+
export interface ComboboxItemGroupLabelProps extends HtmlProps<'span'> {
|
5
|
+
asChild?: AsChild;
|
6
|
+
}
|
5
7
|
</script>
|
6
8
|
|
7
9
|
<script lang="ts">
|
8
|
-
import {mergeProps} from '
|
10
|
+
import {mergeProps} from '../utils.svelte.js';
|
9
11
|
import {comboboxContext, comboboxItemGroupPropsContext} from './context.svelte.js';
|
10
12
|
|
11
|
-
let {children, ...props}: ComboboxItemGroupLabelProps = $props();
|
13
|
+
let {asChild, children, ...props}: ComboboxItemGroupLabelProps = $props();
|
12
14
|
|
13
15
|
let combobox = comboboxContext.get();
|
14
16
|
let itemGroupProps = comboboxItemGroupPropsContext.get();
|
@@ -23,6 +25,10 @@
|
|
23
25
|
);
|
24
26
|
</script>
|
25
27
|
|
26
|
-
|
27
|
-
{@render
|
28
|
-
|
28
|
+
{#if asChild}
|
29
|
+
{@render asChild(attrs)}
|
30
|
+
{:else}
|
31
|
+
<span {...attrs}>
|
32
|
+
{@render children?.()}
|
33
|
+
</span>
|
34
|
+
{/if}
|
@@ -1,17 +1,18 @@
|
|
1
1
|
<script lang="ts" module>
|
2
|
-
import type {Assign, HtmlProps} from '../types.js';
|
2
|
+
import type {AsChild, Assign, HtmlProps} from '../types.js';
|
3
3
|
import type {ItemGroupProps} from '@zag-js/combobox';
|
4
4
|
|
5
5
|
export interface ComboboxItemGroupProps
|
6
|
-
extends Assign<HtmlProps<'div'>, Omit<ItemGroupProps, 'id'>> {
|
6
|
+
extends Assign<HtmlProps<'div'>, Omit<ItemGroupProps, 'id'>> {
|
7
|
+
asChild?: AsChild;
|
8
|
+
}
|
7
9
|
</script>
|
8
10
|
|
9
11
|
<script lang="ts">
|
10
|
-
import {createUniqueId} from '../utils.svelte.js';
|
11
|
-
import {mergeProps} from '@zag-js/svelte';
|
12
|
+
import {createUniqueId, mergeProps} from '../utils.svelte.js';
|
12
13
|
import {comboboxContext, comboboxItemGroupPropsContext} from './context.svelte.js';
|
13
14
|
|
14
|
-
let {id, children, ...props}: ComboboxItemGroupProps = $props();
|
15
|
+
let {id, asChild, children, ...props}: ComboboxItemGroupProps = $props();
|
15
16
|
|
16
17
|
let combobox = comboboxContext.get();
|
17
18
|
|
@@ -26,6 +27,10 @@
|
|
26
27
|
comboboxItemGroupPropsContext.set(() => comboboxItemGroupProps);
|
27
28
|
</script>
|
28
29
|
|
29
|
-
|
30
|
-
{@render
|
31
|
-
|
30
|
+
{#if asChild}
|
31
|
+
{@render asChild(attrs)}
|
32
|
+
{:else}
|
33
|
+
<div {...attrs}>
|
34
|
+
{@render children?.()}
|
35
|
+
</div>
|
36
|
+
{/if}
|
@@ -1,14 +1,16 @@
|
|
1
1
|
<script lang="ts" module>
|
2
|
-
import type {HtmlProps} from '../types.js';
|
2
|
+
import type {AsChild, HtmlProps} from '../types.js';
|
3
3
|
|
4
|
-
export interface ComboboxItemIndicatorProps extends HtmlProps<'span'> {
|
4
|
+
export interface ComboboxItemIndicatorProps extends HtmlProps<'span'> {
|
5
|
+
asChild?: AsChild;
|
6
|
+
}
|
5
7
|
</script>
|
6
8
|
|
7
9
|
<script lang="ts">
|
8
|
-
import {mergeProps} from '
|
10
|
+
import {mergeProps} from '../utils.svelte.js';
|
9
11
|
import {comboboxContext, comboboxItemPropsContext} from './context.svelte.js';
|
10
12
|
|
11
|
-
let {children, ...props}: ComboboxItemIndicatorProps = $props();
|
13
|
+
let {asChild, children, ...props}: ComboboxItemIndicatorProps = $props();
|
12
14
|
|
13
15
|
let combobox = comboboxContext.get();
|
14
16
|
let itemProps = comboboxItemPropsContext.get();
|
@@ -16,6 +18,10 @@
|
|
16
18
|
let attrs = $derived(mergeProps(props, combobox.getItemIndicatorProps(itemProps)));
|
17
19
|
</script>
|
18
20
|
|
19
|
-
|
20
|
-
{@render
|
21
|
-
|
21
|
+
{#if asChild}
|
22
|
+
{@render asChild(attrs)}
|
23
|
+
{:else}
|
24
|
+
<span {...attrs}>
|
25
|
+
{@render children?.()}
|
26
|
+
</span>
|
27
|
+
{/if}
|
@@ -1,14 +1,16 @@
|
|
1
1
|
<script lang="ts" module>
|
2
|
-
import type {HtmlProps} from '../types.js';
|
2
|
+
import type {AsChild, HtmlProps} from '../types.js';
|
3
3
|
|
4
|
-
export interface ComboboxItemTextProps extends HtmlProps<'span'> {
|
4
|
+
export interface ComboboxItemTextProps extends HtmlProps<'span'> {
|
5
|
+
asChild?: AsChild;
|
6
|
+
}
|
5
7
|
</script>
|
6
8
|
|
7
9
|
<script lang="ts">
|
8
|
-
import {mergeProps} from '
|
10
|
+
import {mergeProps} from '../utils.svelte.js';
|
9
11
|
import {comboboxContext, comboboxItemPropsContext} from './context.svelte.js';
|
10
12
|
|
11
|
-
let {children, ...props}: ComboboxItemTextProps = $props();
|
13
|
+
let {asChild, children, ...props}: ComboboxItemTextProps = $props();
|
12
14
|
|
13
15
|
let combobox = comboboxContext.get();
|
14
16
|
let itemProps = comboboxItemPropsContext.get();
|
@@ -16,10 +18,14 @@
|
|
16
18
|
let attrs = $derived(mergeProps(props, combobox.getItemTextProps(itemProps)));
|
17
19
|
</script>
|
18
20
|
|
19
|
-
|
20
|
-
{
|
21
|
-
|
22
|
-
{
|
23
|
-
{
|
24
|
-
|
25
|
-
|
21
|
+
{#if asChild}
|
22
|
+
{@render asChild(attrs)}
|
23
|
+
{:else}
|
24
|
+
<span {...attrs}>
|
25
|
+
{#if children}
|
26
|
+
{@render children?.()}
|
27
|
+
{:else}
|
28
|
+
{combobox.collection.stringifyItem(itemProps.item)}
|
29
|
+
{/if}
|
30
|
+
</span>
|
31
|
+
{/if}
|
@@ -1,18 +1,19 @@
|
|
1
1
|
<script lang="ts" module>
|
2
|
-
import type {Assign, HtmlProps} from '../types.js';
|
2
|
+
import type {AsChild, Assign, GenericHtmlProps, HtmlProps} from '../types.js';
|
3
3
|
import type {ItemProps, ItemState} from '@zag-js/combobox';
|
4
4
|
import type {Snippet} from 'svelte';
|
5
5
|
|
6
6
|
export interface ComboboxItemProps extends Assign<Omit<HtmlProps<'div'>, 'children'>, ItemProps> {
|
7
|
+
asChild?: AsChild<GenericHtmlProps, ItemState>;
|
7
8
|
children?: Snippet<[state: ItemState]>;
|
8
9
|
}
|
9
10
|
</script>
|
10
11
|
|
11
12
|
<script lang="ts">
|
12
|
-
import {mergeProps} from '
|
13
|
+
import {mergeProps} from '../utils.svelte.js';
|
13
14
|
import {comboboxContext, comboboxItemPropsContext} from './context.svelte.js';
|
14
15
|
|
15
|
-
let {
|
16
|
+
let {item, persistFocus, asChild, children, ...props}: ComboboxItemProps = $props();
|
16
17
|
|
17
18
|
let combobox = comboboxContext.get();
|
18
19
|
let itemProps = $derived({
|
@@ -26,6 +27,10 @@
|
|
26
27
|
comboboxItemPropsContext.set(() => itemProps);
|
27
28
|
</script>
|
28
29
|
|
29
|
-
|
30
|
-
{@render
|
31
|
-
|
30
|
+
{#if asChild}
|
31
|
+
{@render asChild(attrs, state)}
|
32
|
+
{:else}
|
33
|
+
<div {...attrs}>
|
34
|
+
{@render children?.(state)}
|
35
|
+
</div>
|
36
|
+
{/if}
|
@@ -1,20 +1,26 @@
|
|
1
1
|
<script lang="ts" module>
|
2
|
-
import type {HtmlProps} from '../types.js';
|
2
|
+
import type {AsChild, HtmlProps} from '../types.js';
|
3
3
|
|
4
|
-
export interface ComboboxLabelProps extends HtmlProps<'label'> {
|
4
|
+
export interface ComboboxLabelProps extends HtmlProps<'label'> {
|
5
|
+
asChild?: AsChild<HtmlProps<'label'>>;
|
6
|
+
}
|
5
7
|
</script>
|
6
8
|
|
7
9
|
<script lang="ts">
|
8
|
-
import {mergeProps} from '
|
10
|
+
import {mergeProps} from '../utils.svelte.js';
|
9
11
|
import {comboboxContext} from './context.svelte.js';
|
10
12
|
|
11
|
-
let {children, ...props}: ComboboxLabelProps = $props();
|
13
|
+
let {asChild, children, ...props}: ComboboxLabelProps = $props();
|
12
14
|
|
13
15
|
let combobox = comboboxContext.get();
|
14
16
|
|
15
17
|
let attrs = $derived(mergeProps(props, combobox.getLabelProps()));
|
16
18
|
</script>
|
17
19
|
|
18
|
-
|
19
|
-
{@render
|
20
|
-
|
20
|
+
{#if asChild}
|
21
|
+
{@render asChild(attrs)}
|
22
|
+
{:else}
|
23
|
+
<label {...attrs}>
|
24
|
+
{@render children?.()}
|
25
|
+
</label>
|
26
|
+
{/if}
|
@@ -1,20 +1,26 @@
|
|
1
1
|
<script lang="ts" module>
|
2
|
-
import type {HtmlProps} from '../types.js';
|
2
|
+
import type {AsChild, HtmlProps} from '../types.js';
|
3
3
|
|
4
|
-
export interface ComboboxListProps extends HtmlProps<'div'> {
|
4
|
+
export interface ComboboxListProps extends HtmlProps<'div'> {
|
5
|
+
asChild?: AsChild;
|
6
|
+
}
|
5
7
|
</script>
|
6
8
|
|
7
9
|
<script lang="ts">
|
8
|
-
import {mergeProps} from '
|
10
|
+
import {mergeProps} from '../utils.svelte.js';
|
9
11
|
import {comboboxContext} from './context.svelte.js';
|
10
12
|
|
11
|
-
let {children, ...props}: ComboboxListProps = $props();
|
13
|
+
let {asChild, children, ...props}: ComboboxListProps = $props();
|
12
14
|
|
13
15
|
let combobox = comboboxContext.get();
|
14
16
|
|
15
17
|
let attrs = $derived(mergeProps(props, combobox.getListProps()));
|
16
18
|
</script>
|
17
19
|
|
18
|
-
|
19
|
-
{@render
|
20
|
-
|
20
|
+
{#if asChild}
|
21
|
+
{@render asChild(attrs)}
|
22
|
+
{:else}
|
23
|
+
<div {...attrs}>
|
24
|
+
{@render children?.()}
|
25
|
+
</div>
|
26
|
+
{/if}
|
@@ -1,20 +1,26 @@
|
|
1
1
|
<script lang="ts" module>
|
2
|
-
import type {HtmlProps} from '../types.js';
|
2
|
+
import type {AsChild, HtmlProps} from '../types.js';
|
3
3
|
|
4
|
-
export interface ComboboxPositionerProps extends HtmlProps<'div'> {
|
4
|
+
export interface ComboboxPositionerProps extends HtmlProps<'div'> {
|
5
|
+
asChild?: AsChild;
|
6
|
+
}
|
5
7
|
</script>
|
6
8
|
|
7
9
|
<script lang="ts">
|
8
|
-
import {mergeProps} from '
|
10
|
+
import {mergeProps} from '../utils.svelte.js';
|
9
11
|
import {comboboxContext} from './context.svelte.js';
|
10
12
|
|
11
|
-
let {children, ...props}: ComboboxPositionerProps = $props();
|
13
|
+
let {asChild, children, ...props}: ComboboxPositionerProps = $props();
|
12
14
|
|
13
15
|
let combobox = comboboxContext.get();
|
14
16
|
|
15
17
|
let attrs = $derived(mergeProps(props, combobox.getPositionerProps()));
|
16
18
|
</script>
|
17
19
|
|
18
|
-
|
19
|
-
{@render
|
20
|
-
|
20
|
+
{#if asChild}
|
21
|
+
{@render asChild(attrs)}
|
22
|
+
{:else}
|
23
|
+
<div {...attrs}>
|
24
|
+
{@render children?.()}
|
25
|
+
</div>
|
26
|
+
{/if}
|
@@ -1,16 +1,17 @@
|
|
1
1
|
<script lang="ts" module>
|
2
|
-
import type {Assign, HtmlProps} from '../types.js';
|
2
|
+
import type {AsChild, Assign, GenericHtmlProps, HtmlProps} from '../types.js';
|
3
3
|
import type {Snippet} from 'svelte';
|
4
4
|
import type {CreateComboboxProps, CreateComboboxReturn} from './create-combobox.svelte.js';
|
5
5
|
|
6
6
|
export interface ComboboxProps<T>
|
7
7
|
extends Assign<Omit<HtmlProps<'div'>, 'children'>, CreateComboboxProps<T>> {
|
8
|
+
asChild?: AsChild<GenericHtmlProps, CreateComboboxReturn>;
|
8
9
|
children?: Snippet<[combobox: CreateComboboxReturn]>;
|
9
10
|
}
|
10
11
|
</script>
|
11
12
|
|
12
13
|
<script lang="ts" generics="T">
|
13
|
-
import {mergeProps} from '
|
14
|
+
import {mergeProps} from '../utils.svelte.js';
|
14
15
|
import {comboboxContext} from './context.svelte.js';
|
15
16
|
import {createCombobox} from './create-combobox.svelte.js';
|
16
17
|
|
@@ -56,6 +57,7 @@
|
|
56
57
|
onPointerDownOutside,
|
57
58
|
getSelectionValue,
|
58
59
|
scrollToIndexFn,
|
60
|
+
asChild,
|
59
61
|
children,
|
60
62
|
...props
|
61
63
|
}: ComboboxProps<T> = $props();
|
@@ -109,6 +111,10 @@
|
|
109
111
|
comboboxContext.set(combobox);
|
110
112
|
</script>
|
111
113
|
|
112
|
-
|
113
|
-
{@render
|
114
|
-
|
114
|
+
{#if asChild}
|
115
|
+
{@render asChild(attrs, combobox)}
|
116
|
+
{:else}
|
117
|
+
<div {...attrs}>
|
118
|
+
{@render children?.(combobox)}
|
119
|
+
</div>
|
120
|
+
{/if}
|
@@ -1,20 +1,26 @@
|
|
1
1
|
<script lang="ts" module>
|
2
|
-
import type {HtmlProps} from '../types.js';
|
2
|
+
import type {AsChild, HtmlProps} from '../types.js';
|
3
3
|
|
4
|
-
export interface ComboboxTriggerProps extends HtmlProps<'button'> {
|
4
|
+
export interface ComboboxTriggerProps extends HtmlProps<'button'> {
|
5
|
+
asChild?: AsChild<HtmlProps<'button'>>;
|
6
|
+
}
|
5
7
|
</script>
|
6
8
|
|
7
9
|
<script lang="ts">
|
8
|
-
import {mergeProps} from '
|
10
|
+
import {mergeProps} from '../utils.svelte.js';
|
9
11
|
import {comboboxContext} from './context.svelte.js';
|
10
12
|
|
11
|
-
let {children, ...props}: ComboboxTriggerProps = $props();
|
13
|
+
let {asChild, children, ...props}: ComboboxTriggerProps = $props();
|
12
14
|
|
13
15
|
let combobox = comboboxContext.get();
|
14
16
|
|
15
17
|
let attrs = $derived(mergeProps(props, combobox.getTriggerProps()));
|
16
18
|
</script>
|
17
19
|
|
18
|
-
|
19
|
-
{@render
|
20
|
-
|
20
|
+
{#if asChild}
|
21
|
+
{@render asChild(attrs)}
|
22
|
+
{:else}
|
23
|
+
<button type="button" {...attrs}>
|
24
|
+
{@render children?.()}
|
25
|
+
</button>
|
26
|
+
{/if}
|
@@ -1,20 +1,26 @@
|
|
1
1
|
<script lang="ts" module>
|
2
|
-
import type {HtmlProps} from '../types.js';
|
2
|
+
import type {AsChild, HtmlProps} from '../types.js';
|
3
3
|
|
4
|
-
export interface DatePickerClearTriggerProps extends HtmlProps<'button'> {
|
4
|
+
export interface DatePickerClearTriggerProps extends HtmlProps<'button'> {
|
5
|
+
asChild?: AsChild<HtmlProps<'button'>>;
|
6
|
+
}
|
5
7
|
</script>
|
6
8
|
|
7
9
|
<script lang="ts">
|
8
|
-
import {mergeProps} from '
|
10
|
+
import {mergeProps} from '../utils.svelte.js';
|
9
11
|
import {datePickerContext} from './context.svelte.js';
|
10
12
|
|
11
|
-
let {children, ...props}: DatePickerClearTriggerProps = $props();
|
13
|
+
let {asChild, children, ...props}: DatePickerClearTriggerProps = $props();
|
12
14
|
|
13
15
|
let datePicker = datePickerContext.get();
|
14
16
|
|
15
17
|
let attrs = $derived(mergeProps(props, datePicker.getClearTriggerProps()));
|
16
18
|
</script>
|
17
19
|
|
18
|
-
|
19
|
-
{@render
|
20
|
-
|
20
|
+
{#if asChild}
|
21
|
+
{@render asChild(attrs)}
|
22
|
+
{:else}
|
23
|
+
<button type="button" {...attrs}>
|
24
|
+
{@render children?.()}
|
25
|
+
</button>
|
26
|
+
{/if}
|
@@ -1,20 +1,26 @@
|
|
1
1
|
<script lang="ts" module>
|
2
|
-
import type {HtmlProps} from '../types.js';
|
2
|
+
import type {AsChild, HtmlProps} from '../types.js';
|
3
3
|
|
4
|
-
export interface DatePickerContentProps extends HtmlProps<'div'> {
|
4
|
+
export interface DatePickerContentProps extends HtmlProps<'div'> {
|
5
|
+
asChild?: AsChild;
|
6
|
+
}
|
5
7
|
</script>
|
6
8
|
|
7
9
|
<script lang="ts">
|
8
|
-
import {mergeProps} from '
|
10
|
+
import {mergeProps} from '../utils.svelte.js';
|
9
11
|
import {datePickerContext} from './context.svelte.js';
|
10
12
|
|
11
|
-
let {children, ...props}: DatePickerContentProps = $props();
|
13
|
+
let {asChild, children, ...props}: DatePickerContentProps = $props();
|
12
14
|
|
13
15
|
let datePicker = datePickerContext.get();
|
14
16
|
|
15
17
|
let attrs = $derived(mergeProps(props, datePicker.getContentProps()));
|
16
18
|
</script>
|
17
19
|
|
18
|
-
|
19
|
-
{@render
|
20
|
-
|
20
|
+
{#if asChild}
|
21
|
+
{@render asChild(attrs)}
|
22
|
+
{:else}
|
23
|
+
<div {...attrs}>
|
24
|
+
{@render children?.()}
|
25
|
+
</div>
|
26
|
+
{/if}
|
@@ -1,20 +1,26 @@
|
|
1
1
|
<script lang="ts" module>
|
2
|
-
import type {HtmlProps} from '../types.js';
|
2
|
+
import type {AsChild, HtmlProps} from '../types.js';
|
3
3
|
|
4
|
-
export interface DatePickerControlProps extends HtmlProps<'div'> {
|
4
|
+
export interface DatePickerControlProps extends HtmlProps<'div'> {
|
5
|
+
asChild?: AsChild;
|
6
|
+
}
|
5
7
|
</script>
|
6
8
|
|
7
9
|
<script lang="ts">
|
8
|
-
import {mergeProps} from '
|
10
|
+
import {mergeProps} from '../utils.svelte.js';
|
9
11
|
import {datePickerContext} from './context.svelte.js';
|
10
12
|
|
11
|
-
let {children, ...props}: DatePickerControlProps = $props();
|
13
|
+
let {asChild, children, ...props}: DatePickerControlProps = $props();
|
12
14
|
|
13
15
|
let datePicker = datePickerContext.get();
|
14
16
|
|
15
17
|
let attrs = $derived(mergeProps(props, datePicker.getControlProps()));
|
16
18
|
</script>
|
17
19
|
|
18
|
-
|
19
|
-
{@render
|
20
|
-
|
20
|
+
{#if asChild}
|
21
|
+
{@render asChild(attrs)}
|
22
|
+
{:else}
|
23
|
+
<div {...attrs}>
|
24
|
+
{@render children?.()}
|
25
|
+
</div>
|
26
|
+
{/if}
|
@@ -1,3 +1,4 @@
|
|
1
|
+
import type { GenericHtmlProps } from '../types.js';
|
1
2
|
import * as datePicker from '@zag-js/date-picker';
|
2
3
|
type Omitted = 'id' | 'dir' | 'min' | 'max' | 'value' | 'focusedValue' | 'getRootNode' | 'open.controlled';
|
3
4
|
export interface CreateDatePickerProps extends Omit<datePicker.Context, Omitted> {
|
@@ -9,6 +10,7 @@ export interface CreateDatePickerProps extends Omit<datePicker.Context, Omitted>
|
|
9
10
|
defaultOpen?: boolean;
|
10
11
|
}
|
11
12
|
export interface CreateDatePickerReturn extends datePicker.Api {
|
13
|
+
getViewProps(props: datePicker.ViewProps): GenericHtmlProps;
|
12
14
|
}
|
13
15
|
export declare function createDatePicker(props: CreateDatePickerProps): CreateDatePickerReturn;
|
14
16
|
export {};
|
@@ -19,6 +19,16 @@ export function createDatePicker(props) {
|
|
19
19
|
locale: props.locale ?? locale?.locale,
|
20
20
|
getRootNode: environment?.getRootNode,
|
21
21
|
}));
|
22
|
-
const api = $derived(reflect(() =>
|
22
|
+
const api = $derived(reflect(() => {
|
23
|
+
const o = datePicker.connect(state, send, normalizeProps);
|
24
|
+
return {
|
25
|
+
...o,
|
26
|
+
getViewProps(props) {
|
27
|
+
return {
|
28
|
+
hidden: o.view !== props.view,
|
29
|
+
};
|
30
|
+
},
|
31
|
+
};
|
32
|
+
}));
|
23
33
|
return api;
|
24
34
|
}
|
@@ -1,14 +1,16 @@
|
|
1
1
|
<script lang="ts" module>
|
2
|
-
import type {HtmlProps} from '../types.js';
|
2
|
+
import type {AsChild, HtmlProps} from '../types.js';
|
3
3
|
|
4
|
-
export interface DatePickerDayTableCellTriggerProps extends HtmlProps<'button'> {
|
4
|
+
export interface DatePickerDayTableCellTriggerProps extends HtmlProps<'button'> {
|
5
|
+
asChild?: AsChild<HtmlProps<'button'>>;
|
6
|
+
}
|
5
7
|
</script>
|
6
8
|
|
7
9
|
<script lang="ts">
|
8
|
-
import {mergeProps} from '
|
10
|
+
import {mergeProps} from '../utils.svelte.js';
|
9
11
|
import {datePickerContext, datePickerDayTableCellPropsContext} from './context.svelte.js';
|
10
12
|
|
11
|
-
let {children, ...props}: DatePickerDayTableCellTriggerProps = $props();
|
13
|
+
let {asChild, children, ...props}: DatePickerDayTableCellTriggerProps = $props();
|
12
14
|
|
13
15
|
let datePicker = datePickerContext.get();
|
14
16
|
let tableCellProps = datePickerDayTableCellPropsContext.get();
|
@@ -16,6 +18,10 @@
|
|
16
18
|
let attrs = $derived(mergeProps(props, datePicker.getDayTableCellTriggerProps(tableCellProps)));
|
17
19
|
</script>
|
18
20
|
|
19
|
-
|
20
|
-
{@render
|
21
|
-
|
21
|
+
{#if asChild}
|
22
|
+
{@render asChild(attrs)}
|
23
|
+
{:else}
|
24
|
+
<button type="button" {...attrs}>
|
25
|
+
{@render children?.()}
|
26
|
+
</button>
|
27
|
+
{/if}
|
@@ -1,26 +1,21 @@
|
|
1
1
|
<script lang="ts" module>
|
2
|
-
import type {Assign, HtmlProps} from '../types.js';
|
2
|
+
import type {AsChild, Assign, GenericHtmlProps, HtmlProps} from '../types.js';
|
3
3
|
import type {DayTableCellProps, DayTableCellState} from '@zag-js/date-picker';
|
4
4
|
import type {Snippet} from 'svelte';
|
5
5
|
|
6
6
|
export interface DatePickerDayTableCellProps
|
7
|
-
extends Assign<Omit<HtmlProps<'
|
7
|
+
extends Assign<Omit<HtmlProps<'td'>, 'children'>, DayTableCellProps> {
|
8
|
+
asChild?: AsChild<GenericHtmlProps, DayTableCellState>;
|
8
9
|
children?: Snippet<[state: DayTableCellState]>;
|
9
10
|
}
|
10
11
|
</script>
|
11
12
|
|
12
13
|
<script lang="ts">
|
13
|
-
import {mergeProps} from '
|
14
|
+
import {mergeProps} from '../utils.svelte.js';
|
14
15
|
import {datePickerContext, datePickerDayTableCellPropsContext} from './context.svelte.js';
|
15
16
|
|
16
|
-
let {
|
17
|
-
|
18
|
-
value,
|
19
|
-
disabled,
|
20
|
-
visibleRange,
|
21
|
-
children,
|
22
|
-
...props
|
23
|
-
}: DatePickerDayTableCellProps = $props();
|
17
|
+
let {value, disabled, visibleRange, asChild, children, ...props}: DatePickerDayTableCellProps =
|
18
|
+
$props();
|
24
19
|
|
25
20
|
let datePicker = datePickerContext.get();
|
26
21
|
let tableCellProps: DayTableCellProps = $derived({
|
@@ -35,6 +30,10 @@
|
|
35
30
|
datePickerDayTableCellPropsContext.set(() => tableCellProps);
|
36
31
|
</script>
|
37
32
|
|
38
|
-
|
39
|
-
{@render
|
40
|
-
|
33
|
+
{#if asChild}
|
34
|
+
{@render asChild(attrs, state)}
|
35
|
+
{:else}
|
36
|
+
<td {...attrs}>
|
37
|
+
{@render children?.(state)}
|
38
|
+
</td>
|
39
|
+
{/if}
|