modelEditor.vue 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268
  1. <template>
  2. <!-- <div id="app">-->
  3. <div class="app-container">
  4. <!-- TODO 芋艿:去除测试任务 -->
  5. <!-- <my-process-palette />-->
  6. <my-process-designer
  7. :key="`designer-${reloadIndex}`"
  8. v-model="xmlString"
  9. v-bind="controlForm"
  10. keyboard
  11. ref="processDesigner"
  12. @element-click="elementClick"
  13. @init-finished="initModeler"
  14. />
  15. <my-properties-panel :key="`penal-${reloadIndex}`" :bpmn-modeler="modeler" :prefix="controlForm.prefix" class="process-panel" />
  16. <!-- demo config -->
  17. <div class="demo-control-bar">
  18. <div class="open-control-dialog" @click="controlDrawerVisible = true"><i class="el-icon-setting"></i></div>
  19. </div>
  20. <el-drawer :visible.sync="controlDrawerVisible" size="400px" title="偏好设置" append-to-body destroy-on-close>
  21. <el-form :model="controlForm" size="small" label-width="100px" class="control-form" @submit.native.prevent>
  22. <el-form-item label="流程ID">
  23. <el-input v-model="controlForm.processId" @change="reloadProcessDesigner" />
  24. </el-form-item>
  25. <el-form-item label="流程名称">
  26. <el-input v-model="controlForm.processName" @change="reloadProcessDesigner" />
  27. </el-form-item>
  28. <el-form-item label="流转模拟">
  29. <el-switch v-model="controlForm.simulation" inactive-text="停用" active-text="启用" @change="reloadProcessDesigner" />
  30. </el-form-item>
  31. <el-form-item label="禁用双击">
  32. <el-switch v-model="controlForm.labelEditing" inactive-text="停用" active-text="启用" @change="changeLabelEditingStatus" />
  33. </el-form-item>
  34. <!-- TODO 芋艿:custom render 依赖报错 -->
  35. <!-- <el-form-item label="隐藏label">-->
  36. <!-- <el-switch v-model="controlForm.labelVisible" inactive-text="停用" active-text="启用" @change="changeLabelVisibleStatus" />-->
  37. <!-- </el-form-item>-->
  38. <el-form-item label="流程引擎">
  39. <el-radio-group v-model="controlForm.prefix" @change="reloadProcessDesigner(true)">
  40. <el-radio label="camunda">camunda</el-radio>
  41. <el-radio label="flowable">flowable</el-radio>
  42. <el-radio label="activiti">activiti</el-radio>
  43. </el-radio-group>
  44. </el-form-item>
  45. <el-form-item label="工具栏">
  46. <el-radio-group v-model="controlForm.headerButtonSize">
  47. <el-radio label="mini">mini</el-radio>
  48. <el-radio label="small">small</el-radio>
  49. <el-radio label="medium">medium</el-radio>
  50. </el-radio-group>
  51. </el-form-item>
  52. </el-form>
  53. </el-drawer>
  54. <!-- TODO 芋艿:去掉多余的 faq -->
  55. <!-- <div class="info-tip">-->
  56. <!-- <p>注:activiti 好像不支持表单配置,控制台可能会报错</p>-->
  57. <!-- <p>更多配置请查看源码:<a href="https://github.com/miyuesc/bpmn-process-designer">MiyueSC/bpmn-process-designer</a></p>-->
  58. <!-- <p>疑问请在此留言:<a href="https://github.com/miyuesc/bpmn-process-designer/issues/16">MiyueSC/bpmn-process-designer/issues</a></p>-->
  59. <!-- </div>-->
  60. </div>
  61. </template>
  62. <script>
  63. import translations from "@/components/bpmnProcessDesigner/src/translations";
  64. // 自定义渲染(隐藏了 label 标签)
  65. // TODO 芋艿:custom render 依赖报错
  66. // import CustomRenderer from "@/modules/custom-renderer";
  67. // 自定义元素选中时的弹出菜单(修改 默认任务 为 用户任务)
  68. import CustomContentPadProvider from "@/components/bpmnProcessDesigner/package/designer/plugins/content-pad";
  69. // 自定义左侧菜单(修改 默认任务 为 用户任务)
  70. import CustomPaletteProvider from "@/components/bpmnProcessDesigner/package/designer/plugins/palette";
  71. // import xmlObj2json from "./utils/xml2json";
  72. import MyProcessPalette from "@/components/bpmnProcessDesigner/package/palette/ProcessPalette";
  73. // 自定义侧边栏
  74. // import MyProcessPanel from "../package/process-panel/ProcessPanel";
  75. export default {
  76. name: "App",
  77. components: { MyProcessPalette },
  78. data() {
  79. return {
  80. xmlString: "",
  81. modeler: null,
  82. reloadIndex: 0,
  83. controlDrawerVisible: false,
  84. translationsSelf: translations,
  85. controlForm: {
  86. processId: "",
  87. processName: "",
  88. simulation: true,
  89. labelEditing: false,
  90. labelVisible: false,
  91. prefix: "flowable",
  92. headerButtonSize: "mini",
  93. // additionalModel: []
  94. additionalModel: [CustomContentPadProvider, CustomPaletteProvider]
  95. },
  96. addis: {
  97. CustomContentPadProvider,
  98. CustomPaletteProvider
  99. }
  100. };
  101. },
  102. created() {},
  103. methods: {
  104. initModeler(modeler) {
  105. setTimeout(() => {
  106. this.modeler = modeler;
  107. console.log(modeler);
  108. }, 10);
  109. },
  110. reloadProcessDesigner(deep) {
  111. this.controlForm.additionalModel = [];
  112. for (let key in this.addis) {
  113. if (this.addis[key]) {
  114. this.controlForm.additionalModel.push(this.addis[key]);
  115. }
  116. }
  117. deep && (this.xmlString = undefined);
  118. this.reloadIndex += 1;
  119. this.modeler = null; // 避免 panel 异常
  120. // if (deep) {
  121. // this.xmlString = undefined;
  122. // this.$refs.processDesigner.processRestart();
  123. // }
  124. },
  125. changeLabelEditingStatus(status) {
  126. this.addis.labelEditing = status ? { labelEditingProvider: ["value", ""] } : false;
  127. this.reloadProcessDesigner();
  128. },
  129. // TODO 芋艿:custom render 依赖报错
  130. // changeLabelVisibleStatus(status) {
  131. // this.addis.customRenderer = status ? CustomRenderer : false;
  132. // this.reloadProcessDesigner();
  133. // },
  134. elementClick(element) {
  135. this.element = element;
  136. !this.elementOverlayIds && (this.elementOverlayIds = {});
  137. !this.overlays && (this.overlays = this.modeler.get("overlays"));
  138. !this.contextPad && (this.contextPad = this.modeler.get("contextPad"));
  139. this.modeler.on("element.hover", ({ element }) => {
  140. if (!this.elementOverlayIds[element.id] && element.type !== "bpmn:Process") {
  141. this.elementOverlayIds[element.id] = this.overlays.add(element, {
  142. position: { left: 0, bottom: 0 },
  143. html: `<div class="element-overlays">
  144. <p>Elemet id: ${element.id}</p>
  145. <p>Elemet type: ${element.type}</p>
  146. </div>`
  147. });
  148. }
  149. });
  150. this.modeler.on("element.out", ({ element }) => {
  151. if (element) {
  152. this.overlays.remove({ element });
  153. this.elementOverlayIds[element.id] = null;
  154. }
  155. });
  156. }
  157. }
  158. };
  159. </script>
  160. <style lang="scss">
  161. body {
  162. overflow: hidden;
  163. margin: 0;
  164. box-sizing: border-box;
  165. }
  166. //#app {
  167. // width: 100%;
  168. // height: 100%;
  169. // box-sizing: border-box;
  170. // display: inline-grid;
  171. // grid-template-columns: 100px auto max-content;
  172. //}
  173. .demo-control-bar {
  174. position: fixed;
  175. right: 8px;
  176. bottom: 8px;
  177. z-index: 1;
  178. .open-control-dialog {
  179. width: 48px;
  180. height: 48px;
  181. display: flex;
  182. align-items: center;
  183. justify-content: center;
  184. border-radius: 4px;
  185. font-size: 32px;
  186. background: rgba(64, 158, 255, 1);
  187. color: #ffffff;
  188. cursor: pointer;
  189. }
  190. }
  191. // TODO 芋艿:去掉多余的 faq
  192. //.info-tip {
  193. // position: fixed;
  194. // top: 40px;
  195. // right: 500px;
  196. // z-index: 10;
  197. // color: #999999;
  198. //}
  199. .control-form {
  200. .el-radio {
  201. width: 100%;
  202. line-height: 32px;
  203. }
  204. }
  205. .element-overlays {
  206. box-sizing: border-box;
  207. padding: 8px;
  208. background: rgba(0, 0, 0, 0.6);
  209. border-radius: 4px;
  210. color: #fafafa;
  211. }
  212. .bjs-container {
  213. height: 400px !important; // TODO 芋艿:bjs 容器的高度不对,临时改下
  214. }
  215. .process-panel__container { // TODO 芋艿:右边的位置不对,临时改下
  216. margin-top: -200px;
  217. float: right;
  218. height: 800px;
  219. z-index: 2147483647 !important;
  220. }
  221. body,
  222. body * {
  223. /* 滚动条 */
  224. &::-webkit-scrollbar-track-piece {
  225. background-color: #fff; /*滚动条的背景颜色*/
  226. -webkit-border-radius: 0; /*滚动条的圆角宽度*/
  227. }
  228. &::-webkit-scrollbar {
  229. width: 10px; /*滚动条的宽度*/
  230. height: 8px; /*滚动条的高度*/
  231. }
  232. &::-webkit-scrollbar-thumb:vertical {
  233. /*垂直滚动条的样式*/
  234. height: 50px;
  235. background-color: rgba(153, 153, 153, 0.5);
  236. -webkit-border-radius: 4px;
  237. outline: 2px solid #fff;
  238. outline-offset: -2px;
  239. border: 2px solid #fff;
  240. }
  241. &::-webkit-scrollbar-thumb {
  242. /*滚动条的hover样式*/
  243. background-color: rgba(159, 159, 159, 0.3);
  244. -webkit-border-radius: 4px;
  245. }
  246. &::-webkit-scrollbar-thumb:hover {
  247. /*滚动条的hover样式*/
  248. background-color: rgba(159, 159, 159, 0.5);
  249. -webkit-border-radius: 4px;
  250. }
  251. }
  252. </style>