UNPKG

ming-demo3

Version:
583 lines (517 loc) 21.3 kB
"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _react = _interopRequireWildcard(require("react")); var _env = _interopRequireDefault(require("../../../helpers/env")); var _SvgIcon = _interopRequireDefault(require("@mdf/metaui-web/lib/components/common/SvgIcon")); var _baseui = require("@mdf/baseui"); var _reactRedux = require("react-redux"); var _redux = require("redux"); var _uuid = _interopRequireDefault(require("uuid")); var portalactions = _interopRequireWildcard(require("../../../redux/portal")); function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } var G6 = process.env.__CLIENT__ && require('@antv/g6'); var dagre = require("dagre"); var ShowFlow = function (_Component) { (0, _inherits2["default"])(ShowFlow, _Component); function ShowFlow(props) { var _this; (0, _classCallCheck2["default"])(this, ShowFlow); _this = (0, _possibleConstructorReturn2["default"])(this, (0, _getPrototypeOf2["default"])(ShowFlow).call(this, props)); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleDblClick", function (i) { var gridModel = _this.props.parentViewModel.getGridModel(); gridModel.execute('dblClick', {}); }); _this.state = { billNumber: _this.props.data.billNum || "pu_arrivalorder", billId: _this.props.data.billId || 1220905394262272, childIds: _this.props.data.childIds || null, childKey: _this.props.data.childKey || null, jsonData: {}, viewModel: _this.props.data.parentViewModel, flowWidth: 1280 }; return _this; } (0, _createClass2["default"])(ShowFlow, [{ key: "componentWillReceiveProps", value: function componentWillReceiveProps(nextProps) { this.setState({ viewModel: nextProps.data.parentViewModel, flowWidth: nextProps.width }); if (!nextProps.callback || nextProps.callback === this.props.callback) return; cb.utils.confirm("\u786E\u5B9A\u8981".concat(nextProps.caption, "\u4E48"), function () { nextProps.callback(); }); } }, { key: "componentDidMount", value: function componentDidMount() { var that = this; var thisdata = {}; thisdata.billNumber = this.state.billNumber; thisdata.billId = this.state.billId; if (this.state.childKey !== null) { thisdata.childIds = this.state.childIds; thisdata.childKey = this.state.childKey; } var proxy = cb.rest.DynamicProxy.create({ map: { url: 'billrelation/map', method: 'POST' } }); function thisCallBack(err, res) { if (err) { console.log(err); return; } console.log(res); function getMaxFloor(treeData) { var floor = 0; var v = this; var max = 0; function each(data, floor) { data.forEach(function (e) { e.floor = floor; if (floor > max) { max = floor; } if (e.nodes && e.nodes.length > 0) { each(e.nodes, floor + 1); } }); } each(treeData, 1); return max; } var resu = getMaxFloor(res.upperNodes); var downresu = getMaxFloor(res.downNodes); var currentWidth = window.innerWidth / 2 - 115; var startX = currentWidth - 280 * resu - 115; G6.registerEdge('hvh', { draw: function draw(cfg, group) { var offset = 0; var MinOffset = 0; var startPoint = cfg.startPoint; var endPoint = cfg.endPoint; if ((startX + 280 < 0 || startX < 0) && endPoint.x - startPoint.x > 50) { offset = -230; } else if ((280 - startX < 115 || startX > 0) && endPoint.x - startPoint.x > 50) { MinOffset = 230; } var shape = group.addShape('path', { attrs: { stroke: '#D9D9D9', path: [['M', startPoint.x + MinOffset, startPoint.y], ['L', (endPoint.x + offset) / 3 + 2 / 3 * (startPoint.x + MinOffset), startPoint.y], ['L', (endPoint.x + offset) / 3 + 2 / 3 * (startPoint.x + MinOffset), endPoint.y], ['L', endPoint.x + offset - 4, endPoint.y]], endArrow: { path: [['M', -6, 6], ['L', 6, 0], ['L', -6, -6], ['A', 11, 11, 0, 0, 1, -6, 6], ['Z']], d: 6 } } }); return shape; } }); var data = { nodes: [], edges: [] }; var thisCount = 0; if (res) { data.nodes.push({ label: "".concat(res.billName), date: "".concat(res.vouchdate.substring(0, 10)), code: "".concat(res.billCode), number: "".concat(res.billNumber), menuCode: "".concat(res.menuCode), srvUrl: res.isCrossDomain && res.srvUrl, id: "".concat(thisCount), billId: "".concat(res.billId), name: "".concat(res.billName), type: 'center' }); if (res.downNodes) { handleDownNodes(res.downNodes, thisCount); } if (res.upperNodes) { handleUpperNodes(res.upperNodes, 0); } } function handleDownNodes(nodesData, count) { nodesData.forEach(function (item) { thisCount += 1; data.nodes.push({ label: "".concat(item.billName), date: "".concat(item.vouchdate.substring(0, 10)), code: "".concat(item.billCode), number: "".concat(item.billNumber), menuCode: "".concat(item.menuCode), srvUrl: item.isCrossDomain && item.srvUrl, id: "".concat(thisCount), billId: "".concat(item.billId), name: "".concat(item.billName) }); data.edges.push({ source: "".concat(count), target: "".concat(thisCount), shape: 'hvh' }); if (item.nodes) { handleDownNodes(item.nodes, thisCount); } }); } function handleUpperNodes(nodesData, parent) { nodesData.forEach(function (item) { thisCount += 1; data.nodes.push({ label: "".concat(item.billName), date: "".concat(item.vouchdate.substring(0, 10)), code: "".concat(item.billCode), number: "".concat(item.billNumber), menuCode: "".concat(item.menuCode), srvUrl: item.isCrossDomain && item.srvUrl, id: "".concat(thisCount), billId: "".concat(item.billId), name: "".concat(item.billName) }); data.edges.push({ source: "".concat(thisCount), target: "".concat(parent), shape: 'hvh' }); if (item.nodes) { handleUpperNodes(item.nodes, thisCount); } }); } var g = new dagre.graphlib.Graph(); g.setDefaultEdgeLabel(function () { return {}; }); g.setGraph({ rankdir: 'LR' }); data.nodes.forEach(function (node) { node.label = ""; g.setNode(node.id, { width: 230, height: 90 }); }); data.edges.forEach(function (edge) { g.setEdge(edge.source, edge.target); }); dagre.layout(g); var coord = void 0; g.nodes().forEach(function (node, i) { coord = g.node(node); data.nodes[i].x = coord.x; data.nodes[i].y = coord.y; }); g.edges().forEach(function (edge, i) { coord = g.edge(edge); data.edges[i].startPoint = coord.points[0]; data.edges[i].endPoint = coord.points[coord.points.length - 1]; data.edges[i].controlPoints = coord.points.slice(1, coord.points.length - 1); }); G6.registerNode('vocherrect', { drawShape: function drawShape(cfg, group) { var fillColor = '#FD9839'; var strokeColor = '#CDCDCD'; var centerNameColor = null; var centerCodeColor = null; var centerDateColor = null; if (cfg.type == 'center') { fillColor = '#9ECAFF'; strokeColor = '#9ECAFF'; centerNameColor = '#0072FF'; centerCodeColor = '#0072FF'; centerDateColor = '#5DA0FF'; } var rect = group.addShape('rect', { attrs: { x: startX, y: -20, width: 230, height: 90, radius: 3, stroke: strokeColor, fill: "l (0) 0:".concat(fillColor, " ") + 0.01 + ":".concat(fillColor, " ") + 0.01 + ':#fff', fillOpacity: 1, lineWidth: 1 } }); group.addShape('text', { attrs: { x: startX + 16, y: 10, fill: centerNameColor || '#333', text: "".concat(cfg.name), fontSize: 14, fontWeight: 510 } }); group.addShape('text', { attrs: { x: startX + 16, y: 18, fill: centerCodeColor || '#666666', text: "".concat(cfg.code), textBaseline: 'top', fontSize: 12 } }); group.addShape('text', { attrs: { x: startX + 16, y: 40, fill: centerDateColor || '#BAC0C7', text: "".concat(cfg.date), textBaseline: 'top', fontSize: 12 } }); if (cfg.type == 'center') { group.addShape('image', { attrs: { x: startX + 200.8, y: -26, width: 32, height: 30, img: '' } }); } return rect; } }, 'single-shape'); G6.registerBehavior('center-active', { getEvents: function getEvents() { return { 'node:mouseenter': 'onMouseenter', 'node:mouseleave': 'onMouseleave' }; }, onMouseenter: function onMouseenter(ev) { if (ev.item.getModel().type == 'center') { var item = graph.findById('0'); graph.update(item, { style: { stroke: '#0072FF', fill: 'l (0) 0:#0072FF ' + 0.01 + ':#0072FF ' + 0.01 + ':#fff', cursor: 'pointer' } }); } else { var _item = ev.item; graph.update(_item, { style: { stroke: '#FD9839', fill: 'l (0) 0:#FD9839 ' + 0.01 + ':#FD9839 ' + 0.01 + ':#fff', cursor: 'pointer' } }); } }, onMouseleave: function onMouseleave(ev) { if (ev.item.getModel().type == 'center') { var item = graph.findById('0'); graph.update(item, { style: { stroke: '#9ECAFF', fill: 'l (0) 0:#9ECAFF ' + 0.01 + ':#9ECAFF ' + 0.01 + ':#fff', cursor: 'default' } }); } else { var _item2 = ev.item; graph.update(_item2, { style: { stroke: '#CDCDCD', fill: 'l (0) 0:#FD9839 ' + 0.01 + ':#FD9839 ' + 0.01 + ':#fff', cursor: 'default' } }); } } }); var DELTA = 0.05; G6.registerBehavior('zoom-canvas', { getDefaultCfg: function getDefaultCfg() { return { sensitivity: 0.5, minZoom: 0.2, maxZoom: 1 }; }, getEvents: function getEvents() { return { wheel: 'onWheel' }; }, onWheel: function onWheel(e) { e.preventDefault(); if (!this.shouldUpdate.call(this, e)) { return; } var graph = this.graph; var canvas = graph.get('canvas'); var point = canvas.getPointByClient(e.clientX, e.clientY); var pixelRatio = canvas.get('pixelRatio'); var sensitivity = this.get('sensitivity'); var ratio = graph.getZoom(); if (e.wheelDelta < 0) { ratio = 1 - DELTA * sensitivity; } else { ratio = 1 + DELTA * sensitivity; } var zoom = ratio * graph.getZoom(); if (zoom < this.get('minZoom') || zoom > this.get('maxZoom')) { return; } graph.zoom(ratio, { x: point.x / pixelRatio, y: point.y / pixelRatio }); graph.paint(); graph.emit('wheelzoom', e); } }); var graph = new G6.Graph({ container: 'mountNode', width: window.innerWidth, height: window.innerHeight - 65, pixelRatio: 2, modes: { "default": ['drag-canvas', 'center-active', 'zoom-canvas'] }, defaultNode: { shape: 'vocherrect', anchorPoints: [[0, 0.5], [1, 0.5]] }, nodeStyle: { "default": {}, selected: { lineWidth: 2, fillOpacity: 0.8, stroke: '#000' }, active: { lineWidth: 1.5, stroke: '#505766', cursor: 'pointer' } }, defaultEdge: { shape: 'hvh' }, edgeStyle: { "default": { endArrow: true, lineWidth: 2, stroke: '#ccc' } } }); graph.data(data); graph.on('node:click', function (i) { var parent = that.state.viewModel; var params = { mode: _env["default"].VOUCHER_STATE_EDIT, id: i.item._cfg.model.billId, readOnly: true }; var dt = { billtype: 'voucher', billno: i.item._cfg.model.number, billid: i.item._cfg.model.billId }; var tempCustomCode = (0, _uuid["default"])(); if (window.parent !== window && window.jDiwork) { window.jDiwork.openService(i.item._cfg.model.menuCode, dt, { code: tempCustomCode }); } else { if (i.item._cfg.model.srvUrl) { cb.utils.getWebUrl(i.item._cfg.model.srvUrl, "/meta/voucher/".concat(dt.billno, "/").concat(dt.billid), function (menuUrl) { var random = (0, _uuid["default"])(); menuUrl += "&random=".concat(random); cb.loader.runCommandLine('menu', { menuId: random, userClick: true, viewType: 'external', menuUrl: menuUrl }, parent); }); } else { dt.params = params; cb.loader.runCommandLine('bill', dt, parent); } } }); graph.render(); if (startX < -115 || downresu > 1) { graph.fitView(); if (graph.getZoom() > 1) { graph.zoomTo(1); } } } proxy.map(thisdata, thisCallBack); } }, { key: "handleClick", value: function handleClick(index) { this.props.delItem(index); this.state.viewModel.execute('back'); } }, { key: "render", value: function render() { var _this2 = this; var index = this.props.index; return _react["default"].createElement("div", null, _react["default"].createElement("div", { className: "voucher-back-button-wrapper" }, _react["default"].createElement(_baseui.Button, { onClick: function onClick() { return _this2.handleClick(index); } }, _react["default"].createElement(_SvgIcon["default"], { type: "rollback" }), _react["default"].createElement("span", { className: "voucher-rollback" }, "\u8FD4\u56DE"))), _react["default"].createElement("div", { className: "voucher-showflow-content-wrapper" }, _react["default"].createElement("div", { id: "mountNode" }))); } }]); return ShowFlow; }(_react.Component); var mapStateToProps = function mapStateToProps(state) { return { portal: state.portal.toJS() }; }; function mapDispatchToProps(dispatch) { return _objectSpread({}, (0, _redux.bindActionCreators)(portalactions, dispatch)); } var _default = (0, _reactRedux.connect)(mapStateToProps, mapDispatchToProps)(ShowFlow); exports["default"] = _default; //# sourceMappingURL=showflow.js.map