| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983 | /* * JQuery zTree core v3.5.37 * http://treejs.cn/ * * Copyright (c) 2010 Hunter.z * * Licensed same as jquery - MIT License * http://www.opensource.org/licenses/mit-license.php * * email: hunter.z@263.net * Date: 2018-08-21 */(function ($) {    var settings = {}, roots = {}, caches = {},        //default consts of core        _consts = {            className: {                BUTTON: "button",                LEVEL: "level",                ICO_LOADING: "ico_loading",                SWITCH: "switch",                NAME: 'node_name'            },            event: {                NODECREATED: "ztree_nodeCreated",                CLICK: "ztree_click",                EXPAND: "ztree_expand",                COLLAPSE: "ztree_collapse",                ASYNC_SUCCESS: "ztree_async_success",                ASYNC_ERROR: "ztree_async_error",                REMOVE: "ztree_remove",                SELECTED: "ztree_selected",                UNSELECTED: "ztree_unselected"            },            id: {                A: "_a",                ICON: "_ico",                SPAN: "_span",                SWITCH: "_switch",                UL: "_ul"            },            line: {                ROOT: "root",                ROOTS: "roots",                CENTER: "center",                BOTTOM: "bottom",                NOLINE: "noline",                LINE: "line"            },            folder: {                OPEN: "open",                CLOSE: "close",                DOCU: "docu"            },            node: {                CURSELECTED: "curSelectedNode"            }        },        //default setting of core        _setting = {            treeId: "",            treeObj: null,            view: {                addDiyDom: null,                autoCancelSelected: true,                dblClickExpand: true,                expandSpeed: "fast",                fontCss: {},                nameIsHTML: false,                selectedMulti: true,                showIcon: true,                showLine: true,                showTitle: true,                txtSelectedEnable: false            },            data: {                key: {                    isParent: "isParent",                    children: "children",                    name: "name",                    title: "",                    url: "url",                    icon: "icon"                },                simpleData: {                    enable: false,                    idKey: "id",                    pIdKey: "pId",                    rootPId: null                },                keep: {                    parent: false,                    leaf: false                }            },            async: {                enable: false,                contentType: "application/x-www-form-urlencoded",                type: "post",                dataType: "text",                headers: {},                xhrFields: {},                url: "",                autoParam: [],                otherParam: [],                dataFilter: null            },            callback: {                beforeAsync: null,                beforeClick: null,                beforeDblClick: null,                beforeRightClick: null,                beforeMouseDown: null,                beforeMouseUp: null,                beforeExpand: null,                beforeCollapse: null,                beforeRemove: null,                onAsyncError: null,                onAsyncSuccess: null,                onNodeCreated: null,                onClick: null,                onDblClick: null,                onRightClick: null,                onMouseDown: null,                onMouseUp: null,                onExpand: null,                onCollapse: null,                onRemove: null            }        },        //default root of core        //zTree use root to save full data        _initRoot = function (setting) {            var r = data.getRoot(setting);            if (!r) {                r = {};                data.setRoot(setting, r);            }            data.nodeChildren(setting, r, []);            r.expandTriggerFlag = false;            r.curSelectedList = [];            r.noSelection = true;            r.createdNodes = [];            r.zId = 0;            r._ver = (new Date()).getTime();        },        //default cache of core        _initCache = function (setting) {            var c = data.getCache(setting);            if (!c) {                c = {};                data.setCache(setting, c);            }            c.nodes = [];            c.doms = [];        },        //default bindEvent of core        _bindEvent = function (setting) {            var o = setting.treeObj,                c = consts.event;            o.bind(c.NODECREATED, function (event, treeId, node) {                tools.apply(setting.callback.onNodeCreated, [event, treeId, node]);            });            o.bind(c.CLICK, function (event, srcEvent, treeId, node, clickFlag) {                tools.apply(setting.callback.onClick, [srcEvent, treeId, node, clickFlag]);            });            o.bind(c.EXPAND, function (event, treeId, node) {                tools.apply(setting.callback.onExpand, [event, treeId, node]);            });            o.bind(c.COLLAPSE, function (event, treeId, node) {                tools.apply(setting.callback.onCollapse, [event, treeId, node]);            });            o.bind(c.ASYNC_SUCCESS, function (event, treeId, node, msg) {                tools.apply(setting.callback.onAsyncSuccess, [event, treeId, node, msg]);            });            o.bind(c.ASYNC_ERROR, function (event, treeId, node, XMLHttpRequest, textStatus, errorThrown) {                tools.apply(setting.callback.onAsyncError, [event, treeId, node, XMLHttpRequest, textStatus, errorThrown]);            });            o.bind(c.REMOVE, function (event, treeId, treeNode) {                tools.apply(setting.callback.onRemove, [event, treeId, treeNode]);            });            o.bind(c.SELECTED, function (event, treeId, node) {                tools.apply(setting.callback.onSelected, [treeId, node]);            });            o.bind(c.UNSELECTED, function (event, treeId, node) {                tools.apply(setting.callback.onUnSelected, [treeId, node]);            });        },        _unbindEvent = function (setting) {            var o = setting.treeObj,                c = consts.event;            o.unbind(c.NODECREATED)                .unbind(c.CLICK)                .unbind(c.EXPAND)                .unbind(c.COLLAPSE)                .unbind(c.ASYNC_SUCCESS)                .unbind(c.ASYNC_ERROR)                .unbind(c.REMOVE)                .unbind(c.SELECTED)                .unbind(c.UNSELECTED);        },        //default event proxy of core        _eventProxy = function (event) {            var target = event.target,                setting = data.getSetting(event.data.treeId),                tId = "", node = null,                nodeEventType = "", treeEventType = "",                nodeEventCallback = null, treeEventCallback = null,                tmp = null;            if (tools.eqs(event.type, "mousedown")) {                treeEventType = "mousedown";            } else if (tools.eqs(event.type, "mouseup")) {                treeEventType = "mouseup";            } else if (tools.eqs(event.type, "contextmenu")) {                treeEventType = "contextmenu";            } else if (tools.eqs(event.type, "click")) {                if (tools.eqs(target.tagName, "span") && target.getAttribute("treeNode" + consts.id.SWITCH) !== null) {                    tId = tools.getNodeMainDom(target).id;                    nodeEventType = "switchNode";                } else {                    tmp = tools.getMDom(setting, target, [{tagName: "a", attrName: "treeNode" + consts.id.A}]);                    if (tmp) {                        tId = tools.getNodeMainDom(tmp).id;                        nodeEventType = "clickNode";                    }                }            } else if (tools.eqs(event.type, "dblclick")) {                treeEventType = "dblclick";                tmp = tools.getMDom(setting, target, [{tagName: "a", attrName: "treeNode" + consts.id.A}]);                if (tmp) {                    tId = tools.getNodeMainDom(tmp).id;                    nodeEventType = "switchNode";                }            }            if (treeEventType.length > 0 && tId.length == 0) {                tmp = tools.getMDom(setting, target, [{tagName: "a", attrName: "treeNode" + consts.id.A}]);                if (tmp) {                    tId = tools.getNodeMainDom(tmp).id;                }            }            // event to node            if (tId.length > 0) {                node = data.getNodeCache(setting, tId);                switch (nodeEventType) {                    case "switchNode" :                        var isParent = data.nodeIsParent(setting, node);                        if (!isParent) {                            nodeEventType = "";                        } else if (tools.eqs(event.type, "click")                            || (tools.eqs(event.type, "dblclick") && tools.apply(setting.view.dblClickExpand, [setting.treeId, node], setting.view.dblClickExpand))) {                            nodeEventCallback = handler.onSwitchNode;                        } else {                            nodeEventType = "";                        }                        break;                    case "clickNode" :                        nodeEventCallback = handler.onClickNode;                        break;                }            }            // event to zTree            switch (treeEventType) {                case "mousedown" :                    treeEventCallback = handler.onZTreeMousedown;                    break;                case "mouseup" :                    treeEventCallback = handler.onZTreeMouseup;                    break;                case "dblclick" :                    treeEventCallback = handler.onZTreeDblclick;                    break;                case "contextmenu" :                    treeEventCallback = handler.onZTreeContextmenu;                    break;            }            var proxyResult = {                stop: false,                node: node,                nodeEventType: nodeEventType,                nodeEventCallback: nodeEventCallback,                treeEventType: treeEventType,                treeEventCallback: treeEventCallback            };            return proxyResult        },        //default init node of core        _initNode = function (setting, level, n, parentNode, isFirstNode, isLastNode, openFlag) {            if (!n) return;            var r = data.getRoot(setting),                children = data.nodeChildren(setting, n);            n.level = level;            n.tId = setting.treeId + "_" + (++r.zId);            n.parentTId = parentNode ? parentNode.tId : null;            n.open = (typeof n.open == "string") ? tools.eqs(n.open, "true") : !!n.open;            var isParent = data.nodeIsParent(setting, n);            if (tools.isArray(children) &&                !(isParent === false || (typeof isParent == "string" && tools.eqs(isParent, "false")))) {                data.nodeIsParent(setting, n, true);                n.zAsync = true;            } else {                isParent = data.nodeIsParent(setting, n, isParent);                n.open = (isParent && !setting.async.enable) ? n.open : false;                n.zAsync = !isParent;            }            n.isFirstNode = isFirstNode;            n.isLastNode = isLastNode;            n.getParentNode = function () {                return data.getNodeCache(setting, n.parentTId);            };            n.getPreNode = function () {                return data.getPreNode(setting, n);            };            n.getNextNode = function () {                return data.getNextNode(setting, n);            };            n.getIndex = function () {                return data.getNodeIndex(setting, n);            };            n.getPath = function () {                return data.getNodePath(setting, n);            };            n.isAjaxing = false;            data.fixPIdKeyValue(setting, n);        },        _init = {            bind: [_bindEvent],            unbind: [_unbindEvent],            caches: [_initCache],            nodes: [_initNode],            proxys: [_eventProxy],            roots: [_initRoot],            beforeA: [],            afterA: [],            innerBeforeA: [],            innerAfterA: [],            zTreeTools: []        },        //method of operate data        data = {            addNodeCache: function (setting, node) {                data.getCache(setting).nodes[data.getNodeCacheId(node.tId)] = node;            },            getNodeCacheId: function (tId) {                return tId.substring(tId.lastIndexOf("_") + 1);            },            addAfterA: function (afterA) {                _init.afterA.push(afterA);            },            addBeforeA: function (beforeA) {                _init.beforeA.push(beforeA);            },            addInnerAfterA: function (innerAfterA) {                _init.innerAfterA.push(innerAfterA);            },            addInnerBeforeA: function (innerBeforeA) {                _init.innerBeforeA.push(innerBeforeA);            },            addInitBind: function (bindEvent) {                _init.bind.push(bindEvent);            },            addInitUnBind: function (unbindEvent) {                _init.unbind.push(unbindEvent);            },            addInitCache: function (initCache) {                _init.caches.push(initCache);            },            addInitNode: function (initNode) {                _init.nodes.push(initNode);            },            addInitProxy: function (initProxy, isFirst) {                if (!!isFirst) {                    _init.proxys.splice(0, 0, initProxy);                } else {                    _init.proxys.push(initProxy);                }            },            addInitRoot: function (initRoot) {                _init.roots.push(initRoot);            },            addNodesData: function (setting, parentNode, index, nodes) {                var children = data.nodeChildren(setting, parentNode), params;                if (!children) {                    children = data.nodeChildren(setting, parentNode, []);                    index = -1;                } else if (index >= children.length) {                    index = -1;                }                if (children.length > 0 && index === 0) {                    children[0].isFirstNode = false;                    view.setNodeLineIcos(setting, children[0]);                } else if (children.length > 0 && index < 0) {                    children[children.length - 1].isLastNode = false;                    view.setNodeLineIcos(setting, children[children.length - 1]);                }                data.nodeIsParent(setting, parentNode, true);                if (index < 0) {                    data.nodeChildren(setting, parentNode, children.concat(nodes));                } else {                    params = [index, 0].concat(nodes);                    children.splice.apply(children, params);                }            },            addSelectedNode: function (setting, node) {                var root = data.getRoot(setting);                if (!data.isSelectedNode(setting, node)) {                    root.curSelectedList.push(node);                }            },            addCreatedNode: function (setting, node) {                if (!!setting.callback.onNodeCreated || !!setting.view.addDiyDom) {                    var root = data.getRoot(setting);                    root.createdNodes.push(node);                }            },            addZTreeTools: function (zTreeTools) {                _init.zTreeTools.push(zTreeTools);            },            exSetting: function (s) {                $.extend(true, _setting, s);            },            fixPIdKeyValue: function (setting, node) {                if (setting.data.simpleData.enable) {                    node[setting.data.simpleData.pIdKey] = node.parentTId ? node.getParentNode()[setting.data.simpleData.idKey] : setting.data.simpleData.rootPId;                }            },            getAfterA: function (setting, node, array) {                for (var i = 0, j = _init.afterA.length; i < j; i++) {                    _init.afterA[i].apply(this, arguments);                }            },            getBeforeA: function (setting, node, array) {                for (var i = 0, j = _init.beforeA.length; i < j; i++) {                    _init.beforeA[i].apply(this, arguments);                }            },            getInnerAfterA: function (setting, node, array) {                for (var i = 0, j = _init.innerAfterA.length; i < j; i++) {                    _init.innerAfterA[i].apply(this, arguments);                }            },            getInnerBeforeA: function (setting, node, array) {                for (var i = 0, j = _init.innerBeforeA.length; i < j; i++) {                    _init.innerBeforeA[i].apply(this, arguments);                }            },            getCache: function (setting) {                return caches[setting.treeId];            },            getNodeIndex: function (setting, node) {                if (!node) return null;                var p = node.parentTId ? node.getParentNode() : data.getRoot(setting),                    children = data.nodeChildren(setting, p);                for (var i = 0, l = children.length - 1; i <= l; i++) {                    if (children[i] === node) {                        return i;                    }                }                return -1;            },            getNextNode: function (setting, node) {                if (!node) return null;                var p = node.parentTId ? node.getParentNode() : data.getRoot(setting),                    children = data.nodeChildren(setting, p);                for (var i = 0, l = children.length - 1; i <= l; i++) {                    if (children[i] === node) {                        return (i == l ? null : children[i + 1]);                    }                }                return null;            },            getNodeByParam: function (setting, nodes, key, value) {                if (!nodes || !key) return null;                for (var i = 0, l = nodes.length; i < l; i++) {                    var node = nodes[i];                    if (node[key] == value) {                        return nodes[i];                    }                    var children = data.nodeChildren(setting, node);                    var tmp = data.getNodeByParam(setting, children, key, value);                    if (tmp) return tmp;                }                return null;            },            getNodeCache: function (setting, tId) {                if (!tId) return null;                var n = caches[setting.treeId].nodes[data.getNodeCacheId(tId)];                return n ? n : null;            },            getNodePath: function (setting, node) {                if (!node) return null;                var path;                if (node.parentTId) {                    path = node.getParentNode().getPath();                } else {                    path = [];                }                if (path) {                    path.push(node);                }                return path;            },            getNodes: function (setting) {                return data.nodeChildren(setting, data.getRoot(setting));            },            getNodesByParam: function (setting, nodes, key, value) {                if (!nodes || !key) return [];                var result = [];                for (var i = 0, l = nodes.length; i < l; i++) {                    var node = nodes[i];                    if (node[key] == value) {                        result.push(node);                    }                    var children = data.nodeChildren(setting, node);                    result = result.concat(data.getNodesByParam(setting, children, key, value));                }                return result;            },            getNodesByParamFuzzy: function (setting, nodes, key, value) {                if (!nodes || !key) return [];                var result = [];                value = value.toLowerCase();                for (var i = 0, l = nodes.length; i < l; i++) {                    var node = nodes[i];                    if (typeof node[key] == "string" && nodes[i][key].toLowerCase().indexOf(value) > -1) {                        result.push(node);                    }                    var children = data.nodeChildren(setting, node);                    result = result.concat(data.getNodesByParamFuzzy(setting, children, key, value));                }                return result;            },            getNodesByFilter: function (setting, nodes, filter, isSingle, invokeParam) {                if (!nodes) return (isSingle ? null : []);                var result = isSingle ? null : [];                for (var i = 0, l = nodes.length; i < l; i++) {                    var node = nodes[i];                    if (tools.apply(filter, [node, invokeParam], false)) {                        if (isSingle) {                            return node;                        }                        result.push(node);                    }                    var children = data.nodeChildren(setting, node);                    var tmpResult = data.getNodesByFilter(setting, children, filter, isSingle, invokeParam);                    if (isSingle && !!tmpResult) {                        return tmpResult;                    }                    result = isSingle ? tmpResult : result.concat(tmpResult);                }                return result;            },            getPreNode: function (setting, node) {                if (!node) return null;                var p = node.parentTId ? node.getParentNode() : data.getRoot(setting),                    children = data.nodeChildren(setting, p);                for (var i = 0, l = children.length; i < l; i++) {                    if (children[i] === node) {                        return (i == 0 ? null : children[i - 1]);                    }                }                return null;            },            getRoot: function (setting) {                return setting ? roots[setting.treeId] : null;            },            getRoots: function () {                return roots;            },            getSetting: function (treeId) {                return settings[treeId];            },            getSettings: function () {                return settings;            },            getZTreeTools: function (treeId) {                var r = this.getRoot(this.getSetting(treeId));                return r ? r.treeTools : null;            },            initCache: function (setting) {                for (var i = 0, j = _init.caches.length; i < j; i++) {                    _init.caches[i].apply(this, arguments);                }            },            initNode: function (setting, level, node, parentNode, preNode, nextNode) {                for (var i = 0, j = _init.nodes.length; i < j; i++) {                    _init.nodes[i].apply(this, arguments);                }            },            initRoot: function (setting) {                for (var i = 0, j = _init.roots.length; i < j; i++) {                    _init.roots[i].apply(this, arguments);                }            },            isSelectedNode: function (setting, node) {                var root = data.getRoot(setting);                for (var i = 0, j = root.curSelectedList.length; i < j; i++) {                    if (node === root.curSelectedList[i]) return true;                }                return false;            },            nodeChildren: function (setting, node, newChildren) {                if (!node) {                    return null;                }                var key = setting.data.key.children;                if (typeof newChildren !== 'undefined') {                    node[key] = newChildren;                }                return node[key];            },            nodeIsParent: function (setting, node, newIsParent) {                if (!node) {                    return false;                }                var key = setting.data.key.isParent;                if (typeof newIsParent !== 'undefined') {                    if (typeof newIsParent === "string") {                        newIsParent = tools.eqs(newIsParent, "true");                    }                    newIsParent = !!newIsParent;                    node[key] = newIsParent;                }                return node[key];            },            nodeName: function (setting, node, newName) {                var key = setting.data.key.name;                if (typeof newName !== 'undefined') {                    node[key] = newName;                }                return "" + node[key];            },            nodeTitle: function (setting, node) {                var t = setting.data.key.title === "" ? setting.data.key.name : setting.data.key.title;                return "" + node[t];            },            removeNodeCache: function (setting, node) {                var children = data.nodeChildren(setting, node);                if (children) {                    for (var i = 0, l = children.length; i < l; i++) {                        data.removeNodeCache(setting, children[i]);                    }                }                data.getCache(setting).nodes[data.getNodeCacheId(node.tId)] = null;            },            removeSelectedNode: function (setting, node) {                var root = data.getRoot(setting);                for (var i = 0, j = root.curSelectedList.length; i < j; i++) {                    if (node === root.curSelectedList[i] || !data.getNodeCache(setting, root.curSelectedList[i].tId)) {                        root.curSelectedList.splice(i, 1);                        setting.treeObj.trigger(consts.event.UNSELECTED, [setting.treeId, node]);                        i--;                        j--;                    }                }            },            setCache: function (setting, cache) {                caches[setting.treeId] = cache;            },            setRoot: function (setting, root) {                roots[setting.treeId] = root;            },            setZTreeTools: function (setting, zTreeTools) {                for (var i = 0, j = _init.zTreeTools.length; i < j; i++) {                    _init.zTreeTools[i].apply(this, arguments);                }            },            transformToArrayFormat: function (setting, nodes) {                if (!nodes) return [];                var r = [];                if (tools.isArray(nodes)) {                    for (var i = 0, l = nodes.length; i < l; i++) {                        var node = nodes[i];                        _do(node);                    }                } else {                    _do(nodes);                }                return r;                function _do(_node) {                    r.push(_node);                    var children = data.nodeChildren(setting, _node);                    if (children) {                        r = r.concat(data.transformToArrayFormat(setting, children));                    }                }            },            transformTozTreeFormat: function (setting, sNodes) {                var i, l,                    key = setting.data.simpleData.idKey,                    parentKey = setting.data.simpleData.pIdKey;                if (!key || key == "" || !sNodes) return [];                if (tools.isArray(sNodes)) {                    var r = [];                    var tmpMap = {};                    for (i = 0, l = sNodes.length; i < l; i++) {                        tmpMap[sNodes[i][key]] = sNodes[i];                    }                    for (i = 0, l = sNodes.length; i < l; i++) {                        var p = tmpMap[sNodes[i][parentKey]];                        if (p && sNodes[i][key] != sNodes[i][parentKey]) {                            var children = data.nodeChildren(setting, p);                            if (!children) {                                children = data.nodeChildren(setting, p, []);                            }                            children.push(sNodes[i]);                        } else {                            r.push(sNodes[i]);                        }                    }                    return r;                } else {                    return [sNodes];                }            }        },        //method of event proxy        event = {            bindEvent: function (setting) {                for (var i = 0, j = _init.bind.length; i < j; i++) {                    _init.bind[i].apply(this, arguments);                }            },            unbindEvent: function (setting) {                for (var i = 0, j = _init.unbind.length; i < j; i++) {                    _init.unbind[i].apply(this, arguments);                }            },            bindTree: function (setting) {                var eventParam = {                        treeId: setting.treeId                    },                    o = setting.treeObj;                if (!setting.view.txtSelectedEnable) {                    // for can't select text                    o.bind('selectstart', handler.onSelectStart).css({                        "-moz-user-select": "-moz-none"                    });                }                o.bind('click', eventParam, event.proxy);                o.bind('dblclick', eventParam, event.proxy);                o.bind('mouseover', eventParam, event.proxy);                o.bind('mouseout', eventParam, event.proxy);                o.bind('mousedown', eventParam, event.proxy);                o.bind('mouseup', eventParam, event.proxy);                o.bind('contextmenu', eventParam, event.proxy);            },            unbindTree: function (setting) {                var o = setting.treeObj;                o.unbind('selectstart', handler.onSelectStart)                    .unbind('click', event.proxy)                    .unbind('dblclick', event.proxy)                    .unbind('mouseover', event.proxy)                    .unbind('mouseout', event.proxy)                    .unbind('mousedown', event.proxy)                    .unbind('mouseup', event.proxy)                    .unbind('contextmenu', event.proxy);            },            doProxy: function (e) {                var results = [];                for (var i = 0, j = _init.proxys.length; i < j; i++) {                    var proxyResult = _init.proxys[i].apply(this, arguments);                    results.push(proxyResult);                    if (proxyResult.stop) {                        break;                    }                }                return results;            },            proxy: function (e) {                var setting = data.getSetting(e.data.treeId);                if (!tools.uCanDo(setting, e)) return true;                var results = event.doProxy(e),                    r = true, x = false;                for (var i = 0, l = results.length; i < l; i++) {                    var proxyResult = results[i];                    if (proxyResult.nodeEventCallback) {                        x = true;                        r = proxyResult.nodeEventCallback.apply(proxyResult, [e, proxyResult.node]) && r;                    }                    if (proxyResult.treeEventCallback) {                        x = true;                        r = proxyResult.treeEventCallback.apply(proxyResult, [e, proxyResult.node]) && r;                    }                }                return r;            }        },        //method of event handler        handler = {            onSwitchNode: function (event, node) {                var setting = data.getSetting(event.data.treeId);                if (node.open) {                    if (tools.apply(setting.callback.beforeCollapse, [setting.treeId, node], true) == false) return true;                    data.getRoot(setting).expandTriggerFlag = true;                    view.switchNode(setting, node);                } else {                    if (tools.apply(setting.callback.beforeExpand, [setting.treeId, node], true) == false) return true;                    data.getRoot(setting).expandTriggerFlag = true;                    view.switchNode(setting, node);                }                return true;            },            onClickNode: function (event, node) {                var setting = data.getSetting(event.data.treeId),                    clickFlag = ((setting.view.autoCancelSelected && (event.ctrlKey || event.metaKey)) && data.isSelectedNode(setting, node)) ? 0 : (setting.view.autoCancelSelected && (event.ctrlKey || event.metaKey) && setting.view.selectedMulti) ? 2 : 1;                if (tools.apply(setting.callback.beforeClick, [setting.treeId, node, clickFlag], true) == false) return true;                if (clickFlag === 0) {                    view.cancelPreSelectedNode(setting, node);                } else {                    view.selectNode(setting, node, clickFlag === 2);                }                setting.treeObj.trigger(consts.event.CLICK, [event, setting.treeId, node, clickFlag]);                return true;            },            onZTreeMousedown: function (event, node) {                var setting = data.getSetting(event.data.treeId);                if (tools.apply(setting.callback.beforeMouseDown, [setting.treeId, node], true)) {                    tools.apply(setting.callback.onMouseDown, [event, setting.treeId, node]);                }                return true;            },            onZTreeMouseup: function (event, node) {                var setting = data.getSetting(event.data.treeId);                if (tools.apply(setting.callback.beforeMouseUp, [setting.treeId, node], true)) {                    tools.apply(setting.callback.onMouseUp, [event, setting.treeId, node]);                }                return true;            },            onZTreeDblclick: function (event, node) {                var setting = data.getSetting(event.data.treeId);                if (tools.apply(setting.callback.beforeDblClick, [setting.treeId, node], true)) {                    tools.apply(setting.callback.onDblClick, [event, setting.treeId, node]);                }                return true;            },            onZTreeContextmenu: function (event, node) {                var setting = data.getSetting(event.data.treeId);                if (tools.apply(setting.callback.beforeRightClick, [setting.treeId, node], true)) {                    tools.apply(setting.callback.onRightClick, [event, setting.treeId, node]);                }                return (typeof setting.callback.onRightClick) != "function";            },            onSelectStart: function (e) {                var n = e.originalEvent.srcElement.nodeName.toLowerCase();                return (n === "input" || n === "textarea");            }        },        //method of tools for zTree        tools = {            apply: function (fun, param, defaultValue) {                if ((typeof fun) == "function") {                    return fun.apply(zt, param ? param : []);                }                return defaultValue;            },            canAsync: function (setting, node) {                var children = data.nodeChildren(setting, node);                var isParent = data.nodeIsParent(setting, node);                return (setting.async.enable && node && isParent && !(node.zAsync || (children && children.length > 0)));            },            clone: function (obj) {                if (obj === null) return null;                var o = tools.isArray(obj) ? [] : {};                for (var i in obj) {                    o[i] = (obj[i] instanceof Date) ? new Date(obj[i].getTime()) : (typeof obj[i] === "object" ? tools.clone(obj[i]) : obj[i]);                }                return o;            },            eqs: function (str1, str2) {                return str1.toLowerCase() === str2.toLowerCase();            },            isArray: function (arr) {                return Object.prototype.toString.apply(arr) === "[object Array]";            },            isElement: function (o) {                return (                    typeof HTMLElement === "object" ? o instanceof HTMLElement : //DOM2                        o && typeof o === "object" && o !== null && o.nodeType === 1 && typeof o.nodeName === "string"                );            },            $: function (node, exp, setting) {                if (!!exp && typeof exp != "string") {                    setting = exp;                    exp = "";                }                if (typeof node == "string") {                    return $(node, setting ? setting.treeObj.get(0).ownerDocument : null);                } else {                    return $("#" + node.tId + exp, setting ? setting.treeObj : null);                }            },            getMDom: function (setting, curDom, targetExpr) {                if (!curDom) return null;                while (curDom && curDom.id !== setting.treeId) {                    for (var i = 0, l = targetExpr.length; curDom.tagName && i < l; i++) {                        if (tools.eqs(curDom.tagName, targetExpr[i].tagName) && curDom.getAttribute(targetExpr[i].attrName) !== null) {                            return curDom;                        }                    }                    curDom = curDom.parentNode;                }                return null;            },            getNodeMainDom: function (target) {                return ($(target).parent("li").get(0) || $(target).parentsUntil("li").parent().get(0));            },            isChildOrSelf: function (dom, parentId) {                return ($(dom).closest("#" + parentId).length > 0);            },            uCanDo: function (setting, e) {                return true;            }        },        //method of operate ztree dom        view = {            addNodes: function (setting, parentNode, index, newNodes, isSilent) {                var isParent = data.nodeIsParent(setting, parentNode);                if (setting.data.keep.leaf && parentNode && !isParent) {                    return;                }                if (!tools.isArray(newNodes)) {                    newNodes = [newNodes];                }                if (setting.data.simpleData.enable) {                    newNodes = data.transformTozTreeFormat(setting, newNodes);                }                if (parentNode) {                    var target_switchObj = $$(parentNode, consts.id.SWITCH, setting),                        target_icoObj = $$(parentNode, consts.id.ICON, setting),                        target_ulObj = $$(parentNode, consts.id.UL, setting);                    if (!parentNode.open) {                        view.replaceSwitchClass(parentNode, target_switchObj, consts.folder.CLOSE);                        view.replaceIcoClass(parentNode, target_icoObj, consts.folder.CLOSE);                        parentNode.open = false;                        target_ulObj.css({                            "display": "none"                        });                    }                    data.addNodesData(setting, parentNode, index, newNodes);                    view.createNodes(setting, parentNode.level + 1, newNodes, parentNode, index);                    if (!isSilent) {                        view.expandCollapseParentNode(setting, parentNode, true);                    }                } else {                    data.addNodesData(setting, data.getRoot(setting), index, newNodes);                    view.createNodes(setting, 0, newNodes, null, index);                }            },            appendNodes: function (setting, level, nodes, parentNode, index, initFlag, openFlag) {                if (!nodes) return [];                var html = [];                var tmpPNode = (parentNode) ? parentNode : data.getRoot(setting),                    tmpPChild = data.nodeChildren(setting, tmpPNode),                    isFirstNode, isLastNode;                if (!tmpPChild || index >= tmpPChild.length - nodes.length) {                    index = -1;                }                for (var i = 0, l = nodes.length; i < l; i++) {                    var node = nodes[i];                    if (initFlag) {                        isFirstNode = ((index === 0 || tmpPChild.length == nodes.length) && (i == 0));                        isLastNode = (index < 0 && i == (nodes.length - 1));                        data.initNode(setting, level, node, parentNode, isFirstNode, isLastNode, openFlag);                        data.addNodeCache(setting, node);                    }                    var isParent = data.nodeIsParent(setting, node);                    var childHtml = [];                    var children = data.nodeChildren(setting, node);                    if (children && children.length > 0) {                        //make child html first, because checkType                        childHtml = view.appendNodes(setting, level + 1, children, node, -1, initFlag, openFlag && node.open);                    }                    if (openFlag) {                        view.makeDOMNodeMainBefore(html, setting, node);                        view.makeDOMNodeLine(html, setting, node);                        data.getBeforeA(setting, node, html);                        view.makeDOMNodeNameBefore(html, setting, node);                        data.getInnerBeforeA(setting, node, html);                        view.makeDOMNodeIcon(html, setting, node);                        data.getInnerAfterA(setting, node, html);                        view.makeDOMNodeNameAfter(html, setting, node);                        data.getAfterA(setting, node, html);                        if (isParent && node.open) {                            view.makeUlHtml(setting, node, html, childHtml.join(''));                        }                        view.makeDOMNodeMainAfter(html, setting, node);                        data.addCreatedNode(setting, node);                    }                }                return html;            },            appendParentULDom: function (setting, node) {                var html = [],                    nObj = $$(node, setting);                if (!nObj.get(0) && !!node.parentTId) {                    view.appendParentULDom(setting, node.getParentNode());                    nObj = $$(node, setting);                }                var ulObj = $$(node, consts.id.UL, setting);                if (ulObj.get(0)) {                    ulObj.remove();                }                var children = data.nodeChildren(setting, node),                    childHtml = view.appendNodes(setting, node.level + 1, children, node, -1, false, true);                view.makeUlHtml(setting, node, html, childHtml.join(''));                nObj.append(html.join(''));            },            asyncNode: function (setting, node, isSilent, callback) {                var i, l;                var isParent = data.nodeIsParent(setting, node);                if (node && !isParent) {                    tools.apply(callback);                    return false;                } else if (node && node.isAjaxing) {                    return false;                } else if (tools.apply(setting.callback.beforeAsync, [setting.treeId, node], true) == false) {                    tools.apply(callback);                    return false;                }                if (node) {                    node.isAjaxing = true;                    var icoObj = $$(node, consts.id.ICON, setting);                    icoObj.attr({"style": "", "class": consts.className.BUTTON + " " + consts.className.ICO_LOADING});                }                var tmpParam = {};                var autoParam = tools.apply(setting.async.autoParam, [setting.treeId, node], setting.async.autoParam);                for (i = 0, l = autoParam.length; node && i < l; i++) {                    var pKey = autoParam[i].split("="), spKey = pKey;                    if (pKey.length > 1) {                        spKey = pKey[1];                        pKey = pKey[0];                    }                    tmpParam[spKey] = node[pKey];                }                var otherParam = tools.apply(setting.async.otherParam, [setting.treeId, node], setting.async.otherParam);                if (tools.isArray(otherParam)) {                    for (i = 0, l = otherParam.length; i < l; i += 2) {                        tmpParam[otherParam[i]] = otherParam[i + 1];                    }                } else {                    for (var p in otherParam) {                        tmpParam[p] = otherParam[p];                    }                }                var _tmpV = data.getRoot(setting)._ver;                $.ajax({                    contentType: setting.async.contentType,                    cache: false,                    type: setting.async.type,                    url: tools.apply(setting.async.url, [setting.treeId, node], setting.async.url),                    data: setting.async.contentType.indexOf('application/json') > -1 ? JSON.stringify(tmpParam) : tmpParam,                    dataType: setting.async.dataType,                    headers: setting.async.headers,                    xhrFields: setting.async.xhrFields,                    success: function (msg) {                        if (_tmpV != data.getRoot(setting)._ver) {                            return;                        }                        var newNodes = [];                        try {                            if (!msg || msg.length == 0) {                                newNodes = [];                            } else if (typeof msg == "string") {                                newNodes = eval("(" + msg + ")");                            } else {                                newNodes = msg;                            }                        } catch (err) {                            newNodes = msg;                        }                        if (node) {                            node.isAjaxing = null;                            node.zAsync = true;                        }                        view.setNodeLineIcos(setting, node);                        if (newNodes && newNodes !== "") {                            newNodes = tools.apply(setting.async.dataFilter, [setting.treeId, node, newNodes], newNodes);                            view.addNodes(setting, node, -1, !!newNodes ? tools.clone(newNodes) : [], !!isSilent);                        } else {                            view.addNodes(setting, node, -1, [], !!isSilent);                        }                        setting.treeObj.trigger(consts.event.ASYNC_SUCCESS, [setting.treeId, node, msg]);                        tools.apply(callback);                    },                    error: function (XMLHttpRequest, textStatus, errorThrown) {                        if (_tmpV != data.getRoot(setting)._ver) {                            return;                        }                        if (node) node.isAjaxing = null;                        view.setNodeLineIcos(setting, node);                        setting.treeObj.trigger(consts.event.ASYNC_ERROR, [setting.treeId, node, XMLHttpRequest, textStatus, errorThrown]);                    }                });                return true;            },            cancelPreSelectedNode: function (setting, node, excludeNode) {                var list = data.getRoot(setting).curSelectedList,                    i, n;                for (i = list.length - 1; i >= 0; i--) {                    n = list[i];                    if (node === n || (!node && (!excludeNode || excludeNode !== n))) {                        $$(n, consts.id.A, setting).removeClass(consts.node.CURSELECTED);                        if (node) {                            data.removeSelectedNode(setting, node);                            break;                        } else {                            list.splice(i, 1);                            setting.treeObj.trigger(consts.event.UNSELECTED, [setting.treeId, n]);                        }                    }                }            },            createNodeCallback: function (setting) {                if (!!setting.callback.onNodeCreated || !!setting.view.addDiyDom) {                    var root = data.getRoot(setting);                    while (root.createdNodes.length > 0) {                        var node = root.createdNodes.shift();                        tools.apply(setting.view.addDiyDom, [setting.treeId, node]);                        if (!!setting.callback.onNodeCreated) {                            setting.treeObj.trigger(consts.event.NODECREATED, [setting.treeId, node]);                        }                    }                }            },            createNodes: function (setting, level, nodes, parentNode, index) {                if (!nodes || nodes.length == 0) return;                var root = data.getRoot(setting),                    openFlag = !parentNode || parentNode.open || !!$$(data.nodeChildren(setting, parentNode)[0], setting).get(0);                root.createdNodes = [];                var zTreeHtml = view.appendNodes(setting, level, nodes, parentNode, index, true, openFlag),                    parentObj, nextObj;                if (!parentNode) {                    parentObj = setting.treeObj;                    //setting.treeObj.append(zTreeHtml.join(''));                } else {                    var ulObj = $$(parentNode, consts.id.UL, setting);                    if (ulObj.get(0)) {                        parentObj = ulObj;                        //ulObj.append(zTreeHtml.join(''));                    }                }                if (parentObj) {                    if (index >= 0) {                        nextObj = parentObj.children()[index];                    }                    if (index >= 0 && nextObj) {                        $(nextObj).before(zTreeHtml.join(''));                    } else {                        parentObj.append(zTreeHtml.join(''));                    }                }                view.createNodeCallback(setting);            },            destroy: function (setting) {                if (!setting) return;                data.initCache(setting);                data.initRoot(setting);                event.unbindTree(setting);                event.unbindEvent(setting);                setting.treeObj.empty();                delete settings[setting.treeId];            },            expandCollapseNode: function (setting, node, expandFlag, animateFlag, callback) {                var root = data.getRoot(setting);                var tmpCb, _callback;                if (!node) {                    tools.apply(callback, []);                    return;                }                var children = data.nodeChildren(setting, node);                var isParent = data.nodeIsParent(setting, node);                if (root.expandTriggerFlag) {                    _callback = callback;                    tmpCb = function () {                        if (_callback) _callback();                        if (node.open) {                            setting.treeObj.trigger(consts.event.EXPAND, [setting.treeId, node]);                        } else {                            setting.treeObj.trigger(consts.event.COLLAPSE, [setting.treeId, node]);                        }                    };                    callback = tmpCb;                    root.expandTriggerFlag = false;                }                if (!node.open && isParent && ((!$$(node, consts.id.UL, setting).get(0)) || (children && children.length > 0 && !$$(children[0], setting).get(0)))) {                    view.appendParentULDom(setting, node);                    view.createNodeCallback(setting);                }                if (node.open == expandFlag) {                    tools.apply(callback, []);                    return;                }                var ulObj = $$(node, consts.id.UL, setting),                    switchObj = $$(node, consts.id.SWITCH, setting),                    icoObj = $$(node, consts.id.ICON, setting);                if (isParent) {                    node.open = !node.open;                    if (node.iconOpen && node.iconClose) {                        icoObj.attr("style", view.makeNodeIcoStyle(setting, node));                    }                    if (node.open) {                        view.replaceSwitchClass(node, switchObj, consts.folder.OPEN);                        view.replaceIcoClass(node, icoObj, consts.folder.OPEN);                        if (animateFlag == false || setting.view.expandSpeed == "") {                            ulObj.show();                            tools.apply(callback, []);                        } else {                            if (children && children.length > 0) {                                ulObj.slideDown(setting.view.expandSpeed, callback);                            } else {                                ulObj.show();                                tools.apply(callback, []);                            }                        }                    } else {                        view.replaceSwitchClass(node, switchObj, consts.folder.CLOSE);                        view.replaceIcoClass(node, icoObj, consts.folder.CLOSE);                        if (animateFlag == false || setting.view.expandSpeed == "" || !(children && children.length > 0)) {                            ulObj.hide();                            tools.apply(callback, []);                        } else {                            ulObj.slideUp(setting.view.expandSpeed, callback);                        }                    }                } else {                    tools.apply(callback, []);                }            },            expandCollapseParentNode: function (setting, node, expandFlag, animateFlag, callback) {                if (!node) return;                if (!node.parentTId) {                    view.expandCollapseNode(setting, node, expandFlag, animateFlag, callback);                    return;                } else {                    view.expandCollapseNode(setting, node, expandFlag, animateFlag);                }                if (node.parentTId) {                    view.expandCollapseParentNode(setting, node.getParentNode(), expandFlag, animateFlag, callback);                }            },            expandCollapseSonNode: function (setting, node, expandFlag, animateFlag, callback) {                var root = data.getRoot(setting),                    treeNodes = (node) ? data.nodeChildren(setting, node) : data.nodeChildren(setting, root),                    selfAnimateSign = (node) ? false : animateFlag,                    expandTriggerFlag = data.getRoot(setting).expandTriggerFlag;                data.getRoot(setting).expandTriggerFlag = false;                if (treeNodes) {                    for (var i = 0, l = treeNodes.length; i < l; i++) {                        if (treeNodes[i]) view.expandCollapseSonNode(setting, treeNodes[i], expandFlag, selfAnimateSign);                    }                }                data.getRoot(setting).expandTriggerFlag = expandTriggerFlag;                view.expandCollapseNode(setting, node, expandFlag, animateFlag, callback);            },            isSelectedNode: function (setting, node) {                if (!node) {                    return false;                }                var list = data.getRoot(setting).curSelectedList,                    i;                for (i = list.length - 1; i >= 0; i--) {                    if (node === list[i]) {                        return true;                    }                }                return false;            },            makeDOMNodeIcon: function (html, setting, node) {                var nameStr = data.nodeName(setting, node),                    name = setting.view.nameIsHTML ? nameStr : nameStr.replace(/&/g, '&').replace(/</g, '<').replace(/>/g, '>');                html.push("<span id='", node.tId, consts.id.ICON,                    "' title='' treeNode", consts.id.ICON, " class='", view.makeNodeIcoClass(setting, node),                    "' style='", view.makeNodeIcoStyle(setting, node), "'></span><span id='", node.tId, consts.id.SPAN,                    "' class='", consts.className.NAME,                    "'>", name, "</span>");            },            makeDOMNodeLine: function (html, setting, node) {                html.push("<span id='", node.tId, consts.id.SWITCH, "' title='' class='", view.makeNodeLineClass(setting, node), "' treeNode", consts.id.SWITCH, "></span>");            },            makeDOMNodeMainAfter: function (html, setting, node) {                html.push("</li>");            },            makeDOMNodeMainBefore: function (html, setting, node) {                html.push("<li id='", node.tId, "' class='", consts.className.LEVEL, node.level, "' tabindex='0' hidefocus='true' treenode>");            },            makeDOMNodeNameAfter: function (html, setting, node) {                html.push("</a>");            },            makeDOMNodeNameBefore: function (html, setting, node) {                var title = data.nodeTitle(setting, node),                    url = view.makeNodeUrl(setting, node),                    fontcss = view.makeNodeFontCss(setting, node),                    fontStyle = [];                for (var f in fontcss) {                    fontStyle.push(f, ":", fontcss[f], ";");                }                html.push("<a id='", node.tId, consts.id.A, "' class='", consts.className.LEVEL, node.level, "' treeNode", consts.id.A, " onclick=\"", (node.click || ''),                    "\" ", ((url != null && url.length > 0) ? "href='" + url + "'" : ""), " target='", view.makeNodeTarget(node), "' style='", fontStyle.join(''),                    "'");                if (tools.apply(setting.view.showTitle, [setting.treeId, node], setting.view.showTitle) && title) {                    html.push("title='", title.replace(/'/g, "'").replace(/</g, '<').replace(/>/g, '>'), "'");                }                html.push(">");            },            makeNodeFontCss: function (setting, node) {                var fontCss = tools.apply(setting.view.fontCss, [setting.treeId, node], setting.view.fontCss);                return (fontCss && ((typeof fontCss) != "function")) ? fontCss : {};            },            makeNodeIcoClass: function (setting, node) {                var icoCss = ["ico"];                if (!node.isAjaxing) {                    var isParent = data.nodeIsParent(setting, node);                    icoCss[0] = (node.iconSkin ? node.iconSkin + "_" : "") + icoCss[0];                    if (isParent) {                        icoCss.push(node.open ? consts.folder.OPEN : consts.folder.CLOSE);                    } else {                        icoCss.push(consts.folder.DOCU);                    }                }                return consts.className.BUTTON + " " + icoCss.join('_');            },            makeNodeIcoStyle: function (setting, node) {                var icoStyle = [];                if (!node.isAjaxing) {                    var isParent = data.nodeIsParent(setting, node);                    var icon = (isParent && node.iconOpen && node.iconClose) ? (node.open ? node.iconOpen : node.iconClose) : node[setting.data.key.icon];                    if (icon) icoStyle.push("background:url(", icon, ") 0 0 no-repeat;");                    if (setting.view.showIcon == false || !tools.apply(setting.view.showIcon, [setting.treeId, node], true)) {                        icoStyle.push("width:0px;height:0px;");                    }                }                return icoStyle.join('');            },            makeNodeLineClass: function (setting, node) {                var lineClass = [];                if (setting.view.showLine) {                    if (node.level == 0 && node.isFirstNode && node.isLastNode) {                        lineClass.push(consts.line.ROOT);                    } else if (node.level == 0 && node.isFirstNode) {                        lineClass.push(consts.line.ROOTS);                    } else if (node.isLastNode) {                        lineClass.push(consts.line.BOTTOM);                    } else {                        lineClass.push(consts.line.CENTER);                    }                } else {                    lineClass.push(consts.line.NOLINE);                }                if (data.nodeIsParent(setting, node)) {                    lineClass.push(node.open ? consts.folder.OPEN : consts.folder.CLOSE);                } else {                    lineClass.push(consts.folder.DOCU);                }                return view.makeNodeLineClassEx(node) + lineClass.join('_');            },            makeNodeLineClassEx: function (node) {                return consts.className.BUTTON + " " + consts.className.LEVEL + node.level + " " + consts.className.SWITCH + " ";            },            makeNodeTarget: function (node) {                return (node.target || "_blank");            },            makeNodeUrl: function (setting, node) {                var urlKey = setting.data.key.url;                return node[urlKey] ? node[urlKey] : null;            },            makeUlHtml: function (setting, node, html, content) {                html.push("<ul id='", node.tId, consts.id.UL, "' class='", consts.className.LEVEL, node.level, " ", view.makeUlLineClass(setting, node), "' style='display:", (node.open ? "block" : "none"), "'>");                html.push(content);                html.push("</ul>");            },            makeUlLineClass: function (setting, node) {                return ((setting.view.showLine && !node.isLastNode) ? consts.line.LINE : "");            },            removeChildNodes: function (setting, node) {                if (!node) return;                var nodes = data.nodeChildren(setting, node);                if (!nodes) return;                for (var i = 0, l = nodes.length; i < l; i++) {                    data.removeNodeCache(setting, nodes[i]);                }                data.removeSelectedNode(setting);                delete node[setting.data.key.children];                if (!setting.data.keep.parent) {                    data.nodeIsParent(setting, node, false);                    node.open = false;                    var tmp_switchObj = $$(node, consts.id.SWITCH, setting),                        tmp_icoObj = $$(node, consts.id.ICON, setting);                    view.replaceSwitchClass(node, tmp_switchObj, consts.folder.DOCU);                    view.replaceIcoClass(node, tmp_icoObj, consts.folder.DOCU);                    $$(node, consts.id.UL, setting).remove();                } else {                    $$(node, consts.id.UL, setting).empty();                }            },            scrollIntoView: function (setting, dom) {                if (!dom) {                    return;                }                // support IE 7                if (typeof Element === 'undefined') {                    var contRect = setting.treeObj.get(0).getBoundingClientRect(),                        findMeRect = dom.getBoundingClientRect();                    if (findMeRect.top < contRect.top || findMeRect.bottom > contRect.bottom                        || findMeRect.right > contRect.right || findMeRect.left < contRect.left) {                        dom.scrollIntoView();                    }                    return;                }                // CC-BY jocki84@googlemail.com, https://gist.github.com/jocki84/6ffafd003387179a988e                if (!Element.prototype.scrollIntoViewIfNeeded) {                    Element.prototype.scrollIntoViewIfNeeded = function (centerIfNeeded) {                        "use strict";                        function makeRange(start, length) {                            return {"start": start, "length": length, "end": start + length};                        }                        function coverRange(inner, outer) {                            if (                                false === centerIfNeeded ||                                (outer.start < inner.end && inner.start < outer.end)                            ) {                                return Math.max(                                    inner.end - outer.length,                                    Math.min(outer.start, inner.start)                                );                            }                            return (inner.start + inner.end - outer.length) / 2;                        }                        function makePoint(x, y) {                            return {                                "x": x,                                "y": y,                                "translate": function translate(dX, dY) {                                    return makePoint(x + dX, y + dY);                                }                            };                        }                        function absolute(elem, pt) {                            while (elem) {                                pt = pt.translate(elem.offsetLeft, elem.offsetTop);                                elem = elem.offsetParent;                            }                            return pt;                        }                        var target = absolute(this, makePoint(0, 0)),                            extent = makePoint(this.offsetWidth, this.offsetHeight),                            elem = this.parentNode,                            origin;                        while (elem instanceof HTMLElement) {                            // Apply desired scroll amount.                            origin = absolute(elem, makePoint(elem.clientLeft, elem.clientTop));                            elem.scrollLeft = coverRange(                                makeRange(target.x - origin.x, extent.x),                                makeRange(elem.scrollLeft, elem.clientWidth)                            );                            elem.scrollTop = coverRange(                                makeRange(target.y - origin.y, extent.y),                                makeRange(elem.scrollTop, elem.clientHeight)                            );                            // Determine actual scroll amount by reading back scroll properties.                            target = target.translate(-elem.scrollLeft, -elem.scrollTop);                            elem = elem.parentNode;                        }                    };                }                dom.scrollIntoViewIfNeeded();            },            setFirstNode: function (setting, parentNode) {                var children = data.nodeChildren(setting, parentNode);                if (children.length > 0) {                    children[0].isFirstNode = true;                }            },            setLastNode: function (setting, parentNode) {                var children = data.nodeChildren(setting, parentNode);                if (children.length > 0) {                    children[children.length - 1].isLastNode = true;                }            },            removeNode: function (setting, node) {                var root = data.getRoot(setting),                    parentNode = (node.parentTId) ? node.getParentNode() : root;                node.isFirstNode = false;                node.isLastNode = false;                node.getPreNode = function () {                    return null;                };                node.getNextNode = function () {                    return null;                };                if (!data.getNodeCache(setting, node.tId)) {                    return;                }                $$(node, setting).remove();                data.removeNodeCache(setting, node);                data.removeSelectedNode(setting, node);                var children = data.nodeChildren(setting, parentNode);                for (var i = 0, l = children.length; i < l; i++) {                    if (children[i].tId == node.tId) {                        children.splice(i, 1);                        break;                    }                }                view.setFirstNode(setting, parentNode);                view.setLastNode(setting, parentNode);                var tmp_ulObj, tmp_switchObj, tmp_icoObj,                    childLength = children.length;                //repair nodes old parent                if (!setting.data.keep.parent && childLength == 0) {                    //old parentNode has no child nodes                    data.nodeIsParent(setting, parentNode, false);                    parentNode.open = false;                    delete parentNode[setting.data.key.children];                    tmp_ulObj = $$(parentNode, consts.id.UL, setting);                    tmp_switchObj = $$(parentNode, consts.id.SWITCH, setting);                    tmp_icoObj = $$(parentNode, consts.id.ICON, setting);                    view.replaceSwitchClass(parentNode, tmp_switchObj, consts.folder.DOCU);                    view.replaceIcoClass(parentNode, tmp_icoObj, consts.folder.DOCU);                    tmp_ulObj.css("display", "none");                } else if (setting.view.showLine && childLength > 0) {                    //old parentNode has child nodes                    var newLast = children[childLength - 1];                    tmp_ulObj = $$(newLast, consts.id.UL, setting);                    tmp_switchObj = $$(newLast, consts.id.SWITCH, setting);                    tmp_icoObj = $$(newLast, consts.id.ICON, setting);                    if (parentNode == root) {                        if (children.length == 1) {                            //node was root, and ztree has only one root after move node                            view.replaceSwitchClass(newLast, tmp_switchObj, consts.line.ROOT);                        } else {                            var tmp_first_switchObj = $$(children[0], consts.id.SWITCH, setting);                            view.replaceSwitchClass(children[0], tmp_first_switchObj, consts.line.ROOTS);                            view.replaceSwitchClass(newLast, tmp_switchObj, consts.line.BOTTOM);                        }                    } else {                        view.replaceSwitchClass(newLast, tmp_switchObj, consts.line.BOTTOM);                    }                    tmp_ulObj.removeClass(consts.line.LINE);                }            },            replaceIcoClass: function (node, obj, newName) {                if (!obj || node.isAjaxing) return;                var tmpName = obj.attr("class");                if (tmpName == undefined) return;                var tmpList = tmpName.split("_");                switch (newName) {                    case consts.folder.OPEN:                    case consts.folder.CLOSE:                    case consts.folder.DOCU:                        tmpList[tmpList.length - 1] = newName;                        break;                }                obj.attr("class", tmpList.join("_"));            },            replaceSwitchClass: function (node, obj, newName) {                if (!obj) return;                var tmpName = obj.attr("class");                if (tmpName == undefined) return;                var tmpList = tmpName.split("_");                switch (newName) {                    case consts.line.ROOT:                    case consts.line.ROOTS:                    case consts.line.CENTER:                    case consts.line.BOTTOM:                    case consts.line.NOLINE:                        tmpList[0] = view.makeNodeLineClassEx(node) + newName;                        break;                    case consts.folder.OPEN:                    case consts.folder.CLOSE:                    case consts.folder.DOCU:                        tmpList[1] = newName;                        break;                }                obj.attr("class", tmpList.join("_"));                if (newName !== consts.folder.DOCU) {                    obj.removeAttr("disabled");                } else {                    obj.attr("disabled", "disabled");                }            },            selectNode: function (setting, node, addFlag) {                if (!addFlag) {                    view.cancelPreSelectedNode(setting, null, node);                }                $$(node, consts.id.A, setting).addClass(consts.node.CURSELECTED);                data.addSelectedNode(setting, node);                setting.treeObj.trigger(consts.event.SELECTED, [setting.treeId, node]);            },            setNodeFontCss: function (setting, treeNode) {                var aObj = $$(treeNode, consts.id.A, setting),                    fontCss = view.makeNodeFontCss(setting, treeNode);                if (fontCss) {                    aObj.css(fontCss);                }            },            setNodeLineIcos: function (setting, node) {                if (!node) return;                var switchObj = $$(node, consts.id.SWITCH, setting),                    ulObj = $$(node, consts.id.UL, setting),                    icoObj = $$(node, consts.id.ICON, setting),                    ulLine = view.makeUlLineClass(setting, node);                if (ulLine.length == 0) {                    ulObj.removeClass(consts.line.LINE);                } else {                    ulObj.addClass(ulLine);                }                switchObj.attr("class", view.makeNodeLineClass(setting, node));                if (data.nodeIsParent(setting, node)) {                    switchObj.removeAttr("disabled");                } else {                    switchObj.attr("disabled", "disabled");                }                icoObj.removeAttr("style");                icoObj.attr("style", view.makeNodeIcoStyle(setting, node));                icoObj.attr("class", view.makeNodeIcoClass(setting, node));            },            setNodeName: function (setting, node) {                var title = data.nodeTitle(setting, node),                    nObj = $$(node, consts.id.SPAN, setting);                nObj.empty();                if (setting.view.nameIsHTML) {                    nObj.html(data.nodeName(setting, node));                } else {                    nObj.text(data.nodeName(setting, node));                }                if (tools.apply(setting.view.showTitle, [setting.treeId, node], setting.view.showTitle)) {                    var aObj = $$(node, consts.id.A, setting);                    aObj.attr("title", !title ? "" : title);                }            },            setNodeTarget: function (setting, node) {                var aObj = $$(node, consts.id.A, setting);                aObj.attr("target", view.makeNodeTarget(node));            },            setNodeUrl: function (setting, node) {                var aObj = $$(node, consts.id.A, setting),                    url = view.makeNodeUrl(setting, node);                if (url == null || url.length == 0) {                    aObj.removeAttr("href");                } else {                    aObj.attr("href", url);                }            },            switchNode: function (setting, node) {                if (node.open || !tools.canAsync(setting, node)) {                    view.expandCollapseNode(setting, node, !node.open);                } else if (setting.async.enable) {                    if (!view.asyncNode(setting, node)) {                        view.expandCollapseNode(setting, node, !node.open);                        return;                    }                } else if (node) {                    view.expandCollapseNode(setting, node, !node.open);                }            }        };    // zTree defind    $.fn.zTree = {        consts: _consts,        _z: {            tools: tools,            view: view,            event: event,            data: data        },        getZTreeObj: function (treeId) {            var o = data.getZTreeTools(treeId);            return o ? o : null;        },        destroy: function (treeId) {            if (!!treeId && treeId.length > 0) {                view.destroy(data.getSetting(treeId));            } else {                for (var s in settings) {                    view.destroy(settings[s]);                }            }        },        init: function (obj, zSetting, zNodes) {            var setting = tools.clone(_setting);            $.extend(true, setting, zSetting);            setting.treeId = obj.attr("id");            setting.treeObj = obj;            setting.treeObj.empty();            settings[setting.treeId] = setting;            //For some older browser,(e.g., ie6)            if (typeof document.body.style.maxHeight === "undefined") {                setting.view.expandSpeed = "";            }            data.initRoot(setting);            var root = data.getRoot(setting);            zNodes = zNodes ? tools.clone(tools.isArray(zNodes) ? zNodes : [zNodes]) : [];            if (setting.data.simpleData.enable) {                data.nodeChildren(setting, root, data.transformTozTreeFormat(setting, zNodes));            } else {                data.nodeChildren(setting, root, zNodes);            }            data.initCache(setting);            event.unbindTree(setting);            event.bindTree(setting);            event.unbindEvent(setting);            event.bindEvent(setting);            var zTreeTools = {                setting: setting,                addNodes: function (parentNode, index, newNodes, isSilent) {                    if (!parentNode) parentNode = null;                    var isParent = data.nodeIsParent(setting, parentNode);                    if (parentNode && !isParent && setting.data.keep.leaf) return null;                    var i = parseInt(index, 10);                    if (isNaN(i)) {                        isSilent = !!newNodes;                        newNodes = index;                        index = -1;                    } else {                        index = i;                    }                    if (!newNodes) return null;                    var xNewNodes = tools.clone(tools.isArray(newNodes) ? newNodes : [newNodes]);                    function addCallback() {                        view.addNodes(setting, parentNode, index, xNewNodes, (isSilent == true));                    }                    if (tools.canAsync(setting, parentNode)) {                        view.asyncNode(setting, parentNode, isSilent, addCallback);                    } else {                        addCallback();                    }                    return xNewNodes;                },                cancelSelectedNode: function (node) {                    view.cancelPreSelectedNode(setting, node);                },                destroy: function () {                    view.destroy(setting);                },                expandAll: function (expandFlag) {                    expandFlag = !!expandFlag;                    view.expandCollapseSonNode(setting, null, expandFlag, true);                    return expandFlag;                },                expandNode: function (node, expandFlag, sonSign, focus, callbackFlag) {                    if (!node || !data.nodeIsParent(setting, node)) return null;                    if (expandFlag !== true && expandFlag !== false) {                        expandFlag = !node.open;                    }                    callbackFlag = !!callbackFlag;                    if (callbackFlag && expandFlag && (tools.apply(setting.callback.beforeExpand, [setting.treeId, node], true) == false)) {                        return null;                    } else if (callbackFlag && !expandFlag && (tools.apply(setting.callback.beforeCollapse, [setting.treeId, node], true) == false)) {                        return null;                    }                    if (expandFlag && node.parentTId) {                        view.expandCollapseParentNode(setting, node.getParentNode(), expandFlag, false);                    }                    if (expandFlag === node.open && !sonSign) {                        return null;                    }                    data.getRoot(setting).expandTriggerFlag = callbackFlag;                    if (!tools.canAsync(setting, node) && sonSign) {                        view.expandCollapseSonNode(setting, node, expandFlag, true, showNodeFocus);                    } else {                        node.open = !expandFlag;                        view.switchNode(this.setting, node);                        showNodeFocus();                    }                    return expandFlag;                    function showNodeFocus() {                        var a = $$(node, setting).get(0);                        if (a && focus !== false) {                            view.scrollIntoView(setting, a);                        }                    }                },                getNodes: function () {                    return data.getNodes(setting);                },                getNodeByParam: function (key, value, parentNode) {                    if (!key) return null;                    return data.getNodeByParam(setting, parentNode ? data.nodeChildren(setting, parentNode) : data.getNodes(setting), key, value);                },                getNodeByTId: function (tId) {                    return data.getNodeCache(setting, tId);                },                getNodesByParam: function (key, value, parentNode) {                    if (!key) return null;                    return data.getNodesByParam(setting, parentNode ? data.nodeChildren(setting, parentNode) : data.getNodes(setting), key, value);                },                getNodesByParamFuzzy: function (key, value, parentNode) {                    if (!key) return null;                    return data.getNodesByParamFuzzy(setting, parentNode ? data.nodeChildren(setting, parentNode) : data.getNodes(setting), key, value);                },                getNodesByFilter: function (filter, isSingle, parentNode, invokeParam) {                    isSingle = !!isSingle;                    if (!filter || (typeof filter != "function")) return (isSingle ? null : []);                    return data.getNodesByFilter(setting, parentNode ? data.nodeChildren(setting, parentNode) : data.getNodes(setting), filter, isSingle, invokeParam);                },                getNodeIndex: function (node) {                    if (!node) return null;                    var parentNode = (node.parentTId) ? node.getParentNode() : data.getRoot(setting);                    var children = data.nodeChildren(setting, parentNode);                    for (var i = 0, l = children.length; i < l; i++) {                        if (children[i] == node) return i;                    }                    return -1;                },                getSelectedNodes: function () {                    var r = [], list = data.getRoot(setting).curSelectedList;                    for (var i = 0, l = list.length; i < l; i++) {                        r.push(list[i]);                    }                    return r;                },                isSelectedNode: function (node) {                    return data.isSelectedNode(setting, node);                },                reAsyncChildNodesPromise: function (parentNode, reloadType, isSilent) {                    var promise = new Promise(function (resolve, reject) {                        try {                            zTreeTools.reAsyncChildNodes(parentNode, reloadType, isSilent, function () {                                resolve(parentNode);                            });                        } catch (e) {                            reject(e);                        }                    });                    return promise;                },                reAsyncChildNodes: function (parentNode, reloadType, isSilent, callback) {                    if (!this.setting.async.enable) return;                    var isRoot = !parentNode;                    if (isRoot) {                        parentNode = data.getRoot(setting);                    }                    if (reloadType == "refresh") {                        var children = data.nodeChildren(setting, parentNode);                        for (var i = 0, l = children ? children.length : 0; i < l; i++) {                            data.removeNodeCache(setting, children[i]);                        }                        data.removeSelectedNode(setting);                        data.nodeChildren(setting, parentNode, []);                        if (isRoot) {                            this.setting.treeObj.empty();                        } else {                            var ulObj = $$(parentNode, consts.id.UL, setting);                            ulObj.empty();                        }                    }                    view.asyncNode(this.setting, isRoot ? null : parentNode, !!isSilent, callback);                },                refresh: function () {                    this.setting.treeObj.empty();                    var root = data.getRoot(setting),                        nodes = data.nodeChildren(setting, root);                    data.initRoot(setting);                    data.nodeChildren(setting, root, nodes);                    data.initCache(setting);                    view.createNodes(setting, 0, data.nodeChildren(setting, root), null, -1);                },                removeChildNodes: function (node) {                    if (!node) return null;                    var nodes = data.nodeChildren(setting, node);                    view.removeChildNodes(setting, node);                    return nodes ? nodes : null;                },                removeNode: function (node, callbackFlag) {                    if (!node) return;                    callbackFlag = !!callbackFlag;                    if (callbackFlag && tools.apply(setting.callback.beforeRemove, [setting.treeId, node], true) == false) return;                    view.removeNode(setting, node);                    if (callbackFlag) {                        this.setting.treeObj.trigger(consts.event.REMOVE, [setting.treeId, node]);                    }                },                selectNode: function (node, addFlag, isSilent) {                    if (!node) return;                    if (tools.uCanDo(setting)) {                        addFlag = setting.view.selectedMulti && addFlag;                        if (node.parentTId) {                            view.expandCollapseParentNode(setting, node.getParentNode(), true, false, showNodeFocus);                        } else if (!isSilent) {                            try {                                $$(node, setting).focus().blur();                            } catch (e) {                            }                        }                        view.selectNode(setting, node, addFlag);                    }                    function showNodeFocus() {                        if (isSilent) {                            return;                        }                        var a = $$(node, setting).get(0);                        view.scrollIntoView(setting, a);                    }                },                transformTozTreeNodes: function (simpleNodes) {                    return data.transformTozTreeFormat(setting, simpleNodes);                },                transformToArray: function (nodes) {                    return data.transformToArrayFormat(setting, nodes);                },                updateNode: function (node, checkTypeFlag) {                    if (!node) return;                    var nObj = $$(node, setting);                    if (nObj.get(0) && tools.uCanDo(setting)) {                        view.setNodeName(setting, node);                        view.setNodeTarget(setting, node);                        view.setNodeUrl(setting, node);                        view.setNodeLineIcos(setting, node);                        view.setNodeFontCss(setting, node);                    }                }            };            root.treeTools = zTreeTools;            data.setZTreeTools(setting, zTreeTools);            var children = data.nodeChildren(setting, root);            if (children && children.length > 0) {                view.createNodes(setting, 0, children, null, -1);            } else if (setting.async.enable && setting.async.url && setting.async.url !== '') {                view.asyncNode(setting);            }            return zTreeTools;        }    };    var zt = $.fn.zTree,        $$ = tools.$,        consts = zt.consts;})(jQuery);
 |