Files
docs/versioned_docs/version-2.1/developer-guide/theme/config.md
Ryan Wang ef03b0fbfb docs: update documentation for Halo 2.1 (#162)
为 Halo 2.1 更新文档。

see https://github.com/halo-dev/halo/releases/tag/v2.1.0

/kind documentation

```release-note
None
```
2023-01-03 07:56:36 +00:00

4.2 KiB

title, description
title description
配置文件 关于主题配置文件的文档。

目前 Halo 2.0 的主题必须在根目录包含 theme.yaml,用于配置主题的基本信息,如主题名称、版本、作者等。

格式示例

apiVersion: theme.halo.run/v1alpha1
kind: Theme
metadata:
  name: theme-foo
spec:
  displayName: 示例主题
  author:
    name: halo-dev
    website: https://halo.run
  description: 一个示例主题
  logo: https://halo.run/logo
  website: 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
  require: 2.0.0

字段详解

字段 描述 是否必填
metadata.name 主题的唯一标识
spec.displayName 显示名称
spec.author.name 作者名称
spec.author.website 作者网站
spec.description 主题描述
spec.logo 主题 Logo
spec.website 主题网站
spec.repo 主题托管地址
spec.settingName 设置表单定义的名称,需要同时创建对应的 settings.yaml 文件
spec.configMapName 设置持久化配置的 ConfigMap 名称
spec.customTemplates.post 文章的自定义模板配置,详细文档可查阅 模板路由
spec.customTemplates.category 分类的自定义模板配置,详细文档可查阅 模板路由
spec.customTemplates.page 独立页面的自定义模板配置,详细文档可查阅 模板路由
spec.version 主题版本
spec.require 所需 Halo 的运行版本

更新配置

由于目前 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.namespec.settingNamespec.configMapName。 :::