| import type {BasicColumn, FormSchema} from '@/components/Table' | 
| import {useRender} from '@/components/Table' | 
| import {DICT_TYPE, getDictOptions} from '@/utils/dict' | 
|   | 
| export const columns: BasicColumn[] = [ | 
| #foreach($column in $columns) | 
| #if ($column.listOperationResult) | 
|   #set ($dictType=$column.dictType) | 
|   #set ($javaField = $column.javaField) | 
|   #set ($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) | 
|   #set ($comment=$column.columnComment) | 
| #if ($column.javaType == "LocalDateTime")## 时间类型 | 
|   { | 
|     title: '${comment}', | 
|     dataIndex: '${javaField}', | 
|     width: 180, | 
|     customRender: ({ text }) => { | 
|       return useRender.renderDate(text) | 
|     }, | 
|   }, | 
| #elseif("" != $column.dictType)## 数据字典 | 
|   { | 
|     title: '${comment}', | 
|     dataIndex: '${javaField}', | 
|     width: 180, | 
|     customRender: ({ text }) => { | 
|       return useRender.renderDict(text, DICT_TYPE.$dictType.toUpperCase()) | 
|     }, | 
|   }, | 
| #else | 
|   { | 
|     title: '${comment}', | 
|     dataIndex: '${javaField}', | 
|     width: 160, | 
|   }, | 
| #end | 
| #end | 
| #end | 
| ] | 
|   | 
| export const searchFormSchema: FormSchema[] = [ | 
| #foreach($column in $columns) | 
| #if ($column.listOperation) | 
|   #set ($dictType=$column.dictType) | 
|   #set ($javaField = $column.javaField) | 
|   #set ($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) | 
|   #set ($comment=$column.columnComment) | 
|   { | 
|     label: '${comment}', | 
|     field: '${javaField}', | 
|   #if ($column.htmlType == "input") | 
|     component: 'Input', | 
|   #elseif ($column.htmlType == "select") | 
|     component: 'Select', | 
|     componentProps: { | 
|       #if ("" != $dictType)## 设置了 dictType 数据字典的情况 | 
|         options: getDictOptions(DICT_TYPE.$dictType.toUpperCase()), | 
|       #else## 未设置 dictType 数据字典的情况 | 
|         options: [], | 
|       #end | 
|     }, | 
|   #elseif ($column.htmlType == "radio") | 
|     component: 'Radio', | 
|     componentProps: { | 
|       #if ("" != $dictType)## 设置了 dictType 数据字典的情况 | 
|         options: getDictOptions(DICT_TYPE.$dictType.toUpperCase()), | 
|       #else## 未设置 dictType 数据字典的情况 | 
|         options: [], | 
|       #end | 
|     }, | 
|   #elseif($column.htmlType == "datetime") | 
|     component: 'RangePicker', | 
|     #end | 
|     colProps: { span: 8 }, | 
|   }, | 
| #end | 
| #end | 
| ] | 
|   | 
| export const createFormSchema: FormSchema[] = [ | 
|   { | 
|     label: '编号', | 
|     field: 'id', | 
|     show: false, | 
|     component: 'Input', | 
|   }, | 
| #foreach($column in $columns) | 
| #if ($column.createOperation) | 
|   #set ($dictType = $column.dictType) | 
|   #set ($javaField = $column.javaField) | 
|   #set ($AttrName = $column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) | 
|   #set ($comment = $column.columnComment) | 
| #if (!$column.primaryKey)## 忽略主键,不用在表单里 | 
|   { | 
|     label: '${comment}', | 
|     field: '${javaField}', | 
|   #if (($column.createOperation || $column.updateOperation) && !$column.nullable && !${column.primaryKey})## 创建或者更新操作 && 要求非空 && 非主键 | 
|     required: true, | 
|     #end | 
|   #if ($column.htmlType == "input") | 
|     component: 'Input', | 
|   #elseif($column.htmlType == "imageUpload")## 图片上传 | 
|     component: 'FileUpload', | 
|     componentProps: { | 
|       fileType: 'image', | 
|       maxCount: 1, | 
|     }, | 
|   #elseif($column.htmlType == "fileUpload")## 文件上传 | 
|     component: 'FileUpload', | 
|     componentProps: { | 
|       fileType: 'file', | 
|       maxCount: 1, | 
|     }, | 
|   #elseif($column.htmlType == "editor")## 文本编辑器 | 
|     component: 'Editor', | 
|   #elseif($column.htmlType == "select")## 下拉框 | 
|     component: 'Select', | 
|     componentProps: { | 
|       #if ("" != $dictType)## 有数据字典 | 
|         options: getDictOptions(DICT_TYPE.$dictType.toUpperCase(), 'number'), | 
|       #else##没数据字典 | 
|         options:[], | 
|       #end | 
|     }, | 
|   #elseif($column.htmlType == "checkbox")## 多选框 | 
|     component: 'Checkbox', | 
|     componentProps: { | 
|       #if ("" != $dictType)## 有数据字典 | 
|         options: getDictOptions(DICT_TYPE.$dictType.toUpperCase(), 'number'), | 
|       #else##没数据字典 | 
|         options:[], | 
|       #end | 
|     }, | 
|   #elseif($column.htmlType == "radio")## 单选框 | 
|     component: 'RadioButtonGroup', | 
|     componentProps: { | 
|       #if ("" != $dictType)## 有数据字典 | 
|         options: getDictOptions(DICT_TYPE.$dictType.toUpperCase(), 'number'), | 
|       #else##没数据字典 | 
|         options:[], | 
|       #end | 
|     }, | 
|   #elseif($column.htmlType == "datetime")## 时间框 | 
|     component: 'DatePicker', | 
|     componentProps: { | 
|       showTime: true, | 
|       format: 'YYYY-MM-DD HH:mm:ss', | 
|       valueFormat: 'x', | 
|     }, | 
|   #elseif($column.htmlType == "textarea")## 文本域 | 
|     component: 'InputTextArea', | 
|   #end | 
|   }, | 
| #end | 
| #end | 
| #end | 
| ] | 
|   | 
| export const updateFormSchema: FormSchema[] = [ | 
|   { | 
|     label: '编号', | 
|     field: 'id', | 
|     show: false, | 
|     component: 'Input', | 
|   }, | 
| #foreach($column in $columns) | 
| #if ($column.updateOperation) | 
| #set ($dictType = $column.dictType) | 
| #set ($javaField = $column.javaField) | 
| #set ($AttrName = $column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) | 
| #set ($comment = $column.columnComment) | 
|   #if (!$column.primaryKey)## 忽略主键,不用在表单里 | 
|   { | 
|     label: '${comment}', | 
|     field: '${javaField}', | 
|     #if (($column.createOperation || $column.updateOperation) && !$column.nullable && !${column.primaryKey})## 创建或者更新操作 && 要求非空 && 非主键 | 
|     required: true, | 
|     #end | 
|     #if ($column.htmlType == "input") | 
|     component: 'Input', | 
|     #elseif($column.htmlType == "imageUpload")## 图片上传 | 
|     component: 'FileUpload', | 
|     componentProps: { | 
|       fileType: 'image', | 
|       maxCount: 1, | 
|     }, | 
|     #elseif($column.htmlType == "fileUpload")## 文件上传 | 
|     component: 'FileUpload', | 
|     componentProps: { | 
|       fileType: 'file', | 
|       maxCount: 1, | 
|     }, | 
|     #elseif($column.htmlType == "editor")## 文本编辑器 | 
|     component: 'Editor', | 
|     #elseif($column.htmlType == "select")## 下拉框 | 
|     component: 'Select', | 
|     componentProps: { | 
|       #if ("" != $dictType)## 有数据字典 | 
|       options: getDictOptions(DICT_TYPE.$dictType.toUpperCase(), 'number'), | 
|       #else##没数据字典 | 
|       options:[], | 
|       #end | 
|     }, | 
|     #elseif($column.htmlType == "checkbox")## 多选框 | 
|     component: 'Checkbox', | 
|     componentProps: { | 
|       #if ("" != $dictType)## 有数据字典 | 
|       options: getDictOptions(DICT_TYPE.$dictType.toUpperCase(), 'number'), | 
|       #else##没数据字典 | 
|       options:[], | 
|       #end | 
|     }, | 
|     #elseif($column.htmlType == "radio")## 单选框 | 
|     component: 'RadioButtonGroup', | 
|     componentProps: { | 
|       #if ("" != $dictType)## 有数据字典 | 
|       options: getDictOptions(DICT_TYPE.$dictType.toUpperCase(), 'number'), | 
|       #else##没数据字典 | 
|       options:[], | 
|       #end | 
|     }, | 
|     #elseif($column.htmlType == "datetime")## 时间框 | 
|     component: 'DatePicker', | 
|     componentProps: { | 
|       showTime: true, | 
|       format: 'YYYY-MM-DD HH:mm:ss', | 
|       valueFormat: 'x', | 
|     }, | 
|     #elseif($column.htmlType == "textarea")## 文本域 | 
|     component: 'InputTextArea', | 
|     #end | 
|   }, | 
|   #end | 
| #end | 
| #end | 
| ] |