first commit
This commit is contained in:
143
src/views/flow/task/cc.vue
Normal file
143
src/views/flow/task/cc.vue
Normal file
@@ -0,0 +1,143 @@
|
||||
<template>
|
||||
<div class="layout-padding">
|
||||
<div class="layout-padding-auto layout-padding-view">
|
||||
<el-row shadow="hover" v-show="showSearch" class="ml10">
|
||||
<el-form :model="state.queryForm" ref="queryRef" :inline="true" @keyup.enter="getDataList">
|
||||
<el-form-item label="发起时间" prop="taskTime">
|
||||
<el-date-picker
|
||||
type="datetimerange"
|
||||
value-format="YYYY-MM-DD HH:mm:ss"
|
||||
v-model="state.queryForm.taskTime"
|
||||
is-range
|
||||
range-separator="To"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item>
|
||||
<el-button icon="search" type="primary" @click="getDataList">
|
||||
{{ $t('common.queryBtn') }}
|
||||
</el-button>
|
||||
<el-button icon="Refresh" @click="resetQuery">{{ $t('common.resetBtn') }}</el-button>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
</el-row>
|
||||
|
||||
<el-row>
|
||||
<div class="mb8" style="width: 100%">
|
||||
<right-toolbar
|
||||
v-model:showSearch="showSearch"
|
||||
class="ml10"
|
||||
style="float: right; margin-right: 20px"
|
||||
@queryTable="getDataList"
|
||||
></right-toolbar>
|
||||
</div>
|
||||
</el-row>
|
||||
|
||||
<el-table
|
||||
ref="dataTableRef"
|
||||
v-loading="loading"
|
||||
:data="state.dataList"
|
||||
highlight-current-row
|
||||
border
|
||||
:cell-style="tableStyle.cellStyle"
|
||||
:header-cell-style="tableStyle.headerCellStyle"
|
||||
>
|
||||
<el-table-column label="分组" prop="groupName" width="100" />
|
||||
<el-table-column label="流程" prop="processName" />
|
||||
<el-table-column label="发起人" prop="startUserName" />
|
||||
<el-table-column label="发起时间" prop="startTime" />
|
||||
<el-table-column label="节点" prop="nodeName" />
|
||||
<el-table-column label="抄送时间" prop="nodeTime" />
|
||||
|
||||
<el-table-column fixed="right" label="操作" width="200">
|
||||
<template #default="scope">
|
||||
<el-button type="primary" size="small" icon="View" link @click="deal(scope.row)"> 查看 </el-button>
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
|
||||
<pagination @current-change="currentChangeHandle" @size-change="sizeChangeHandle" v-bind="state.pagination"></pagination>
|
||||
</div>
|
||||
<!-- 右侧抽屉-->
|
||||
<el-drawer v-model="rightDrawerVisible" v-if="rightDrawerVisible" direction="rtl" size="600px">
|
||||
<template #header>
|
||||
<h3>{{ currentData?.processName }}</h3>
|
||||
</template>
|
||||
<template #default>
|
||||
<el-card class="box-card">
|
||||
<FormCreate :rule="rule" v-model="formData" v-model:api="fApi" />
|
||||
</el-card>
|
||||
<flow-node-format
|
||||
:disableSelect="true"
|
||||
:processInstanceId="currentData.processInstanceId"
|
||||
:flow-id="currentData.flowId"
|
||||
ref="flowNodeFormatRef"
|
||||
></flow-node-format>
|
||||
</template>
|
||||
</el-drawer>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup lang="ts">
|
||||
import FlowNodeFormat from '/@/views/flow/form/tools/FlowNodeFormatData.vue';
|
||||
import FormCreate from '/@/views/flow/workflow/components/FormCreate.vue';
|
||||
|
||||
import { queryMineCC, queryMineCCDetail } from '/@/api/flow/task';
|
||||
import { BasicTableProps, useTable } from '/@/hooks/table';
|
||||
|
||||
import FcDesigner from 'form-create-designer';
|
||||
import { processFormItemsWithPerms } from '/@/views/flow/workflow/utils/formPermissions';
|
||||
|
||||
const rule = ref([]);
|
||||
const fApi = ref();
|
||||
const formData = ref({});
|
||||
const currentData = ref();
|
||||
|
||||
const state: BasicTableProps = reactive<BasicTableProps>({
|
||||
pageList: queryMineCC,
|
||||
queryForm: {
|
||||
taskTime: undefined,
|
||||
},
|
||||
});
|
||||
|
||||
const { tableStyle ,getDataList, currentChangeHandle,
|
||||
sortChangeHandle,
|
||||
sizeChangeHandle, } = useTable(state);
|
||||
|
||||
const rightDrawerVisible = ref(false);
|
||||
|
||||
const loading = ref(false);
|
||||
const showSearch = ref(true);
|
||||
const queryRef = ref();
|
||||
|
||||
/**
|
||||
* 点击开始处理
|
||||
* @param row
|
||||
*/
|
||||
const deal = (row) => {
|
||||
currentData.value = row;
|
||||
|
||||
queryMineCCDetail({ id: row.id }).then((res) => {
|
||||
const { formItems, formPerms, formData: responseFormData } = res.data;
|
||||
|
||||
// 解析表单项并处理权限
|
||||
const parsedFormItems = FcDesigner.formCreate.parseJson(formItems);
|
||||
const itemsWithPerms = processFormItemsWithPerms(parsedFormItems, formPerms);
|
||||
|
||||
rule.value = itemsWithPerms;
|
||||
formData.value = FcDesigner.formCreate.parseJson(responseFormData);
|
||||
currentOpenFlowForm.value = formItems;
|
||||
rightDrawerVisible.value = true;
|
||||
});
|
||||
};
|
||||
const currentOpenFlowForm = ref();
|
||||
|
||||
// 清空搜索条件
|
||||
const resetQuery = () => {
|
||||
queryRef.value.resetFields();
|
||||
getDataList();
|
||||
};
|
||||
|
||||
onMounted(() => {
|
||||
getDataList();
|
||||
});
|
||||
</script>
|
||||
140
src/views/flow/task/completed.vue
Normal file
140
src/views/flow/task/completed.vue
Normal file
@@ -0,0 +1,140 @@
|
||||
<template>
|
||||
<div class="layout-padding">
|
||||
<div class="layout-padding-auto layout-padding-view">
|
||||
<el-row shadow="hover" v-show="showSearch" class="ml10">
|
||||
<el-form :model="state.queryForm" ref="queryRef" :inline="true" @keyup.enter="getDataList">
|
||||
<el-form-item label="发起时间" prop="taskTime">
|
||||
<el-date-picker
|
||||
type="datetimerange"
|
||||
value-format="YYYY-MM-DD HH:mm:ss"
|
||||
v-model="state.queryForm.taskTime"
|
||||
is-range
|
||||
range-separator="To"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item>
|
||||
<el-button icon="search" type="primary" @click="getDataList">
|
||||
{{ $t('common.queryBtn') }}
|
||||
</el-button>
|
||||
<el-button icon="Refresh" @click="resetQuery">{{ $t('common.resetBtn') }}</el-button>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
</el-row>
|
||||
|
||||
<el-row>
|
||||
<div class="mb8" style="width: 100%">
|
||||
<right-toolbar
|
||||
v-model:showSearch="showSearch"
|
||||
class="ml10"
|
||||
style="float: right; margin-right: 20px"
|
||||
@queryTable="getDataList"
|
||||
></right-toolbar>
|
||||
</div>
|
||||
</el-row>
|
||||
<el-table
|
||||
ref="dataTableRef"
|
||||
v-loading="loading"
|
||||
:data="state.dataList"
|
||||
highlight-current-row
|
||||
border
|
||||
:cell-style="tableStyle.cellStyle"
|
||||
:header-cell-style="tableStyle.headerCellStyle"
|
||||
>
|
||||
<el-table-column label="分组" prop="groupName" width="100" />
|
||||
<el-table-column label="流程" prop="processName" />
|
||||
<el-table-column label="发起人" prop="rootUserName" />
|
||||
<el-table-column label="发起时间" prop="startTime" />
|
||||
<el-table-column label="任务名称" prop="taskName" />
|
||||
<el-table-column label="任务开始时间" prop="taskCreateTime" />
|
||||
<el-table-column label="任务结束时间" prop="taskEndTime" />
|
||||
<el-table-column fixed="right" label="操作" width="200">
|
||||
<template #default="scope">
|
||||
<el-button type="primary" size="small" link icon="View" @click="deal(scope.row)"> 查看 </el-button>
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
|
||||
<pagination @current-change="currentChangeHandle" @size-change="sizeChangeHandle" v-bind="state.pagination"></pagination>
|
||||
</div>
|
||||
<!-- 右侧抽屉-->
|
||||
<el-drawer v-model="rightDrawerVisible" v-if="rightDrawerVisible" direction="rtl" size="600px">
|
||||
<template #header>
|
||||
<h3>{{ currentData?.processName }}</h3>
|
||||
</template>
|
||||
<template #default>
|
||||
<el-card class="box-card">
|
||||
<FormCreate
|
||||
:rule="rule"
|
||||
v-model="formData"
|
||||
v-model:api="fApi"
|
||||
/>
|
||||
</el-card>
|
||||
<flow-node-format
|
||||
:disableSelect="true"
|
||||
:processInstanceId="currentData.processInstanceId"
|
||||
:flow-id="currentData.flowId"
|
||||
ref="flowNodeFormatRef"
|
||||
></flow-node-format>
|
||||
</template>
|
||||
</el-drawer>
|
||||
</div>
|
||||
</template>
|
||||
<script setup lang="ts">
|
||||
import FlowNodeFormat from '/@/views/flow/form/tools/FlowNodeFormatData.vue';
|
||||
import FormCreate from '/@/views/flow/workflow/components/FormCreate.vue';
|
||||
|
||||
import { queryMineEndTask, queryTask, stopProcessInstance } from '/@/api/flow/task';
|
||||
|
||||
import { BasicTableProps, useTable } from '/@/hooks/table';
|
||||
import FcDesigner from 'form-create-designer';
|
||||
import { processFormItemsWithPerms } from '/@/views/flow/workflow/utils/formPermissions';
|
||||
|
||||
const rule = ref([]);
|
||||
const fApi = ref();
|
||||
const formData = ref({});
|
||||
const state: BasicTableProps = reactive<BasicTableProps>({
|
||||
pageList: queryMineEndTask,
|
||||
queryForm: {
|
||||
taskTime: undefined,
|
||||
},
|
||||
});
|
||||
|
||||
const { tableStyle, getDataList, currentChangeHandle, sortChangeHandle, sizeChangeHandle } = useTable(state);
|
||||
|
||||
const rightDrawerVisible = ref(false);
|
||||
|
||||
const loading = ref(false);
|
||||
const showSearch = ref(true);
|
||||
const queryRef = ref();
|
||||
const currentData = ref();
|
||||
/**
|
||||
* 点击开始处理
|
||||
* @param row
|
||||
*/
|
||||
const deal = (row) => {
|
||||
currentData.value = row;
|
||||
queryTask(row.taskId, true).then((res) => {
|
||||
const { formItems, formPerms, formData: responseFormData } = res.data;
|
||||
|
||||
// 解析表单项并处理权限
|
||||
const parsedFormItems = FcDesigner.formCreate.parseJson(formItems);
|
||||
const itemsWithPerms = processFormItemsWithPerms(parsedFormItems, formPerms);
|
||||
|
||||
rule.value = itemsWithPerms;
|
||||
formData.value = responseFormData;
|
||||
currentOpenFlowForm.value = formItems;
|
||||
rightDrawerVisible.value = true;
|
||||
});
|
||||
};
|
||||
const currentOpenFlowForm = ref();
|
||||
|
||||
// 清空搜索条件
|
||||
const resetQuery = () => {
|
||||
queryRef.value.resetFields();
|
||||
getDataList();
|
||||
};
|
||||
|
||||
onMounted(() => {
|
||||
getDataList();
|
||||
});
|
||||
</script>
|
||||
84
src/views/flow/task/handler/agree.vue
Normal file
84
src/views/flow/task/handler/agree.vue
Normal file
@@ -0,0 +1,84 @@
|
||||
<script setup lang="ts">
|
||||
import { ref } from 'vue'
|
||||
import { completeTask } from '/@/api/flow/task'
|
||||
import type { FlowFormItem, TaskData, TaskSubmitParam } from './types'
|
||||
|
||||
const dialogVisible = ref(false)
|
||||
const submitDesc = ref('')
|
||||
const currentData = ref<TaskData>()
|
||||
const currentOpenFlowForm = ref<FlowFormItem[]>()
|
||||
|
||||
const handle = (row: TaskData, formData: FlowFormItem[]) => {
|
||||
submitDesc.value = ''
|
||||
currentData.value = row
|
||||
currentOpenFlowForm.value = formData
|
||||
dialogVisible.value = true
|
||||
}
|
||||
|
||||
defineExpose({ handle })
|
||||
const emit = defineEmits<{
|
||||
(e: 'taskSubmitEvent'): void
|
||||
}>()
|
||||
|
||||
const submit = async () => {
|
||||
if (!currentData.value || !currentOpenFlowForm.value) return
|
||||
|
||||
const formData: Record<string, any> = {}
|
||||
formData[`${currentData.value.nodeId}_approve_condition`] = true
|
||||
|
||||
const param: TaskSubmitParam = {
|
||||
paramMap: formData,
|
||||
taskId: currentData.value.taskId,
|
||||
taskLocalParamMap: {
|
||||
approveDesc: submitDesc.value,
|
||||
},
|
||||
}
|
||||
|
||||
try {
|
||||
await completeTask(param)
|
||||
dialogVisible.value = false
|
||||
emit('taskSubmitEvent')
|
||||
} catch (error) {
|
||||
console.error('Failed to complete task:', error)
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<div>
|
||||
<el-dialog
|
||||
v-model="dialogVisible"
|
||||
title="提交审核"
|
||||
:width="400"
|
||||
class="rounded-lg shadow-xl"
|
||||
>
|
||||
<div class="p-4 space-y-4">
|
||||
<el-input
|
||||
v-model="submitDesc"
|
||||
type="textarea"
|
||||
maxlength="100"
|
||||
:rows="5"
|
||||
placeholder="请输入审核意见..."
|
||||
show-word-limit
|
||||
class="w-full transition-all duration-300 focus:ring-2 focus:ring-primary"
|
||||
/>
|
||||
|
||||
<div class="flex justify-end pt-4 space-x-3">
|
||||
<el-button
|
||||
@click="dialogVisible = false"
|
||||
class="hover:bg-gray-100 dark:hover:bg-gray-700"
|
||||
>
|
||||
取消
|
||||
</el-button>
|
||||
<el-button
|
||||
type="primary"
|
||||
@click="submit"
|
||||
class="bg-primary hover:bg-primary-focus"
|
||||
>
|
||||
确定
|
||||
</el-button>
|
||||
</div>
|
||||
</div>
|
||||
</el-dialog>
|
||||
</div>
|
||||
</template>
|
||||
56
src/views/flow/task/handler/refuse.vue
Normal file
56
src/views/flow/task/handler/refuse.vue
Normal file
@@ -0,0 +1,56 @@
|
||||
<script setup lang="ts">
|
||||
import {defineExpose} from 'vue';
|
||||
import {completeTask} from '/@/api/flow/task';
|
||||
|
||||
const dialogVisible = ref(false);
|
||||
|
||||
const submitDesc = ref('');
|
||||
|
||||
const currentData = ref();
|
||||
const currentProcessInstanceId = ref('')
|
||||
const currentOpenFlowForm = ref();
|
||||
|
||||
const handle = (row, formData) => {
|
||||
submitDesc.value = '';
|
||||
currentProcessInstanceId.value = row.processInstanceId;
|
||||
currentData.value = row;
|
||||
currentOpenFlowForm.value = formData;
|
||||
|
||||
dialogVisible.value = true;
|
||||
};
|
||||
|
||||
defineExpose({ handle });
|
||||
const emit = defineEmits(['taskSubmitEvent']);
|
||||
|
||||
const submit = () => {
|
||||
const formData: Record<string, any> = {};
|
||||
formData[`${currentData.value.nodeId}_approve_condition`] = false;
|
||||
|
||||
const param = {
|
||||
paramMap: formData,
|
||||
taskId: currentData.value.taskId,
|
||||
taskLocalParamMap: {
|
||||
approveDesc: '拒绝原因:' + submitDesc.value,
|
||||
},
|
||||
};
|
||||
|
||||
completeTask(param).then((res) => {
|
||||
dialogVisible.value = false;
|
||||
emit('taskSubmitEvent');
|
||||
});
|
||||
};
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<div>
|
||||
<el-dialog v-model="dialogVisible" title="拒绝审核" width="400px">
|
||||
<el-input v-model="submitDesc" type="textarea" maxlength="100" :rows="5" placeholder="审核意见" show-word-limit />
|
||||
<template #footer>
|
||||
<span class="dialog-footer">
|
||||
<el-button @click="dialogVisible = false">取消</el-button>
|
||||
<el-button type="primary" @click="submit"> 确定 </el-button>
|
||||
</span>
|
||||
</template>
|
||||
</el-dialog>
|
||||
</div>
|
||||
</template>
|
||||
113
src/views/flow/task/handler/transfer.vue
Normal file
113
src/views/flow/task/handler/transfer.vue
Normal file
@@ -0,0 +1,113 @@
|
||||
<script setup lang="ts">
|
||||
import { defineExpose, ref } from 'vue';
|
||||
import { transferTask } from '/@/api/flow/task';
|
||||
import selectShow from '/@/components/OrgSelector/index.vue';
|
||||
import { ElMessage } from 'element-plus';
|
||||
|
||||
interface FlowFormItem {
|
||||
id: string;
|
||||
type: string;
|
||||
props: {
|
||||
value: any;
|
||||
label?: string;
|
||||
};
|
||||
}
|
||||
|
||||
interface TaskData {
|
||||
taskId: string;
|
||||
nodeId: string;
|
||||
}
|
||||
|
||||
const dialogVisible = ref(false);
|
||||
const submitDesc = ref('');
|
||||
const userList = ref<Array<{ id: string }>>([]);
|
||||
const currentData = ref<TaskData>();
|
||||
const currentOpenFlowForm = ref<FlowFormItem[]>();
|
||||
|
||||
const handle = (row: TaskData, formData: FlowFormItem[]) => {
|
||||
submitDesc.value = '';
|
||||
currentData.value = row;
|
||||
currentOpenFlowForm.value = formData;
|
||||
dialogVisible.value = true;
|
||||
};
|
||||
|
||||
defineExpose({ handle });
|
||||
const emit = defineEmits(['taskSubmitEvent']);
|
||||
|
||||
const validateForm = (): boolean => {
|
||||
if (userList.value.length === 0) {
|
||||
ElMessage.warning('请选择转办人员');
|
||||
return false;
|
||||
}
|
||||
|
||||
if (!submitDesc.value.trim()) {
|
||||
ElMessage.warning('请输入审核意见');
|
||||
return false;
|
||||
}
|
||||
|
||||
if (submitDesc.value.trim().length < 2) {
|
||||
ElMessage.warning('审核意见至少需要2个字符');
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
};
|
||||
|
||||
const submit = async () => {
|
||||
if (!currentOpenFlowForm.value || !currentData.value) return;
|
||||
|
||||
// 表单校验
|
||||
if (!validateForm()) return;
|
||||
|
||||
try {
|
||||
const formData: Record<string, any> = {};
|
||||
|
||||
formData[`${currentData.value.nodeId}_approve_condition`] = true;
|
||||
|
||||
const param = {
|
||||
paramMap: formData,
|
||||
taskId: currentData.value.taskId,
|
||||
targetUserIdList: userList.value.map((user) => user.id),
|
||||
taskLocalParamMap: {
|
||||
approveDesc: '转办事由:' + submitDesc.value.trim(),
|
||||
},
|
||||
};
|
||||
|
||||
await transferTask(param);
|
||||
ElMessage.success('转办成功');
|
||||
dialogVisible.value = false;
|
||||
emit('taskSubmitEvent');
|
||||
} catch (error) {
|
||||
ElMessage.error('转办失败,请重试');
|
||||
}
|
||||
};
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<div>
|
||||
<el-dialog v-model="dialogVisible" width="400px" :close-on-click-modal="false" :close-on-press-escape="false" class="transfer-dialog">
|
||||
<div class="space-y-4">
|
||||
<div class="w-full">
|
||||
<label class="block pb-2">
|
||||
<span class="text-base font-medium after:content-['*'] after:text-red-500 after:ml-1"> 选择转办人员 </span>
|
||||
</label>
|
||||
<select-show v-model:orgList="userList" type="user" :multiple="true"></select-show>
|
||||
</div>
|
||||
|
||||
<div class="w-full">
|
||||
<label class="block pb-2">
|
||||
<span class="text-base font-medium after:content-['*'] after:text-red-500 after:ml-1"> 审核意见 </span>
|
||||
</label>
|
||||
<el-input v-model="submitDesc" type="textarea" maxlength="100" :rows="5" placeholder="请输入审核意见(2-100字)" show-word-limit />
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<template #footer>
|
||||
<span class="flex justify-end gap-2">
|
||||
<el-button @click="dialogVisible = false">取消</el-button>
|
||||
<el-button type="primary" @click="submit">确定</el-button>
|
||||
</span>
|
||||
</template>
|
||||
</el-dialog>
|
||||
</div>
|
||||
</template>
|
||||
22
src/views/flow/task/handler/types.ts
Normal file
22
src/views/flow/task/handler/types.ts
Normal file
@@ -0,0 +1,22 @@
|
||||
// First let's create types for our form data
|
||||
export interface FlowFormItem {
|
||||
id: string
|
||||
type: string
|
||||
props: {
|
||||
value: any
|
||||
[key: string]: any
|
||||
}
|
||||
}
|
||||
|
||||
export interface TaskData {
|
||||
taskId: string
|
||||
nodeId: string
|
||||
}
|
||||
|
||||
export interface TaskSubmitParam {
|
||||
paramMap: Record<string, any>
|
||||
taskId: string
|
||||
taskLocalParamMap: {
|
||||
approveDesc: string
|
||||
}
|
||||
}
|
||||
198
src/views/flow/task/pending.vue
Normal file
198
src/views/flow/task/pending.vue
Normal file
@@ -0,0 +1,198 @@
|
||||
<template>
|
||||
<div class="layout-padding">
|
||||
<div class="layout-padding-auto layout-padding-view">
|
||||
<el-row shadow="hover" v-show="showSearch" class="ml10">
|
||||
<el-form :model="state.queryForm" ref="queryRef" :inline="true" @keyup.enter="getDataList">
|
||||
<el-form-item label="流程" prop="processName">
|
||||
<el-input placeholder="请输入流程名称" v-model="state.queryForm.processName" />
|
||||
</el-form-item>
|
||||
<el-form-item label="发起时间" prop="taskTime">
|
||||
<el-date-picker
|
||||
type="datetimerange"
|
||||
value-format="YYYY-MM-DD HH:mm:ss"
|
||||
v-model="state.queryForm.taskTime"
|
||||
is-range
|
||||
range-separator="To"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item>
|
||||
<el-button icon="search" type="primary" @click="getDataList">
|
||||
{{ $t('common.queryBtn') }}
|
||||
</el-button>
|
||||
<el-button icon="Refresh" @click="resetQuery">{{ $t('common.resetBtn') }}</el-button>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
</el-row>
|
||||
|
||||
<el-row>
|
||||
<div class="mb8" style="width: 100%">
|
||||
<right-toolbar
|
||||
v-model:showSearch="showSearch"
|
||||
class="ml10"
|
||||
style="float: right; margin-right: 20px"
|
||||
@queryTable="getDataList"
|
||||
></right-toolbar>
|
||||
</div>
|
||||
</el-row>
|
||||
|
||||
<el-table
|
||||
ref="dataTableRef"
|
||||
v-loading="loading"
|
||||
:data="state.dataList"
|
||||
highlight-current-row
|
||||
border
|
||||
:cell-style="tableStyle.cellStyle"
|
||||
:header-cell-style="tableStyle.headerCellStyle"
|
||||
>
|
||||
<el-table-column label="分组" prop="groupName" width="100" />
|
||||
<el-table-column label="流程" prop="processName" />
|
||||
<el-table-column label="发起人" prop="rootUserName" />
|
||||
<el-table-column label="发起时间" prop="startTime" />
|
||||
<el-table-column label="当前节点" prop="taskName" />
|
||||
<el-table-column label="任务时间" prop="taskCreateTime" />
|
||||
<el-table-column fixed="right" label="操作" width="200">
|
||||
<template #default="scope">
|
||||
<el-button type="primary" size="small" link icon="VideoPlay" @click="deal(scope.row)"> 开始处理 </el-button>
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
|
||||
<pagination @current-change="currentChangeHandle" @size-change="sizeChangeHandle" v-bind="state.pagination"></pagination>
|
||||
|
||||
<!-- 右侧抽屉-->
|
||||
<el-drawer v-model="rightDrawerVisible" v-if="rightDrawerVisible" direction="rtl" size="600px">
|
||||
<template #header>
|
||||
<h3>{{ currentData?.processName }}</h3>
|
||||
</template>
|
||||
<template #default>
|
||||
<el-card class="box-card">
|
||||
<FormCreate :rule="rule" v-model="formData" v-model:api="fApi" />
|
||||
</el-card>
|
||||
<flow-node-format
|
||||
:disableSelect="true"
|
||||
:task-id="currentData.taskId"
|
||||
:processInstanceId="currentData.processInstanceId"
|
||||
:flow-id="currentData.flowId"
|
||||
ref="flowNodeFormatRef"
|
||||
class="mt-4"
|
||||
/>
|
||||
</template>
|
||||
<template #footer>
|
||||
<div style="flex: auto">
|
||||
<el-button size="large" type="danger" icon="Close" @click="refuseTask">拒绝</el-button>
|
||||
<el-button size="large" type="primary" icon="Check" @click="submitTask">提交</el-button>
|
||||
<el-button size="large" type="info" icon="Share" @click="transferTask">转办</el-button>
|
||||
</div>
|
||||
</template>
|
||||
</el-drawer>
|
||||
|
||||
<!--同意提交处理-->
|
||||
<agree-handle @taskSubmitEvent="taskSubmitEvent" ref="agreeHandler"></agree-handle>
|
||||
|
||||
<!--拒绝审核处理-->
|
||||
<refuse-handle @taskSubmitEvent="taskSubmitEvent" ref="refuseHandler"></refuse-handle>
|
||||
|
||||
<!--转办处理-->
|
||||
<transfer-handle @taskSubmitEvent="taskSubmitEvent" ref="transferHandler"></transfer-handle>
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
<script setup lang="ts">
|
||||
import AgreeHandle from './handler/agree.vue';
|
||||
import RefuseHandle from './handler/refuse.vue';
|
||||
import TransferHandle from './handler/transfer.vue';
|
||||
import FlowNodeFormat from '/@/views/flow/form/tools/FlowNodeFormatData.vue';
|
||||
import { queryMineTask, queryTask } from '/@/api/flow/task';
|
||||
import { BasicTableProps, useTable } from '/@/hooks/table';
|
||||
import FcDesigner from 'form-create-designer';
|
||||
import { processFormItemsWithPerms } from '/@/views/flow/workflow/utils/formPermissions';
|
||||
import FormCreate from '/@/views/flow/workflow/components/FormCreate.vue';
|
||||
|
||||
const rightDrawerVisible = ref(false);
|
||||
const showSearch = ref(true);
|
||||
const loading = ref(false);
|
||||
const queryRef = ref();
|
||||
|
||||
const fApi = ref();
|
||||
const formData = ref({});
|
||||
|
||||
// Define the FormItem interface if not already defined
|
||||
interface FormItem {
|
||||
// Define the properties of FormItem based on your data structure
|
||||
}
|
||||
|
||||
const rule = ref<FormItem[]>([]);
|
||||
|
||||
const currentData = ref();
|
||||
const state: BasicTableProps = reactive<BasicTableProps>({
|
||||
pageList: queryMineTask,
|
||||
queryForm: {
|
||||
processName: '',
|
||||
taskTime: undefined,
|
||||
},
|
||||
});
|
||||
|
||||
const { tableStyle, getDataList, currentChangeHandle, sizeChangeHandle } = useTable(state);
|
||||
|
||||
/**
|
||||
* 点击开始处理
|
||||
* @param row
|
||||
*/
|
||||
const deal = (row: any) => {
|
||||
currentData.value = row;
|
||||
queryTask(row.taskId, false).then((res) => {
|
||||
const { formItems, formPerms, formData: responseFormData } = res.data;
|
||||
|
||||
// 解析表单项
|
||||
const parsedFormItems = FcDesigner.formCreate.parseJson(formItems);
|
||||
|
||||
// 递归处理所有表单项的权限
|
||||
const itemsWithPerms = processFormItemsWithPerms(parsedFormItems, formPerms);
|
||||
|
||||
rule.value = itemsWithPerms;
|
||||
formData.value = responseFormData;
|
||||
currentOpenFlowForm.value = formItems;
|
||||
rightDrawerVisible.value = true;
|
||||
});
|
||||
};
|
||||
const currentOpenFlowForm = ref();
|
||||
|
||||
const agreeHandler = ref();
|
||||
const refuseHandler = ref();
|
||||
const transferHandler = ref();
|
||||
|
||||
// 清空搜索条件
|
||||
const resetQuery = () => {
|
||||
queryRef.value.resetFields();
|
||||
getDataList();
|
||||
};
|
||||
|
||||
const taskSubmitEvent = () => {
|
||||
rightDrawerVisible.value = false;
|
||||
getDataList();
|
||||
};
|
||||
|
||||
/**
|
||||
* 提交任务
|
||||
*/
|
||||
const submitTask = () => {
|
||||
agreeHandler.value.handle(currentData.value, currentOpenFlowForm.value);
|
||||
};
|
||||
/**
|
||||
* 拒绝任务
|
||||
*/
|
||||
const refuseTask = () => {
|
||||
refuseHandler.value.handle(currentData.value, currentOpenFlowForm.value);
|
||||
};
|
||||
|
||||
/**
|
||||
* 转办任务
|
||||
*/
|
||||
const transferTask = () => {
|
||||
transferHandler.value.handle(currentData.value, currentOpenFlowForm.value);
|
||||
};
|
||||
|
||||
onMounted(() => {
|
||||
getDataList();
|
||||
});
|
||||
</script>
|
||||
161
src/views/flow/task/started.vue
Normal file
161
src/views/flow/task/started.vue
Normal file
@@ -0,0 +1,161 @@
|
||||
<template>
|
||||
<div class="layout-padding">
|
||||
<div class="layout-padding-auto layout-padding-view">
|
||||
<el-row shadow="hover" v-show="showSearch" class="ml10">
|
||||
<el-form :model="state.queryForm" ref="queryRef" :inline="true" @keyup.enter="getDataList">
|
||||
<el-form-item label="状态" prop="status">
|
||||
<el-select v-model="state.queryForm.status" placeholder="请选择状态">
|
||||
<el-option :key="1" label="进行中" :value="1" />
|
||||
<el-option :key="2" label="已结束" :value="2" />
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="发起时间" prop="taskTime">
|
||||
<el-date-picker
|
||||
type="datetimerange"
|
||||
value-format="YYYY-MM-DD HH:mm:ss"
|
||||
v-model="state.queryForm.taskTime"
|
||||
is-range
|
||||
range-separator="To"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item>
|
||||
<el-button icon="search" type="primary" @click="getDataList">
|
||||
{{ $t('common.queryBtn') }}
|
||||
</el-button>
|
||||
<el-button icon="Refresh" @click="resetQuery">{{ $t('common.resetBtn') }}</el-button>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
</el-row>
|
||||
|
||||
<el-row>
|
||||
<div class="mb8" style="width: 100%">
|
||||
<right-toolbar
|
||||
v-model:showSearch="showSearch"
|
||||
class="ml10"
|
||||
style="float: right; margin-right: 20px"
|
||||
@queryTable="getDataList"
|
||||
></right-toolbar>
|
||||
</div>
|
||||
</el-row>
|
||||
|
||||
<el-table
|
||||
ref="dataTableRef"
|
||||
v-loading="loading"
|
||||
:data="state.dataList"
|
||||
highlight-current-row
|
||||
border
|
||||
:cell-style="tableStyle.cellStyle"
|
||||
:header-cell-style="tableStyle.headerCellStyle"
|
||||
>
|
||||
<el-table-column label="分组" prop="groupName" width="100" />
|
||||
<el-table-column label="流程" prop="name" width="150" />
|
||||
<el-table-column label="发起时间" prop="createTime" width="200" />
|
||||
<el-table-column label="结束时间" prop="endTime" width="200" />
|
||||
<el-table-column label="状态" prop="taskCreateTime" width="100">
|
||||
<template #default="scope">
|
||||
<el-tag v-if="scope.row.status == 1" type="success">进行中</el-tag>
|
||||
<el-tag v-else>已结束</el-tag>
|
||||
</template>
|
||||
</el-table-column>
|
||||
|
||||
<el-table-column fixed="right" label="操作">
|
||||
<template #default="scope">
|
||||
<el-button type="primary" size="small" link icon="View" @click="deal(scope.row)"> 查看 </el-button>
|
||||
<el-button :disabled="scope.row.status != 1" type="primary" size="small" link icon="VideoPause" @click="stop(scope.row)">
|
||||
终止流程
|
||||
</el-button>
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
|
||||
<pagination @current-change="currentChangeHandle" @size-change="sizeChangeHandle" v-bind="state.pagination"></pagination>
|
||||
<!-- 右侧抽屉-->
|
||||
<el-drawer v-model="rightDrawerVisible" v-if="rightDrawerVisible" direction="rtl" size="600px">
|
||||
<template #header>
|
||||
<h3>{{ currentData?.name }}</h3>
|
||||
</template>
|
||||
<template #default>
|
||||
<el-card class="box-card">
|
||||
<FormCreate :rule="rule" v-model="formData" v-model:api="fApi" />
|
||||
</el-card>
|
||||
<flow-node-format
|
||||
:disableSelect="true"
|
||||
:processInstanceId="currentData.processInstanceId"
|
||||
:flow-id="currentData.flowId"
|
||||
ref="flowNodeFormatRef"
|
||||
></flow-node-format>
|
||||
</template>
|
||||
</el-drawer>
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
<script setup lang="ts">
|
||||
import FlowNodeFormat from '/@/views/flow/form/tools/FlowNodeFormatData.vue';
|
||||
import { queryMineStarted, stopProcessInstance } from '/@/api/flow/task';
|
||||
import { detail } from '/@/api/flow/processInstance';
|
||||
import { BasicTableProps, useTable } from '/@/hooks/table';
|
||||
|
||||
import FcDesigner from 'form-create-designer';
|
||||
import { processFormItemsWithPerms } from '/@/views/flow/workflow/utils/formPermissions';
|
||||
import FormCreate from '/@/views/flow/workflow/components/FormCreate.vue';
|
||||
|
||||
const rule = ref([]);
|
||||
const fApi = ref();
|
||||
const formData = ref({});
|
||||
|
||||
const rightDrawerVisible = ref(false);
|
||||
|
||||
const loading = ref(false);
|
||||
const showSearch = ref(true);
|
||||
const queryRef = ref();
|
||||
const state: BasicTableProps = reactive<BasicTableProps>({
|
||||
pageList: queryMineStarted,
|
||||
queryForm: {
|
||||
taskTime: undefined,
|
||||
status: 1,
|
||||
},
|
||||
});
|
||||
|
||||
const { tableStyle, getDataList, currentChangeHandle, sortChangeHandle, sizeChangeHandle } = useTable(state);
|
||||
function stop(row) {
|
||||
stopProcessInstance({
|
||||
processInstanceId: row.processInstanceId,
|
||||
}).then((res) => {
|
||||
getDataList();
|
||||
});
|
||||
}
|
||||
|
||||
const currentData = ref();
|
||||
/**
|
||||
* 点击开始处理
|
||||
* @param row
|
||||
*/
|
||||
const deal = (row) => {
|
||||
currentData.value = row;
|
||||
detail({
|
||||
processInstanceId: row.processInstanceId,
|
||||
}).then((res) => {
|
||||
const { formItems, formPerms, formData: responseFormData } = res.data;
|
||||
|
||||
// 解析表单项并处理权限
|
||||
const parsedFormItems = FcDesigner.formCreate.parseJson(formItems);
|
||||
const itemsWithPerms = processFormItemsWithPerms(parsedFormItems, formPerms);
|
||||
|
||||
rule.value = itemsWithPerms;
|
||||
formData.value = FcDesigner.formCreate.parseJson(responseFormData);
|
||||
currentOpenFlowForm.value = formItems;
|
||||
rightDrawerVisible.value = true;
|
||||
});
|
||||
};
|
||||
const currentOpenFlowForm = ref();
|
||||
|
||||
// 清空搜索条件
|
||||
const resetQuery = () => {
|
||||
queryRef.value.resetFields();
|
||||
getDataList();
|
||||
};
|
||||
|
||||
onMounted(() => {
|
||||
getDataList();
|
||||
});
|
||||
</script>
|
||||
Reference in New Issue
Block a user