import { createRequire } from "module"
import { generateSitemap as sitemap } from "sitemap-ts"
import { PageData, defineConfig } from "vitepress"
const require = createRequire(import.meta.url)
// https://vitepress.dev/reference/site-config
export default defineConfig({
// remove trailing `.html`
// https://vitepress.dev/guide/routing#generating-clean-url
cleanUrls: true,
// Whether to get the last updated timestamp for each page using Git.
lastUpdated: true,
// SEO Improvement - sitemap.xml & robots.txt
buildEnd: async ({ outDir }) => {
sitemap({
hostname: "https://nixos-and-flakes.thiscute.world/",
outDir: outDir,
generateRobotsTxt: true,
})
},
// SEO Improvement - JSON-LD
transformPageData(pageData) {
return {
frontmatter: {
...pageData.frontmatter,
head: [["script", { type: "application/ld+json" }, getJSONLD(pageData)]],
},
}
},
head: [
["link", { rel: "icon", href: "/favicon-32x32.png" }],
["meta", { name: "theme-color", content: "#5f67ee" }],
["meta", { name: "og:type", content: "website" }],
["meta", { name: "og:site_name", content: "NixOS & Flakes Book" }],
[
"meta",
{
name: "og:image",
content: "https://nixos-and-flakes.thiscute.world/nixos-and-flakes-book.webp",
},
],
[
"meta",
{
name: "twitter:image",
content: "https://nixos-and-flakes.thiscute.world/nixos-and-flakes-book.webp",
},
],
[
"script",
{
async: "",
src: "https://www.googletagmanager.com/gtag/js?id=G-N90909Y4XL",
},
],
[
"script",
{},
`window.dataLayer = window.dataLayer || [];
function gtag(){dataLayer.push(arguments);}
gtag('js', new Date());
gtag('config', 'G-N90909Y4XL');`,
],
],
// markdown options
markdown: {
lineNumbers: true,
config: (md) => {
// add support for footnote
md.use(require("markdown-it-footnote"))
md.use(require("markdown-it-cjk-breaks"))
},
},
themeConfig: {
footer: {
message:
'Licensed under CC BY-SA 4.0',
copyright:
'Copyright © 2023-present Ryan Yin',
},
search: {
provider: "local",
// for debugging
// options: {
// /**
// * @param {string} src
// * @param {import('vitepress').MarkdownEnv} env
// * @param {import('markdown-it')} md
// */
// _render(src, env, md) {
// console.log("start...")
// console.log("src", src)
// let out = md.render(src, env)
// console.log("success...")
// return out
// },
// },
// provider: 'algolia',
// options: {
// appId: '747LJ10EI7',
// apiKey: '658db5f2bf056f83458cacf5dd58ec80',
// indexName: 'nixos-and-flakes-book'
// }
},
editLink: {
pattern: "https://github.com/ryan4yin/nixos-and-flakes-book/edit/main/docs/:path",
},
socialLinks: [
{
icon: "github",
link: "https://github.com/ryan4yin/nixos-and-flakes-book",
},
],
},
locales: {
root: themeConfigEnglish(),
zh: themeConfigChinese(),
},
})
function themeConfigEnglish() {
return {
label: "English",
lang: "en",
link: "/",
title: "NixOS & Flakes Book",
description: "An unofficial and opinionated book for beginners",
themeConfig: {
// https://vitepress.dev/reference/default-theme-config
nav: [
{ text: "Home", link: "/" },
{ text: "Preface", link: "/preface.md" },
{ text: "Get Started", link: "/introduction/index.md" },
{ text: "Best Practices", link: "/best-practices/intro.md" },
],
sidebar: [
{
text: "Preface",
items: [{ text: "Preface", link: "/preface.md" }],
},
{
text: "Get Started",
items: [
{ text: "Introduction", link: "/introduction/index.md" },
{
text: "Advantages and Disadvantages",
link: "/introduction/advantages-and-disadvantages.md",
},
{
text: "Installation",
link: "/introduction/installation.md",
},
],
},
{
text: "The Nix Language",
items: [{ text: "Basics", link: "/the-nix-language/index.md" }],
},
{
text: "NixOS with Flakes",
items: [
{
text: "Get Started with NixOS",
link: "/nixos-with-flakes/get-started-with-nixos.md",
},
{
text: "Introduction to Flakes",
link: "/nixos-with-flakes/introduction-to-flakes.md",
},
{
text: "NixOS with Flakes Enabled",
link: "/nixos-with-flakes/nixos-with-flakes-enabled.md",
},
{
text: "NixOS's flake.nix Explained",
link: "/nixos-with-flakes/nixos-flake-configuration-explained.md",
},
{
text: "The combination ability of Flakes and Nixpkgs module system",
link: "/nixos-with-flakes/nixos-flake-and-module-system.md",
},
{
text: "Getting Started with Home Manager",
link: "/nixos-with-flakes/start-using-home-manager.md",
},
{
text: "Modularize the Configuration",
link: "/nixos-with-flakes/modularize-the-configuration.md",
},
{
text: "Updating the System",
link: "/nixos-with-flakes/update-the-system.md",
},
{
text: "Downgrading or Upgrading Packages",
link: "/nixos-with-flakes/downgrade-or-upgrade-packages.md",
},
{
text: "Other useful Tips",
link: "/nixos-with-flakes/other-useful-tips.md",
},
],
},
{
text: "Nixpkgs's Advanced Usage",
items: [
{ text: "Introduction", link: "/nixpkgs/intro.md" },
{ text: "callPackage", link: "/nixpkgs/callpackage.md" },
{ text: "Overriding", link: "/nixpkgs/overriding.md" },
{ text: "Overlays", link: "/nixpkgs/overlays.md" },
{
text: "Multiple Nixpkgs Instances",
link: "/nixpkgs/multiple-nixpkgs.md",
},
],
},
{
text: "Nix Store & Binary Cache",
items: [
{ text: "Introduction", link: "/nix-store/intro.md" },
{
text: "Add Binary Cache Servers",
link: "nix-store/add-binary-cache-servers.md",
},
{
text: "Host Your Own Binary Cache Server",
link: "/nix-store/host-your-own-binary-cache-server.md",
},
],
},
{
text: "Best Practices",
items: [
{ text: "Introduction", link: "/best-practices/intro.md" },
{
text: "Run downloaded binaries on NixOS",
link: "/best-practices/run-downloaded-binaries-on-nixos.md",
},
{
text: "Simplify NixOS-related Commands",
link: "/best-practices/simplify-nixos-related-commands.md",
},
{
text: "Accelerating Dotfiles Debugging",
link: "/best-practices/accelerating-dotfiles-debugging.md",
},
{
text: "Custom NIX_PATH and Flake Registry",
link: "/best-practices/nix-path-and-flake-registry.md",
},
{
text: "Remote Deployment",
link: "/best-practices/remote-deployment.md",
},
{
text: "Debugging Derivations and Nix Expressions",
link: "/best-practices/debugging.md",
},
],
},
{
text: "Other Usage of Flakes",
items: [
{ text: "Introduction", link: "/other-usage-of-flakes/intro.md" },
{
text: "Flake Inputs",
link: "/other-usage-of-flakes/inputs.md",
},
{
text: "Flake Outputs",
link: "/other-usage-of-flakes/outputs.md",
},
{
text: "The New CLI",
link: "/other-usage-of-flakes/the-new-cli.md",
},
{
text: "Module System & Custom Options",
link: "/other-usage-of-flakes/module-system.md",
},
{
text: "[WIP]Testing",
link: "/other-usage-of-flakes/testing.md",
},
],
},
{
text: "Dev Environments on NixOS",
items: [
{
text: "nix shell, nix develop & pkgs.runCommand",
link: "/development/intro.md",
},
{
text: "Dev Environments",
link: "/development/dev-environments.md",
},
{
text: "[WIP]Packaging 101",
link: "/development/packaging-101.md",
},
{
text: "Cross-platform Compilation",
link: "/development/cross-platform-compilation.md",
},
{
text: "Distributed Building",
link: "/development/distributed-building.md",
},
{
text: "[WIP]Kernel Development",
link: "/development/kernel-development.md",
},
],
},
{
text: "Advanced Topics",
items: [{ text: "Advanced Topics", link: "/advanced-topics/index.md" }],
},
{
text: "Frequently Asked Questions",
items: [{ text: "Frequently Asked Questions", link: "/faq/index.md" }],
},
],
},
}
}
function themeConfigChinese() {
return {
label: "简体中文",
lang: "zh-CN",
link: "/zh/",
title: "NixOS 与 Flakes",
description: "一份非官方的新手指南",
themeConfig: {
// https://vitepress.dev/reference/default-theme-config
nav: [
{ text: "首页", link: "/zh/" },
{ text: "前言", link: "/zh/preface.md" },
{ text: "开始使用", link: "/zh/introduction/index.md" },
{ text: "最佳实践", link: "/zh/best-practices/intro.md" },
],
sidebar: [
{
text: "前言",
items: [{ text: "前言", link: "/zh/preface.md" }],
},
{
text: "开始使用",
items: [
{ text: "简介", link: "/zh/introduction/index.md" },
{
text: "优缺点",
link: "/zh/introduction/advantages-and-disadvantages.md",
},
{
text: "安装",
link: "/zh/introduction/installation.md",
},
],
},
{
text: "Nix 语言",
items: [{ text: "快速入门", link: "/zh/the-nix-language/index.md" }],
},
{
text: "NixOS 与 Flakes",
items: [
{
text: "开始使用 NixOS",
link: "/zh/nixos-with-flakes/get-started-with-nixos.md",
},
{
text: "Flakes 简介",
link: "/zh/nixos-with-flakes/introduction-to-flakes.md",
},
{
text: "使用 Flakes 管理 NixOS",
link: "/zh/nixos-with-flakes/nixos-with-flakes-enabled.md",
},
{
text: "NixOS 的 flake.nix 内容详解",
link: "/zh/nixos-with-flakes/nixos-flake-configuration-explained.md",
},
{
text: "Flakes 的组合能力与 Nixpkgs 模块系统",
link: "/zh/nixos-with-flakes/nixos-flake-and-module-system.md",
},
{
text: "安装使用 Home Manager",
link: "/zh/nixos-with-flakes/start-using-home-manager.md",
},
{
text: "模块化系统配置",
link: "/zh/nixos-with-flakes/modularize-the-configuration.md",
},
{
text: "更新系统",
link: "/zh/nixos-with-flakes/update-the-system.md",
},
{
text: "降级或升级软件包",
link: "/zh/nixos-with-flakes/downgrade-or-upgrade-packages.md",
},
{
text: "其他杂七杂八的内容",
link: "/zh/nixos-with-flakes/other-useful-tips.md",
},
],
},
{
text: "Nixpkgs 高级用法",
items: [
{ text: "简介", link: "/zh/nixpkgs/intro.md" },
{ text: "callPackage", link: "/zh/nixpkgs/callpackage.md" },
{ text: "Overriding", link: "/zh/nixpkgs/overriding.md" },
{ text: "Overlays", link: "/zh/nixpkgs/overlays.md" },
{
text: "多 Nixpkgs 实例的妙用",
link: "/zh/nixpkgs/multiple-nixpkgs.md",
},
],
},
{
text: "Nix Store 与二进制缓存",
items: [
{ text: "简介", link: "/zh/nix-store/intro.md" },
{
text: "添加二进制缓存服务器",
link: "/zh/nix-store/add-binary-cache-servers.md",
},
{
text: "搭建你自己的缓存服务器",
link: "/zh/nix-store/host-your-own-binary-cache-server.md",
},
],
},
{
text: "NixOS 最佳实践",
items: [
{ text: "简介", link: "/zh/best-practices/intro.md" },
{
text: "运行非 NixOS 的二进制文件",
link: "/zh/best-practices/run-downloaded-binaries-on-nixos.md",
},
{
text: "简化常用的 NixOS 相关命令",
link: "/zh/best-practices/simplify-nixos-related-commands.md",
},
{
text: "加速 Dotfiles 的调试",
link: "/zh/best-practices/accelerating-dotfiles-debugging.md",
},
{
text: "自定义 NIX_PATH 与 Flake Registry",
link: "/zh/best-practices/nix-path-and-flake-registry.md",
},
{
text: "远程部署 NixOS 配置",
link: "/zh/best-practices/remote-deployment.md",
},
{
text: "调试 Nix 软件包与 Nix 表达式",
link: "/zh/best-practices/debugging.md",
},
],
},
{
text: "Flakes 的其他玩法",
items: [
{ text: "简介", link: "/zh/other-usage-of-flakes/intro.md" },
{
text: "Flake Inputs",
link: "/zh/other-usage-of-flakes/inputs.md",
},
{
text: "Flake Outputs",
link: "/zh/other-usage-of-flakes/outputs.md",
},
{
text: "新一代 Nix 命令行工具的使用",
link: "/zh/other-usage-of-flakes/the-new-cli.md",
},
{
text: "模块系统与自定义 options",
link: "/zh/other-usage-of-flakes/module-system.md",
},
{
text: "[WIP]Testing",
link: "/zh/other-usage-of-flakes/testing.md",
},
],
},
{
text: "在 NixOS 上进行开发工作",
items: [
{
text: "nix shell, nix develop & pkgs.runCommand",
link: "/zh/development/intro.md",
},
{
text: "各语言的开发环境",
link: "/zh/development/dev-environments.md",
},
{
text: "[WIP]软件打包",
link: "/zh/development/packaging-101.md",
},
{
text: "跨平台编译",
link: "/zh/development/cross-platform-compilation.md",
},
{
text: "分布式构建",
link: "/zh/development/distributed-building.md",
},
{
text: "[WIP]内核开发",
link: "/zh/development/kernel-development.md",
},
],
},
{
text: "其他进阶话题",
items: [{ text: "其他进阶话题", link: "/zh/advanced-topics/index.md" }],
},
{
text: "常见问题 FAQ",
items: [{ text: "常见问题 FAQ", link: "/zh/faq/index.md" }],
},
],
},
}
}
function getJSONLD(pageData: PageData) {
if (pageData.relativePath === "index.md") {
return `{
"@context":"http://schema.org",
"@type":"WebSite",
"url":"https:\/\/nixos-and-flakes.thiscute.world\/",
"inLanguage":"en",
"description":"An unofficial and opinionated book for beginners",
"name":"${pageData.title}"
}`
} else if (pageData.relativePath === "zh/index.md") {
return `{
"@context":"http://schema.org",
"@type":"WebSite",
"url":"https:\/\/nixos-and-flakes.thiscute.world\/zh\/",
"inLanguage":"zh-CN",
"description":"一份非官方的新手指南",
"name":"${pageData.title}"
}`
} else {
let lang = pageData.relativePath.startsWith("zh/") ? "zh-CN" : "en"
let url = `https:\/\/nixos-and-flakes.thiscute.world\/${pageData.relativePath
.replace(/\.md$/, "")
.replace(/\/index\$/, "/")}`
return `{
"@context":"http://schema.org",
"@type":"TechArticle",
"headline":"${pageData.title} | NixOS & Flakes Book",
"inLanguage":"${lang}",
"mainEntityOfPage":{
"@type":"WebPage",
"@id":"${url}"
},
"keywords":"NixOS, Nix, Flakes, Linux, Tutorial",
"url":"${url}"
}`
}
}