ElementTask.vue 3.0 KB

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