mirror of
https://github.com/makeplane/plane.git
synced 2025-12-24 15:49:36 +01:00
104 lines
4.4 KiB
TypeScript
104 lines
4.4 KiB
TypeScript
import Script from "next/script";
|
|
|
|
// styles
|
|
import "@/styles/globals.css";
|
|
|
|
import { SITE_DESCRIPTION, SITE_NAME } from "@plane/constants";
|
|
|
|
// helpers
|
|
import { cn } from "@plane/utils";
|
|
|
|
// assets
|
|
import favicon16 from "@/app/assets/favicon/favicon-16x16.png?url";
|
|
import favicon32 from "@/app/assets/favicon/favicon-32x32.png?url";
|
|
import faviconIco from "@/app/assets/favicon/favicon.ico?url";
|
|
import icon180 from "@/app/assets/icons/icon-180x180.png?url";
|
|
import icon512 from "@/app/assets/icons/icon-512x512.png?url";
|
|
|
|
// local
|
|
import { AppProvider } from "./provider";
|
|
|
|
export const meta = () => [
|
|
{ title: "Plane | Simple, extensible, open-source project management tool." },
|
|
{ name: "description", content: SITE_DESCRIPTION },
|
|
{
|
|
name: "keywords",
|
|
content:
|
|
"software development, plan, ship, software, accelerate, code management, release management, project management, work item tracking, agile, scrum, kanban, collaboration",
|
|
},
|
|
{
|
|
name: "viewport",
|
|
content:
|
|
"width=device-width, initial-scale=1, minimum-scale=1, maximum-scale=1, user-scalable=no, viewport-fit=cover",
|
|
},
|
|
{ property: "og:title", content: "Plane | Simple, extensible, open-source project management tool." },
|
|
{
|
|
property: "og:description",
|
|
content: "Open-source project management tool to manage work items, cycles, and product roadmaps easily",
|
|
},
|
|
{ property: "og:url", content: "https://app.plane.so/" },
|
|
{ property: "og:image", content: "https://app.plane.so/og-image.png" },
|
|
{ property: "og:image:width", content: "1200" },
|
|
{ property: "og:image:height", content: "630" },
|
|
{ property: "og:image:alt", content: "Plane - Modern project management" },
|
|
{ name: "twitter:site", content: "@planepowers" },
|
|
{ name: "twitter:card", content: "summary_large_image" },
|
|
{ name: "twitter:image", content: "https://app.plane.so/og-image.png" },
|
|
{ name: "twitter:image:width", content: "1200" },
|
|
{ name: "twitter:image:height", content: "630" },
|
|
{ name: "twitter:image:alt", content: "Plane - Modern project management" },
|
|
];
|
|
|
|
export default function RootLayout({ children }: { children: React.ReactNode }) {
|
|
const isSessionRecorderEnabled = parseInt(process.env.NEXT_PUBLIC_ENABLE_SESSION_RECORDER || "0");
|
|
|
|
return (
|
|
<html lang="en">
|
|
<head>
|
|
<meta name="theme-color" content="#fff" />
|
|
<link rel="icon" type="image/png" sizes="32x32" href={favicon32} />
|
|
<link rel="icon" type="image/png" sizes="16x16" href={favicon16} />
|
|
<link rel="manifest" href="/site.webmanifest.json" />
|
|
<link rel="shortcut icon" href={faviconIco} />
|
|
{/* Meta info for PWA */}
|
|
<meta name="application-name" content="Plane" />
|
|
<meta name="apple-mobile-web-app-capable" content="yes" />
|
|
<meta name="apple-mobile-web-app-status-bar-style" content="default" />
|
|
<meta name="apple-mobile-web-app-title" content={SITE_NAME} />
|
|
<meta name="format-detection" content="telephone=no" />
|
|
<meta name="mobile-web-app-capable" content="yes" />
|
|
<link rel="apple-touch-icon" href={icon512} />
|
|
<link rel="apple-touch-icon" sizes="180x180" href={icon180} />
|
|
<link rel="apple-touch-icon" sizes="512x512" href={icon512} />
|
|
<link rel="manifest" href="/manifest.json" />
|
|
</head>
|
|
<body>
|
|
<div id="context-menu-portal" />
|
|
<div id="editor-portal" />
|
|
<AppProvider>
|
|
<div
|
|
className={cn(
|
|
"h-screen w-full overflow-hidden bg-custom-background-100 relative flex flex-col",
|
|
"app-container"
|
|
)}
|
|
>
|
|
<main className="w-full h-full overflow-hidden relative">{children}</main>
|
|
</div>
|
|
</AppProvider>
|
|
</body>
|
|
{process.env.NEXT_PUBLIC_PLAUSIBLE_DOMAIN && (
|
|
<Script defer data-domain={process.env.NEXT_PUBLIC_PLAUSIBLE_DOMAIN} src="https://plausible.io/js/script.js" />
|
|
)}
|
|
{!!isSessionRecorderEnabled && process.env.NEXT_PUBLIC_SESSION_RECORDER_KEY && (
|
|
<Script id="clarity-tracking">
|
|
{`(function(c,l,a,r,i,t,y){
|
|
c[a]=c[a]||function(){(c[a].q=c[a].q||[]).push(arguments)};
|
|
t=l.createElement(r);t.async=1;t.src="https://www.clarity.ms/tag/"+i;
|
|
y=l.getElementsByTagName(r)[0];if(y){y.parentNode.insertBefore(t,y);}
|
|
})(window, document, "clarity", "script", "${process.env.NEXT_PUBLIC_SESSION_RECORDER_KEY}");`}
|
|
</Script>
|
|
)}
|
|
</html>
|
|
);
|
|
}
|