index.ts 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. // @ts-nocheck 过滤ts校验
  2. import { attr as domAttr, query as domQuery, classes as domClasses, domify as domify, delegate as domDelegate, event as domEvent } from 'min-dom';
  3. import { assign, forEach, isArray } from 'min-dash';
  4. import { escapeCSS } from 'diagram-js/lib/util/EscapeUtil';
  5. import contextPad from 'diagram-js/lib/features/context-pad/ContextPad';
  6. import { bpmnGroup, bpmnLabel, bpmnTask } from '../config/variableName';
  7. var entrySelector = '.entry';
  8. function addClasses(element: any, classNames: any) {
  9. var classes = domClasses(element);
  10. classNames = isArray(classNames) ? classNames : classNames.split(/\s+/g);
  11. classNames.forEach(function (cls: any) {
  12. classes.add(cls);
  13. });
  14. }
  15. class YmContextPad extends contextPad {
  16. constructor(canvas: any, config: any, eventBus: any, overlays: any) {
  17. super(canvas, config, eventBus, overlays);
  18. }
  19. // 打开节点右侧面板
  20. open(target: any, force: any) {
  21. if (target.type === bpmnLabel || target.type === bpmnGroup) return;
  22. if (!force && this.isOpen(target)) return;
  23. this.close();
  24. this._updateAndOpen(target);
  25. }
  26. isShown() {
  27. return this.isOpen();
  28. }
  29. arrowOpen(target: any) {
  30. var entries = this.getEntries(target),
  31. arrow = this.getArrow(target),
  32. html = arrow.html;
  33. let container = domify('<div class="rightArrow" id="rightArrow"></div>');
  34. html.appendChild(container);
  35. domClasses(html).add('open');
  36. this._current = {
  37. target: target,
  38. entries: entries,
  39. pad: arrow,
  40. };
  41. this._eventBus.fire('contextPad.open', { current: this._current });
  42. }
  43. getArrow(target: any) {
  44. if (this.isOpen()) {
  45. return this._current.pad;
  46. }
  47. var self = this;
  48. var overlays = this._overlays;
  49. var html = domify('<div class="ymArrow"></div>');
  50. var position = this._getPosition(target);
  51. domDelegate.bind(html, entrySelector, 'click', function (event) {
  52. self.trigger('click', event);
  53. });
  54. let newPosition = {
  55. position: {
  56. top: position.position.top + target.height / 2,
  57. left: position.position.left,
  58. },
  59. };
  60. var overlaysConfig = assign({ html: html }, this._overlaysConfig, newPosition);
  61. var overlaysConfig1 = assign({ html: html }, this._overlaysConfig, position);
  62. domDelegate.bind(html, '.rightArrow', 'click', function (event) {
  63. self._updateAndOpen(target);
  64. self.trigger('click', event);
  65. });
  66. domDelegate.bind(html, entrySelector, 'dragstart', function (event) {
  67. self.trigger('dragstart', event);
  68. });
  69. // stop propagation of mouse events
  70. domEvent.bind(html, 'mousedown', function (event: any) {
  71. event.stopPropagation();
  72. });
  73. var activeRootElement = this._canvas.getRootElement();
  74. this._overlayId = overlays.add(activeRootElement, 'context-pad', overlaysConfig);
  75. var arrow = overlays.get(this._overlayId);
  76. this._eventBus.fire('contextPad.create', { target: target, pad: arrow });
  77. return arrow;
  78. }
  79. getPad(target: any) {
  80. if (this.isOpen()) return this._current.pad;
  81. var self = this;
  82. var overlays = this._overlays;
  83. var html = domify('<div class="djs-context-pad"></div>');
  84. var position = this._getPosition(target);
  85. var overlaysConfig = assign(
  86. {
  87. html: html,
  88. },
  89. this._overlaysConfig,
  90. position,
  91. );
  92. domDelegate.bind(html, entrySelector, 'click', function (event) {
  93. self.trigger('click', event);
  94. });
  95. domDelegate.bind(html, entrySelector, 'dragstart', function (event) {
  96. self.trigger('dragstart', event);
  97. });
  98. // stop propagation of mouse events
  99. domEvent.bind(html, 'mousedown', function (event: any) {
  100. event.stopPropagation();
  101. });
  102. var activeRootElement = this._canvas.getRootElement();
  103. this._overlayId = overlays?.add(activeRootElement, 'context-pad', overlaysConfig);
  104. var pad = overlays.get(this._overlayId);
  105. this._eventBus.fire('contextPad.create', {
  106. target: target,
  107. pad: pad,
  108. });
  109. return pad;
  110. }
  111. // 重写父类contextPad样式
  112. _updateAndOpen(target: any) {
  113. var entries = this.getEntries(target),
  114. pad = this.getPad(target),
  115. html = pad.html,
  116. image;
  117. forEach(entries, (entry: any, id: any) => {
  118. let grouping = 'default',
  119. control = domify(entry.html || '<div class="entry" draggable="true"></div>'),
  120. container;
  121. let svg = domify(entry.html || `<span class='svgText' >${entry.title}</span>`);
  122. control.appendChild(svg);
  123. domAttr(control, 'data-action', id);
  124. container = domQuery('[data-group=' + escapeCSS(grouping) + ']', html);
  125. if (!container) {
  126. container = domify('<div class="group"></div>');
  127. domAttr(container, 'data-group', grouping);
  128. html.appendChild(container);
  129. }
  130. container.appendChild(control);
  131. if (entry.className) addClasses(control, entry.className);
  132. if (entry.title) domAttr(control, 'title', entry.title);
  133. if (entry.imageUrl) {
  134. image = domify('<img>');
  135. domAttr(image, 'src', entry.imageUrl);
  136. image.style.width = '100%';
  137. image.style.height = '100%';
  138. control.appendChild(image);
  139. }
  140. });
  141. domClasses(html).add('open');
  142. this._current = {
  143. target: target,
  144. entries: entries,
  145. pad: pad,
  146. };
  147. this._eventBus.fire('contextPad.open', { current: this._current });
  148. }
  149. }
  150. YmContextPad.$inject = ['canvas', 'config.contextPad', 'eventBus', 'overlays'];
  151. export default YmContextPad;