42aaade8852fde54550dfa0e2193f623.json 63 KB

1
  1. {"remainingRequest":"E:\\boman-framwork\\ruoyi-ui\\node_modules\\babel-loader\\lib\\index.js!E:\\boman-framwork\\ruoyi-ui\\node_modules\\eslint-loader\\index.js??ref--13-0!E:\\boman-framwork\\ruoyi-ui\\src\\utils\\flow-display.js","dependencies":[{"path":"E:\\boman-framwork\\ruoyi-ui\\src\\utils\\flow-display.js","mtime":1623215520361},{"path":"E:\\boman-framwork\\ruoyi-ui\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"E:\\boman-framwork\\ruoyi-ui\\node_modules\\babel-loader\\lib\\index.js","mtime":315532800000},{"path":"E:\\boman-framwork\\ruoyi-ui\\node_modules\\eslint-loader\\index.js","mtime":499162500000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:"use strict";

var _interopRequireDefault = require("E:/boman-framwork/ruoyi-ui/node_modules/@babel/runtime/helpers/interopRequireDefault").default;

Object.defineProperty(exports, "__esModule", {
  value: true
});
exports.default = void 0;

var _defineProperty2 = _interopRequireDefault(require("E:/boman-framwork/ruoyi-ui/node_modules/@babel/runtime/helpers/defineProperty"));

require("core-js/modules/es.string.split.js");

require("core-js/modules/es.regexp.exec.js");

require("core-js/modules/es.array.fill.js");

require("core-js/modules/es.array.map.js");

function FlowDisplay(diagramDiv, event) {
  var G = go.GraphObject.make;
  var _this = {};
  var _displayer = {};
  /** 处理传入事件 */

  if (!event) {
    event = {
      showEditNode: function showEditNode() {},
      SelectionDeleted: function SelectionDeleted() {},
      LinkDrawn: function LinkDrawn() {},
      externalobjectsdropped: function externalobjectsdropped() {}
    };
  }

  if (event.showEditNode) {
    //编辑节点
    _this.showEditNode = event.showEditNode;
  }

  if (event.SelectionDeleted) {
    //删除事件
    _this.SelectionDeleted = event.SelectionDeleted;
  }

  if (event.LinkDrawn) {
    //线的生成事件
    _this.LinkDrawn = event.LinkDrawn;
  }

  if (event.externalobjectsdropped) {
    //节点的生成事件
    _this.externalobjectsdropped = event.externalobjectsdropped;
  }
  /** --------public method----------------------------------------**/

  /**
   * 显示流程图
   * @param flowData  流程图json数据
   */


  this.loadFlow = function (flowData) {
    if (!flowData) return;
    _displayer.model = go.Model.fromJson(flowData);
    var pos = _displayer.model.modelData.position; // if (pos) _displayer.initialPosition = go.Point.parse(pos);

    this.diagram = _displayer; // 更改所有连线中间的文本背景色

    setLinkTextBg();
  };
  /**
   * 获取流程图数据
   * @returns {*}
   */


  this.getFlowData = function () {
    _displayer.model.modelData.position = go.Point.stringify(_displayer.position);
    return _displayer.model.toJson();
  };
  /**
   * 动画显示流程路径状态
   * strStepKeys 已经通过的流程节点key
   * isCompleted 流程是否已完成
   * isEnd 是否是已关闭流程，已关闭流程的待处理节点则为关闭状态
   */


  this.animateFlowPath = function (strStepKeys, errorPathIds, isCompleted, isEnd) {
    if (!strStepKeys) {
      return;
    }

    var stepKeys = strStepKeys.split(','); // 查找所有【已完成】步骤：【开始】-> 【已完成】（N个）

    var steps = findFinishedSteps(stepKeys, isCompleted); // 高亮所有“已完成”步骤

    showFinishedNodes(steps); //【开始】-> 【已完成】（N个）->【待处理】
    // 或
    //【开始】-> 【已完成】（N个）->【结束】

    var lastStep = findLastStep(stepKeys, steps, isCompleted, isEnd);
    steps.push(lastStep);

    if (!isCompleted) {
      // “待处理”步骤，加上闪烁动画
      loopRunningNode(lastStep, isEnd);
    } // 在连线上加闪烁动画


    if (errorPathIds && errorPathIds.length > 0) {
      var links = findFinishedLinks(lastStep);
      loopLinks(links);
    }
  }; // 当前画布实例

  /** --------public method-------------end---------------------------**/


  this.diagram = init(diagramDiv);
  /** --------private method----------------------------------------**/

  /**
   * 初始化流程设计器
   * @param divId 设计器Div
   */

  function init(divId) {
    _displayer = G(go.Diagram, divId, {
      allowDrop: false,
      allowSelect: false,
      allowHorizontalScroll: true,
      allowVerticalScroll: true,
      allowMove: false,
      allowLink: false,
      allowRelink: false,
      "draggingTool.dragsLink": false
    }); // 流程步骤的样式模板

    _displayer.nodeTemplate = makeNodeTemplate(); // 双击事件

    _displayer.addDiagramListener("ObjectDoubleClicked", onObjectDoubleClicked); // 添加开始节点


    _displayer.nodeTemplateMap.add("Start", G(go.Node, "Spot", {
      locationSpot: go.Spot.Center
    }, new go.Binding("location", "loc", go.Point.parse).makeTwoWay(go.Point.stringify), {
      selectable: true,
      selectionAdornmentTemplate: makeNodeSelectionAdornmentTemplate()
    }, new go.Binding("angle").makeTwoWay(), G(go.Panel, "Auto", {
      name: "PANEL"
    }, new go.Binding("desiredSize", "size", go.Size.parse).makeTwoWay(go.Size.stringify), G(go.Shape, "Circle", // default figure
    {
      portId: "",
      // the default port: if no spot on link data, use closest side
      name: "PIPE",
      fromLinkable: true,
      toLinkable: true,
      cursor: "pointer",
      fill: "#5F7790",
      // default color
      strokeWidth: 1,
      stroke: "#5F7790"
    }, new go.Binding("figure"), new go.Binding("stroke"), new go.Binding("strokeDashArray"), new go.Binding("strokeWidth"), new go.Binding("fill")), G(go.TextBlock, {
      font: "bold 11pt Helvetica, Arial, sans-serif",
      margin: 8,
      wrap: go.TextBlock.WrapFit,
      stroke: "white",
      overflow: go.TextBlock.OverflowEllipsis
    }, new go.Binding("text").makeTwoWay()) // {
    //     toolTip: G(go.Adornment, "Auto",
    //         G(go.Shape, { fill: "#FFFFCC" }),
    //         G(go.TextBlock, { margin: 4 },
    //             new go.Binding("text", "", nodeInfo))
    //     )
    // }
    ))); // 添加结束节点


    _displayer.nodeTemplateMap.add("End", G(go.Node, "Spot", {
      locationSpot: go.Spot.Center
    }, new go.Binding("location", "loc", go.Point.parse).makeTwoWay(go.Point.stringify), {
      selectable: true,
      selectionAdornmentTemplate: makeNodeSelectionAdornmentTemplate()
    }, new go.Binding("angle").makeTwoWay(), G(go.Panel, "Auto", {
      name: "PANEL"
    }, new go.Binding("desiredSize", "size", go.Size.parse).makeTwoWay(go.Size.stringify), G(go.Shape, "Circle", // default figure
    {
      portId: "",
      // the default port: if no spot on link data, use closest side
      name: "PIPE",
      fromLinkable: true,
      toLinkable: true,
      cursor: "pointer",
      fill: "#5F7790",
      // default color
      strokeWidth: 1,
      stroke: "#5F7790"
    }, new go.Binding("figure"), new go.Binding("stroke"), new go.Binding("strokeDashArray"), new go.Binding("strokeWidth"), new go.Binding("fill")), G(go.TextBlock, {
      font: "bold 11pt Helvetica, Arial, sans-serif",
      margin: 8,
      wrap: go.TextBlock.WrapFit,
      stroke: "white"
    }, new go.Binding("text").makeTwoWay()) // {
    //     toolTip: G(go.Adornment, "Auto",
    //         G(go.Shape, { fill: "#FFFFCC" }),
    //         G(go.TextBlock, { margin: 4 },
    //             new go.Binding("text", "", nodeInfo))
    //     )
    // }
    ))); // 流程连接线的样式模板


    _displayer.linkTemplate = makeLinkTemplate();
    return _displayer;
  }
  /**
   * 步骤图的样式模板
   * @returns {*}
   */


  function makeNodeTemplate() {
    var _G;

    return G(go.Node, "Spot", {
      locationSpot: go.Spot.Center
    }, new go.Binding("location", "loc", go.Point.parse).makeTwoWay(go.Point.stringify), {
      selectable: true,
      selectionAdornmentTemplate: makeNodeSelectionAdornmentTemplate()
    }, new go.Binding("angle").makeTwoWay(), G(go.Panel, "Auto", {
      name: "PANEL"
    }, new go.Binding("desiredSize", "size", go.Size.parse).makeTwoWay(go.Size.stringify), G(go.Shape, "RoundedRectangle", // default figure
    {
      portId: "",
      // the default port: if no spot on link data, use closest side
      name: "PIPE",
      fromLinkable: true,
      toLinkable: true,
      cursor: "pointer",
      fill: "white",
      // default color
      strokeWidth: 1,
      stroke: "#DCDEE2"
    }, new go.Binding("figure"), new go.Binding("stroke"), new go.Binding("strokeDashArray"), new go.Binding("strokeWidth"), new go.Binding("fill")), G(go.TextBlock, (_G = {
      font: "bold 11pt Helvetica, Arial, sans-serif",
      margin: 8,
      wrap: go.TextBlock.WrapFit,
      stroke: "#343434",
      textAlign: "center",
      alignment: go.Spot.Center,
      verticalAlignment: go.Spot.Center
    }, (0, _defineProperty2.default)(_G, "wrap", go.TextBlock.WrapFit), (0, _defineProperty2.default)(_G, "minSize", new go.Size(126, 27)), (0, _defineProperty2.default)(_G, "maxSize", new go.Size(126, NaN)), _G), new go.Binding("text").makeTwoWay()) // {
    //     toolTip: G(go.Adornment, "Auto",
    //         G(go.Shape, { fill: "#FFFFCC" }),
    //         G(go.TextBlock, { margin: 4 },
    //             new go.Binding("text", "", nodeInfo))
    //     )
    // }
    ));
  }
  /**
   * 选中节点的样式
   * @returns {*}
   */


  function makeNodeSelectionAdornmentTemplate() {
    return G(go.Adornment, "Auto", G(go.Shape, {
      fill: null,
      stroke: "deepskyblue",
      strokeWidth: 1.5,
      strokeDashArray: [4, 2]
    }), G(go.Placeholder));
  }
  /**
   * 流程图元素的双击事件
   * @param ev
   */


  function onObjectDoubleClicked(ev) {
    var part = ev.subject.part;
    showEditNode(part);
  }
  /**
   * 编辑节点信息
   */


  function showEditNode(node) {
    _this.showEditNode(node);

    return node;
  }
  /**
   * tooltip上显示的信息
   * @param d
   * @returns {string}
   */


  function nodeInfo(d) {
    if (!d.key) return "无key";
    return "编号：" + d.key;
  }
  /**
   * 定义连接线的样式模板
   * @returns {*}
   */


  function makeLinkTemplate() {
    return G(go.Link, {
      selectable: false
    }, {
      relinkableFrom: true,
      relinkableTo: true,
      reshapable: true
    }, {
      routing: go.Link.AvoidsNodes,
      curve: go.Link.JumpOver,
      corner: 5,
      toShortLength: 4
    }, new go.Binding("layerName", "color"), new go.Binding("zOrder"), // G(go.Shape, { isPanelMain: true, stroke: "black", strokeWidth: 3 }, new go.Binding("stroke"),new go.Binding("zOrder")),
    G(go.Shape, {
      isPanelMain: true,
      stroke: "#D5D5D5",
      strokeWidth: 2
    }), G(go.Shape, {
      isPanelMain: true,
      stroke: "#D5D5D5",
      strokeWidth: 1,
      name: "PIPE"
    }), G(go.Shape, {
      toArrow: "standard",
      stroke: null,
      fill: '#D5D5D5'
    }, new go.Binding("stroke"), new go.Binding("fill"), new go.Binding("zOrder")), G(go.Panel, "Auto", G(go.Shape, {
      fill: null,
      stroke: null
    }, new go.Binding("fill", "pFill"), new go.Binding("zOrder")), G(go.TextBlock, {
      textAlign: "center",
      font: "10pt helvetica, arial, sans-serif",
      stroke: "#555555",
      margin: 4
    }, new go.Binding("text", "text"), new go.Binding("zOrder"))));
  }
  /**
   * 返回所有【已完成】的步骤
   * @param stepKeys
   * @param isCompleted
   * @returns {Array}
   */


  function findFinishedSteps(stepKeys, isCompleted) {
    var arrStep = [];
    if (!stepKeys) return arrStep;
    var startStep = findStartStep(); // 【开始】步骤

    arrStep.push(startStep); // 【已完成】的步骤

    var finishedCount = stepKeys.length - 1; // 不包含最后一个“待处理“步骤

    if (isCompleted) {
      finishedCount = stepKeys.length; // 包含所有步骤
    }

    for (var i = 0; i < finishedCount; i++) {
      var stepKey = stepKeys[i];

      var step = _displayer.findNodeForKey(stepKey);

      if (!step) continue;
      arrStep.push(step);
    }

    return arrStep;
  }
  /**
   * 高亮“已完成”步骤
   * @param steps
   */


  function showFinishedNodes(steps) {
    if (!steps) return;

    for (var i = 0; i < steps.length; i++) {
      var step = steps[i]; // 步骤(去除开始和结束节点)

      if (step.data.type !== 1 && step.data.type !== 2) {
        _displayer.startTransaction("vacate");

        _displayer.model.setDataProperty(step.data, "fill", "rgba(9,161,85,0.04)");

        _displayer.model.setDataProperty(step.data, "stroke", "rgba(9,161,85,1)");

        _displayer.model.setDataProperty(step.data, "strokeWidth", 1);

        _displayer.commitTransaction("vacate");
      }
    }
  }
  /**
   *
   * 查找【开始】节点
   * @param {} steps
   * @returns {}
   */


  function findStartStep() {
    var startStep = null;

    _displayer.nodes.each(function (step) {
      if (step.data.hasOwnProperty('key') && step.data.key == -1) {
        startStep = step;
        return false;
      }
    });

    return startStep;
  }
  /**
   * 循环闪烁“已完成”步骤之间的连线
   * @param links
   */


  function loopLinks(links) {
    setTimeout(function () {
      showFinishedLinks(links); // “已完成”连线
    }, 300);
  }
  /**
   * 循环闪烁“待处理”步骤
   * @param node
   */


  function loopRunningNode(node, isEnd) {
    setTimeout(function () {
      showRunningNode(node, isEnd); // loopRunningNode(node);
    }, 200);
  }
  /**
   * 高亮“待处理”步骤
   * @param node
   */


  function showRunningNode(node, isEnd) {
    if (!node) return; // 去除结束节点和开始节点

    if (node.data.type === 1 || node.data.type === 2) {
      return;
    }

    if (!isEnd) {
      _displayer.startTransaction("vacate");

      _displayer.model.setDataProperty(node.data, "fill", node.data.fill === "#ff9001" ? "#ffB001" : "rgba(255,153,0,0.04)");

      _displayer.commitTransaction("vacate");
    } else {
      _displayer.startTransaction("vacate");

      _displayer.model.setDataProperty(node.data, "fill", node.data.fill === "#ff9001" ? "#ffB001" : "rgba(237,64,20,0.04)");

      _displayer.commitTransaction("vacate");
    } // 边框加上流水动画
    // var shape = node.findObject("PIPE");
    // var off = shape.strokeDashOffset - 2;
    // shape.strokeDashOffset = (off <= 0) ? 20 : off;

  }
  /**
   * 获取最后一个步骤（【待处理】或【结束】）
   * @param stepKeys
   * @param steps
   * @param isCompleted
   * @returns {*}
   */


  function findLastStep(stepKeys, steps, isCompleted, isEnd) {
    var lastStep;

    if (!isCompleted) {
      // 获取“待处理”步骤
      var lastKey = stepKeys[stepKeys.length - 1];

      var step = _displayer.findNodeForKey(lastKey);

      if (step.data.type === 1 || step.data.type === 2) {
        return step;
      }

      if (!isEnd) {
        _displayer.startTransaction("vacate");

        _displayer.model.setDataProperty(step.data, "stroke", "#FF9900");

        _displayer.model.setDataProperty(step.data, "strokeWidth", 1); // _displayer.model.setDataProperty(step.data, "strokeDashArray", [10, 10]);


        _displayer.commitTransaction("vacate");
      } else {
        _displayer.startTransaction("vacate");

        _displayer.model.setDataProperty(step.data, "stroke", "#ED4014");

        _displayer.model.setDataProperty(step.data, "strokeWidth", 1); // _displayer.model.setDataProperty(step.data, "strokeDashArray", [10, 10]);


        _displayer.commitTransaction("vacate");
      } //【开始】-> 【已完成】（N个）->【待处理】


      lastStep = step;
    } else {
      // 用最后一根连线获取【结束】步骤
      var lastFinishedStep = steps[steps.length - 1];
      var it = lastFinishedStep.findLinksOutOf();
      var lastLink = it.first();
      var endStep = lastLink.toNode; //【开始】-> 【已完成】（N个）->【结束】

      lastStep = endStep;
    }

    return lastStep;
  }
  /**
   * 查找错误连线
   * @param steps
   * @returns {Array}
   */


  function findFinishedLinks(lastStep) {
    var arrLinks = [];
    lastStep.findLinksOutOf().map(function (item) {
      arrLinks.push(item);
    });
    return arrLinks;
  }
  /**
   * 高亮所有“已完成”步骤的连线
   * @param links
   */


  function showFinishedLinks(links) {
    if (!links) return;

    for (var i = 0; i < links.length; i++) {
      // 连线
      var link = links[i];

      _displayer.startTransaction("vacate");

      _displayer.model.setDataProperty(link.data, "stroke", link.data.stroke === "#4fba4f" ? "#4fba4f" : "#ED4014");

      _displayer.model.setDataProperty(link.data, "fill", link.data.fill === "#4fba4f" ? "#4fba4f" : "#ED4014");

      _displayer.model.setDataProperty(link.data, "zOrder", 999);

      _displayer.commitTransaction("vacate"); // 置于最上层，防止被遮挡


      _displayer.startTransaction('modified zOrder');

      _displayer.model.setDataProperty(link.data, "zOrder", 1);

      _displayer.commitTransaction('modified zOrder'); // 连线加上流水动画


      var shape = link.findObject("PIPE");
      shape.stroke = '#ED4014';
      var off = shape.strokeDashOffset - 2;
      shape.strokeDashOffset = off <= 0 ? 20 : off;
    }
  }
  /**
   * 更改所有连线中间的文本背景色
   */


  function setLinkTextBg() {
    _displayer.links.each(function (link) {
      _displayer.startTransaction("vacate");

      if (link.data.text) {
        _displayer.model.setDataProperty(link.data, "pFill", window.go.GraphObject.make(go.Brush, "Radial", {
          0: "rgb(240, 240, 240)",
          0.3: "rgb(240, 240, 240)",
          1: "rgba(240, 240, 240, 0)"
        }));
      }

      _displayer.commitTransaction("vacate");
    });
  }
  /** --------private method------------------end----------------------**/


  return this;
}

var _default = FlowDisplay;
exports.default = _default;"},{"version":3,"sources":["E:/boman-framwork/ruoyi-ui/src/utils/flow-display.js"],"names":["FlowDisplay","diagramDiv","event","G","go","GraphObject","make","_this","_displayer","showEditNode","SelectionDeleted","LinkDrawn","externalobjectsdropped","loadFlow","flowData","model","Model","fromJson","pos","modelData","position","diagram","setLinkTextBg","getFlowData","Point","stringify","toJson","animateFlowPath","strStepKeys","errorPathIds","isCompleted","isEnd","stepKeys","split","steps","findFinishedSteps","showFinishedNodes","lastStep","findLastStep","push","loopRunningNode","length","links","findFinishedLinks","loopLinks","init","divId","Diagram","allowDrop","allowSelect","allowHorizontalScroll","allowVerticalScroll","allowMove","allowLink","allowRelink","nodeTemplate","makeNodeTemplate","addDiagramListener","onObjectDoubleClicked","nodeTemplateMap","add","Node","locationSpot","Spot","Center","Binding","parse","makeTwoWay","selectable","selectionAdornmentTemplate","makeNodeSelectionAdornmentTemplate","Panel","name","Size","Shape","portId","fromLinkable","toLinkable","cursor","fill","strokeWidth","stroke","TextBlock","font","margin","wrap","WrapFit","overflow","OverflowEllipsis","linkTemplate","makeLinkTemplate","textAlign","alignment","verticalAlignment","NaN","Adornment","strokeDashArray","Placeholder","ev","part","subject","node","nodeInfo","d","key","Link","relinkableFrom","relinkableTo","reshapable","routing","AvoidsNodes","curve","JumpOver","corner","toShortLength","isPanelMain","toArrow","arrStep","startStep","findStartStep","finishedCount","i","stepKey","step","findNodeForKey","data","type","startTransaction","setDataProperty","commitTransaction","nodes","each","hasOwnProperty","setTimeout","showFinishedLinks","showRunningNode","lastKey","lastFinishedStep","it","findLinksOutOf","lastLink","first","endStep","toNode","arrLinks","map","item","link","shape","findObject","off","strokeDashOffset","text","window","Brush"],"mappings":"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","sourcesContent":["function FlowDisplay (diagramDiv,event) {\r\n var G = go.GraphObject.make;\r\n var _this = {};\r\n var _displayer = {};\r\n\r\n /** 处理传入事件 */\r\n if(!event){\r\n event = {\r\n showEditNode:()=>{},\r\n SelectionDeleted:() => {},\r\n LinkDrawn:() => {},\r\n externalobjectsdropped: () => {}\r\n }\r\n }\r\n if(event.showEditNode){ //编辑节点\r\n _this.showEditNode = event.showEditNode\r\n }\r\n if(event.SelectionDeleted){ //删除事件\r\n _this.SelectionDeleted = event.SelectionDeleted\r\n }\r\n if(event.LinkDrawn){ //线的生成事件\r\n _this.LinkDrawn = event.LinkDrawn\r\n }\r\n if(event.externalobjectsdropped){ //节点的生成事件\r\n _this.externalobjectsdropped = event.externalobjectsdropped\r\n }\r\n\r\n /** --------public method----------------------------------------**/\r\n\r\n /**\r\n * 显示流程图\r\n * @param flowData 流程图json数据\r\n */\r\n this.loadFlow = function (flowData) {\r\n if(!flowData) return;\r\n\r\n _displayer.model = go.Model.fromJson(flowData);\r\n\r\n var pos = _displayer.model.modelData.position;\r\n // if (pos) _displayer.initialPosition = go.Point.parse(pos);\r\n\r\n\r\n this.diagram = _displayer\r\n\r\n // 更改所有连线中间的文本背景色\r\n setLinkTextBg();\r\n };\r\n\r\n /**\r\n * 获取流程图数据\r\n * @returns {*}\r\n */\r\n this.getFlowData = function () {\r\n _displayer.model.modelData.position = go.Point.stringify(_displayer.position);\r\n return _displayer.model.toJson();\r\n };\r\n\r\n /**\r\n * 动画显示流程路径状态\r\n * strStepKeys 已经通过的流程节点key\r\n * isCompleted 流程是否已完成\r\n * isEnd 是否是已关闭流程,已关闭流程的待处理节点则为关闭状态\r\n */\r\n this.animateFlowPath = function(strStepKeys, errorPathIds, isCompleted, isEnd) {\r\n if(!strStepKeys){\r\n return\r\n }\r\n var stepKeys = strStepKeys.split(',');\r\n \r\n // 查找所有【已完成】步骤:【开始】-> 【已完成】(N个)\r\n var steps = findFinishedSteps(stepKeys, isCompleted);\r\n // 高亮所有“已完成”步骤\r\n showFinishedNodes(steps);\r\n\r\n //【开始】-> 【已完成】(N个)->【待处理】\r\n // 或\r\n //【开始】-> 【已完成】(N个)->【结束】\r\n var lastStep = findLastStep(stepKeys, steps, isCompleted,isEnd);\r\n steps.push(lastStep);\r\n if (!isCompleted) {\r\n // “待处理”步骤,加上闪烁动画\r\n loopRunningNode(lastStep,isEnd);\r\n }\r\n\r\n // 在连线上加闪烁动画\r\n if(errorPathIds && errorPathIds.length > 0){\r\n var links = findFinishedLinks(lastStep);\r\n loopLinks(links);\r\n }\r\n \r\n };\r\n\r\n // 当前画布实例\r\n /** --------public method-------------end---------------------------**/\r\n\r\n this.diagram = init(diagramDiv);\r\n\r\n /** --------private method----------------------------------------**/\r\n\r\n /**\r\n * 初始化流程设计器\r\n * @param divId 设计器Div\r\n */\r\n function init(divId) {\r\n _displayer = G(go.Diagram, divId,\r\n {\r\n allowDrop: false,\r\n allowSelect: false,\r\n allowHorizontalScroll: true,\r\n allowVerticalScroll: true,\r\n allowMove: false,\r\n allowLink: false,\r\n allowRelink: false,\r\n \"draggingTool.dragsLink\": false\r\n });\r\n\r\n // 流程步骤的样式模板\r\n _displayer.nodeTemplate = makeNodeTemplate();\r\n\r\n // 双击事件\r\n _displayer.addDiagramListener(\"ObjectDoubleClicked\", onObjectDoubleClicked);\r\n \r\n\r\n // 添加开始节点\r\n _displayer.nodeTemplateMap.add(\"Start\",\r\n G(go.Node, \"Spot\",\r\n { locationSpot: go.Spot.Center },\r\n new go.Binding(\"location\", \"loc\", go.Point.parse).makeTwoWay(go.Point.stringify),\r\n { selectable: true, selectionAdornmentTemplate: makeNodeSelectionAdornmentTemplate() },\r\n new go.Binding(\"angle\").makeTwoWay(),\r\n G(go.Panel, \"Auto\",\r\n { name: \"PANEL\" },\r\n new go.Binding(\"desiredSize\", \"size\", go.Size.parse).makeTwoWay(go.Size.stringify),\r\n G(go.Shape, \"Circle\", // default figure\r\n {\r\n portId: \"\", // the default port: if no spot on link data, use closest side\r\n name: \"PIPE\",\r\n fromLinkable: true,\r\n toLinkable: true,\r\n cursor: \"pointer\",\r\n fill: \"#5F7790\", // default color\r\n strokeWidth: 1,\r\n stroke: \"#5F7790\"\r\n },\r\n new go.Binding(\"figure\"),\r\n new go.Binding(\"stroke\"),\r\n new go.Binding(\"strokeDashArray\"),\r\n new go.Binding(\"strokeWidth\"),\r\n new go.Binding(\"fill\")),\r\n G(go.TextBlock,\r\n {\r\n font: \"bold 11pt Helvetica, Arial, sans-serif\",\r\n margin:8,\r\n wrap: go.TextBlock.WrapFit,\r\n stroke: \"white\",\r\n overflow:go.TextBlock.OverflowEllipsis\r\n },\r\n new go.Binding(\"text\").makeTwoWay()),\r\n // {\r\n // toolTip: G(go.Adornment, \"Auto\",\r\n // G(go.Shape, { fill: \"#FFFFCC\" }),\r\n // G(go.TextBlock, { margin: 4 },\r\n // new go.Binding(\"text\", \"\", nodeInfo))\r\n // )\r\n // }\r\n )\r\n ));\r\n \r\n // 添加结束节点\r\n _displayer.nodeTemplateMap.add(\"End\",\r\n G(go.Node, \"Spot\",\r\n { locationSpot: go.Spot.Center },\r\n new go.Binding(\"location\", \"loc\", go.Point.parse).makeTwoWay(go.Point.stringify),\r\n { selectable: true, selectionAdornmentTemplate: makeNodeSelectionAdornmentTemplate() },\r\n new go.Binding(\"angle\").makeTwoWay(),\r\n G(go.Panel, \"Auto\",\r\n { name: \"PANEL\" },\r\n new go.Binding(\"desiredSize\", \"size\", go.Size.parse).makeTwoWay(go.Size.stringify),\r\n G(go.Shape, \"Circle\", // default figure\r\n {\r\n portId: \"\", // the default port: if no spot on link data, use closest side\r\n name: \"PIPE\",\r\n fromLinkable: true,\r\n toLinkable: true,\r\n cursor: \"pointer\",\r\n fill: \"#5F7790\", // default color\r\n strokeWidth: 1,\r\n stroke: \"#5F7790\"\r\n },\r\n new go.Binding(\"figure\"),\r\n new go.Binding(\"stroke\"),\r\n new go.Binding(\"strokeDashArray\"),\r\n new go.Binding(\"strokeWidth\"),\r\n new go.Binding(\"fill\")),\r\n G(go.TextBlock,\r\n {\r\n font: \"bold 11pt Helvetica, Arial, sans-serif\",\r\n margin: 8,\r\n wrap: go.TextBlock.WrapFit,\r\n stroke: \"white\"\r\n },\r\n new go.Binding(\"text\").makeTwoWay()),\r\n // {\r\n // toolTip: G(go.Adornment, \"Auto\",\r\n // G(go.Shape, { fill: \"#FFFFCC\" }),\r\n // G(go.TextBlock, { margin: 4 },\r\n // new go.Binding(\"text\", \"\", nodeInfo))\r\n // )\r\n // }\r\n )\r\n ));\r\n\r\n // 流程连接线的样式模板\r\n _displayer.linkTemplate = makeLinkTemplate();\r\n\r\n return _displayer\r\n }\r\n\r\n\r\n /**\r\n * 步骤图的样式模板\r\n * @returns {*}\r\n */\r\n function makeNodeTemplate(){\r\n return G(go.Node, \"Spot\",\r\n { locationSpot: go.Spot.Center },\r\n new go.Binding(\"location\", \"loc\", go.Point.parse).makeTwoWay(go.Point.stringify),\r\n { selectable: true, selectionAdornmentTemplate: makeNodeSelectionAdornmentTemplate() },\r\n new go.Binding(\"angle\").makeTwoWay(),\r\n G(go.Panel, \"Auto\",\r\n { name: \"PANEL\" },\r\n new go.Binding(\"desiredSize\", \"size\", go.Size.parse).makeTwoWay(go.Size.stringify),\r\n G(go.Shape, \"RoundedRectangle\", // default figure\r\n {\r\n portId: \"\", // the default port: if no spot on link data, use closest side\r\n name: \"PIPE\",\r\n fromLinkable: true,\r\n toLinkable: true,\r\n cursor: \"pointer\",\r\n fill: \"white\", // default color\r\n strokeWidth: 1,\r\n stroke: \"#DCDEE2\"\r\n },\r\n new go.Binding(\"figure\"),\r\n new go.Binding(\"stroke\"),\r\n new go.Binding(\"strokeDashArray\"),\r\n new go.Binding(\"strokeWidth\"),\r\n new go.Binding(\"fill\")),\r\n G(go.TextBlock,\r\n {\r\n font: \"bold 11pt Helvetica, Arial, sans-serif\",\r\n margin: 8,\r\n wrap: go.TextBlock.WrapFit,\r\n stroke: \"#343434\",\r\n textAlign: \"center\",\r\n alignment: go.Spot.Center,\r\n verticalAlignment: go.Spot.Center,\r\n wrap: go.TextBlock.WrapFit,\r\n minSize: new go.Size(126, 27),\r\n maxSize: new go.Size(126, NaN)\r\n },\r\n new go.Binding(\"text\").makeTwoWay()),\r\n // {\r\n // toolTip: G(go.Adornment, \"Auto\",\r\n // G(go.Shape, { fill: \"#FFFFCC\" }),\r\n // G(go.TextBlock, { margin: 4 },\r\n // new go.Binding(\"text\", \"\", nodeInfo))\r\n // )\r\n // }\r\n )\r\n );\r\n }\r\n\r\n /**\r\n * 选中节点的样式\r\n * @returns {*}\r\n */\r\n function makeNodeSelectionAdornmentTemplate(){\r\n return G(go.Adornment, \"Auto\",\r\n G(go.Shape, { fill: null, stroke: \"deepskyblue\", strokeWidth: 1.5, strokeDashArray: [4, 2] }),\r\n G(go.Placeholder)\r\n );\r\n }\r\n\r\n /**\r\n * 流程图元素的双击事件\r\n * @param ev\r\n */\r\n function onObjectDoubleClicked(ev) {\r\n var part = ev.subject.part;\r\n showEditNode(part);\r\n }\r\n\r\n /**\r\n * 编辑节点信息\r\n */\r\n function showEditNode(node) {\r\n _this.showEditNode(node)\r\n return node\r\n }\r\n\r\n /**\r\n * tooltip上显示的信息\r\n * @param d\r\n * @returns {string}\r\n */\r\n function nodeInfo(d) {\r\n if (!d.key) return \"无key\";\r\n return \"编号:\" + d.key;\r\n }\r\n\r\n /**\r\n * 定义连接线的样式模板\r\n * @returns {*}\r\n */\r\n function makeLinkTemplate(){\r\n return G(go.Link,\r\n { selectable: false },\r\n { relinkableFrom: true, relinkableTo: true, reshapable: true },\r\n {\r\n routing: go.Link.AvoidsNodes,\r\n curve: go.Link.JumpOver,\r\n corner: 5,\r\n toShortLength: 4\r\n },\r\n new go.Binding(\"layerName\", \"color\"),\r\n new go.Binding(\"zOrder\"),\r\n // G(go.Shape, { isPanelMain: true, stroke: \"black\", strokeWidth: 3 }, new go.Binding(\"stroke\"),new go.Binding(\"zOrder\")),\r\n G(go.Shape, { isPanelMain: true, stroke: \"#D5D5D5\", strokeWidth: 2 }),\r\n G(go.Shape, { isPanelMain: true, stroke: \"#D5D5D5\", strokeWidth: 1, name: \"PIPE\", }),\r\n G(go.Shape,\r\n { toArrow: \"standard\", stroke: null, fill: '#D5D5D5' }, new go.Binding(\"stroke\"), new go.Binding(\"fill\"), new go.Binding(\"zOrder\")),\r\n G(go.Panel, \"Auto\",\r\n G(go.Shape, {\r\n fill: null,\r\n stroke: null\r\n }, new go.Binding(\"fill\", \"pFill\"), new go.Binding(\"zOrder\")),\r\n G(go.TextBlock,\r\n {\r\n textAlign: \"center\",\r\n font: \"10pt helvetica, arial, sans-serif\",\r\n stroke: \"#555555\",\r\n margin: 4\r\n },\r\n new go.Binding(\"text\", \"text\"), new go.Binding(\"zOrder\"))\r\n )\r\n );\r\n }\r\n\r\n /**\r\n * 返回所有【已完成】的步骤\r\n * @param stepKeys\r\n * @param isCompleted\r\n * @returns {Array}\r\n */\r\n function findFinishedSteps(stepKeys, isCompleted) {\r\n\r\n var arrStep = [];\r\n\r\n if (!stepKeys) return arrStep;\r\n\r\n var startStep = findStartStep();// 【开始】步骤\r\n arrStep.push(startStep);\r\n\r\n // 【已完成】的步骤\r\n var finishedCount = stepKeys.length - 1;// 不包含最后一个“待处理“步骤\r\n if (isCompleted) {\r\n finishedCount = stepKeys.length;// 包含所有步骤\r\n }\r\n for (var i = 0; i < finishedCount; i++) {\r\n var stepKey = stepKeys[i];\r\n var step = _displayer.findNodeForKey(stepKey);\r\n if (!step) continue;\r\n\r\n arrStep.push(step);\r\n }\r\n return arrStep;\r\n }\r\n\r\n /**\r\n * 高亮“已完成”步骤\r\n * @param steps\r\n */\r\n function showFinishedNodes(steps) {\r\n\r\n if (!steps) return;\r\n for (var i = 0; i < steps.length; i++) {\r\n var step = steps[i];\r\n // 步骤(去除开始和结束节点)\r\n if(step.data.type !== 1 && step.data.type !== 2){\r\n _displayer.startTransaction(\"vacate\");\r\n _displayer.model.setDataProperty(step.data, \"fill\", \"rgba(9,161,85,0.04)\");\r\n _displayer.model.setDataProperty(step.data, \"stroke\", \"rgba(9,161,85,1)\");\r\n _displayer.model.setDataProperty(step.data, \"strokeWidth\", 1);\r\n _displayer.commitTransaction(\"vacate\");\r\n }\r\n \r\n \r\n }\r\n }\r\n\r\n /**\r\n *\r\n * 查找【开始】节点\r\n * @param {} steps\r\n * @returns {}\r\n */\r\n function findStartStep() {\r\n var startStep = null;\r\n _displayer.nodes.each(function(step) {\r\n if (step.data.hasOwnProperty('key') && step.data.key == -1) {\r\n startStep = step;\r\n return false;\r\n }\r\n });\r\n return startStep;\r\n }\r\n\r\n /**\r\n * 循环闪烁“已完成”步骤之间的连线\r\n * @param links\r\n */\r\n function loopLinks(links) {\r\n setTimeout(function () {\r\n showFinishedLinks(links);// “已完成”连线\r\n }, 300);\r\n }\r\n\r\n /**\r\n * 循环闪烁“待处理”步骤\r\n * @param node\r\n */\r\n function loopRunningNode(node,isEnd) {\r\n setTimeout(function () {\r\n showRunningNode(node,isEnd);\r\n // loopRunningNode(node);\r\n }, 200);\r\n }\r\n\r\n /**\r\n * 高亮“待处理”步骤\r\n * @param node\r\n */\r\n function showRunningNode(node,isEnd) {\r\n if (!node) return;\r\n // 去除结束节点和开始节点\r\n if(node.data.type === 1 || node.data.type === 2){\r\n return\r\n }\r\n if(!isEnd){\r\n _displayer.startTransaction(\"vacate\");\r\n _displayer.model.setDataProperty(node.data, \"fill\", (node.data.fill === \"#ff9001\") ? \"#ffB001\" : \"rgba(255,153,0,0.04)\");\r\n _displayer.commitTransaction(\"vacate\");\r\n }else{\r\n _displayer.startTransaction(\"vacate\");\r\n _displayer.model.setDataProperty(node.data, \"fill\", (node.data.fill === \"#ff9001\") ? \"#ffB001\" : \"rgba(237,64,20,0.04)\");\r\n _displayer.commitTransaction(\"vacate\");\r\n }\r\n \r\n \r\n\r\n // 边框加上流水动画\r\n // var shape = node.findObject(\"PIPE\");\r\n // var off = shape.strokeDashOffset - 2;\r\n // shape.strokeDashOffset = (off <= 0) ? 20 : off;\r\n }\r\n\r\n /**\r\n * 获取最后一个步骤(【待处理】或【结束】)\r\n * @param stepKeys\r\n * @param steps\r\n * @param isCompleted\r\n * @returns {*}\r\n */\r\n function findLastStep(stepKeys, steps, isCompleted, isEnd) {\r\n var lastStep;\r\n if (!isCompleted) {\r\n // 获取“待处理”步骤\r\n var lastKey = stepKeys[stepKeys.length - 1];\r\n var step = _displayer.findNodeForKey(lastKey);\r\n if(step.data.type === 1 || step.data.type === 2){\r\n\r\n return step\r\n }\r\n if(!isEnd){\r\n _displayer.startTransaction(\"vacate\");\r\n _displayer.model.setDataProperty(step.data, \"stroke\", \"#FF9900\");\r\n _displayer.model.setDataProperty(step.data, \"strokeWidth\", 1);\r\n // _displayer.model.setDataProperty(step.data, \"strokeDashArray\", [10, 10]);\r\n _displayer.commitTransaction(\"vacate\");\r\n }else{\r\n _displayer.startTransaction(\"vacate\");\r\n _displayer.model.setDataProperty(step.data, \"stroke\", \"#ED4014\");\r\n _displayer.model.setDataProperty(step.data, \"strokeWidth\", 1);\r\n // _displayer.model.setDataProperty(step.data, \"strokeDashArray\", [10, 10]);\r\n _displayer.commitTransaction(\"vacate\");\r\n }\r\n \r\n\r\n //【开始】-> 【已完成】(N个)->【待处理】\r\n lastStep = step;\r\n } else {\r\n // 用最后一根连线获取【结束】步骤\r\n var lastFinishedStep = steps[steps.length - 1];\r\n\r\n var it = lastFinishedStep.findLinksOutOf();\r\n var lastLink = it.first();\r\n var endStep = lastLink.toNode;\r\n\r\n //【开始】-> 【已完成】(N个)->【结束】\r\n lastStep = endStep;\r\n }\r\n\r\n return lastStep;\r\n }\r\n\r\n /**\r\n * 查找错误连线\r\n * @param steps\r\n * @returns {Array}\r\n */\r\n function findFinishedLinks(lastStep) {\r\n\r\n var arrLinks = [];\r\n lastStep.findLinksOutOf().map(item => {\r\n arrLinks.push(item)\r\n })\r\n\r\n return arrLinks;\r\n }\r\n\r\n /**\r\n * 高亮所有“已完成”步骤的连线\r\n * @param links\r\n */\r\n function showFinishedLinks(links) {\r\n\r\n if (!links) return;\r\n\r\n for (var i = 0; i < links.length; i++) {\r\n // 连线\r\n var link = links[i];\r\n _displayer.startTransaction(\"vacate\");\r\n _displayer.model.setDataProperty(link.data, \"stroke\", (link.data.stroke === \"#4fba4f\" ? \"#4fba4f\" : \"#ED4014\"));\r\n _displayer.model.setDataProperty(link.data, \"fill\", (link.data.fill === \"#4fba4f\" ? \"#4fba4f\" : \"#ED4014\"));\r\n _displayer.model.setDataProperty(link.data, \"zOrder\", 999);\r\n _displayer.commitTransaction(\"vacate\");\r\n\r\n // 置于最上层,防止被遮挡\r\n _displayer.startTransaction('modified zOrder');\r\n _displayer.model.setDataProperty(link.data, \"zOrder\", 1);\r\n _displayer.commitTransaction('modified zOrder');\r\n\r\n // 连线加上流水动画\r\n var shape = link.findObject(\"PIPE\");\r\n shape.stroke = '#ED4014'\r\n var off = shape.strokeDashOffset - 2;\r\n shape.strokeDashOffset = (off <= 0) ? 20 : off;\r\n }\r\n }\r\n\r\n /**\r\n * 更改所有连线中间的文本背景色\r\n */\r\n function setLinkTextBg() {\r\n _displayer.links.each(function (link) {\r\n _displayer.startTransaction(\"vacate\");\r\n if (link.data.text) {\r\n _displayer.model.setDataProperty(link.data, \"pFill\", window.go.GraphObject.make(go.Brush, \"Radial\", {\r\n 0: \"rgb(240, 240, 240)\",\r\n 0.3: \"rgb(240, 240, 240)\",\r\n 1: \"rgba(240, 240, 240, 0)\"\r\n }));\r\n }\r\n _displayer.commitTransaction(\"vacate\");\r\n });\r\n }\r\n\r\n /** --------private method------------------end----------------------**/\r\n\r\n return this;\r\n}\r\n\r\nexport default FlowDisplay\r\n"]}]}