dept.data.ts 3.05 KB
import { BasicColumn } from '/@/components/Table';
import { FormSchema } from '/@/components/Table';
import { h } from 'vue';
import { Tag } from 'ant-design-vue';
import {useI18n} from "/@/hooks/web/useI18n";
const { t } = useI18n();

export const columns: BasicColumn[] = [
  {
    title: t('routes.common.dept.queryDeptName'),//部门名称
    dataIndex: 'deptName',
    width: 160,
    align: 'left',
  },
  {
    title: t('routes.common.dept.tableTitleDeptSort'),//排序
    dataIndex: 'orderNo',
    width: 50,
  },
  {
    title: t('routes.common.dept.queryDeptStatus'),//状态
    dataIndex: 'status',
    width: 80,
    customRender: ({ record }) => {
      const status = record.status;
      const enable = ~~status === 0;
      const color = enable ? 'green' : 'red';
      const text = enable ? t('routes.common.dept.drawerTitleDeptEnable') : t('routes.common.dept.drawerTitleDeptDisable');
      // const text = enable ? '启用' : '停用';
      return h(Tag, { color: color }, () => text);
    },
  },
  {
    title: t('routes.common.dept.tableTitleDeptCreateTime'),//创建时间
    dataIndex: 'createTime',
    width: 180,
  },
  {
    title: t('routes.common.dept.tableTitleMemo'),//备注
    dataIndex: 'remark',
  },
];

export const searchFormSchema: FormSchema[] = [
  {
    field: 'deptName',
    label: t('routes.common.dept.queryDeptName'),//部门名称
    component: 'Input',
    colProps: { span: 8 },
  },
  {
    field: 'status',
    label: t('routes.common.dept.queryDeptStatus'),//状态
    component: 'Select',
    componentProps: {
      options: [
        { label: t('routes.common.dept.drawerTitleDeptEnable'), value: 0 },
        // { label: '启用', value: 0 },
        { label: t('routes.common.dept.drawerTitleDeptDisable'), value: 1 },
        // { label: '停用', value: 1 },
      ],
    },
    colProps: { span: 8 },
  },
];

export const formSchema: FormSchema[] = [
  {
    field: 'deptName',
    label: t('routes.common.dept.queryDeptName'),//部门名称
    component: 'Input',
    required: true,
  },
  {
    field: 'parentId',
    label: t('routes.common.dept.drawerTitleDeptParentDept'),//上级部门
    component: 'TreeSelect',
    componentProps: {
      replaceFields: {
        title: 'deptName',
        key: 'id',
        value: 'id',
      },
      getPopupContainer: () => document.body,
    },
    // required: true,
  },
  {
    field: 'orderNo',
    label: t('routes.common.dept.tableTitleDeptSort'),//排序
    component: 'InputNumber',
    required: true,
  },
  {
    field: 'status',
    label: t('routes.common.dept.queryDeptStatus'),//状态
    component: 'RadioButtonGroup',
    defaultValue: 0,
    componentProps: {
      options: [
        { label: t('routes.common.dept.drawerTitleDeptEnable'), value: 0 },
        // { label: '启用', value: 0 },
        { label: t('routes.common.dept.drawerTitleDeptDisable'), value: 1 },
        // { label: '停用', value: 1 },
      ],
    },
    required: true,
  },
  {
    label: t('routes.common.dept.tableTitleMemo'),//备注
    field: 'remark',
    component: 'InputTextArea',
  },
];