aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/docs/components/logos/TurboAnimated.tsx
diff options
context:
space:
mode:
authorHsiangNianian <admin@jyunko.cn>2023-04-22 19:52:26 +0800
committerHsiangNianian <admin@jyunko.cn>2023-04-22 19:52:26 +0800
commit4838df315931bb883f704ec3e1abe2685f296cdf (patch)
tree57a8550c4cd5338f1126364bb518c6cde8d96e7d /docs/components/logos/TurboAnimated.tsx
parentdb74ade0234a40c2120ad5f2a41bee50ce13de02 (diff)
downloadHydroRoll-4838df315931bb883f704ec3e1abe2685f296cdf.tar.gz
HydroRoll-4838df315931bb883f704ec3e1abe2685f296cdf.zip
😀
Diffstat (limited to 'docs/components/logos/TurboAnimated.tsx')
-rw-r--r--docs/components/logos/TurboAnimated.tsx157
1 files changed, 157 insertions, 0 deletions
diff --git a/docs/components/logos/TurboAnimated.tsx b/docs/components/logos/TurboAnimated.tsx
new file mode 100644
index 0000000..c70f42d
--- /dev/null
+++ b/docs/components/logos/TurboAnimated.tsx
@@ -0,0 +1,157 @@
+import { AnimatePresence, motion, Variants } from "framer-motion";
+import { useTurboSite } from "../SiteSwitcher";
+import cn from "classnames";
+import styles from "../header-logo.module.css";
+
+type LogoProps = {
+ className?: string;
+ height?: number;
+};
+
+const LEFT_PADDING = 8;
+const RIGHT_PADDING = 12;
+// The width of the logo + wordmark. This does not include the "invisible" padding.
+const VISUAL_WIDTH = 112;
+
+const TurboAnimated = ({ height = 32, className = "" }: LogoProps) => {
+ const site = useTurboSite();
+
+ return (
+ <svg
+ className={className}
+ width={LEFT_PADDING + VISUAL_WIDTH}
+ height={height}
+ viewBox={`0 0 ${LEFT_PADDING + VISUAL_WIDTH} 28`}
+ fill="none"
+ xmlns="http://www.w3.org/2000/svg"
+ >
+ <title>Turborepo</title>
+
+ <defs>
+ <linearGradient
+ id="logo-ring-gradient"
+ x1="15.0234"
+ y1="4.00556"
+ x2="3.64419"
+ y2="15.3847"
+ gradientUnits="userSpaceOnUse"
+ >
+ <stop stopColor="#0096FF" />
+ <stop offset="1" stopColor="#FF1E56" />
+ </linearGradient>
+ <linearGradient id="gradient">
+ <stop offset="0%" stopColor="#000000" />
+ <stop offset="25%" stopColor="#ffffff" />
+ <stop offset="85%" stopColor="#ffffff" />
+ <stop offset="100%" stopColor="#000000" />
+ </linearGradient>
+ <mask id="logo-mask">
+ <rect
+ x="0"
+ y="0"
+ width={`${26 + LEFT_PADDING + RIGHT_PADDING}`}
+ height="26"
+ fill="url(#gradient)"
+ transform="translate(-8,0)"
+ />
+ </mask>
+ </defs>
+
+ <g mask="url(#logo-mask)" transform={`translate(${LEFT_PADDING},0)`}>
+ <AnimatePresence mode="sync" initial={false}>
+ {site === "repo" || site === undefined ? (
+ <motion.g
+ key="turborepo"
+ variants={variants}
+ initial="hidden"
+ animate="visible"
+ exit="hidden"
+ custom={24}
+ className="z-0 relative"
+ >
+ <path
+ d="M13.9396 6.42181C9.79423 6.42181 6.42163 9.79441 6.42163 13.9398C6.42163 18.0852 9.79423 21.4578 13.9396 21.4578C18.085 21.4578 21.4576 18.0852 21.4576 13.9398C21.4576 9.79441 18.085 6.42181 13.9396 6.42181ZM13.9396 17.8304C11.7906 17.8304 10.049 16.0888 10.049 13.9398C10.049 11.7908 11.7906 10.0492 13.9396 10.0492C16.0886 10.0492 17.8302 11.7908 17.8302 13.9398C17.8302 16.0888 16.0886 17.8304 13.9396 17.8304Z"
+ className="dark:fill-white fill-black"
+ />
+ <path
+ fillRule="evenodd"
+ clipRule="evenodd"
+ d="M14.5697 5.187V2.38C20.6709 2.7062 25.5177 7.7574 25.5177 13.9398C25.5177 20.1222 20.6709 25.172 14.5697 25.4996V22.6926C19.1169 22.3678 22.7177 18.5682 22.7177 13.9398C22.7177 9.3114 19.1169 5.5118 14.5697 5.187ZM7.30928 19.6798C6.10388 18.2882 5.32688 16.5158 5.18828 14.5698H2.37988C2.52548 17.2928 3.61468 19.7638 5.32128 21.6664L7.30788 19.6798H7.30928ZM13.3097 25.4996V22.6926C11.3623 22.554 9.5899 21.7784 8.1983 20.5716L6.2117 22.5582C8.1157 24.2662 10.5867 25.354 13.3083 25.4996H13.3097Z"
+ fill="url(#logo-ring-gradient)"
+ />
+ </motion.g>
+ ) : (
+ <motion.g
+ key="turbopack"
+ variants={variants}
+ initial="hidden"
+ animate="visible"
+ exit="hidden"
+ custom={-24}
+ className="z-0 relative"
+ >
+ <path
+ fillRule="evenodd"
+ clipRule="evenodd"
+ d="M10.9443 10.4846C10.6829 10.4846 10.4709 10.6966 10.4709 10.958V16.2234C10.4709 16.4849 10.6829 16.6968 10.9443 16.6968H16.2097C16.4712 16.6968 16.6831 16.4849 16.6831 16.2234V10.958C16.6831 10.6966 16.4712 10.4846 16.2097 10.4846H10.9443ZM7.14628 6.72631C6.90676 6.72631 6.71263 6.92045 6.71263 7.15994V20.0215C6.71263 20.261 6.90676 20.4551 7.14628 20.4551H20.0078C20.2473 20.4551 20.4414 20.261 20.4414 20.0215V7.15994C20.4414 6.92045 20.2473 6.72631 20.0078 6.72631H7.14628Z"
+ className="dark:fill-white fill-black"
+ />
+ <path
+ fillRule="evenodd"
+ clipRule="evenodd"
+ d="M2 13.8059V22.1684C2 22.7295 2.15656 23.254 2.42838 23.7007L5.44339 20.6857V13.8059H2ZM3.37481 24.664L6.36423 21.6745C6.38505 21.6758 6.40605 21.6765 6.42723 21.6765H13.0144V25.12H4.95147C4.37169 25.12 3.83094 24.9528 3.37481 24.664ZM14.3648 25.12H22.1684C23.7985 25.12 25.12 23.7985 25.12 22.1684V4.95147C25.12 3.32142 23.7985 2 22.1684 2H13.8059V5.44339H20.6927C21.236 5.44339 21.6765 5.88386 21.6765 6.42723V20.6927C21.6765 21.2361 21.236 21.6765 20.6927 21.6765H14.3648V25.12Z"
+ fill="url(#logo-ring-gradient)"
+ />
+ </motion.g>
+ )}
+ </AnimatePresence>
+ </g>
+
+ {/* Turbo Wordmark */}
+ <g
+ className={cn("z-10 relative", styles.desktopLogo)}
+ transform={`translate(${LEFT_PADDING},0)`}
+ >
+ <path
+ d="M48.2623 11.2944V8.24418H33.5623V11.2944H39.1115V21.4374H42.713V11.2944H48.2623Z"
+ className="dark:fill-white fill-black"
+ />
+ <path
+ d="M56.5679 21.6396C61.0882 21.6396 63.5688 19.3427 63.5688 15.5574V8.24418H59.9673V15.2083C59.9673 17.3214 58.8648 18.5158 56.5679 18.5158C54.271 18.5158 53.1685 17.3214 53.1685 15.2083V8.24418H49.567V15.5574C49.567 19.3427 52.0476 21.6396 56.5679 21.6396Z"
+ className="dark:fill-white fill-black"
+ />
+ <path
+ d="M69.0819 17.0642H72.665L75.4947 21.4374H79.6291L76.4319 16.6783C78.2326 16.0352 79.3351 14.6019 79.3351 12.6542C79.3351 9.82443 77.222 8.24418 74.0064 8.24418H65.4804V21.4374H69.0819V17.0642ZM69.0819 14.2161V11.2577H73.8226C75.0905 11.2577 75.7887 11.8089 75.7887 12.7461C75.7887 13.6281 75.0905 14.2161 73.8226 14.2161H69.0819Z"
+ className="dark:fill-white fill-black"
+ />
+ <path
+ d="M81.0108 21.4374H90.4372C93.3772 21.4374 95.0677 20.0409 95.0677 17.7073C95.0677 16.1454 94.0754 15.0797 92.8994 14.6019C93.7079 14.2161 94.7002 13.2973 94.7002 11.8457C94.7002 9.51206 93.0464 8.24418 90.1248 8.24418H81.0108V21.4374ZM84.4653 13.4076V11.1658H89.7573C90.7496 11.1658 91.3008 11.5517 91.3008 12.2867C91.3008 13.0217 90.7496 13.4076 89.7573 13.4076H84.4653ZM84.4653 16.1087H90.0881C91.0619 16.1087 91.5948 16.5864 91.5948 17.3031C91.5948 18.0197 91.0619 18.4974 90.0881 18.4974H84.4653V16.1087Z"
+ className="dark:fill-white fill-black"
+ />
+ <path
+ d="M103.873 8.02368C99.2612 8.02368 95.9353 10.9086 95.9353 14.8408C95.9353 18.7731 99.2612 21.6579 103.873 21.6579C108.485 21.6579 111.793 18.7731 111.793 14.8408C111.793 10.9086 108.485 8.02368 103.873 8.02368ZM103.873 11.1474C106.299 11.1474 108.118 12.5807 108.118 14.8408C108.118 17.1009 106.299 18.5342 103.873 18.5342C101.448 18.5342 99.6287 17.1009 99.6287 14.8408C99.6287 12.5807 101.448 11.1474 103.873 11.1474Z"
+ className="dark:fill-white fill-black"
+ />
+ </g>
+ </svg>
+ );
+};
+
+export default TurboAnimated;
+
+const variants: Variants = {
+ visible: {
+ opacity: 1,
+ x: 0,
+ transition: {
+ duration: 0.3,
+ },
+ },
+ hidden: (distance) => ({
+ opacity: 0,
+ x: distance,
+ transition: {
+ duration: 0.3,
+ },
+ }),
+};