123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258 |
- <template>
- <div class="process-panel__container" :style="{ width: `${width}px`, maxHeight: '600px' }">
- <el-collapse v-model="activeTab" v-if="isReady">
- <el-collapse-item name="base">
- <!-- class="panel-tab__title" -->
- <template #title>
- <Icon icon="ep:info-filled" />
- 常规</template
- >
- <ElementBaseInfo
- :id-edit-disabled="idEditDisabled"
- :business-object="elementBusinessObject"
- :type="elementType"
- :model="model"
- />
- </el-collapse-item>
- <el-collapse-item name="condition" v-if="elementType === 'Process'" key="message">
- <template #title><Icon icon="ep:comment" />消息与信号</template>
- <signal-and-massage />
- </el-collapse-item>
- <el-collapse-item name="condition" v-if="conditionFormVisible" key="condition">
- <template #title><Icon icon="ep:promotion" />流转条件</template>
- <flow-condition :business-object="elementBusinessObject" :type="elementType" />
- </el-collapse-item>
- <el-collapse-item name="condition" v-if="formVisible" key="form">
- <template #title><Icon icon="ep:list" />表单</template>
- <element-form :id="elementId" :type="elementType" />
- </el-collapse-item>
- <el-collapse-item name="task" v-if="isTaskCollapseItemShow(elementType)" key="task">
- <template #title
- ><Icon icon="ep:checked" />{{ getTaskCollapseItemName(elementType) }}</template
- >
- <element-task :id="elementId" :type="elementType" />
- </el-collapse-item>
- <el-collapse-item
- name="multiInstance"
- v-if="elementType.indexOf('Task') !== -1"
- key="multiInstance"
- >
- <template #title><Icon icon="ep:help-filled" />多人审批方式</template>
- <element-multi-instance
- :id="elementId"
- :business-object="elementBusinessObject"
- :type="elementType"
- />
- </el-collapse-item>
- <el-collapse-item name="listeners" key="listeners">
- <template #title><Icon icon="ep:bell-filled" />执行监听器</template>
- <element-listeners :id="elementId" :type="elementType" />
- </el-collapse-item>
- <el-collapse-item name="taskListeners" v-if="elementType === 'UserTask'" key="taskListeners">
- <template #title><Icon icon="ep:bell-filled" />任务监听器</template>
- <user-task-listeners :id="elementId" :type="elementType" />
- </el-collapse-item>
- <el-collapse-item name="extensions" key="extensions">
- <template #title><Icon icon="ep:circle-plus-filled" />扩展属性</template>
- <element-properties :id="elementId" :type="elementType" />
- </el-collapse-item>
- <el-collapse-item name="other" key="other">
- <template #title><Icon icon="ep:promotion" />其他</template>
- <element-other-config :id="elementId" />
- </el-collapse-item>
- <el-collapse-item name="customConfig" key="customConfig">
- <template #title><Icon icon="ep:tools" />自定义配置</template>
- <element-custom-config
- :id="elementId"
- :type="elementType"
- :business-object="elementBusinessObject"
- />
- </el-collapse-item>
- </el-collapse>
- </div>
- </template>
- <script lang="ts" setup>
- import ElementBaseInfo from './base/ElementBaseInfo.vue'
- import ElementOtherConfig from './other/ElementOtherConfig.vue'
- import ElementTask from './task/ElementTask.vue'
- import ElementMultiInstance from './multi-instance/ElementMultiInstance.vue'
- import FlowCondition from './flow-condition/FlowCondition.vue'
- import SignalAndMassage from './signal-message/SignalAndMessage.vue'
- import ElementListeners from './listeners/ElementListeners.vue'
- import ElementProperties from './properties/ElementProperties.vue'
- // import ElementForm from './form/ElementForm.vue'
- import UserTaskListeners from './listeners/UserTaskListeners.vue'
- import { getTaskCollapseItemName, isTaskCollapseItemShow } from './task/data'
- defineOptions({ name: 'MyPropertiesPanel' })
- /**
- * 侧边栏
- * @Author MiyueFE
- * @Home https://github.com/miyuesc
- * @Date 2021年3月31日18:57:51
- */
- const props = defineProps({
- bpmnModeler: {
- type: Object,
- default: () => {}
- },
- prefix: {
- type: String,
- default: 'camunda'
- },
- width: {
- type: Number,
- default: 480
- },
- idEditDisabled: {
- type: Boolean,
- default: false
- },
- model: Object // 流程模型的数据
- })
- const activeTab = ref('base')
- const elementId = ref('')
- const elementType = ref('')
- const elementBusinessObject = ref<any>({}) // 元素 businessObject 镜像,提供给需要做判断的组件使用
- const conditionFormVisible = ref(false) // 流转条件设置
- const formVisible = ref(false) // 表单配置
- const bpmnElement = ref()
- const isReady = ref(false)
- provide('prefix', props.prefix)
- provide('width', props.width)
- // 初始化 bpmnInstances
- const initBpmnInstances = () => {
- if (!props.bpmnModeler) return false
- try {
- const instances = {
- modeler: props.bpmnModeler,
- modeling: props.bpmnModeler.get('modeling'),
- moddle: props.bpmnModeler.get('moddle'),
- eventBus: props.bpmnModeler.get('eventBus'),
- bpmnFactory: props.bpmnModeler.get('bpmnFactory'),
- elementFactory: props.bpmnModeler.get('elementFactory'),
- elementRegistry: props.bpmnModeler.get('elementRegistry'),
- replace: props.bpmnModeler.get('replace'),
- selection: props.bpmnModeler.get('selection')
- }
- // 检查所有实例是否都存在
- const allInstancesExist = Object.values(instances).every(instance => instance)
- if (allInstancesExist) {
- const w = window as any
- w.bpmnInstances = instances
- return true
- }
- return false
- } catch (error) {
- console.error('初始化 bpmnInstances 失败:', error)
- return false
- }
- }
- const bpmnInstances = () => (window as any)?.bpmnInstances
- // 监听 props.bpmnModeler 然后 initModels
- const unwatchBpmn = watch(
- () => props.bpmnModeler,
- async () => {
- // 避免加载时 流程图 并未加载完成
- if (!props.bpmnModeler) {
- console.log('缺少props.bpmnModeler')
- return
- }
- try {
- // 等待 modeler 初始化完成
- await nextTick()
- if (initBpmnInstances()) {
- isReady.value = true
- await nextTick()
- getActiveElement()
- } else {
- console.error('modeler 实例未完全初始化')
- }
- } catch (error) {
- console.error('初始化失败:', error)
- }
- },
- {
- immediate: true
- }
- )
- const getActiveElement = () => {
- if (!isReady.value || !props.bpmnModeler) return
- // 初始第一个选中元素 bpmn:Process
- initFormOnChanged(null)
- props.bpmnModeler.on('import.done', (e) => {
- console.log(e, 'eeeee')
- initFormOnChanged(null)
- })
- // 监听选择事件,修改当前激活的元素以及表单
- props.bpmnModeler.on('selection.changed', ({ newSelection }) => {
- initFormOnChanged(newSelection[0] || null)
- })
- props.bpmnModeler.on('element.changed', ({ element }) => {
- // 保证 修改 "默认流转路径" 类似需要修改多个元素的事件发生的时候,更新表单的元素与原选中元素不一致。
- if (element && element.id === elementId.value) {
- initFormOnChanged(element)
- }
- })
- }
- // 初始化数据
- const initFormOnChanged = (element) => {
- if (!isReady.value || !bpmnInstances()) return
- let activatedElement = element
- if (!activatedElement) {
- activatedElement =
- bpmnInstances().elementRegistry.find((el) => el.type === 'bpmn:Process') ??
- bpmnInstances().elementRegistry.find((el) => el.type === 'bpmn:Collaboration')
- }
- if (!activatedElement) return
- try {
- console.log(`
- ----------
- select element changed:
- id: ${activatedElement.id}
- type: ${activatedElement.businessObject.$type}
- ----------
- `)
- console.log('businessObject: ', activatedElement.businessObject)
- bpmnInstances().bpmnElement = activatedElement
- bpmnElement.value = activatedElement
- elementId.value = activatedElement.id
- elementType.value = activatedElement.type.split(':')[1] || ''
- elementBusinessObject.value = JSON.parse(JSON.stringify(activatedElement.businessObject))
- conditionFormVisible.value = !!(
- elementType.value === 'SequenceFlow' &&
- activatedElement.source &&
- activatedElement.source.type.indexOf('StartEvent') === -1
- )
- formVisible.value = elementType.value === 'UserTask' || elementType.value === 'StartEvent'
- } catch (error) {
- console.error('初始化表单数据失败:', error)
- }
- }
- onBeforeUnmount(() => {
- const w = window as any
- w.bpmnInstances = null
- isReady.value = false
- })
- watch(
- () => elementId.value,
- () => {
- activeTab.value = 'base'
- }
- )
- </script>
|