Files
iot-device-management-frontend/apps/web-antd/src/components/description/typing.ts

57 lines
1.3 KiB
TypeScript
Raw Normal View History

2025-10-21 11:38:02 +08:00
import type { DescriptionsProps } from 'ant-design-vue/es/descriptions';
import type { JSX } from 'vue/jsx-runtime';
import type { CSSProperties, VNode } from 'vue';
2025-10-21 11:38:02 +08:00
import type { Recordable } from '@vben/types';
export interface DescriptionItemSchema {
2025-10-21 11:38:02 +08:00
labelMinWidth?: number;
contentMinWidth?: number;
// 自定义标签样式
labelStyle?: CSSProperties;
// 对应 data 中的字段名
field: string;
// 内容的描述
label: JSX.Element | string | VNode;
// 包含列的数量
span?: number;
// 是否显示
show?: (...arg: any) => boolean;
// 插槽名称
slot?: string;
// 自定义需要展示的内容
render?: (
val: any,
data?: Recordable<any>,
) => Element | JSX.Element | number | string | undefined | VNode;
}
export interface DescriptionProps extends DescriptionsProps {
// 是否包含卡片组件
useCard?: boolean;
// 描述项配置
schema: DescriptionItemSchema[];
// 数据
data: Recordable<any>;
// 标题
title?: string;
// 是否包含边框
bordered?: boolean;
// 列数
column?:
| number
| {
lg: number;
md: number;
sm: number;
xl: number;
xs: number;
xxl: number;
};
}
2025-10-21 11:38:02 +08:00
export interface DescInstance {
setDescProps(descProps: Partial<DescriptionProps>): void;
}