|
|
|
|
@@ -6,7 +6,8 @@
|
|
|
|
|
<component :is="headerIcon"/>
|
|
|
|
|
</el-icon>
|
|
|
|
|
<ellipsis class="name" hover-tip :content="title"/>
|
|
|
|
|
<el-icon v-if="!isRoot && designState" size="20" style="float:right;cursor: pointer" @click.stop="emit('delNode')">
|
|
|
|
|
<el-icon v-if="!isRoot && designState" size="20" style="float:right;cursor: pointer"
|
|
|
|
|
@click.stop="emit('delNode')">
|
|
|
|
|
<Close/>
|
|
|
|
|
</el-icon>
|
|
|
|
|
</div>
|
|
|
|
|
@@ -22,10 +23,14 @@
|
|
|
|
|
</template>
|
|
|
|
|
<template v-else-if="showAvatar">
|
|
|
|
|
<span class="placeholder" v-if="userInfo.length === 0">{{ placeholder }}</span>
|
|
|
|
|
<div v-else v-for="item in userInfo" class="circle-user">
|
|
|
|
|
<span >{{item.name}}</span>
|
|
|
|
|
<div v-else v-for="item in userInfo" class="circle-user">
|
|
|
|
|
<span>{{ item.name }}</span>
|
|
|
|
|
<el-button v-if="item.state==='RUNNING'" type="warning" loading circle class="circle-icon"></el-button>
|
|
|
|
|
<el-button v-else-if="item.state==='UNACTIVATED'" type="info" :icon="More" circle
|
|
|
|
|
class="circle-icon"></el-button>
|
|
|
|
|
<el-button v-else type="success" :icon="Check" circle class="circle-icon"></el-button>
|
|
|
|
|
</div>
|
|
|
|
|
<!-- <avatar-ellipsis :row="3" :user-info="userInfo"/>-->
|
|
|
|
|
<!-- <avatar-ellipsis :row="3" :user-info="userInfo"/>-->
|
|
|
|
|
</template>
|
|
|
|
|
<template v-else>
|
|
|
|
|
<span class="placeholder" v-if="(content || '').trim() === ''">{{ placeholder }}</span>
|
|
|
|
|
@@ -43,9 +48,9 @@
|
|
|
|
|
<div class="node-footer">
|
|
|
|
|
<div v-if="merge" class="branch-merge">
|
|
|
|
|
<svg-icon name="fenzhi" :class-name="'fen-icon'"/>
|
|
|
|
|
<!-- <img data-v-1e7b1da5=""-->
|
|
|
|
|
<!-- src=""-->
|
|
|
|
|
<!-- alt="">-->
|
|
|
|
|
<!-- <img data-v-1e7b1da5=""-->
|
|
|
|
|
<!-- src=""-->
|
|
|
|
|
<!-- alt="">-->
|
|
|
|
|
</div>
|
|
|
|
|
<div class="btn">
|
|
|
|
|
<insert-button v-if="designState" @insertNode="type => emit('insertNode', type)"/>
|
|
|
|
|
@@ -62,7 +67,7 @@ import InsertButton from '../common/InsertButton.vue'
|
|
|
|
|
import Ellipsis from '../common/Ellipsis.vue'
|
|
|
|
|
import AvatarEllipsis from '../common/AvatarEllipsis.vue'
|
|
|
|
|
import SvgIcon from '@/components/svgIcon/index.vue'
|
|
|
|
|
import {Close, Warning, Plus} from '@element-plus/icons-vue'
|
|
|
|
|
import {Close, Warning, Plus, Check, More} from '@element-plus/icons-vue'
|
|
|
|
|
|
|
|
|
|
const emit = defineEmits(['insertNode'])
|
|
|
|
|
const props = defineProps({
|
|
|
|
|
@@ -154,7 +159,16 @@ const props = defineProps({
|
|
|
|
|
const designState = computed(() => {
|
|
|
|
|
return props.mode === 'design'
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
const getState = (state) => {
|
|
|
|
|
switch (state) {
|
|
|
|
|
case 'finish':
|
|
|
|
|
return 'check'
|
|
|
|
|
case 'UNACTIVATED':
|
|
|
|
|
return 'more'
|
|
|
|
|
case 'RUNNING':
|
|
|
|
|
return 'loading'
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const init = () => {
|
|
|
|
|
// let userInfo = this.$store.state.selectUserMap.get(this.nodeId);
|
|
|
|
|
@@ -176,7 +190,7 @@ const init = () => {
|
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
<style lang="scss" scoped>
|
|
|
|
|
.circle-user{
|
|
|
|
|
.circle-user {
|
|
|
|
|
width: 50px;
|
|
|
|
|
height: 50px;
|
|
|
|
|
display: flex;
|
|
|
|
|
@@ -184,7 +198,18 @@ const init = () => {
|
|
|
|
|
align-items: center;
|
|
|
|
|
border-radius: 50%;
|
|
|
|
|
border: 1px solid #ACACAC;
|
|
|
|
|
position: relative;
|
|
|
|
|
|
|
|
|
|
.circle-icon {
|
|
|
|
|
width: 10px;
|
|
|
|
|
height: 10px;
|
|
|
|
|
position: absolute;
|
|
|
|
|
top: auto !important;
|
|
|
|
|
bottom: -9px;
|
|
|
|
|
right: 15px !important;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.root {
|
|
|
|
|
&:before {
|
|
|
|
|
display: none !important;
|
|
|
|
|
|