mirror of
https://github.com/zhenxun-org/zhenxun_bot.git
synced 2025-12-14 21:52: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
* ✨ feat(table): 添加 ComponentCell 以支持表格单元格中嵌入可渲染组件 * ✨ feat(ui): 增强表格构建器并完善组件模型文档 - 增强 `TableBuilder`,新增 `_normalize_cell` 辅助方法,支持自动将原生数据类型(如 `str`, `int`, `Path`)转换为 `TableCell` 模型,简化了表格行的创建。 - 完善 `zhenxun/ui/models` 目录下所有组件模型字段的 `description` 属性和文档字符串,显著提升了代码可读性和开发者体验。 - 优化 `shop/_data_source.py` 中 `gold_rank` 函数的平台路径判断格式,并统一 `my_props` 函数中图标路径的处理逻辑。 * 🚨 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>
44 lines
1.4 KiB
Python
44 lines
1.4 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属性,控制分割线上下的间距")
|
||
"""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"
|
||
|
||
|
||
class Rectangle(RenderableComponent):
|
||
"""一个矩形背景块组件。"""
|
||
|
||
component_type: Literal["rectangle"] = "rectangle"
|
||
height: str = Field("50px", description="矩形的高度 (CSS value)")
|
||
"""矩形的高度 (CSS value)"""
|
||
background_color: str = Field("#fdf1f5", description="背景颜色")
|
||
"""背景颜色"""
|
||
border: str = Field("1px solid #fce4ec", description="CSS border属性")
|
||
"""CSS border属性"""
|
||
border_radius: str = Field("8px", description="CSS border-radius属性")
|
||
"""CSS border-radius属性"""
|
||
|
||
@property
|
||
def template_name(self) -> str:
|
||
return "components/widgets/rectangle"
|