Files
210486d3-6206-48c4-a5d3-cdf…/src/app/layout.tsx
2026-06-11 15:09:52 +00:00

78 lines
2.5 KiB
TypeScript

import type { Metadata } from "next";
import { Halant } from "next/font/google";
import { Inter } from "next/font/google";
import "./globals.css";
import "@/lib/gsap-setup";
import { ServiceWrapper } from "@/components/ServiceWrapper";
import Tag from "@/tag/Tag";
import { getVisualEditScript } from "@/utils/visual-edit-script";
import { DM_Sans } from "next/font/google";
import { Figtree } from "next/font/google";
import { Manrope } from "next/font/google";
export const metadata: Metadata = {
title: 'ÉditeurPro | SaaS B2B pour Éditeurs Freelance',
description: 'La plateforme SaaS de pointe pour les éditeurs de livre freelance. Optimisez la relecture, la collaboration et la gestion de projet avec des outils puissants et un design luxueux.',
keywords: ["SaaS B2B, éditeur freelance, édition livre, relecture IA, gestion de projet, collaboration, logiciel édition, ÉditeurPro"],
openGraph: {
"title": "ÉditeurPro | Révolutionnez votre Édition Freelance",
"description": "La plateforme SaaS de pointe pour les éditeurs de livre freelance. Optimisez la relecture, la collaboration et la gestion de projet avec des outils puissants et un design luxueux.",
"url": "https://www.editeurpro.com",
"siteName": "ÉditeurPro",
"images": [
{
"url": "http://img.b2bpic.net/free-photo/tablet-heap-books_23-2147845956.jpg",
"alt": "Interface ÉditeurPro pour éditeurs de livre freelance"
}
],
"type": "website"
},
twitter: {
"card": "summary_large_image",
"title": "ÉditeurPro | SaaS B2B pour Éditeurs Freelance",
"description": "Optimisez votre relecture et collaboration avec ÉditeurPro, la solution luxe pour les éditeurs de livre freelance.",
"images": [
"http://img.b2bpic.net/free-photo/tablet-heap-books_23-2147845956.jpg"
]
},
robots: {
"index": true,
"follow": true
},
};
const manrope = Manrope({
variable: "--font-manrope",
subsets: ["latin"],
});
const dmSans = DM_Sans({
variable: "--font-dm-sans",
subsets: ["latin"],
});
export default function RootLayout({
children,
}: Readonly<{
children: React.ReactNode;
}>) {
return (
<html lang="en" suppressHydrationWarning>
<ServiceWrapper>
<body className={`${manrope.variable} ${dmSans.variable} antialiased`}>
<Tag />
{children}
<script
dangerouslySetInnerHTML={{
__html: `${getVisualEditScript()}`
}}
/>
</body>
</ServiceWrapper>
</html>
);
}