12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576 |
- import { reactive } from 'vue'
- import { useI18n } from '@/hooks/web/useI18n'
- import { CrudSchema, useCrudSchemas } from '@/hooks/web/useCrudSchemas'
- const { t } = useI18n() // 国际化
- // CrudSchema
- const crudSchemas = reactive<CrudSchema[]>([
- {
- label: t('common.index'),
- field: 'id',
- type: 'index'
- },
- {
- label: '任务名称',
- field: 'name',
- search: {
- show: true
- }
- },
- {
- label: '所属流程',
- field: 'processInstance.name'
- },
- {
- label: '流程发起人',
- field: 'processInstance.startUserNickname'
- },
- {
- label: t('common.createTime'),
- field: 'createTime',
- search: {
- show: true,
- component: 'DatePicker',
- componentProps: {
- type: 'datetimerange',
- valueFormat: 'YYYY-MM-DD HH:mm:ss',
- defaultTime: [new Date(2000, 1, 1, 0, 0, 0), new Date(2000, 2, 1, 23, 59, 59)],
- shortcuts: [
- {
- text: '近一周',
- value: () => {
- const end = new Date()
- const start = new Date()
- start.setTime(start.getTime() - 3600 * 1000 * 24 * 7)
- return [start, end]
- }
- },
- {
- text: '近一个月',
- value: () => {
- const end = new Date()
- const start = new Date()
- start.setTime(start.getTime() - 3600 * 1000 * 24 * 30)
- return [start, end]
- }
- },
- {
- text: '近三个月',
- value: () => {
- const end = new Date()
- const start = new Date()
- start.setTime(start.getTime() - 3600 * 1000 * 24 * 90)
- return [start, end]
- }
- }
- ]
- }
- }
- },
- {
- label: t('table.action'),
- field: 'action',
- width: '100px'
- }
- ])
- export const { allSchemas } = useCrudSchemas(crudSchemas)
|