auth-web/src/views/scheduler/schedulers/utils/hooks.ts

139 lines
3.5 KiB
TypeScript
Raw Normal View History

2024-10-14 21:18:42 +08:00
import { addDialog } from '@/components/BaseDialog/index';
2024-10-17 15:07:45 +08:00
import SchedulersDialog from '@/views/scheduler/schedulers/schedulers-dialog.vue';
2024-10-18 13:51:03 +08:00
import { useSchedulersStore } from '@/store/scheduler/schedulers';
2024-10-14 21:18:42 +08:00
import { h, ref } from 'vue';
import { messageBox } from '@/utils/message';
2024-10-17 15:07:45 +08:00
import type { FormItemProps } from '@/views/scheduler/schedulers/utils/types';
2024-10-14 21:18:42 +08:00
import { $t } from '@/plugins/i18n';
export const formRef = ref();
const schedulersStore = useSchedulersStore();
/** 搜索初始化Schedulers视图 */
2024-10-14 21:18:42 +08:00
export async function onSearch() {
schedulersStore.loading = true;
await schedulersStore.getSchedulersList();
schedulersStore.loading = false;
}
/** 添加Schedulers视图 */
2024-10-14 21:18:42 +08:00
export function onAdd() {
addDialog({
2024-10-24 10:42:44 +08:00
title: `${$t('addNew')}${$t('schedulers')}`,
2024-10-14 21:18:42 +08:00
width: '30%',
props: {
formInline: {
jobName: undefined,
jobGroup: undefined,
description: undefined,
jobClassName: undefined,
cronExpression: undefined,
},
},
draggable: true,
fullscreenIcon: true,
closeOnClickModal: false,
contentRenderer: () => h(SchedulersDialog, { ref: formRef }),
beforeSure: (done, { options }) => {
const form = options.props.formInline as FormItemProps;
formRef.value.formRef.validate(async (valid: any) => {
if (!valid) return;
const result = await schedulersStore.addSchedulers(form);
if (!result) return;
done();
await onSearch();
});
},
});
}
/**
* * Schedulers视图
* @param row
*/
export function onUpdate(row: any) {
addDialog({
title: `${$t('modify')}${$t('schedulers')}`,
width: '30%',
props: {
formInline: {
jobName: row.jobName,
jobGroup: row.jobGroup,
description: row.description,
jobClassName: row.jobClassName,
cronExpression: row.cronExpression,
},
},
draggable: true,
fullscreenIcon: true,
closeOnClickModal: false,
contentRenderer: () => h(SchedulersDialog, { ref: formRef }),
beforeSure: (done, { options }) => {
const form = options.props.formInline as FormItemProps;
formRef.value.formRef.validate(async (valid: any) => {
if (!valid) return;
const result = await schedulersStore.updateSchedulers({ ...form, id: row.id });
if (!result) return;
done();
await onSearch();
});
},
});
}
2024-10-21 16:45:04 +08:00
/** 删除Schedulers视图 */
2024-10-14 21:18:42 +08:00
export const onDelete = async (row: any) => {
2024-10-16 16:57:28 +08:00
const data = { jobName: row.jobName, jobGroup: row.jobGroup };
2024-10-14 21:18:42 +08:00
// 是否确认删除
const result = await messageBox({
2024-10-24 10:42:44 +08:00
title: $t('confirmDelete'),
2024-10-14 21:18:42 +08:00
showMessage: false,
confirmMessage: undefined,
2024-10-24 10:42:44 +08:00
cancelMessage: $t('confirmDelete'),
2024-10-14 21:18:42 +08:00
});
if (!result) return;
// 删除数据
2024-10-16 16:57:28 +08:00
await schedulersStore.deleteSchedulers(data);
2024-10-14 21:18:42 +08:00
await onSearch();
};
2024-10-21 16:45:04 +08:00
/** 暂停任务 */
export const onPause = async (row: any) => {
const data = { jobName: row.jobName, jobGroup: row.jobGroup };
// 是否确认删除
const result = await messageBox({
title: $t('confirm_update_status'),
showMessage: false,
confirmMessage: undefined,
cancelMessage: $t('cancel'),
});
if (!result) return;
// 暂停任务
await schedulersStore.pauseSchedulers(data);
await onSearch();
};
/** 恢复任务 */
export const onResume = async (row: any) => {
const data = { jobName: row.jobName, jobGroup: row.jobGroup };
// 是否确认删除
const result = await messageBox({
title: $t('confirm_update_status'),
showMessage: false,
confirmMessage: undefined,
cancelMessage: $t('cancel'),
});
if (!result) return;
// 恢复任务
await schedulersStore.resumeSchedulers(data);
await onSearch();
};