config.ts 1.54 KB
import { h } from 'vue';
import { BasicColumn, FormSchema } from '/@/components/Table';
import { Tag } from 'ant-design-vue';
import { withInstall } from '/@/utils/index';

import VideoPlay from './video.vue';
export const Video = withInstall(VideoPlay);

enum ChannelStatusEnum {
  ONLINE = 'ONLINE',
}

export const configColumns: BasicColumn[] = [
  {
    title: '通道编号',
    dataIndex: 'channelId',
  },
  {
    title: '通道名称',
    dataIndex: 'name',
  },
  {
    title: '型号',
    dataIndex: 'model',
  },
  {
    title: '厂商',
    dataIndex: 'manufacturer',
  },
  // {
  //   title: '开启音频',
  //   dataIndex: 'hasAudio',
  //   slots: { customRender: 'hasAudio' },
  // },
  {
    title: '状态',
    dataIndex: 'status',
    customRender: ({ text }: { text: ChannelStatusEnum }) => {
      return h(
        Tag,
        {
          color: text === ChannelStatusEnum.ONLINE ? 'green' : 'blue',
        },
        () => (text === ChannelStatusEnum.ONLINE ? '在线' : '离线')
      );
    },
  },
  {
    title: '操作',
    dataIndex: 'action',
    slots: { customRender: 'action' },
  },
];

export const searchFormSchema: FormSchema[] | any = [
  {
    field: 'name',
    label: '通道名称',
    component: 'Input',
    colProps: { span: 6 },
    componentProps: {
      maxLength: 255,
      placeholder: '请输入通道名称',
    },
  },
  {
    field: 'cameraCode',
    label: '国标编号',
    component: 'Input',
    colProps: { span: 6 },
    componentProps: {
      placeholder: '请输入国标编号',
    },
  },
];