You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
4.7 KiB
4.7 KiB
title | description |
---|---|
配置文件 | 关于主题配置文件的文档。 |
目前 Halo 2.0 的主题必须在根目录包含 theme.yaml
,用于配置主题的基本信息,如主题名称、版本、作者等。
格式示例
apiVersion: theme.halo.run/v1alpha1
kind: Theme
metadata:
name: theme-foo
spec:
displayName: 示例主题
author:
name: Halo
website: https://www.halo.run
description: 一个示例主题
logo: https://www.halo.run/logo
homepage: https://github.com/halo-sigs/theme-foo
repo: https://github.com/halo-sigs/theme-foo.git
settingName: "theme-foo-setting"
configMapName: "theme-foo-configMap"
customTemplates:
post:
- name: 文档
description: 文档类型的文章
screenshot:
file: post_documentation.html
category:
- name: 知识库
description: 知识库类型的分类
screenshot:
file: category_knowledge.html
page:
- name: 关于
description: 关于页面
screenshot:
file: page_about.html
version: 1.0.0
requires: 2.0.0
license:
- name: "GPL-3.0"
url: "https://github.com/halo-sigs/theme-foo/blob/main/LICENSE"
字段详解
字段 | 描述 | 是否必填 |
---|---|---|
metadata.name |
主题的唯一标识 | 是 |
spec.displayName |
显示名称 | 是 |
spec.author.name |
作者名称 | 否 |
spec.author.website |
作者网站 | 否 |
spec.description |
主题描述 | 否 |
spec.logo |
主题 Logo | 否 |
spec.homepage |
主题网站 | 否 |
spec.repo |
主题代码托管地址 | 否 |
spec.settingName |
设置表单定义的名称,需要同时创建对应的 settings.yaml 文件 |
否 |
spec.configMapName |
设置持久化配置的 ConfigMap 名称 | 否 |
spec.customTemplates.post |
文章的自定义模板配置,详细文档可查阅 模板路由 | 否 |
spec.customTemplates.category |
分类的自定义模板配置,详细文档可查阅 模板路由 | 否 |
spec.customTemplates.page |
独立页面的自定义模板配置,详细文档可查阅 模板路由 | 否 |
spec.version |
主题版本 | 是 |
spec.requires |
所需 Halo 的运行版本 | 是 |
spec.license |
协议 | 否 |
更新配置
由于目前 theme.yaml
是持久化存储在数据库中的,不会在修改之后主动更新,所以我们在 Console 的主题页面添加了 重载主题配置
的选项。
从 1.x 迁移
为了方便主题开发者从 1.x 迁移,我们提供了工具用于迁移配置文件。
工具仓库地址:https://github.com/halo-sigs/convert-theme-config-to-next
# 1.x 版本主题
cd path/to/theme
npx @halo-dev/convert-theme-config-to-next theme
执行完成之后即可看到主题目录下生成了 theme.2.0.yaml
文件,重命名为 theme.yaml
即可。
:::tip
转换完成之后需要修改 metadata.name
、spec.settingName
和 spec.configMapName
。
:::