ElementTask.vue 2.8 KB

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