index.ts 2.62 KB
import {FormSchema} from "/@/components/Form";
import {useI18n} from "/@/hooks/web/useI18n";
import {BasicColumn} from "/@/components/Table";
const { t } = useI18n();


const statusOptions = [
  { label: t('equipment.checkPlan.enableText'), value: 'ENABLE' },
  { label: t('equipment.checkPlan.disabledText'), value: 'DISABLE' },
];
const typeOptions = [
  { label: t('equipment.checkPlan.inspectionText'), value: 'INSPECTION' },
  { label: t('equipment.checkPlan.maintenanceText'), value: 'MAINTENANCE' },
];

export const columns: BasicColumn[] = [
  {
    title: t('equipment.checkPlan.nameCode'),
    dataIndex: 'code',
  },
  {
    title: t('equipment.checkPlan.nameText'),
    dataIndex: 'name',
  },
  {
    title: t('equipment.checkPlan.typeText'),
    dataIndex: 'type',
    slots: { customRender: 'type' },
  },
  {
    title: t('equipment.checkPlan.statusText'),
    dataIndex: 'status',
    slots: { customRender: 'status' },
  },
  {
    title: t('equipment.checkPlan.planDetails'),
    dataIndex: 'planDetails',
  },
];

export const searchFormSchema: FormSchema[] = [
  {
    field: 'name',
    label: t('equipment.checkPlan.nameText'),
    component: 'Input',
    colProps: { span: 6 },
    componentProps: {
      maxLength: 255,
    },
  },

  {
    field: 'type',
    label: t('equipment.checkPlan.typeText'),
    component: 'Select',
    colProps: { span: 6 },
    componentProps: {
      options: typeOptions,
    },
  },
  {
    field: 'status',
    label: t('equipment.checkPlan.statusText'),
    component: 'Select',
    colProps: { span: 6 },
    componentProps: {
      options: statusOptions,
    },
  }
];

export const schemas: FormSchema[] = [
  {
    field: 'code',
    label: t('equipment.checkPlan.nameCode'),
    component: 'Input',
    colProps: { span: 21 },
    required: true,
    componentProps: {
      maxLength: 20,
    },
  },
  {
    field: 'name',
    label: t('equipment.checkPlan.nameText'),
    component: 'Input',
    colProps: { span: 21 },
    required: true,
    componentProps: {
      maxLength: 20,
    },
  },
  {
    field: 'type',
    label: t('equipment.checkPlan.typeText'),
    component: 'RadioButtonGroup',
    defaultValue: 'INSPECTION',
    componentProps: {
      options: typeOptions,
    },
  },
  {
    field: 'status',
    label: t('equipment.checkPlan.statusText'),
    component: 'RadioButtonGroup',
    defaultValue: 'ENABLE',
    componentProps: {
      options: statusOptions,
    },
  },
  {
    field: 'planDetails',
    label: t('equipment.checkPlan.nameDetail'),
    component: 'InputTextArea',
    colProps: { span: 21 },
    required: true,
    componentProps: {
      maxLength: 200,
    },
  },
];