|
After Width: | Height: | Size: 1.8 KiB |
|
After Width: | Height: | Size: 1.0 KiB |
|
After Width: | Height: | Size: 1.7 KiB |
|
After Width: | Height: | Size: 2.5 KiB |
|
After Width: | Height: | Size: 752 B |
|
After Width: | Height: | Size: 1.8 KiB |
|
After Width: | Height: | Size: 2.1 KiB |
|
After Width: | Height: | Size: 4.0 KiB |
@ -0,0 +1,194 @@ |
|||
<!-- |
|||
@ 作者: 秦东 |
|||
@ 时间: 2023-11-22 14:56:17 |
|||
@ 备注: 已办事宜 |
|||
--> |
|||
<script lang='ts' setup> |
|||
|
|||
import { taskFlowList } from '@/api/DesignForm/requestapi' |
|||
import { taskflowquery } from '@/api/DesignForm/type' |
|||
|
|||
import LookAndOperateLogInfo from '@/views/taskplatform/taskmanagement/lookAndOperateLogInfo.vue' |
|||
|
|||
const selectInfo = reactive<taskflowquery>({ |
|||
page: 1, |
|||
pagesize: 20, |
|||
class:3 |
|||
}) |
|||
const loading = ref(false) |
|||
const searckFormRef = ref(ElForm); |
|||
const totals = ref<number>(0) //总共多少条记录 |
|||
const taskFlowAry = ref<any>([]) //记录数组 |
|||
//获取我的请求 |
|||
const getToDoList = () => { |
|||
loading.value = true |
|||
taskFlowList(selectInfo) |
|||
.then((data:any)=>{ |
|||
console.log("获取我的请求",data) |
|||
totals.value = data.data.total |
|||
taskFlowAry.value = data.data.list |
|||
}) |
|||
.finally(()=>{ |
|||
loading.value = false |
|||
}) |
|||
} |
|||
//重置表单 |
|||
const resetQuery = () =>{ |
|||
searckFormRef.value.resetFields(); |
|||
initData(); |
|||
} |
|||
//初始化数据 |
|||
const initData = () =>{ |
|||
selectInfo.page = 1; |
|||
selectInfo.pagesize = 15; |
|||
selectInfo.title = "" |
|||
selectInfo.class = 3; |
|||
selectInfo.state = 0; |
|||
} |
|||
const myappbox = ref() |
|||
const drawerMyWith = ref<number>(0); |
|||
//加载数据 |
|||
onMounted(()=>{ |
|||
getToDoList(); |
|||
drawerMyWith.value = myappbox.value?.clientWidth |
|||
}) |
|||
const flowLogInfo = ref<any>() |
|||
const darwOpenOrClose = ref(false) |
|||
|
|||
/** |
|||
* 查看流程任务 |
|||
* val 记录内容 |
|||
* types 记录类型; 1、我的请求;2、待办事宜;3、已办事宜;4:草稿箱 |
|||
*/ |
|||
const lookFlowInfo = (val:any,types:number) => { |
|||
flowLogInfo.value = val |
|||
darwOpenOrClose.value = true |
|||
} |
|||
</script> |
|||
<template> |
|||
<div ref="myappbox" class="app_box"> |
|||
<div class="app-container"> |
|||
<div class="search"> |
|||
<el-form ref="searckFormRef" :model="selectInfo" :inline="true"> |
|||
<el-form-item label="任务标题" prop="name"> |
|||
<el-input |
|||
v-model="selectInfo.title" |
|||
placeholder="请输入任务标题" |
|||
clearable |
|||
@keyup.enter="searchQuery" |
|||
/> |
|||
</el-form-item> |
|||
<el-form-item> |
|||
<el-button type="primary" @click="getToDoList()"><i-ep-search />搜索</el-button> |
|||
<el-button @click="resetQuery()"><i-ep-refresh />重置</el-button> |
|||
</el-form-item> |
|||
</el-form> |
|||
</div> |
|||
<el-card shadow="never"> |
|||
<el-table |
|||
v-loading="loading" |
|||
element-loading-text="Loading..." |
|||
highlight-current-row |
|||
:data="taskFlowAry" |
|||
border |
|||
class="table_box" |
|||
> |
|||
<el-table-column fixed label="标题" prop="title" width="500" /> |
|||
<el-table-column label="创建人" prop="creater" > |
|||
<template #default="scope"> |
|||
{{ scope.row.creatorInfo.name }}(<el-text type="info">{{ scope.row.creatorInfo.number }}</el-text>) |
|||
</template> |
|||
</el-table-column> |
|||
<el-table-column label="发起日期" prop="startDate" align="center" width="300" /> |
|||
<el-table-column label="状态" prop="status" align="center" width="220" > |
|||
|
|||
<template #default="scope"> |
|||
<el-tag |
|||
v-if="scope.row.status==1" |
|||
class="mx-1" |
|||
effect="plain" |
|||
round |
|||
> |
|||
草稿 |
|||
</el-tag> |
|||
<el-tag |
|||
v-else-if="scope.row.status==2" |
|||
type="danger" |
|||
class="mx-1" |
|||
effect="plain" |
|||
round |
|||
> |
|||
驳回 |
|||
</el-tag> |
|||
<el-tag |
|||
v-else-if="scope.row.status==3" |
|||
type="success" |
|||
class="mx-1" |
|||
effect="plain" |
|||
round |
|||
> |
|||
审批中 |
|||
</el-tag> |
|||
<el-tag |
|||
v-else-if="scope.row.status==4" |
|||
type="info" |
|||
class="mx-1" |
|||
effect="plain" |
|||
round |
|||
> |
|||
归档 |
|||
</el-tag> |
|||
<el-tag |
|||
v-else |
|||
type="info" |
|||
class="mx-1" |
|||
effect="plain" |
|||
round |
|||
> |
|||
删除 |
|||
</el-tag> |
|||
</template> |
|||
|
|||
</el-table-column> |
|||
<el-table-column label="当前节点及操作人" prop="currentStep" width="400" > |
|||
<template #default="scope"> |
|||
<el-text v-if="scope.row.currentNodeName" type="success">{{ scope.row.currentNodeName }}:</el-text><el-text v-for="(item,index) in scope.row.currentNodeUser" :key="index" type="warning">{{ item.name }}({{ item.number }})</el-text> |
|||
</template> |
|||
</el-table-column> |
|||
<el-table-column fixed="right" align="center" label="操作" width="100" > |
|||
<template #default="scope"> |
|||
<el-button type="primary" class="fa fa-eye" @click="lookFlowInfo(scope.row,3)" /> |
|||
</template> |
|||
</el-table-column> |
|||
</el-table> |
|||
<pagination |
|||
v-model:total="totals" |
|||
v-model:page="selectInfo.page" |
|||
v-model:limit="selectInfo.pagesize" |
|||
@pagination="getToDoList" |
|||
/> |
|||
</el-card> |
|||
|
|||
|
|||
<LookAndOperateLogInfo v-if="darwOpenOrClose" v-model:isshow="darwOpenOrClose" :flow-log-info="flowLogInfo" :drawer-with="drawerMyWith" @getmytodolist="getMyToDoList" /> |
|||
|
|||
|
|||
|
|||
</div> |
|||
</div> |
|||
|
|||
</template> |
|||
<style lang='scss' scoped> |
|||
.app_box{ |
|||
width:100%; |
|||
overflow: hidden; |
|||
overflow-y: auto; |
|||
} |
|||
.box-card { |
|||
width: 100%; |
|||
} |
|||
.table_box{ |
|||
width: 100%; |
|||
height: calc(100vh - 308px); |
|||
} |
|||
</style> |
|||
@ -0,0 +1,173 @@ |
|||
<!-- |
|||
@ 作者: 秦东 |
|||
@ 时间: 2023-11-24 08:10:23 |
|||
@ 备注: 草稿箱 |
|||
--> |
|||
<script lang='ts' setup> |
|||
import { Delete, Edit, Search, Share, Upload,View } from '@element-plus/icons-vue' |
|||
import { taskFlowList } from '@/api/DesignForm/requestapi' |
|||
import { taskflowquery } from '@/api/DesignForm/type' |
|||
|
|||
const selectInfoDr = reactive<taskflowquery>({ |
|||
page: 1, |
|||
pagesize: 20, |
|||
class: 1, |
|||
state:1 |
|||
}) |
|||
const loadingDr = ref(false) |
|||
const searckFormRefdr = ref(ElForm); |
|||
const totalsdr = ref<number>(0) //总共多少条记录 |
|||
const taskFlowAryDr = ref<any>([]) //记录数组 |
|||
//获取我的请求 |
|||
const getToDoListDr = () => { |
|||
loadingDr.value = true |
|||
taskFlowList(selectInfoDr) |
|||
.then((data:any)=>{ |
|||
console.log("获取我的请求",data) |
|||
totalsdr.value = data.data.total |
|||
taskFlowAryDr.value = data.data.list |
|||
}) |
|||
.finally(()=>{ |
|||
loadingDr.value = false |
|||
}) |
|||
} |
|||
//重置表单 |
|||
const resetQueryDr = () =>{ |
|||
searckFormRefdr.value.resetFields(); |
|||
initDataDr(); |
|||
} |
|||
//初始化数据 |
|||
const initDataDr = () =>{ |
|||
selectInfoDr.page = 1; |
|||
selectInfoDr.pagesize = 15; |
|||
selectInfoDr.title = "" |
|||
selectInfoDr.class = 1; |
|||
selectInfoDr.state = 1; |
|||
} |
|||
onMounted(()=>{ |
|||
getToDoListDr(); |
|||
}) |
|||
</script> |
|||
<template> |
|||
<div class="app_box"> |
|||
<div class="app-container"> |
|||
<div class="search"> |
|||
<el-form ref="searckFormRefdr" :model="selectInfoDr" :inline="true"> |
|||
<el-form-item label="任务标题" prop="name"> |
|||
<el-input |
|||
v-model="selectInfoDr.title" |
|||
placeholder="请输入任务标题" |
|||
clearable |
|||
@keyup.enter="searchQuery" |
|||
/> |
|||
</el-form-item> |
|||
<el-form-item> |
|||
<el-button type="primary" @click="getToDoListDr()"><i-ep-search />搜索</el-button> |
|||
<el-button @click="resetQueryDr()"><i-ep-refresh />重置</el-button> |
|||
</el-form-item> |
|||
</el-form> |
|||
</div> |
|||
<el-card shadow="never"> |
|||
<el-table |
|||
v-loadingDr="loadingDr" |
|||
element-loadingDr-text="Loading..." |
|||
highlight-current-row |
|||
:data="taskFlowAryDr" |
|||
border |
|||
class="table_box" |
|||
> |
|||
<el-table-column fixed label="标题" prop="title" width="500" /> |
|||
<el-table-column label="创建人" prop="creater" > |
|||
<template #default="scope"> |
|||
{{ scope.row.creatorInfo.name }}(<el-text type="info">{{ scope.row.creatorInfo.number }}</el-text>) |
|||
</template> |
|||
</el-table-column> |
|||
<el-table-column label="发起日期" prop="startDate" align="center" width="300" /> |
|||
<el-table-column label="状态" prop="status" align="center" width="220" > |
|||
|
|||
<template #default="scope"> |
|||
<el-tag |
|||
v-if="scope.row.status==1" |
|||
class="mx-1" |
|||
effect="plain" |
|||
round |
|||
> |
|||
草稿 |
|||
</el-tag> |
|||
<el-tag |
|||
v-else-if="scope.row.status==2" |
|||
type="danger" |
|||
class="mx-1" |
|||
effect="plain" |
|||
round |
|||
> |
|||
驳回 |
|||
</el-tag> |
|||
<el-tag |
|||
v-else-if="scope.row.status==3" |
|||
type="success" |
|||
class="mx-1" |
|||
effect="plain" |
|||
round |
|||
> |
|||
审批中 |
|||
</el-tag> |
|||
<el-tag |
|||
v-else-if="scope.row.status==4" |
|||
type="info" |
|||
class="mx-1" |
|||
effect="plain" |
|||
round |
|||
> |
|||
归档 |
|||
</el-tag> |
|||
<el-tag |
|||
v-else |
|||
type="info" |
|||
class="mx-1" |
|||
effect="plain" |
|||
round |
|||
> |
|||
删除 |
|||
</el-tag> |
|||
</template> |
|||
|
|||
</el-table-column> |
|||
<el-table-column fixed="right" align="center" label="操作" width="150" > |
|||
<template #default="scope"> |
|||
<el-button type="warning" :icon="Edit" @click="editFlow(scope.row)" /> |
|||
<el-button type="danger" :icon="Delete" @click="editFlow(scope.row.flowkeys)" /> |
|||
</template> |
|||
</el-table-column> |
|||
</el-table> |
|||
<pagination |
|||
v-model:total="totalsdr" |
|||
v-model:page="selectInfoDr.page" |
|||
v-model:limit="selectInfoDr.pagesize" |
|||
@pagination="getToDoListDr" |
|||
/> |
|||
</el-card> |
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
</div> |
|||
</div> |
|||
|
|||
</template> |
|||
<style lang='scss' scoped> |
|||
.app_box{ |
|||
width:100%; |
|||
overflow: hidden; |
|||
overflow-y: auto; |
|||
} |
|||
.box-card { |
|||
width: 100%; |
|||
} |
|||
.table_box{ |
|||
width: 100%; |
|||
height: calc(100vh - 308px); |
|||
} |
|||
</style> |
|||
@ -0,0 +1,188 @@ |
|||
<!-- |
|||
@ 作者: 秦东 |
|||
@ 时间: 2023-11-24 08:50:26 |
|||
@ 备注: 查看或操作工作流记录 |
|||
--> |
|||
<script lang='ts' setup> |
|||
import { |
|||
json2string, |
|||
objToStringify, |
|||
string2json, |
|||
stringToObj |
|||
} from '@/utils/DesignForm/form' |
|||
|
|||
import RunFlowStep from '@/views/taskplatform/taskmanagement/runFlowStep.vue' |
|||
|
|||
const props = defineProps({ |
|||
isshow:{ |
|||
type:Boolean, |
|||
default:true |
|||
}, |
|||
drawerWith:{ |
|||
type:Number, |
|||
default:0 |
|||
}, |
|||
flowLogInfo:{ |
|||
type:Object, |
|||
default(){ |
|||
return {} |
|||
} |
|||
} |
|||
}) |
|||
const emits = defineEmits(["update:isshow","getmytodolist"]); |
|||
const isOpen = computed({ |
|||
get: () => props.isshow, |
|||
set: (val) => { |
|||
emits("update:isshow", val); |
|||
}, |
|||
}); |
|||
const loadingData = ref(false) //加载表单数据 |
|||
const flowLoading = ref(false) //加载流程数据 |
|||
const versiontitle = ref<any>("1") |
|||
const flowMap = ref<any>() |
|||
const nextStep = ref(0) |
|||
const nodeKey = ref<string>(''); |
|||
const currentProgress = ref<number>(1); |
|||
|
|||
//表单相关内容 |
|||
const formState = reactive({ |
|||
formData: { |
|||
list: [], |
|||
form: {}, |
|||
config: {} |
|||
}, |
|||
dict: {}, |
|||
formId: 25, |
|||
id: 1, |
|||
loading: true |
|||
}) |
|||
|
|||
const formType = computed(() => { |
|||
// 带有参数id为编辑状态 |
|||
if (true) { |
|||
return 2 |
|||
} else { |
|||
return 1 |
|||
} |
|||
}) |
|||
|
|||
|
|||
|
|||
|
|||
|
|||
const formEl = ref() |
|||
|
|||
|
|||
|
|||
|
|||
onMounted(()=>{ |
|||
versiontitle.value = props.flowLogInfo.title |
|||
console.log("props.flowLogInfo---4-------->",props.flowLogInfo) |
|||
flowMap.value = JSON.parse(props.flowLogInfo.flowcont) |
|||
nextStep.value = props.flowLogInfo.nextStep |
|||
nodeKey.value = props.flowLogInfo.nodeKey; |
|||
currentProgress.value = props.flowLogInfo.currentStep |
|||
console.log("props.flowLogInfo--5-------->",props.flowLogInfo.mastesform) |
|||
formState.formData = stringToObj(props.flowLogInfo.mastesform) |
|||
nextTick(() => { |
|||
console.log("res----------->", formEl.value) |
|||
formEl.value.getData({ id: props.flowLogInfo.flowkeys}) |
|||
}) |
|||
|
|||
}) |
|||
</script> |
|||
<template> |
|||
<el-drawer v-model="isOpen" v-loading="loadingData" element-loading-my-text="Loading..." :title="versiontitle" :close-on-click-modal="false" :close-on-press-escape="false" :destroy-on-close="true" :size="props.drawerWith" class="drawerClass" > |
|||
<table border="0" class="tableFlowBox"> |
|||
<tr> |
|||
<td valign="top"> |
|||
<div class="drawerFormBox boxLeft"> |
|||
<ak-form |
|||
ref="formEl" |
|||
v-loading="formLoading" element-loading-text="Loading..." |
|||
:form-data="formState.formData" |
|||
:type="formType" |
|||
:dict="formState.dict" |
|||
request-url="getFormContent" |
|||
add-url="saveFormContent" |
|||
edit-url="editFormContent" |
|||
:before-submit="beforeSubmit" |
|||
:after-submit="afterSubmit" |
|||
:close-app-submit="closeAppSubmit" |
|||
:change-key-val="changeKeyVal" |
|||
/> |
|||
|
|||
</div> |
|||
</td> |
|||
<td valign="top" width="350"> |
|||
<RunFlowStep :flow-key="props.flowLogInfo.flowkeys" :current-progress="currentProgress" /> |
|||
</td> |
|||
</tr> |
|||
</table> |
|||
</el-drawer> |
|||
</template> |
|||
<style lang='scss' scoped> |
|||
.tableFlowBox{ |
|||
width: 100%; |
|||
height: 100%; |
|||
// background-color: #000000; |
|||
.drawerFormBox{ |
|||
width: 100%; |
|||
height: 100%; |
|||
// background-color: #ff0000; |
|||
} |
|||
} |
|||
.boxLeft{ |
|||
padding: 0 10px 0 15px; |
|||
overflow: hidden; |
|||
overflow-y: auto; |
|||
} |
|||
.flowBox{ |
|||
padding: 0 5px 0 10px; |
|||
} |
|||
.boxRight{ |
|||
overflow: hidden; |
|||
overflow-y: auto; |
|||
border-left: 1px solid #EEEEEE; |
|||
} |
|||
.approvalBoard{ |
|||
padding: 5px 10px; |
|||
background-color: #FFFFFF; |
|||
border-top: 1px solid #EEEEEE; |
|||
.juzhong{ |
|||
padding: 10px 0; |
|||
text-align: center; |
|||
} |
|||
.appBoardTitle{ |
|||
padding: 5px 0 10px 0; |
|||
display: block; |
|||
} |
|||
} |
|||
</style> |
|||
<style lang='scss'> |
|||
|
|||
.drawerClass ::v-deep.el-drawer__header { |
|||
font-size: 22px; |
|||
text-align: center; |
|||
margin-bottom: 0px; |
|||
padding: 0; |
|||
.el-drawer__close-btn{ |
|||
background-color: rgb(255, 77, 79); |
|||
color: white; |
|||
} |
|||
} |
|||
::v-deep .el-drawer__body { |
|||
padding: 0px; |
|||
} |
|||
.details { |
|||
width: 80%; |
|||
margin-right: 0px; |
|||
margin-left: 20%; |
|||
box-shadow: 0 2px 12px 0 rgb(0 0 0 / 10%); |
|||
} |
|||
.drawerBody{ |
|||
padding: 20px; |
|||
|
|||
} |
|||
|
|||
</style> |
|||
@ -0,0 +1,194 @@ |
|||
<!-- |
|||
@ 作者: 秦东 |
|||
@ 时间: 2023-11-22 14:56:54 |
|||
@ 备注: 我的请求 |
|||
--> |
|||
<script lang='ts' setup> |
|||
import { Delete, Edit, Search, Share, Upload,View } from '@element-plus/icons-vue' |
|||
import { taskFlowList } from '@/api/DesignForm/requestapi' |
|||
import { taskflowquery } from '@/api/DesignForm/type' |
|||
|
|||
import LookAndOperateLogInfo from '@/views/taskplatform/taskmanagement/lookAndOperateLogInfo.vue' |
|||
|
|||
const selectMyInfo = reactive<taskflowquery>({ |
|||
page: 1, |
|||
pagesize: 20, |
|||
class:1 |
|||
}) |
|||
const loadingMy = ref(false) |
|||
const searckFormReMyf = ref(ElForm); |
|||
const totalsMy = ref<number>(0) //总共多少条记录 |
|||
const taskFlowMyAry = ref<any>([]) //记录数组 |
|||
//获取我的请求 |
|||
const getMyToDoList = () => { |
|||
loadingMy.value = true |
|||
taskFlowList(selectMyInfo) |
|||
.then((data:any)=>{ |
|||
console.log("获取我的请求",data) |
|||
totalsMy.value = data.data.total |
|||
taskFlowMyAry.value = data.data.list |
|||
}) |
|||
.finally(()=>{ |
|||
loadingMy.value = false |
|||
}) |
|||
} |
|||
//重置表单 |
|||
const resetQueryMy = () =>{ |
|||
searckFormReMyf.value.resetFields(); |
|||
initMyData(); |
|||
} |
|||
//初始化数据 |
|||
const initMyData = () =>{ |
|||
selectMyInfo.page = 1; |
|||
selectMyInfo.pagesize = 15; |
|||
selectMyInfo.title = "" |
|||
selectMyInfo.class = 1; |
|||
selectMyInfo.state = 0; |
|||
} |
|||
const myappbox = ref() |
|||
const drawerMyWith = ref<number>(0); //页面宽度 |
|||
onMounted(()=>{ |
|||
getMyToDoList(); |
|||
drawerMyWith.value = myappbox.value?.clientWidth |
|||
}) |
|||
const flowLogInfo = ref<any>() |
|||
const darwOpenOrClose = ref(false) |
|||
|
|||
/** |
|||
* 查看流程任务 |
|||
* val 记录内容 |
|||
* types 记录类型; 1、我的请求;2、待办事宜;3、已办事宜;4:草稿箱 |
|||
*/ |
|||
const lookFlowInfo = (val:any,types:number) => { |
|||
flowLogInfo.value = val |
|||
darwOpenOrClose.value = true |
|||
} |
|||
</script> |
|||
<template> |
|||
<div ref="myappbox" class="app_box"> |
|||
|
|||
<div class="app-container"> |
|||
<div class="search"> |
|||
<el-form ref="searckFormReMyf" :model="selectMyInfo" :inline="true"> |
|||
<el-form-item label="任务标题" prop="name"> |
|||
<el-input |
|||
v-model="selectMyInfo.title" |
|||
placeholder="请输入任务标题" |
|||
clearable |
|||
@keyup.enter="searchQuery" |
|||
/> |
|||
</el-form-item> |
|||
<el-form-item> |
|||
<el-button type="primary" @click="getMyToDoList()"><i-ep-search />搜索</el-button> |
|||
<el-button @click="resetQueryMy()"><i-ep-refresh />重置</el-button> |
|||
</el-form-item> |
|||
</el-form> |
|||
</div> |
|||
<el-card shadow="never"> |
|||
<el-table |
|||
v-loadingMy="loadingMy" |
|||
element-loading-my-text="Loading..." |
|||
highlight-current-row |
|||
:data="taskFlowMyAry" |
|||
border |
|||
class="table_box" |
|||
> |
|||
<el-table-column fixed label="标题" prop="title" width="500" /> |
|||
<el-table-column label="创建人" prop="creater" width="200" > |
|||
<template #default="scope"> |
|||
{{ scope.row.creatorInfo.name }}(<el-text type="info">{{ scope.row.creatorInfo.number }}</el-text>) |
|||
</template> |
|||
</el-table-column> |
|||
<el-table-column label="发起日期" prop="startDate" align="center" width="300" /> |
|||
<el-table-column label="状态" prop="status" align="center" width="220" > |
|||
|
|||
<template #default="scope"> |
|||
<el-tag |
|||
v-if="scope.row.status==1" |
|||
class="mx-1" |
|||
effect="plain" |
|||
round |
|||
> |
|||
草稿 |
|||
</el-tag> |
|||
<el-tag |
|||
v-else-if="scope.row.status==2" |
|||
type="danger" |
|||
class="mx-1" |
|||
effect="plain" |
|||
round |
|||
> |
|||
驳回 |
|||
</el-tag> |
|||
<el-tag |
|||
v-else-if="scope.row.status==3" |
|||
type="success" |
|||
class="mx-1" |
|||
effect="plain" |
|||
round |
|||
> |
|||
审批中 |
|||
</el-tag> |
|||
<el-tag |
|||
v-else-if="scope.row.status==4" |
|||
type="info" |
|||
class="mx-1" |
|||
effect="plain" |
|||
round |
|||
> |
|||
归档 |
|||
</el-tag> |
|||
<el-tag |
|||
v-else |
|||
type="info" |
|||
class="mx-1" |
|||
effect="plain" |
|||
round |
|||
> |
|||
删除 |
|||
</el-tag> |
|||
</template> |
|||
|
|||
</el-table-column> |
|||
<el-table-column label="当前节点及操作人" prop="currentStep" width="400" > |
|||
<template #default="scope"> |
|||
<el-text v-if="scope.row.currentNodeName" type="success">{{ scope.row.currentNodeName }}:</el-text><el-text v-for="(item,index) in scope.row.currentNodeUser" :key="index" type="warning">{{ item.name }}({{ item.number }})</el-text> |
|||
</template> |
|||
</el-table-column> |
|||
<el-table-column fixed="right" align="center" label="操作" width="100" > |
|||
<template #default="scope"> |
|||
<el-button type="primary" class="fa fa-eye" @click="lookFlowInfo(scope.row,1)" /> |
|||
</template> |
|||
</el-table-column> |
|||
</el-table> |
|||
<pagination |
|||
v-model:total="totalsMy" |
|||
v-model:page="selectMyInfo.page" |
|||
v-model:limit="selectMyInfo.pagesize" |
|||
@pagination="getMyToDoList" |
|||
/> |
|||
</el-card> |
|||
|
|||
<LookAndOperateLogInfo v-if="darwOpenOrClose" v-model:isshow="darwOpenOrClose" :flow-log-info="flowLogInfo" :drawer-with="drawerMyWith" @getmytodolist="getMyToDoList" /> |
|||
|
|||
|
|||
|
|||
|
|||
</div> |
|||
</div> |
|||
|
|||
</template> |
|||
<style lang='scss' scoped> |
|||
.app_box{ |
|||
width:100%; |
|||
overflow: hidden; |
|||
overflow-y: auto; |
|||
} |
|||
.box-card { |
|||
width: 100%; |
|||
} |
|||
.table_box{ |
|||
width: 100%; |
|||
height: calc(100vh - 308px); |
|||
} |
|||
</style> |
|||
@ -0,0 +1,98 @@ |
|||
<!-- |
|||
@ 作者: 秦东 |
|||
@ 时间: 2023-11-22 14:55:07 |
|||
@ 备注: 新建流程 |
|||
--> |
|||
<script lang='ts' setup> |
|||
import { gainTaskListQuery,taskListCont } from '@/api/taskapi/types' |
|||
import { gainTaskList } from '@/api/taskapi/management' |
|||
|
|||
import TaskCustomerForm from '@/views/taskplatform/taskmanagement/taskcustomerformnew.vue' |
|||
|
|||
const taskLoding = ref(false); |
|||
const gainTaskListInfo = reactive<gainTaskListQuery>({ |
|||
page:1, |
|||
pagesize:16, |
|||
status:1, |
|||
type:2 |
|||
}); |
|||
const taskTotal = ref<number>(0) |
|||
const taskList = ref<taskListCont[]>(); |
|||
const openTaskDrawer = ref(false) |
|||
//获取记录 |
|||
const gainTaskContAry = () => { |
|||
taskLoding.value = true |
|||
gainTaskList(gainTaskListInfo) |
|||
.then(({data})=>{ |
|||
// console.log(data) |
|||
if(data != null){ |
|||
taskList.value = data.list; |
|||
taskTotal.value = data.total; |
|||
} |
|||
}) |
|||
.finally(()=>{ |
|||
taskLoding.value = false |
|||
}) |
|||
} |
|||
const contbody = ref<any>(null) |
|||
const versionId = ref<string>() |
|||
const versionTitle = ref<string>() |
|||
const drawerWith = ref<number>(0); |
|||
//使用版本 |
|||
const startUsing = (id:string,title:string) => { |
|||
drawerWith.value = contbody.value?.clientWidth |
|||
versionId.value = id |
|||
versionTitle.value = title |
|||
openTaskDrawer.value = true |
|||
} |
|||
onMounted(()=>{ |
|||
gainTaskContAry(); |
|||
}) |
|||
</script> |
|||
<template> |
|||
<div ref="contbody" class="app_body"> |
|||
<el-row :gutter="30"> |
|||
<el-col v-for="item in taskList" :key="item.id" :xs="24" :sm="12" :md="12" :lg="8" :xl="6"> |
|||
<el-card style="margin-top: 15px; height:200px;"> |
|||
<div class="jianju" style="width:100%;"><el-text class="mx-1">{{ item.name }}</el-text></div> |
|||
<div class="jianju" style="width:100%;"><el-text class="mx-1">设计者:{{ item.createrName }}({{ item.createrNumber }})</el-text></div> |
|||
<div class="jianju" style="width:100%;"><el-text class="mx-1">发布时间:{{ item.createrTame }}</el-text></div> |
|||
<div class="taskButton"><el-button type="primary" @click.stop="startUsing(item.id,item.name)">创建流程</el-button></div> |
|||
</el-card> |
|||
</el-col> |
|||
</el-row> |
|||
<div class="pageCont"> |
|||
<pagination |
|||
v-if="taskTotal > 0" |
|||
v-model:total="taskTotal" |
|||
v-model:page="gainTaskListInfo.page" |
|||
v-model:limit="gainTaskListInfo.pagesize" |
|||
align="center" |
|||
@pagination="gainTaskContAry" |
|||
/> |
|||
</div> |
|||
<TaskCustomerForm v-model:isopen="openTaskDrawer" :versionid="versionId" :versiontitle="versionTitle" :drawerwith="drawerWith" @searchquery="gainTaskContAry" /> |
|||
</div> |
|||
</template> |
|||
<style lang='scss' scoped> |
|||
.app_body{ |
|||
width: 100%; |
|||
height: calc(100vh - 85px); |
|||
// background-color:#000000; |
|||
overflow: hidden; |
|||
overflow-y: auto; |
|||
padding: 0 15px 0 15px; |
|||
.taskButton{ |
|||
width: 100%; |
|||
text-align: center; |
|||
} |
|||
.jianju{ |
|||
margin-bottom: 15px; |
|||
} |
|||
.pageCont{ |
|||
background-color: #FFFFFF; |
|||
margin-top: 15px; |
|||
text-align: center; |
|||
} |
|||
} |
|||
</style> |
|||
@ -0,0 +1,213 @@ |
|||
<!-- |
|||
@ 作者: 秦东 |
|||
@ 时间: 2023-11-24 13:18:02 |
|||
@ 备注: 流程执行 |
|||
--> |
|||
<script lang='ts' setup> |
|||
import SvgIcon from "@/components/SvgIcon/index.vue"; |
|||
import OrgUserPage from "@/views/public/orguser/orguser.vue" |
|||
import OrgAllUserPage from "@/views/public/orguser/orgalluser.vue" |
|||
|
|||
// import { nodeFlow,conditionInfo,nodelPeoples } from '@/api/taskapi/types' |
|||
import { gainRunTaskFlow } from '@/api/DesignForm/requestapi' |
|||
//引入图标 |
|||
import squareUrlOne from "@/assets/images/1.png" |
|||
import squareUrlTwo from "@/assets/images/2.png" |
|||
|
|||
const state = reactive({ |
|||
circleUrl:squareUrlTwo, |
|||
squareUrl: squareUrlOne, |
|||
sizeList: ['small', '', 'large'] as const, |
|||
}) |
|||
const { circleUrl, squareUrl, sizeList } = toRefs(state) |
|||
|
|||
const props = defineProps({ |
|||
flowKey:{ |
|||
type:String, |
|||
default:"" |
|||
}, |
|||
currentProgress:{ |
|||
type:Number, |
|||
default:0 |
|||
} |
|||
}) |
|||
const flowLoading = ref(false) |
|||
const openOrClose = ref(false) //开启指定人员选择 |
|||
const openclosebox = ref(false) //开启全部人员选择 |
|||
const presetPersonnel = ref<any>([]); //预设选择人 |
|||
const selectedPeople = ref<any>([]); //已选择人 |
|||
const flowOpinion = ref(false) //是否可以写评论 |
|||
|
|||
const flowMaps = ref<any[]>(); |
|||
|
|||
//获取任务流程 |
|||
const gainRunFlowTask = () =>{ |
|||
flowLoading.value = true |
|||
let sendInfo = { |
|||
id:props.flowKey |
|||
} |
|||
gainRunTaskFlow(sendInfo) |
|||
.then((data:any) =>{ |
|||
// console.log("获取流程----->",data) |
|||
flowMaps.value = data.data.flowList |
|||
flowOpinion.value = data.data.operational |
|||
}) |
|||
.finally(()=>{ |
|||
flowLoading.value = false |
|||
}) |
|||
} |
|||
//组件渲染之前 |
|||
onBeforeMount(()=>{ |
|||
gainRunFlowTask(); |
|||
}) |
|||
//组件渲染完毕 |
|||
onMounted(()=>{ |
|||
|
|||
}) |
|||
//判断是否可以添加人员 |
|||
const judgeAddUser = (val:any):boolean =>{ |
|||
console.log("获取流程----1111->",val.judgelist) |
|||
if(val.judgelist){ |
|||
return true |
|||
} |
|||
return false |
|||
} |
|||
let zhiXingStep = 1; |
|||
//添加操作人 |
|||
const addPeople = (val:any) =>{ |
|||
zhiXingStep = val.step |
|||
presetPersonnel.value = val.pendpers |
|||
selectedPeople.value = val.operator |
|||
if(val.runscope == 1){ |
|||
openclosebox.value = true |
|||
}else{ |
|||
openOrClose.value = true |
|||
} |
|||
} |
|||
//更新节点操作人 |
|||
const updateNode = (val:any) =>{ |
|||
flowMaps.value.forEach((item:any) =>{ |
|||
if(item.step == zhiXingStep){ |
|||
item.operator = val |
|||
} |
|||
}) |
|||
} |
|||
const sendFlowInfo = ref<string>() //审批意见 |
|||
//提交审批 |
|||
const yesOrNo = (val:string,agreeOrRefuse:number) =>{ |
|||
console.log("提交审批----1111->",val,agreeOrRefuse,sendFlowInfo.value) |
|||
} |
|||
</script> |
|||
<template> |
|||
<div class="drawerFormBox boxRight"> |
|||
<div class="flowBox"> |
|||
<el-affix :offset="20" style="width:100%"> |
|||
<el-text size="large">审批流程</el-text> |
|||
</el-affix> |
|||
|
|||
<el-steps v-loading="flowLoading" element-loading-text="Loading..." direction="vertical" :active="props.currentProgress"> |
|||
<el-step v-for="item in flowMaps" :key="item.step"> |
|||
<template #title> |
|||
{{ item.nodeName }} |
|||
</template> |
|||
<template #description> |
|||
<table> |
|||
<tr v-for="items in item.operator" :key="items.id"> |
|||
<td valign="top" align="center" width="50"> |
|||
<el-avatar v-if="items.iconbase64==''&&items.icon!=''" shape="square" fit="cover" :src="items.icon" /> |
|||
<el-avatar v-else-if="items.iconbase64!=''" shape="square" fit="cover" :src="items.iconbase64" /> |
|||
<el-avatar v-else shape="square" fit="cover" :src="squareUrl" /> |
|||
</td> |
|||
<td valign="top" align="left"> |
|||
<el-row> |
|||
<el-col :span="24"> |
|||
<el-text>{{ items.departmentname }}</el-text> |
|||
<el-text><span v-if="items.departmentname"> - </span>{{ items.postname }}</el-text> |
|||
<el-text><span v-if="items.departmentname||items.postname"> - </span>{{ items.name }}</el-text> |
|||
</el-col> |
|||
<el-col :span="24"> |
|||
<ul> |
|||
<li v-for="(logItem,logIndex) in items.log" :key="logIndex" class="logLi"> |
|||
<el-text v-if="logItem.state==2" type="success"> |
|||
<span v-if="logItem.cause">logItem.cause</span><span v-else>已同意</span> |
|||
</el-text> |
|||
<el-text v-else-if="logItem.state==3" type="danger"> |
|||
<span v-if="logItem.cause">logItem.cause</span><span v-else>已驳回</span> |
|||
</el-text> |
|||
<el-text v-else> |
|||
<span v-if="logItem.cause">logItem.cause</span><span v-else>未操作</span> |
|||
</el-text> · {{ logItem.time }} |
|||
</li> |
|||
</ul> |
|||
</el-col> |
|||
</el-row> |
|||
</td> |
|||
</tr> |
|||
<tr> |
|||
<td> |
|||
<div v-if="item.judgelist" class="addUser" @click="addPeople(item)"> |
|||
<svg-icon icon-class="addxuxian" size="50" /> |
|||
</div> |
|||
</td> |
|||
<td></td> |
|||
</tr> |
|||
</table> |
|||
</template> |
|||
</el-step> |
|||
</el-steps> |
|||
</div> |
|||
<el-affix v-if="flowOpinion" position="bottom" :offset="0"> |
|||
<div class="approvalBoard"> |
|||
<el-text size="large" class="appBoardTitle">审批意见</el-text> |
|||
<el-row :gutter="20"> |
|||
<el-col :span="24"> |
|||
<el-input |
|||
v-model="sendFlowInfo" |
|||
:autosize="{ minRows: 2, maxRows: 6 }" |
|||
type="textarea" |
|||
placeholder="请输入审批意见" |
|||
/> |
|||
</el-col> |
|||
</el-row> |
|||
<el-row :gutter="20"> |
|||
<el-col :span="4"></el-col> |
|||
<el-col :span="8" class="juzhong"><el-button type="primary" style="width:100%" @click="yesOrNo(props.flowKey,1)">同意</el-button></el-col> |
|||
<el-col :span="8" class="juzhong"><el-button type="danger" style="width:100%" @click="yesOrNo(props.flowKey,2)">驳回</el-button></el-col> |
|||
<el-col :span="4"></el-col> |
|||
</el-row> |
|||
</div> |
|||
</el-affix> |
|||
|
|||
|
|||
<OrgUserPage v-if="openOrClose" v-model:openclose="openOrClose" :preset-personnel="presetPersonnel" :selected-people="selectedPeople" @update-node="updateNode" /> |
|||
<OrgAllUserPage v-if="openclosebox" v-model:openclosebox="openclosebox" :selected-people="selectedPeople" @update-node="updateNode" /> |
|||
</div> |
|||
</template> |
|||
<style lang='scss' scoped> |
|||
.drawerFormBox{ |
|||
width: 100%; |
|||
height: 100%; |
|||
} |
|||
.boxRight{ |
|||
overflow: hidden; |
|||
overflow-y: auto; |
|||
border-left: 1px solid #EEEEEE; |
|||
} |
|||
.flowBox{ |
|||
width: 100%; |
|||
padding: 0 5px 0 10px; |
|||
} |
|||
.approvalBoard{ |
|||
padding: 5px 10px; |
|||
background-color: #FFFFFF; |
|||
border-top: 1px solid #EEEEEE; |
|||
.juzhong{ |
|||
padding: 10px 0; |
|||
text-align: center; |
|||
} |
|||
.appBoardTitle{ |
|||
padding: 5px 0 10px 0; |
|||
display: block; |
|||
} |
|||
} |
|||
</style> |
|||
@ -0,0 +1,194 @@ |
|||
<!-- |
|||
@ 作者: 秦东 |
|||
@ 时间: 2023-11-22 14:55:46 |
|||
@ 备注: 待办事宜 |
|||
--> |
|||
<script lang='ts' setup> |
|||
|
|||
import { taskFlowList } from '@/api/DesignForm/requestapi' |
|||
import { taskflowquery } from '@/api/DesignForm/type' |
|||
|
|||
import LookAndOperateLogInfo from '@/views/taskplatform/taskmanagement/lookAndOperateLogInfo.vue' |
|||
|
|||
const selectInfoTd = reactive<taskflowquery>({ |
|||
page: 1, |
|||
pagesize: 20, |
|||
class: 2 |
|||
}) |
|||
const loadingTd = ref(false) |
|||
const searckFormRefTd = ref(ElForm); |
|||
const totalstd = ref<number>(0) //总共多少条记录 |
|||
const taskFlowAryTd = ref<any>([]) //记录数组 |
|||
//获取我的请求 |
|||
const getToDoListTd = () => { |
|||
loadingTd.value = true |
|||
taskFlowList(selectInfoTd) |
|||
.then((data:any)=>{ |
|||
console.log("获取我的请求",data) |
|||
totalstd.value = data.data.total |
|||
taskFlowAryTd.value = data.data.list |
|||
}) |
|||
.finally(()=>{ |
|||
loadingTd.value = false |
|||
}) |
|||
} |
|||
//重置表单 |
|||
const resetQueryTd = () =>{ |
|||
searckFormRefTd.value.resetFields(); |
|||
initData(); |
|||
} |
|||
//初始化数据 |
|||
const initData = () =>{ |
|||
selectInfoTd.page = 1; |
|||
selectInfoTd.pagesize = 15; |
|||
selectInfoTd.title = "" |
|||
selectInfoTd.class = 2; |
|||
selectInfoTd.state = 0; |
|||
} |
|||
const myappbox = ref() |
|||
const drawerMyWith = ref<number>(0); |
|||
//加载数据 |
|||
onMounted(()=>{ |
|||
getToDoListTd(); |
|||
drawerMyWith.value = myappbox.value?.clientWidth |
|||
}) |
|||
const flowLogInfo = ref<any>() |
|||
const darwOpenOrClose = ref(false) |
|||
|
|||
/** |
|||
* 查看流程任务 |
|||
* val 记录内容 |
|||
* types 记录类型; 1、我的请求;2、待办事宜;3、已办事宜;4:草稿箱 |
|||
*/ |
|||
const lookFlowInfo = (val:any,types:number) => { |
|||
flowLogInfo.value = val |
|||
darwOpenOrClose.value = true |
|||
} |
|||
</script> |
|||
<template> |
|||
<div ref="myappbox" class="app_box"> |
|||
<div class="app-container"> |
|||
<div class="search"> |
|||
<el-form ref="searckFormRefTd" :model="selectInfoTd" :inline="true"> |
|||
<el-form-item label="任务标题" prop="name"> |
|||
<el-input |
|||
v-model="selectInfoTd.title" |
|||
placeholder="请输入任务标题" |
|||
clearable |
|||
@keyup.enter="searchQuery" |
|||
/> |
|||
</el-form-item> |
|||
<el-form-item> |
|||
<el-button type="primary" @click="getToDoListTd()"><i-ep-search />搜索</el-button> |
|||
<el-button @click="resetQueryTd()"><i-ep-refresh />重置</el-button> |
|||
</el-form-item> |
|||
</el-form> |
|||
</div> |
|||
<el-card shadow="never"> |
|||
<el-table |
|||
v-loadingTd="loadingTd" |
|||
element-loadingTd-text="Loading..." |
|||
highlight-current-row |
|||
:data="taskFlowAryTd" |
|||
border |
|||
class="table_box" |
|||
> |
|||
<el-table-column fixed label="标题" prop="title" width="500" /> |
|||
<el-table-column label="创建人" prop="creater" > |
|||
<template #default="scope"> |
|||
{{ scope.row.creatorInfo.name }}(<el-text type="info">{{ scope.row.creatorInfo.number }}</el-text>) |
|||
</template> |
|||
</el-table-column> |
|||
<el-table-column label="发起日期" prop="startDate" align="center" width="300" /> |
|||
<el-table-column label="状态" prop="status" align="center" width="220" > |
|||
|
|||
<template #default="scope"> |
|||
<el-tag |
|||
v-if="scope.row.status==1" |
|||
class="mx-1" |
|||
effect="plain" |
|||
round |
|||
> |
|||
草稿 |
|||
</el-tag> |
|||
<el-tag |
|||
v-else-if="scope.row.status==2" |
|||
type="danger" |
|||
class="mx-1" |
|||
effect="plain" |
|||
round |
|||
> |
|||
驳回 |
|||
</el-tag> |
|||
<el-tag |
|||
v-else-if="scope.row.status==3" |
|||
type="success" |
|||
class="mx-1" |
|||
effect="plain" |
|||
round |
|||
> |
|||
审批中 |
|||
</el-tag> |
|||
<el-tag |
|||
v-else-if="scope.row.status==4" |
|||
type="info" |
|||
class="mx-1" |
|||
effect="plain" |
|||
round |
|||
> |
|||
归档 |
|||
</el-tag> |
|||
<el-tag |
|||
v-else |
|||
type="info" |
|||
class="mx-1" |
|||
effect="plain" |
|||
round |
|||
> |
|||
删除 |
|||
</el-tag> |
|||
</template> |
|||
|
|||
</el-table-column> |
|||
<el-table-column label="当前节点及操作人" prop="currentStep" width="400" > |
|||
<template #default="scope"> |
|||
<el-text v-if="scope.row.currentNodeName" type="success">{{ scope.row.currentNodeName }}:</el-text><el-text v-for="(item,index) in scope.row.currentNodeUser" :key="index" type="warning">{{ item.name }}({{ item.number }})</el-text> |
|||
</template> |
|||
</el-table-column> |
|||
<el-table-column fixed="right" align="center" label="操作" width="100" > |
|||
<template #default="scope"> |
|||
<el-button type="primary" class="fa fa-eye" @click="lookFlowInfo(scope.row,2)" /> |
|||
</template> |
|||
</el-table-column> |
|||
</el-table> |
|||
<pagination |
|||
v-model:total="totalstd" |
|||
v-model:page="selectInfoTd.page" |
|||
v-model:limit="selectInfoTd.pagesize" |
|||
@pagination="getToDoListTd" |
|||
/> |
|||
</el-card> |
|||
|
|||
|
|||
<LookAndOperateLogInfo v-if="darwOpenOrClose" v-model:isshow="darwOpenOrClose" :flow-log-info="flowLogInfo" :drawer-with="drawerMyWith" @getmytodolist="getMyToDoList" /> |
|||
|
|||
|
|||
|
|||
</div> |
|||
</div> |
|||
|
|||
</template> |
|||
<style lang='scss' scoped> |
|||
.app_box{ |
|||
width:100%; |
|||
overflow: hidden; |
|||
overflow-y: auto; |
|||
} |
|||
.box-card { |
|||
width: 100%; |
|||
} |
|||
.table_box{ |
|||
width: 100%; |
|||
height: calc(100vh - 308px); |
|||
} |
|||
</style> |
|||