ElementTask.vue 3.2 KB

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