Selaa lähdekoodia

feat: 延时处理 50%

luoyali 1 vuosi sitten
vanhempi
sitoutus
01b9cc3142

+ 10 - 1
src/components/scWorkflow/nodeWrap.vue

@@ -1,16 +1,23 @@
 <template>
+	<!-- 发起人 -->
 	<promoter v-if="nodeConfig.type == 0" v-model="nodeConfig" :disabled="disabled"></promoter>
 
+	<!-- 审批人 -->
 	<approver v-if="nodeConfig.type == 1" v-model="nodeConfig" :disabled="disabled"></approver>
 
+	<!-- 抄送人 -->
 	<send v-if="nodeConfig.type == 2" v-model="nodeConfig" :disabled="disabled"></send>
 
+	<!-- 分支 -->
 	<branch v-if="nodeConfig.type == 4" v-model="nodeConfig" :disabled="disabled">
 		<template #default="slot">
 			<node-wrap v-if="slot.node" v-model="slot.node.childNode" :disabled="disabled"></node-wrap>
 		</template>
 	</branch>
 
+	<!-- 延时处理 -->
+	<delay-process v-if="nodeConfig.type == 5" v-model="nodeConfig" :disabled="disabled"></delay-process>
+
 	<node-wrap v-if="nodeConfig.childNode" v-model="nodeConfig.childNode" :disabled="disabled"></node-wrap>
 </template>
 
@@ -19,13 +26,15 @@ import approver from './nodes/approver'
 import promoter from './nodes/promoter'
 import branch from './nodes/branch'
 import send from './nodes/send'
+import delayProcess from './nodes/delayProcess'
 
 export default {
 	components: {
 		approver,
 		promoter,
 		branch,
-		send
+		send,
+		delayProcess
 	},
 	props: {
 		modelValue: { type: Object, default: () => {} },

+ 17 - 0
src/components/scWorkflow/nodes/addNode.vue

@@ -19,6 +19,14 @@
 							<el-icon style="color: var(--el-color-success)" @click="addType(4)"><share /></el-icon>
 							<p>条件分支</p>
 						</li>
+						<li>
+							<el-icon style="color: var(--el-color-danger)" @click="addType(5)"><Clock /></el-icon>
+							<p>延迟等待</p>
+						</li>
+						<li>
+							<el-icon style="color: var(--el-color-success)" @click="addType(6)"><SetUp /></el-icon>
+							<p>触发器</p>
+						</li>
 					</ul>
 				</div>
 			</el-popover>
@@ -90,6 +98,15 @@ export default {
 					],
 					childNode: this.modelValue
 				}
+			} else if (type == 5) {
+				node = {
+					nodeName: '延时处理',
+					type: 5,
+					delayType: '1',
+					automaticComputed: '', // 自动计算
+					fixedDuration: 0, // 固定时长
+					fixedDurationType: '3' // 固定时长
+				}
 			}
 			this.$emit('update:modelValue', node)
 		}

+ 12 - 0
src/components/scWorkflow/nodes/config.ts

@@ -128,6 +128,18 @@ export const approveSelfOptions = [
 	}
 ]
 
+// 延时处理
+export const delayProcessSelfOptions = [
+	{
+		label: '固定时长',
+		value: '1'
+	},
+	{
+		label: '自动计算',
+		value: '2'
+	}
+]
+
 // export const approveSelfOptions_config = approveSelfOptions.reduce((res: { [key: string]: any }, { label, value }) => {
 // 	res[value] = label
 // 	return res

+ 169 - 0
src/components/scWorkflow/nodes/delayProcess.vue

