maplayout.js 5.64 KB
layui.define(["jquery", "layer", "bootstrap"],
    function (exports) {
        var $ = layui.jquery;
        var layer = layui.layer;
        //初始化设计流程器
        $.fn.flowdesign = function (options) {
            var $frmpreview = $(this);
            if (!$frmpreview.attr('id')) {
                return false;
            }
            $frmpreview.html("");

            var defaultcnf = {
                width: 500,
                height: 400,
                haveHead: true,
                initLabelText: "地图编辑",
                haveTool: true,
                headLabel: true,
                headBtns: ["big", "small", "reset", "switch"
                ],
                toolBtns: [
                ],
                haveGroup: true,
                useOperStack: false,
            };
            if (options != undefined) {
                $.extend(defaultcnf, options);
            }

            var flowPanel = $.createGooFlow($(this), defaultcnf);
            flowPanel.setNodeRemarks({
                group: "编辑",
                user_cangchuqu: "仓储区",
                user_zhangaiqu: "障碍区",
                user_shengchanxian: "生产线",
                user_yunxingqu: "运行区",
                user_chongdianzhuang1:"充电桩",
                user_tingchequ: "停车区",
                user_diantiqu_xz: "电梯区",
                user_tishengjiqu_xz: "对接区",
                user_quliaoqu: "取料区",
                user_fangliaoqu: "放料区",
                user_rfid_yxd_0000: "RFID",
                user_fastmode: "快速模式",
            });

            flowPanel.setHeadToolsRemarks({
                undo: "撤销",
                redo: "重做",
                big: "放大",
                small: "缩小",
                reset: "还原",
                switch: "隐藏RFID",
                info: "显示未编辑的RFID"
            });

            if (options != undefined
                && options.flowcontent != undefined
                && options.flowcontent != null) {  //加载内容
                flowPanel.loadData(options.flowcontent);
            }

            //导出数据扩展方法
            //所有节点必须有进出线段
            //必须有开始结束节点(且只能为一个)
            //分流合流节点必须成对出现
            //分流合流节点必须一一对应且中间必须有且只能有一个普通节点
            //分流节点与合流节点之前的审核节点必须有且只能有一条出去和进来节点
            flowPanel.exportDataEx = function () {
                var data = flowPanel.exportData();
                return data;
            }

            flowPanel.onItemDbClick = function (id, type) {
                var obj = flowPanel.getItemInfo(id, type);
                switch (type) {
                    case "node":
                        options.OpenNode(id, obj);
                        break;
                    case "area":
                        if (obj.color.indexOf("user_rfid") > -1) {
                            options.OpenNode(id, obj);
                        }
                        else {
                            options.OpenArea(id, obj);
                        }

                        break;
                    default:
                        break;
                }
                return false;
            }

            flowPanel.onItemRightClick = function (id, type) {
                var obj = flowPanel.getItemInfo(id, type);
                switch (type) {
                    case "node":
                        options.OpenNode(id, obj);
                        break;
                    case "area":
                        if (obj.color.indexOf("user_rfid") > -1) {
                            options.OpenNode(id, obj, true);
                        }
                        else {
                            options.OpenArea(id, obj);
                        }

                        break;
                    default:
                        break;
                }
                return false;
            }

            var xyHtml = '<div style="position:absolute;left:450px;margin-top:-30px;padding:3px;z-index:1000;line-height:15px;">';
            xyHtml += '<div style="display: inline-block;"><span id = "xyHtml"></span></div></div>';
            $frmpreview.append(xyHtml);

            flowPanel.$workArea.on('mousemove', function (e) {
                if (!e) e = window.event;
                var X, Y;
                var ev = _mouseP(e), t = _elCsys(this);
                X = ev.x - t.left + this.parentNode.scrollLeft;
                Y = ev.y - t.top + this.parentNode.scrollTop;

                var new_X, new_Y;
                new_X = Math.floor(X / 30) * 30;
                new_Y = Math.floor(Y / 30) * 30;
                if ($("#xyHtml") != undefined) {
                    $("#xyHtml").html("【" + new_X + "," + new_Y + "】");
                }
            });

            return flowPanel;
        }

        exports('mappreview/maplayout');
    });

function _elCsys(dom) {
    var t = dom.offsetTop;
    var l = dom.offsetLeft;
    dom = dom.offsetParent;
    while (dom) {
        t += dom.offsetTop;
        l += dom.offsetLeft;
        dom = dom.offsetParent;
    }
    return { top: t, left: l };
}
//兼容各种浏览器的,获取鼠标真实位置
function _mouseP(ev) {
    if (!ev) ev = window.event;
    if (ev.pageX || ev.pageY) {
        return { x: ev.pageX, y: ev.pageY };
    }
    return {
        x: ev.clientX + document.documentElement.scrollLeft - document.body.clientLeft,
        y: ev.clientY + document.documentElement.scrollTop - document.body.clientTop
    };
}