mirror of
https://github.com/zhenxun-org/zhenxun_bot.git
synced 2025-12-14 13:42:56 +08:00
Some checks failed
检查bot是否运行正常 / bot check (push) Has been cancelled
CodeQL Code Security Analysis / Analyze (${{ matrix.language }}) (none, javascript-typescript) (push) Has been cancelled
CodeQL Code Security Analysis / Analyze (${{ matrix.language }}) (none, python) (push) Has been cancelled
Sequential Lint and Type Check / ruff-call (push) Has been cancelled
Release Drafter / Update Release Draft (push) Has been cancelled
Force Sync to Aliyun / sync (push) Has been cancelled
Update Version / update-version (push) Has been cancelled
Sequential Lint and Type Check / pyright-call (push) Has been cancelled
* ♻️ refactor: 统一图片渲染架构并引入通用UI组件系统 🎨 **渲染服务重构** - 统一图片渲染入口,引入主题系统支持 - 优化Jinja2环境管理,支持主题覆盖和插件命名空间 - 新增UI缓存机制和主题重载功能 ✨ **通用UI组件系统** - 新增 zhenxun.ui 模块,提供数据模型和构建器 - 引入BaseBuilder基类,支持链式调用 - 新增多种UI构建器:InfoCard, Markdown, Table, Chart, Layout等 - 新增通用组件:Divider, Badge, ProgressBar, UserInfoBlock 🔄 **插件迁移** - 迁移9个内置插件至新渲染系统 - 移除各插件中分散的图片生成工具 - 优化数据处理和渲染逻辑 💥 **Breaking Changes** - 移除旧的图片渲染接口和模板路径 - TEMPLATE_PATH 更名为 THEMES_PATH - 插件需适配新的RendererService和zhenxun.ui模块 * ✅ test(check): 更新自检插件测试中的渲染服务模拟 * ♻️ refactor(renderer): 将缓存文件名哈希算法切换到 SHA256 * ♻️ refactor(shop): 移除商店HTML图片生成模块 * 🚨 auto fix by pre-commit hooks --------- Co-authored-by: webjoin111 <455457521@qq.com> Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
36 lines
1.2 KiB
Python
36 lines
1.2 KiB
Python
from typing import Literal
|
||
|
||
from pydantic import Field
|
||
|
||
from ..core.base import RenderableComponent
|
||
|
||
__all__ = ["Divider", "Rectangle"]
|
||
|
||
|
||
class Divider(RenderableComponent):
|
||
"""一个简单的分割线组件。"""
|
||
|
||
component_type: Literal["divider"] = "divider"
|
||
margin: str = Field("2em 0", description="CSS margin属性,控制分割线上下的间距")
|
||
color: str = Field("#f7889c", description="分割线颜色")
|
||
style: Literal["solid", "dashed", "dotted"] = Field("solid", description="线条样式")
|
||
thickness: str = Field("1px", description="线条粗细")
|
||
|
||
@property
|
||
def template_name(self) -> str:
|
||
return "components/widgets/divider/main.html"
|
||
|
||
|
||
class Rectangle(RenderableComponent):
|
||
"""一个矩形背景块组件。"""
|
||
|
||
component_type: Literal["rectangle"] = "rectangle"
|
||
height: str = Field("50px", description="矩形的高度 (CSS value)")
|
||
background_color: str = Field("#fdf1f5", description="背景颜色")
|
||
border: str = Field("1px solid #fce4ec", description="CSS border属性")
|
||
border_radius: str = Field("8px", description="CSS border-radius属性")
|
||
|
||
@property
|
||
def template_name(self) -> str:
|
||
return "components/widgets/rectangle/main.html"
|