config.ts 3.17 KB
import { DescItem } from '/@/components/Description';
import { ExecuteTimeTypeEnum, FormFieldsEnum } from '../DetailModal/config';
import { TaskStatusEnum, TaskTargetEnum } from '../../config';
import { h } from 'vue';
import { Tag, Input } from 'ant-design-vue';
import { TaskRecordType } from '/@/api/task/model';
import { PeriodTypeEnum } from '../DetailModal/config';
import { isString } from '/@/utils/is';
import { useI18n } from '/@/hooks/web/useI18n';

enum WeekEnum {
  MON = 'MON',
  TUES = 'TUES',
  WED = 'WED',
  THUR = 'THUR',
  FRI = 'FRI',
  SAT = 'SAT',
  SUN = 'SUN',
}

const { t } = useI18n();
const isWeek = (string: string) => {
  return Object.keys(WeekEnum).some((item) => string.includes(item));
};

const extractCronExpression = (expression: string) => {
  const flag = isWeek(expression);
  const list = expression.split(' ');
  const unit = flag ? list[list.length - 1] : list[3];
  return flag ? t(`enum.week.${unit}`) : unit;
};

export const schemas: DescItem[] = [
  {
    field: FormFieldsEnum.NAME,
    label: t('taskCenter.task.detail.taskname'),
  },
  {
    field: FormFieldsEnum.TARGET_TYPE,
    label: t('taskCenter.task.detail.targetType'),
    render(val: TaskTargetEnum) {
      return h(Tag, { color: val === TaskTargetEnum.DEVICES ? 'blue' : 'cyan' }, () =>
        t(`enum.taskTarget.${val}`)
      );
    },
  },
  {
    field: 'state',
    label: t('taskCenter.task.detail.state'),
    render(val: TaskStatusEnum) {
      return h(Tag, { color: val === TaskStatusEnum.NORMAL ? 'success' : 'error' }, () =>
        t(`enum.taskStatus.${TaskStatusEnum[val]}`)
      );
    },
  },
  {
    field: FormFieldsEnum.EXECUTE_CONTENT_TYPE,
    label: t('taskCenter.task.detail.taskType'),
    render(_val: any, data: TaskRecordType) {
      return t(`enum.taskType.${data.executeContent.type}`);
    },
  },
  {
    field: FormFieldsEnum.EXECUTE_TIME_TYPE,
    label: t('taskCenter.task.detail.timeingMethod'),
    render(_val: any, data: TaskRecordType) {
      return t(`enum.executeTimeType.${data.executeTime.type}`);
    },
  },
  {
    field: FormFieldsEnum.EXECUTE_TIME_INTERVAL,
    label: t('taskCenter.task.detail.intervalTime'),
    render(_val: any, data: TaskRecordType) {
      const { executeTime } = data;
      const { time, type, periodType, pollUnit, period } = executeTime;
      return type === ExecuteTimeTypeEnum.POLL
        ? `${time}${t(`enum.timeUnit.${pollUnit}`)}`
        : `${t(`enum.periodType.${periodType}`)} ${
            periodType === PeriodTypeEnum.DAY
              ? ''
              : `/ ${extractCronExpression(period)}${isWeek(period) ? '' : '号'}`
          } / ${time}`;
    },
  },
  {
    field: 'rpcCommand',
    label: t('taskCenter.task.detail.commandContent'),
    render(_val: any, data: TaskRecordType) {
      const value = data.executeContent.pushContent.rpcCommand;
      return h(Input.TextArea, {
        value: isString(value) ? value : JSON.stringify(value, null, '\t'),
        autoSize: true,
        style: { border: 'none', padding: 0 },
      } as Recordable);
    },
  },
  {
    field: 'createTime',
    label: t('taskCenter.task.detail.createTime'),
  },
  {
    field: 'updateTime',
    label: t('taskCenter.task.detail.editTime'),
  },
];