|
After Width: | Height: | Size: 1.2 KiB |
|
After Width: | Height: | Size: 7.0 KiB |
|
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 |
@ -1,398 +0,0 @@ |
|||||
<!-- |
|
||||
@ 作者: 秦东 |
|
||||
@ 时间: 2023-11-06 13:39:13 |
|
||||
@ 备注: 首页 |
|
||||
--> |
|
||||
<script lang='ts' setup> |
|
||||
import * as echarts from 'echarts'; //引入图形界面 |
|
||||
|
|
||||
import { useUserStore } from "@/store/modules/user"; |
|
||||
|
|
||||
|
|
||||
import { sendOrgCont } from '@/api/displayboardapi/types' |
|
||||
import { getOrgChiled,getCompanyDeparment,targetListForDepartment } from '@/api/displayboardapi/indexapi' |
|
||||
|
|
||||
import UserInfo from "@/views/dashboard/components/userinfo.vue"; |
|
||||
|
|
||||
import DingLiangTongBiHuanBi from "@/views/dashboard/components/dltbhb.vue"; |
|
||||
|
|
||||
import EducationChart from "@/views/dashboard/components/education.vue"; |
|
||||
|
|
||||
const userStore = useUserStore(); |
|
||||
|
|
||||
const legendList = new Array |
|
||||
const seriesData = new Array |
|
||||
const orgListCont = ref<sendOrgCont>() |
|
||||
const educationOrgId = ref<number>(309) |
|
||||
//公司主部门 |
|
||||
const mainOrgList = ref<any[]>([]) |
|
||||
const targetListAry = ref<any[]>([]) |
|
||||
const targetXingListAry = ref<any[]>([]) |
|
||||
//定性同比环比分析 |
|
||||
const dingXingYear = ref<number>() |
|
||||
const dingXingOrg = ref<any>() |
|
||||
const dingXingTarget = ref<any>() |
|
||||
//定量指标目标达成 |
|
||||
const dingLiangDaChengYear = ref<number>() |
|
||||
const dingLiangDaChengOrg = ref<any>() |
|
||||
const dingLiangDaChengTarget = ref<any>() |
|
||||
//定量同比环比分析 |
|
||||
const dingLiangYear = ref<number>() |
|
||||
const dingLiangOrg = ref<any>() |
|
||||
const dingLiangTarget = ref<any>() |
|
||||
|
|
||||
const loadPage = ref(false) |
|
||||
/** |
|
||||
* 获取行政组织 |
|
||||
*/ |
|
||||
function getOrgList(){ |
|
||||
getOrgChiled({id:313}) |
|
||||
.then(( {data} )=>{ |
|
||||
console.log("获取行政组织-2-->",data) |
|
||||
orgListCont.value = data.list |
|
||||
educationOrgId.value = data.current |
|
||||
|
|
||||
}) |
|
||||
} |
|
||||
|
|
||||
|
|
||||
|
|
||||
//根据行政组织获取指标 |
|
||||
const orgAboutTarget = (orgId:string,tarAttribute:number) =>{ |
|
||||
let sendIfo = { |
|
||||
id:orgId, |
|
||||
attribute:tarAttribute |
|
||||
} |
|
||||
targetListForDepartment(sendIfo) |
|
||||
.then((data:any) =>{ |
|
||||
console.log("获取指标-1-->",data) |
|
||||
if(tarAttribute==1){ |
|
||||
targetXingListAry.value = data.data |
|
||||
if(data.data&&data.data.length>0){ |
|
||||
dingXingTarget.value = data.data[0].id |
|
||||
} |
|
||||
}else{ |
|
||||
targetListAry.value = data.data |
|
||||
if(data.data&&data.data.length>0){ |
|
||||
dingLiangDaChengTarget.value = data.data[0].id |
|
||||
dingLiangTarget.value = data.data[0].id.toString() |
|
||||
} |
|
||||
} |
|
||||
|
|
||||
}) |
|
||||
.finally(() =>{ |
|
||||
loadPage.value = true |
|
||||
}) |
|
||||
} |
|
||||
|
|
||||
//所有行政组织月度画图对象 |
|
||||
const orgYearFullMonths = ref<any>() |
|
||||
const orgAllYears = ref<any>() //当前年 |
|
||||
const allOrgOneMonth = ref<any>() //指定月 |
|
||||
const oenOrgAllYears = ref<any>() //单一行政指定年 |
|
||||
const oenOrg = ref<any>() //单一行政组织 |
|
||||
//行政组织月度绩效 |
|
||||
const departmentYears = ref<any>(null) |
|
||||
|
|
||||
//渲染完页面再执行 |
|
||||
onMounted(() => { |
|
||||
let dataTime:any = new Date(); |
|
||||
console.log("dataTime--->",dataTime.getFullYear()) |
|
||||
let timeStrint:any = dataTime; |
|
||||
dingXingYear.value = dataTime |
|
||||
dingLiangDaChengYear.value = dataTime |
|
||||
dingLiangYear.value = dataTime |
|
||||
console.log("timeStrint-1-->",dataTime,dingLiangYear) |
|
||||
getOrgList(); |
|
||||
orgYearFullMonths.value = echarts.init(departmentYears.value) |
|
||||
let option = { |
|
||||
|
|
||||
tooltip: { |
|
||||
trigger: 'axis' |
|
||||
}, |
|
||||
legend: { |
|
||||
data: ['Email', 'Union Ads', 'Video Ads', 'Direct', 'Search Engine'], |
|
||||
bottom:0 |
|
||||
}, |
|
||||
grid: { |
|
||||
top:"20px", |
|
||||
left: '1%', |
|
||||
right: '2%', |
|
||||
bottom: '30px', |
|
||||
containLabel: true |
|
||||
}, |
|
||||
toolbox: { |
|
||||
feature: { |
|
||||
saveAsImage: {} |
|
||||
} |
|
||||
}, |
|
||||
xAxis: { |
|
||||
type: 'category', |
|
||||
boundaryGap: false, |
|
||||
data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'] |
|
||||
}, |
|
||||
yAxis: { |
|
||||
type: 'value' |
|
||||
}, |
|
||||
series: [ |
|
||||
{ |
|
||||
name: 'Email', |
|
||||
type: 'line', |
|
||||
stack: 'Total', |
|
||||
data: [120, 132, 101, 134, 90, 230, 210] |
|
||||
}, |
|
||||
{ |
|
||||
name: 'Union Ads', |
|
||||
type: 'line', |
|
||||
stack: 'Total', |
|
||||
data: [220, 182, 191, 234, 290, 330, 310] |
|
||||
}, |
|
||||
{ |
|
||||
name: 'Video Ads', |
|
||||
type: 'line', |
|
||||
stack: 'Total', |
|
||||
data: [150, 232, 201, 154, 190, 330, 410] |
|
||||
}, |
|
||||
{ |
|
||||
name: 'Direct', |
|
||||
type: 'line', |
|
||||
stack: 'Total', |
|
||||
data: [320, 332, 301, 334, 390, 330, 320] |
|
||||
}, |
|
||||
{ |
|
||||
name: 'Search Engine', |
|
||||
type: 'line', |
|
||||
stack: 'Total', |
|
||||
data: [820, 932, 901, 934, 1290, 1330, 1320] |
|
||||
} |
|
||||
] |
|
||||
}; |
|
||||
|
|
||||
orgYearFullMonths.value.setOption(option) |
|
||||
}) |
|
||||
</script> |
|
||||
<template> |
|
||||
<div ref="masterBody" class="app-container" style="margin-top:10px;"> |
|
||||
<el-row :gutter="10"> |
|
||||
<el-col :xs="24" :sm="16" :md="16" :lg="18" :xl="19" class="readback"> |
|
||||
<el-card shadow="always" :body-style="{ padding: '10px' }" style = "border-radius: 12px;margin-top: 10px;"> |
|
||||
<!--分厂数据统计--> |
|
||||
<div class="orgAllMothsTitle"> |
|
||||
<el-text class="titleInfo">2023年绩效成绩</el-text> |
|
||||
<el-date-picker |
|
||||
v-model="allOrgOneMonth" |
|
||||
type="year" |
|
||||
placeholder="请选择时间" |
|
||||
/> |
|
||||
</div> |
|
||||
<div ref="departmentYears" class="allOrgAxisCares"> |
|
||||
|
|
||||
</div> |
|
||||
</el-card> |
|
||||
</el-col> |
|
||||
<el-col :xs="24" :sm="8" :md="8" :lg="6" :xl="5" class="greenColor"> |
|
||||
<UserInfo :user-store="userStore" /> |
|
||||
</el-col> |
|
||||
</el-row> |
|
||||
<el-row :gutter="10" class="cart_top_juLi"> |
|
||||
<el-col :xs="24" :sm="16" :md="16" :lg="18" :xl="19" class="readback"> |
|
||||
|
|
||||
<el-row :gutter="10"> |
|
||||
<el-col :xs="24" :sm="24" :md="24" :lg="12" :xl="12" class="readback"> |
|
||||
|
|
||||
<el-card shadow="always" :body-style="{ padding: '10px' }" style = "border-radius: 12px;margin-top: 10px;"> |
|
||||
<!--单月全厂统计--> |
|
||||
<div class="orgAllMothsTitle"> |
|
||||
<el-text class="titleInfo">2023年10月绩效成绩</el-text> |
|
||||
<el-date-picker |
|
||||
v-model="orgAllYears" |
|
||||
type="month" |
|
||||
placeholder="请选择时间" |
|
||||
/> |
|
||||
</div> |
|
||||
<div ref="departmentMonths" class="allOrgAxisCares"> |
|
||||
|
|
||||
</div> |
|
||||
</el-card> |
|
||||
|
|
||||
</el-col> |
|
||||
<el-col :xs="24" :sm="24" :md="24" :lg="12" :xl="12" class="readback"> |
|
||||
|
|
||||
<el-card shadow="always" :body-style="{ padding: '10px' }" style = "border-radius: 12px;margin-top: 10px;"> |
|
||||
<!--单一行政组织全年统计--> |
|
||||
<div class="orgAllMothsTitle"> |
|
||||
<el-text class="titleInfo">2023年备煤绩效成绩</el-text> |
|
||||
<div> |
|
||||
<el-select v-model="oenOrg" placeholder="" style="width:100px"> |
|
||||
<el-option |
|
||||
v-for="item in options" |
|
||||
:key="item.value" |
|
||||
:label="item.label" |
|
||||
:value="item.value"> |
|
||||
</el-option> |
|
||||
</el-select> |
|
||||
<el-date-picker |
|
||||
v-model="oenOrgAllmonth" |
|
||||
type="month" |
|
||||
placeholder="请选择时间" |
|
||||
style="width:120px" |
|
||||
/> |
|
||||
</div> |
|
||||
</div> |
|
||||
<div ref="departmentMonths" class="allOrgAxisCares"> |
|
||||
|
|
||||
</div> |
|
||||
</el-card> |
|
||||
|
|
||||
</el-col> |
|
||||
</el-row> |
|
||||
|
|
||||
|
|
||||
|
|
||||
|
|
||||
|
|
||||
</el-col> |
|
||||
<el-col :xs="24" :sm="8" :md="8" :lg="6" :xl="5" class="greenColor"> |
|
||||
|
|
||||
<el-card shadow="always" :body-style="{ padding: '10px' }" style = "border-radius: 12px;margin-top: 10px;; height: 335px"> |
|
||||
<!--单月全厂统计--> |
|
||||
<div class="orgAllMothsTitle"> |
|
||||
<el-text class="titleInfo">热门新闻</el-text> |
|
||||
</div> |
|
||||
<div ref="departmentMonths" class="allOrgAxisCares"> |
|
||||
|
|
||||
</div> |
|
||||
</el-card> |
|
||||
|
|
||||
</el-col> |
|
||||
</el-row> |
|
||||
<el-row :gutter="10" class="cart_top_juLi"> |
|
||||
<el-col :xs="24" :sm="16" :md="16" :lg="18" :xl="19" class="readback"> |
|
||||
|
|
||||
<el-row :gutter="10"> |
|
||||
<el-col :xs="24" :sm="24" :md="24" :lg="8" :xl="8"> |
|
||||
<el-card shadow="always" :body-style="{ padding: '10px' }" style = "border-radius: 12px;margin-top: 10px;"> |
|
||||
<div class="orgAllMothsTitle"> |
|
||||
<el-row> |
|
||||
<el-col :span="8"> |
|
||||
<el-date-picker |
|
||||
v-model="dingXingYear" |
|
||||
type="year" |
|
||||
placeholder="请选择时间" |
|
||||
style="width:100%" |
|
||||
/> |
|
||||
</el-col> |
|
||||
<el-col :span="8"> |
|
||||
<el-select v-model="dingXingOrg" placeholder="" style="width:100%"> |
|
||||
<el-option |
|
||||
v-for="item in mainOrgList" |
|
||||
:key="item.id" |
|
||||
:label="item.name" |
|
||||
:value="item.id"> |
|
||||
</el-option> |
|
||||
</el-select> |
|
||||
</el-col> |
|
||||
<el-col :span="8"> |
|
||||
<el-select v-model="dingXingTarget" placeholder="" style="width:100%"> |
|
||||
<el-option |
|
||||
v-for="item in targetXingListAry" |
|
||||
:key="item.id" |
|
||||
:label="item.name" |
|
||||
:value="item.id"> |
|
||||
</el-option> |
|
||||
</el-select> |
|
||||
</el-col> |
|
||||
</el-row> |
|
||||
</div> |
|
||||
<div ref="departmentMonths" class="allOrgAxisCares"> |
|
||||
|
|
||||
</div> |
|
||||
</el-card> |
|
||||
</el-col> |
|
||||
<el-col :xs="24" :sm="24" :md="24" :lg="8" :xl="8"> |
|
||||
<el-card shadow="always" :body-style="{ padding: '10px' }" style = "border-radius: 12px;margin-top: 10px;"> |
|
||||
<div class="orgAllMothsTitle"> |
|
||||
<el-row> |
|
||||
<el-col :span="8"> |
|
||||
<el-date-picker |
|
||||
v-model="dingLiangDaChengYear" |
|
||||
type="year" |
|
||||
placeholder="请选择时间" |
|
||||
style="width:100%" |
|
||||
/> |
|
||||
</el-col> |
|
||||
<el-col :span="8"> |
|
||||
<el-select v-model="dingLiangDaChengOrg" placeholder="" style="width:100%"> |
|
||||
<el-option |
|
||||
v-for="item in mainOrgList" |
|
||||
:key="item.id" |
|
||||
:label="item.name" |
|
||||
:value="item.id"> |
|
||||
</el-option> |
|
||||
</el-select> |
|
||||
</el-col> |
|
||||
<el-col :span="8"> |
|
||||
<el-select v-model="dingLiangDaChengTarget" placeholder="" style="width:100%"> |
|
||||
<el-option |
|
||||
v-for="item in targetListAry" |
|
||||
:key="item.id" |
|
||||
:label="item.name" |
|
||||
:value="item.id"> |
|
||||
</el-option> |
|
||||
</el-select> |
|
||||
</el-col> |
|
||||
</el-row> |
|
||||
</div> |
|
||||
<div ref="departmentMonths" class="allOrgAxisCares"> |
|
||||
|
|
||||
</div> |
|
||||
</el-card> |
|
||||
</el-col> |
|
||||
<el-col :xs="24" :sm="24" :md="24" :lg="8" :xl="8"> |
|
||||
<!--定量指标同比环比--> |
|
||||
<DingLiangTongBiHuanBi v-if="loadPage" :main-org-list="mainOrgList" :target-list-ary="targetListAry" :dlyear="dingLiangYear" :ding-liang-org="dingLiangOrg" :ding-liang-target="dingLiangTarget" /> |
|
||||
</el-col> |
|
||||
</el-row> |
|
||||
|
|
||||
</el-col> |
|
||||
<el-col :xs="24" :sm="8" :md="8" :lg="6" :xl="5" class="greenColor"> |
|
||||
<EducationChart :org-list-cont="orgListCont" :education-org-id="educationOrgId" /> |
|
||||
|
|
||||
</el-col> |
|
||||
</el-row> |
|
||||
</div> |
|
||||
</template> |
|
||||
<style lang='scss' scoped> |
|
||||
.readback{ |
|
||||
// background-color:#FF0000; |
|
||||
.allOrgAxisCares{ |
|
||||
display: block; |
|
||||
width:100%; |
|
||||
height:280px; |
|
||||
overflow:auto; |
|
||||
} |
|
||||
|
|
||||
} |
|
||||
.orgAllMothsTitle{ |
|
||||
width:100%; |
|
||||
display: flex; |
|
||||
align-items: center; |
|
||||
justify-content:space-between; |
|
||||
|
|
||||
} |
|
||||
.greenColor{ |
|
||||
// background-color:#FFAC52; |
|
||||
|
|
||||
// padding:0 10px 0 10px; |
|
||||
} |
|
||||
.span_icon_left{ |
|
||||
margin-right:10px; |
|
||||
} |
|
||||
.cart_top_juLi{ |
|
||||
// margin-top:10px; |
|
||||
} |
|
||||
.titleInfo{ |
|
||||
font-size: 20px; |
|
||||
font-weight: bold; |
|
||||
} |
|
||||
</style> |
|
||||
@ -0,0 +1,347 @@ |
|||||
|
<!-- |
||||
|
@ 作者: 秦东 |
||||
|
@ 时间: 2023-11-22 08:16:12 |
||||
|
@ 备注: 全部行政组织 |
||||
|
--> |
||||
|
<script lang='ts' setup> |
||||
|
import { getOrgFormTree,getOrgFormUserList,searchUserCustomerFormList } from '@/api/hr/org/index' |
||||
|
import { orgform,criteriaForPeopleList } from '@/api/hr/org/type' |
||||
|
import UserRole from '@/assets/icons/user.svg' |
||||
|
|
||||
|
import { searchUserList,gainFlowPeople } from '@/api/DesignForm/requestapi' |
||||
|
|
||||
|
const props = defineProps({ |
||||
|
openclosebox:{ |
||||
|
type:Boolean, |
||||
|
default:false |
||||
|
}, |
||||
|
selectedPeople: { |
||||
|
type: Array, |
||||
|
default: () => [] |
||||
|
} |
||||
|
}) |
||||
|
const emits = defineEmits(["update:openclosebox","updateNode"]); |
||||
|
const isOpen = computed({ |
||||
|
get: () => props.openclosebox, |
||||
|
set: (val) => { |
||||
|
emits("update:openclosebox", val); |
||||
|
}, |
||||
|
}); |
||||
|
const defaultProps ={ |
||||
|
children: 'children', |
||||
|
label: 'name', |
||||
|
} |
||||
|
const orgLoading = ref(false) |
||||
|
const userLoading = ref(false) |
||||
|
// 侧栏处理 |
||||
|
const treeEl = ref(null) |
||||
|
const treeData = ref<orgform[]>([]) |
||||
|
const department = ref<any>() |
||||
|
const userName = ref<any>() |
||||
|
const tableData = ref<criteriaForPeopleList[]>(); |
||||
|
const page = reactive({ |
||||
|
total: 0, |
||||
|
current: 1, |
||||
|
pageSize: 11 |
||||
|
}) |
||||
|
//行政组织树单击事件 |
||||
|
const handleNodeClick = (data: any) => { |
||||
|
department.value = data.id |
||||
|
getUserList() |
||||
|
} |
||||
|
//重置搜索 |
||||
|
const resetClick = () => { |
||||
|
userName.value = '' |
||||
|
department.value = '' |
||||
|
treeEl.value.setCurrentKey(null) |
||||
|
getUserList() |
||||
|
} |
||||
|
//获取行政组织 |
||||
|
const getTreeData = () => { |
||||
|
orgLoading.value = true |
||||
|
getOrgFormTree() |
||||
|
.then(({ data }) => { |
||||
|
// console.log(data) |
||||
|
treeData.value = data.list |
||||
|
}).finally(()=>{ |
||||
|
orgLoading.value = false |
||||
|
}) |
||||
|
} |
||||
|
//获取人员列表信息 |
||||
|
const getUserList = () => { |
||||
|
userLoading.value = true |
||||
|
const params = { |
||||
|
page: page.current, |
||||
|
pagesize: page.pageSize, |
||||
|
name: userName.value, |
||||
|
department: department.value |
||||
|
} |
||||
|
searchUserList(params) |
||||
|
.then(({ data })=>{ |
||||
|
tableData.value = data.list |
||||
|
page.total = data.total |
||||
|
userLoading.value = false |
||||
|
}) |
||||
|
.finally(()=>{ |
||||
|
userLoading.value = false |
||||
|
}) |
||||
|
} |
||||
|
//翻页 |
||||
|
const currentChange = (current: number) => { |
||||
|
page.current = current |
||||
|
getUserList() |
||||
|
} |
||||
|
|
||||
|
onMounted(() => { |
||||
|
nextTick(() => { |
||||
|
// 可根据实际情况放在点击打开弹窗后加载,会出现loading |
||||
|
getTreeData() |
||||
|
getUserList() |
||||
|
backfillData() |
||||
|
}) |
||||
|
}) |
||||
|
//已选择内容 |
||||
|
const checkDataList = reactive<criteriaForPeopleList[]>([]); |
||||
|
const tableRowClick = (row: any) => { |
||||
|
if(checkDataList.length > 0){ |
||||
|
let isIn = true |
||||
|
checkDataList.forEach(item =>{ |
||||
|
if(item.id == row.id){ |
||||
|
isIn = false |
||||
|
} |
||||
|
}) |
||||
|
if(isIn){ |
||||
|
checkDataList.push(row) |
||||
|
} |
||||
|
}else{ |
||||
|
checkDataList.push(row) |
||||
|
} |
||||
|
// console.log("checkDataList",checkDataList,row) |
||||
|
} |
||||
|
//删除单一选择 |
||||
|
const delRowClick = (row: criteriaForPeopleList) => { |
||||
|
// console.log("checkDataList",row) |
||||
|
if(checkDataList &&checkDataList.length > 0) { |
||||
|
checkDataList.forEach((item:criteriaForPeopleList,index:number) => { |
||||
|
if(item.id == row.id){ |
||||
|
if(!item.noedit){ |
||||
|
checkDataList.splice(index,1) |
||||
|
} |
||||
|
} |
||||
|
}) |
||||
|
} |
||||
|
} |
||||
|
//清除所有的选择 |
||||
|
const delAllClick = () => { |
||||
|
// checkDataList.splice(0,checkDataList.length) |
||||
|
checkDataList.forEach((item:criteriaForPeopleList,index:number) => { |
||||
|
if(!item.noedit){ |
||||
|
checkDataList.splice(index,1) |
||||
|
} |
||||
|
}) |
||||
|
} |
||||
|
|
||||
|
//关闭弹窗 |
||||
|
const clostBox = () =>{ |
||||
|
emits("update:openclosebox", false); |
||||
|
} |
||||
|
//提交选择 |
||||
|
const confirmChoices = () => { |
||||
|
// console.log("confirmChoices",checkDataList) |
||||
|
emits('updateNode', checkDataList) |
||||
|
clostBox() |
||||
|
} |
||||
|
//回填已经选中得内容 |
||||
|
const backfillData = () => { |
||||
|
if(props.selectedPeople && props.selectedPeople.length > 0){ |
||||
|
checkDataList.splice(0,checkDataList.length) |
||||
|
props.selectedPeople.forEach((item:any)=>{ |
||||
|
checkDataList.push(item) |
||||
|
}) |
||||
|
} |
||||
|
// console.log("props.selectedPeople",props.selectedPeople,checkDataList) |
||||
|
} |
||||
|
</script> |
||||
|
<template> |
||||
|
<el-dialog |
||||
|
v-model="isOpen" |
||||
|
title="选择人员" |
||||
|
:append-to-body="true" |
||||
|
:props="defaultProps " |
||||
|
width="80%" |
||||
|
top="2vh" |
||||
|
draggable |
||||
|
> |
||||
|
<el-row :gutter="20"> |
||||
|
<el-col :span="6" style="padding:0"> |
||||
|
<div class="sidebar_tree"> |
||||
|
<el-text class="orgTitle" size="large">行政组织</el-text> |
||||
|
<el-tree |
||||
|
v-loading="orgLoading" |
||||
|
element-loading-text="Loading..." |
||||
|
ref="treeEl" |
||||
|
:data="treeData" |
||||
|
node-key="id" |
||||
|
@node-click="handleNodeClick" |
||||
|
:props="defaultProps " |
||||
|
highlight-current |
||||
|
/> |
||||
|
</div> |
||||
|
</el-col> |
||||
|
<el-col :span="12"> |
||||
|
<div class="search"> |
||||
|
<el-input placeholder="请输入用户名" v-model="userName" /> |
||||
|
<el-button type="primary" @click="getUserList">查询</el-button> |
||||
|
<el-button @click="resetClick">重置</el-button> |
||||
|
</div> |
||||
|
<div class="list"> |
||||
|
<el-table v-loading="userLoading" element-loading-text="Loading..." :data="tableData" style="width: 100%; height:660px"> |
||||
|
<el-table-column fixed prop="userName" label="照片" width="60px" align="center"> |
||||
|
<template #default="scope"> |
||||
|
<el-avatar v-if="scope.row.icon != ''" shape="square" :size="30" :src="scope.row.icon" /> |
||||
|
<el-avatar v-else shape="square" :size="30" :src="UserRole" /> |
||||
|
</template> |
||||
|
</el-table-column> |
||||
|
<el-table-column fixed prop="name" label="姓名" width="150px" align="left"> |
||||
|
<template #default="scope"> |
||||
|
{{ scope.row.name }}({{ scope.row.number }}) |
||||
|
</template> |
||||
|
</el-table-column> |
||||
|
<el-table-column prop="tel" label="联系方式" width="120px" align="left" /> |
||||
|
<el-table-column prop="nickName" label="归属行政组织" width="500px" align="left"> |
||||
|
<template #default="{ row }"> |
||||
|
{{ row.companyName }}<span v-if="row.departmentname!=''"> / {{ row.departmentname }}</span><span v-if="row.postname!=''"> / {{ row.postname }}</span> |
||||
|
</template> |
||||
|
</el-table-column> |
||||
|
<el-table-column fixed="right" label="操作" width="60px"> |
||||
|
<template #default="{ row }"> |
||||
|
<el-button circle size="small" @click="tableRowClick(row)"><el-icon><ArrowRight /></el-icon></el-button> |
||||
|
</template> |
||||
|
</el-table-column> |
||||
|
</el-table> |
||||
|
<div class="page"> |
||||
|
<el-pagination |
||||
|
background |
||||
|
layout="prev, pager, next, jumper" |
||||
|
small |
||||
|
hide-on-single-page |
||||
|
:current-page="page.current" |
||||
|
:total="page.total" |
||||
|
:page-size="page.pageSize" |
||||
|
@current-change="currentChange" |
||||
|
/> |
||||
|
</div> |
||||
|
</div> |
||||
|
</el-col> |
||||
|
<el-col :span="6"> |
||||
|
<div class="has_select"> |
||||
|
<div class="total"> |
||||
|
<div>已选择:{{ checkDataList.length }}</div> |
||||
|
<el-button type="danger" @click="delAllClick" size="small">全部移除</el-button> |
||||
|
</div> |
||||
|
<el-table :data="checkDataList" style="height:680px"> |
||||
|
<el-table-column prop="userName" label="照片" width="60px" align="center"> |
||||
|
<template #default="scope"> |
||||
|
<el-avatar v-if="scope.row.icon != ''" shape="square" :size="30" :src="scope.row.icon" /> |
||||
|
<el-avatar v-else shape="square" :size="30" :src="UserRole" /> |
||||
|
</template> |
||||
|
</el-table-column> |
||||
|
<el-table-column prop="name" label="姓名" align="left"> |
||||
|
<template #default="scope"> |
||||
|
{{ scope.row.name }}({{ scope.row.number }}) |
||||
|
</template> |
||||
|
</el-table-column> |
||||
|
<el-table-column label="操作" width="60px"> |
||||
|
<template #default="{ row }"> |
||||
|
<el-button v-if="!row.noedit" size="small" type="danger" @click="delRowClick(row)">移除</el-button> |
||||
|
</template> |
||||
|
</el-table-column> |
||||
|
</el-table> |
||||
|
</div> |
||||
|
</el-col> |
||||
|
|
||||
|
</el-row> |
||||
|
<template #footer> |
||||
|
<div> |
||||
|
<el-button @click="clostBox">取消</el-button> |
||||
|
<el-button type="primary" @click="confirmChoices"> 确定 </el-button> |
||||
|
</div> |
||||
|
</template> |
||||
|
</el-dialog> |
||||
|
</template> |
||||
|
<style lang='scss' scoped> |
||||
|
.orgTitle{ |
||||
|
padding: 0 0 0 5px; |
||||
|
} |
||||
|
.sidebar_tree { |
||||
|
width: 100%; |
||||
|
border: 1px solid #ebeef5; |
||||
|
border-radius: 3px; |
||||
|
padding: 10px 0; |
||||
|
margin-right: 10px; |
||||
|
height: 750px; |
||||
|
overflow-y: auto; |
||||
|
} |
||||
|
.has_select { |
||||
|
width: 100%; |
||||
|
|
||||
|
.total { |
||||
|
display: flex; |
||||
|
justify-content: space-between; |
||||
|
align-items: center; |
||||
|
height: 32px; |
||||
|
margin-bottom: 10px; |
||||
|
} |
||||
|
} |
||||
|
.search { |
||||
|
display: flex; |
||||
|
margin-bottom: 10px; |
||||
|
.el-input { |
||||
|
margin-right: 10px; |
||||
|
} |
||||
|
} |
||||
|
.page { |
||||
|
padding-top: 20px; |
||||
|
display: flex; |
||||
|
justify-content:space-between; |
||||
|
} |
||||
|
.expand-user-dialog { |
||||
|
display: flex; |
||||
|
align-items: flex-start; |
||||
|
.sidebar-tree { |
||||
|
width: 180px; |
||||
|
border: 1px solid #ebeef5; |
||||
|
border-radius: 3px; |
||||
|
padding: 10px 0; |
||||
|
margin-right: 10px; |
||||
|
max-height: 500px; |
||||
|
overflow-y: auto; |
||||
|
} |
||||
|
.table-list { |
||||
|
|
||||
|
} |
||||
|
.search { |
||||
|
display: flex; |
||||
|
margin-bottom: 10px; |
||||
|
.el-input { |
||||
|
margin-right: 10px; |
||||
|
} |
||||
|
} |
||||
|
.page { |
||||
|
padding-top: 20px; |
||||
|
display: flex; |
||||
|
justify-content: flex-end; |
||||
|
} |
||||
|
.has-select { |
||||
|
width: 200px; |
||||
|
margin-left: 20px; |
||||
|
.total { |
||||
|
display: flex; |
||||
|
justify-content: space-between; |
||||
|
align-items: center; |
||||
|
height: 32px; |
||||
|
margin-bottom: 10px; |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
</style> |
||||
@ -0,0 +1,195 @@ |
|||||
|
<!-- |
||||
|
@ 作者: 秦东 |
||||
|
@ 时间: 2023-11-21 13:01:56 |
||||
|
@ 备注: 选择人员 |
||||
|
--> |
||||
|
<script lang='ts' setup> |
||||
|
const state = reactive({ |
||||
|
circleUrl:'https://cube.elemecdn.com/3/7c/3ea6beec64369c2642b92c6726f1epng.png', |
||||
|
squareUrl:'https://cube.elemecdn.com/9/c2/f0ee8a3c7c9638a54940382568c9dpng.png', |
||||
|
sizeList: ['small', '', 'large'] as const, |
||||
|
}) |
||||
|
const { circleUrl, squareUrl, sizeList } = toRefs(state) |
||||
|
const props = defineProps({ |
||||
|
openclose:{ |
||||
|
type:Boolean, |
||||
|
default:false |
||||
|
}, |
||||
|
presetPersonnel: { |
||||
|
type: Array, |
||||
|
default: () => [] |
||||
|
}, |
||||
|
selectedPeople: { |
||||
|
type: Array, |
||||
|
default: () => [] |
||||
|
} |
||||
|
}) |
||||
|
const emits = defineEmits(["update:openclose","updateNode"]); |
||||
|
const isShow = computed({ |
||||
|
get: () => props.openclose, |
||||
|
set: (val) => { |
||||
|
emits("update:openclose", val); |
||||
|
}, |
||||
|
}); |
||||
|
//指定人员 |
||||
|
const prePers = ref<any>([]); |
||||
|
//选择人员 |
||||
|
const setUpPrePers = ref<any>([]); |
||||
|
|
||||
|
watch(() =>props.openclose,(val:boolean)=>{ |
||||
|
// console.log("props.openclose--1-->",val) |
||||
|
// console.log("props.openclose--2-->",props.selectedPeople) |
||||
|
// console.log("props.openclose--3-->",props.presetPersonnel) |
||||
|
if(props.openclose){ |
||||
|
if(props.selectedPeople && props.selectedPeople.length > 0){ |
||||
|
setUpPrePers.value = props.selectedPeople |
||||
|
}else{ |
||||
|
setUpPrePers.value = new Array |
||||
|
if(props.presetPersonnel && props.presetPersonnel.length > 0){ |
||||
|
console.log("props.openclose--4-->",props.presetPersonnel) |
||||
|
props.presetPersonnel.forEach((item)=>{ |
||||
|
item.isTrue = false |
||||
|
}) |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
|
||||
|
}) |
||||
|
|
||||
|
const setUpUser = (val:any) => { |
||||
|
// console.log("setUpUser---->",val,prePers.value) |
||||
|
let isNewAdd = true; |
||||
|
if(setUpPrePers.value && setUpPrePers.value.length > 0){ |
||||
|
setUpPrePers.value.forEach((item:any,index:number) => { |
||||
|
if(val.id == item.id){ |
||||
|
isNewAdd = false; |
||||
|
if(!item.noedit){ |
||||
|
val.isTrue = false |
||||
|
setUpPrePers.value.splice(index,1) |
||||
|
}else{ |
||||
|
val.isTrue = true |
||||
|
} |
||||
|
} |
||||
|
}) |
||||
|
} |
||||
|
if(isNewAdd){ |
||||
|
val.isTrue = true |
||||
|
setUpPrePers.value.push(val) |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
//初始化数据 |
||||
|
const initDataUser = () => { |
||||
|
// console.log("销毁---->",prePers.value,setUpPrePers.value) |
||||
|
} |
||||
|
onMounted(() => { |
||||
|
if(props.openclose){ |
||||
|
if(props.selectedPeople && props.selectedPeople.length > 0){ |
||||
|
setUpPrePers.value = props.selectedPeople |
||||
|
}else{ |
||||
|
setUpPrePers.value = new Array |
||||
|
if(props.presetPersonnel && props.presetPersonnel.length > 0){ |
||||
|
// console.log("props.openclose--4-->",props.presetPersonnel) |
||||
|
props.presetPersonnel.forEach((item)=>{ |
||||
|
item.isTrue = false |
||||
|
}) |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
}) |
||||
|
const closeBox = () => { |
||||
|
emits("update:openclose", false); |
||||
|
} |
||||
|
//确定选择 |
||||
|
const saveFlowUser = () => { |
||||
|
emits("updateNode", setUpPrePers); |
||||
|
closeBox(); |
||||
|
} |
||||
|
</script> |
||||
|
<template> |
||||
|
<el-dialog |
||||
|
v-model="isShow" |
||||
|
title="选择人员" |
||||
|
width="800" |
||||
|
draggable |
||||
|
:before-close="handleClose" |
||||
|
> |
||||
|
<el-row :gutter="20"> |
||||
|
<el-col :span="12" > |
||||
|
<div class="bianKuan"> |
||||
|
<ul> |
||||
|
<li v-for="item in props.presetPersonnel" :key="item.id" :class="item.isTrue?'xuanZeUser active':'xuanZeUser'" @click="setUpUser(item)"> |
||||
|
<table> |
||||
|
<tr> |
||||
|
<td valign="top" align="center" width="50"> |
||||
|
<el-avatar v-if="item.iconbase64==''&&item.icon!=''" shape="square" fit="cover" :src="item.icon" /> |
||||
|
<el-avatar v-else-if="item.iconbase64!=''" shape="square" fit="cover" :src="item.iconbase64" /> |
||||
|
<el-avatar v-else shape="square" fit="cover" :src="squareUrl" /> |
||||
|
</td> |
||||
|
<td> |
||||
|
<el-text>{{ item.name }}({{ item.number }})</el-text><br> |
||||
|
<el-text v-if="item.departmentname">{{ item.departmentname }}</el-text> |
||||
|
<el-text v-if="item.postname"><span v-if="item.departmentname"> - </span>{{ item.postname }}</el-text> |
||||
|
</td> |
||||
|
</tr> |
||||
|
</table> |
||||
|
</li> |
||||
|
</ul> |
||||
|
</div> |
||||
|
</el-col> |
||||
|
<el-col :span="12"> |
||||
|
<div class="bianKuan"> |
||||
|
|
||||
|
<ul> |
||||
|
<li v-for="item in setUpPrePers" :key="item.id" class="xuanZeUser" @click="setUpUser(item)"> |
||||
|
<table> |
||||
|
<tr> |
||||
|
<td valign="top" align="center" width="50"> |
||||
|
<el-avatar v-if="item.iconbase64==''&&item.icon!=''" shape="square" fit="cover" :src="item.icon" /> |
||||
|
<el-avatar v-else-if="item.iconbase64!=''" shape="square" fit="cover" :src="item.iconbase64" /> |
||||
|
<el-avatar v-else shape="square" fit="cover" :src="squareUrl" /> |
||||
|
</td> |
||||
|
<td style="width:100%"> |
||||
|
<el-text>{{ item.name }}({{ item.number }})</el-text><br> |
||||
|
<el-text v-if="item.departmentname">{{ item.departmentname }}</el-text> |
||||
|
<el-text v-if="item.postname"><span v-if="item.departmentname"> - </span>{{ item.postname }}</el-text> |
||||
|
</td> |
||||
|
<td align="center" width="10"> |
||||
|
<i class="fa fa-close"></i> |
||||
|
</td> |
||||
|
</tr> |
||||
|
</table> |
||||
|
</li> |
||||
|
</ul> |
||||
|
|
||||
|
</div> |
||||
|
</el-col> |
||||
|
</el-row> |
||||
|
|
||||
|
<template #footer> |
||||
|
<span class="dialog-footer"> |
||||
|
<el-button @click="closeBox">关闭</el-button> |
||||
|
<el-button type="primary" @click="saveFlowUser">确定</el-button> |
||||
|
</span> |
||||
|
</template> |
||||
|
</el-dialog> |
||||
|
</template> |
||||
|
<style lang='scss' scoped> |
||||
|
.bianKuan{ |
||||
|
width: 100%; |
||||
|
height: 500px; |
||||
|
border: 1px solid #CCCCCC; |
||||
|
overflow: hidden; |
||||
|
overflow-y: auto; |
||||
|
} |
||||
|
.xuanZeUser{ |
||||
|
cursor: pointer; |
||||
|
// background-color: #F56C6C; |
||||
|
padding-top: 5px; |
||||
|
margin-bottom: 5px; |
||||
|
} |
||||
|
.xuanZeUser.active{ |
||||
|
background-color: #F56C6C; |
||||
|
} |
||||
|
</style> |
||||
@ -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,190 @@ |
|||||
|
<!-- |
||||
|
@ 作者: 秦东 |
||||
|
@ 时间: 2023-11-17 16:43:55 |
||||
|
@ 备注: 工作流步进图 |
||||
|
--> |
||||
|
<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 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 openOrClose = ref(false) |
||||
|
const openclosebox = ref(false) |
||||
|
const props = defineProps({ |
||||
|
flowMap: { |
||||
|
type: Array, |
||||
|
default: () => [] |
||||
|
}, |
||||
|
nodeKey:{ |
||||
|
type:String, |
||||
|
default:"" |
||||
|
}, |
||||
|
currentProgress:{ |
||||
|
type:Number, |
||||
|
default:0 |
||||
|
} |
||||
|
, |
||||
|
nextStep:{ |
||||
|
type:Number, |
||||
|
default:0 |
||||
|
} |
||||
|
}) |
||||
|
const presetPersonnel = ref<any>([]); //预设选择人 |
||||
|
const selectedPeople = ref<any>([]); //已选择人 |
||||
|
const flowMaps = ref<any[]>(); |
||||
|
const emits = defineEmits(["update:flowMap"]); |
||||
|
const flowList = computed({ |
||||
|
get: () => props.flowMap, |
||||
|
set: (val) => { |
||||
|
emits("update:flowMap", val); |
||||
|
}, |
||||
|
}); |
||||
|
watch(()=>props.flowMap,(val:any)=>{ |
||||
|
|
||||
|
emits("update:flowMap", val); |
||||
|
}) |
||||
|
onMounted(()=>{ |
||||
|
|
||||
|
}) |
||||
|
//判断是否有增加人员按钮 |
||||
|
const judgeAddUser = (val:any):boolean =>{ |
||||
|
// console.log("val----->",val) |
||||
|
if(val.customNode == "beginnode"){ |
||||
|
val.runscope = val.runscope!=0?val.runscope:1 |
||||
|
return true |
||||
|
} |
||||
|
switch(val.runtype){ |
||||
|
case 1: |
||||
|
val.runscope = val.runscope!=0?val.runscope:1 |
||||
|
return true |
||||
|
break; |
||||
|
case 3: |
||||
|
if(val.customNode == props.nodeKey){ |
||||
|
val.runscope = val.runscope!=0?val.runscope:1 |
||||
|
return true |
||||
|
} |
||||
|
break; |
||||
|
case 4: |
||||
|
if(val.runscope==1){ |
||||
|
val.runscope = val.runscope!=0?val.runscope:1 |
||||
|
return true |
||||
|
} |
||||
|
break; |
||||
|
default: |
||||
|
if(!val.operator){ |
||||
|
val.runscope = val.runscope!=0?val.runscope:1 |
||||
|
return true |
||||
|
}else if(val.operator.length < 1){ |
||||
|
val.runscope = val.runscope!=0?val.runscope:1 |
||||
|
return true |
||||
|
} |
||||
|
return false |
||||
|
} |
||||
|
|
||||
|
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 |
||||
|
} |
||||
|
|
||||
|
// console.log("PresetPersonnel.value--------1-------->",val) |
||||
|
// console.log("PresetPersonnel.value--------2-------->",val.pendpers) |
||||
|
// console.log("PresetPersonnel.value--------3-------->",val.operator) |
||||
|
// console.log("PresetPersonnel.value--------4-------->",selectedPeople.value) |
||||
|
} |
||||
|
//更新节点操作人 |
||||
|
const updateNode = (val:any) =>{ |
||||
|
// console.log("P更新节点操作人",zhiXingStep,val) |
||||
|
flowList.value.forEach((item:any) =>{ |
||||
|
if(item.step == zhiXingStep){ |
||||
|
// console.log("P更新节点操作人---1-->",item.step , zhiXingStep) |
||||
|
item.operator = val |
||||
|
} |
||||
|
}) |
||||
|
// console.log("P更新节点操作人--2--->",flowList) |
||||
|
} |
||||
|
</script> |
||||
|
<template> |
||||
|
<div> |
||||
|
<el-steps direction="vertical" :active="props.currentProgress"> |
||||
|
<el-step v-for="item in flowList" :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="judgeAddUser(item)" class="addUser" @click="addPeople(item)"> |
||||
|
<svg-icon icon-class="addxuxian" size="50" /> |
||||
|
</div> |
||||
|
|
||||
|
</td> |
||||
|
<td></td> |
||||
|
</tr> |
||||
|
</table> |
||||
|
</template> |
||||
|
</el-step> |
||||
|
</el-steps> |
||||
|
<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> |
||||
|
.logLi{ |
||||
|
color:#999999; |
||||
|
} |
||||
|
.addUser{ |
||||
|
display:block; |
||||
|
cursor:pointer; |
||||
|
} |
||||
|
</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,580 @@ |
|||||
|
<!-- |
||||
|
@ 作者: 秦东 |
||||
|
@ 时间: 2023-09-22 15:26:36 |
||||
|
@ 备注: 回显表单 |
||||
|
--> |
||||
|
<script lang='ts' setup> |
||||
|
import { ref, reactive, onMounted, computed, nextTick } from 'vue' |
||||
|
import { useRouter } from 'vue-router' |
||||
|
|
||||
|
import { notAsA_BasisForJudgment,asAnApprovalActionControl,fixedValueControl,timeControl,timeEquation } from '@/utils/workflow/const' |
||||
|
|
||||
|
import { |
||||
|
string2json, |
||||
|
stringToObj |
||||
|
} from '@/utils/DesignForm/form' |
||||
|
import { nodeFlow,conditionInfo,nodelPeoples } from '@/api/taskapi/types' |
||||
|
import { haveCustomerFormVersion,generateFlow } from '@/api/taskapi/management' |
||||
|
import { judgeSubmitCancel,startRunFlow } from '@/api/DesignForm/requestapi' |
||||
|
|
||||
|
import '@/assets/scss/element-var.scss' |
||||
|
import '@/assets/scss/index.scss' |
||||
|
import '@/assets/iconfont/iconfont.css' |
||||
|
import 'element-plus/dist/index.css' |
||||
|
|
||||
|
import FlowStep from '@/views/taskplatform/taskmanagement/flowStep.vue' |
||||
|
|
||||
|
const props = defineProps({ |
||||
|
isopen:{ |
||||
|
type:Boolean, |
||||
|
default:true |
||||
|
}, |
||||
|
versionid:{ |
||||
|
type:String, |
||||
|
default:"" |
||||
|
}, |
||||
|
versiontitle:{ |
||||
|
type:String, |
||||
|
default:"" |
||||
|
}, |
||||
|
infoid:{ |
||||
|
type:String, |
||||
|
default:"" |
||||
|
}, |
||||
|
drawerwith:{ |
||||
|
type:Number, |
||||
|
default:0 |
||||
|
} |
||||
|
}) |
||||
|
const submitButton = { |
||||
|
type: "div", |
||||
|
control: |
||||
|
{}, |
||||
|
config: |
||||
|
{ |
||||
|
textAlign: "center", |
||||
|
span: "" |
||||
|
}, |
||||
|
list: [ |
||||
|
{ |
||||
|
type: "button", |
||||
|
control: |
||||
|
{ |
||||
|
label: "保存", |
||||
|
type: "primary", |
||||
|
key: "submit" |
||||
|
}, |
||||
|
config: |
||||
|
{ |
||||
|
textAlign: "center" |
||||
|
} |
||||
|
}] |
||||
|
} |
||||
|
|
||||
|
const formLoading = ref(false) |
||||
|
const flowLoading = ref(false) |
||||
|
|
||||
|
const flowOpinion = ref(false); //审批窗口 |
||||
|
const isFlowForm = ref(false) |
||||
|
const loadingData = ref(false) |
||||
|
const formEl = ref() |
||||
|
const router = useRouter() |
||||
|
const state = reactive<any>({ |
||||
|
type: 1, // 1新增;2修改;3查看(表单模式) ;4查看; 5设计 |
||||
|
formData: { |
||||
|
list: [], |
||||
|
form: {}, |
||||
|
config: {} |
||||
|
}, |
||||
|
dict: {}, |
||||
|
formId: props.versionid, |
||||
|
id: 0, |
||||
|
loading: true |
||||
|
}) |
||||
|
|
||||
|
|
||||
|
|
||||
|
//获取工作流条件 |
||||
|
const gainFlowChart = reactive<nodeFlow>({ |
||||
|
id:0 |
||||
|
}) |
||||
|
const flowFactor = reactive<conditionInfo[]>([]) //表单组件 |
||||
|
const nodelUserList = reactive<nodelPeoples[]>([]) |
||||
|
//工作流数据 |
||||
|
const flowMap = ref<any[]>(); |
||||
|
const nextStep = ref<number>(0); |
||||
|
const currentProgress = ref<number>(1); |
||||
|
const nodeKey = ref<string>(''); |
||||
|
const formType = computed(() => { |
||||
|
// 带有参数id为编辑状态 |
||||
|
if (props.infoid) { |
||||
|
return 2 |
||||
|
} else { |
||||
|
return 1 |
||||
|
} |
||||
|
}) |
||||
|
|
||||
|
const emits = defineEmits(["update:isopen","searchquery"]); |
||||
|
const drawerOpenOrClose = computed({ |
||||
|
get: () => props.isopen, |
||||
|
set: (val) => { |
||||
|
emits("update:isopen", val); |
||||
|
}, |
||||
|
}); |
||||
|
|
||||
|
//获取表单数据 |
||||
|
const getTaskFormData = () =>{ |
||||
|
loadingData.value = true; |
||||
|
formLoading.value = true; |
||||
|
formLoading.value = true; |
||||
|
haveCustomerFormVersion({id:props.versionid}) |
||||
|
.then(({ data }) =>{ |
||||
|
// console.log("表单数据",data) |
||||
|
if(data.classify == 2){ |
||||
|
isFlowForm.value = true; |
||||
|
}else{ |
||||
|
isFlowForm.value = false; |
||||
|
} |
||||
|
state.id=props.versionid |
||||
|
state.formData = stringToObj(data.mastesform) |
||||
|
state.dict = string2json(data.dict) |
||||
|
judgeSubmitCancel({"name":data.mastesformjson}) |
||||
|
.then((data:any) =>{ |
||||
|
if(data.code == 0){ |
||||
|
if (data.data == 3 || data.data == 4){ |
||||
|
state.formData.list.push(submitButton) |
||||
|
} |
||||
|
} |
||||
|
}) |
||||
|
//获取工作流不进图 |
||||
|
gainFlowChart.id=data.flowkeystr |
||||
|
generateFlow(gainFlowChart) |
||||
|
.then((data:any) =>{ |
||||
|
console.log("获取工作流不进图",data.data) |
||||
|
flowMap.value = data.data.flowList |
||||
|
console.log("获取工作流不进图--->",flowMap.value) |
||||
|
formLoading.value = false |
||||
|
}) |
||||
|
}) |
||||
|
.finally(()=>{ |
||||
|
loadingData.value = false; |
||||
|
formLoading.value = false; |
||||
|
}) |
||||
|
} |
||||
|
|
||||
|
const drawerWith = ref<number>(0); |
||||
|
onMounted(()=>{ |
||||
|
drawerWith.value = window.innerWidth - 220 |
||||
|
|
||||
|
}); |
||||
|
window.addEventListener("resize", function(){ |
||||
|
drawerWith.value = window.innerWidth -220 |
||||
|
}) |
||||
|
const beforeSubmit = (params: any) => { |
||||
|
params.formId = props.versionid |
||||
|
params.id = "" |
||||
|
// emits("update:isopen", false); |
||||
|
return params |
||||
|
} |
||||
|
const afterSubmit = (type: string,val?:any) => { |
||||
|
console.log("表单提交成功------------------>",type,val) |
||||
|
if (type === 'success') { |
||||
|
// router.go(-1) |
||||
|
if(isFlowForm.value){ |
||||
|
if(val.code == 0){ |
||||
|
if(val.data){ |
||||
|
let sendInfo ={ |
||||
|
id:val.data.uuid, |
||||
|
flowList:flowMap.value |
||||
|
} |
||||
|
startRunFlow(sendInfo) |
||||
|
.then((data:any)=>{ |
||||
|
console.log("流程提交成功--------1---------->",data) |
||||
|
}) |
||||
|
} |
||||
|
} |
||||
|
// console.log("表单提交成功--------1---------->",type,val) |
||||
|
} |
||||
|
emits("searchquery"); |
||||
|
closeAppSubmit(); |
||||
|
} |
||||
|
} |
||||
|
const closeAppSubmit = () => { |
||||
|
emits("update:isopen", false); |
||||
|
initData(); |
||||
|
} |
||||
|
const initData = () => { |
||||
|
state.formData = { |
||||
|
list: [], |
||||
|
form: {}, |
||||
|
config: {} |
||||
|
}; |
||||
|
state.dict = {}; |
||||
|
state.formId = 0; |
||||
|
state.id = 0; |
||||
|
state.loading = true; |
||||
|
let aryLen = flowFactor.length |
||||
|
if(aryLen > 0) flowFactor.splice(0,aryLen); |
||||
|
} |
||||
|
watch(()=>props.isopen,()=>{ |
||||
|
if(props.isopen){ |
||||
|
getTaskFormData(); |
||||
|
}else{ |
||||
|
initData() |
||||
|
} |
||||
|
}) |
||||
|
|
||||
|
const changeKeyVal = (key:any,val:any,type:any,attribute:any) => { |
||||
|
// console.log("改变表单值--key--->",key) |
||||
|
// console.log("改变表单值--val--->",val,Array.isArray(val)) |
||||
|
// console.log("改变表单值--type--->",type) |
||||
|
// console.log("改变表单值--attribute--->",attribute) |
||||
|
|
||||
|
// console.log("改变表单值--type-1-true->",notAsA_BasisForJudgment.indexOf(type)) |
||||
|
// if(notAsA_BasisForJudgment.indexOf(type) != -1){ |
||||
|
// console.log("改变表单值--type--true->",notAsA_BasisForJudgment.indexOf(type)) |
||||
|
// } |
||||
|
let unitsVal = val |
||||
|
let isUpdateFlowChart = false |
||||
|
//单选,多选,下拉菜单 |
||||
|
if(notAsA_BasisForJudgment.indexOf(type) === -1){ |
||||
|
let isWrite = true |
||||
|
flowFactor.forEach((item:any)=>{ |
||||
|
if(item.factorid == key){ |
||||
|
isWrite = false |
||||
|
isUpdateFlowChart = true |
||||
|
item.type=3 |
||||
|
if(type == "checkbox"){ |
||||
|
item.isCheckbox = true |
||||
|
item.answers = val.map(String) |
||||
|
}else{ |
||||
|
item.isCheckbox = false |
||||
|
item.oneanswer = val.toString() |
||||
|
} |
||||
|
} |
||||
|
}) |
||||
|
if(isWrite){ |
||||
|
if(type == "checkbox"){ |
||||
|
flowFactor.push({ |
||||
|
factorid:key, |
||||
|
type:3, |
||||
|
isCheckbox:true, |
||||
|
answers:val.map(String) |
||||
|
}) |
||||
|
}else{ |
||||
|
flowFactor.push({ |
||||
|
factorid:key, |
||||
|
type:3, |
||||
|
isCheckbox:false, |
||||
|
oneanswer:val.toString() |
||||
|
}) |
||||
|
} |
||||
|
isUpdateFlowChart = true |
||||
|
} |
||||
|
// console.log("改变表单值--flowFactor--->",flowFactor) |
||||
|
|
||||
|
} |
||||
|
// console.log("改变表单值--flowFactor--1->",unitsVal,timeControl,type) |
||||
|
//时间类空间附加判断条件 |
||||
|
if(timeControl.indexOf(type) > -1 || fixedValueControl.indexOf(type) > -1 || type == "input"){ |
||||
|
// console.log("改变表单值--flowFactor--3->",unitsVal) |
||||
|
let addNewTime = true //判断是否新增 |
||||
|
flowFactor.forEach((item:any)=>{ |
||||
|
// console.log("改变表单值--flowFactor--5->",item.type) |
||||
|
if(item.type == 2){ |
||||
|
addNewTime = false |
||||
|
// console.log("改变表单值--flowFactor--5====1->",item.type) |
||||
|
// console.log("改变表单值--flowFactor--5====3->",item.customFields,item.customFields.length) |
||||
|
if(item.customFields && item.customFields.length > 0){ |
||||
|
// console.log("改变表单值--flowFactor--5====2->",item.customFields) |
||||
|
let sunNewAdd = true |
||||
|
item.customFields.forEach((sunItem:any)=>{ |
||||
|
// console.log("改变表单值--flowFactor-4->",sunItem.wordfield , key,sunItem.wordfield == key) |
||||
|
if(sunItem.wordfield == key){ |
||||
|
sunNewAdd = false |
||||
|
isUpdateFlowChart = true |
||||
|
if(timeEquation.indexOf(attribute) === -1){ //非区间性时间 |
||||
|
sunItem.leftval = val.toString() |
||||
|
}else{ //区间性时间 |
||||
|
if(Array.isArray(val)){ |
||||
|
if(val.length >= 2){ |
||||
|
sunItem.leftval = val[0].toString() |
||||
|
sunItem.rightval = val[val.length - 1].toString() |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
}) |
||||
|
if(sunNewAdd){ |
||||
|
isUpdateFlowChart = true |
||||
|
if(timeEquation.indexOf(attribute) === -1){//非区间性时间 |
||||
|
let customFieldInfo = { |
||||
|
wordfield: key, |
||||
|
optType: "1", |
||||
|
leftval: val.toString() |
||||
|
} |
||||
|
item.customFields.push(customFieldInfo) |
||||
|
}else{ //区间性时间 |
||||
|
if(Array.isArray(val)){ |
||||
|
if(val.length >= 2){ |
||||
|
let customFieldInfo = { |
||||
|
wordfield: key, |
||||
|
optType: "6", |
||||
|
leftval: val[0].toString(), |
||||
|
leftoptType:"3", |
||||
|
rightoptType:"3", |
||||
|
rightval:val[val.length - 1].toString() |
||||
|
} |
||||
|
item.customFields.push(customFieldInfo) |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
}) |
||||
|
|
||||
|
if(addNewTime){ //新增自定义类数据判断 |
||||
|
isUpdateFlowChart = true |
||||
|
if(timeEquation.indexOf(attribute) === -1){ //非区间性时间 |
||||
|
let customFieldInfo = { |
||||
|
wordfield: key, |
||||
|
optType: "1", |
||||
|
leftval: val.toString() |
||||
|
} |
||||
|
let condInfo = { |
||||
|
factorid:"customFields", |
||||
|
type:2, |
||||
|
isCheckbox:false, |
||||
|
customFields:[customFieldInfo] |
||||
|
} |
||||
|
flowFactor.push(condInfo) |
||||
|
}else{ //区间性时间 |
||||
|
if(Array.isArray(val)){ |
||||
|
|
||||
|
if(val.length >= 2){ |
||||
|
let customFieldInfo = { |
||||
|
wordfield: key, |
||||
|
optType: "6", |
||||
|
leftval: val[0].toString(), |
||||
|
leftoptType:"3", |
||||
|
rightoptType:"3", |
||||
|
rightval:val[val.length - 1].toString() |
||||
|
} |
||||
|
let condInfo = { |
||||
|
factorid:"customFields", |
||||
|
type:2, |
||||
|
isCheckbox:false, |
||||
|
customFields:[customFieldInfo] |
||||
|
} |
||||
|
flowFactor.push(condInfo) |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
} |
||||
|
} |
||||
|
//操作人 |
||||
|
if(asAnApprovalActionControl.indexOf(type) > -1){ |
||||
|
isUpdateFlowChart = true |
||||
|
let isWriteUs = true |
||||
|
nodelUserList.forEach((item:any)=>{ |
||||
|
if(item.factorid == key){ |
||||
|
isWriteUs = false |
||||
|
item.userList = val |
||||
|
} |
||||
|
}) |
||||
|
if(isWriteUs){ |
||||
|
nodelUserList.push({ |
||||
|
factorid:key, |
||||
|
userList:val |
||||
|
}) |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
// console.log("改变表单值--flowFactor--->",flowFactor) |
||||
|
//更新工作流图 |
||||
|
if(isUpdateFlowChart){ |
||||
|
flowLoading.value = true |
||||
|
//获取工作流不进图 |
||||
|
gainFlowChart.conditionList=flowFactor |
||||
|
gainFlowChart.nodelPeople=nodelUserList |
||||
|
// console.log("获取工作流不进图--gainFlowChart--->",gainFlowChart) |
||||
|
generateFlow(gainFlowChart) |
||||
|
.then((data:any) =>{ |
||||
|
// console.log("获取工作流不进图-new-->",data) |
||||
|
flowMap.value = data.data.flowList |
||||
|
nextStep.value = data.data.nextStep; |
||||
|
currentProgress.value = data.data.Step; |
||||
|
nodeKey.value = data.data.nodeKey; |
||||
|
// console.log("获取工作流不进图-1-->",flowMap.value) |
||||
|
flowLoading.value = false |
||||
|
}) |
||||
|
} |
||||
|
} |
||||
|
watch(()=>flowMap,(val:any)=>{ |
||||
|
// console.log("工作流在变化-->",flowMap.value) |
||||
|
}) |
||||
|
const sendFlowInfo = ref<any>() |
||||
|
</script> |
||||
|
<template> |
||||
|
<el-drawer v-model="drawerOpenOrClose" v-loading="loadingData" :title="versiontitle" :close-on-click-modal="false" :close-on-press-escape="false" :destroy-on-close="true" :size="props.drawerwith" class="drawerClass" > |
||||
|
<table border="0" v-if="isFlowForm" class="tableFlowBox"> |
||||
|
<tr> |
||||
|
<td valign="top"> |
||||
|
<div class="drawerFormBox boxLeft"> |
||||
|
<ak-form |
||||
|
v-loading="formLoading" element-loading-text="Loading..." |
||||
|
ref="formEl" |
||||
|
:form-data="state.formData" |
||||
|
:type="formType" |
||||
|
:dict="state.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"> |
||||
|
<div v-loading="flowLoading" element-loading-text="Loading..." class="drawerFormBox boxRight"> |
||||
|
<div class="flowBox"> |
||||
|
<el-affix :offset="20"> |
||||
|
<el-text size="large">审批流程</el-text> |
||||
|
</el-affix> |
||||
|
<FlowStep v-model:flow-map="flowMap" :next-step="nextStep" :current-progress="currentProgress" :node-key="nodeKey" /> |
||||
|
</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%">同意</el-button></el-col> |
||||
|
<el-col :span="8" class="juzhong"><el-button type="danger" style="width:100%">驳回</el-button></el-col> |
||||
|
<el-col :span="4"></el-col> |
||||
|
</el-row> |
||||
|
</div> |
||||
|
</el-affix> |
||||
|
</div> |
||||
|
|
||||
|
</td> |
||||
|
</tr> |
||||
|
</table> |
||||
|
<!--无流程表单--> |
||||
|
<div v-else class="drawerBody"> |
||||
|
<ak-form |
||||
|
ref="formEl" |
||||
|
:form-data="state.formData" |
||||
|
:type="formType" |
||||
|
:dict="state.dict" |
||||
|
request-url="getFormContent" |
||||
|
add-url="saveFormContent" |
||||
|
edit-url="editFormContent" |
||||
|
:before-submit="beforeSubmit" |
||||
|
:after-submit="afterSubmit" |
||||
|
:close-app-submit="closeAppSubmit" |
||||
|
|
||||
|
/> |
||||
|
</div> |
||||
|
</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> |
||||
|
<style> |
||||
|
.demo-tabs > .el-tabs__content { |
||||
|
padding: 0px 20px 20px 20px; |
||||
|
overflow: hidden; |
||||
|
overflow-y: auto; |
||||
|
} |
||||
|
.el-tabs--right .el-tabs__content, |
||||
|
.el-tabs--left .el-tabs__content { |
||||
|
height: 100%; |
||||
|
|
||||
|
} |
||||
|
</style> |
||||
|
<style scoped> |
||||
|
.affix-container { |
||||
|
text-align: center; |
||||
|
height: 400px; |
||||
|
border-radius: 4px; |
||||
|
background: var(--el-color-primary-light-9); |
||||
|
} |
||||
|
</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> |
||||