استفاده از یک تم سفارشی
Resolve کردن تم
میتوانید با ایجاد یک فایل .vitepress/theme/index.js
یا .vitepress/theme/index.ts
(فایل ورودی تم) تم سفارشی را فعال کنید:
.
├─ docs # ریشه پروژه
│ ├─ .vitepress
│ │ ├─ theme
│ │ │ └─ index.js # ورودی تم
│ │ └─ config.js # فایل پیکربندی
│ └─ index.md
└─ package.json
وقتی ویتپرس حضور یک فایل ورودی تم را شناسایی کند، همواره از تم سفارشی به جای تم پیشفرض استفاده میکند. با این حال، شما میتوانید تم پیشفرض را گسترش دهید تا سفارشیسازیهای پیشرفتهتری را روی آن اعمال کنید.
رابط تم
یک تم سفارشی ویتپرس به عنوان یک شی تعریف میشود که شامل رابط زیر است:
interface Theme {
/**
* کامپوننت لایهی ریشه برای هر صفحه
* @required
*/
Layout: Component
/**
* تقویت نمونه Vue اپلیکیشن
* @optional
*/
enhanceApp?: (ctx: EnhanceAppContext) => Awaitable<void>
/**
* گسترش یک تم دیگر، با فراخوانی `enhanceApp` آن پیش از ما
* @optional
*/
extends?: Theme
}
interface EnhanceAppContext {
app: App // نمونه Vue اپلیکیشن
router: Router // نمونه روتر ویتپرس
siteData: Ref<SiteData> // متادیتاهای سطح سایت
}
فایل ورودی تم باید تم را به عنوان export پیشفرض خود export کند:
// شما میتوانید فایلهای Vue را مستقیماً در ورودی تم وارد کنید
// ویتپرس با @vitejs/plugin-vue پیشتنظیم شده است.
import Layout from './Layout.vue'
export default {
Layout,
enhanceApp({ app, router, siteData }) {
// ...
}
}
export پیشفرض تنها قراردادی برای یک تم سفارشی است و تنها ویژگی Layout
لازم است. بنابراین، به شیء تم ویتپرس میتوان به عنوان یک کامپوننت Vue ساده ترتیب داد.
درون کامپوننت لایهی خود، دقیقاً مانند یک برنامه Vite + Vue 3 عادی عمل میکند. با این وجود، توجه داشته باشید که تم همچنین باید سازگار با SSR باشد.
ساخت یک لایه
بیشترین لایهی پایهای نیازمند دارای یک کامپوننت <Content />
است:
<template>
<h1>طرح سفارشی!</h1>
<!-- اینجا محتوای markdown نمایش داده میشود -->
<Content />
</template>
لایهی بالا به سادگی تمام محتوای markdown هر صفحه را به عنوان HTML نمایش میدهد. اولین بهبودی که میتوانیم اعمال کنیم، مدیریت خطاهای 404 است:
<script setup>
import { useData } from 'vitepress'
const { page } = useData()
</script>
<template>
<h1>طرح سفارشی!</h1>
<div v-if="page.isNotFound">
صفحه 404 سفارشی!
</div>
<Content v-else />
</template>
کمککننده useData()
اطلاعات اجرایی مورد نیاز ما را برای رندر شرایطی صفحات مختلف فراهم میکند. یکی از دیگر اطلاعاتی که ما میتوانیم به آن دسترسی داشته باشیم، اطلاعات اولیه صفحه فعلی است. ما میتوانیم از این اطلاعات برای اجازه دادن به کاربر برای کنترل لایه در هر صفحه استفاده کنیم. به عنوان مثال، کاربر میتواند مشخص کند که صفحه باید از یک طرح صفحه خانه خاص استفاده کند با:
---
layout: home
---
و ما میتوانیم تم خود را تنظیم کنیم تا با این موضوع برخورد کند:
<script setup>
import { useData } from 'vitepress'
const { page, frontmatter } = useData()
</script>
<template>
<h1>طرح سفارشی!</h1>
<div v-if="page.isNotFound">
صفحه 404 سفارشی!
</div>
<div v-if="frontmatter.layout === 'home'">
صفحه خانه سفارشی!
</div>
<Content v-else />
</template>
طبیعتا، شما میتوانید لایهی خود را به کامپوننتهای بیشتری تقسیم کنید:
<script setup>
import { useData } from 'vitepress'
import NotFound from './NotFound.vue'
import Home from './Home.vue'
import Page from './Page.vue'
const { page, frontmatter } = useData()
</script>
<template>
<h1>طرح سفارشی!</h1>
<NotFound v-if="page.isNotFound" />
<Home v-if="frontmatter.layout === 'home'" />
<Page v-else /> <!-- <Page /> با `<Content />` را نمایش میدهد -->
</template>
برای همه چیزی که در کامپوننتهای تم موجود است، به مستندات API اجرایی مراجعه کنید. به علاوه، شما میتوانید از بارگذاری داده در زمان ساخت استفاده کنید تا لایههای مبتنی بر داده را تولید کنید - به عنوان مثال، یک صفحه که تمام پستهای وبلاگ در پروژه فعلی را لیست میکند.
توزیع یک تم سفارشی
آسانترین روش برای توزیع یک تم سفارشی ارائه آن به عنوان قالب مخزن در GitHub است.
اگر میخواهید تم را به عنوان یک بسته npm توزیع کنید، مراحل زیر را دنبال کنید:
شیء تم را به عنوان export پیشفرض در ورودی بستهتان export کنید.
اگر امکان دارد، تعریف نوع پیکربندی تم خود را به عنوان
ThemeConfig
export کنید.اگر تم شما نیاز به تنظیم پیکربندی ویتپرس دارد، پیکربندی را تحت یک زیرمسیر بسته (مانند
my-theme/config
) export کنید تا کاربر بتواند آن را گسترش دهد.گزینههای پیکربندی تم را مستند کنید (هم از طریق فایل پیکربندی و هم از طریق frontmatter).
دستورالعملهای روشنی برای مصرف تم خود ارائه دهید (مانند زیر).
مصرف یک تم سفارشی
برای مصرف یک تم خارجی، آن را از ورودی تم سفارشی وارد و دوباره export کنید:
import Theme from 'awesome-vitepress-theme'
export default Theme
اگر تم نیاز به گسترش دارد:
import Theme from 'awesome-vitepress-theme'
export default {
extends: Theme,
enhanceApp(ctx) {
// ...
}
}
اگر تم نیاز به پیکربندی خاص ویتپرس دارد، شما همچنین باید آن را در پیکربندی خود گسترش دهید:
import baseConfig from 'awesome-vitepress-theme/config'
export default {
// گسترش پیکربندی پایهی تم (اگر لازم باشد)
extends: baseConfig
}
سرانجام، اگر تم انواع خود را برای پیکربندی تماش ارائه میدهد:
import baseConfig from 'awesome-vitepress-theme/config'
import { defineConfigWithTheme } from 'vitepress'
import type { ThemeConfig } from 'awesome-vitepress-theme'
export default defineConfigWithTheme<ThemeConfig>({
extends: baseConfig,
themeConfig: {
// نوع `ThemeConfig` است
}
})