ElementCustomConfig.vue 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. <!-- UserTask 自定义配置:
  2. 1. 审批人与提交人为同一人时
  3. -->
  4. <template>
  5. <div class="panel-tab__content">
  6. <el-divider content-position="left">审批人与提交人为同一人时</el-divider>
  7. <el-radio-group v-model="assignStartUserHandlerType" @change="updateAssignStartUserHandlerType">
  8. <div class="flex-col">
  9. <div v-for="(item, index) in ASSIGN_START_USER_HANDLER_TYPES" :key="index">
  10. <el-radio :key="item.value" :value="item.value" :label="item.label" />
  11. </div>
  12. </div>
  13. </el-radio-group>
  14. </div>
  15. </template>
  16. <script lang="ts" setup>
  17. import { ASSIGN_START_USER_HANDLER_TYPES } from '@/components/SimpleProcessDesignerV2/src/consts'
  18. defineOptions({ name: 'ElementCustomConfig' })
  19. const props = defineProps({
  20. id: String,
  21. type: String
  22. })
  23. const prefix = inject('prefix')
  24. const elExtensionElements = ref()
  25. const assignStartUserHandlerTypeEl = ref()
  26. const assignStartUserHandlerType = ref()
  27. const otherExtensions = ref()
  28. const bpmnElement = ref()
  29. const bpmnInstances = () => (window as any)?.bpmnInstances
  30. const resetAttributesList = () => {
  31. bpmnElement.value = bpmnInstances().bpmnElement
  32. // 获取元素扩展属性 或者 创建扩展属性
  33. elExtensionElements.value =
  34. bpmnElement.value.businessObject?.extensionElements ??
  35. bpmnInstances().moddle.create('bpmn:ExtensionElements', { values: [] })
  36. assignStartUserHandlerTypeEl.value =
  37. elExtensionElements.value.values?.filter(
  38. (ex) => ex.$type === `${prefix}:AssignStartUserHandlerType`
  39. )?.[0] || bpmnInstances().moddle.create(`${prefix}:AssignStartUserHandlerType`, { value: 1 })
  40. assignStartUserHandlerType.value = assignStartUserHandlerTypeEl.value.value
  41. // 保留剩余扩展元素,便于后面更新该元素对应属性
  42. otherExtensions.value =
  43. elExtensionElements.value.values?.filter(
  44. (ex) => ex.$type !== `${prefix}:AssignStartUserHandlerType`
  45. ) ?? []
  46. // 更新元素扩展属性,避免后续报错
  47. updateElementExtensions()
  48. }
  49. const updateAssignStartUserHandlerType = () => {
  50. assignStartUserHandlerTypeEl.value.value = assignStartUserHandlerType.value
  51. updateElementExtensions()
  52. }
  53. const updateElementExtensions = () => {
  54. const extensions = bpmnInstances().moddle.create('bpmn:ExtensionElements', {
  55. values: otherExtensions.value.concat([assignStartUserHandlerTypeEl.value])
  56. })
  57. bpmnInstances().modeling.updateProperties(toRaw(bpmnElement.value), {
  58. extensionElements: extensions
  59. })
  60. }
  61. watch(
  62. () => props.id,
  63. (val) => {
  64. val &&
  65. val.length &&
  66. nextTick(() => {
  67. resetAttributesList()
  68. })
  69. },
  70. { immediate: true }
  71. )
  72. </script>