ElementTask.vue 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. <template>
  2. <div class="panel-tab__content">
  3. <el-form size="small" label-width="90px">
  4. <el-form-item label="异步延续">
  5. <el-checkbox
  6. v-model="taskConfigForm.asyncBefore"
  7. label="异步前"
  8. @change="changeTaskAsync"
  9. />
  10. <el-checkbox v-model="taskConfigForm.asyncAfter" label="异步后" @change="changeTaskAsync" />
  11. <el-checkbox
  12. v-model="taskConfigForm.exclusive"
  13. v-if="taskConfigForm.asyncAfter || taskConfigForm.asyncBefore"
  14. label="排除"
  15. @change="changeTaskAsync"
  16. />
  17. </el-form-item>
  18. <component :is="witchTaskComponent" v-bind="$props" />
  19. </el-form>
  20. </div>
  21. </template>
  22. <script setup lang="ts" name="ElementTaskConfig">
  23. import UserTask from './task-components/UserTask.vue'
  24. import ScriptTask from './task-components/ScriptTask.vue'
  25. import ReceiveTask from './task-components/ReceiveTask.vue'
  26. const props = defineProps({
  27. id: String,
  28. type: String
  29. })
  30. const taskConfigForm = ref({
  31. asyncAfter: false,
  32. asyncBefore: false,
  33. exclusive: false
  34. })
  35. const witchTaskComponent = ref()
  36. const installedComponent = ref({
  37. // 手工任务与普通任务一致,不需要其他配置
  38. // 接收消息任务,需要在全局下插入新的消息实例,并在该节点下的 messageRef 属性绑定该实例
  39. // 发送任务、服务任务、业务规则任务共用一个相同配置
  40. UserTask: 'UserTask', // 用户任务配置
  41. ScriptTask: 'ScriptTask', // 脚本任务配置
  42. ReceiveTask: 'ReceiveTask' // 消息接收任务
  43. })
  44. const bpmnElement = ref()
  45. const changeTaskAsync = () => {
  46. if (!taskConfigForm.value.asyncBefore && !taskConfigForm.value.asyncAfter) {
  47. taskConfigForm.value.exclusive = false
  48. }
  49. window.bpmnInstances.modeling.updateProperties(window.bpmnInstances.bpmnElement, {
  50. ...taskConfigForm.value
  51. })
  52. }
  53. watch(
  54. () => props.id,
  55. () => {
  56. bpmnElement.value = window.bpmnInstances.bpmnElement
  57. taskConfigForm.value.asyncBefore = bpmnElement.value?.businessObject?.asyncBefore
  58. taskConfigForm.value.asyncAfter = bpmnElement.value?.businessObject?.asyncAfter
  59. taskConfigForm.value.exclusive = bpmnElement.value?.businessObject?.exclusive
  60. },
  61. { immediate: true }
  62. )
  63. watch(
  64. () => props.type,
  65. () => {
  66. // witchTaskComponent.value = installedComponent.value[props.type]
  67. if (props.type == installedComponent.value.UserTask) {
  68. witchTaskComponent.value = UserTask
  69. }
  70. if (props.type == installedComponent.value.ScriptTask) {
  71. witchTaskComponent.value = ScriptTask
  72. }
  73. if (props.type == installedComponent.value.ReceiveTask) {
  74. witchTaskComponent.value = ReceiveTask
  75. }
  76. },
  77. { immediate: true }
  78. )
  79. </script>