import type { VxeTableGridOptions } from '@vben/plugins/vxe-table'; import type { VbenFormSchema } from '#/adapter/form'; import type { OnActionClickFn } from '#/adapter/vxe-table'; import type { ${app_name_camel}${model_name}Api } from '#/models/${app_name}/${model_name_snake}'; import { z } from '#/adapter/form'; import { $$t } from '#/locales'; import { format_datetime } from '#/utils/date'; /** * 获取编辑表单的字段配置 */ export function useSchema(): VbenFormSchema[] { return [ ${form_fields} ]; } /** * 获取表格列配置 * @description 使用函数的形式返回列数据而不是直接export一个Array常量,是为了响应语言切换时重新翻译表头 * @param onActionClick 表格操作按钮点击事件 */ export function useColumns( onActionClick?: OnActionClickFn<${app_name_camel}${model_name}Api.${app_name_camel}${model_name}>, ): VxeTableGridOptions<${app_name_camel}${model_name}Api.${app_name_camel}${model_name}>['columns'] { return [ ${columns} { align: 'center', cellRender: { attrs: { nameField: 'name', nameTitle: $t('${app_name}.${model_name_snake}.name'), onClick: onActionClick, }, name: 'CellOperation', options: ['edit', 'delete'], }, field: 'action', fixed: 'right', title: '操作', width: 120, }, ]; }