@@ -0,0 +1,169 @@
+<template>
+	<div class="node-wrap">
+		<!-- 节点显示 start -->
+		<div class="node-wrap-box" :class="[disabled ? 'node-wrap-box--disabled' : '', `node-wrap-box--${nodeConfig.local_status}`]">
+			<div class="title" style="background: var(--el-color-danger)">
+				<el-icon class="icon"><Clock /></el-icon>
+				<span v-show="!isEditTitle" class="title_label" @click="editTitle('box_nodeTitle')"
+					>{{ nodeConfig.nodeName }}<el-icon v-if="!disabled" class="edit-icon"><edit /></el-icon
+				></span>
+				<el-input
+					v-show="isEditTitle"
+					ref="box_nodeTitle"
+					v-model="nodeConfig.nodeName"
+					clearable
+					size="small"
+					@blur="saveTitle"
+					@keyup.enter="saveTitle"
+				></el-input>
+				<el-icon v-if="!disabled" class="close" @click.stop="delNode()"><close /></el-icon>
+			</div>
+			<div class="content" @click="show">
+				<span v-if="toText(nodeConfig)">{{ toText(nodeConfig) }}</span>
+				<span v-else class="placeholder">请选择人员</span>
+			</div>
+		</div>
+		<!-- 节点显示 end -->
+
+		<!-- 添加节点 start -->
+		<add-node v-model="nodeConfig.childNode" :disabled="disabled"></add-node>
+		<!-- 添加节点 end -->
+
+		<!-- 打开侧边弹窗 start -->
+		<el-drawer v-model="drawer" title="延时处理设置" destroy-on-close append-to-body :size="500" class="aDrawer">
+			<template #header>
+				<div class="node-wrap-drawer__title">
+					<label v-show="!isEditTitle" @click="editTitle('nodeTitle')"
+						>{{ form.nodeName }}<el-icon class="node-wrap-drawer__title-edit"><edit /></el-icon
+					></label>
+					<el-input v-show="isEditTitle" ref="nodeTitle" v-model="form.nodeName" clearable @blur="saveTitle" @keyup.enter="saveTitle"></el-input>
+				</div>
+			</template>
+			<el-container>
+				<el-main>
+					<el-form label-position="top">
+						<el-form-item label="延时方式">
+							<el-radio-group v-model="delayType">
+								<el-radio-button v-for="v of delayProcessSelfOptions" :key="v.value" :label="v.value">{{ v.label }}</el-radio-button>
+							</el-radio-group>
+						</el-form-item>
+
+						<el-form-item v-if="delayType === '1'" label="">
+							<el-input v-model="fixedDuration" style="max-width: 300px" placeholder="" class="input-with-select">
+								<template #append>
+									<el-select v-model="fixedDurationType" style="width: 115px">
+										<el-option label="天" value="1" />
+										<el-option label="小时" value="2" />
+										<el-option label="分钟" value="3" />
+									</el-select>
+								</template> </el-input
+							><span>后进入下一步</span>
+						</el-form-item>
+
+						<el-form-item v-if="delayType === '2'" label="">
+							<el-time-picker v-model="automaticComputed" placeholder="时间点" />
+							<span>后进入下一步</span>
+						</el-form-item>
+					</el-form>
+				</el-main>
+				<el-footer>
+					<el-button type="primary" @click="save">保存</el-button>
+					<el-button @click="drawer = false">取消</el-button>
+				</el-footer>
+			</el-container>
+		</el-drawer>
+		<!-- 打开侧边弹窗 end -->
+	</div>
+</template>
+
+<script>
+import addNode from './addNode'
+import { delayProcessSelfOptions } from './config'
+export default {
+	components: {
+		addNode
+	},
+	inject: ['select'],
+	props: {
+		modelValue: { type: Object, default: () => {} },
+		disabled: {
+			type: Boolean,
+			default: false
+		}
+	},
+	data() {
+		return {
+			// 延时类型
+			delayType: '1',
+			// 固定时长 start
+			fixedDuration: 0,
+			fixedDurationType: '3',
+			// 固定时长 end
+
+			// 自动计算 start
+			automaticComputed: '',
+			// 自动计算 end
+			delayProcessSelfOptions,
+			nodeConfig: {},
+			drawer: false,
+			isEditTitle: false,
+			form: {}
+		}
+	},
+	watch: {
+		modelValue() {
+			this.nodeConfig = this.modelValue
+		}
+	},
+	mounted() {
+		this.nodeConfig = this.modelValue
+	},
+	methods: {
+		show() {
+			if (this.disabled) return
+			this.form = {}
+			this.form = JSON.parse(JSON.stringify(this.nodeConfig))
+			this.drawer = true
+		},
+		editTitle(refName) {
+			if (this.disabled) return
+			this.isEditTitle = true
+			this.$nextTick(() => {
+				if (this.$refs[refName]) {
+					this.$refs[refName].focus()
+				}
+			})
+		},
+		saveTitle() {
+			this.isEditTitle = false
+		},
+		save() {
+			this.$emit('update:modelValue', this.form)
+			this.drawer = false
+		},
+		delNode() {
+			this.$emit('update:modelValue', this.nodeConfig.childNode)
+		},
+		delUser(index) {
+			this.form.nodeAssigneeList.splice(index, 1)
+		},
+		selectHandle(type, data) {
+			this.select(type, data)
+		},
+		toText(nodeConfig) {
+			if (nodeConfig.nodeAssigneeList && nodeConfig.nodeAssigneeList.length > 0) {
+				const users = nodeConfig.nodeAssigneeList.map(item => item.name).join('、')
+				return users
+			} else {
+				if (nodeConfig.allowSelection) {
+					return '发起人自选'
+				} else {
+					return false
+				}
+			}
+		}
+	}
+}
+</script>
+
+<style></style>