@radix-ui/react-tooltip 0.1.8-rc.34 → 0.1.8-rc.35
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.
- package/dist/index.d.ts +12 -5
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +30 -5
- package/dist/index.js.map +1 -1
- package/dist/index.module.js +33 -8
- package/dist/index.module.js.map +1 -1
- package/package.json +12 -12
package/dist/index.d.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import * as React from "react";
|
|
2
2
|
import { DismissableLayer } from "@radix-ui/react-dismissable-layer";
|
|
3
3
|
import * as PopperPrimitive from "@radix-ui/react-popper";
|
|
4
|
+
import { UnstablePortal } from "@radix-ui/react-portal";
|
|
4
5
|
import * as Radix from "@radix-ui/react-primitive";
|
|
5
6
|
import { Primitive } from "@radix-ui/react-primitive";
|
|
6
7
|
export const createTooltipScope: import("@radix-ui/react-context").CreateScope;
|
|
@@ -35,6 +36,16 @@ type PrimitiveButtonProps = Radix.ComponentPropsWithoutRef<typeof Primitive.butt
|
|
|
35
36
|
export interface TooltipTriggerProps extends PrimitiveButtonProps {
|
|
36
37
|
}
|
|
37
38
|
export const TooltipTrigger: React.ForwardRefExoticComponent<TooltipTriggerProps & React.RefAttributes<HTMLButtonElement>>;
|
|
39
|
+
type PortalProps = React.ComponentPropsWithoutRef<typeof UnstablePortal>;
|
|
40
|
+
export interface TooltipPortalProps extends Omit<PortalProps, 'asChild'> {
|
|
41
|
+
children?: React.ReactNode;
|
|
42
|
+
/**
|
|
43
|
+
* Used to force mounting when more control is needed. Useful when
|
|
44
|
+
* controlling animation with React animation libraries.
|
|
45
|
+
*/
|
|
46
|
+
forceMount?: true;
|
|
47
|
+
}
|
|
48
|
+
export const TooltipPortal: React.FC<TooltipPortalProps>;
|
|
38
49
|
export interface TooltipContentProps extends TooltipContentImplProps {
|
|
39
50
|
/**
|
|
40
51
|
* Used to force mounting when more control is needed. Useful when
|
|
@@ -60,11 +71,6 @@ interface TooltipContentImplProps extends PopperContentProps {
|
|
|
60
71
|
* Can be prevented.
|
|
61
72
|
*/
|
|
62
73
|
onPointerDownOutside?: DismissableLayerProps['onPointerDownOutside'];
|
|
63
|
-
/**
|
|
64
|
-
* Whether the Tooltip should render in a Portal
|
|
65
|
-
* (default: `true`)
|
|
66
|
-
*/
|
|
67
|
-
portalled?: boolean;
|
|
68
74
|
}
|
|
69
75
|
type PopperArrowProps = Radix.ComponentPropsWithoutRef<typeof PopperPrimitive.Arrow>;
|
|
70
76
|
export interface TooltipArrowProps extends PopperArrowProps {
|
|
@@ -73,6 +79,7 @@ export const TooltipArrow: React.ForwardRefExoticComponent<TooltipArrowProps & R
|
|
|
73
79
|
export const Provider: React.FC<TooltipProviderProps>;
|
|
74
80
|
export const Root: React.FC<TooltipProps>;
|
|
75
81
|
export const Trigger: React.ForwardRefExoticComponent<TooltipTriggerProps & React.RefAttributes<HTMLButtonElement>>;
|
|
82
|
+
export const Portal: React.FC<TooltipPortalProps>;
|
|
76
83
|
export const Content: React.ForwardRefExoticComponent<TooltipContentProps & React.RefAttributes<HTMLDivElement>>;
|
|
77
84
|
export const Arrow: React.ForwardRefExoticComponent<TooltipArrowProps & React.RefAttributes<SVGSVGElement>>;
|
|
78
85
|
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"mappings":"
|
|
1
|
+
{"mappings":";;;;;;AAmBA,OAAA,yFAEE,CAAC;AA0BH;IACE,QAAQ,EAAE,MAAM,SAAS,CAAC;IAC1B;;;OAGG;IACH,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB;;;OAGG;IACH,iBAAiB,CAAC,EAAE,MAAM,CAAC;CAC5B;AAED,OAAA,MAAM,iBAAiB,MAAM,EAAE,CAAC,oBAAoB,CAqCnD,CAAC;AAwBF;IACE,QAAQ,CAAC,EAAE,MAAM,SAAS,CAAC;IAC3B,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,YAAY,CAAC,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAC;IAEvC;;;;OAIG;IACH,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB;AAED,OAAA,MAAM,SAAS,MAAM,EAAE,CAAC,YAAY,CA+EnC,CAAC;AAWF,4BAA4B,MAAM,wBAAwB,CAAC,OAAO,UAAU,MAAM,CAAC,CAAC;AACpF,oCAA8B,SAAQ,oBAAoB;CAAG;AAE7D,OAAA,MAAM,6GA4CL,CAAC;AAeF,mBAAmB,MAAM,wBAAwB,CAAC,qBAAqB,CAAC,CAAC;AACzE,mCAA6B,SAAQ,IAAI,CAAC,WAAW,EAAE,SAAS,CAAC;IAC/D,QAAQ,CAAC,EAAE,MAAM,SAAS,CAAC;IAC3B;;;OAGG;IACH,UAAU,CAAC,EAAE,IAAI,CAAC;CACnB;AAED,OAAA,MAAM,eAAe,MAAM,EAAE,CAAC,kBAAkB,CAY/C,CAAC;AAWF,oCAA8B,SAAQ,uBAAuB;IAC3D;;;OAGG;IACH,UAAU,CAAC,EAAE,IAAI,CAAC;CACnB;AAED,OAAA,MAAM,0GAWL,CAAC;AAGF,6BAA6B,MAAM,wBAAwB,CAAC,uBAAuB,CAAC,CAAC;AACrF,0BAA0B,MAAM,wBAAwB,CAAC,OAAO,gBAAgB,OAAO,CAAC,CAAC;AACzF,iCAAkC,SAAQ,kBAAkB;IAC1D;;OAEG;IACH,YAAY,CAAC,EAAE,MAAM,CAAC;IAEtB;;;OAGG;IACH,eAAe,CAAC,EAAE,qBAAqB,CAAC,iBAAiB,CAAC,CAAC;IAC3D;;;OAGG;IACH,oBAAoB,CAAC,EAAE,qBAAqB,CAAC,sBAAsB,CAAC,CAAC;CACtE;AA0ED,wBAAwB,MAAM,wBAAwB,CAAC,OAAO,gBAAgB,KAAK,CAAC,CAAC;AACrF,kCAA4B,SAAQ,gBAAgB;CAAG;AAEvD,OAAA,MAAM,qGAML,CAAC;AAMF,OAAA,MAAM,wCAA0B,CAAC;AACjC,OAAA,MAAM,4BAAc,CAAC;AACrB,OAAA,MAAM,sGAAwB,CAAC;AAC/B,OAAA,MAAM,oCAAsB,CAAC;AAC7B,OAAA,MAAM,mGAAwB,CAAC;AAC/B,OAAA,MAAM,8FAAoB,CAAC","sources":["packages/react/tooltip/src/packages/react/tooltip/src/Tooltip.tsx","packages/react/tooltip/src/packages/react/tooltip/src/index.ts","packages/react/tooltip/src/index.ts"],"sourcesContent":[null,null,"export * from './Tooltip';\n"],"names":[],"version":3,"file":"index.d.ts.map"}
|
package/dist/index.js
CHANGED
|
@@ -41,11 +41,13 @@ $parcel$export($c34afbc43c90cc6f$exports, "createTooltipScope", () => $c34afbc43
|
|
|
41
41
|
$parcel$export($c34afbc43c90cc6f$exports, "TooltipProvider", () => $c34afbc43c90cc6f$export$f78649fb9ca566b8);
|
|
42
42
|
$parcel$export($c34afbc43c90cc6f$exports, "Tooltip", () => $c34afbc43c90cc6f$export$28c660c63b792dea);
|
|
43
43
|
$parcel$export($c34afbc43c90cc6f$exports, "TooltipTrigger", () => $c34afbc43c90cc6f$export$8c610744efcf8a1d);
|
|
44
|
+
$parcel$export($c34afbc43c90cc6f$exports, "TooltipPortal", () => $c34afbc43c90cc6f$export$7b36b8f925ab7497);
|
|
44
45
|
$parcel$export($c34afbc43c90cc6f$exports, "TooltipContent", () => $c34afbc43c90cc6f$export$e9003e2be37ec060);
|
|
45
46
|
$parcel$export($c34afbc43c90cc6f$exports, "TooltipArrow", () => $c34afbc43c90cc6f$export$c27ee0ad710f7559);
|
|
46
47
|
$parcel$export($c34afbc43c90cc6f$exports, "Provider", () => $c34afbc43c90cc6f$export$2881499e37b75b9a);
|
|
47
48
|
$parcel$export($c34afbc43c90cc6f$exports, "Root", () => $c34afbc43c90cc6f$export$be92b6f5f03c0fe9);
|
|
48
49
|
$parcel$export($c34afbc43c90cc6f$exports, "Trigger", () => $c34afbc43c90cc6f$export$41fb9f06171c75f4);
|
|
50
|
+
$parcel$export($c34afbc43c90cc6f$exports, "Portal", () => $c34afbc43c90cc6f$export$602eac185826482c);
|
|
49
51
|
$parcel$export($c34afbc43c90cc6f$exports, "Content", () => $c34afbc43c90cc6f$export$7c6e2c02157bb7d2);
|
|
50
52
|
$parcel$export($c34afbc43c90cc6f$exports, "Arrow", () => $c34afbc43c90cc6f$export$21b07c8f274aebd5);
|
|
51
53
|
|
|
@@ -245,11 +247,34 @@ const $c34afbc43c90cc6f$export$8c610744efcf8a1d = /*#__PURE__*/ $iVrL9$react.for
|
|
|
245
247
|
/*#__PURE__*/ Object.assign($c34afbc43c90cc6f$export$8c610744efcf8a1d, {
|
|
246
248
|
displayName: $c34afbc43c90cc6f$var$TRIGGER_NAME
|
|
247
249
|
});
|
|
250
|
+
/* -------------------------------------------------------------------------------------------------
|
|
251
|
+
* TooltipPortal
|
|
252
|
+
* -----------------------------------------------------------------------------------------------*/ const $c34afbc43c90cc6f$var$PORTAL_NAME = 'TooltipPortal';
|
|
253
|
+
const [$c34afbc43c90cc6f$var$PortalProvider, $c34afbc43c90cc6f$var$usePortalContext] = $c34afbc43c90cc6f$var$createTooltipContext($c34afbc43c90cc6f$var$PORTAL_NAME, {
|
|
254
|
+
forceMount: undefined
|
|
255
|
+
});
|
|
256
|
+
const $c34afbc43c90cc6f$export$7b36b8f925ab7497 = (props)=>{
|
|
257
|
+
const { __scopeTooltip: __scopeTooltip , forceMount: forceMount , children: children , container: container } = props;
|
|
258
|
+
const context = $c34afbc43c90cc6f$var$useTooltipContext($c34afbc43c90cc6f$var$PORTAL_NAME, __scopeTooltip);
|
|
259
|
+
return /*#__PURE__*/ $iVrL9$react.createElement($c34afbc43c90cc6f$var$PortalProvider, {
|
|
260
|
+
scope: __scopeTooltip,
|
|
261
|
+
forceMount: forceMount
|
|
262
|
+
}, /*#__PURE__*/ $iVrL9$react.createElement($iVrL9$radixuireactpresence.Presence, {
|
|
263
|
+
present: forceMount || context.open
|
|
264
|
+
}, /*#__PURE__*/ $iVrL9$react.createElement($iVrL9$radixuireactportal.UnstablePortal, {
|
|
265
|
+
asChild: true,
|
|
266
|
+
container: container
|
|
267
|
+
}, children)));
|
|
268
|
+
};
|
|
269
|
+
/*#__PURE__*/ Object.assign($c34afbc43c90cc6f$export$7b36b8f925ab7497, {
|
|
270
|
+
displayName: $c34afbc43c90cc6f$var$PORTAL_NAME
|
|
271
|
+
});
|
|
248
272
|
/* -------------------------------------------------------------------------------------------------
|
|
249
273
|
* TooltipContent
|
|
250
274
|
* -----------------------------------------------------------------------------------------------*/ const $c34afbc43c90cc6f$var$CONTENT_NAME = 'TooltipContent';
|
|
251
275
|
const $c34afbc43c90cc6f$export$e9003e2be37ec060 = /*#__PURE__*/ $iVrL9$react.forwardRef((props, forwardedRef)=>{
|
|
252
|
-
const
|
|
276
|
+
const portalContext = $c34afbc43c90cc6f$var$usePortalContext($c34afbc43c90cc6f$var$CONTENT_NAME, props.__scopeTooltip);
|
|
277
|
+
const { forceMount: forceMount = portalContext.forceMount , ...contentProps } = props;
|
|
253
278
|
const context = $c34afbc43c90cc6f$var$useTooltipContext($c34afbc43c90cc6f$var$CONTENT_NAME, props.__scopeTooltip);
|
|
254
279
|
return /*#__PURE__*/ $iVrL9$react.createElement($iVrL9$radixuireactpresence.Presence, {
|
|
255
280
|
present: forceMount || context.open
|
|
@@ -258,10 +283,9 @@ const $c34afbc43c90cc6f$export$e9003e2be37ec060 = /*#__PURE__*/ $iVrL9$react.for
|
|
|
258
283
|
}, contentProps)));
|
|
259
284
|
});
|
|
260
285
|
const $c34afbc43c90cc6f$var$TooltipContentImpl = /*#__PURE__*/ $iVrL9$react.forwardRef((props, forwardedRef)=>{
|
|
261
|
-
const { __scopeTooltip: __scopeTooltip , children: children , 'aria-label': ariaLabel ,
|
|
286
|
+
const { __scopeTooltip: __scopeTooltip , children: children , 'aria-label': ariaLabel , onEscapeKeyDown: onEscapeKeyDown , onPointerDownOutside: onPointerDownOutside , ...contentProps } = props;
|
|
262
287
|
const context = $c34afbc43c90cc6f$var$useTooltipContext($c34afbc43c90cc6f$var$CONTENT_NAME, __scopeTooltip);
|
|
263
288
|
const popperScope = $c34afbc43c90cc6f$var$usePopperScope(__scopeTooltip);
|
|
264
|
-
const PortalWrapper = portalled ? $iVrL9$radixuireactportal.Portal : $iVrL9$react.Fragment;
|
|
265
289
|
const { onClose: onClose } = context; // Close this tooltip if another one opens
|
|
266
290
|
$iVrL9$react.useEffect(()=>{
|
|
267
291
|
document.addEventListener($c34afbc43c90cc6f$var$TOOLTIP_OPEN, onClose);
|
|
@@ -288,7 +312,7 @@ const $c34afbc43c90cc6f$var$TooltipContentImpl = /*#__PURE__*/ $iVrL9$react.forw
|
|
|
288
312
|
context.trigger,
|
|
289
313
|
onClose
|
|
290
314
|
]);
|
|
291
|
-
return /*#__PURE__*/ $iVrL9$react.createElement(
|
|
315
|
+
return /*#__PURE__*/ $iVrL9$react.createElement($iVrL9$radixuireactdismissablelayer.DismissableLayer, {
|
|
292
316
|
asChild: true,
|
|
293
317
|
disableOutsidePointerEvents: false,
|
|
294
318
|
onEscapeKeyDown: onEscapeKeyDown,
|
|
@@ -308,7 +332,7 @@ const $c34afbc43c90cc6f$var$TooltipContentImpl = /*#__PURE__*/ $iVrL9$react.forw
|
|
|
308
332
|
}), /*#__PURE__*/ $iVrL9$react.createElement($iVrL9$radixuireactslot.Slottable, null, children), /*#__PURE__*/ $iVrL9$react.createElement($iVrL9$radixuireactvisuallyhidden.Root, {
|
|
309
333
|
id: context.contentId,
|
|
310
334
|
role: "tooltip"
|
|
311
|
-
}, ariaLabel || children)))
|
|
335
|
+
}, ariaLabel || children)));
|
|
312
336
|
});
|
|
313
337
|
/*#__PURE__*/ Object.assign($c34afbc43c90cc6f$export$e9003e2be37ec060, {
|
|
314
338
|
displayName: $c34afbc43c90cc6f$var$CONTENT_NAME
|
|
@@ -329,6 +353,7 @@ const $c34afbc43c90cc6f$export$c27ee0ad710f7559 = /*#__PURE__*/ $iVrL9$react.for
|
|
|
329
353
|
/* -----------------------------------------------------------------------------------------------*/ const $c34afbc43c90cc6f$export$2881499e37b75b9a = $c34afbc43c90cc6f$export$f78649fb9ca566b8;
|
|
330
354
|
const $c34afbc43c90cc6f$export$be92b6f5f03c0fe9 = $c34afbc43c90cc6f$export$28c660c63b792dea;
|
|
331
355
|
const $c34afbc43c90cc6f$export$41fb9f06171c75f4 = $c34afbc43c90cc6f$export$8c610744efcf8a1d;
|
|
356
|
+
const $c34afbc43c90cc6f$export$602eac185826482c = $c34afbc43c90cc6f$export$7b36b8f925ab7497;
|
|
332
357
|
const $c34afbc43c90cc6f$export$7c6e2c02157bb7d2 = $c34afbc43c90cc6f$export$e9003e2be37ec060;
|
|
333
358
|
const $c34afbc43c90cc6f$export$21b07c8f274aebd5 = $c34afbc43c90cc6f$export$c27ee0ad710f7559;
|
|
334
359
|
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;A;;;;;;;;;;;;;;;ACmBA,MAAM,CAACc,0CAAD,EAAuBC,yCAAvB,CAAA,GAA6CZ,6CAAkB,CAAC,SAAD,EAAY;IAC/EI,2CAD+E;CAAZ,CAArE,AAAA;AAGA,MAAMS,oCAAc,GAAGT,2CAAiB,EAAxC,AAAA;AAEA;;oGAEA,CAEA,MAAMU,mCAAa,GAAG,iBAAtB,AAAA;AACA,MAAMC,4CAAsB,GAAG,GAA/B,AAAA;AACA,MAAMC,kCAAY,GAAG,cAArB,AAAA;AASA,MAAM,CAACC,oDAAD,EAAiCC,+CAAjC,CAAA,GACJP,0CAAoB,CAA8BG,mCAA9B,EAA6C;IAC/DK,aAAa,EAAE,IADgD;IAE/DC,aAAa,EAAEL,4CAFgD;IAG/DM,MAAM,EAAE,IAAM,EAHiD;IAI/DC,OAAO,EAAE,IAAM,EAAfA;CAJkB,CADtB,AACmE;AAqBnE,MAAMC,yCAA+C,GACnDC,CAAAA,KADsD,GAEnD;IACH,MAAM,E,gBACJC,cADI,CAAA,iBAEJL,aAAa,GAAGL,4CAFZ,sBAGJW,iBAAiB,GAAG,GAHhB,G,UAIJC,QAAAA,CAAAA,EAJI,GAKFH,KALJ,AAAM;IAMN,MAAM,CAACL,aAAD,EAAgBS,gBAAhB,CAAA,GAAoC/B,qBAAA,CAAe,IAAf,CAA1C,AAAA;IACA,MAAMiC,iBAAiB,GAAGjC,mBAAA,CAAa,CAAb,CAA1B,AAAA;IAEAA,sBAAA,CAAgB,IAAM;QACpB,MAAMoC,cAAc,GAAGH,iBAAiB,CAACI,OAAzC,AAAA;QACA,OAAO,IAAMC,MAAM,CAACC,YAAP,CAAoBH,cAApB,CAAb;QAAA,CAAA;KAFF,EAGG,EAHH,CAGC,CAAA;IAED,OAAA,aACE,CAAA,0BAAA,CAAC,oDAAD,EADF;QAEI,KAAK,EAAER,cADT;QAEE,aAAa,EAAEN,aAFjB;QAGE,aAAa,EAAEC,aAHjB;QAIE,MAAM,EAAEvB,wBAAA,CAAkB,IAAM;YAC9BsC,MAAM,CAACC,YAAP,CAAoBN,iBAAiB,CAACI,OAAtC,CAAAC,CAAAA;YACAP,gBAAgB,CAAC,KAAD,CAAhB,CAAAA;SAFM,EAGL,EAHK,CAJV;QAQE,OAAO,EAAE/B,wBAAA,CAAkB,IAAM;YAC/BsC,MAAM,CAACC,YAAP,CAAoBN,iBAAiB,CAACI,OAAtC,CAAAC,CAAAA;YACAL,iBAAiB,CAACI,OAAlB,GAA4BC,MAAM,CAACG,UAAP,CAC1B,IAAMV,gBAAgB,CAAC,IAAD,CADI;YAAA,EAE1BF,iBAF0B,CAA5B,CAAAI;SAFO,EAMN;YAACJ,iBAAD;SANM,CAMR;KAdH,EAgBGC,QAhBH,CADF,CACE;CAlBJ,AAqCC;AAED,aAAA,CAAA,MAAA,CAAA,MAAA,CAAA,yCAAA,EAAA;IAAA,WAAA,EAAA,mCAAA;CAAA,CAAA,CAAA;AAEA;;oGAEA,CAEA,MAAMY,kCAAY,GAAG,SAArB,AAAA;AAaA,MAAM,CAACC,4CAAD,EAAyBC,uCAAzB,CAAA,GACJ9B,0CAAoB,CAAsB4B,kCAAtB,CADtB,AAAA;AAiBA,MAAMG,yCAA+B,GAAIlB,CAAAA,KAAD,GAAsC;IAC5E,MAAM,E,gBACJC,cADI,CAAA,E,UAEJE,QAFI,CAAA,EAGJgB,IAAI,EAAEC,QAHF,CAAA,eAIJC,WAAW,GAAG,KAJV,G,cAKJC,YALI,CAAA,EAMJ1B,aAAa,EAAE2B,iBAAf3B,CAAAA,EANI,GAOFI,KAPJ,AAAM;IAQN,MAAMwB,OAAO,GAAG9B,+CAAyB,CAACqB,kCAAD,EAAed,cAAf,CAAzC,AAAA;IACA,MAAMwB,WAAW,GAAGpC,oCAAc,CAACY,cAAD,CAAlC,AAAA;IACA,MAAM,CAACyB,OAAD,EAAUC,UAAV,CAAA,GAAwBtD,qBAAA,CAAyC,IAAzC,CAA9B,AAAA;IACA,MAAMuD,SAAS,GAAGlD,2BAAK,EAAvB,AAAA;IACA,MAAMmD,YAAY,GAAGxD,mBAAA,CAAa,CAAb,CAArB,AAAA;IACA,MAAMuB,aAAa,GAAG2B,iBAAH,KAAA,IAAA,IAAGA,iBAAH,KAAA,KAAA,CAAA,GAAGA,iBAAH,GAAwBC,OAAO,CAAC5B,aAAnD,AAAA;IACA,MAAMkC,iBAAiB,GAAGzD,mBAAA,CAAa,KAAb,CAA1B,AAAA;IACA,MAAM,E,QAAEwB,MAAF,CAAA,E,SAAUC,OAAAA,CAAAA,EAAV,GAAsB0B,OAA5B,AAAM;IACN,MAAM,CAACL,KAAI,GAAG,KAAR,EAAeY,OAAf,CAAA,GAA0B9C,4DAAoB,CAAC;QACnD+C,IAAI,EAAEZ,QAD6C;QAEnDa,WAAW,EAAEZ,WAFsC;QAGnDa,QAAQ,EAAGf,CAAAA,IAAD,GAAU;YAClB,IAAIA,IAAJ,EAAU;gBACR,0DAAA;gBACA,uDAAA;gBACA,EAAA;gBACA,uDAAA;gBACA,uDAAA;gBACAgB,QAAQ,CAACC,aAAT,CAAuB,IAAIC,WAAJ,CAAgB7C,kCAAhB,CAAvB,CAAA2C,CAAAA;gBACAtC,MAAM,EAANA,CAAAA;aACD;YACDyB,YAAY,KAAA,IAAZ,IAAAA,YAAY,KAAA,KAAA,CAAZ,IAAAA,YAAY,CAAGH,IAAH,CAAZ,CAAAG;SACD;KAdiD,CAApD,AAAqD;IAgBrD,MAAMgB,cAAc,GAAGjE,oBAAA,CAAc,IAAM;QACzC,OAAO8C,KAAI,GAAIW,iBAAiB,CAACpB,OAAlB,GAA4B,cAA5B,GAA6C,cAAjD,GAAmE,QAA9E,CAAA;KADqB,EAEpB;QAACS,KAAD;KAFoB,CAAvB,AAEC;IAED,MAAMqB,UAAU,GAAGnE,wBAAA,CAAkB,IAAM;QACzCsC,MAAM,CAACC,YAAP,CAAoBiB,YAAY,CAACnB,OAAjC,CAAAC,CAAAA;QACAmB,iBAAiB,CAACpB,OAAlB,GAA4B,KAA5B,CAAAoB;QACAC,OAAO,CAAC,IAAD,CAAP,CAAAA;KAHiB,EAIhB;QAACA,OAAD;KAJgB,CAAnB,AAIC;IAED,MAAMU,iBAAiB,GAAGpE,wBAAA,CAAkB,IAAM;QAChDsC,MAAM,CAACC,YAAP,CAAoBiB,YAAY,CAACnB,OAAjC,CAAAC,CAAAA;QACAkB,YAAY,CAACnB,OAAb,GAAuBC,MAAM,CAACG,UAAP,CAAkB,IAAM;YAC7CgB,iBAAiB,CAACpB,OAAlB,GAA4B,IAA5B,CAAAoB;YACAC,OAAO,CAAC,IAAD,CAAP,CAAAA;SAFqB,EAGpBnC,aAHoB,CAAvB,CAGC;KALuB,EAMvB;QAACA,aAAD;QAAgBmC,OAAhB;KANuB,CAA1B,AAMC;IAED1D,sBAAA,CAAgB,IAAM;QACpB,OAAO,IAAMsC,MAAM,CAACC,YAAP,CAAoBiB,YAAY,CAACnB,OAAjC,CAAb;QAAA,CAAA;KADF,EAEG,EAFH,CAEC,CAAA;IAED,OAAA,aACE,CAAA,0BAAA,CAAC,8BAAD,EAA0Be,WAA1B,EAAA,aACE,CAAA,0BAAA,CAAC,4CAAD,EAFJ;QAGM,KAAK,EAAExB,cADT;QAEE,SAAS,EAAE2B,SAFb;QAGE,IAAI,EAAET,KAHR;QAIE,cAAc,EAAEmB,cAJlB;QAKE,OAAO,EAAEZ,OALX;QAME,eAAe,EAAEC,UANnB;QAOE,cAAc,EAAEtD,wBAAA,CAAkB,IAAM;YACtC,IAAImD,OAAO,CAAC7B,aAAZ,EAA2B8C,iBAAiB,EAAA,CAA5C;iBACKD,UAAU,EADf,CAAA;SADc,EAGb;YAAChB,OAAO,CAAC7B,aAAT;YAAwB8C,iBAAxB;YAA2CD,UAA3C;SAHa,CAPlB;QAWE,MAAM,EAAEnE,wBAAA,CAAkBmE,UAAlB,EAA8B;YAACA,UAAD;SAA9B,CAXV;QAYE,OAAO,EAAEnE,wBAAA,CAAkB,IAAM;YAC/BsC,MAAM,CAACC,YAAP,CAAoBiB,YAAY,CAACnB,OAAjC,CAAAC,CAAAA;YACAoB,OAAO,CAAC,KAAD,CAAP,CAAAA;YACAjC,OAAO,EAAPA,CAAAA;SAHO,EAIN;YAACiC,OAAD;YAAUjC,OAAV;SAJM,CAIR;KAhBH,EAkBGK,QAlBH,CADF,CADF,CAEI;CAzDN,AA+EC;AAED,aAAA,CAAA,MAAA,CAAA,MAAA,CAAA,yCAAA,EAAA;IAAA,WAAA,EAAA,kCAAA;CAAA,CAAA,CAAA;AAEA;;oGAEA,CAEA,MAAMuC,kCAAY,GAAG,gBAArB,AAAA;AAMA,MAAMC,yCAAc,GAAA,aAAGtE,CAAAA,uBAAA,CACrB,CAAC2B,KAAD,EAA0C6C,YAA1C,GAA2D;IACzD,MAAM,E,gBAAE5C,cAAF,CAAA,EAAkB,GAAG6C,YAAH,EAAlB,GAAsC9C,KAA5C,AAAM;IACN,MAAMwB,OAAO,GAAGP,uCAAiB,CAACyB,kCAAD,EAAezC,cAAf,CAAjC,AAAA;IACA,MAAMwB,WAAW,GAAGpC,oCAAc,CAACY,cAAD,CAAlC,AAAA;IACA,MAAM8C,kBAAkB,GAAGxE,8CAAe,CAACsE,YAAD,EAAerB,OAAO,CAACwB,eAAvB,CAA1C,AAAA;IACA,MAAMC,gBAAgB,GAAG5E,mBAAA,CAAa,KAAb,CAAzB,AAAA;IACA,MAAM6E,eAAe,GAAG7E,wBAAA,CAAkB,IAAO4E,gBAAgB,CAACvC,OAAjB,GAA2B,KAApD;IAAA,EAA4D,EAA5D,CAAxB,AAAA;IAEArC,sBAAA,CAAgB,IAAM;QACpB,OAAO,IAAM8D,QAAQ,CAACgB,mBAAT,CAA6B,WAA7B,EAA0CD,eAA1C,CAAb;QAAA,CAAA;KADF,EAEG;QAACA,eAAD;KAFH,CAEC,CAAA;IAED,OAAA,aACE,CAAA,0BAAA,CAAC,gCAAD,EADF,2DAAA,CAAA;QAC0B,OAAO,EAAP,IAAA;KAAxB,EAAoCzB,WAApC,CAAA,EAAA,aACE,CAAA,0BAAA,CAAC,sCAAD,CAAW,MAAX,EADF,2DAAA,CAAA;QAEI,oFAAA;QACA,wEAAA;QACA,kBAAA,EAAkBD,OAAO,CAACL,IAAR,GAAeK,OAAO,CAACI,SAAvB,GAAmCwB,SAHvD;QAIE,YAAA,EAAY5B,OAAO,CAACc,cAApB;KAJF,EAKMQ,YALN,EAAA;QAME,GAAG,EAAEC,kBANP;QAOE,cAAc,EAAEzE,4CAAoB,CAAC0B,KAAK,CAACqD,cAAP,EAAwBC,CAAAA,KAAD,GAAW;YACpE,IAAIA,KAAK,CAACC,WAAN,KAAsB,OAA1B,EAAmC/B,OAAO,CAACgC,cAAR,EAAnC,CAAA;SADkC,CAPtC;QAUE,cAAc,EAAElF,4CAAoB,CAAC0B,KAAK,CAACyD,cAAP,EAAuBjC,OAAO,CAAC1B,OAA/B,CAVtC;QAWE,aAAa,EAAExB,4CAAoB,CAAC0B,KAAK,CAAC0D,aAAP,EAAsB,IAAM;YAC7DT,gBAAgB,CAACvC,OAAjB,GAA2B,IAA3B,CAAAuC;YACAd,QAAQ,CAACwB,gBAAT,CAA0B,WAA1B,EAAuCT,eAAvC,EAAwD;gBAAEU,IAAI,EAAE,IAANA;aAA1D,CAAwD,CAAA;SAFvB,CAXrC;QAeE,OAAO,EAAEtF,4CAAoB,CAAC0B,KAAK,CAAC6D,OAAP,EAAgB,IAAM;YACjD,IAAI,CAACZ,gBAAgB,CAACvC,OAAtB,EAA+Bc,OAAO,CAAC3B,MAAR,EAA/B,CAAA;SAD2B,CAf/B;QAkBE,MAAM,EAAEvB,4CAAoB,CAAC0B,KAAK,CAAC8D,MAAP,EAAetC,OAAO,CAAC1B,OAAvB,CAlB9B;QAmBE,OAAO,EAAExB,4CAAoB,CAAC0B,KAAK,CAAC+D,OAAP,EAAiBT,CAAAA,KAAD,GAAW;YACtD,0EAAA;YACA,mEAAA;YACA,MAAMU,eAAe,GAAGV,KAAK,CAACW,MAAN,KAAiB,CAAzC,AAAA;YACA,IAAID,eAAJ,EAAqBxC,OAAO,CAAC1B,OAAR,EAArB,CAAA;SAJ2B,CAK5B;KAxBH,CAAA,CADF,CADF,CAEI;CAfe,CAAvB,AA2CG;AAGH,aAAA,CAAA,MAAA,CAAA,MAAA,CAAA,yCAAA,EAAA;IAAA,WAAA,EAAA,kCAAA;CAAA,CAAA,CAAA;AAEA;;oGAEA,CAEA,MAAMoE,kCAAY,GAAG,gBAArB,AAAA;AAWA,MAAMC,yCAAc,GAAA,aAAG9F,CAAAA,uBAAA,CACrB,CAAC2B,KAAD,EAA0C6C,YAA1C,GAA2D;IACzD,MAAM,E,YAAEuB,UAAF,CAAA,EAAc,GAAGC,YAAH,EAAd,GAAkCrE,KAAxC,AAAM;IACN,MAAMwB,OAAO,GAAGP,uCAAiB,CAACiD,kCAAD,EAAelE,KAAK,CAACC,cAArB,CAAjC,AAAA;IACA,OAAA,aACE,CAAA,0BAAA,CAAC,oCAAD,EADF;QACY,OAAO,EAAEmE,UAAU,IAAI5C,OAAO,CAACL,IAA/B;KAAV,EAAA,aACE,CAAA,0BAAA,CAAC,wCAAD,EADF,2DAAA,CAAA;QACsB,GAAG,EAAE0B,YAAL;KAApB,EAA2CwB,YAA3C,CAAA,CADF,CADF,CAEI;CANe,CAAvB,AASG;AA8BH,MAAMC,wCAAkB,GAAA,aAAGjG,CAAAA,uBAAA,CACzB,CAAC2B,KAAD,EAA8C6C,YAA9C,GAA+D;IAC7D,MAAM,E,gBACJ5C,cADI,CAAA,E,UAEJE,QAFI,CAAA,EAGJ,YAAA,EAAcoE,SAHV,CAAA,aAIJC,SAAS,GAAG,IAJR,G,iBAKJC,eALI,CAAA,E,sBAMJC,oBANI,CAAA,EAOJ,GAAGL,YAAH,EAPI,GAQFrE,KARJ,AAAM;IASN,MAAMwB,OAAO,GAAGP,uCAAiB,CAACiD,kCAAD,EAAejE,cAAf,CAAjC,AAAA;IACA,MAAMwB,WAAW,GAAGpC,oCAAc,CAACY,cAAD,CAAlC,AAAA;IACA,MAAM0E,aAAa,GAAGH,SAAS,GAAG3F,gCAAH,GAAYR,qBAA3C,AAAA;IACA,MAAM,E,SAAEyB,OAAAA,CAAAA,EAAF,GAAc0B,OAApB,AAb6D,EAe7D,0CAFM;IAGNnD,sBAAA,CAAgB,IAAM;QACpB8D,QAAQ,CAACwB,gBAAT,CAA0BnE,kCAA1B,EAAwCM,OAAxC,CAAAqC,CAAAA;QACA,OAAO,IAAMA,QAAQ,CAACgB,mBAAT,CAA6B3D,kCAA7B,EAA2CM,OAA3C,CAAb;QAAA,CAAA;KAFF,EAGG;QAACA,OAAD;KAHH,CAAA,CAhB6D,CAqB7D,+CAFC;IAGDzB,sBAAA,CAAgB,IAAM;QACpB,IAAImD,OAAO,CAACE,OAAZ,EAAqB;YACnB,MAAMmD,YAAY,GAAIvB,CAAAA,KAAD,GAAkB;gBACrC,MAAMwB,MAAM,GAAGxB,KAAK,CAACwB,MAArB,AAAA;gBACA,IAAIA,MAAJ,KAAA,IAAA,IAAIA,MAAJ,KAAA,KAAA,CAAA,IAAIA,MAAM,CAAEC,QAAR,CAAiBvD,OAAO,CAACE,OAAzB,CAAJ,EAAuC5B,OAAO,EAA9C,CAAA;aAFF,AAGC;YACDa,MAAM,CAACgD,gBAAP,CAAwB,QAAxB,EAAkCkB,YAAlC,EAAgD;gBAAEG,OAAO,EAAE,IAATA;aAAlD,CAAgD,CAAA;YAChD,OAAO,IAAMrE,MAAM,CAACwC,mBAAP,CAA2B,QAA3B,EAAqC0B,YAArC,EAAmD;oBAAEG,OAAO,EAAE,IAATA;iBAArD,CAAb;YAAA,CAAgE;SACjE;KARH,EASG;QAACxD,OAAO,CAACE,OAAT;QAAkB5B,OAAlB;KATH,CASC,CAAA;IAED,OAAA,aACE,CAAA,0BAAA,CAAC,aAAD,EAAA,IAAA,EAAA,aACE,CAAA,0BAAA,CAAC,oDAAD,EAFJ;QAGM,OAAO,EAAA,IADT;QAEE,2BAA2B,EAAE,KAF/B;QAGE,eAAe,EAAE2E,eAHnB;QAIE,oBAAoB,EAAEC,oBAJxB;QAKE,cAAc,EAAGpB,CAAAA,KAAD,GAAWA,KAAK,CAAC2B,cAAN,EAL7B;QAAA;QAME,SAAS,EAAEnF,OAAX;KANF,EAAA,aAQE,CAAA,0BAAA,CAAC,iCAAD,EARF,2DAAA,CAAA;QASI,YAAA,EAAY0B,OAAO,CAACc,cAApB;KADF,EAEMb,WAFN,EAGM4C,YAHN,EAAA;QAIE,GAAG,EAAExB,YAJP;QAKE,KAAK,EAAE;YACL,GAAGwB,YAAY,CAACa,KADX;YAEL,+CAAA;YACA,CAAC,0CAAD,CAAA,EACE,sCADF;SAHK;KALT,CAAA,EAAA,aAYE,CAAA,0BAAA,CAAC,iCAAD,EAAA,IAAA,EAAY/E,QAAZ,CAZF,EAAA,aAaE,CAAA,0BAAA,CAAC,sCAAD,EAbF;QAagC,EAAE,EAAEqB,OAAO,CAACI,SAA1C;QAAqD,IAAI,EAAC,SAAL;KAArD,EACG2C,SAAS,IAAIpE,QADhB,CAbF,CARF,CADF,CADF,CAuBQ;CAzDe,CAA3B,AAgEG;AAGH,aAAA,CAAA,MAAA,CAAA,MAAA,CAAA,yCAAA,EAAA;IAAA,WAAA,EAAA,kCAAA;CAAA,CAAA,CAAA;AAEA;;oGAEA,CAEA,MAAMgF,gCAAU,GAAG,cAAnB,AAAA;AAMA,MAAMC,yCAAY,GAAA,aAAG/G,CAAAA,uBAAA,CACnB,CAAC2B,KAAD,EAAwC6C,YAAxC,GAAyD;IACvD,MAAM,E,gBAAE5C,cAAF,CAAA,EAAkB,GAAGoF,UAAH,EAAlB,GAAoCrF,KAA1C,AAAM;IACN,MAAMyB,WAAW,GAAGpC,oCAAc,CAACY,cAAD,CAAlC,AAAA;IACA,OAAA,aAAO,CAAA,0BAAA,CAAC,+BAAD,EAAA,2DAAA,CAAA,EAAA,EAA2BwB,WAA3B,EAA4C4D,UAA5C,EAAP;QAA+D,GAAG,EAAExC,YAAL;KAAxD,CAAA,CAAP,CAAO;CAJU,CAArB,AAKG;AAGH,aAAA,CAAA,MAAA,CAAA,MAAA,CAAA,yCAAA,EAAA;IAAA,WAAA,EAAA,gCAAA;CAAA,CAAA,CAAA;AAEA,oGAAA,CAEA,MAAMyC,yCAAQ,GAAGvF,yCAAjB,AAAA;AACA,MAAMwF,yCAAI,GAAGrE,yCAAb,AAAA;AACA,MAAMsE,yCAAO,GAAG7C,yCAAhB,AAAA;AACA,MAAM8C,yCAAO,GAAGtB,yCAAhB,AAAA;AACA,MAAMuB,yCAAK,GAAGN,yCAAd,AAAA;;AD1aA","sources":["packages/react/tooltip/src/index.ts","packages/react/tooltip/src/Tooltip.tsx"],"sourcesContent":["export * from './Tooltip';\n","import * as React from 'react';\nimport { composeEventHandlers } from '@radix-ui/primitive';\nimport { useComposedRefs } from '@radix-ui/react-compose-refs';\nimport { createContextScope } from '@radix-ui/react-context';\nimport { DismissableLayer } from '@radix-ui/react-dismissable-layer';\nimport { useId } from '@radix-ui/react-id';\nimport * as PopperPrimitive from '@radix-ui/react-popper';\nimport { createPopperScope } from '@radix-ui/react-popper';\nimport { Portal } from '@radix-ui/react-portal';\nimport { Presence } from '@radix-ui/react-presence';\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slottable } from '@radix-ui/react-slot';\nimport { useControllableState } from '@radix-ui/react-use-controllable-state';\nimport * as VisuallyHiddenPrimitive from '@radix-ui/react-visually-hidden';\n\nimport type * as Radix from '@radix-ui/react-primitive';\nimport type { Scope } from '@radix-ui/react-context';\n\ntype ScopedProps<P = {}> = P & { __scopeTooltip?: Scope };\nconst [createTooltipContext, createTooltipScope] = createContextScope('Tooltip', [\n createPopperScope,\n]);\nconst usePopperScope = createPopperScope();\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipProvider\n * -----------------------------------------------------------------------------------------------*/\n\nconst PROVIDER_NAME = 'TooltipProvider';\nconst DEFAULT_DELAY_DURATION = 700;\nconst TOOLTIP_OPEN = 'tooltip.open';\n\ntype TooltipProviderContextValue = {\n isOpenDelayed: boolean;\n delayDuration: number;\n onOpen(): void;\n onClose(): void;\n};\n\nconst [TooltipProviderContextProvider, useTooltipProviderContext] =\n createTooltipContext<TooltipProviderContextValue>(PROVIDER_NAME, {\n isOpenDelayed: true,\n delayDuration: DEFAULT_DELAY_DURATION,\n onOpen: () => {},\n onClose: () => {},\n });\n\ninterface TooltipProviderProps {\n children: React.ReactNode;\n /**\n * The duration from when the pointer enters the trigger until the tooltip gets opened.\n * @defaultValue 700\n */\n delayDuration?: number;\n /**\n * How much time a user has to enter another trigger without incurring a delay again.\n * @defaultValue 300\n */\n skipDelayDuration?: number;\n}\n\nconst TooltipProvider: React.FC<TooltipProviderProps> = (\n props: ScopedProps<TooltipProviderProps>\n) => {\n const {\n __scopeTooltip,\n delayDuration = DEFAULT_DELAY_DURATION,\n skipDelayDuration = 300,\n children,\n } = props;\n const [isOpenDelayed, setIsOpenDelayed] = React.useState(true);\n const skipDelayTimerRef = React.useRef(0);\n\n React.useEffect(() => {\n const skipDelayTimer = skipDelayTimerRef.current;\n return () => window.clearTimeout(skipDelayTimer);\n }, []);\n\n return (\n <TooltipProviderContextProvider\n scope={__scopeTooltip}\n isOpenDelayed={isOpenDelayed}\n delayDuration={delayDuration}\n onOpen={React.useCallback(() => {\n window.clearTimeout(skipDelayTimerRef.current);\n setIsOpenDelayed(false);\n }, [])}\n onClose={React.useCallback(() => {\n window.clearTimeout(skipDelayTimerRef.current);\n skipDelayTimerRef.current = window.setTimeout(\n () => setIsOpenDelayed(true),\n skipDelayDuration\n );\n }, [skipDelayDuration])}\n >\n {children}\n </TooltipProviderContextProvider>\n );\n};\n\nTooltipProvider.displayName = PROVIDER_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * Tooltip\n * -----------------------------------------------------------------------------------------------*/\n\nconst TOOLTIP_NAME = 'Tooltip';\n\ntype TooltipContextValue = {\n contentId: string;\n open: boolean;\n stateAttribute: 'closed' | 'delayed-open' | 'instant-open';\n trigger: TooltipTriggerElement | null;\n onTriggerChange(trigger: TooltipTriggerElement | null): void;\n onTriggerEnter(): void;\n onOpen(): void;\n onClose(): void;\n};\n\nconst [TooltipContextProvider, useTooltipContext] =\n createTooltipContext<TooltipContextValue>(TOOLTIP_NAME);\n\ninterface TooltipProps {\n children?: React.ReactNode;\n open?: boolean;\n defaultOpen?: boolean;\n onOpenChange?: (open: boolean) => void;\n\n /**\n * The duration from when the pointer enters the trigger until the tooltip gets opened. This will\n * override the prop with the same name passed to Provider.\n * @defaultValue 700\n */\n delayDuration?: number;\n}\n\nconst Tooltip: React.FC<TooltipProps> = (props: ScopedProps<TooltipProps>) => {\n const {\n __scopeTooltip,\n children,\n open: openProp,\n defaultOpen = false,\n onOpenChange,\n delayDuration: delayDurationProp,\n } = props;\n const context = useTooltipProviderContext(TOOLTIP_NAME, __scopeTooltip);\n const popperScope = usePopperScope(__scopeTooltip);\n const [trigger, setTrigger] = React.useState<HTMLButtonElement | null>(null);\n const contentId = useId();\n const openTimerRef = React.useRef(0);\n const delayDuration = delayDurationProp ?? context.delayDuration;\n const wasOpenDelayedRef = React.useRef(false);\n const { onOpen, onClose } = context;\n const [open = false, setOpen] = useControllableState({\n prop: openProp,\n defaultProp: defaultOpen,\n onChange: (open) => {\n if (open) {\n // we dispatch here so `TooltipProvider` isn't required to\n // ensure other tooltips are aware of this one opening.\n //\n // as `onChange` is called within a lifecycle method we\n // avoid dispatching via `dispatchDiscreteCustomEvent`.\n document.dispatchEvent(new CustomEvent(TOOLTIP_OPEN));\n onOpen();\n }\n onOpenChange?.(open);\n },\n });\n const stateAttribute = React.useMemo(() => {\n return open ? (wasOpenDelayedRef.current ? 'delayed-open' : 'instant-open') : 'closed';\n }, [open]);\n\n const handleOpen = React.useCallback(() => {\n window.clearTimeout(openTimerRef.current);\n wasOpenDelayedRef.current = false;\n setOpen(true);\n }, [setOpen]);\n\n const handleDelayedOpen = React.useCallback(() => {\n window.clearTimeout(openTimerRef.current);\n openTimerRef.current = window.setTimeout(() => {\n wasOpenDelayedRef.current = true;\n setOpen(true);\n }, delayDuration);\n }, [delayDuration, setOpen]);\n\n React.useEffect(() => {\n return () => window.clearTimeout(openTimerRef.current);\n }, []);\n\n return (\n <PopperPrimitive.Root {...popperScope}>\n <TooltipContextProvider\n scope={__scopeTooltip}\n contentId={contentId}\n open={open}\n stateAttribute={stateAttribute}\n trigger={trigger}\n onTriggerChange={setTrigger}\n onTriggerEnter={React.useCallback(() => {\n if (context.isOpenDelayed) handleDelayedOpen();\n else handleOpen();\n }, [context.isOpenDelayed, handleDelayedOpen, handleOpen])}\n onOpen={React.useCallback(handleOpen, [handleOpen])}\n onClose={React.useCallback(() => {\n window.clearTimeout(openTimerRef.current);\n setOpen(false);\n onClose();\n }, [setOpen, onClose])}\n >\n {children}\n </TooltipContextProvider>\n </PopperPrimitive.Root>\n );\n};\n\nTooltip.displayName = TOOLTIP_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipTrigger\n * -----------------------------------------------------------------------------------------------*/\n\nconst TRIGGER_NAME = 'TooltipTrigger';\n\ntype TooltipTriggerElement = React.ElementRef<typeof Primitive.button>;\ntype PrimitiveButtonProps = Radix.ComponentPropsWithoutRef<typeof Primitive.button>;\ninterface TooltipTriggerProps extends PrimitiveButtonProps {}\n\nconst TooltipTrigger = React.forwardRef<TooltipTriggerElement, TooltipTriggerProps>(\n (props: ScopedProps<TooltipTriggerProps>, forwardedRef) => {\n const { __scopeTooltip, ...triggerProps } = props;\n const context = useTooltipContext(TRIGGER_NAME, __scopeTooltip);\n const popperScope = usePopperScope(__scopeTooltip);\n const composedTriggerRef = useComposedRefs(forwardedRef, context.onTriggerChange);\n const isPointerDownRef = React.useRef(false);\n const handlePointerUp = React.useCallback(() => (isPointerDownRef.current = false), []);\n\n React.useEffect(() => {\n return () => document.removeEventListener('pointerup', handlePointerUp);\n }, [handlePointerUp]);\n\n return (\n <PopperPrimitive.Anchor asChild {...popperScope}>\n <Primitive.button\n // We purposefully avoid adding `type=button` here because tooltip triggers are also\n // commonly anchors and the anchor `type` attribute signifies MIME type.\n aria-describedby={context.open ? context.contentId : undefined}\n data-state={context.stateAttribute}\n {...triggerProps}\n ref={composedTriggerRef}\n onPointerEnter={composeEventHandlers(props.onPointerEnter, (event) => {\n if (event.pointerType !== 'touch') context.onTriggerEnter();\n })}\n onPointerLeave={composeEventHandlers(props.onPointerLeave, context.onClose)}\n onPointerDown={composeEventHandlers(props.onPointerDown, () => {\n isPointerDownRef.current = true;\n document.addEventListener('pointerup', handlePointerUp, { once: true });\n })}\n onFocus={composeEventHandlers(props.onFocus, () => {\n if (!isPointerDownRef.current) context.onOpen();\n })}\n onBlur={composeEventHandlers(props.onBlur, context.onClose)}\n onClick={composeEventHandlers(props.onClick, (event) => {\n // keyboard click will occur under different conditions for different node\n // types so we use `onClick` instead of `onKeyDown` to respect that\n const isKeyboardClick = event.detail === 0;\n if (isKeyboardClick) context.onClose();\n })}\n />\n </PopperPrimitive.Anchor>\n );\n }\n);\n\nTooltipTrigger.displayName = TRIGGER_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipContent\n * -----------------------------------------------------------------------------------------------*/\n\nconst CONTENT_NAME = 'TooltipContent';\n\ntype TooltipContentElement = TooltipContentImplElement;\ninterface TooltipContentProps extends TooltipContentImplProps {\n /**\n * Used to force mounting when more control is needed. Useful when\n * controlling animation with React animation libraries.\n */\n forceMount?: true;\n}\n\nconst TooltipContent = React.forwardRef<TooltipContentElement, TooltipContentProps>(\n (props: ScopedProps<TooltipContentProps>, forwardedRef) => {\n const { forceMount, ...contentProps } = props;\n const context = useTooltipContext(CONTENT_NAME, props.__scopeTooltip);\n return (\n <Presence present={forceMount || context.open}>\n <TooltipContentImpl ref={forwardedRef} {...contentProps} />\n </Presence>\n );\n }\n);\n\ntype TooltipContentImplElement = React.ElementRef<typeof PopperPrimitive.Content>;\ntype DismissableLayerProps = Radix.ComponentPropsWithoutRef<typeof DismissableLayer>;\ntype PopperContentProps = Radix.ComponentPropsWithoutRef<typeof PopperPrimitive.Content>;\ninterface TooltipContentImplProps extends PopperContentProps {\n /**\n * A more descriptive label for accessibility purpose\n */\n 'aria-label'?: string;\n\n /**\n * Event handler called when the escape key is down.\n * Can be prevented.\n */\n onEscapeKeyDown?: DismissableLayerProps['onEscapeKeyDown'];\n /**\n * Event handler called when the a `pointerdown` event happens outside of the `Tooltip`.\n * Can be prevented.\n */\n onPointerDownOutside?: DismissableLayerProps['onPointerDownOutside'];\n\n /**\n * Whether the Tooltip should render in a Portal\n * (default: `true`)\n */\n portalled?: boolean;\n}\n\nconst TooltipContentImpl = React.forwardRef<TooltipContentImplElement, TooltipContentImplProps>(\n (props: ScopedProps<TooltipContentImplProps>, forwardedRef) => {\n const {\n __scopeTooltip,\n children,\n 'aria-label': ariaLabel,\n portalled = true,\n onEscapeKeyDown,\n onPointerDownOutside,\n ...contentProps\n } = props;\n const context = useTooltipContext(CONTENT_NAME, __scopeTooltip);\n const popperScope = usePopperScope(__scopeTooltip);\n const PortalWrapper = portalled ? Portal : React.Fragment;\n const { onClose } = context;\n\n // Close this tooltip if another one opens\n React.useEffect(() => {\n document.addEventListener(TOOLTIP_OPEN, onClose);\n return () => document.removeEventListener(TOOLTIP_OPEN, onClose);\n }, [onClose]);\n\n // Close the tooltip if the trigger is scrolled\n React.useEffect(() => {\n if (context.trigger) {\n const handleScroll = (event: Event) => {\n const target = event.target as HTMLElement;\n if (target?.contains(context.trigger)) onClose();\n };\n window.addEventListener('scroll', handleScroll, { capture: true });\n return () => window.removeEventListener('scroll', handleScroll, { capture: true });\n }\n }, [context.trigger, onClose]);\n\n return (\n <PortalWrapper>\n <DismissableLayer\n asChild\n disableOutsidePointerEvents={false}\n onEscapeKeyDown={onEscapeKeyDown}\n onPointerDownOutside={onPointerDownOutside}\n onFocusOutside={(event) => event.preventDefault()}\n onDismiss={onClose}\n >\n <PopperPrimitive.Content\n data-state={context.stateAttribute}\n {...popperScope}\n {...contentProps}\n ref={forwardedRef}\n style={{\n ...contentProps.style,\n // re-namespace exposed content custom property\n ['--radix-tooltip-content-transform-origin' as any]:\n 'var(--radix-popper-transform-origin)',\n }}\n >\n <Slottable>{children}</Slottable>\n <VisuallyHiddenPrimitive.Root id={context.contentId} role=\"tooltip\">\n {ariaLabel || children}\n </VisuallyHiddenPrimitive.Root>\n </PopperPrimitive.Content>\n </DismissableLayer>\n </PortalWrapper>\n );\n }\n);\n\nTooltipContent.displayName = CONTENT_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipArrow\n * -----------------------------------------------------------------------------------------------*/\n\nconst ARROW_NAME = 'TooltipArrow';\n\ntype TooltipArrowElement = React.ElementRef<typeof PopperPrimitive.Arrow>;\ntype PopperArrowProps = Radix.ComponentPropsWithoutRef<typeof PopperPrimitive.Arrow>;\ninterface TooltipArrowProps extends PopperArrowProps {}\n\nconst TooltipArrow = React.forwardRef<TooltipArrowElement, TooltipArrowProps>(\n (props: ScopedProps<TooltipArrowProps>, forwardedRef) => {\n const { __scopeTooltip, ...arrowProps } = props;\n const popperScope = usePopperScope(__scopeTooltip);\n return <PopperPrimitive.Arrow {...popperScope} {...arrowProps} ref={forwardedRef} />;\n }\n);\n\nTooltipArrow.displayName = ARROW_NAME;\n\n/* -----------------------------------------------------------------------------------------------*/\n\nconst Provider = TooltipProvider;\nconst Root = Tooltip;\nconst Trigger = TooltipTrigger;\nconst Content = TooltipContent;\nconst Arrow = TooltipArrow;\n\nexport {\n createTooltipScope,\n //\n TooltipProvider,\n Tooltip,\n TooltipTrigger,\n TooltipContent,\n TooltipArrow,\n //\n Provider,\n Root,\n Trigger,\n Content,\n Arrow,\n};\nexport type { TooltipProps, TooltipTriggerProps, TooltipContentProps, TooltipArrowProps };\n"],"names":["React","composeEventHandlers","useComposedRefs","createContextScope","DismissableLayer","useId","PopperPrimitive","createPopperScope","Portal","Presence","Primitive","Slottable","useControllableState","VisuallyHiddenPrimitive","createTooltipContext","createTooltipScope","usePopperScope","PROVIDER_NAME","DEFAULT_DELAY_DURATION","TOOLTIP_OPEN","TooltipProviderContextProvider","useTooltipProviderContext","isOpenDelayed","delayDuration","onOpen","onClose","TooltipProvider","props","__scopeTooltip","skipDelayDuration","children","setIsOpenDelayed","useState","skipDelayTimerRef","useRef","useEffect","skipDelayTimer","current","window","clearTimeout","useCallback","setTimeout","TOOLTIP_NAME","TooltipContextProvider","useTooltipContext","Tooltip","open","openProp","defaultOpen","onOpenChange","delayDurationProp","context","popperScope","trigger","setTrigger","contentId","openTimerRef","wasOpenDelayedRef","setOpen","prop","defaultProp","onChange","document","dispatchEvent","CustomEvent","stateAttribute","useMemo","handleOpen","handleDelayedOpen","TRIGGER_NAME","TooltipTrigger","forwardRef","forwardedRef","triggerProps","composedTriggerRef","onTriggerChange","isPointerDownRef","handlePointerUp","removeEventListener","undefined","onPointerEnter","event","pointerType","onTriggerEnter","onPointerLeave","onPointerDown","addEventListener","once","onFocus","onBlur","onClick","isKeyboardClick","detail","CONTENT_NAME","TooltipContent","forceMount","contentProps","TooltipContentImpl","ariaLabel","portalled","onEscapeKeyDown","onPointerDownOutside","PortalWrapper","Fragment","handleScroll","target","contains","capture","preventDefault","style","ARROW_NAME","TooltipArrow","arrowProps","Provider","Root","Trigger","Content","Arrow"],"version":3,"file":"index.js.map"}
|
|
1
|
+
{"mappings":"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","sources":["packages/react/tooltip/src/index.ts","packages/react/tooltip/src/Tooltip.tsx"],"sourcesContent":["export * from './Tooltip';\n","import * as React from 'react';\nimport { composeEventHandlers } from '@radix-ui/primitive';\nimport { useComposedRefs } from '@radix-ui/react-compose-refs';\nimport { createContextScope } from '@radix-ui/react-context';\nimport { DismissableLayer } from '@radix-ui/react-dismissable-layer';\nimport { useId } from '@radix-ui/react-id';\nimport * as PopperPrimitive from '@radix-ui/react-popper';\nimport { createPopperScope } from '@radix-ui/react-popper';\nimport { UnstablePortal } from '@radix-ui/react-portal';\nimport { Presence } from '@radix-ui/react-presence';\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slottable } from '@radix-ui/react-slot';\nimport { useControllableState } from '@radix-ui/react-use-controllable-state';\nimport * as VisuallyHiddenPrimitive from '@radix-ui/react-visually-hidden';\n\nimport type * as Radix from '@radix-ui/react-primitive';\nimport type { Scope } from '@radix-ui/react-context';\n\ntype ScopedProps<P = {}> = P & { __scopeTooltip?: Scope };\nconst [createTooltipContext, createTooltipScope] = createContextScope('Tooltip', [\n createPopperScope,\n]);\nconst usePopperScope = createPopperScope();\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipProvider\n * -----------------------------------------------------------------------------------------------*/\n\nconst PROVIDER_NAME = 'TooltipProvider';\nconst DEFAULT_DELAY_DURATION = 700;\nconst TOOLTIP_OPEN = 'tooltip.open';\n\ntype TooltipProviderContextValue = {\n isOpenDelayed: boolean;\n delayDuration: number;\n onOpen(): void;\n onClose(): void;\n};\n\nconst [TooltipProviderContextProvider, useTooltipProviderContext] =\n createTooltipContext<TooltipProviderContextValue>(PROVIDER_NAME, {\n isOpenDelayed: true,\n delayDuration: DEFAULT_DELAY_DURATION,\n onOpen: () => {},\n onClose: () => {},\n });\n\ninterface TooltipProviderProps {\n children: React.ReactNode;\n /**\n * The duration from when the pointer enters the trigger until the tooltip gets opened.\n * @defaultValue 700\n */\n delayDuration?: number;\n /**\n * How much time a user has to enter another trigger without incurring a delay again.\n * @defaultValue 300\n */\n skipDelayDuration?: number;\n}\n\nconst TooltipProvider: React.FC<TooltipProviderProps> = (\n props: ScopedProps<TooltipProviderProps>\n) => {\n const {\n __scopeTooltip,\n delayDuration = DEFAULT_DELAY_DURATION,\n skipDelayDuration = 300,\n children,\n } = props;\n const [isOpenDelayed, setIsOpenDelayed] = React.useState(true);\n const skipDelayTimerRef = React.useRef(0);\n\n React.useEffect(() => {\n const skipDelayTimer = skipDelayTimerRef.current;\n return () => window.clearTimeout(skipDelayTimer);\n }, []);\n\n return (\n <TooltipProviderContextProvider\n scope={__scopeTooltip}\n isOpenDelayed={isOpenDelayed}\n delayDuration={delayDuration}\n onOpen={React.useCallback(() => {\n window.clearTimeout(skipDelayTimerRef.current);\n setIsOpenDelayed(false);\n }, [])}\n onClose={React.useCallback(() => {\n window.clearTimeout(skipDelayTimerRef.current);\n skipDelayTimerRef.current = window.setTimeout(\n () => setIsOpenDelayed(true),\n skipDelayDuration\n );\n }, [skipDelayDuration])}\n >\n {children}\n </TooltipProviderContextProvider>\n );\n};\n\nTooltipProvider.displayName = PROVIDER_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * Tooltip\n * -----------------------------------------------------------------------------------------------*/\n\nconst TOOLTIP_NAME = 'Tooltip';\n\ntype TooltipContextValue = {\n contentId: string;\n open: boolean;\n stateAttribute: 'closed' | 'delayed-open' | 'instant-open';\n trigger: TooltipTriggerElement | null;\n onTriggerChange(trigger: TooltipTriggerElement | null): void;\n onTriggerEnter(): void;\n onOpen(): void;\n onClose(): void;\n};\n\nconst [TooltipContextProvider, useTooltipContext] =\n createTooltipContext<TooltipContextValue>(TOOLTIP_NAME);\n\ninterface TooltipProps {\n children?: React.ReactNode;\n open?: boolean;\n defaultOpen?: boolean;\n onOpenChange?: (open: boolean) => void;\n\n /**\n * The duration from when the pointer enters the trigger until the tooltip gets opened. This will\n * override the prop with the same name passed to Provider.\n * @defaultValue 700\n */\n delayDuration?: number;\n}\n\nconst Tooltip: React.FC<TooltipProps> = (props: ScopedProps<TooltipProps>) => {\n const {\n __scopeTooltip,\n children,\n open: openProp,\n defaultOpen = false,\n onOpenChange,\n delayDuration: delayDurationProp,\n } = props;\n const context = useTooltipProviderContext(TOOLTIP_NAME, __scopeTooltip);\n const popperScope = usePopperScope(__scopeTooltip);\n const [trigger, setTrigger] = React.useState<HTMLButtonElement | null>(null);\n const contentId = useId();\n const openTimerRef = React.useRef(0);\n const delayDuration = delayDurationProp ?? context.delayDuration;\n const wasOpenDelayedRef = React.useRef(false);\n const { onOpen, onClose } = context;\n const [open = false, setOpen] = useControllableState({\n prop: openProp,\n defaultProp: defaultOpen,\n onChange: (open) => {\n if (open) {\n // we dispatch here so `TooltipProvider` isn't required to\n // ensure other tooltips are aware of this one opening.\n //\n // as `onChange` is called within a lifecycle method we\n // avoid dispatching via `dispatchDiscreteCustomEvent`.\n document.dispatchEvent(new CustomEvent(TOOLTIP_OPEN));\n onOpen();\n }\n onOpenChange?.(open);\n },\n });\n const stateAttribute = React.useMemo(() => {\n return open ? (wasOpenDelayedRef.current ? 'delayed-open' : 'instant-open') : 'closed';\n }, [open]);\n\n const handleOpen = React.useCallback(() => {\n window.clearTimeout(openTimerRef.current);\n wasOpenDelayedRef.current = false;\n setOpen(true);\n }, [setOpen]);\n\n const handleDelayedOpen = React.useCallback(() => {\n window.clearTimeout(openTimerRef.current);\n openTimerRef.current = window.setTimeout(() => {\n wasOpenDelayedRef.current = true;\n setOpen(true);\n }, delayDuration);\n }, [delayDuration, setOpen]);\n\n React.useEffect(() => {\n return () => window.clearTimeout(openTimerRef.current);\n }, []);\n\n return (\n <PopperPrimitive.Root {...popperScope}>\n <TooltipContextProvider\n scope={__scopeTooltip}\n contentId={contentId}\n open={open}\n stateAttribute={stateAttribute}\n trigger={trigger}\n onTriggerChange={setTrigger}\n onTriggerEnter={React.useCallback(() => {\n if (context.isOpenDelayed) handleDelayedOpen();\n else handleOpen();\n }, [context.isOpenDelayed, handleDelayedOpen, handleOpen])}\n onOpen={React.useCallback(handleOpen, [handleOpen])}\n onClose={React.useCallback(() => {\n window.clearTimeout(openTimerRef.current);\n setOpen(false);\n onClose();\n }, [setOpen, onClose])}\n >\n {children}\n </TooltipContextProvider>\n </PopperPrimitive.Root>\n );\n};\n\nTooltip.displayName = TOOLTIP_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipTrigger\n * -----------------------------------------------------------------------------------------------*/\n\nconst TRIGGER_NAME = 'TooltipTrigger';\n\ntype TooltipTriggerElement = React.ElementRef<typeof Primitive.button>;\ntype PrimitiveButtonProps = Radix.ComponentPropsWithoutRef<typeof Primitive.button>;\ninterface TooltipTriggerProps extends PrimitiveButtonProps {}\n\nconst TooltipTrigger = React.forwardRef<TooltipTriggerElement, TooltipTriggerProps>(\n (props: ScopedProps<TooltipTriggerProps>, forwardedRef) => {\n const { __scopeTooltip, ...triggerProps } = props;\n const context = useTooltipContext(TRIGGER_NAME, __scopeTooltip);\n const popperScope = usePopperScope(__scopeTooltip);\n const composedTriggerRef = useComposedRefs(forwardedRef, context.onTriggerChange);\n const isPointerDownRef = React.useRef(false);\n const handlePointerUp = React.useCallback(() => (isPointerDownRef.current = false), []);\n\n React.useEffect(() => {\n return () => document.removeEventListener('pointerup', handlePointerUp);\n }, [handlePointerUp]);\n\n return (\n <PopperPrimitive.Anchor asChild {...popperScope}>\n <Primitive.button\n // We purposefully avoid adding `type=button` here because tooltip triggers are also\n // commonly anchors and the anchor `type` attribute signifies MIME type.\n aria-describedby={context.open ? context.contentId : undefined}\n data-state={context.stateAttribute}\n {...triggerProps}\n ref={composedTriggerRef}\n onPointerEnter={composeEventHandlers(props.onPointerEnter, (event) => {\n if (event.pointerType !== 'touch') context.onTriggerEnter();\n })}\n onPointerLeave={composeEventHandlers(props.onPointerLeave, context.onClose)}\n onPointerDown={composeEventHandlers(props.onPointerDown, () => {\n isPointerDownRef.current = true;\n document.addEventListener('pointerup', handlePointerUp, { once: true });\n })}\n onFocus={composeEventHandlers(props.onFocus, () => {\n if (!isPointerDownRef.current) context.onOpen();\n })}\n onBlur={composeEventHandlers(props.onBlur, context.onClose)}\n onClick={composeEventHandlers(props.onClick, (event) => {\n // keyboard click will occur under different conditions for different node\n // types so we use `onClick` instead of `onKeyDown` to respect that\n const isKeyboardClick = event.detail === 0;\n if (isKeyboardClick) context.onClose();\n })}\n />\n </PopperPrimitive.Anchor>\n );\n }\n);\n\nTooltipTrigger.displayName = TRIGGER_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipPortal\n * -----------------------------------------------------------------------------------------------*/\n\nconst PORTAL_NAME = 'TooltipPortal';\n\ntype PortalContextValue = { forceMount?: true };\nconst [PortalProvider, usePortalContext] = createTooltipContext<PortalContextValue>(PORTAL_NAME, {\n forceMount: undefined,\n});\n\ntype PortalProps = React.ComponentPropsWithoutRef<typeof UnstablePortal>;\ninterface TooltipPortalProps extends Omit<PortalProps, 'asChild'> {\n children?: React.ReactNode;\n /**\n * Used to force mounting when more control is needed. Useful when\n * controlling animation with React animation libraries.\n */\n forceMount?: true;\n}\n\nconst TooltipPortal: React.FC<TooltipPortalProps> = (props: ScopedProps<TooltipPortalProps>) => {\n const { __scopeTooltip, forceMount, children, container } = props;\n const context = useTooltipContext(PORTAL_NAME, __scopeTooltip);\n return (\n <PortalProvider scope={__scopeTooltip} forceMount={forceMount}>\n <Presence present={forceMount || context.open}>\n <UnstablePortal asChild container={container}>\n {children}\n </UnstablePortal>\n </Presence>\n </PortalProvider>\n );\n};\n\nTooltipPortal.displayName = PORTAL_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipContent\n * -----------------------------------------------------------------------------------------------*/\n\nconst CONTENT_NAME = 'TooltipContent';\n\ntype TooltipContentElement = TooltipContentImplElement;\ninterface TooltipContentProps extends TooltipContentImplProps {\n /**\n * Used to force mounting when more control is needed. Useful when\n * controlling animation with React animation libraries.\n */\n forceMount?: true;\n}\n\nconst TooltipContent = React.forwardRef<TooltipContentElement, TooltipContentProps>(\n (props: ScopedProps<TooltipContentProps>, forwardedRef) => {\n const portalContext = usePortalContext(CONTENT_NAME, props.__scopeTooltip);\n const { forceMount = portalContext.forceMount, ...contentProps } = props;\n const context = useTooltipContext(CONTENT_NAME, props.__scopeTooltip);\n return (\n <Presence present={forceMount || context.open}>\n <TooltipContentImpl ref={forwardedRef} {...contentProps} />\n </Presence>\n );\n }\n);\n\ntype TooltipContentImplElement = React.ElementRef<typeof PopperPrimitive.Content>;\ntype DismissableLayerProps = Radix.ComponentPropsWithoutRef<typeof DismissableLayer>;\ntype PopperContentProps = Radix.ComponentPropsWithoutRef<typeof PopperPrimitive.Content>;\ninterface TooltipContentImplProps extends PopperContentProps {\n /**\n * A more descriptive label for accessibility purpose\n */\n 'aria-label'?: string;\n\n /**\n * Event handler called when the escape key is down.\n * Can be prevented.\n */\n onEscapeKeyDown?: DismissableLayerProps['onEscapeKeyDown'];\n /**\n * Event handler called when the a `pointerdown` event happens outside of the `Tooltip`.\n * Can be prevented.\n */\n onPointerDownOutside?: DismissableLayerProps['onPointerDownOutside'];\n}\n\nconst TooltipContentImpl = React.forwardRef<TooltipContentImplElement, TooltipContentImplProps>(\n (props: ScopedProps<TooltipContentImplProps>, forwardedRef) => {\n const {\n __scopeTooltip,\n children,\n 'aria-label': ariaLabel,\n onEscapeKeyDown,\n onPointerDownOutside,\n ...contentProps\n } = props;\n const context = useTooltipContext(CONTENT_NAME, __scopeTooltip);\n const popperScope = usePopperScope(__scopeTooltip);\n const { onClose } = context;\n\n // Close this tooltip if another one opens\n React.useEffect(() => {\n document.addEventListener(TOOLTIP_OPEN, onClose);\n return () => document.removeEventListener(TOOLTIP_OPEN, onClose);\n }, [onClose]);\n\n // Close the tooltip if the trigger is scrolled\n React.useEffect(() => {\n if (context.trigger) {\n const handleScroll = (event: Event) => {\n const target = event.target as HTMLElement;\n if (target?.contains(context.trigger)) onClose();\n };\n window.addEventListener('scroll', handleScroll, { capture: true });\n return () => window.removeEventListener('scroll', handleScroll, { capture: true });\n }\n }, [context.trigger, onClose]);\n\n return (\n <DismissableLayer\n asChild\n disableOutsidePointerEvents={false}\n onEscapeKeyDown={onEscapeKeyDown}\n onPointerDownOutside={onPointerDownOutside}\n onFocusOutside={(event) => event.preventDefault()}\n onDismiss={onClose}\n >\n <PopperPrimitive.Content\n data-state={context.stateAttribute}\n {...popperScope}\n {...contentProps}\n ref={forwardedRef}\n style={{\n ...contentProps.style,\n // re-namespace exposed content custom property\n ['--radix-tooltip-content-transform-origin' as any]:\n 'var(--radix-popper-transform-origin)',\n }}\n >\n <Slottable>{children}</Slottable>\n <VisuallyHiddenPrimitive.Root id={context.contentId} role=\"tooltip\">\n {ariaLabel || children}\n </VisuallyHiddenPrimitive.Root>\n </PopperPrimitive.Content>\n </DismissableLayer>\n );\n }\n);\n\nTooltipContent.displayName = CONTENT_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipArrow\n * -----------------------------------------------------------------------------------------------*/\n\nconst ARROW_NAME = 'TooltipArrow';\n\ntype TooltipArrowElement = React.ElementRef<typeof PopperPrimitive.Arrow>;\ntype PopperArrowProps = Radix.ComponentPropsWithoutRef<typeof PopperPrimitive.Arrow>;\ninterface TooltipArrowProps extends PopperArrowProps {}\n\nconst TooltipArrow = React.forwardRef<TooltipArrowElement, TooltipArrowProps>(\n (props: ScopedProps<TooltipArrowProps>, forwardedRef) => {\n const { __scopeTooltip, ...arrowProps } = props;\n const popperScope = usePopperScope(__scopeTooltip);\n return <PopperPrimitive.Arrow {...popperScope} {...arrowProps} ref={forwardedRef} />;\n }\n);\n\nTooltipArrow.displayName = ARROW_NAME;\n\n/* -----------------------------------------------------------------------------------------------*/\n\nconst Provider = TooltipProvider;\nconst Root = Tooltip;\nconst Trigger = TooltipTrigger;\nconst Portal = TooltipPortal;\nconst Content = TooltipContent;\nconst Arrow = TooltipArrow;\n\nexport {\n createTooltipScope,\n //\n TooltipProvider,\n Tooltip,\n TooltipTrigger,\n TooltipPortal,\n TooltipContent,\n TooltipArrow,\n //\n Provider,\n Root,\n Trigger,\n Portal,\n Content,\n Arrow,\n};\nexport type {\n TooltipProps,\n TooltipTriggerProps,\n TooltipPortalProps,\n TooltipContentProps,\n TooltipArrowProps,\n};\n"],"names":["React","composeEventHandlers","useComposedRefs","createContextScope","DismissableLayer","useId","PopperPrimitive","createPopperScope","UnstablePortal","Presence","Primitive","Slottable","useControllableState","VisuallyHiddenPrimitive","createTooltipContext","createTooltipScope","usePopperScope","PROVIDER_NAME","DEFAULT_DELAY_DURATION","TOOLTIP_OPEN","TooltipProviderContextProvider","useTooltipProviderContext","isOpenDelayed","delayDuration","onOpen","onClose","TooltipProvider","props","__scopeTooltip","skipDelayDuration","children","setIsOpenDelayed","useState","skipDelayTimerRef","useRef","useEffect","skipDelayTimer","current","window","clearTimeout","useCallback","setTimeout","TOOLTIP_NAME","TooltipContextProvider","useTooltipContext","Tooltip","open","openProp","defaultOpen","onOpenChange","delayDurationProp","context","popperScope","trigger","setTrigger","contentId","openTimerRef","wasOpenDelayedRef","setOpen","prop","defaultProp","onChange","document","dispatchEvent","CustomEvent","stateAttribute","useMemo","handleOpen","handleDelayedOpen","TRIGGER_NAME","TooltipTrigger","forwardRef","forwardedRef","triggerProps","composedTriggerRef","onTriggerChange","isPointerDownRef","handlePointerUp","removeEventListener","undefined","onPointerEnter","event","pointerType","onTriggerEnter","onPointerLeave","onPointerDown","addEventListener","once","onFocus","onBlur","onClick","isKeyboardClick","detail","PORTAL_NAME","PortalProvider","usePortalContext","forceMount","TooltipPortal","container","CONTENT_NAME","TooltipContent","portalContext","contentProps","TooltipContentImpl","ariaLabel","onEscapeKeyDown","onPointerDownOutside","handleScroll","target","contains","capture","preventDefault","style","ARROW_NAME","TooltipArrow","arrowProps","Provider","Root","Trigger","Portal","Content","Arrow"],"version":3,"file":"index.js.map"}
|
package/dist/index.module.js
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import $8wepK$babelruntimehelpersesmextends from "@babel/runtime/helpers/esm/extends";
|
|
2
|
-
import {useState as $8wepK$useState, useRef as $8wepK$useRef, useEffect as $8wepK$useEffect, createElement as $8wepK$createElement, useCallback as $8wepK$useCallback, useMemo as $8wepK$useMemo, forwardRef as $8wepK$forwardRef
|
|
2
|
+
import {useState as $8wepK$useState, useRef as $8wepK$useRef, useEffect as $8wepK$useEffect, createElement as $8wepK$createElement, useCallback as $8wepK$useCallback, useMemo as $8wepK$useMemo, forwardRef as $8wepK$forwardRef} from "react";
|
|
3
3
|
import {composeEventHandlers as $8wepK$composeEventHandlers} from "@radix-ui/primitive";
|
|
4
4
|
import {useComposedRefs as $8wepK$useComposedRefs} from "@radix-ui/react-compose-refs";
|
|
5
5
|
import {createContextScope as $8wepK$createContextScope} from "@radix-ui/react-context";
|
|
6
6
|
import {DismissableLayer as $8wepK$DismissableLayer} from "@radix-ui/react-dismissable-layer";
|
|
7
7
|
import {useId as $8wepK$useId} from "@radix-ui/react-id";
|
|
8
8
|
import {createPopperScope as $8wepK$createPopperScope, Root as $8wepK$Root, Anchor as $8wepK$Anchor, Content as $8wepK$Content, Arrow as $8wepK$Arrow} from "@radix-ui/react-popper";
|
|
9
|
-
import {
|
|
9
|
+
import {UnstablePortal as $8wepK$UnstablePortal} from "@radix-ui/react-portal";
|
|
10
10
|
import {Presence as $8wepK$Presence} from "@radix-ui/react-presence";
|
|
11
11
|
import {Primitive as $8wepK$Primitive} from "@radix-ui/react-primitive";
|
|
12
12
|
import {Slottable as $8wepK$Slottable} from "@radix-ui/react-slot";
|
|
@@ -22,11 +22,13 @@ $parcel$export($a093c7e1ec25a057$exports, "createTooltipScope", () => $a093c7e1e
|
|
|
22
22
|
$parcel$export($a093c7e1ec25a057$exports, "TooltipProvider", () => $a093c7e1ec25a057$export$f78649fb9ca566b8);
|
|
23
23
|
$parcel$export($a093c7e1ec25a057$exports, "Tooltip", () => $a093c7e1ec25a057$export$28c660c63b792dea);
|
|
24
24
|
$parcel$export($a093c7e1ec25a057$exports, "TooltipTrigger", () => $a093c7e1ec25a057$export$8c610744efcf8a1d);
|
|
25
|
+
$parcel$export($a093c7e1ec25a057$exports, "TooltipPortal", () => $a093c7e1ec25a057$export$7b36b8f925ab7497);
|
|
25
26
|
$parcel$export($a093c7e1ec25a057$exports, "TooltipContent", () => $a093c7e1ec25a057$export$e9003e2be37ec060);
|
|
26
27
|
$parcel$export($a093c7e1ec25a057$exports, "TooltipArrow", () => $a093c7e1ec25a057$export$c27ee0ad710f7559);
|
|
27
28
|
$parcel$export($a093c7e1ec25a057$exports, "Provider", () => $a093c7e1ec25a057$export$2881499e37b75b9a);
|
|
28
29
|
$parcel$export($a093c7e1ec25a057$exports, "Root", () => $a093c7e1ec25a057$export$be92b6f5f03c0fe9);
|
|
29
30
|
$parcel$export($a093c7e1ec25a057$exports, "Trigger", () => $a093c7e1ec25a057$export$41fb9f06171c75f4);
|
|
31
|
+
$parcel$export($a093c7e1ec25a057$exports, "Portal", () => $a093c7e1ec25a057$export$602eac185826482c);
|
|
30
32
|
$parcel$export($a093c7e1ec25a057$exports, "Content", () => $a093c7e1ec25a057$export$7c6e2c02157bb7d2);
|
|
31
33
|
$parcel$export($a093c7e1ec25a057$exports, "Arrow", () => $a093c7e1ec25a057$export$21b07c8f274aebd5);
|
|
32
34
|
|
|
@@ -226,11 +228,34 @@ const $a093c7e1ec25a057$export$8c610744efcf8a1d = /*#__PURE__*/ $8wepK$forwardRe
|
|
|
226
228
|
/*#__PURE__*/ Object.assign($a093c7e1ec25a057$export$8c610744efcf8a1d, {
|
|
227
229
|
displayName: $a093c7e1ec25a057$var$TRIGGER_NAME
|
|
228
230
|
});
|
|
231
|
+
/* -------------------------------------------------------------------------------------------------
|
|
232
|
+
* TooltipPortal
|
|
233
|
+
* -----------------------------------------------------------------------------------------------*/ const $a093c7e1ec25a057$var$PORTAL_NAME = 'TooltipPortal';
|
|
234
|
+
const [$a093c7e1ec25a057$var$PortalProvider, $a093c7e1ec25a057$var$usePortalContext] = $a093c7e1ec25a057$var$createTooltipContext($a093c7e1ec25a057$var$PORTAL_NAME, {
|
|
235
|
+
forceMount: undefined
|
|
236
|
+
});
|
|
237
|
+
const $a093c7e1ec25a057$export$7b36b8f925ab7497 = (props)=>{
|
|
238
|
+
const { __scopeTooltip: __scopeTooltip , forceMount: forceMount , children: children , container: container } = props;
|
|
239
|
+
const context = $a093c7e1ec25a057$var$useTooltipContext($a093c7e1ec25a057$var$PORTAL_NAME, __scopeTooltip);
|
|
240
|
+
return /*#__PURE__*/ $8wepK$createElement($a093c7e1ec25a057$var$PortalProvider, {
|
|
241
|
+
scope: __scopeTooltip,
|
|
242
|
+
forceMount: forceMount
|
|
243
|
+
}, /*#__PURE__*/ $8wepK$createElement($8wepK$Presence, {
|
|
244
|
+
present: forceMount || context.open
|
|
245
|
+
}, /*#__PURE__*/ $8wepK$createElement($8wepK$UnstablePortal, {
|
|
246
|
+
asChild: true,
|
|
247
|
+
container: container
|
|
248
|
+
}, children)));
|
|
249
|
+
};
|
|
250
|
+
/*#__PURE__*/ Object.assign($a093c7e1ec25a057$export$7b36b8f925ab7497, {
|
|
251
|
+
displayName: $a093c7e1ec25a057$var$PORTAL_NAME
|
|
252
|
+
});
|
|
229
253
|
/* -------------------------------------------------------------------------------------------------
|
|
230
254
|
* TooltipContent
|
|
231
255
|
* -----------------------------------------------------------------------------------------------*/ const $a093c7e1ec25a057$var$CONTENT_NAME = 'TooltipContent';
|
|
232
256
|
const $a093c7e1ec25a057$export$e9003e2be37ec060 = /*#__PURE__*/ $8wepK$forwardRef((props, forwardedRef)=>{
|
|
233
|
-
const
|
|
257
|
+
const portalContext = $a093c7e1ec25a057$var$usePortalContext($a093c7e1ec25a057$var$CONTENT_NAME, props.__scopeTooltip);
|
|
258
|
+
const { forceMount: forceMount = portalContext.forceMount , ...contentProps } = props;
|
|
234
259
|
const context = $a093c7e1ec25a057$var$useTooltipContext($a093c7e1ec25a057$var$CONTENT_NAME, props.__scopeTooltip);
|
|
235
260
|
return /*#__PURE__*/ $8wepK$createElement($8wepK$Presence, {
|
|
236
261
|
present: forceMount || context.open
|
|
@@ -239,10 +264,9 @@ const $a093c7e1ec25a057$export$e9003e2be37ec060 = /*#__PURE__*/ $8wepK$forwardRe
|
|
|
239
264
|
}, contentProps)));
|
|
240
265
|
});
|
|
241
266
|
const $a093c7e1ec25a057$var$TooltipContentImpl = /*#__PURE__*/ $8wepK$forwardRef((props, forwardedRef)=>{
|
|
242
|
-
const { __scopeTooltip: __scopeTooltip , children: children , 'aria-label': ariaLabel ,
|
|
267
|
+
const { __scopeTooltip: __scopeTooltip , children: children , 'aria-label': ariaLabel , onEscapeKeyDown: onEscapeKeyDown , onPointerDownOutside: onPointerDownOutside , ...contentProps } = props;
|
|
243
268
|
const context = $a093c7e1ec25a057$var$useTooltipContext($a093c7e1ec25a057$var$CONTENT_NAME, __scopeTooltip);
|
|
244
269
|
const popperScope = $a093c7e1ec25a057$var$usePopperScope(__scopeTooltip);
|
|
245
|
-
const PortalWrapper = portalled ? $8wepK$Portal : $8wepK$Fragment;
|
|
246
270
|
const { onClose: onClose } = context; // Close this tooltip if another one opens
|
|
247
271
|
$8wepK$useEffect(()=>{
|
|
248
272
|
document.addEventListener($a093c7e1ec25a057$var$TOOLTIP_OPEN, onClose);
|
|
@@ -269,7 +293,7 @@ const $a093c7e1ec25a057$var$TooltipContentImpl = /*#__PURE__*/ $8wepK$forwardRef
|
|
|
269
293
|
context.trigger,
|
|
270
294
|
onClose
|
|
271
295
|
]);
|
|
272
|
-
return /*#__PURE__*/ $8wepK$createElement(
|
|
296
|
+
return /*#__PURE__*/ $8wepK$createElement($8wepK$DismissableLayer, {
|
|
273
297
|
asChild: true,
|
|
274
298
|
disableOutsidePointerEvents: false,
|
|
275
299
|
onEscapeKeyDown: onEscapeKeyDown,
|
|
@@ -289,7 +313,7 @@ const $a093c7e1ec25a057$var$TooltipContentImpl = /*#__PURE__*/ $8wepK$forwardRef
|
|
|
289
313
|
}), /*#__PURE__*/ $8wepK$createElement($8wepK$Slottable, null, children), /*#__PURE__*/ $8wepK$createElement($8wepK$Root1, {
|
|
290
314
|
id: context.contentId,
|
|
291
315
|
role: "tooltip"
|
|
292
|
-
}, ariaLabel || children)))
|
|
316
|
+
}, ariaLabel || children)));
|
|
293
317
|
});
|
|
294
318
|
/*#__PURE__*/ Object.assign($a093c7e1ec25a057$export$e9003e2be37ec060, {
|
|
295
319
|
displayName: $a093c7e1ec25a057$var$CONTENT_NAME
|
|
@@ -310,11 +334,12 @@ const $a093c7e1ec25a057$export$c27ee0ad710f7559 = /*#__PURE__*/ $8wepK$forwardRe
|
|
|
310
334
|
/* -----------------------------------------------------------------------------------------------*/ const $a093c7e1ec25a057$export$2881499e37b75b9a = $a093c7e1ec25a057$export$f78649fb9ca566b8;
|
|
311
335
|
const $a093c7e1ec25a057$export$be92b6f5f03c0fe9 = $a093c7e1ec25a057$export$28c660c63b792dea;
|
|
312
336
|
const $a093c7e1ec25a057$export$41fb9f06171c75f4 = $a093c7e1ec25a057$export$8c610744efcf8a1d;
|
|
337
|
+
const $a093c7e1ec25a057$export$602eac185826482c = $a093c7e1ec25a057$export$7b36b8f925ab7497;
|
|
313
338
|
const $a093c7e1ec25a057$export$7c6e2c02157bb7d2 = $a093c7e1ec25a057$export$e9003e2be37ec060;
|
|
314
339
|
const $a093c7e1ec25a057$export$21b07c8f274aebd5 = $a093c7e1ec25a057$export$c27ee0ad710f7559;
|
|
315
340
|
|
|
316
341
|
|
|
317
342
|
|
|
318
343
|
|
|
319
|
-
export {$a093c7e1ec25a057$export$1c540a2224f0d865 as createTooltipScope, $a093c7e1ec25a057$export$f78649fb9ca566b8 as TooltipProvider, $a093c7e1ec25a057$export$28c660c63b792dea as Tooltip, $a093c7e1ec25a057$export$8c610744efcf8a1d as TooltipTrigger, $a093c7e1ec25a057$export$e9003e2be37ec060 as TooltipContent, $a093c7e1ec25a057$export$c27ee0ad710f7559 as TooltipArrow, $a093c7e1ec25a057$export$2881499e37b75b9a as Provider, $a093c7e1ec25a057$export$be92b6f5f03c0fe9 as Root, $a093c7e1ec25a057$export$41fb9f06171c75f4 as Trigger, $a093c7e1ec25a057$export$7c6e2c02157bb7d2 as Content, $a093c7e1ec25a057$export$21b07c8f274aebd5 as Arrow};
|
|
344
|
+
export {$a093c7e1ec25a057$export$1c540a2224f0d865 as createTooltipScope, $a093c7e1ec25a057$export$f78649fb9ca566b8 as TooltipProvider, $a093c7e1ec25a057$export$28c660c63b792dea as Tooltip, $a093c7e1ec25a057$export$8c610744efcf8a1d as TooltipTrigger, $a093c7e1ec25a057$export$7b36b8f925ab7497 as TooltipPortal, $a093c7e1ec25a057$export$e9003e2be37ec060 as TooltipContent, $a093c7e1ec25a057$export$c27ee0ad710f7559 as TooltipArrow, $a093c7e1ec25a057$export$2881499e37b75b9a as Provider, $a093c7e1ec25a057$export$be92b6f5f03c0fe9 as Root, $a093c7e1ec25a057$export$41fb9f06171c75f4 as Trigger, $a093c7e1ec25a057$export$602eac185826482c as Portal, $a093c7e1ec25a057$export$7c6e2c02157bb7d2 as Content, $a093c7e1ec25a057$export$21b07c8f274aebd5 as Arrow};
|
|
320
345
|
//# sourceMappingURL=index.module.js.map
|
package/dist/index.module.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"mappings":"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","sources":["packages/react/tooltip/src/index.ts","packages/react/tooltip/src/Tooltip.tsx"],"sourcesContent":["export * from './Tooltip';\n","import * as React from 'react';\nimport { composeEventHandlers } from '@radix-ui/primitive';\nimport { useComposedRefs } from '@radix-ui/react-compose-refs';\nimport { createContextScope } from '@radix-ui/react-context';\nimport { DismissableLayer } from '@radix-ui/react-dismissable-layer';\nimport { useId } from '@radix-ui/react-id';\nimport * as PopperPrimitive from '@radix-ui/react-popper';\nimport { createPopperScope } from '@radix-ui/react-popper';\nimport { Portal } from '@radix-ui/react-portal';\nimport { Presence } from '@radix-ui/react-presence';\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slottable } from '@radix-ui/react-slot';\nimport { useControllableState } from '@radix-ui/react-use-controllable-state';\nimport * as VisuallyHiddenPrimitive from '@radix-ui/react-visually-hidden';\n\nimport type * as Radix from '@radix-ui/react-primitive';\nimport type { Scope } from '@radix-ui/react-context';\n\ntype ScopedProps<P = {}> = P & { __scopeTooltip?: Scope };\nconst [createTooltipContext, createTooltipScope] = createContextScope('Tooltip', [\n createPopperScope,\n]);\nconst usePopperScope = createPopperScope();\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipProvider\n * -----------------------------------------------------------------------------------------------*/\n\nconst PROVIDER_NAME = 'TooltipProvider';\nconst DEFAULT_DELAY_DURATION = 700;\nconst TOOLTIP_OPEN = 'tooltip.open';\n\ntype TooltipProviderContextValue = {\n isOpenDelayed: boolean;\n delayDuration: number;\n onOpen(): void;\n onClose(): void;\n};\n\nconst [TooltipProviderContextProvider, useTooltipProviderContext] =\n createTooltipContext<TooltipProviderContextValue>(PROVIDER_NAME, {\n isOpenDelayed: true,\n delayDuration: DEFAULT_DELAY_DURATION,\n onOpen: () => {},\n onClose: () => {},\n });\n\ninterface TooltipProviderProps {\n children: React.ReactNode;\n /**\n * The duration from when the pointer enters the trigger until the tooltip gets opened.\n * @defaultValue 700\n */\n delayDuration?: number;\n /**\n * How much time a user has to enter another trigger without incurring a delay again.\n * @defaultValue 300\n */\n skipDelayDuration?: number;\n}\n\nconst TooltipProvider: React.FC<TooltipProviderProps> = (\n props: ScopedProps<TooltipProviderProps>\n) => {\n const {\n __scopeTooltip,\n delayDuration = DEFAULT_DELAY_DURATION,\n skipDelayDuration = 300,\n children,\n } = props;\n const [isOpenDelayed, setIsOpenDelayed] = React.useState(true);\n const skipDelayTimerRef = React.useRef(0);\n\n React.useEffect(() => {\n const skipDelayTimer = skipDelayTimerRef.current;\n return () => window.clearTimeout(skipDelayTimer);\n }, []);\n\n return (\n <TooltipProviderContextProvider\n scope={__scopeTooltip}\n isOpenDelayed={isOpenDelayed}\n delayDuration={delayDuration}\n onOpen={React.useCallback(() => {\n window.clearTimeout(skipDelayTimerRef.current);\n setIsOpenDelayed(false);\n }, [])}\n onClose={React.useCallback(() => {\n window.clearTimeout(skipDelayTimerRef.current);\n skipDelayTimerRef.current = window.setTimeout(\n () => setIsOpenDelayed(true),\n skipDelayDuration\n );\n }, [skipDelayDuration])}\n >\n {children}\n </TooltipProviderContextProvider>\n );\n};\n\nTooltipProvider.displayName = PROVIDER_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * Tooltip\n * -----------------------------------------------------------------------------------------------*/\n\nconst TOOLTIP_NAME = 'Tooltip';\n\ntype TooltipContextValue = {\n contentId: string;\n open: boolean;\n stateAttribute: 'closed' | 'delayed-open' | 'instant-open';\n trigger: TooltipTriggerElement | null;\n onTriggerChange(trigger: TooltipTriggerElement | null): void;\n onTriggerEnter(): void;\n onOpen(): void;\n onClose(): void;\n};\n\nconst [TooltipContextProvider, useTooltipContext] =\n createTooltipContext<TooltipContextValue>(TOOLTIP_NAME);\n\ninterface TooltipProps {\n children?: React.ReactNode;\n open?: boolean;\n defaultOpen?: boolean;\n onOpenChange?: (open: boolean) => void;\n\n /**\n * The duration from when the pointer enters the trigger until the tooltip gets opened. This will\n * override the prop with the same name passed to Provider.\n * @defaultValue 700\n */\n delayDuration?: number;\n}\n\nconst Tooltip: React.FC<TooltipProps> = (props: ScopedProps<TooltipProps>) => {\n const {\n __scopeTooltip,\n children,\n open: openProp,\n defaultOpen = false,\n onOpenChange,\n delayDuration: delayDurationProp,\n } = props;\n const context = useTooltipProviderContext(TOOLTIP_NAME, __scopeTooltip);\n const popperScope = usePopperScope(__scopeTooltip);\n const [trigger, setTrigger] = React.useState<HTMLButtonElement | null>(null);\n const contentId = useId();\n const openTimerRef = React.useRef(0);\n const delayDuration = delayDurationProp ?? context.delayDuration;\n const wasOpenDelayedRef = React.useRef(false);\n const { onOpen, onClose } = context;\n const [open = false, setOpen] = useControllableState({\n prop: openProp,\n defaultProp: defaultOpen,\n onChange: (open) => {\n if (open) {\n // we dispatch here so `TooltipProvider` isn't required to\n // ensure other tooltips are aware of this one opening.\n //\n // as `onChange` is called within a lifecycle method we\n // avoid dispatching via `dispatchDiscreteCustomEvent`.\n document.dispatchEvent(new CustomEvent(TOOLTIP_OPEN));\n onOpen();\n }\n onOpenChange?.(open);\n },\n });\n const stateAttribute = React.useMemo(() => {\n return open ? (wasOpenDelayedRef.current ? 'delayed-open' : 'instant-open') : 'closed';\n }, [open]);\n\n const handleOpen = React.useCallback(() => {\n window.clearTimeout(openTimerRef.current);\n wasOpenDelayedRef.current = false;\n setOpen(true);\n }, [setOpen]);\n\n const handleDelayedOpen = React.useCallback(() => {\n window.clearTimeout(openTimerRef.current);\n openTimerRef.current = window.setTimeout(() => {\n wasOpenDelayedRef.current = true;\n setOpen(true);\n }, delayDuration);\n }, [delayDuration, setOpen]);\n\n React.useEffect(() => {\n return () => window.clearTimeout(openTimerRef.current);\n }, []);\n\n return (\n <PopperPrimitive.Root {...popperScope}>\n <TooltipContextProvider\n scope={__scopeTooltip}\n contentId={contentId}\n open={open}\n stateAttribute={stateAttribute}\n trigger={trigger}\n onTriggerChange={setTrigger}\n onTriggerEnter={React.useCallback(() => {\n if (context.isOpenDelayed) handleDelayedOpen();\n else handleOpen();\n }, [context.isOpenDelayed, handleDelayedOpen, handleOpen])}\n onOpen={React.useCallback(handleOpen, [handleOpen])}\n onClose={React.useCallback(() => {\n window.clearTimeout(openTimerRef.current);\n setOpen(false);\n onClose();\n }, [setOpen, onClose])}\n >\n {children}\n </TooltipContextProvider>\n </PopperPrimitive.Root>\n );\n};\n\nTooltip.displayName = TOOLTIP_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipTrigger\n * -----------------------------------------------------------------------------------------------*/\n\nconst TRIGGER_NAME = 'TooltipTrigger';\n\ntype TooltipTriggerElement = React.ElementRef<typeof Primitive.button>;\ntype PrimitiveButtonProps = Radix.ComponentPropsWithoutRef<typeof Primitive.button>;\ninterface TooltipTriggerProps extends PrimitiveButtonProps {}\n\nconst TooltipTrigger = React.forwardRef<TooltipTriggerElement, TooltipTriggerProps>(\n (props: ScopedProps<TooltipTriggerProps>, forwardedRef) => {\n const { __scopeTooltip, ...triggerProps } = props;\n const context = useTooltipContext(TRIGGER_NAME, __scopeTooltip);\n const popperScope = usePopperScope(__scopeTooltip);\n const composedTriggerRef = useComposedRefs(forwardedRef, context.onTriggerChange);\n const isPointerDownRef = React.useRef(false);\n const handlePointerUp = React.useCallback(() => (isPointerDownRef.current = false), []);\n\n React.useEffect(() => {\n return () => document.removeEventListener('pointerup', handlePointerUp);\n }, [handlePointerUp]);\n\n return (\n <PopperPrimitive.Anchor asChild {...popperScope}>\n <Primitive.button\n // We purposefully avoid adding `type=button` here because tooltip triggers are also\n // commonly anchors and the anchor `type` attribute signifies MIME type.\n aria-describedby={context.open ? context.contentId : undefined}\n data-state={context.stateAttribute}\n {...triggerProps}\n ref={composedTriggerRef}\n onPointerEnter={composeEventHandlers(props.onPointerEnter, (event) => {\n if (event.pointerType !== 'touch') context.onTriggerEnter();\n })}\n onPointerLeave={composeEventHandlers(props.onPointerLeave, context.onClose)}\n onPointerDown={composeEventHandlers(props.onPointerDown, () => {\n isPointerDownRef.current = true;\n document.addEventListener('pointerup', handlePointerUp, { once: true });\n })}\n onFocus={composeEventHandlers(props.onFocus, () => {\n if (!isPointerDownRef.current) context.onOpen();\n })}\n onBlur={composeEventHandlers(props.onBlur, context.onClose)}\n onClick={composeEventHandlers(props.onClick, (event) => {\n // keyboard click will occur under different conditions for different node\n // types so we use `onClick` instead of `onKeyDown` to respect that\n const isKeyboardClick = event.detail === 0;\n if (isKeyboardClick) context.onClose();\n })}\n />\n </PopperPrimitive.Anchor>\n );\n }\n);\n\nTooltipTrigger.displayName = TRIGGER_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipContent\n * -----------------------------------------------------------------------------------------------*/\n\nconst CONTENT_NAME = 'TooltipContent';\n\ntype TooltipContentElement = TooltipContentImplElement;\ninterface TooltipContentProps extends TooltipContentImplProps {\n /**\n * Used to force mounting when more control is needed. Useful when\n * controlling animation with React animation libraries.\n */\n forceMount?: true;\n}\n\nconst TooltipContent = React.forwardRef<TooltipContentElement, TooltipContentProps>(\n (props: ScopedProps<TooltipContentProps>, forwardedRef) => {\n const { forceMount, ...contentProps } = props;\n const context = useTooltipContext(CONTENT_NAME, props.__scopeTooltip);\n return (\n <Presence present={forceMount || context.open}>\n <TooltipContentImpl ref={forwardedRef} {...contentProps} />\n </Presence>\n );\n }\n);\n\ntype TooltipContentImplElement = React.ElementRef<typeof PopperPrimitive.Content>;\ntype DismissableLayerProps = Radix.ComponentPropsWithoutRef<typeof DismissableLayer>;\ntype PopperContentProps = Radix.ComponentPropsWithoutRef<typeof PopperPrimitive.Content>;\ninterface TooltipContentImplProps extends PopperContentProps {\n /**\n * A more descriptive label for accessibility purpose\n */\n 'aria-label'?: string;\n\n /**\n * Event handler called when the escape key is down.\n * Can be prevented.\n */\n onEscapeKeyDown?: DismissableLayerProps['onEscapeKeyDown'];\n /**\n * Event handler called when the a `pointerdown` event happens outside of the `Tooltip`.\n * Can be prevented.\n */\n onPointerDownOutside?: DismissableLayerProps['onPointerDownOutside'];\n\n /**\n * Whether the Tooltip should render in a Portal\n * (default: `true`)\n */\n portalled?: boolean;\n}\n\nconst TooltipContentImpl = React.forwardRef<TooltipContentImplElement, TooltipContentImplProps>(\n (props: ScopedProps<TooltipContentImplProps>, forwardedRef) => {\n const {\n __scopeTooltip,\n children,\n 'aria-label': ariaLabel,\n portalled = true,\n onEscapeKeyDown,\n onPointerDownOutside,\n ...contentProps\n } = props;\n const context = useTooltipContext(CONTENT_NAME, __scopeTooltip);\n const popperScope = usePopperScope(__scopeTooltip);\n const PortalWrapper = portalled ? Portal : React.Fragment;\n const { onClose } = context;\n\n // Close this tooltip if another one opens\n React.useEffect(() => {\n document.addEventListener(TOOLTIP_OPEN, onClose);\n return () => document.removeEventListener(TOOLTIP_OPEN, onClose);\n }, [onClose]);\n\n // Close the tooltip if the trigger is scrolled\n React.useEffect(() => {\n if (context.trigger) {\n const handleScroll = (event: Event) => {\n const target = event.target as HTMLElement;\n if (target?.contains(context.trigger)) onClose();\n };\n window.addEventListener('scroll', handleScroll, { capture: true });\n return () => window.removeEventListener('scroll', handleScroll, { capture: true });\n }\n }, [context.trigger, onClose]);\n\n return (\n <PortalWrapper>\n <DismissableLayer\n asChild\n disableOutsidePointerEvents={false}\n onEscapeKeyDown={onEscapeKeyDown}\n onPointerDownOutside={onPointerDownOutside}\n onFocusOutside={(event) => event.preventDefault()}\n onDismiss={onClose}\n >\n <PopperPrimitive.Content\n data-state={context.stateAttribute}\n {...popperScope}\n {...contentProps}\n ref={forwardedRef}\n style={{\n ...contentProps.style,\n // re-namespace exposed content custom property\n ['--radix-tooltip-content-transform-origin' as any]:\n 'var(--radix-popper-transform-origin)',\n }}\n >\n <Slottable>{children}</Slottable>\n <VisuallyHiddenPrimitive.Root id={context.contentId} role=\"tooltip\">\n {ariaLabel || children}\n </VisuallyHiddenPrimitive.Root>\n </PopperPrimitive.Content>\n </DismissableLayer>\n </PortalWrapper>\n );\n }\n);\n\nTooltipContent.displayName = CONTENT_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipArrow\n * -----------------------------------------------------------------------------------------------*/\n\nconst ARROW_NAME = 'TooltipArrow';\n\ntype TooltipArrowElement = React.ElementRef<typeof PopperPrimitive.Arrow>;\ntype PopperArrowProps = Radix.ComponentPropsWithoutRef<typeof PopperPrimitive.Arrow>;\ninterface TooltipArrowProps extends PopperArrowProps {}\n\nconst TooltipArrow = React.forwardRef<TooltipArrowElement, TooltipArrowProps>(\n (props: ScopedProps<TooltipArrowProps>, forwardedRef) => {\n const { __scopeTooltip, ...arrowProps } = props;\n const popperScope = usePopperScope(__scopeTooltip);\n return <PopperPrimitive.Arrow {...popperScope} {...arrowProps} ref={forwardedRef} />;\n }\n);\n\nTooltipArrow.displayName = ARROW_NAME;\n\n/* -----------------------------------------------------------------------------------------------*/\n\nconst Provider = TooltipProvider;\nconst Root = Tooltip;\nconst Trigger = TooltipTrigger;\nconst Content = TooltipContent;\nconst Arrow = TooltipArrow;\n\nexport {\n createTooltipScope,\n //\n TooltipProvider,\n Tooltip,\n TooltipTrigger,\n TooltipContent,\n TooltipArrow,\n //\n Provider,\n Root,\n Trigger,\n Content,\n Arrow,\n};\nexport type { TooltipProps, TooltipTriggerProps, TooltipContentProps, TooltipArrowProps };\n"],"names":["React","composeEventHandlers","useComposedRefs","createContextScope","DismissableLayer","useId","PopperPrimitive","createPopperScope","Portal","Presence","Primitive","Slottable","useControllableState","VisuallyHiddenPrimitive","createTooltipContext","createTooltipScope","usePopperScope","PROVIDER_NAME","DEFAULT_DELAY_DURATION","TOOLTIP_OPEN","TooltipProviderContextProvider","useTooltipProviderContext","isOpenDelayed","delayDuration","onOpen","onClose","TooltipProvider","props","__scopeTooltip","skipDelayDuration","children","setIsOpenDelayed","useState","skipDelayTimerRef","useRef","useEffect","skipDelayTimer","current","window","clearTimeout","useCallback","setTimeout","TOOLTIP_NAME","TooltipContextProvider","useTooltipContext","Tooltip","open","openProp","defaultOpen","onOpenChange","delayDurationProp","context","popperScope","trigger","setTrigger","contentId","openTimerRef","wasOpenDelayedRef","setOpen","prop","defaultProp","onChange","document","dispatchEvent","CustomEvent","stateAttribute","useMemo","handleOpen","handleDelayedOpen","TRIGGER_NAME","TooltipTrigger","forwardRef","forwardedRef","triggerProps","composedTriggerRef","onTriggerChange","isPointerDownRef","handlePointerUp","removeEventListener","undefined","onPointerEnter","event","pointerType","onTriggerEnter","onPointerLeave","onPointerDown","addEventListener","once","onFocus","onBlur","onClick","isKeyboardClick","detail","CONTENT_NAME","TooltipContent","forceMount","contentProps","TooltipContentImpl","ariaLabel","portalled","onEscapeKeyDown","onPointerDownOutside","PortalWrapper","Fragment","handleScroll","target","contains","capture","preventDefault","style","ARROW_NAME","TooltipArrow","arrowProps","Provider","Root","Trigger","Content","Arrow"],"version":3,"file":"index.module.js.map"}
|
|
1
|
+
{"mappings":"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","sources":["packages/react/tooltip/src/index.ts","packages/react/tooltip/src/Tooltip.tsx"],"sourcesContent":["export * from './Tooltip';\n","import * as React from 'react';\nimport { composeEventHandlers } from '@radix-ui/primitive';\nimport { useComposedRefs } from '@radix-ui/react-compose-refs';\nimport { createContextScope } from '@radix-ui/react-context';\nimport { DismissableLayer } from '@radix-ui/react-dismissable-layer';\nimport { useId } from '@radix-ui/react-id';\nimport * as PopperPrimitive from '@radix-ui/react-popper';\nimport { createPopperScope } from '@radix-ui/react-popper';\nimport { UnstablePortal } from '@radix-ui/react-portal';\nimport { Presence } from '@radix-ui/react-presence';\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slottable } from '@radix-ui/react-slot';\nimport { useControllableState } from '@radix-ui/react-use-controllable-state';\nimport * as VisuallyHiddenPrimitive from '@radix-ui/react-visually-hidden';\n\nimport type * as Radix from '@radix-ui/react-primitive';\nimport type { Scope } from '@radix-ui/react-context';\n\ntype ScopedProps<P = {}> = P & { __scopeTooltip?: Scope };\nconst [createTooltipContext, createTooltipScope] = createContextScope('Tooltip', [\n createPopperScope,\n]);\nconst usePopperScope = createPopperScope();\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipProvider\n * -----------------------------------------------------------------------------------------------*/\n\nconst PROVIDER_NAME = 'TooltipProvider';\nconst DEFAULT_DELAY_DURATION = 700;\nconst TOOLTIP_OPEN = 'tooltip.open';\n\ntype TooltipProviderContextValue = {\n isOpenDelayed: boolean;\n delayDuration: number;\n onOpen(): void;\n onClose(): void;\n};\n\nconst [TooltipProviderContextProvider, useTooltipProviderContext] =\n createTooltipContext<TooltipProviderContextValue>(PROVIDER_NAME, {\n isOpenDelayed: true,\n delayDuration: DEFAULT_DELAY_DURATION,\n onOpen: () => {},\n onClose: () => {},\n });\n\ninterface TooltipProviderProps {\n children: React.ReactNode;\n /**\n * The duration from when the pointer enters the trigger until the tooltip gets opened.\n * @defaultValue 700\n */\n delayDuration?: number;\n /**\n * How much time a user has to enter another trigger without incurring a delay again.\n * @defaultValue 300\n */\n skipDelayDuration?: number;\n}\n\nconst TooltipProvider: React.FC<TooltipProviderProps> = (\n props: ScopedProps<TooltipProviderProps>\n) => {\n const {\n __scopeTooltip,\n delayDuration = DEFAULT_DELAY_DURATION,\n skipDelayDuration = 300,\n children,\n } = props;\n const [isOpenDelayed, setIsOpenDelayed] = React.useState(true);\n const skipDelayTimerRef = React.useRef(0);\n\n React.useEffect(() => {\n const skipDelayTimer = skipDelayTimerRef.current;\n return () => window.clearTimeout(skipDelayTimer);\n }, []);\n\n return (\n <TooltipProviderContextProvider\n scope={__scopeTooltip}\n isOpenDelayed={isOpenDelayed}\n delayDuration={delayDuration}\n onOpen={React.useCallback(() => {\n window.clearTimeout(skipDelayTimerRef.current);\n setIsOpenDelayed(false);\n }, [])}\n onClose={React.useCallback(() => {\n window.clearTimeout(skipDelayTimerRef.current);\n skipDelayTimerRef.current = window.setTimeout(\n () => setIsOpenDelayed(true),\n skipDelayDuration\n );\n }, [skipDelayDuration])}\n >\n {children}\n </TooltipProviderContextProvider>\n );\n};\n\nTooltipProvider.displayName = PROVIDER_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * Tooltip\n * -----------------------------------------------------------------------------------------------*/\n\nconst TOOLTIP_NAME = 'Tooltip';\n\ntype TooltipContextValue = {\n contentId: string;\n open: boolean;\n stateAttribute: 'closed' | 'delayed-open' | 'instant-open';\n trigger: TooltipTriggerElement | null;\n onTriggerChange(trigger: TooltipTriggerElement | null): void;\n onTriggerEnter(): void;\n onOpen(): void;\n onClose(): void;\n};\n\nconst [TooltipContextProvider, useTooltipContext] =\n createTooltipContext<TooltipContextValue>(TOOLTIP_NAME);\n\ninterface TooltipProps {\n children?: React.ReactNode;\n open?: boolean;\n defaultOpen?: boolean;\n onOpenChange?: (open: boolean) => void;\n\n /**\n * The duration from when the pointer enters the trigger until the tooltip gets opened. This will\n * override the prop with the same name passed to Provider.\n * @defaultValue 700\n */\n delayDuration?: number;\n}\n\nconst Tooltip: React.FC<TooltipProps> = (props: ScopedProps<TooltipProps>) => {\n const {\n __scopeTooltip,\n children,\n open: openProp,\n defaultOpen = false,\n onOpenChange,\n delayDuration: delayDurationProp,\n } = props;\n const context = useTooltipProviderContext(TOOLTIP_NAME, __scopeTooltip);\n const popperScope = usePopperScope(__scopeTooltip);\n const [trigger, setTrigger] = React.useState<HTMLButtonElement | null>(null);\n const contentId = useId();\n const openTimerRef = React.useRef(0);\n const delayDuration = delayDurationProp ?? context.delayDuration;\n const wasOpenDelayedRef = React.useRef(false);\n const { onOpen, onClose } = context;\n const [open = false, setOpen] = useControllableState({\n prop: openProp,\n defaultProp: defaultOpen,\n onChange: (open) => {\n if (open) {\n // we dispatch here so `TooltipProvider` isn't required to\n // ensure other tooltips are aware of this one opening.\n //\n // as `onChange` is called within a lifecycle method we\n // avoid dispatching via `dispatchDiscreteCustomEvent`.\n document.dispatchEvent(new CustomEvent(TOOLTIP_OPEN));\n onOpen();\n }\n onOpenChange?.(open);\n },\n });\n const stateAttribute = React.useMemo(() => {\n return open ? (wasOpenDelayedRef.current ? 'delayed-open' : 'instant-open') : 'closed';\n }, [open]);\n\n const handleOpen = React.useCallback(() => {\n window.clearTimeout(openTimerRef.current);\n wasOpenDelayedRef.current = false;\n setOpen(true);\n }, [setOpen]);\n\n const handleDelayedOpen = React.useCallback(() => {\n window.clearTimeout(openTimerRef.current);\n openTimerRef.current = window.setTimeout(() => {\n wasOpenDelayedRef.current = true;\n setOpen(true);\n }, delayDuration);\n }, [delayDuration, setOpen]);\n\n React.useEffect(() => {\n return () => window.clearTimeout(openTimerRef.current);\n }, []);\n\n return (\n <PopperPrimitive.Root {...popperScope}>\n <TooltipContextProvider\n scope={__scopeTooltip}\n contentId={contentId}\n open={open}\n stateAttribute={stateAttribute}\n trigger={trigger}\n onTriggerChange={setTrigger}\n onTriggerEnter={React.useCallback(() => {\n if (context.isOpenDelayed) handleDelayedOpen();\n else handleOpen();\n }, [context.isOpenDelayed, handleDelayedOpen, handleOpen])}\n onOpen={React.useCallback(handleOpen, [handleOpen])}\n onClose={React.useCallback(() => {\n window.clearTimeout(openTimerRef.current);\n setOpen(false);\n onClose();\n }, [setOpen, onClose])}\n >\n {children}\n </TooltipContextProvider>\n </PopperPrimitive.Root>\n );\n};\n\nTooltip.displayName = TOOLTIP_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipTrigger\n * -----------------------------------------------------------------------------------------------*/\n\nconst TRIGGER_NAME = 'TooltipTrigger';\n\ntype TooltipTriggerElement = React.ElementRef<typeof Primitive.button>;\ntype PrimitiveButtonProps = Radix.ComponentPropsWithoutRef<typeof Primitive.button>;\ninterface TooltipTriggerProps extends PrimitiveButtonProps {}\n\nconst TooltipTrigger = React.forwardRef<TooltipTriggerElement, TooltipTriggerProps>(\n (props: ScopedProps<TooltipTriggerProps>, forwardedRef) => {\n const { __scopeTooltip, ...triggerProps } = props;\n const context = useTooltipContext(TRIGGER_NAME, __scopeTooltip);\n const popperScope = usePopperScope(__scopeTooltip);\n const composedTriggerRef = useComposedRefs(forwardedRef, context.onTriggerChange);\n const isPointerDownRef = React.useRef(false);\n const handlePointerUp = React.useCallback(() => (isPointerDownRef.current = false), []);\n\n React.useEffect(() => {\n return () => document.removeEventListener('pointerup', handlePointerUp);\n }, [handlePointerUp]);\n\n return (\n <PopperPrimitive.Anchor asChild {...popperScope}>\n <Primitive.button\n // We purposefully avoid adding `type=button` here because tooltip triggers are also\n // commonly anchors and the anchor `type` attribute signifies MIME type.\n aria-describedby={context.open ? context.contentId : undefined}\n data-state={context.stateAttribute}\n {...triggerProps}\n ref={composedTriggerRef}\n onPointerEnter={composeEventHandlers(props.onPointerEnter, (event) => {\n if (event.pointerType !== 'touch') context.onTriggerEnter();\n })}\n onPointerLeave={composeEventHandlers(props.onPointerLeave, context.onClose)}\n onPointerDown={composeEventHandlers(props.onPointerDown, () => {\n isPointerDownRef.current = true;\n document.addEventListener('pointerup', handlePointerUp, { once: true });\n })}\n onFocus={composeEventHandlers(props.onFocus, () => {\n if (!isPointerDownRef.current) context.onOpen();\n })}\n onBlur={composeEventHandlers(props.onBlur, context.onClose)}\n onClick={composeEventHandlers(props.onClick, (event) => {\n // keyboard click will occur under different conditions for different node\n // types so we use `onClick` instead of `onKeyDown` to respect that\n const isKeyboardClick = event.detail === 0;\n if (isKeyboardClick) context.onClose();\n })}\n />\n </PopperPrimitive.Anchor>\n );\n }\n);\n\nTooltipTrigger.displayName = TRIGGER_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipPortal\n * -----------------------------------------------------------------------------------------------*/\n\nconst PORTAL_NAME = 'TooltipPortal';\n\ntype PortalContextValue = { forceMount?: true };\nconst [PortalProvider, usePortalContext] = createTooltipContext<PortalContextValue>(PORTAL_NAME, {\n forceMount: undefined,\n});\n\ntype PortalProps = React.ComponentPropsWithoutRef<typeof UnstablePortal>;\ninterface TooltipPortalProps extends Omit<PortalProps, 'asChild'> {\n children?: React.ReactNode;\n /**\n * Used to force mounting when more control is needed. Useful when\n * controlling animation with React animation libraries.\n */\n forceMount?: true;\n}\n\nconst TooltipPortal: React.FC<TooltipPortalProps> = (props: ScopedProps<TooltipPortalProps>) => {\n const { __scopeTooltip, forceMount, children, container } = props;\n const context = useTooltipContext(PORTAL_NAME, __scopeTooltip);\n return (\n <PortalProvider scope={__scopeTooltip} forceMount={forceMount}>\n <Presence present={forceMount || context.open}>\n <UnstablePortal asChild container={container}>\n {children}\n </UnstablePortal>\n </Presence>\n </PortalProvider>\n );\n};\n\nTooltipPortal.displayName = PORTAL_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipContent\n * -----------------------------------------------------------------------------------------------*/\n\nconst CONTENT_NAME = 'TooltipContent';\n\ntype TooltipContentElement = TooltipContentImplElement;\ninterface TooltipContentProps extends TooltipContentImplProps {\n /**\n * Used to force mounting when more control is needed. Useful when\n * controlling animation with React animation libraries.\n */\n forceMount?: true;\n}\n\nconst TooltipContent = React.forwardRef<TooltipContentElement, TooltipContentProps>(\n (props: ScopedProps<TooltipContentProps>, forwardedRef) => {\n const portalContext = usePortalContext(CONTENT_NAME, props.__scopeTooltip);\n const { forceMount = portalContext.forceMount, ...contentProps } = props;\n const context = useTooltipContext(CONTENT_NAME, props.__scopeTooltip);\n return (\n <Presence present={forceMount || context.open}>\n <TooltipContentImpl ref={forwardedRef} {...contentProps} />\n </Presence>\n );\n }\n);\n\ntype TooltipContentImplElement = React.ElementRef<typeof PopperPrimitive.Content>;\ntype DismissableLayerProps = Radix.ComponentPropsWithoutRef<typeof DismissableLayer>;\ntype PopperContentProps = Radix.ComponentPropsWithoutRef<typeof PopperPrimitive.Content>;\ninterface TooltipContentImplProps extends PopperContentProps {\n /**\n * A more descriptive label for accessibility purpose\n */\n 'aria-label'?: string;\n\n /**\n * Event handler called when the escape key is down.\n * Can be prevented.\n */\n onEscapeKeyDown?: DismissableLayerProps['onEscapeKeyDown'];\n /**\n * Event handler called when the a `pointerdown` event happens outside of the `Tooltip`.\n * Can be prevented.\n */\n onPointerDownOutside?: DismissableLayerProps['onPointerDownOutside'];\n}\n\nconst TooltipContentImpl = React.forwardRef<TooltipContentImplElement, TooltipContentImplProps>(\n (props: ScopedProps<TooltipContentImplProps>, forwardedRef) => {\n const {\n __scopeTooltip,\n children,\n 'aria-label': ariaLabel,\n onEscapeKeyDown,\n onPointerDownOutside,\n ...contentProps\n } = props;\n const context = useTooltipContext(CONTENT_NAME, __scopeTooltip);\n const popperScope = usePopperScope(__scopeTooltip);\n const { onClose } = context;\n\n // Close this tooltip if another one opens\n React.useEffect(() => {\n document.addEventListener(TOOLTIP_OPEN, onClose);\n return () => document.removeEventListener(TOOLTIP_OPEN, onClose);\n }, [onClose]);\n\n // Close the tooltip if the trigger is scrolled\n React.useEffect(() => {\n if (context.trigger) {\n const handleScroll = (event: Event) => {\n const target = event.target as HTMLElement;\n if (target?.contains(context.trigger)) onClose();\n };\n window.addEventListener('scroll', handleScroll, { capture: true });\n return () => window.removeEventListener('scroll', handleScroll, { capture: true });\n }\n }, [context.trigger, onClose]);\n\n return (\n <DismissableLayer\n asChild\n disableOutsidePointerEvents={false}\n onEscapeKeyDown={onEscapeKeyDown}\n onPointerDownOutside={onPointerDownOutside}\n onFocusOutside={(event) => event.preventDefault()}\n onDismiss={onClose}\n >\n <PopperPrimitive.Content\n data-state={context.stateAttribute}\n {...popperScope}\n {...contentProps}\n ref={forwardedRef}\n style={{\n ...contentProps.style,\n // re-namespace exposed content custom property\n ['--radix-tooltip-content-transform-origin' as any]:\n 'var(--radix-popper-transform-origin)',\n }}\n >\n <Slottable>{children}</Slottable>\n <VisuallyHiddenPrimitive.Root id={context.contentId} role=\"tooltip\">\n {ariaLabel || children}\n </VisuallyHiddenPrimitive.Root>\n </PopperPrimitive.Content>\n </DismissableLayer>\n );\n }\n);\n\nTooltipContent.displayName = CONTENT_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * TooltipArrow\n * -----------------------------------------------------------------------------------------------*/\n\nconst ARROW_NAME = 'TooltipArrow';\n\ntype TooltipArrowElement = React.ElementRef<typeof PopperPrimitive.Arrow>;\ntype PopperArrowProps = Radix.ComponentPropsWithoutRef<typeof PopperPrimitive.Arrow>;\ninterface TooltipArrowProps extends PopperArrowProps {}\n\nconst TooltipArrow = React.forwardRef<TooltipArrowElement, TooltipArrowProps>(\n (props: ScopedProps<TooltipArrowProps>, forwardedRef) => {\n const { __scopeTooltip, ...arrowProps } = props;\n const popperScope = usePopperScope(__scopeTooltip);\n return <PopperPrimitive.Arrow {...popperScope} {...arrowProps} ref={forwardedRef} />;\n }\n);\n\nTooltipArrow.displayName = ARROW_NAME;\n\n/* -----------------------------------------------------------------------------------------------*/\n\nconst Provider = TooltipProvider;\nconst Root = Tooltip;\nconst Trigger = TooltipTrigger;\nconst Portal = TooltipPortal;\nconst Content = TooltipContent;\nconst Arrow = TooltipArrow;\n\nexport {\n createTooltipScope,\n //\n TooltipProvider,\n Tooltip,\n TooltipTrigger,\n TooltipPortal,\n TooltipContent,\n TooltipArrow,\n //\n Provider,\n Root,\n Trigger,\n Portal,\n Content,\n Arrow,\n};\nexport type {\n TooltipProps,\n TooltipTriggerProps,\n TooltipPortalProps,\n TooltipContentProps,\n TooltipArrowProps,\n};\n"],"names":["React","composeEventHandlers","useComposedRefs","createContextScope","DismissableLayer","useId","PopperPrimitive","createPopperScope","UnstablePortal","Presence","Primitive","Slottable","useControllableState","VisuallyHiddenPrimitive","createTooltipContext","createTooltipScope","usePopperScope","PROVIDER_NAME","DEFAULT_DELAY_DURATION","TOOLTIP_OPEN","TooltipProviderContextProvider","useTooltipProviderContext","isOpenDelayed","delayDuration","onOpen","onClose","TooltipProvider","props","__scopeTooltip","skipDelayDuration","children","setIsOpenDelayed","useState","skipDelayTimerRef","useRef","useEffect","skipDelayTimer","current","window","clearTimeout","useCallback","setTimeout","TOOLTIP_NAME","TooltipContextProvider","useTooltipContext","Tooltip","open","openProp","defaultOpen","onOpenChange","delayDurationProp","context","popperScope","trigger","setTrigger","contentId","openTimerRef","wasOpenDelayedRef","setOpen","prop","defaultProp","onChange","document","dispatchEvent","CustomEvent","stateAttribute","useMemo","handleOpen","handleDelayedOpen","TRIGGER_NAME","TooltipTrigger","forwardRef","forwardedRef","triggerProps","composedTriggerRef","onTriggerChange","isPointerDownRef","handlePointerUp","removeEventListener","undefined","onPointerEnter","event","pointerType","onTriggerEnter","onPointerLeave","onPointerDown","addEventListener","once","onFocus","onBlur","onClick","isKeyboardClick","detail","PORTAL_NAME","PortalProvider","usePortalContext","forceMount","TooltipPortal","container","CONTENT_NAME","TooltipContent","portalContext","contentProps","TooltipContentImpl","ariaLabel","onEscapeKeyDown","onPointerDownOutside","handleScroll","target","contains","capture","preventDefault","style","ARROW_NAME","TooltipArrow","arrowProps","Provider","Root","Trigger","Portal","Content","Arrow"],"version":3,"file":"index.module.js.map"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@radix-ui/react-tooltip",
|
|
3
|
-
"version": "0.1.8-rc.
|
|
3
|
+
"version": "0.1.8-rc.35",
|
|
4
4
|
"license": "MIT",
|
|
5
5
|
"source": "src/index.ts",
|
|
6
6
|
"main": "dist/index.js",
|
|
@@ -18,17 +18,17 @@
|
|
|
18
18
|
"dependencies": {
|
|
19
19
|
"@babel/runtime": "^7.13.10",
|
|
20
20
|
"@radix-ui/primitive": "0.1.0",
|
|
21
|
-
"@radix-ui/react-compose-refs": "0.1.1-rc.
|
|
22
|
-
"@radix-ui/react-context": "0.1.2-rc.
|
|
23
|
-
"@radix-ui/react-dismissable-layer": "0.1.6-rc.
|
|
24
|
-
"@radix-ui/react-id": "0.1.6-rc.
|
|
25
|
-
"@radix-ui/react-popper": "0.1.5-rc.
|
|
26
|
-
"@radix-ui/react-portal": "0.1.5-rc.
|
|
27
|
-
"@radix-ui/react-presence": "0.1.3-rc.
|
|
28
|
-
"@radix-ui/react-primitive": "0.1.5-rc.
|
|
29
|
-
"@radix-ui/react-slot": "0.1.3-rc.
|
|
30
|
-
"@radix-ui/react-use-controllable-state": "0.1.1-rc.
|
|
31
|
-
"@radix-ui/react-visually-hidden": "0.1.5-rc.
|
|
21
|
+
"@radix-ui/react-compose-refs": "0.1.1-rc.30",
|
|
22
|
+
"@radix-ui/react-context": "0.1.2-rc.30",
|
|
23
|
+
"@radix-ui/react-dismissable-layer": "0.1.6-rc.30",
|
|
24
|
+
"@radix-ui/react-id": "0.1.6-rc.30",
|
|
25
|
+
"@radix-ui/react-popper": "0.1.5-rc.30",
|
|
26
|
+
"@radix-ui/react-portal": "0.1.5-rc.30",
|
|
27
|
+
"@radix-ui/react-presence": "0.1.3-rc.30",
|
|
28
|
+
"@radix-ui/react-primitive": "0.1.5-rc.30",
|
|
29
|
+
"@radix-ui/react-slot": "0.1.3-rc.30",
|
|
30
|
+
"@radix-ui/react-use-controllable-state": "0.1.1-rc.30",
|
|
31
|
+
"@radix-ui/react-visually-hidden": "0.1.5-rc.30"
|
|
32
32
|
},
|
|
33
33
|
"peerDependencies": {
|
|
34
34
|
"react": "^16.8 || ^17.0 || ^18.0",
|