first commit

This commit is contained in:
2025-12-26 23:19:09 +08:00
commit b29d128e41
788 changed files with 100922 additions and 0 deletions

143
src/views/flow/task/cc.vue Normal file
View 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>

View 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>

View 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>

View 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>

View 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>

View 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
}
}

View 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>

View 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>