mirror of
https://github.com/zhenxun-org/zhenxun_bot.git
synced 2025-12-15 14:22:55 +08:00
- 增强 `TableBuilder`,新增 `_normalize_cell` 辅助方法,支持自动将原生数据类型(如 `str`, `int`, `Path`)转换为 `TableCell` 模型,简化了表格行的创建。 - 完善 `zhenxun/ui/models` 目录下所有组件模型字段的 `description` 属性和文档字符串,显著提升了代码可读性和开发者体验。 - 优化 `shop/_data_source.py` 中 `gold_rank` 函数的平台路径判断格式,并统一 `my_props` 函数中图标路径的处理逻辑。
59 lines
1.8 KiB
Python
59 lines
1.8 KiB
Python
from collections.abc import Iterable
|
|
from typing import Any
|
|
|
|
from pydantic import BaseModel, Field
|
|
|
|
from .base import ContainerComponent, RenderableComponent
|
|
|
|
__all__ = ["LayoutData", "LayoutItem"]
|
|
|
|
|
|
class LayoutItem(BaseModel):
|
|
"""布局中的单个项目,现在持有可渲染组件的数据模型"""
|
|
|
|
component: RenderableComponent = Field(..., description="要渲染的组件的数据模型")
|
|
"""要渲染的组件的数据模型"""
|
|
metadata: dict[str, Any] | None = Field(None, description="传递给模板的额外元数据")
|
|
"""传递给模板的额外元数据"""
|
|
|
|
|
|
class LayoutData(ContainerComponent):
|
|
"""布局构建器的数据模型"""
|
|
|
|
style_name: str | None = None
|
|
"""应用于布局容器的样式名称"""
|
|
layout_type: str = "column"
|
|
"""布局类型 (如 'column', 'row', 'grid')"""
|
|
children: list[LayoutItem] = Field(
|
|
default_factory=list, description="要布局的项目列表"
|
|
)
|
|
"""要布局的项目列表"""
|
|
options: dict[str, Any] = Field(
|
|
default_factory=dict, description="传递给模板的选项"
|
|
)
|
|
"""传递给模板的选项"""
|
|
|
|
@property
|
|
def template_name(self) -> str:
|
|
return f"components/core/layouts/{self.layout_type}"
|
|
|
|
def get_extra_css(self, context: Any) -> str:
|
|
"""聚合所有子组件的 extra_css。"""
|
|
all_css = []
|
|
if self.component_css:
|
|
all_css.append(self.component_css)
|
|
|
|
for item in self.children:
|
|
if (
|
|
item.component
|
|
and hasattr(item.component, "component_css")
|
|
and item.component.component_css
|
|
):
|
|
all_css.append(item.component.component_css)
|
|
|
|
return "\n".join(all_css)
|
|
|
|
def get_children(self) -> Iterable[RenderableComponent]:
|
|
for item in self.children:
|
|
yield item.component
|