index.ts 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. import BpmnRenderer from 'bpmn-js/lib/draw/BpmnRenderer';
  2. import CustomizeRenderer from './CustomizeRenderer';
  3. import { getRectPath } from 'bpmn-js/lib/draw/BpmnRenderUtil';
  4. import createAddMarkerSelect from './connect/marker';
  5. import { typeConfluence } from '../../config/variableName';
  6. import { createLine } from 'diagram-js/lib/util/RenderUtil';
  7. import { append as svgAppend } from 'tiny-svg';
  8. import { hasGatewayType } from '../../config';
  9. let jnpfCanvas: any;
  10. let defaultStrokeColor = '#A2B9D5';
  11. let jnpfFlowInfo: any;
  12. class YmRenderer extends BpmnRenderer {
  13. _styles: any;
  14. _injector: any;
  15. constructor(config: any, injector: any, eventBus: any, styles: any, pathMap: any, canvas: any, textRenderer: any, flowInfo: any, priority: number) {
  16. super(
  17. (config = {
  18. defaultLabelColor: 'rgb(102,102,102)',
  19. defaultStrokeColor: defaultStrokeColor,
  20. ...config,
  21. }),
  22. eventBus,
  23. styles,
  24. pathMap,
  25. canvas,
  26. textRenderer,
  27. priority,
  28. );
  29. this._styles = styles;
  30. jnpfCanvas = canvas;
  31. jnpfFlowInfo = flowInfo;
  32. this._injector = injector;
  33. }
  34. canRender(element: any) {
  35. return super.canRender(element);
  36. }
  37. // 绘制画布上元素
  38. drawShape(parentNode: any, element: any) {
  39. if (element) return CustomizeRenderer(parentNode, element, jnpfFlowInfo, this._injector) || super.drawShape(parentNode, element);
  40. return super.drawShape(parentNode, element);
  41. }
  42. drawConnection(parentGfx: any, element: any) {
  43. let stroke = '';
  44. if (
  45. element.target?.wnType === typeConfluence ||
  46. (element.isPreview && hasGatewayType.has(element.target.wnType)) ||
  47. (element.isPreview && hasGatewayType.has(element.source.wnType))
  48. ) {
  49. function lineStyle(_styles, attrs) {
  50. return _styles.computeStyle(attrs, ['no-fill'], {
  51. strokeLinecap: 'round',
  52. strokeLinejoin: 'round',
  53. stroke: defaultStrokeColor,
  54. strokeWidth: 2,
  55. });
  56. }
  57. function drawLine(parentGfx, waypoints, attrs, radius, _styles) {
  58. attrs = lineStyle(_styles, attrs);
  59. var line = createLine(waypoints, attrs, radius);
  60. svgAppend(parentGfx, line);
  61. return line;
  62. }
  63. if (element.isPreview && element.waypoints?.length > 1) {
  64. if (element.waypoints.length === 2) {
  65. element.waypoints = [
  66. {
  67. x: element.waypoints[0].x,
  68. y: element.waypoints[0].y,
  69. },
  70. {
  71. x: element.waypoints[1].x,
  72. y: element.waypoints[1].y + 15,
  73. },
  74. ];
  75. } else {
  76. element.waypoints = [
  77. {
  78. x: element.waypoints[0].x > element.waypoints[1].x ? element.waypoints[0].x + 45 : element.waypoints[0].x - 45,
  79. y: element.waypoints[0].y,
  80. },
  81. {
  82. x: element.waypoints[1].x,
  83. y: element.waypoints[1].y,
  84. },
  85. {
  86. x: element.waypoints[2].x,
  87. y: element.waypoints[2].y,
  88. },
  89. ];
  90. }
  91. }
  92. var connection = drawLine(
  93. parentGfx,
  94. element.waypoints,
  95. {
  96. markerEnd: '',
  97. stroke: stroke || defaultStrokeColor,
  98. },
  99. 5,
  100. this._styles,
  101. );
  102. return connection;
  103. } else {
  104. let connect = super.drawConnection(parentGfx, element, { stroke });
  105. createAddMarkerSelect(element, jnpfCanvas); // 选中线的箭头
  106. return connect;
  107. }
  108. }
  109. // 绘制
  110. getShapePath(shape: any) {
  111. return getRectPath(shape);
  112. }
  113. }
  114. YmRenderer.$inject = ['config.bpmnRenderer', 'injector', 'eventBus', 'styles', 'pathMap', 'canvas', 'textRenderer', 'config.flowInfo'];
  115. export default YmRenderer;