@telegraph/tooltip 0.0.2
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/CHANGELOG.md +19 -0
- package/README.md +17 -0
- package/dist/cjs/index.js +2 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/css/default.css +1 -0
- package/dist/esm/index.mjs +130 -0
- package/dist/esm/index.mjs.map +1 -0
- package/dist/types/Tooltip/Tooltip.d.ts +12 -0
- package/dist/types/Tooltip/Tooltip.d.ts.map +1 -0
- package/dist/types/Tooltip/index.d.ts +2 -0
- package/dist/types/Tooltip/index.d.ts.map +1 -0
- package/dist/types/index.d.ts +2 -0
- package/dist/types/index.d.ts.map +1 -0
- package/package.json +66 -0
package/CHANGELOG.md
ADDED
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
# @telegraph/tooltip
|
|
2
|
+
|
|
3
|
+
## 0.0.2
|
|
4
|
+
|
|
5
|
+
### Patch Changes
|
|
6
|
+
|
|
7
|
+
- [#128](https://github.com/knocklabs/telegraph/pull/128) [`0d709cc`](https://github.com/knocklabs/telegraph/commit/0d709cca3708aa976daa78added35260e9c02834) Thanks [@kylemcd](https://github.com/kylemcd)! - adds tooltip to copy button + fixes small fixes
|
|
8
|
+
|
|
9
|
+
## 0.0.1
|
|
10
|
+
|
|
11
|
+
### Patch Changes
|
|
12
|
+
|
|
13
|
+
- [#127](https://github.com/knocklabs/telegraph/pull/127) [`04e1459`](https://github.com/knocklabs/telegraph/commit/04e14597ed2148354923023b3668f63387ce63c4) Thanks [@kylemcd](https://github.com/kylemcd)! - tooltip + better themeing support
|
|
14
|
+
|
|
15
|
+
- Updated dependencies [[`04e1459`](https://github.com/knocklabs/telegraph/commit/04e14597ed2148354923023b3668f63387ce63c4), [`def3d89`](https://github.com/knocklabs/telegraph/commit/def3d89056aa54c0d24f74e33bc04df8efc712d9), [`790c5e0`](https://github.com/knocklabs/telegraph/commit/790c5e0626c9b99451214f892def9807165d9572)]:
|
|
16
|
+
- @telegraph/appearance@0.0.1
|
|
17
|
+
- @telegraph/typography@0.0.11
|
|
18
|
+
- @telegraph/layout@0.0.12
|
|
19
|
+
- @telegraph/helpers@0.0.2
|
package/README.md
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+

|
|
2
|
+
|
|
3
|
+
[](https://www.npmjs.com/package/@telegraph/tooltip)
|
|
4
|
+
|
|
5
|
+
# @telegraph/tooltip
|
|
6
|
+
> A simple tooltip component
|
|
7
|
+
|
|
8
|
+
## Installation Instructions
|
|
9
|
+
|
|
10
|
+
```
|
|
11
|
+
npm install @telegraph/tooltip
|
|
12
|
+
```
|
|
13
|
+
|
|
14
|
+
### Add stylesheet
|
|
15
|
+
```
|
|
16
|
+
@import "@telegraph/tooltip"
|
|
17
|
+
```
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react/jsx-runtime"),F=require("@radix-ui/react-tooltip"),v=require("@telegraph/appearance"),M=require("@telegraph/helpers"),_=require("@telegraph/layout"),q=require("@telegraph/typography"),R=require("framer-motion");function E(t){const i=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(t){for(const r in t)if(r!=="default"){const o=Object.getOwnPropertyDescriptor(t,r);Object.defineProperty(i,r,o.get?o:{enumerable:!0,get:()=>t[r]})}}return i.default=t,Object.freeze(i)}const n=E(F),P=({delayDuration:t=0,skipDelayDuration:i,disableHoverableContent:r,defaultOpen:o,open:u,onOpenChange:p,"aria-label":d,onEscapeKeyDown:f,onPointerDownOutside:g,forceMount:y,side:s="bottom",sideOffset:T=4,align:x="center",alignOffset:O,avoidCollisions:j,collisionBoundary:h,collisionPadding:m,arrowPadding:A,sticky:N,hideWhenDetached:b,label:c,labelProps:l,children:I})=>{const S=a=>{if(a==="top")return{y:-5};if(a==="bottom")return{y:5};if(a==="left")return{x:-5};if(a==="right")return{x:5}};return e.jsx(n.Provider,{delayDuration:t,skipDelayDuration:i,disableHoverableContent:r,children:e.jsxs(n.Root,{defaultOpen:o,open:u,onOpenChange:p,children:[e.jsx(n.Trigger,{asChild:!0,children:e.jsx(M.RefToTgphRef,{children:I})}),e.jsx(n.Portal,{children:e.jsx(n.Content,{"aria-label":d,onEscapeKeyDown:f,onPointerDownOutside:g,forceMount:y,side:s,sideOffset:T,align:x,alignOffset:O,avoidCollisions:j,collisionBoundary:h,collisionPadding:m,arrowPadding:A,sticky:N,hideWhenDetached:b,children:e.jsx(v.InvertedAppearance,{children:e.jsxs(_.Stack,{as:R.motion.div,className:"tgph",initial:{opacity:.5,scale:.6,...S(s)},animate:{opacity:1,scale:1,x:0,y:0},transition:{duration:.2,type:"spring",bounce:0},bg:"gray-1",rounded:"3",py:"2",px:"3",align:"center",justify:"center",style:{transformOrigin:"var(--radix-tooltip-content-transform-origin)"},...l?{labelProps:l}:{},children:[e.jsx(n.Arrow,{fill:"var(--tgph-gray-1)"}),typeof c=="string"?e.jsx(q.Text,{as:"span",size:"1",children:c}):c]})})})})]})})};exports.Tooltip=P;
|
|
2
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../src/Tooltip/Tooltip.tsx"],"sourcesContent":["import * as RadixTooltip from \"@radix-ui/react-tooltip\";\nimport { InvertedAppearance } from \"@telegraph/appearance\";\nimport {\n RefToTgphRef,\n type TgphComponentProps,\n type TgphElement,\n} from \"@telegraph/helpers\";\nimport { Stack } from \"@telegraph/layout\";\nimport { Text } from \"@telegraph/typography\";\nimport { motion } from \"framer-motion\";\nimport React from \"react\";\n\ntype TooltipBaseProps<T extends TgphElement> = {\n label: string | React.ReactNode;\n labelProps?: TgphComponentProps<typeof Stack<T>>;\n};\n\ntype TooltipProps<T extends TgphElement> = React.ComponentPropsWithoutRef<\n typeof RadixTooltip.Root\n> &\n React.ComponentPropsWithoutRef<typeof RadixTooltip.Provider> &\n React.ComponentPropsWithoutRef<typeof RadixTooltip.Content> &\n TooltipBaseProps<T>;\n\nconst Tooltip = <T extends TgphElement>({\n // Radix Tooltip Provider Props\n delayDuration = 0,\n skipDelayDuration,\n disableHoverableContent,\n // Radix Tooltip Root Props\n defaultOpen,\n open,\n onOpenChange,\n // Radix Tooltip Content Props\n \"aria-label\": ariaLabel,\n onEscapeKeyDown,\n onPointerDownOutside,\n forceMount,\n side = \"bottom\",\n sideOffset = 4,\n align = \"center\",\n alignOffset,\n avoidCollisions,\n collisionBoundary,\n collisionPadding,\n arrowPadding,\n sticky,\n hideWhenDetached,\n // Label Props\n label,\n labelProps,\n children,\n}: TooltipProps<T>) => {\n const deriveAnimationBasedOnSide = (side: TooltipProps<T>[\"side\"]) => {\n const ANIMATION_OFFSET = 5;\n if (side === \"top\") {\n return {\n y: -ANIMATION_OFFSET,\n };\n }\n\n if (side === \"bottom\") {\n return {\n y: ANIMATION_OFFSET,\n };\n }\n\n if (side === \"left\") {\n return {\n x: -ANIMATION_OFFSET,\n };\n }\n\n if (side === \"right\") {\n return {\n x: ANIMATION_OFFSET,\n };\n }\n };\n return (\n <RadixTooltip.Provider\n delayDuration={delayDuration}\n skipDelayDuration={skipDelayDuration}\n disableHoverableContent={disableHoverableContent}\n >\n <RadixTooltip.Root\n defaultOpen={defaultOpen}\n open={open}\n onOpenChange={onOpenChange}\n >\n <RadixTooltip.Trigger asChild={true}>\n <RefToTgphRef>{children}</RefToTgphRef>\n </RadixTooltip.Trigger>\n <RadixTooltip.Portal>\n <RadixTooltip.Content\n aria-label={ariaLabel}\n onEscapeKeyDown={onEscapeKeyDown}\n onPointerDownOutside={onPointerDownOutside}\n forceMount={forceMount}\n side={side}\n sideOffset={sideOffset}\n align={align}\n alignOffset={alignOffset}\n avoidCollisions={avoidCollisions}\n collisionBoundary={collisionBoundary}\n collisionPadding={collisionPadding}\n arrowPadding={arrowPadding}\n sticky={sticky}\n hideWhenDetached={hideWhenDetached}\n >\n <InvertedAppearance>\n <Stack\n as={motion.div}\n // Add tgph class so that this always works in portals\n className=\"tgph\"\n initial={{\n opacity: 0.5,\n scale: 0.6,\n ...deriveAnimationBasedOnSide(side),\n }}\n animate={{\n opacity: 1,\n scale: 1,\n x: 0,\n y: 0,\n }}\n transition={{ duration: 0.2, type: \"spring\", bounce: 0 }}\n bg=\"gray-1\"\n rounded=\"3\"\n py=\"2\"\n px=\"3\"\n align=\"center\"\n justify=\"center\"\n style={{\n transformOrigin:\n \"var(--radix-tooltip-content-transform-origin)\",\n }}\n {...(labelProps ? { labelProps } : {})}\n >\n <RadixTooltip.Arrow fill=\"var(--tgph-gray-1)\" />\n {typeof label === \"string\" ? (\n <Text as=\"span\" size=\"1\">\n {label}\n </Text>\n ) : (\n label\n )}\n </Stack>\n </InvertedAppearance>\n </RadixTooltip.Content>\n </RadixTooltip.Portal>\n </RadixTooltip.Root>\n </RadixTooltip.Provider>\n );\n};\n\nexport { Tooltip };\n"],"names":["Tooltip","delayDuration","skipDelayDuration","disableHoverableContent","defaultOpen","open","onOpenChange","ariaLabel","onEscapeKeyDown","onPointerDownOutside","forceMount","side","sideOffset","align","alignOffset","avoidCollisions","collisionBoundary","collisionPadding","arrowPadding","sticky","hideWhenDetached","label","labelProps","children","deriveAnimationBasedOnSide","jsx","RadixTooltip","jsxs","RefToTgphRef","InvertedAppearance","Stack","motion","Text"],"mappings":"olBAwBMA,EAAU,CAAwB,CAEtC,cAAAC,EAAgB,EAChB,kBAAAC,EACA,wBAAAC,EAEA,YAAAC,EACA,KAAAC,EACA,aAAAC,EAEA,aAAcC,EACd,gBAAAC,EACA,qBAAAC,EACA,WAAAC,EACA,KAAAC,EAAO,SACP,WAAAC,EAAa,EACb,MAAAC,EAAQ,SACR,YAAAC,EACA,gBAAAC,EACA,kBAAAC,EACA,iBAAAC,EACA,aAAAC,EACA,OAAAC,EACA,iBAAAC,EAEA,MAAAC,EACA,WAAAC,EACA,SAAAC,CACF,IAAuB,CACf,MAAAC,EAA8Bb,GAAkC,CAEpE,GAAIA,IAAS,MACJ,MAAA,CACL,EAAG,EAAC,EAIR,GAAIA,IAAS,SACJ,MAAA,CACL,EAAG,CAAA,EAIP,GAAIA,IAAS,OACJ,MAAA,CACL,EAAG,EAAC,EAIR,GAAIA,IAAS,QACJ,MAAA,CACL,EAAG,CAAA,CAEP,EAGA,OAAAc,EAAA,IAACC,EAAa,SAAb,CACC,cAAAzB,EACA,kBAAAC,EACA,wBAAAC,EAEA,SAAAwB,EAAA,KAACD,EAAa,KAAb,CACC,YAAAtB,EACA,KAAAC,EACA,aAAAC,EAEA,SAAA,CAACmB,EAAAA,IAAAC,EAAa,QAAb,CAAqB,QAAS,GAC7B,SAACD,EAAAA,IAAAG,EAAA,aAAA,CAAc,SAAAL,EAAS,CAC1B,CAAA,EACAE,EAAAA,IAACC,EAAa,OAAb,CACC,SAAAD,EAAA,IAACC,EAAa,QAAb,CACC,aAAYnB,EACZ,gBAAAC,EACA,qBAAAC,EACA,WAAAC,EACA,KAAAC,EACA,WAAAC,EACA,MAAAC,EACA,YAAAC,EACA,gBAAAC,EACA,kBAAAC,EACA,iBAAAC,EACA,aAAAC,EACA,OAAAC,EACA,iBAAAC,EAEA,eAACS,qBACC,CAAA,SAAAF,EAAA,KAACG,EAAA,MAAA,CACC,GAAIC,EAAO,OAAA,IAEX,UAAU,OACV,QAAS,CACP,QAAS,GACT,MAAO,GACP,GAAGP,EAA2Bb,CAAI,CACpC,EACA,QAAS,CACP,QAAS,EACT,MAAO,EACP,EAAG,EACH,EAAG,CACL,EACA,WAAY,CAAE,SAAU,GAAK,KAAM,SAAU,OAAQ,CAAE,EACvD,GAAG,SACH,QAAQ,IACR,GAAG,IACH,GAAG,IACH,MAAM,SACN,QAAQ,SACR,MAAO,CACL,gBACE,+CACJ,EACC,GAAIW,EAAa,CAAE,WAAAA,CAAA,EAAe,CAAC,EAEpC,SAAA,CAAAG,EAAAA,IAACC,EAAa,MAAb,CAAmB,KAAK,oBAAqB,CAAA,EAC7C,OAAOL,GAAU,SACfI,MAAAO,EAAAA,KAAA,CAAK,GAAG,OAAO,KAAK,IAClB,SAAAX,CAAA,CACH,EAEAA,CAAA,CAAA,CAAA,EAGN,CAAA,CAAA,EAEJ,CAAA,CAAA,CACF,CAAA,CAAA,CAGN"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.tgph :is(.sticky){position:sticky}.tgph :is(.transition){transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
import { jsx as r, jsxs as a } from "react/jsx-runtime";
|
|
2
|
+
import * as t from "@radix-ui/react-tooltip";
|
|
3
|
+
import { InvertedAppearance as M } from "@telegraph/appearance";
|
|
4
|
+
import { RefToTgphRef as _ } from "@telegraph/helpers";
|
|
5
|
+
import { Stack as R } from "@telegraph/layout";
|
|
6
|
+
import { Text as b } from "@telegraph/typography";
|
|
7
|
+
import { motion as j } from "framer-motion";
|
|
8
|
+
const D = ({
|
|
9
|
+
// Radix Tooltip Provider Props
|
|
10
|
+
delayDuration: p = 0,
|
|
11
|
+
skipDelayDuration: c,
|
|
12
|
+
disableHoverableContent: m,
|
|
13
|
+
// Radix Tooltip Root Props
|
|
14
|
+
defaultOpen: l,
|
|
15
|
+
open: f,
|
|
16
|
+
onOpenChange: s,
|
|
17
|
+
// Radix Tooltip Content Props
|
|
18
|
+
"aria-label": d,
|
|
19
|
+
onEscapeKeyDown: T,
|
|
20
|
+
onPointerDownOutside: g,
|
|
21
|
+
forceMount: h,
|
|
22
|
+
side: n = "bottom",
|
|
23
|
+
sideOffset: A = 4,
|
|
24
|
+
align: y = "center",
|
|
25
|
+
alignOffset: O,
|
|
26
|
+
avoidCollisions: I,
|
|
27
|
+
collisionBoundary: N,
|
|
28
|
+
collisionPadding: u,
|
|
29
|
+
arrowPadding: x,
|
|
30
|
+
sticky: F,
|
|
31
|
+
hideWhenDetached: S,
|
|
32
|
+
// Label Props
|
|
33
|
+
label: o,
|
|
34
|
+
labelProps: e,
|
|
35
|
+
children: v
|
|
36
|
+
}) => {
|
|
37
|
+
const E = (i) => {
|
|
38
|
+
if (i === "top")
|
|
39
|
+
return {
|
|
40
|
+
y: -5
|
|
41
|
+
};
|
|
42
|
+
if (i === "bottom")
|
|
43
|
+
return {
|
|
44
|
+
y: 5
|
|
45
|
+
};
|
|
46
|
+
if (i === "left")
|
|
47
|
+
return {
|
|
48
|
+
x: -5
|
|
49
|
+
};
|
|
50
|
+
if (i === "right")
|
|
51
|
+
return {
|
|
52
|
+
x: 5
|
|
53
|
+
};
|
|
54
|
+
};
|
|
55
|
+
return /* @__PURE__ */ r(
|
|
56
|
+
t.Provider,
|
|
57
|
+
{
|
|
58
|
+
delayDuration: p,
|
|
59
|
+
skipDelayDuration: c,
|
|
60
|
+
disableHoverableContent: m,
|
|
61
|
+
children: /* @__PURE__ */ a(
|
|
62
|
+
t.Root,
|
|
63
|
+
{
|
|
64
|
+
defaultOpen: l,
|
|
65
|
+
open: f,
|
|
66
|
+
onOpenChange: s,
|
|
67
|
+
children: [
|
|
68
|
+
/* @__PURE__ */ r(t.Trigger, { asChild: !0, children: /* @__PURE__ */ r(_, { children: v }) }),
|
|
69
|
+
/* @__PURE__ */ r(t.Portal, { children: /* @__PURE__ */ r(
|
|
70
|
+
t.Content,
|
|
71
|
+
{
|
|
72
|
+
"aria-label": d,
|
|
73
|
+
onEscapeKeyDown: T,
|
|
74
|
+
onPointerDownOutside: g,
|
|
75
|
+
forceMount: h,
|
|
76
|
+
side: n,
|
|
77
|
+
sideOffset: A,
|
|
78
|
+
align: y,
|
|
79
|
+
alignOffset: O,
|
|
80
|
+
avoidCollisions: I,
|
|
81
|
+
collisionBoundary: N,
|
|
82
|
+
collisionPadding: u,
|
|
83
|
+
arrowPadding: x,
|
|
84
|
+
sticky: F,
|
|
85
|
+
hideWhenDetached: S,
|
|
86
|
+
children: /* @__PURE__ */ r(M, { children: /* @__PURE__ */ a(
|
|
87
|
+
R,
|
|
88
|
+
{
|
|
89
|
+
as: j.div,
|
|
90
|
+
className: "tgph",
|
|
91
|
+
initial: {
|
|
92
|
+
opacity: 0.5,
|
|
93
|
+
scale: 0.6,
|
|
94
|
+
...E(n)
|
|
95
|
+
},
|
|
96
|
+
animate: {
|
|
97
|
+
opacity: 1,
|
|
98
|
+
scale: 1,
|
|
99
|
+
x: 0,
|
|
100
|
+
y: 0
|
|
101
|
+
},
|
|
102
|
+
transition: { duration: 0.2, type: "spring", bounce: 0 },
|
|
103
|
+
bg: "gray-1",
|
|
104
|
+
rounded: "3",
|
|
105
|
+
py: "2",
|
|
106
|
+
px: "3",
|
|
107
|
+
align: "center",
|
|
108
|
+
justify: "center",
|
|
109
|
+
style: {
|
|
110
|
+
transformOrigin: "var(--radix-tooltip-content-transform-origin)"
|
|
111
|
+
},
|
|
112
|
+
...e ? { labelProps: e } : {},
|
|
113
|
+
children: [
|
|
114
|
+
/* @__PURE__ */ r(t.Arrow, { fill: "var(--tgph-gray-1)" }),
|
|
115
|
+
typeof o == "string" ? /* @__PURE__ */ r(b, { as: "span", size: "1", children: o }) : o
|
|
116
|
+
]
|
|
117
|
+
}
|
|
118
|
+
) })
|
|
119
|
+
}
|
|
120
|
+
) })
|
|
121
|
+
]
|
|
122
|
+
}
|
|
123
|
+
)
|
|
124
|
+
}
|
|
125
|
+
);
|
|
126
|
+
};
|
|
127
|
+
export {
|
|
128
|
+
D as Tooltip
|
|
129
|
+
};
|
|
130
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../../src/Tooltip/Tooltip.tsx"],"sourcesContent":["import * as RadixTooltip from \"@radix-ui/react-tooltip\";\nimport { InvertedAppearance } from \"@telegraph/appearance\";\nimport {\n RefToTgphRef,\n type TgphComponentProps,\n type TgphElement,\n} from \"@telegraph/helpers\";\nimport { Stack } from \"@telegraph/layout\";\nimport { Text } from \"@telegraph/typography\";\nimport { motion } from \"framer-motion\";\nimport React from \"react\";\n\ntype TooltipBaseProps<T extends TgphElement> = {\n label: string | React.ReactNode;\n labelProps?: TgphComponentProps<typeof Stack<T>>;\n};\n\ntype TooltipProps<T extends TgphElement> = React.ComponentPropsWithoutRef<\n typeof RadixTooltip.Root\n> &\n React.ComponentPropsWithoutRef<typeof RadixTooltip.Provider> &\n React.ComponentPropsWithoutRef<typeof RadixTooltip.Content> &\n TooltipBaseProps<T>;\n\nconst Tooltip = <T extends TgphElement>({\n // Radix Tooltip Provider Props\n delayDuration = 0,\n skipDelayDuration,\n disableHoverableContent,\n // Radix Tooltip Root Props\n defaultOpen,\n open,\n onOpenChange,\n // Radix Tooltip Content Props\n \"aria-label\": ariaLabel,\n onEscapeKeyDown,\n onPointerDownOutside,\n forceMount,\n side = \"bottom\",\n sideOffset = 4,\n align = \"center\",\n alignOffset,\n avoidCollisions,\n collisionBoundary,\n collisionPadding,\n arrowPadding,\n sticky,\n hideWhenDetached,\n // Label Props\n label,\n labelProps,\n children,\n}: TooltipProps<T>) => {\n const deriveAnimationBasedOnSide = (side: TooltipProps<T>[\"side\"]) => {\n const ANIMATION_OFFSET = 5;\n if (side === \"top\") {\n return {\n y: -ANIMATION_OFFSET,\n };\n }\n\n if (side === \"bottom\") {\n return {\n y: ANIMATION_OFFSET,\n };\n }\n\n if (side === \"left\") {\n return {\n x: -ANIMATION_OFFSET,\n };\n }\n\n if (side === \"right\") {\n return {\n x: ANIMATION_OFFSET,\n };\n }\n };\n return (\n <RadixTooltip.Provider\n delayDuration={delayDuration}\n skipDelayDuration={skipDelayDuration}\n disableHoverableContent={disableHoverableContent}\n >\n <RadixTooltip.Root\n defaultOpen={defaultOpen}\n open={open}\n onOpenChange={onOpenChange}\n >\n <RadixTooltip.Trigger asChild={true}>\n <RefToTgphRef>{children}</RefToTgphRef>\n </RadixTooltip.Trigger>\n <RadixTooltip.Portal>\n <RadixTooltip.Content\n aria-label={ariaLabel}\n onEscapeKeyDown={onEscapeKeyDown}\n onPointerDownOutside={onPointerDownOutside}\n forceMount={forceMount}\n side={side}\n sideOffset={sideOffset}\n align={align}\n alignOffset={alignOffset}\n avoidCollisions={avoidCollisions}\n collisionBoundary={collisionBoundary}\n collisionPadding={collisionPadding}\n arrowPadding={arrowPadding}\n sticky={sticky}\n hideWhenDetached={hideWhenDetached}\n >\n <InvertedAppearance>\n <Stack\n as={motion.div}\n // Add tgph class so that this always works in portals\n className=\"tgph\"\n initial={{\n opacity: 0.5,\n scale: 0.6,\n ...deriveAnimationBasedOnSide(side),\n }}\n animate={{\n opacity: 1,\n scale: 1,\n x: 0,\n y: 0,\n }}\n transition={{ duration: 0.2, type: \"spring\", bounce: 0 }}\n bg=\"gray-1\"\n rounded=\"3\"\n py=\"2\"\n px=\"3\"\n align=\"center\"\n justify=\"center\"\n style={{\n transformOrigin:\n \"var(--radix-tooltip-content-transform-origin)\",\n }}\n {...(labelProps ? { labelProps } : {})}\n >\n <RadixTooltip.Arrow fill=\"var(--tgph-gray-1)\" />\n {typeof label === \"string\" ? (\n <Text as=\"span\" size=\"1\">\n {label}\n </Text>\n ) : (\n label\n )}\n </Stack>\n </InvertedAppearance>\n </RadixTooltip.Content>\n </RadixTooltip.Portal>\n </RadixTooltip.Root>\n </RadixTooltip.Provider>\n );\n};\n\nexport { Tooltip };\n"],"names":["Tooltip","delayDuration","skipDelayDuration","disableHoverableContent","defaultOpen","open","onOpenChange","ariaLabel","onEscapeKeyDown","onPointerDownOutside","forceMount","side","sideOffset","align","alignOffset","avoidCollisions","collisionBoundary","collisionPadding","arrowPadding","sticky","hideWhenDetached","label","labelProps","children","deriveAnimationBasedOnSide","jsx","RadixTooltip","jsxs","RefToTgphRef","InvertedAppearance","Stack","motion","Text"],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { TgphComponentProps, TgphElement } from '@telegraph/helpers';
|
|
2
|
+
import { Stack } from '@telegraph/layout';
|
|
3
|
+
import { default as React } from 'react';
|
|
4
|
+
import * as RadixTooltip from "@radix-ui/react-tooltip";
|
|
5
|
+
type TooltipBaseProps<T extends TgphElement> = {
|
|
6
|
+
label: string | React.ReactNode;
|
|
7
|
+
labelProps?: TgphComponentProps<typeof Stack<T>>;
|
|
8
|
+
};
|
|
9
|
+
type TooltipProps<T extends TgphElement> = React.ComponentPropsWithoutRef<typeof RadixTooltip.Root> & React.ComponentPropsWithoutRef<typeof RadixTooltip.Provider> & React.ComponentPropsWithoutRef<typeof RadixTooltip.Content> & TooltipBaseProps<T>;
|
|
10
|
+
declare const Tooltip: <T extends TgphElement>({ delayDuration, skipDelayDuration, disableHoverableContent, defaultOpen, open, onOpenChange, "aria-label": ariaLabel, onEscapeKeyDown, onPointerDownOutside, forceMount, side, sideOffset, align, alignOffset, avoidCollisions, collisionBoundary, collisionPadding, arrowPadding, sticky, hideWhenDetached, label, labelProps, children, }: TooltipProps<T>) => import("react/jsx-runtime").JSX.Element;
|
|
11
|
+
export { Tooltip };
|
|
12
|
+
//# sourceMappingURL=Tooltip.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Tooltip.d.ts","sourceRoot":"","sources":["../../../src/Tooltip/Tooltip.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,YAAY,MAAM,yBAAyB,CAAC;AAExD,OAAO,EAEL,KAAK,kBAAkB,EACvB,KAAK,WAAW,EACjB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAG1C,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,KAAK,gBAAgB,CAAC,CAAC,SAAS,WAAW,IAAI;IAC7C,KAAK,EAAE,MAAM,GAAG,KAAK,CAAC,SAAS,CAAC;IAChC,UAAU,CAAC,EAAE,kBAAkB,CAAC,OAAO,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;CAClD,CAAC;AAEF,KAAK,YAAY,CAAC,CAAC,SAAS,WAAW,IAAI,KAAK,CAAC,wBAAwB,CACvE,OAAO,YAAY,CAAC,IAAI,CACzB,GACC,KAAK,CAAC,wBAAwB,CAAC,OAAO,YAAY,CAAC,QAAQ,CAAC,GAC5D,KAAK,CAAC,wBAAwB,CAAC,OAAO,YAAY,CAAC,OAAO,CAAC,GAC3D,gBAAgB,CAAC,CAAC,CAAC,CAAC;AAEtB,QAAA,MAAM,OAAO,wWA4BV,aAAa,CAAC,CAAC,4CAsGjB,CAAC;AAEF,OAAO,EAAE,OAAO,EAAE,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/Tooltip/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC"}
|
package/package.json
ADDED
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@telegraph/tooltip",
|
|
3
|
+
"version": "0.0.2",
|
|
4
|
+
"description": "A simple tooltip component ",
|
|
5
|
+
"repository": "https://github.com/knocklabs/telegraph/tree/main/packages/tooltip",
|
|
6
|
+
"author": "@knocklabs",
|
|
7
|
+
"license": "MIT",
|
|
8
|
+
"main": "./dist/cjs/index.js",
|
|
9
|
+
"module": "./dist/esm/index.mjs",
|
|
10
|
+
"types": "./dist/types/index.d.ts",
|
|
11
|
+
"exports": {
|
|
12
|
+
".": {
|
|
13
|
+
"import": "./dist/esm/index.mjs",
|
|
14
|
+
"require": "./dist/cjs/index.js",
|
|
15
|
+
"types": "./dist/types/index.d.ts",
|
|
16
|
+
"default": "./dist/css/default.css"
|
|
17
|
+
},
|
|
18
|
+
"./default.css": "./dist/css/default.css"
|
|
19
|
+
},
|
|
20
|
+
"files": [
|
|
21
|
+
"dist",
|
|
22
|
+
"README.md"
|
|
23
|
+
],
|
|
24
|
+
"prettier": "@telegraph/prettier-config",
|
|
25
|
+
"scripts": {
|
|
26
|
+
"clean": "rm -rf dist",
|
|
27
|
+
"dev": "vite build --watch --emptyOutDir false",
|
|
28
|
+
"build": "yarn clean && vite build",
|
|
29
|
+
"//test": "vitest run",
|
|
30
|
+
"//test:watch": "vitest",
|
|
31
|
+
"coverage": "vitest run --coverage",
|
|
32
|
+
"lint": "eslint . --ext ts,tsx --report-unused-disable-directives --max-warnings 0",
|
|
33
|
+
"format": "prettier \"src/**/*.{js,ts,tsx}\" --write",
|
|
34
|
+
"format:check": "prettier \"src/**/*.{js,ts,tsx}\" --check",
|
|
35
|
+
"preview": "vite preview"
|
|
36
|
+
},
|
|
37
|
+
"dependencies": {
|
|
38
|
+
"@radix-ui/react-slot": "^1.0.2",
|
|
39
|
+
"@radix-ui/react-tooltip": "^1.0.7",
|
|
40
|
+
"@telegraph/appearance": "^0.0.1",
|
|
41
|
+
"@telegraph/helpers": "^0.0.2",
|
|
42
|
+
"@telegraph/layout": "^0.0.12",
|
|
43
|
+
"@telegraph/typography": "^0.0.11",
|
|
44
|
+
"framer-motion": "^11.1.9"
|
|
45
|
+
},
|
|
46
|
+
"devDependencies": {
|
|
47
|
+
"@knocklabs/eslint-config": "^0.0.3",
|
|
48
|
+
"@knocklabs/typescript-config": "^0.0.2",
|
|
49
|
+
"@telegraph/postcss-config": "^0.0.16",
|
|
50
|
+
"@telegraph/prettier-config": "^0.0.6",
|
|
51
|
+
"@telegraph/tailwind-config": "^0.0.11",
|
|
52
|
+
"@telegraph/vite-config": "^0.0.9",
|
|
53
|
+
"@telegraph/vitest-config": "^0.0.6",
|
|
54
|
+
"@types/react": "^18.2.48",
|
|
55
|
+
"eslint": "^8.56.0",
|
|
56
|
+
"react": "^18.2.0",
|
|
57
|
+
"react-dom": "^18.2.0",
|
|
58
|
+
"typescript": "^5.3.3",
|
|
59
|
+
"vite": "^5.2.13",
|
|
60
|
+
"vitest": "^1.2.2"
|
|
61
|
+
},
|
|
62
|
+
"peerDependencies": {
|
|
63
|
+
"react": "^18.2.0",
|
|
64
|
+
"react-dom": "^18.2.0"
|
|
65
|
+
}
|
|
66
|
+
}
|