// @ts-check // Note: type annotations allow type checking and IDEs autocompletion require("dotenv").config(); const lightCodeTheme = require("prism-react-renderer/themes/github"); const darkCodeTheme = require("prism-react-renderer/themes/dracula"); /** @type {import('@docusaurus/types').Config} */ const config = { title: "Jan", tagline: "Run your own AI", favicon: "img/favicon.ico", // Set the production url of your site here url: "https://jan.ai", // Set the // pathname under which your site is served // For GitHub pages deployment, it is often '//' baseUrl: "/", // GitHub pages deployment config. // If you aren't using GitHub pages, you don't need these. organizationName: "janhq", // Usually your GitHub org/user name. projectName: "jan", // Usually your repo name. onBrokenLinks: "warn", onBrokenMarkdownLinks: "warn", trailingSlash: true, // Even if you don't use internalization, you can use this field to set useful // metadata like html lang. For example, if your site is Chinese, you may want // to replace "en" with "zh-Hans". i18n: { defaultLocale: "en", locales: ["en"], }, markdown: { mermaid: true, }, noIndex: false, // Plugins we added plugins: [ "docusaurus-plugin-sass", async function myPlugin(context, options) { return { name: "docusaurus-tailwindcss", configurePostCss(postcssOptions) { // Appends TailwindCSS and AutoPrefixer. postcssOptions.plugins.push(require("tailwindcss")); postcssOptions.plugins.push(require("autoprefixer")); return postcssOptions; }, }; }, [ "posthog-docusaurus", { apiKey: process.env.POSTHOG_PROJECT_API_KEY || "XXX", appUrl: process.env.POSTHOG_APP_URL || "XXX", // optional enableInDevelopment: false, // optional }, ], ], // The classic preset will relay each option entry to the respective sub plugin/theme. presets: [ [ "@docusaurus/preset-classic", { // Will be passed to @docusaurus/plugin-content-docs (false to disable) docs: { routeBasePath: "/", sidebarPath: require.resolve("./sidebars.js"), editUrl: "https://github.com/janhq/jan/tree/main/docs", showLastUpdateAuthor: true, showLastUpdateTime: true, }, // Will be passed to @docusaurus/plugin-content-sitemap (false to disable) sitemap: { changefreq: "daily", priority: 1.0, ignorePatterns: ["/tags/**"], filename: "sitemap.xml", }, // Will be passed to @docusaurus/plugin-content-blog (false to disable) blog: { blogSidebarTitle: "All Posts", blogSidebarCount: "ALL", }, // Will be passed to @docusaurus/theme-classic. theme: { customCss: require.resolve("./src/styles/main.scss"), }, // GTM is always inactive in development and only active in production to avoid polluting the analytics statistics. googleTagManager: { containerId: process.env.GTM_ID || "XXX", }, // Will be passed to @docusaurus/plugin-content-pages (false to disable) // pages: {}, }, ], // Redoc preset [ "redocusaurus", { specs: [ { spec: "openapi/jan.yaml", // can be local file, url, or parsed json object route: "/api-reference/", // path where to render docs }, ], theme: { primaryColor: "#1a73e8", primaryColorDark: "#1a73e8", options: { requiredPropsFirst: true, noAutoAuth: true, hideDownloadButton: true, disableSearch: true, }, }, }, ], ], // Docs: https://docusaurus.io/docs/api/themes/configuration themeConfig: { image: "img/jan-social-card.png", // Only for react live liveCodeBlock: { playgroundPosition: "bottom", }, docs: { sidebar: { hideable: true, autoCollapseCategories: true, }, }, // SEO Docusarus metadata: [ { name: 'description', content: 'Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.' }, { name: 'keywords', content: 'Jan, ChatGPT alternative, on-premises AI, local API server, local AI, llm, conversational AI, no-subscription fee' }, { name: 'robots', content: 'index, follow' }, { property: 'og:title', content: 'Run your own AI | Jan' }, { property: 'og:description', content: 'Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.' }, { property: 'og:image', content: 'https://jan.ai/img/jan-social-card.png' }, { property: 'twitter:card', content: 'summary_large_image' }, { property: 'twitter:site', content: '@janhq_' }, { property: 'twitter:title', content: 'Run your own AI | Jan' }, { property: 'twitter:description', content: 'Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.' }, { property: 'twitter:image', content: 'https://jan.ai/img/jan-social-card.png' }, ], headTags: [ // Declare a preconnect tag { tagName: 'link', attributes: { rel: 'preconnect', href: 'https://jan.ai/', }, }, // Declare some json-ld structured data { tagName: 'script', attributes: { type: 'application/ld+json', }, innerHTML: JSON.stringify({ '@context': 'https://schema.org/', '@type': 'localAI', name: 'Jan', description: "Jan is a ChatGPT-alternative that runs on your own computer, with a local API server.", keywords: "Jan, ChatGPT alternative, on-premises AI, local API server, local AI, llm, conversational AI, no-subscription fee", applicationCategory: "BusinessApplication", operatingSystem: "Multiple", url: 'https://jan.ai/', }), }, ], navbar: { title: "Jan", logo: { alt: "Jan Logo", src: "img/logo.svg", }, items: [ // Navbar Left { type: "docSidebar", sidebarId: "guidesSidebar", position: "left", label: "Guides", }, { type: "docSidebar", sidebarId: "developerSidebar", position: "left", label: "Developer", }, { position: "left", to: "/api-reference", label: "API Reference", }, { type: "docSidebar", position: "left", sidebarId: "specsSidebar", label: "Specs", }, // Navbar right { type: "docSidebar", position: "right", sidebarId: "communitySidebar", label: "Community", }, { to: "blog", label: "Blog", position: "right", }, { type: "docSidebar", sidebarId: "aboutSidebar", position: "right", label: "About", }, ], }, prism: { theme: darkCodeTheme, darkTheme: darkCodeTheme, additionalLanguages: ["python"], }, colorMode: { defaultMode: "dark", disableSwitch: false, respectPrefersColorScheme: false, }, }, themes: ["@docusaurus/theme-live-codeblock", "@docusaurus/theme-mermaid"], }; module.exports = config;