From d1c199d4bf895e3a1c8ecfbb1414c44c4a0fc718 Mon Sep 17 00:00:00 2001 From: LiuHao <liuhaoai545@gmail.com> Date: 星期五, 08 三月 2024 18:22:28 +0800 Subject: [PATCH] update 优化流程预览 --- src/components/Process/approvalRecord.vue | 176 ++++++++++++++++++++++++++++++++-------------------------- 1 files changed, 96 insertions(+), 80 deletions(-) diff --git a/src/components/Process/approvalRecord.vue b/src/components/Process/approvalRecord.vue index 2c43dc5..88dccf2 100644 --- a/src/components/Process/approvalRecord.vue +++ b/src/components/Process/approvalRecord.vue @@ -1,86 +1,90 @@ <template> - <el-dialog v-model="visible" draggable title="瀹℃壒璁板綍" :width="props.width" :height="props.height" append-to-body :close-on-click-modal="false"> - <el-tabs v-model="tabActiveName" class="demo-tabs"> - <el-tab-pane label="娴佺▼鍥�" name="bpmn"> - <div v-loading="loading"> - <div style="width: 100%; height: 300px; overflow: auto; position: relative"> - <div - v-for="(graphic, index) in graphicInfoVos" - :key="index" - :style="{ - position: 'absolute', - left: `${graphic.x}px`, - top: `${graphic.y}px`, - width: `${graphic.width}px`, - height: `${graphic.height}px`, - cursor: 'pointer', - zIndex: 99 - }" - @mouseover="handleMouseOver(graphic)" - @mouseleave="handleMouseLeave()" - ></div> - <!-- 寮瑰嚭鐨� div 鍏冪礌 --> - <div - v-show="popupVisible" - class="triangle" - :style="{ - position: 'absolute', - left: `${graphicX}px`, - top: `${graphicY}px`, - backgroundColor: '#fff', - padding: '10px', - zIndex: 100 - }" - > - <p>瀹℃壒浜哄憳: {{ nodeInfo.nickName }}</p> - <p>鑺傜偣鐘舵�侊細{{ nodeInfo.status }}</p> - <p>寮�濮嬫椂闂达細{{ nodeInfo.startTime }}</p> - <p>缁撴潫鏃堕棿锛歿{ nodeInfo.endTime }}</p> - <p>瀹℃壒鑰楁椂锛歿{ nodeInfo.runDuration }}</p> - </div> - <el-image :src="src" /> + <div class="container"> + <el-dialog v-model="visible" draggable title="瀹℃壒璁板綍" :width="props.width" :height="props.height" :close-on-click-modal="false"> + <el-tabs v-model="tabActiveName" class="demo-tabs"> + <el-tab-pane label="娴佺▼鍥�" name="bpmn"> + <!-- <div v-loading="loading">--> + <!-- <div style="width: 100%; height: 300px; overflow: auto; position: relative">--> + <!-- <div--> + <!-- v-for="(graphic, index) in graphicInfoVos"--> + <!-- :key="index"--> + <!-- :style="{--> + <!-- position: 'absolute',--> + <!-- left: `${graphic.x}px`,--> + <!-- top: `${graphic.y}px`,--> + <!-- width: `${graphic.width}px`,--> + <!-- height: `${graphic.height}px`,--> + <!-- cursor: 'pointer',--> + <!-- zIndex: 99--> + <!-- }"--> + <!-- @mouseover="handleMouseOver(graphic)"--> + <!-- @mouseleave="handleMouseLeave()"--> + <!-- ></div>--> + <!-- <!– 寮瑰嚭鐨� div 鍏冪礌 –>--> + <!-- <div--> + <!-- v-show="popupVisible"--> + <!-- class="triangle"--> + <!-- :style="{--> + <!-- position: 'absolute',--> + <!-- left: `${graphicX}px`,--> + <!-- top: `${graphicY}px`,--> + <!-- backgroundColor: '#fff',--> + <!-- padding: '10px',--> + <!-- zIndex: 100--> + <!-- }"--> + <!-- >--> + <!-- <p>瀹℃壒浜哄憳: {{ nodeInfo.nickName }}</p>--> + <!-- <p>鑺傜偣鐘舵�侊細{{ nodeInfo.status }}</p>--> + <!-- <p>寮�濮嬫椂闂达細{{ nodeInfo.startTime }}</p>--> + <!-- <p>缁撴潫鏃堕棿锛歿{ nodeInfo.endTime }}</p>--> + <!-- <p>瀹℃壒鑰楁椂锛歿{ nodeInfo.runDuration }}</p>--> + <!-- </div>--> + <!-- <el-image :src="src" />--> + <!-- </div>--> + <!-- </div>--> + <BpmnView ref="bpmnViewRef"></BpmnView> + </el-tab-pane> + <el-tab-pane label="瀹℃壒淇℃伅" name="info"> + <div> + <el-table :data="historyList" style="width: 100%" border fit max-height="570"> + <el-table-column type="index" label="搴忓彿" align="center" width="50"></el-table-column> + <el-table-column prop="name" label="浠诲姟鍚嶇О" sortable align="center"></el-table-column> + <el-table-column prop="nickName" label="鍔炵悊浜�" sortable align="center"></el-table-column> + <el-table-column label="鐘舵��" sortable align="center"> + <template #default="scope"> + <el-tag type="success">{{ scope.row.statusName }}</el-tag> + </template> + </el-table-column> + <el-table-column prop="comment" label="瀹℃壒鎰忚" sortable align="center"></el-table-column> + <el-table-column prop="attachmentList" label="闄勪欢" sortable align="center"> + <template #default="scope"> + <el-popover v-if="scope.row.attachmentList && scope.row.attachmentList.length > 0" placement="right" :width="310" trigger="click"> + <template #reference> + <el-button style="margin-right: 16px">闄勪欢</el-button> + </template> + <el-table border :data="scope.row.attachmentList"> + <el-table-column prop="name" width="202" :show-overflow-tooltip="true" label="闄勪欢鍚嶇О"></el-table-column> + <el-table-column prop="name" width="80" align="center" :show-overflow-tooltip="true" label="鎿嶄綔"> + <template #default="tool"> + <el-button type="text" @click="handleDownload(tool.row.contentId)">涓嬭浇</el-button> + </template> + </el-table-column> + </el-table> + </el-popover> + </template> + </el-table-column> + <el-table-column prop="startTime" label="寮�濮嬫椂闂�" sortable align="center"></el-table-column> + <el-table-column prop="endTime" label="缁撴潫鏃堕棿" sortable align="center"></el-table-column> + <el-table-column prop="runDuration" label="杩愯鏃堕暱" sortable align="center"></el-table-column> + </el-table> </div> - </div> - </el-tab-pane> - <el-tab-pane label="瀹℃壒淇℃伅" name="info"> - <div> - <el-table :data="historyList" style="width: 100%" border fit max-height="570"> - <el-table-column type="index" label="搴忓彿" align="center" width="50"></el-table-column> - <el-table-column prop="name" label="浠诲姟鍚嶇О" sortable align="center"></el-table-column> - <el-table-column prop="nickName" label="鍔炵悊浜�" sortable align="center"></el-table-column> - <el-table-column label="鐘舵��" sortable align="center"> - <template #default="scope"> - <el-tag type="success">{{ scope.row.statusName }}</el-tag> - </template> - </el-table-column> - <el-table-column prop="comment" label="瀹℃壒鎰忚" sortable align="center"></el-table-column> - <el-table-column prop="attachmentList" label="闄勪欢" sortable align="center"> - <template #default="scope"> - <el-popover v-if="scope.row.attachmentList && scope.row.attachmentList.length > 0" placement="right" :width="310" trigger="click"> - <template #reference> - <el-button style="margin-right: 16px">闄勪欢</el-button> - </template> - <el-table border :data="scope.row.attachmentList"> - <el-table-column prop="name" width="202" :show-overflow-tooltip="true" label="闄勪欢鍚嶇О"></el-table-column> - <el-table-column prop="name" width="80" align="center" :show-overflow-tooltip="true" label="鎿嶄綔"> - <template #default="tool"> - <el-button type="text" @click="handleDownload(tool.row.contentId)">涓嬭浇</el-button> - </template> - </el-table-column> - </el-table> - </el-popover> - </template> - </el-table-column> - <el-table-column prop="startTime" label="寮�濮嬫椂闂�" sortable align="center"></el-table-column> - <el-table-column prop="endTime" label="缁撴潫鏃堕棿" sortable align="center"></el-table-column> - <el-table-column prop="runDuration" label="杩愯鏃堕暱" sortable align="center"></el-table-column> - </el-table> - </div> - </el-tab-pane> - </el-tabs> - </el-dialog> + </el-tab-pane> + </el-tabs> + </el-dialog> + </div> </template> <script lang="ts" setup> +import BpmnView from '@/components/BpmnView/index.vue'; import processApi from '@/api/workflow/processInstance'; import { propTypes } from '@/utils/propTypes'; @@ -111,6 +115,8 @@ const graphicY = ref<number | string>(0); const tabActiveName = ref('bpmn'); +const bpmnViewRef = ref<BpmnView>(); + //鍒濆鍖栨煡璇㈠鎵硅褰� const init = async (instanceId: string) => { visible.value = true; @@ -126,6 +132,9 @@ nodeListInfo.value = resp.data.nodeListInfo; deleteReason.value = resp.data.deleteReason; loading.value = false; + }); + await nextTick(() => { + bpmnViewRef.value.init(instanceId); }); }; //鎮诞浜嬩欢 @@ -163,7 +172,7 @@ init }); </script> -<style scoped> +<style lang="scss" scoped> .triangle { box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3); border-radius: 6px; @@ -177,4 +186,11 @@ border: 15px solid; border-color: transparent #fff transparent transparent; } + +.container { + :deep(.el-dialog .el-dialog__body) { + max-height: calc(100vh - 300px) !important; + min-height: calc(100vh - 300px) !important; + } +} </style> -- Gitblit v1.9.3