PropertiesPanel.vue 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204
  1. <template>
  2. <div class="process-panel__container" :style="{ width: `${width}px;` }">
  3. <el-collapse v-model="activeTab">
  4. <el-collapse-item name="base">
  5. <!-- class="panel-tab__title" -->
  6. <template #title>
  7. <Icon icon="ep:info-filled" />
  8. 常规</template
  9. >
  10. <ElementBaseInfo
  11. :id-edit-disabled="idEditDisabled"
  12. :business-object="elementBusinessObject"
  13. :type="elementType"
  14. :model="model"
  15. />
  16. </el-collapse-item>
  17. <el-collapse-item name="condition" v-if="elementType === 'Process'" key="message">
  18. <template #title><Icon icon="ep:comment" />消息与信号</template>
  19. <signal-and-massage />
  20. </el-collapse-item>
  21. <el-collapse-item name="condition" v-if="conditionFormVisible" key="condition">
  22. <template #title><Icon icon="ep:promotion" />流转条件</template>
  23. <flow-condition :business-object="elementBusinessObject" :type="elementType" />
  24. </el-collapse-item>
  25. <el-collapse-item name="condition" v-if="formVisible" key="form">
  26. <template #title><Icon icon="ep:list" />表单</template>
  27. <!-- <element-form :id="elementId" :type="elementType" /> -->
  28. 友情提示:使用
  29. <router-link :to="{ path: '/bpm/manager/form' }"
  30. ><el-link type="danger">流程表单</el-link>
  31. </router-link>
  32. 替代,提供更好的表单设计功能
  33. </el-collapse-item>
  34. <el-collapse-item name="task" v-if="elementType.indexOf('Task') !== -1" key="task">
  35. <template #title><Icon icon="ep:checked" />任务</template>
  36. <element-task :id="elementId" :type="elementType" />
  37. </el-collapse-item>
  38. <el-collapse-item
  39. name="multiInstance"
  40. v-if="elementType.indexOf('Task') !== -1"
  41. key="multiInstance"
  42. >
  43. <template #title><Icon icon="ep:help-filled" />多实例</template>
  44. <element-multi-instance :business-object="elementBusinessObject" :type="elementType" />
  45. </el-collapse-item>
  46. <el-collapse-item name="listeners" key="listeners">
  47. <template #title><Icon icon="ep:bell-filled" />执行监听器</template>
  48. <element-listeners :id="elementId" :type="elementType" />
  49. </el-collapse-item>
  50. <el-collapse-item name="taskListeners" v-if="elementType === 'UserTask'" key="taskListeners">
  51. <template #title><Icon icon="ep:bell-filled" />任务监听器</template>
  52. <user-task-listeners :id="elementId" :type="elementType" />
  53. </el-collapse-item>
  54. <el-collapse-item name="extensions" key="extensions">
  55. <template #title><Icon icon="ep:circle-plus-filled" />扩展属性</template>
  56. <element-properties :id="elementId" :type="elementType" />
  57. </el-collapse-item>
  58. <el-collapse-item name="other" key="other">
  59. <template #title><Icon icon="ep:promotion" />其他</template>
  60. <element-other-config :id="elementId" />
  61. </el-collapse-item>
  62. </el-collapse>
  63. </div>
  64. </template>
  65. <script setup lang="ts" name="MyPropertiesPanel">
  66. import ElementBaseInfo from './base/ElementBaseInfo.vue'
  67. import ElementOtherConfig from './other/ElementOtherConfig.vue'
  68. import ElementTask from './task/ElementTask.vue'
  69. import ElementMultiInstance from './multi-instance/ElementMultiInstance.vue'
  70. import FlowCondition from './flow-condition/FlowCondition.vue'
  71. import SignalAndMassage from './signal-message/SignalAndMessage.vue'
  72. import ElementListeners from './listeners/ElementListeners.vue'
  73. import ElementProperties from './properties/ElementProperties.vue'
  74. // import ElementForm from './form/ElementForm.vue'
  75. import UserTaskListeners from './listeners/UserTaskListeners.vue'
  76. import { provide, ref, watch, onBeforeUnmount, onMounted } from 'vue'
  77. import { ElCollapse, ElCollapseItem, ElLink } from 'element-plus'
  78. /**
  79. * 侧边栏
  80. * @Author MiyueFE
  81. * @Home https://github.com/miyuesc
  82. * @Date 2021年3月31日18:57:51
  83. */
  84. const props = defineProps({
  85. bpmnModeler: Object,
  86. prefix: {
  87. type: String,
  88. default: 'camunda'
  89. },
  90. width: {
  91. type: Number,
  92. default: 500
  93. },
  94. idEditDisabled: {
  95. type: Boolean,
  96. default: false
  97. },
  98. model: Object // 流程模型的数据
  99. })
  100. const activeTab = ref('base')
  101. const elementId = ref('')
  102. const elementType = ref('')
  103. const elementBusinessObject = ref({}) // 元素 businessObject 镜像,提供给需要做判断的组件使用
  104. const conditionFormVisible = ref(false) // 流转条件设置
  105. const formVisible = ref(false) // 表单配置
  106. const bpmnElement = ref()
  107. const timer = ref()
  108. provide('prefix', props.prefix)
  109. provide('width', props.width)
  110. const initModels = () => {
  111. // console.log(props, 'props')
  112. // console.log(props.bpmnModeler, 'sakdjjaskdsajdkasdjkadsjk')
  113. // 初始化 modeler 以及其他 moddle
  114. // nextTick(() => {
  115. if (!props.bpmnModeler) {
  116. // 避免加载时 流程图 并未加载完成
  117. timer.value = setTimeout(() => initModels(), 10)
  118. return
  119. }
  120. if (timer.value) {
  121. clearTimeout(timer.value)
  122. window.bpmnInstances = {
  123. modeler: props.bpmnModeler,
  124. modeling: props.bpmnModeler.get('modeling'),
  125. moddle: props.bpmnModeler.get('moddle'),
  126. eventBus: props.bpmnModeler.get('eventBus'),
  127. bpmnFactory: props.bpmnModeler.get('bpmnFactory'),
  128. elementFactory: props.bpmnModeler.get('elementFactory'),
  129. elementRegistry: props.bpmnModeler.get('elementRegistry'),
  130. replace: props.bpmnModeler.get('replace'),
  131. selection: props.bpmnModeler.get('selection')
  132. }
  133. }
  134. console.log(window.bpmnInstances, 'window.bpmnInstances')
  135. getActiveElement()
  136. // })
  137. }
  138. const getActiveElement = () => {
  139. // 初始第一个选中元素 bpmn:Process
  140. initFormOnChanged(null)
  141. props.bpmnModeler.on('import.done', (e) => {
  142. console.log(e, 'eeeee')
  143. initFormOnChanged(null)
  144. })
  145. // 监听选择事件,修改当前激活的元素以及表单
  146. props.bpmnModeler.on('selection.changed', ({ newSelection }) => {
  147. initFormOnChanged(newSelection[0] || null)
  148. })
  149. props.bpmnModeler.on('element.changed', ({ element }) => {
  150. // 保证 修改 "默认流转路径" 类似需要修改多个元素的事件发生的时候,更新表单的元素与原选中元素不一致。
  151. if (element && element.id === elementId.value) {
  152. initFormOnChanged(element)
  153. }
  154. })
  155. }
  156. // 初始化数据
  157. const initFormOnChanged = (element) => {
  158. let activatedElement = element
  159. if (!activatedElement) {
  160. activatedElement =
  161. window.bpmnInstances.elementRegistry.find((el) => el.type === 'bpmn:Process') ??
  162. window.bpmnInstances.elementRegistry.find((el) => el.type === 'bpmn:Collaboration')
  163. }
  164. if (!activatedElement) return
  165. console.log(`
  166. ----------
  167. select element changed:
  168. id: ${activatedElement.id}
  169. type: ${activatedElement.businessObject.$type}
  170. ----------
  171. `)
  172. console.log('businessObject: ', activatedElement.businessObject)
  173. window.bpmnInstances.bpmnElement = activatedElement
  174. bpmnElement.value = activatedElement
  175. elementId.value = activatedElement.id
  176. elementType.value = activatedElement.type.split(':')[1] || ''
  177. elementBusinessObject.value = JSON.parse(JSON.stringify(activatedElement.businessObject))
  178. conditionFormVisible.value = !!(
  179. elementType.value === 'SequenceFlow' &&
  180. activatedElement.source &&
  181. activatedElement.source.type.indexOf('StartEvent') === -1
  182. )
  183. formVisible.value = elementType.value === 'UserTask' || elementType.value === 'StartEvent'
  184. }
  185. onMounted(() => {
  186. setTimeout(() => {
  187. initModels()
  188. }, 100)
  189. })
  190. onBeforeUnmount(() => {
  191. window.bpmnInstances = null
  192. console.log(props, 'props1')
  193. console.log(props.bpmnModeler, 'props.bpmnModeler1')
  194. })
  195. watch(
  196. () => elementId.value,
  197. () => {
  198. activeTab.value = 'base'
  199. }
  200. )
  201. </script>