-
Notifications
You must be signed in to change notification settings - Fork 97
/
Copy pathframe.json
21 lines (21 loc) · 2.71 KB
/
frame.json
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
{
"name": "frame",
"type": "registry:ui",
"registryDependencies": [],
"dependencies": [
"motion"
],
"devDependencies": [],
"tailwind": {},
"cssVars": {
"light": {},
"dark": {}
},
"files": [
{
"path": "frame.tsx",
"content": "'use client';\n\nimport type { Transition } from 'motion/react';\nimport { motion, useAnimation } from 'motion/react';\n\nconst defaultTransition: Transition = {\n type: 'spring',\n stiffness: 160,\n damping: 17,\n mass: 1,\n};\n\nconst FrameIcon = () => {\n const controls = useAnimation();\n\n return (\n <div\n className=\"cursor-pointer select-none p-2 hover:bg-accent rounded-md transition-colors duration-200 flex items-center justify-center\"\n onMouseEnter={() => controls.start('animate')}\n onMouseLeave={() => controls.start('normal')}\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width={28}\n height={28}\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth={2}\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n >\n <motion.line\n variants={{\n animate: { translateY: -4 },\n normal: {\n translateX: 0,\n rotate: 0,\n translateY: 0,\n },\n }}\n animate={controls}\n transition={defaultTransition}\n x1={22}\n x2={2}\n y1={6}\n y2={6}\n />\n <motion.line\n variants={{\n animate: { translateY: 4 },\n normal: {\n translateX: 0,\n rotate: 0,\n translateY: 0,\n },\n }}\n animate={controls}\n transition={defaultTransition}\n x1={22}\n x2={2}\n y1={18}\n y2={18}\n />\n <motion.line\n variants={{\n animate: { translateX: -4 },\n normal: {\n translateX: 0,\n rotate: 0,\n translateY: 0,\n },\n }}\n animate={controls}\n transition={defaultTransition}\n x1={6}\n x2={6}\n y1={2}\n y2={22}\n />\n <motion.line\n variants={{\n animate: { translateX: 4 },\n normal: {\n translateX: 0,\n rotate: 0,\n translateY: 0,\n },\n }}\n animate={controls}\n transition={defaultTransition}\n x1={18}\n x2={18}\n y1={2}\n y2={22}\n />\n </svg>\n </div>\n );\n};\n\nexport { FrameIcon };\n",
"type": "registry:ui"
}
]
}