StartEventNodePropertyPanel.vue 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240
  1. <template>
  2. <div>
  3. <!-- 开始节点 -->
  4. <el-collapse v-if="localFormData.type=='bpmn:StartEvent'" v-model="activeNames" accordion>
  5. <el-collapse-item name="1">
  6. <template slot="title">
  7. <div class="title">
  8. <i class="header-icon el-icon-setting"></i>
  9. <span>基本设置</span>
  10. </div>
  11. </template>
  12. <div>
  13. <el-form label-position="right" label-width="70px">
  14. <el-form-item label="节点类型">
  15. <el-input v-model="localFormData.type" disabled></el-input>
  16. </el-form-item>
  17. <el-form-item label="ID">
  18. <el-input v-model="localFormData.id" @input="updateId"></el-input>
  19. </el-form-item>
  20. <el-form-item label="名称">
  21. <el-input v-model="localFormData.name " @input="updateName"></el-input>
  22. </el-form-item>
  23. </el-form>
  24. </div>
  25. </el-collapse-item>
  26. <el-collapse-item name="2">
  27. <template slot="title">
  28. <div class="title">
  29. <i class="header-icon el-icon-setting"></i>
  30. <span>执行监听</span>
  31. </div>
  32. </template>
  33. <div>
  34. <div style="margin: 10px 3%;float: right">
  35. <el-button size="mini" plain @click="showEventDialogMethod">添加</el-button>
  36. </div>
  37. <el-table
  38. border :data="listenerTable"
  39. style="width: 93%;margin: 0 auto">
  40. <el-table-column align="center" prop="event"
  41. label="事件">
  42. </el-table-column>
  43. <el-table-column align="center" prop="type" :show-overflow-tooltip="true"
  44. label="类型">
  45. </el-table-column>
  46. <el-table-column align="center" prop="class" :show-overflow-tooltip="true"
  47. label="实现">
  48. </el-table-column>
  49. <el-table-column align="center"
  50. label="操作">
  51. <template slot-scope="scope">
  52. <div>
  53. <i class="el-icon-delete" @click="deleteEvent(scope.$index)"></i>
  54. </div>
  55. </template>
  56. </el-table-column>
  57. </el-table>
  58. </div>
  59. </el-collapse-item>
  60. </el-collapse>
  61. <EventListenerDialog @commitEventForm="commitEventForm"
  62. :dialogFormVisibleBool="showEventDialog"
  63. :formData="eventFormData" :nodeElement="nodeElement" :modeler="modeler" :listenerTable="listenerTable"></EventListenerDialog>
  64. </div>
  65. </template>
  66. <script>
  67. import EventListenerDialog from "./dialog/EventListenerDialog"
  68. export default {
  69. name: "NodePropertyPanel",
  70. data() {
  71. return {
  72. activeNames: ['1'],
  73. input3: 1,
  74. listenerTable: [],
  75. showEventDialog: false,
  76. eventFormData: {},
  77. bpmnData: {
  78. assignees: [{
  79. value: "${assignee}",
  80. label: "表达式"
  81. }, {
  82. value: "1001",
  83. label: "张三"
  84. }, {
  85. value: "1002",
  86. label: "李四"
  87. }, {
  88. value: "1003",
  89. label: "王五"
  90. }],
  91. candidateUsers:[{
  92. value: "1001",
  93. label: "张三"
  94. }, {
  95. value: "1002",
  96. label: "李四"
  97. }, {
  98. value: "1003",
  99. label: "王五"
  100. }],
  101. roles: [
  102. {
  103. value: "manager",
  104. label: "经理"
  105. },
  106. {
  107. value: "personnel",
  108. label: "人事"
  109. },
  110. {
  111. value: "charge",
  112. label: "主管"
  113. }
  114. ]
  115. }
  116. }
  117. },
  118. components: {
  119. EventListenerDialog
  120. },
  121. props: {
  122. modeler: {
  123. type: Object,
  124. required: true
  125. },
  126. nodeElement: {
  127. type: Object,
  128. required: true
  129. },
  130. formData:{
  131. type: Object,
  132. required: true
  133. }
  134. },
  135. computed:{
  136. localFormData:{
  137. get(){
  138. return this.formData
  139. }
  140. }
  141. },
  142. watch:{
  143. nodeElement:{
  144. handler(){
  145. if(this.nodeElement.type==="bpmn:StartEvent"){
  146. this.updateName("开始");
  147. }
  148. if(this.nodeElement.type==="bpmn:EndEvent"){
  149. this.updateName("结束");
  150. }
  151. }
  152. }
  153. },
  154. mounted() {
  155. const that = this
  156. if (this.nodeElement.businessObject
  157. && this.nodeElement.businessObject.extensionElements
  158. && this.nodeElement.businessObject.extensionElements.values) {
  159. // 根据xml 组合当前节点的监听数据
  160. that.listenerTable = this.nodeElement.businessObject.extensionElements.values.filter(
  161. (item) => {
  162. if (item.$type === 'activiti:ExecutionListener') {
  163. item.type = Object.keys(item)[1]
  164. item.class = item[Object.keys(item)[1]]
  165. return true;
  166. }
  167. }
  168. )
  169. }
  170. },
  171. methods: {
  172. updateProperties(properties){
  173. console.log(this.nodeElement)
  174. console.log(properties)
  175. this.modeler.get("modeling").updateProperties(this.nodeElement, properties);
  176. },
  177. updateId(name) {
  178. this.updateProperties({id: name});
  179. },
  180. updateName(name) {
  181. this.updateProperties({name: name});
  182. },
  183. changeUserType() {
  184. },
  185. updateSequenceFlow(val){
  186. let newCondition = this.modeler.get("moddle").create('bpmn:FormalExpression', {
  187. body: val
  188. });
  189. this.updateProperties({conditionExpression:newCondition});
  190. },
  191. addUser(properties){
  192. this.updateProperties(properties);
  193. Object.assign(properties, {
  194. userType: Object.keys(properties)[0]
  195. });
  196. console.log(properties)
  197. this.$emit('modifyFormData',properties);
  198. },
  199. showEventDialogMethod(){
  200. this.showEventDialog = true;
  201. this.eventFormData= {
  202. event:"start",
  203. type:"class"
  204. }
  205. },
  206. deleteEvent(index){
  207. const data = this.listenerTable[index]
  208. if (this.nodeElement.businessObject
  209. && this.nodeElement.businessObject.extensionElements
  210. && this.nodeElement.businessObject.extensionElements.values) {
  211. // 排除全局监听类型 并且class为删除的class的数据。
  212. const filterArr = this.nodeElement.businessObject.extensionElements.values.filter(
  213. (item) => !(item.$type === 'activiti:ExecutionListener' && item.event === data.event && data.class === item[data.type])
  214. )
  215. // 刷新数据
  216. let extensionElements = this.modeler.get("bpmnFactory").create("bpmn:ExtensionElements", {values: filterArr});
  217. this.modeler.get("modeling").updateProperties(this.nodeElement, {extensionElements});
  218. }
  219. this.listenerTable.splice(index, 1);
  220. },
  221. commitEventForm(from){
  222. this.showEventDialog = false
  223. if (from != null) {
  224. this.listenerTable.push(from)
  225. }
  226. }
  227. }
  228. }
  229. </script>
  230. <style scoped>
  231. .bpmnclass .title span{
  232. font-weight: bold;
  233. margin-left: 5px;
  234. }
  235. </style>