2024-10-14 21:18:42 +08:00
|
|
|
<script lang="ts" setup>
|
2024-10-15 22:40:19 +08:00
|
|
|
import { onMounted, ref } from 'vue';
|
2024-10-14 21:18:42 +08:00
|
|
|
import { FormInstance } from 'element-plus';
|
2024-10-17 15:07:45 +08:00
|
|
|
import { rules } from '@/views/scheduler/schedulers/utils/columns';
|
|
|
|
import { FormProps } from '@/views/scheduler/schedulers/utils/types';
|
2024-10-14 21:18:42 +08:00
|
|
|
import { $t } from '@/plugins/i18n';
|
2024-10-18 13:51:03 +08:00
|
|
|
import { useSchedulersGroupStore } from '@/store/scheduler/schedulersGroup';
|
|
|
|
import { useSchedulersStore } from '@/store/scheduler/schedulers';
|
2024-10-14 21:18:42 +08:00
|
|
|
|
|
|
|
const props = withDefaults(defineProps<FormProps>(), {
|
|
|
|
formInline: () => ({
|
|
|
|
// 任务名称
|
|
|
|
jobName: undefined,
|
|
|
|
// 任务分组
|
|
|
|
jobGroup: undefined,
|
|
|
|
// 任务详情
|
|
|
|
description: undefined,
|
|
|
|
// 任务类名称
|
|
|
|
jobClassName: undefined,
|
|
|
|
// corn表达式
|
|
|
|
cronExpression: undefined,
|
2024-10-15 16:52:03 +08:00
|
|
|
// 执行方法
|
|
|
|
jobMethodName: undefined,
|
2024-10-14 21:18:42 +08:00
|
|
|
}),
|
|
|
|
});
|
|
|
|
|
|
|
|
const formRef = ref<FormInstance>();
|
|
|
|
const form = ref(props.formInline);
|
2024-10-15 22:40:19 +08:00
|
|
|
const schedulersStore = useSchedulersStore();
|
|
|
|
const schedulersGroupStore = useSchedulersGroupStore();
|
|
|
|
|
|
|
|
onMounted(() => {
|
|
|
|
// 获取所有可用调度任务
|
|
|
|
schedulersStore.getAllScheduleJobList();
|
|
|
|
|
|
|
|
// 获取所有任务调度分组
|
|
|
|
schedulersGroupStore.getAllSchedulersGroup();
|
|
|
|
});
|
2024-10-14 21:18:42 +08:00
|
|
|
|
|
|
|
defineExpose({ formRef });
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<template>
|
|
|
|
<el-form ref="formRef" :model="form" :rules="rules" label-width="auto">
|
2024-10-15 22:40:19 +08:00
|
|
|
<!-- 任务名称 -->
|
2024-10-14 21:18:42 +08:00
|
|
|
<el-form-item :label="$t('schedulers_jobName')" prop="jobName">
|
2024-10-15 22:40:19 +08:00
|
|
|
<el-input v-model="form.jobName" :placeholder="$t('input') + $t('schedulers_jobName')" autocomplete="off" type="text" />
|
2024-10-14 21:18:42 +08:00
|
|
|
</el-form-item>
|
2024-10-15 22:40:19 +08:00
|
|
|
|
|
|
|
<!-- 任务分组 -->
|
2024-10-14 21:18:42 +08:00
|
|
|
<el-form-item :label="$t('schedulers_jobGroup')" prop="jobGroup">
|
2024-10-15 22:40:19 +08:00
|
|
|
<el-select v-model="form.jobGroup" :placeholder="$t('select') + $t('schedulers_jobGroup')" clearable filterable>
|
|
|
|
<el-option v-for="(item, index) in schedulersGroupStore.allSchedulersGroup" :key="index" :label="item.groupName" :navigationBar="false" :value="item.groupName" />
|
|
|
|
</el-select>
|
2024-10-14 21:18:42 +08:00
|
|
|
</el-form-item>
|
2024-10-15 22:40:19 +08:00
|
|
|
|
|
|
|
<!-- 需要执行的任务类名 -->
|
2024-10-14 21:18:42 +08:00
|
|
|
<el-form-item :label="$t('schedulers_jobClassName')" prop="jobClassName">
|
2024-10-15 22:40:19 +08:00
|
|
|
<el-select v-model="form.jobClassName" :placeholder="$t('select') + $t('schedulers_jobClassName')" clearable filterable>
|
|
|
|
<el-option v-for="(item, index) in schedulersStore.allScheduleJobList" :key="index" :label="item.label" :navigationBar="false" :value="item.value" />
|
|
|
|
</el-select>
|
2024-10-14 21:18:42 +08:00
|
|
|
</el-form-item>
|
2024-10-15 22:40:19 +08:00
|
|
|
|
|
|
|
<!-- 执行的corn表达式 -->
|
2024-10-14 21:18:42 +08:00
|
|
|
<el-form-item :label="$t('schedulers_cronExpression')" prop="cronExpression">
|
2024-10-15 22:40:19 +08:00
|
|
|
<el-input v-model="form.cronExpression" :placeholder="$t('input') + $t('schedulers_cronExpression')" autocomplete="off" type="text" />
|
2024-10-14 21:18:42 +08:00
|
|
|
</el-form-item>
|
2024-10-17 16:51:56 +08:00
|
|
|
|
|
|
|
<!-- 任务详情 -->
|
|
|
|
<el-form-item :label="$t('schedulers_description')" prop="description">
|
|
|
|
<el-input v-model="form.description" :placeholder="$t('input') + $t('schedulers_description')" autocomplete="off" type="text" />
|
|
|
|
</el-form-item>
|
2024-10-14 21:18:42 +08:00
|
|
|
</el-form>
|
|
|
|
</template>
|