jiangping
2025-04-16 9f1e7f80a3260c30e1e534437da5c79e17fc20af
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
<template>
  <GlobalWindow
    title="手动执行任务"
    :visible.sync="visible"
    :confirm-working="isWorking"
    confirm-text="立即执行"
    cancel-text="关闭"
    @confirm="confirm"
  >
    <el-form :model="form" ref="form" :rules="rules">
      <template v-if="job != null">
        <el-form-item label="任务名称" prop="jobName">
          {{job.jobName}}
        </el-form-item>
        <el-form-item label="任务处理器" prop="handler">
          {{job.handler}}
        </el-form-item>
      </template>
      <el-form-item label="业务时间" prop="businessTime" required>
        <el-date-picker
          v-model="form.businessTime"
          :clearable="false"
          type="datetime"
          placeholder="请选择业务时间"
          value-format="yyyy-MM-dd HH:mm:ss"
         >
        </el-date-picker>
      </el-form-item>
    </el-form>
  </GlobalWindow>
</template>
 
<script>
import dayjs from 'dayjs'
import GlobalWindow from '@/components/common/GlobalWindow'
import { trigger } from '@/api/system/job'
 
export default {
  name: 'TriggerJobWindow',
  components: { GlobalWindow },
  data () {
    return {
      visible: false,
      isWorking: false,
      // 表单数据
      form: {
        id: null,
        businessTime: null
      },
      // 任务数据
      job: null,
      // 验证规则
      rules: {
        businessTime: [
          { required: true, message: '请选择业务时间' }
        ]
      }
    }
  },
  methods: {
    /**
     * 打开窗口
     *
     * @param row 行对象
     */
    open (row) {
      this.visible = true
      this.form.id = row.id
      this.form.businessTime = dayjs().format('YYYY-MM-DD HH:mm:ss')
      this.job = row
    },
    /**
     * 确认执行
     */
    confirm () {
      this.isWorking = true
      trigger(this.form)
        .then(() => {
          this.$tip.apiSuccess('任务已启动,如任务启用了日志,可在任务日志中查看执行进度。')
          this.visible = false
        })
        .catch(e => {
          this.$tip.apiFailed(e)
        })
        .finally(() => {
          this.isWorking = false
        })
    }
  }
}
</script>