Bläddra i källkod

feat: 触发器 页面100%

luoyali 1 år sedan
förälder
incheckning
667c80b83f

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

@@ -18,6 +18,9 @@
 	<!-- 延时处理 -->
 	<delay-process v-if="nodeConfig.type == 6" v-model="nodeConfig" :disabled="disabled"></delay-process>
 
+	<!-- 触发器 -->
+	<trigger v-if="nodeConfig.type == 7" v-model="nodeConfig" :disabled="disabled"></trigger>
+
 	<node-wrap v-if="nodeConfig.childNode" v-model="nodeConfig.childNode" :disabled="disabled"></node-wrap>
 </template>
 
@@ -27,6 +30,7 @@ import promoter from './nodes/promoter'
 import branch from './nodes/branch'
 import send from './nodes/send'
 import delayProcess from './nodes/delayProcess'
+import trigger from './nodes/trigger'
 
 export default {
 	components: {
@@ -34,7 +38,8 @@ export default {
 		promoter,
 		branch,
 		send,
-		delayProcess
+		delayProcess,
+		trigger
 	},
 	props: {
 		modelValue: { type: Object, default: () => {} },

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

@@ -108,6 +108,19 @@ export default {
 						time: '0:m'
 					}
 				}
+			} else if (type == 7) {
+				node = {
+					nodeName: '触发器',
+					type: 7,
+					delayType: '1', // 延时类型
+					triggerType: '1', // 触发器类型: 立即执行('1') 延时执行('2')
+					// 一小时后触发 {"time": "1:h"} 单位【 d 天 h 时 m 分 】 发起后一小时三十分后触发 {"time": "01:30:00"}
+					extendConfig: {
+						time: '', // 立即执行 time不用设置
+						args: '',
+						trigger: ''
+					}
+				}
 			}
 			this.$emit('update:modelValue', node)
 		}

+ 197 - 0
src/components/scWorkflow/nodes/trigger.vue

@@ -0,0 +1,197 @@
+<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-success)">
+				<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-radio-group v-model="form.triggerType" style="margin-bottom: 15px;">
+						<el-radio value="1">立即执行</el-radio>
+						<el-radio value="2">延迟执行</el-radio>
+					</el-radio-group>
+					<el-form label-position="top">
+						<template v-if="form.triggerType === '2'">
+							<el-form-item label="">
+								<el-radio-group v-model="form.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="form.delayType === '1'">
+								<el-input v-model="fixedDuration" style="max-width: 300px" type="number" min="0" class="input-with-select">
+									<template #append>
+										<el-select v-model="fixedDurationType" style="width: 115px">
+											<el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value"></el-option>
+										</el-select>
+									</template> </el-input
+								><span>后进入下一步</span>
+							</el-form-item>
+
+							<el-form-item v-if="form.delayType === '2'">
+								<el-time-picker v-model="automaticComputed" placeholder="时间点" value-format="HH:mm:ss" />
+								<span>后进入下一步</span>
+							</el-form-item>
+						</template>
+						<el-form-item label="">
+							<el-input v-model="form.extendConfig.args" :rows="5" type="textarea" placeholder="请输入执行参数(json格式)" />
+						</el-form-item>
+
+						<el-form-item label="">
+							<el-input
+								v-model="form.extendConfig.trigger"
+								placeholder="接口 TaskTrigger 实现
+ class 如果不配置,调用全局实现子类"
+							/>
+						</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'
+const mapTip = {
+	d: '天',
+	h: '小时',
+	m: '分钟'
+}
+export default {
+	components: {
+		addNode
+	},
+	props: {
+		modelValue: { type: Object, default: () => {} },
+		disabled: {
+			type: Boolean,
+			default: false
+		}
+	},
+	data() {
+		return {
+			nodeConfig: {},
+			drawer: false,
+			isEditTitle: false,
+			form: {},
+			options: [
+				{ label: '天', value: 'd' },
+				{ label: '小时', value: 'h' },
+				{ label: '分钟', value: 'm' }
+			],
+			// 固定时长 start
+			fixedDuration: 0,
+			fixedDurationType: 'm',
+			selectedLabel: '分钟',
+			// 固定时长 end
+
+			// 自动计算 start
+			automaticComputed: '',
+			// 自动计算 end
+			delayProcessSelfOptions,
+		}
+	},
+	watch: {
+		modelValue() {
+			this.nodeConfig = this.modelValue
+		}
+	},
+	mounted() {
+		this.nodeConfig = this.modelValue
+		const extendConfig = this.nodeConfig.extendConfig.time.split(':')
+		if (this.nodeConfig.delayType === '1') {
+			this.fixedDuration = extendConfig[0]
+			this.fixedDurationType = extendConfig[1]
+		}
+
+		if (this.form.delayType === '2') {
+			this.automaticComputed = this.nodeConfig.extendConfig.time
+		}
+	},
+	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.form.extendConfig = {
+				time: this.form.delayType === '1' ? `${this.fixedDuration}:${this.fixedDurationType}` : `${this.automaticComputed}`
+			}
+			this.$emit('update:modelValue', this.form)
+			this.drawer = false
+		},
+		delNode() {
+			this.$emit('update:modelValue', this.nodeConfig.childNode)
+		},
+		toText(nodeConfig) {
+			return false
+			// if (nodeConfig.delayType === '1') {
+			// 	return `等待${this.fixedDuration}${mapTip[this.fixedDurationType]}`
+			// } else if (nodeConfig.delayType === '2') {
+			// 	this.automaticComputed = this.nodeConfig.extendConfig.time
+			// 	return !this.automaticComputed ? `至当天` : `至当天${this.automaticComputed}`
+			// } else {
+			// 	return false
+			// }
+		}
+	}
+}
+</script>
+
+<style></style>