ElementTask.vue 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  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 lang="ts" setup>
  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. defineOptions({ name: 'ElementTaskConfig' })
  27. const props = defineProps({
  28. id: String,
  29. type: String
  30. })
  31. const taskConfigForm = ref({
  32. asyncAfter: false,
  33. asyncBefore: false,
  34. exclusive: false
  35. })
  36. const witchTaskComponent = ref()
  37. const installedComponent = ref({
  38. // 手工任务与普通任务一致,不需要其他配置
  39. // 接收消息任务,需要在全局下插入新的消息实例,并在该节点下的 messageRef 属性绑定该实例
  40. // 发送任务、服务任务、业务规则任务共用一个相同配置
  41. UserTask: 'UserTask', // 用户任务配置
  42. ScriptTask: 'ScriptTask', // 脚本任务配置
  43. ReceiveTask: 'ReceiveTask' // 消息接收任务
  44. })
  45. const bpmnElement = ref()
  46. const bpmnInstances = () => (window as any).bpmnInstances
  47. const changeTaskAsync = () => {
  48. if (!taskConfigForm.value.asyncBefore && !taskConfigForm.value.asyncAfter) {
  49. taskConfigForm.value.exclusive = false
  50. }
  51. bpmnInstances().modeling.updateProperties(bpmnInstances().bpmnElement, {
  52. ...taskConfigForm.value
  53. })
  54. }
  55. watch(
  56. () => props.id,
  57. () => {
  58. bpmnElement.value = bpmnInstances().bpmnElement
  59. taskConfigForm.value.asyncBefore = bpmnElement.value?.businessObject?.asyncBefore
  60. taskConfigForm.value.asyncAfter = bpmnElement.value?.businessObject?.asyncAfter
  61. taskConfigForm.value.exclusive = bpmnElement.value?.businessObject?.exclusive
  62. },
  63. { immediate: true }
  64. )
  65. watch(
  66. () => props.type,
  67. () => {
  68. // witchTaskComponent.value = installedComponent.value[props.type]
  69. if (props.type == installedComponent.value.UserTask) {
  70. witchTaskComponent.value = UserTask
  71. }
  72. if (props.type == installedComponent.value.ScriptTask) {
  73. witchTaskComponent.value = ScriptTask
  74. }
  75. if (props.type == installedComponent.value.ReceiveTask) {
  76. witchTaskComponent.value = ReceiveTask
  77. }
  78. },
  79. { immediate: true }
  80. )
  81. </script>