bits-ui 1.1.0 → 1.2.1

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.
Files changed (38) hide show
  1. package/dist/bits/context-menu/components/context-menu-content-static.svelte +2 -0
  2. package/dist/bits/context-menu/components/context-menu-content.svelte +2 -0
  3. package/dist/bits/date-range-field/date-range-field.svelte.d.ts +0 -7
  4. package/dist/bits/date-range-field/date-range-field.svelte.js +58 -52
  5. package/dist/bits/dialog/dialog.svelte.d.ts +1 -3
  6. package/dist/bits/dialog/dialog.svelte.js +0 -14
  7. package/dist/bits/dropdown-menu/components/dropdown-menu-content-static.svelte +2 -0
  8. package/dist/bits/dropdown-menu/components/dropdown-menu-content.svelte +2 -0
  9. package/dist/bits/link-preview/components/link-preview-content-static.svelte +7 -22
  10. package/dist/bits/link-preview/components/link-preview-content.svelte +7 -22
  11. package/dist/bits/link-preview/link-preview.svelte.d.ts +14 -1
  12. package/dist/bits/link-preview/link-preview.svelte.js +24 -0
  13. package/dist/bits/menu/components/menu-content-static.svelte +2 -0
  14. package/dist/bits/menu/components/menu-content.svelte +2 -0
  15. package/dist/bits/menu/menu.svelte.d.ts +3 -1
  16. package/dist/bits/menu/menu.svelte.js +3 -1
  17. package/dist/bits/menubar/components/menubar-content-static.svelte +1 -9
  18. package/dist/bits/menubar/components/menubar-content.svelte +1 -9
  19. package/dist/bits/menubar/menubar.svelte.d.ts +10 -4
  20. package/dist/bits/menubar/menubar.svelte.js +14 -12
  21. package/dist/bits/popover/components/popover-content-static.svelte +2 -7
  22. package/dist/bits/popover/components/popover-content.svelte +2 -6
  23. package/dist/bits/popover/popover.svelte.d.ts +8 -3
  24. package/dist/bits/popover/popover.svelte.js +11 -9
  25. package/dist/bits/progress/components/progress.svelte +2 -0
  26. package/dist/bits/progress/progress.svelte.d.ts +7 -5
  27. package/dist/bits/progress/progress.svelte.js +6 -5
  28. package/dist/bits/progress/types.d.ts +11 -2
  29. package/dist/bits/select/components/select-content-static.svelte +7 -30
  30. package/dist/bits/select/components/select-content.svelte +4 -27
  31. package/dist/bits/select/select.svelte.d.ts +17 -2
  32. package/dist/bits/select/select.svelte.js +30 -3
  33. package/dist/bits/select/types.d.ts +2 -2
  34. package/dist/bits/tooltip/components/tooltip-content-static.svelte +7 -23
  35. package/dist/bits/tooltip/components/tooltip-content.svelte +7 -22
  36. package/dist/bits/tooltip/tooltip.svelte.d.ts +14 -1
  37. package/dist/bits/tooltip/tooltip.svelte.js +31 -1
  38. package/package.json +1 -1
@@ -75,11 +75,18 @@ declare class TooltipTriggerState {
75
75
  onclick: () => void;
76
76
  };
77
77
  }
78
- type TooltipContentStateProps = WithRefProps;
78
+ type TooltipContentStateProps = WithRefProps & ReadableBoxedValues<{
79
+ onInteractOutside: (e: PointerEvent) => void;
80
+ onEscapeKeydown: (e: KeyboardEvent) => void;
81
+ }>;
79
82
  declare class TooltipContentState {
80
83
  readonly opts: TooltipContentStateProps;
81
84
  readonly root: TooltipRootState;
82
85
  constructor(opts: TooltipContentStateProps, root: TooltipRootState);
86
+ onInteractOutside: (e: PointerEvent) => void;
87
+ onEscapeKeydown: (e: KeyboardEvent) => void;
88
+ onOpenAutoFocus: (e: Event) => void;
89
+ onCloseAutoFocus: (e: Event) => void;
83
90
  snippetProps: {
84
91
  open: boolean;
85
92
  };
@@ -93,6 +100,12 @@ declare class TooltipContentState {
93
100
  };
94
101
  readonly "data-tooltip-content": "";
95
102
  };
103
+ popperProps: {
104
+ onInteractOutside: (e: PointerEvent) => void;
105
+ onEscapeKeydown: (e: KeyboardEvent) => void;
106
+ onOpenAutoFocus: (e: Event) => void;
107
+ onCloseAutoFocus: (e: Event) => void;
108
+ };
96
109
  }
97
110
  export declare function useTooltipProvider(props: TooltipProviderStateProps): TooltipProviderState;
98
111
  export declare function useTooltipRoot(props: TooltipRootStateProps): TooltipRootState;
@@ -2,7 +2,7 @@ import { box, executeCallbacks, onMountEffect, useRefById } from "svelte-toolbel
2
2
  import { on } from "svelte/events";
3
3
  import { Context, watch } from "runed";
4
4
  import { useTimeoutFn } from "../../internal/use-timeout-fn.svelte.js";
5
- import { isFocusVisible } from "../../internal/is.js";
5
+ import { isElement, isFocusVisible } from "../../internal/is.js";
6
6
  import { useGraceArea } from "../../internal/use-grace-area.svelte.js";
7
7
  import { getDataDisabled } from "../../internal/attrs.js";
8
8
  import { CustomEventDispatcher } from "../../internal/events.js";
@@ -224,6 +224,30 @@ class TooltipContentState {
224
224
  }
225
225
  }), TooltipOpenEvent.listen(window, this.root.handleClose)));
226
226
  }
227
+ onInteractOutside = (e) => {
228
+ if (isElement(e.target) &&
229
+ this.root.triggerNode?.contains(e.target) &&
230
+ this.root.disableCloseOnTriggerClick) {
231
+ e.preventDefault();
232
+ return;
233
+ }
234
+ this.opts.onInteractOutside.current(e);
235
+ if (e.defaultPrevented)
236
+ return;
237
+ this.root.handleClose();
238
+ };
239
+ onEscapeKeydown = (e) => {
240
+ this.opts.onEscapeKeydown.current?.(e);
241
+ if (e.defaultPrevented)
242
+ return;
243
+ this.root.handleClose();
244
+ };
245
+ onOpenAutoFocus = (e) => {
246
+ e.preventDefault();
247
+ };
248
+ onCloseAutoFocus = (e) => {
249
+ e.preventDefault();
250
+ };
227
251
  snippetProps = $derived.by(() => ({ open: this.root.opts.open.current }));
228
252
  props = $derived.by(() => ({
229
253
  id: this.opts.id.current,
@@ -235,6 +259,12 @@ class TooltipContentState {
235
259
  },
236
260
  [TOOLTIP_CONTENT_ATTR]: "",
237
261
  }));
262
+ popperProps = {
263
+ onInteractOutside: this.onInteractOutside,
264
+ onEscapeKeydown: this.onEscapeKeydown,
265
+ onOpenAutoFocus: this.onOpenAutoFocus,
266
+ onCloseAutoFocus: this.onCloseAutoFocus,
267
+ };
238
268
  }
239
269
  //
240
270
  // CONTEXT METHODS
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "bits-ui",
3
- "version": "1.1.0",
3
+ "version": "1.2.1",
4
4
  "license": "MIT",
5
5
  "repository": "github:huntabyte/bits-ui",
6
6
  "funding": "https://github.com/sponsors/huntabyte",