import type { FormSchemaGetter } from '#/adapter/form'; import type { VxeGridProps } from '#/adapter/vxe-table'; import { h } from 'vue'; import { getPopupContainer } from '@vben/utils'; import { getDictOptions } from '#/utils/dict'; import { DictEnum } from '@vben/constants'; export const fallImg = ''; export const querySchema: FormSchemaGetter = () => [ { component: 'Input', fieldName: 'alarmType', label: '视频预警类型', }, { component: 'Select', componentProps: { getPopupContainer, options: getDictOptions(DictEnum.alarm_level, true), }, fieldName: 'level', label: '级别', }, { component: 'Select', componentProps: { getPopupContainer, options: getDictOptions(DictEnum.alarm_state, true), }, fieldName: 'state', label: '处理状态', }, ]; export const columns: VxeGridProps['columns'] = [ { type: 'checkbox', width: 60 }, { title: '预警编号', field: 'id', }, { title: '预警时间', field: 'reportTime', }, { title: '设备名称', field: 'deviceName', }, { title: '级别', field: 'level', slots: { default: ({ row }: any) => { const levelColors: Record = { 1: 'red', 2: 'orange', 3: 'blue', }; return h( 'span', { style: { color: levelColors[row.level] || '#666', fontWeight: 'bold', }, }, row.levelName, ); }, }, }, { title: '预警类型', field: 'alarmTypeName', slots: { default: ({ row }: any) => { return h('span', row.bigTypeName + '-' + row.smallTypeName); }, }, }, { title: '处理状态', field: 'stateName', }, { title: '预期处理时间', field: 'servBeginTime', }, { title: '处理时间', field: 'servEndTime', }, { field: 'action', fixed: 'right', slots: { default: 'action' }, title: '操作', width: 380, }, ]; export const modalSchema: FormSchemaGetter = () => [ { label: '主键', fieldName: 'id', component: 'Input', dependencies: { show: () => false, triggerFields: [''], }, }, { label: '预警编号', fieldName: 'id', component: 'Input', rules: 'required', disabled: true, }, { label: '预警时间', fieldName: 'reportTime', component: 'DatePicker', componentProps: { format: 'YYYY.MM.DD HH:mm', valueFormat: 'YYYY.MM.DD HH:mm', showTime: true, }, rules: 'required', disabled: true, }, { label: '预警类型', fieldName: 'bigTypeName', component: 'Input', rules: 'required', disabled: true, }, { label: '描述', fieldName: 'description', component: 'Input', formItemClass: 'col-span-2', disabled: true, }, /* { label: '所在位置', fieldName: 'location', component: 'Input', rules: 'required', disabled: true, },*/ { label: '设备名称', fieldName: 'deviceName', component: 'Input', rules: 'required', disabled: true, }, { label: '处理情况', fieldName: 'processingDetails', component: 'Input', componentProps: { rows: 3, }, formItemClass: 'col-span-2', disabled: true, }, { label: '处理时间', fieldName: 'processingTime', component: 'DatePicker', componentProps: { format: 'YYYY.MM.DD HH:mm', valueFormat: 'YYYY.MM.DD HH:mm', showTime: true, }, disabled: true, }, { label: '处理图片', fieldName: 'imgUrl', component: 'Input', rules: 'required', disabled: true, }, { label: '级别', fieldName: 'level', component: 'Select', componentProps: { getPopupContainer, options: getDictOptions(DictEnum.alarm_level, true), }, rules: 'selectRequired', }, { label: '处理状态', component: 'Select', componentProps: { getPopupContainer, options: getDictOptions(DictEnum.alarm_state, true), }, fieldName: 'state', rules: 'selectRequired', }, { label: '预期处理时间', fieldName: 'expectedProcessingTime', component: 'DatePicker', componentProps: { format: 'YYYY.MM.DD HH:mm', valueFormat: 'YYYY.MM.DD HH:mm', showTime: true, }, rules: 'required', }, ];