index.ts 1.8 KB
import { FormSchema } from '/@/components/Form';
import { useI18n } from '/@/hooks/web/useI18n';
import { BasicColumn } from '/@/components/Table';
import { getServicePlanList } from '/@/api/inspection/servicePlan';
const { t } = useI18n();

const statusOptions = [
  { label: t('inspection.serviceRecord.INCOMPLETE'), value: 'INCOMPLETE' },
  { label: t('inspection.serviceRecord.COMPLETE'), value: 'COMPLETE' },
];

export const searchFormSchema: FormSchema[] = [
  {
    field: 'preservePlanId',
    label: t('inspection.serviceRecord.planText'),
    component: 'ApiSelect',
    colProps: { span: 6 },
    componentProps: {
      api: getServicePlanList,
      params: {
        page: 1,
        pageSize: 999,
      },
      resultField: 'items',
      labelField: 'preserveName',
      valueField: 'id',
    },
  },
  {
    field: 'preserveStatus',
    label: t('inspection.serviceRecord.preserveNameText'),
    component: 'Select',
    colProps: { span: 6 },
    componentProps: {
      options: statusOptions,
    },
  },
  {
    field: 'startDate',
    label: t('inspection.serviceRecord.startTime'),
    component: 'DatePicker',
    colProps: { span: 6 },
  },
  {
    field: 'endDate',
    label: t('inspection.serviceRecord.endTime'),
    component: 'DatePicker',
    colProps: { span: 6 },
  },
];

export const columns: BasicColumn[] = [
  {
    title: t('inspection.serviceRecord.recordCodeText'),
    dataIndex: 'recordCode',
  },
  {
    title: t('inspection.serviceRecord.createTimeText'),
    dataIndex: 'preserveDate',
  },
  {
    dataIndex: 'preserveByName',
  },
  {
    title: t('inspection.serviceRecord.preserveNameText'),
    dataIndex: 'preserveStatus',
    slots: { customRender: 'preserveStatus' },
  },
  {
    title: t('inspection.serviceRecord.preservePlanName'),
    dataIndex: 'preservePlanName',
  },
];