button.ts 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. //
  2. import { append as svgAppend, attr as svgAttr, create as svgCreate } from 'tiny-svg';
  3. import { assign } from 'min-dash';
  4. import { query as domQuery } from 'min-dom';
  5. export default function createButton(element: any, ymCanvas: any) {
  6. var activeElement = document.getElementById('bpmnSequenceFlowActiveId');
  7. if (!activeElement) {
  8. if (element.type === 'bpmn:SequenceFlow') {
  9. // svgAttr(sequenceflowEnd, { d: 'M 1 5 L 11 10 L 1 15 Z' });
  10. const foreignObject: any = svgCreate('foreignObject', {
  11. class: 'startBody',
  12. x: 8,
  13. y: 40,
  14. width: 184,
  15. height: 38,
  16. });
  17. addMarker(
  18. 'bpmnSequenceFlowActiveId',
  19. {
  20. element: foreignObject,
  21. ref: { x: 11, y: 10 },
  22. scale: 0.5,
  23. attrs: {
  24. fill: 'rgb(24, 131, 255)',
  25. stroke: 'rgb(24, 131, 255)',
  26. },
  27. },
  28. ymCanvas,
  29. );
  30. }
  31. }
  32. }
  33. function addMarker(id: any, options: any, ymCanvas: any) {
  34. let attrs = assign(
  35. {
  36. fill: 'hsl(225, 10%, 15%)',
  37. strokeWidth: 1,
  38. strokeLinecap: 'round',
  39. strokeDasharray: 'none',
  40. },
  41. options.attrs,
  42. );
  43. let ref = options.ref || { x: 0, y: 0 };
  44. let scale = options.scale || 1;
  45. if (attrs.strokeDasharray === 'none') {
  46. attrs.strokeDasharray = [10000, 1];
  47. }
  48. let marker = svgCreate('marker');
  49. svgAttr(options.element, attrs);
  50. svgAppend(marker, options.element);
  51. svgAttr(marker, {
  52. id: id,
  53. viewBox: '0 0 20 20',
  54. refX: ref.x,
  55. refY: ref.y,
  56. markerWidth: 20 * scale,
  57. markerHeight: 20 * scale,
  58. orient: 'auto',
  59. });
  60. let defs = domQuery('defs', ymCanvas._svg);
  61. if (!defs) {
  62. defs = svgCreate('defs');
  63. svgAppend(ymCanvas._svg, defs);
  64. }
  65. svgAppend(defs, marker);
  66. // markers[id] = marker;
  67. }