jquery.ztree.core.js 73 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017
  1. /*
  2. * JQuery zTree core
  3. * v3.5.48
  4. * http://treejs.cn/
  5. *
  6. * Copyright (c) 2010 Hunter.z
  7. *
  8. * Licensed same as jquery - MIT License
  9. * http://www.opensource.org/licenses/mit-license.php
  10. *
  11. * Date: 2020-11-21
  12. */
  13. (function ($) {
  14. var settings = {}, roots = {}, caches = {},
  15. //default consts of core
  16. _consts = {
  17. className: {
  18. BUTTON: "button",
  19. LEVEL: "level",
  20. ICO_LOADING: "ico_loading",
  21. SWITCH: "switch",
  22. NAME: 'node_name'
  23. },
  24. event: {
  25. NODECREATED: "ztree_nodeCreated",
  26. CLICK: "ztree_click",
  27. EXPAND: "ztree_expand",
  28. COLLAPSE: "ztree_collapse",
  29. ASYNC_SUCCESS: "ztree_async_success",
  30. ASYNC_ERROR: "ztree_async_error",
  31. REMOVE: "ztree_remove",
  32. SELECTED: "ztree_selected",
  33. UNSELECTED: "ztree_unselected"
  34. },
  35. id: {
  36. A: "_a",
  37. ICON: "_ico",
  38. SPAN: "_span",
  39. SWITCH: "_switch",
  40. UL: "_ul"
  41. },
  42. line: {
  43. ROOT: "root",
  44. ROOTS: "roots",
  45. CENTER: "center",
  46. BOTTOM: "bottom",
  47. NOLINE: "noline",
  48. LINE: "line"
  49. },
  50. folder: {
  51. OPEN: "open",
  52. CLOSE: "close",
  53. DOCU: "docu"
  54. },
  55. node: {
  56. CURSELECTED: "curSelectedNode"
  57. }
  58. },
  59. //default setting of core
  60. _setting = {
  61. treeId: "",
  62. treeObj: null,
  63. view: {
  64. addDiyDom: null,
  65. autoCancelSelected: true,
  66. dblClickExpand: true,
  67. expandSpeed: "fast",
  68. fontCss: {},
  69. nodeClasses: {},
  70. nameIsHTML: false,
  71. selectedMulti: true,
  72. showIcon: true,
  73. showLine: true,
  74. showTitle: true,
  75. txtSelectedEnable: false
  76. },
  77. data: {
  78. key: {
  79. isParent: "isParent",
  80. children: "children",
  81. name: "name",
  82. title: "",
  83. url: "url",
  84. icon: "icon"
  85. },
  86. render: {
  87. name: null,
  88. title: null,
  89. },
  90. simpleData: {
  91. enable: false,
  92. idKey: "id",
  93. pIdKey: "pId",
  94. rootPId: null
  95. },
  96. keep: {
  97. parent: false,
  98. leaf: false
  99. }
  100. },
  101. async: {
  102. enable: false,
  103. contentType: "application/x-www-form-urlencoded",
  104. type: "post",
  105. dataType: "text",
  106. headers: {},
  107. xhrFields: {},
  108. url: "",
  109. autoParam: [],
  110. otherParam: [],
  111. dataFilter: null
  112. },
  113. callback: {
  114. beforeAsync: null,
  115. beforeClick: null,
  116. beforeDblClick: null,
  117. beforeRightClick: null,
  118. beforeMouseDown: null,
  119. beforeMouseUp: null,
  120. beforeExpand: null,
  121. beforeCollapse: null,
  122. beforeRemove: null,
  123. onAsyncError: null,
  124. onAsyncSuccess: null,
  125. onNodeCreated: null,
  126. onClick: null,
  127. onDblClick: null,
  128. onRightClick: null,
  129. onMouseDown: null,
  130. onMouseUp: null,
  131. onExpand: null,
  132. onCollapse: null,
  133. onRemove: null
  134. }
  135. },
  136. //default root of core
  137. //zTree use root to save full data
  138. _initRoot = function (setting) {
  139. var r = data.getRoot(setting);
  140. if (!r) {
  141. r = {};
  142. data.setRoot(setting, r);
  143. }
  144. data.nodeChildren(setting, r, []);
  145. r.expandTriggerFlag = false;
  146. r.curSelectedList = [];
  147. r.noSelection = true;
  148. r.createdNodes = [];
  149. r.zId = 0;
  150. r._ver = (new Date()).getTime();
  151. },
  152. //default cache of core
  153. _initCache = function (setting) {
  154. var c = data.getCache(setting);
  155. if (!c) {
  156. c = {};
  157. data.setCache(setting, c);
  158. }
  159. c.nodes = [];
  160. c.doms = [];
  161. },
  162. //default bindEvent of core
  163. _bindEvent = function (setting) {
  164. var o = setting.treeObj,
  165. c = consts.event;
  166. o.bind(c.NODECREATED, function (event, treeId, node) {
  167. tools.apply(setting.callback.onNodeCreated, [event, treeId, node]);
  168. });
  169. o.bind(c.CLICK, function (event, srcEvent, treeId, node, clickFlag) {
  170. tools.apply(setting.callback.onClick, [srcEvent, treeId, node, clickFlag]);
  171. });
  172. o.bind(c.EXPAND, function (event, treeId, node) {
  173. tools.apply(setting.callback.onExpand, [event, treeId, node]);
  174. });
  175. o.bind(c.COLLAPSE, function (event, treeId, node) {
  176. tools.apply(setting.callback.onCollapse, [event, treeId, node]);
  177. });
  178. o.bind(c.ASYNC_SUCCESS, function (event, treeId, node, msg) {
  179. tools.apply(setting.callback.onAsyncSuccess, [event, treeId, node, msg]);
  180. });
  181. o.bind(c.ASYNC_ERROR, function (event, treeId, node, XMLHttpRequest, textStatus, errorThrown) {
  182. tools.apply(setting.callback.onAsyncError, [event, treeId, node, XMLHttpRequest, textStatus, errorThrown]);
  183. });
  184. o.bind(c.REMOVE, function (event, treeId, treeNode) {
  185. tools.apply(setting.callback.onRemove, [event, treeId, treeNode]);
  186. });
  187. o.bind(c.SELECTED, function (event, treeId, node) {
  188. tools.apply(setting.callback.onSelected, [treeId, node]);
  189. });
  190. o.bind(c.UNSELECTED, function (event, treeId, node) {
  191. tools.apply(setting.callback.onUnSelected, [treeId, node]);
  192. });
  193. },
  194. _unbindEvent = function (setting) {
  195. var o = setting.treeObj,
  196. c = consts.event;
  197. o.unbind(c.NODECREATED)
  198. .unbind(c.CLICK)
  199. .unbind(c.EXPAND)
  200. .unbind(c.COLLAPSE)
  201. .unbind(c.ASYNC_SUCCESS)
  202. .unbind(c.ASYNC_ERROR)
  203. .unbind(c.REMOVE)
  204. .unbind(c.SELECTED)
  205. .unbind(c.UNSELECTED);
  206. },
  207. //default event proxy of core
  208. _eventProxy = function (event) {
  209. var target = event.target,
  210. setting = data.getSetting(event.data.treeId),
  211. tId = "", node = null,
  212. nodeEventType = "", treeEventType = "",
  213. nodeEventCallback = null, treeEventCallback = null,
  214. tmp = null;
  215. if (tools.eqs(event.type, "mousedown")) {
  216. treeEventType = "mousedown";
  217. } else if (tools.eqs(event.type, "mouseup")) {
  218. treeEventType = "mouseup";
  219. } else if (tools.eqs(event.type, "contextmenu")) {
  220. treeEventType = "contextmenu";
  221. } else if (tools.eqs(event.type, "click")) {
  222. if (tools.eqs(target.tagName, "span") && target.getAttribute("treeNode" + consts.id.SWITCH) !== null) {
  223. tId = tools.getNodeMainDom(target).id;
  224. nodeEventType = "switchNode";
  225. } else {
  226. tmp = tools.getMDom(setting, target, [{tagName: "a", attrName: "treeNode" + consts.id.A}]);
  227. if (tmp) {
  228. tId = tools.getNodeMainDom(tmp).id;
  229. nodeEventType = "clickNode";
  230. }
  231. }
  232. } else if (tools.eqs(event.type, "dblclick")) {
  233. treeEventType = "dblclick";
  234. tmp = tools.getMDom(setting, target, [{tagName: "a", attrName: "treeNode" + consts.id.A}]);
  235. if (tmp) {
  236. tId = tools.getNodeMainDom(tmp).id;
  237. nodeEventType = "switchNode";
  238. }
  239. }
  240. if (treeEventType.length > 0 && tId.length == 0) {
  241. tmp = tools.getMDom(setting, target, [{tagName: "a", attrName: "treeNode" + consts.id.A}]);
  242. if (tmp) {
  243. tId = tools.getNodeMainDom(tmp).id;
  244. }
  245. }
  246. // event to node
  247. if (tId.length > 0) {
  248. node = data.getNodeCache(setting, tId);
  249. switch (nodeEventType) {
  250. case "switchNode" :
  251. var isParent = data.nodeIsParent(setting, node);
  252. if (!isParent) {
  253. nodeEventType = "";
  254. } else if (tools.eqs(event.type, "click")
  255. || (tools.eqs(event.type, "dblclick") && tools.apply(setting.view.dblClickExpand, [setting.treeId, node], setting.view.dblClickExpand))) {
  256. nodeEventCallback = handler.onSwitchNode;
  257. } else {
  258. nodeEventType = "";
  259. }
  260. break;
  261. case "clickNode" :
  262. nodeEventCallback = handler.onClickNode;
  263. break;
  264. }
  265. }
  266. // event to zTree
  267. switch (treeEventType) {
  268. case "mousedown" :
  269. treeEventCallback = handler.onZTreeMousedown;
  270. break;
  271. case "mouseup" :
  272. treeEventCallback = handler.onZTreeMouseup;
  273. break;
  274. case "dblclick" :
  275. treeEventCallback = handler.onZTreeDblclick;
  276. break;
  277. case "contextmenu" :
  278. treeEventCallback = handler.onZTreeContextmenu;
  279. break;
  280. }
  281. var proxyResult = {
  282. stop: false,
  283. node: node,
  284. nodeEventType: nodeEventType,
  285. nodeEventCallback: nodeEventCallback,
  286. treeEventType: treeEventType,
  287. treeEventCallback: treeEventCallback
  288. };
  289. return proxyResult
  290. },
  291. //default init node of core
  292. _initNode = function (setting, level, n, parentNode, isFirstNode, isLastNode, openFlag) {
  293. if (!n) return;
  294. var r = data.getRoot(setting),
  295. children = data.nodeChildren(setting, n);
  296. n.level = level;
  297. n.tId = setting.treeId + "_" + (++r.zId);
  298. n.parentTId = parentNode ? parentNode.tId : null;
  299. n.open = (typeof n.open == "string") ? tools.eqs(n.open, "true") : !!n.open;
  300. var isParent = data.nodeIsParent(setting, n);
  301. if (tools.isArray(children)) {
  302. data.nodeIsParent(setting, n, true);
  303. n.zAsync = true;
  304. } else {
  305. isParent = data.nodeIsParent(setting, n, isParent);
  306. n.open = (isParent && !setting.async.enable) ? n.open : false;
  307. n.zAsync = !isParent;
  308. }
  309. n.isFirstNode = isFirstNode;
  310. n.isLastNode = isLastNode;
  311. n.getParentNode = function () {
  312. return data.getNodeCache(setting, n.parentTId);
  313. };
  314. n.getPreNode = function () {
  315. return data.getPreNode(setting, n);
  316. };
  317. n.getNextNode = function () {
  318. return data.getNextNode(setting, n);
  319. };
  320. n.getIndex = function () {
  321. return data.getNodeIndex(setting, n);
  322. };
  323. n.getPath = function () {
  324. return data.getNodePath(setting, n);
  325. };
  326. n.isAjaxing = false;
  327. data.fixPIdKeyValue(setting, n);
  328. },
  329. _init = {
  330. bind: [_bindEvent],
  331. unbind: [_unbindEvent],
  332. caches: [_initCache],
  333. nodes: [_initNode],
  334. proxys: [_eventProxy],
  335. roots: [_initRoot],
  336. beforeA: [],
  337. afterA: [],
  338. innerBeforeA: [],
  339. innerAfterA: [],
  340. zTreeTools: []
  341. },
  342. //method of operate data
  343. data = {
  344. addNodeCache: function (setting, node) {
  345. data.getCache(setting).nodes[data.getNodeCacheId(node.tId)] = node;
  346. },
  347. getNodeCacheId: function (tId) {
  348. return tId.substring(tId.lastIndexOf("_") + 1);
  349. },
  350. addAfterA: function (afterA) {
  351. _init.afterA.push(afterA);
  352. },
  353. addBeforeA: function (beforeA) {
  354. _init.beforeA.push(beforeA);
  355. },
  356. addInnerAfterA: function (innerAfterA) {
  357. _init.innerAfterA.push(innerAfterA);
  358. },
  359. addInnerBeforeA: function (innerBeforeA) {
  360. _init.innerBeforeA.push(innerBeforeA);
  361. },
  362. addInitBind: function (bindEvent) {
  363. _init.bind.push(bindEvent);
  364. },
  365. addInitUnBind: function (unbindEvent) {
  366. _init.unbind.push(unbindEvent);
  367. },
  368. addInitCache: function (initCache) {
  369. _init.caches.push(initCache);
  370. },
  371. addInitNode: function (initNode) {
  372. _init.nodes.push(initNode);
  373. },
  374. addInitProxy: function (initProxy, isFirst) {
  375. if (!!isFirst) {
  376. _init.proxys.splice(0, 0, initProxy);
  377. } else {
  378. _init.proxys.push(initProxy);
  379. }
  380. },
  381. addInitRoot: function (initRoot) {
  382. _init.roots.push(initRoot);
  383. },
  384. addNodesData: function (setting, parentNode, index, nodes) {
  385. var children = data.nodeChildren(setting, parentNode), params;
  386. if (!children) {
  387. children = data.nodeChildren(setting, parentNode, []);
  388. index = -1;
  389. } else if (index >= children.length) {
  390. index = -1;
  391. }
  392. if (children.length > 0 && index === 0) {
  393. children[0].isFirstNode = false;
  394. view.setNodeLineIcos(setting, children[0]);
  395. } else if (children.length > 0 && index < 0) {
  396. children[children.length - 1].isLastNode = false;
  397. view.setNodeLineIcos(setting, children[children.length - 1]);
  398. }
  399. data.nodeIsParent(setting, parentNode, true);
  400. if (index < 0) {
  401. data.nodeChildren(setting, parentNode, children.concat(nodes));
  402. } else {
  403. params = [index, 0].concat(nodes);
  404. children.splice.apply(children, params);
  405. }
  406. },
  407. addSelectedNode: function (setting, node) {
  408. var root = data.getRoot(setting);
  409. if (!data.isSelectedNode(setting, node)) {
  410. root.curSelectedList.push(node);
  411. }
  412. },
  413. addCreatedNode: function (setting, node) {
  414. if (!!setting.callback.onNodeCreated || !!setting.view.addDiyDom) {
  415. var root = data.getRoot(setting);
  416. root.createdNodes.push(node);
  417. }
  418. },
  419. addZTreeTools: function (zTreeTools) {
  420. _init.zTreeTools.push(zTreeTools);
  421. },
  422. exSetting: function (s) {
  423. $.extend(true, _setting, s);
  424. },
  425. fixPIdKeyValue: function (setting, node) {
  426. if (setting.data.simpleData.enable) {
  427. node[setting.data.simpleData.pIdKey] = node.parentTId ? node.getParentNode()[setting.data.simpleData.idKey] : setting.data.simpleData.rootPId;
  428. }
  429. },
  430. getAfterA: function (setting, node, array) {
  431. for (var i = 0, j = _init.afterA.length; i < j; i++) {
  432. _init.afterA[i].apply(this, arguments);
  433. }
  434. },
  435. getBeforeA: function (setting, node, array) {
  436. for (var i = 0, j = _init.beforeA.length; i < j; i++) {
  437. _init.beforeA[i].apply(this, arguments);
  438. }
  439. },
  440. getInnerAfterA: function (setting, node, array) {
  441. for (var i = 0, j = _init.innerAfterA.length; i < j; i++) {
  442. _init.innerAfterA[i].apply(this, arguments);
  443. }
  444. },
  445. getInnerBeforeA: function (setting, node, array) {
  446. for (var i = 0, j = _init.innerBeforeA.length; i < j; i++) {
  447. _init.innerBeforeA[i].apply(this, arguments);
  448. }
  449. },
  450. getCache: function (setting) {
  451. return caches[setting.treeId];
  452. },
  453. getNodeIndex: function (setting, node) {
  454. if (!node) return null;
  455. var p = node.parentTId ? node.getParentNode() : data.getRoot(setting),
  456. children = data.nodeChildren(setting, p);
  457. for (var i = 0, l = children.length - 1; i <= l; i++) {
  458. if (children[i] === node) {
  459. return i;
  460. }
  461. }
  462. return -1;
  463. },
  464. getNextNode: function (setting, node) {
  465. if (!node) return null;
  466. var p = node.parentTId ? node.getParentNode() : data.getRoot(setting),
  467. children = data.nodeChildren(setting, p);
  468. for (var i = 0, l = children.length - 1; i <= l; i++) {
  469. if (children[i] === node) {
  470. return (i == l ? null : children[i + 1]);
  471. }
  472. }
  473. return null;
  474. },
  475. getNodeByParam: function (setting, nodes, key, value) {
  476. if (!nodes || !key) return null;
  477. for (var i = 0, l = nodes.length; i < l; i++) {
  478. var node = nodes[i];
  479. if (node[key] == value) {
  480. return nodes[i];
  481. }
  482. var children = data.nodeChildren(setting, node);
  483. var tmp = data.getNodeByParam(setting, children, key, value);
  484. if (tmp) return tmp;
  485. }
  486. return null;
  487. },
  488. getNodeCache: function (setting, tId) {
  489. if (!tId) return null;
  490. var n = caches[setting.treeId].nodes[data.getNodeCacheId(tId)];
  491. return n ? n : null;
  492. },
  493. getNodePath: function (setting, node) {
  494. if (!node) return null;
  495. var path;
  496. if (node.parentTId) {
  497. path = node.getParentNode().getPath();
  498. } else {
  499. path = [];
  500. }
  501. if (path) {
  502. path.push(node);
  503. }
  504. return path;
  505. },
  506. getNodes: function (setting) {
  507. return data.nodeChildren(setting, data.getRoot(setting));
  508. },
  509. getNodesByParam: function (setting, nodes, key, value) {
  510. if (!nodes || !key) return [];
  511. var result = [];
  512. for (var i = 0, l = nodes.length; i < l; i++) {
  513. var node = nodes[i];
  514. if (node[key] == value) {
  515. result.push(node);
  516. }
  517. var children = data.nodeChildren(setting, node);
  518. result = result.concat(data.getNodesByParam(setting, children, key, value));
  519. }
  520. return result;
  521. },
  522. getNodesByParamFuzzy: function (setting, nodes, key, value) {
  523. if (!nodes || !key) return [];
  524. var result = [];
  525. value = value.toLowerCase();
  526. for (var i = 0, l = nodes.length; i < l; i++) {
  527. var node = nodes[i];
  528. if (typeof node[key] == "string" && nodes[i][key].toLowerCase().indexOf(value) > -1) {
  529. result.push(node);
  530. }
  531. var children = data.nodeChildren(setting, node);
  532. result = result.concat(data.getNodesByParamFuzzy(setting, children, key, value));
  533. }
  534. return result;
  535. },
  536. getNodesByFilter: function (setting, nodes, filter, isSingle, invokeParam) {
  537. if (!nodes) return (isSingle ? null : []);
  538. var result = isSingle ? null : [];
  539. for (var i = 0, l = nodes.length; i < l; i++) {
  540. var node = nodes[i];
  541. if (tools.apply(filter, [node, invokeParam], false)) {
  542. if (isSingle) {
  543. return node;
  544. }
  545. result.push(node);
  546. }
  547. var children = data.nodeChildren(setting, node);
  548. var tmpResult = data.getNodesByFilter(setting, children, filter, isSingle, invokeParam);
  549. if (isSingle && !!tmpResult) {
  550. return tmpResult;
  551. }
  552. result = isSingle ? tmpResult : result.concat(tmpResult);
  553. }
  554. return result;
  555. },
  556. getPreNode: function (setting, node) {
  557. if (!node) return null;
  558. var p = node.parentTId ? node.getParentNode() : data.getRoot(setting),
  559. children = data.nodeChildren(setting, p);
  560. for (var i = 0, l = children.length; i < l; i++) {
  561. if (children[i] === node) {
  562. return (i == 0 ? null : children[i - 1]);
  563. }
  564. }
  565. return null;
  566. },
  567. getRoot: function (setting) {
  568. return setting ? roots[setting.treeId] : null;
  569. },
  570. getRoots: function () {
  571. return roots;
  572. },
  573. getSetting: function (treeId) {
  574. return settings[treeId];
  575. },
  576. getSettings: function () {
  577. return settings;
  578. },
  579. getZTreeTools: function (treeId) {
  580. var r = this.getRoot(this.getSetting(treeId));
  581. return r ? r.treeTools : null;
  582. },
  583. initCache: function (setting) {
  584. for (var i = 0, j = _init.caches.length; i < j; i++) {
  585. _init.caches[i].apply(this, arguments);
  586. }
  587. },
  588. initNode: function (setting, level, node, parentNode, preNode, nextNode) {
  589. for (var i = 0, j = _init.nodes.length; i < j; i++) {
  590. _init.nodes[i].apply(this, arguments);
  591. }
  592. },
  593. initRoot: function (setting) {
  594. for (var i = 0, j = _init.roots.length; i < j; i++) {
  595. _init.roots[i].apply(this, arguments);
  596. }
  597. },
  598. isSelectedNode: function (setting, node) {
  599. var root = data.getRoot(setting);
  600. for (var i = 0, j = root.curSelectedList.length; i < j; i++) {
  601. if (node === root.curSelectedList[i]) return true;
  602. }
  603. return false;
  604. },
  605. nodeChildren: function (setting, node, newChildren) {
  606. if (!node) {
  607. return null;
  608. }
  609. var key = setting.data.key.children;
  610. if (typeof newChildren !== 'undefined') {
  611. node[key] = newChildren;
  612. }
  613. return node[key];
  614. },
  615. nodeIsParent: function (setting, node, newIsParent) {
  616. if (!node) {
  617. return false;
  618. }
  619. var key = setting.data.key.isParent;
  620. if (typeof newIsParent !== 'undefined') {
  621. if (typeof newIsParent === "string") {
  622. newIsParent = tools.eqs(newIsParent, "true");
  623. }
  624. newIsParent = !!newIsParent;
  625. node[key] = newIsParent;
  626. } else if (typeof node[key] == "string"){
  627. node[key] = tools.eqs(node[key], "true");
  628. } else {
  629. node[key] = !!node[key];
  630. }
  631. return node[key];
  632. },
  633. nodeName: function (setting, node, newName) {
  634. var key = setting.data.key.name;
  635. if (typeof newName !== 'undefined') {
  636. node[key] = newName;
  637. }
  638. var rawName = "" + node[key];
  639. if(typeof setting.data.render.name === 'function') {
  640. return setting.data.render.name.call(this,rawName,node);
  641. }
  642. return rawName;
  643. },
  644. nodeTitle: function (setting, node) {
  645. var t = setting.data.key.title === "" ? setting.data.key.name : setting.data.key.title;
  646. var rawTitle = "" + node[t];
  647. if(typeof setting.data.render.title === 'function') {
  648. return setting.data.render.title.call(this,rawTitle,node);
  649. }
  650. return rawTitle;
  651. },
  652. removeNodeCache: function (setting, node) {
  653. var children = data.nodeChildren(setting, node);
  654. if (children) {
  655. for (var i = 0, l = children.length; i < l; i++) {
  656. data.removeNodeCache(setting, children[i]);
  657. }
  658. }
  659. data.getCache(setting).nodes[data.getNodeCacheId(node.tId)] = null;
  660. },
  661. removeSelectedNode: function (setting, node) {
  662. var root = data.getRoot(setting);
  663. for (var i = 0, j = root.curSelectedList.length; i < j; i++) {
  664. if (node === root.curSelectedList[i] || !data.getNodeCache(setting, root.curSelectedList[i].tId)) {
  665. root.curSelectedList.splice(i, 1);
  666. setting.treeObj.trigger(consts.event.UNSELECTED, [setting.treeId, node]);
  667. i--;
  668. j--;
  669. }
  670. }
  671. },
  672. setCache: function (setting, cache) {
  673. caches[setting.treeId] = cache;
  674. },
  675. setRoot: function (setting, root) {
  676. roots[setting.treeId] = root;
  677. },
  678. setZTreeTools: function (setting, zTreeTools) {
  679. for (var i = 0, j = _init.zTreeTools.length; i < j; i++) {
  680. _init.zTreeTools[i].apply(this, arguments);
  681. }
  682. },
  683. transformToArrayFormat: function (setting, nodes) {
  684. if (!nodes) return [];
  685. var r = [];
  686. if (tools.isArray(nodes)) {
  687. for (var i = 0, l = nodes.length; i < l; i++) {
  688. var node = nodes[i];
  689. _do(node);
  690. }
  691. } else {
  692. _do(nodes);
  693. }
  694. return r;
  695. function _do(_node) {
  696. r.push(_node);
  697. var children = data.nodeChildren(setting, _node);
  698. if (children) {
  699. r = r.concat(data.transformToArrayFormat(setting, children));
  700. }
  701. }
  702. },
  703. transformTozTreeFormat: function (setting, sNodes) {
  704. var i, l,
  705. key = setting.data.simpleData.idKey,
  706. parentKey = setting.data.simpleData.pIdKey;
  707. if (!key || key == "" || !sNodes) return [];
  708. if (tools.isArray(sNodes)) {
  709. var r = [];
  710. var tmpMap = {};
  711. for (i = 0, l = sNodes.length; i < l; i++) {
  712. tmpMap[sNodes[i][key]] = sNodes[i];
  713. }
  714. for (i = 0, l = sNodes.length; i < l; i++) {
  715. var p = tmpMap[sNodes[i][parentKey]];
  716. if (p && sNodes[i][key] != sNodes[i][parentKey]) {
  717. var children = data.nodeChildren(setting, p);
  718. if (!children) {
  719. children = data.nodeChildren(setting, p, []);
  720. }
  721. children.push(sNodes[i]);
  722. } else {
  723. r.push(sNodes[i]);
  724. }
  725. }
  726. return r;
  727. } else {
  728. return [sNodes];
  729. }
  730. }
  731. },
  732. //method of event proxy
  733. event = {
  734. bindEvent: function (setting) {
  735. for (var i = 0, j = _init.bind.length; i < j; i++) {
  736. _init.bind[i].apply(this, arguments);
  737. }
  738. },
  739. unbindEvent: function (setting) {
  740. for (var i = 0, j = _init.unbind.length; i < j; i++) {
  741. _init.unbind[i].apply(this, arguments);
  742. }
  743. },
  744. bindTree: function (setting) {
  745. var eventParam = {
  746. treeId: setting.treeId
  747. },
  748. o = setting.treeObj;
  749. if (!setting.view.txtSelectedEnable) {
  750. // for can't select text
  751. o.bind('selectstart', handler.onSelectStart).css({
  752. "-moz-user-select": "-moz-none"
  753. });
  754. }
  755. o.bind('click', eventParam, event.proxy);
  756. o.bind('dblclick', eventParam, event.proxy);
  757. o.bind('mouseover', eventParam, event.proxy);
  758. o.bind('mouseout', eventParam, event.proxy);
  759. o.bind('mousedown', eventParam, event.proxy);
  760. o.bind('mouseup', eventParam, event.proxy);
  761. o.bind('contextmenu', eventParam, event.proxy);
  762. },
  763. unbindTree: function (setting) {
  764. var o = setting.treeObj;
  765. o.unbind('selectstart', handler.onSelectStart)
  766. .unbind('click', event.proxy)
  767. .unbind('dblclick', event.proxy)
  768. .unbind('mouseover', event.proxy)
  769. .unbind('mouseout', event.proxy)
  770. .unbind('mousedown', event.proxy)
  771. .unbind('mouseup', event.proxy)
  772. .unbind('contextmenu', event.proxy);
  773. },
  774. doProxy: function (e) {
  775. var results = [];
  776. for (var i = 0, j = _init.proxys.length; i < j; i++) {
  777. var proxyResult = _init.proxys[i].apply(this, arguments);
  778. results.push(proxyResult);
  779. if (proxyResult.stop) {
  780. break;
  781. }
  782. }
  783. return results;
  784. },
  785. proxy: function (e) {
  786. var setting = data.getSetting(e.data.treeId);
  787. if (!tools.uCanDo(setting, e)) return true;
  788. var results = event.doProxy(e),
  789. r = true;
  790. for (var i = 0, l = results.length; i < l; i++) {
  791. var proxyResult = results[i];
  792. if (proxyResult.nodeEventCallback) {
  793. r = proxyResult.nodeEventCallback.apply(proxyResult, [e, proxyResult.node]) && r;
  794. }
  795. if (proxyResult.treeEventCallback) {
  796. r = proxyResult.treeEventCallback.apply(proxyResult, [e, proxyResult.node]) && r;
  797. }
  798. }
  799. return r;
  800. }
  801. },
  802. //method of event handler
  803. handler = {
  804. onSwitchNode: function (event, node) {
  805. var setting = data.getSetting(event.data.treeId);
  806. if (node.open) {
  807. if (tools.apply(setting.callback.beforeCollapse, [setting.treeId, node], true) == false) return true;
  808. data.getRoot(setting).expandTriggerFlag = true;
  809. view.switchNode(setting, node);
  810. } else {
  811. if (tools.apply(setting.callback.beforeExpand, [setting.treeId, node], true) == false) return true;
  812. data.getRoot(setting).expandTriggerFlag = true;
  813. view.switchNode(setting, node);
  814. }
  815. return true;
  816. },
  817. onClickNode: function (event, node) {
  818. var setting = data.getSetting(event.data.treeId),
  819. 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;
  820. if (tools.apply(setting.callback.beforeClick, [setting.treeId, node, clickFlag], true) == false) return true;
  821. if (clickFlag === 0) {
  822. view.cancelPreSelectedNode(setting, node);
  823. } else {
  824. view.selectNode(setting, node, clickFlag === 2);
  825. }
  826. setting.treeObj.trigger(consts.event.CLICK, [event, setting.treeId, node, clickFlag]);
  827. return true;
  828. },
  829. onZTreeMousedown: function (event, node) {
  830. var setting = data.getSetting(event.data.treeId);
  831. if (tools.apply(setting.callback.beforeMouseDown, [setting.treeId, node], true)) {
  832. tools.apply(setting.callback.onMouseDown, [event, setting.treeId, node]);
  833. }
  834. return true;
  835. },
  836. onZTreeMouseup: function (event, node) {
  837. var setting = data.getSetting(event.data.treeId);
  838. if (tools.apply(setting.callback.beforeMouseUp, [setting.treeId, node], true)) {
  839. tools.apply(setting.callback.onMouseUp, [event, setting.treeId, node]);
  840. }
  841. return true;
  842. },
  843. onZTreeDblclick: function (event, node) {
  844. var setting = data.getSetting(event.data.treeId);
  845. if (tools.apply(setting.callback.beforeDblClick, [setting.treeId, node], true)) {
  846. tools.apply(setting.callback.onDblClick, [event, setting.treeId, node]);
  847. }
  848. return true;
  849. },
  850. onZTreeContextmenu: function (event, node) {
  851. var setting = data.getSetting(event.data.treeId);
  852. if (tools.apply(setting.callback.beforeRightClick, [setting.treeId, node], true)) {
  853. tools.apply(setting.callback.onRightClick, [event, setting.treeId, node]);
  854. }
  855. return (typeof setting.callback.onRightClick) != "function";
  856. },
  857. onSelectStart: function (e) {
  858. var n = e.originalEvent.srcElement.nodeName.toLowerCase();
  859. return (n === "input" || n === "textarea");
  860. }
  861. },
  862. //method of tools for zTree
  863. tools = {
  864. apply: function (fun, param, defaultValue) {
  865. if ((typeof fun) == "function") {
  866. return fun.apply(zt, param ? param : []);
  867. }
  868. return defaultValue;
  869. },
  870. canAsync: function (setting, node) {
  871. var children = data.nodeChildren(setting, node);
  872. var isParent = data.nodeIsParent(setting, node);
  873. return (setting.async.enable && node && isParent && !(node.zAsync || (children && children.length > 0)));
  874. },
  875. clone: function (obj) {
  876. if (obj === null) return null;
  877. var o = tools.isArray(obj) ? [] : {};
  878. for (var i in obj) {
  879. o[i] = (obj[i] instanceof Date) ? new Date(obj[i].getTime()) : (typeof obj[i] === "object" ? tools.clone(obj[i]) : obj[i]);
  880. }
  881. return o;
  882. },
  883. eqs: function (str1, str2) {
  884. return str1.toLowerCase() === str2.toLowerCase();
  885. },
  886. isArray: function (arr) {
  887. return Object.prototype.toString.apply(arr) === "[object Array]";
  888. },
  889. isElement: function (o) {
  890. return (
  891. typeof HTMLElement === "object" ? o instanceof HTMLElement : //DOM2
  892. o && typeof o === "object" && o !== null && o.nodeType === 1 && typeof o.nodeName === "string"
  893. );
  894. },
  895. $: function (node, exp, setting) {
  896. if (!!exp && typeof exp != "string") {
  897. setting = exp;
  898. exp = "";
  899. }
  900. if (typeof node == "string") {
  901. return $(node, setting ? setting.treeObj.get(0).ownerDocument : null);
  902. } else {
  903. return $("#" + node.tId + exp, setting ? setting.treeObj : null);
  904. }
  905. },
  906. getMDom: function (setting, curDom, targetExpr) {
  907. if (!curDom) return null;
  908. while (curDom && curDom.id !== setting.treeId) {
  909. for (var i = 0, l = targetExpr.length; curDom.tagName && i < l; i++) {
  910. if (tools.eqs(curDom.tagName, targetExpr[i].tagName) && curDom.getAttribute(targetExpr[i].attrName) !== null) {
  911. return curDom;
  912. }
  913. }
  914. curDom = curDom.parentNode;
  915. }
  916. return null;
  917. },
  918. getNodeMainDom: function (target) {
  919. return ($(target).parent("li").get(0) || $(target).parentsUntil("li").parent().get(0));
  920. },
  921. isChildOrSelf: function (dom, parentId) {
  922. return ($(dom).closest("#" + parentId).length > 0);
  923. },
  924. uCanDo: function (setting, e) {
  925. return true;
  926. }
  927. },
  928. //method of operate ztree dom
  929. view = {
  930. addNodes: function (setting, parentNode, index, newNodes, isSilent) {
  931. var isParent = data.nodeIsParent(setting, parentNode);
  932. if (setting.data.keep.leaf && parentNode && !isParent) {
  933. return;
  934. }
  935. if (!tools.isArray(newNodes)) {
  936. newNodes = [newNodes];
  937. }
  938. if (setting.data.simpleData.enable) {
  939. newNodes = data.transformTozTreeFormat(setting, newNodes);
  940. }
  941. if (parentNode) {
  942. var target_switchObj = $$(parentNode, consts.id.SWITCH, setting),
  943. target_icoObj = $$(parentNode, consts.id.ICON, setting),
  944. target_ulObj = $$(parentNode, consts.id.UL, setting);
  945. if (!parentNode.open) {
  946. view.replaceSwitchClass(parentNode, target_switchObj, consts.folder.CLOSE);
  947. view.replaceIcoClass(parentNode, target_icoObj, consts.folder.CLOSE);
  948. parentNode.open = false;
  949. target_ulObj.css({
  950. "display": "none"
  951. });
  952. }
  953. data.addNodesData(setting, parentNode, index, newNodes);
  954. view.createNodes(setting, parentNode.level + 1, newNodes, parentNode, index);
  955. if (!isSilent) {
  956. view.expandCollapseParentNode(setting, parentNode, true);
  957. }
  958. } else {
  959. data.addNodesData(setting, data.getRoot(setting), index, newNodes);
  960. view.createNodes(setting, 0, newNodes, null, index);
  961. }
  962. },
  963. appendNodes: function (setting, level, nodes, parentNode, index, initFlag, openFlag) {
  964. if (!nodes) return [];
  965. var html = [];
  966. var tmpPNode = (parentNode) ? parentNode : data.getRoot(setting),
  967. tmpPChild = data.nodeChildren(setting, tmpPNode),
  968. isFirstNode, isLastNode;
  969. if (!tmpPChild || index >= tmpPChild.length - nodes.length) {
  970. index = -1;
  971. }
  972. for (var i = 0, l = nodes.length; i < l; i++) {
  973. var node = nodes[i];
  974. if (initFlag) {
  975. isFirstNode = ((index === 0 || tmpPChild.length == nodes.length) && (i == 0));
  976. isLastNode = (index < 0 && i == (nodes.length - 1));
  977. data.initNode(setting, level, node, parentNode, isFirstNode, isLastNode, openFlag);
  978. data.addNodeCache(setting, node);
  979. }
  980. var isParent = data.nodeIsParent(setting, node);
  981. var childHtml = [];
  982. var children = data.nodeChildren(setting, node);
  983. if (children && children.length > 0) {
  984. //make child html first, because checkType
  985. childHtml = view.appendNodes(setting, level + 1, children, node, -1, initFlag, openFlag && node.open);
  986. }
  987. if (openFlag) {
  988. view.makeDOMNodeMainBefore(html, setting, node);
  989. view.makeDOMNodeLine(html, setting, node);
  990. data.getBeforeA(setting, node, html);
  991. view.makeDOMNodeNameBefore(html, setting, node);
  992. data.getInnerBeforeA(setting, node, html);
  993. view.makeDOMNodeIcon(html, setting, node);
  994. data.getInnerAfterA(setting, node, html);
  995. view.makeDOMNodeNameAfter(html, setting, node);
  996. data.getAfterA(setting, node, html);
  997. if (isParent && node.open) {
  998. view.makeUlHtml(setting, node, html, childHtml.join(''));
  999. }
  1000. view.makeDOMNodeMainAfter(html, setting, node);
  1001. data.addCreatedNode(setting, node);
  1002. }
  1003. }
  1004. return html;
  1005. },
  1006. appendParentULDom: function (setting, node) {
  1007. var html = [],
  1008. nObj = $$(node, setting);
  1009. if (!nObj.get(0) && !!node.parentTId) {
  1010. view.appendParentULDom(setting, node.getParentNode());
  1011. nObj = $$(node, setting);
  1012. }
  1013. var ulObj = $$(node, consts.id.UL, setting);
  1014. if (ulObj.get(0)) {
  1015. ulObj.remove();
  1016. }
  1017. var children = data.nodeChildren(setting, node),
  1018. childHtml = view.appendNodes(setting, node.level + 1, children, node, -1, false, true);
  1019. view.makeUlHtml(setting, node, html, childHtml.join(''));
  1020. nObj.append(html.join(''));
  1021. },
  1022. asyncNode: function (setting, node, isSilent, callback) {
  1023. var i, l;
  1024. var isParent = data.nodeIsParent(setting, node);
  1025. if (node && !isParent) {
  1026. tools.apply(callback);
  1027. return false;
  1028. } else if (node && node.isAjaxing) {
  1029. return false;
  1030. } else if (tools.apply(setting.callback.beforeAsync, [setting.treeId, node], true) == false) {
  1031. tools.apply(callback);
  1032. return false;
  1033. }
  1034. if (node) {
  1035. node.isAjaxing = true;
  1036. var icoObj = $$(node, consts.id.ICON, setting);
  1037. icoObj.attr({"style": "", "class": consts.className.BUTTON + " " + consts.className.ICO_LOADING});
  1038. }
  1039. var tmpParam = {};
  1040. var autoParam = tools.apply(setting.async.autoParam, [setting.treeId, node], setting.async.autoParam);
  1041. for (i = 0, l = autoParam.length; node && i < l; i++) {
  1042. var pKey = autoParam[i].split("="), spKey = pKey;
  1043. if (pKey.length > 1) {
  1044. spKey = pKey[1];
  1045. pKey = pKey[0];
  1046. }
  1047. tmpParam[spKey] = node[pKey];
  1048. }
  1049. var otherParam = tools.apply(setting.async.otherParam, [setting.treeId, node], setting.async.otherParam);
  1050. if (tools.isArray(otherParam)) {
  1051. for (i = 0, l = otherParam.length; i < l; i += 2) {
  1052. tmpParam[otherParam[i]] = otherParam[i + 1];
  1053. }
  1054. } else {
  1055. for (var p in otherParam) {
  1056. tmpParam[p] = otherParam[p];
  1057. }
  1058. }
  1059. var _tmpV = data.getRoot(setting)._ver;
  1060. $.ajax({
  1061. contentType: setting.async.contentType,
  1062. cache: false,
  1063. type: setting.async.type,
  1064. url: tools.apply(setting.async.url, [setting.treeId, node], setting.async.url),
  1065. data: setting.async.contentType.indexOf('application/json') > -1 ? JSON.stringify(tmpParam) : tmpParam,
  1066. dataType: setting.async.dataType,
  1067. headers: setting.async.headers,
  1068. xhrFields: setting.async.xhrFields,
  1069. success: function (msg) {
  1070. if (_tmpV != data.getRoot(setting)._ver) {
  1071. return;
  1072. }
  1073. var newNodes = [];
  1074. try {
  1075. if (!msg || msg.length == 0) {
  1076. newNodes = [];
  1077. } else if (typeof msg == "string") {
  1078. newNodes = eval("(" + msg + ")");
  1079. } else {
  1080. newNodes = msg;
  1081. }
  1082. } catch (err) {
  1083. newNodes = msg;
  1084. }
  1085. if (node) {
  1086. node.isAjaxing = null;
  1087. node.zAsync = true;
  1088. }
  1089. view.setNodeLineIcos(setting, node);
  1090. if (newNodes && newNodes !== "") {
  1091. newNodes = tools.apply(setting.async.dataFilter, [setting.treeId, node, newNodes], newNodes);
  1092. view.addNodes(setting, node, -1, !!newNodes ? tools.clone(newNodes) : [], !!isSilent);
  1093. } else {
  1094. view.addNodes(setting, node, -1, [], !!isSilent);
  1095. }
  1096. setting.treeObj.trigger(consts.event.ASYNC_SUCCESS, [setting.treeId, node, msg]);
  1097. tools.apply(callback);
  1098. },
  1099. error: function (XMLHttpRequest, textStatus, errorThrown) {
  1100. if (_tmpV != data.getRoot(setting)._ver) {
  1101. return;
  1102. }
  1103. if (node) node.isAjaxing = null;
  1104. view.setNodeLineIcos(setting, node);
  1105. setting.treeObj.trigger(consts.event.ASYNC_ERROR, [setting.treeId, node, XMLHttpRequest, textStatus, errorThrown]);
  1106. }
  1107. });
  1108. return true;
  1109. },
  1110. cancelPreSelectedNode: function (setting, node, excludeNode) {
  1111. var list = data.getRoot(setting).curSelectedList,
  1112. i, n;
  1113. for (i = list.length - 1; i >= 0; i--) {
  1114. n = list[i];
  1115. if (node === n || (!node && (!excludeNode || excludeNode !== n))) {
  1116. $$(n, consts.id.A, setting).removeClass(consts.node.CURSELECTED);
  1117. if (node) {
  1118. data.removeSelectedNode(setting, node);
  1119. break;
  1120. } else {
  1121. list.splice(i, 1);
  1122. setting.treeObj.trigger(consts.event.UNSELECTED, [setting.treeId, n]);
  1123. }
  1124. }
  1125. }
  1126. },
  1127. createNodeCallback: function (setting) {
  1128. if (!!setting.callback.onNodeCreated || !!setting.view.addDiyDom) {
  1129. var root = data.getRoot(setting);
  1130. while (root.createdNodes.length > 0) {
  1131. var node = root.createdNodes.shift();
  1132. tools.apply(setting.view.addDiyDom, [setting.treeId, node]);
  1133. if (!!setting.callback.onNodeCreated) {
  1134. setting.treeObj.trigger(consts.event.NODECREATED, [setting.treeId, node]);
  1135. }
  1136. }
  1137. }
  1138. },
  1139. createNodes: function (setting, level, nodes, parentNode, index) {
  1140. if (!nodes || nodes.length == 0) return;
  1141. var root = data.getRoot(setting),
  1142. openFlag = !parentNode || parentNode.open || !!$$(data.nodeChildren(setting, parentNode)[0], setting).get(0);
  1143. root.createdNodes = [];
  1144. var zTreeHtml = view.appendNodes(setting, level, nodes, parentNode, index, true, openFlag),
  1145. parentObj, nextObj;
  1146. if (!parentNode) {
  1147. parentObj = setting.treeObj;
  1148. //setting.treeObj.append(zTreeHtml.join(''));
  1149. } else {
  1150. var ulObj = $$(parentNode, consts.id.UL, setting);
  1151. if (ulObj.get(0)) {
  1152. parentObj = ulObj;
  1153. //ulObj.append(zTreeHtml.join(''));
  1154. }
  1155. }
  1156. if (parentObj) {
  1157. if (index >= 0) {
  1158. nextObj = parentObj.children()[index];
  1159. }
  1160. if (index >= 0 && nextObj) {
  1161. $(nextObj).before(zTreeHtml.join(''));
  1162. } else {
  1163. parentObj.append(zTreeHtml.join(''));
  1164. }
  1165. }
  1166. view.createNodeCallback(setting);
  1167. },
  1168. destroy: function (setting) {
  1169. if (!setting) return;
  1170. data.initCache(setting);
  1171. data.initRoot(setting);
  1172. event.unbindTree(setting);
  1173. event.unbindEvent(setting);
  1174. setting.treeObj.empty();
  1175. delete settings[setting.treeId];
  1176. },
  1177. expandCollapseNode: function (setting, node, expandFlag, animateFlag, callback) {
  1178. var root = data.getRoot(setting);
  1179. var tmpCb, _callback;
  1180. if (!node) {
  1181. tools.apply(callback, []);
  1182. return;
  1183. }
  1184. var children = data.nodeChildren(setting, node);
  1185. var isParent = data.nodeIsParent(setting, node);
  1186. if (root.expandTriggerFlag) {
  1187. _callback = callback;
  1188. tmpCb = function () {
  1189. if (_callback) _callback();
  1190. if (node.open) {
  1191. setting.treeObj.trigger(consts.event.EXPAND, [setting.treeId, node]);
  1192. } else {
  1193. setting.treeObj.trigger(consts.event.COLLAPSE, [setting.treeId, node]);
  1194. }
  1195. };
  1196. callback = tmpCb;
  1197. root.expandTriggerFlag = false;
  1198. }
  1199. if (!node.open && isParent && ((!$$(node, consts.id.UL, setting).get(0)) || (children && children.length > 0 && !$$(children[0], setting).get(0)))) {
  1200. view.appendParentULDom(setting, node);
  1201. view.createNodeCallback(setting);
  1202. }
  1203. if (node.open == expandFlag) {
  1204. tools.apply(callback, []);
  1205. return;
  1206. }
  1207. var ulObj = $$(node, consts.id.UL, setting),
  1208. switchObj = $$(node, consts.id.SWITCH, setting),
  1209. icoObj = $$(node, consts.id.ICON, setting);
  1210. if (isParent) {
  1211. node.open = !node.open;
  1212. if (node.iconOpen && node.iconClose) {
  1213. icoObj.attr("style", view.makeNodeIcoStyle(setting, node));
  1214. }
  1215. if (node.open) {
  1216. view.replaceSwitchClass(node, switchObj, consts.folder.OPEN);
  1217. view.replaceIcoClass(node, icoObj, consts.folder.OPEN);
  1218. if (animateFlag == false || setting.view.expandSpeed == "") {
  1219. ulObj.show();
  1220. tools.apply(callback, []);
  1221. } else {
  1222. if (children && children.length > 0) {
  1223. ulObj.slideDown(setting.view.expandSpeed, callback);
  1224. } else {
  1225. ulObj.show();
  1226. tools.apply(callback, []);
  1227. }
  1228. }
  1229. } else {
  1230. view.replaceSwitchClass(node, switchObj, consts.folder.CLOSE);
  1231. view.replaceIcoClass(node, icoObj, consts.folder.CLOSE);
  1232. if (animateFlag == false || setting.view.expandSpeed == "" || !(children && children.length > 0)) {
  1233. ulObj.hide();
  1234. tools.apply(callback, []);
  1235. } else {
  1236. ulObj.slideUp(setting.view.expandSpeed, callback);
  1237. }
  1238. }
  1239. } else {
  1240. tools.apply(callback, []);
  1241. }
  1242. },
  1243. expandCollapseParentNode: function (setting, node, expandFlag, animateFlag, callback) {
  1244. if (!node) return;
  1245. if (!node.parentTId) {
  1246. view.expandCollapseNode(setting, node, expandFlag, animateFlag, callback);
  1247. return;
  1248. } else {
  1249. view.expandCollapseNode(setting, node, expandFlag, animateFlag);
  1250. }
  1251. if (node.parentTId) {
  1252. view.expandCollapseParentNode(setting, node.getParentNode(), expandFlag, animateFlag, callback);
  1253. }
  1254. },
  1255. expandCollapseSonNode: function (setting, node, expandFlag, animateFlag, callback) {
  1256. var root = data.getRoot(setting),
  1257. treeNodes = (node) ? data.nodeChildren(setting, node) : data.nodeChildren(setting, root),
  1258. selfAnimateSign = (node) ? false : animateFlag,
  1259. expandTriggerFlag = data.getRoot(setting).expandTriggerFlag;
  1260. data.getRoot(setting).expandTriggerFlag = false;
  1261. if (treeNodes) {
  1262. for (var i = 0, l = treeNodes.length; i < l; i++) {
  1263. if (treeNodes[i]) view.expandCollapseSonNode(setting, treeNodes[i], expandFlag, selfAnimateSign);
  1264. }
  1265. }
  1266. data.getRoot(setting).expandTriggerFlag = expandTriggerFlag;
  1267. view.expandCollapseNode(setting, node, expandFlag, animateFlag, callback);
  1268. },
  1269. isSelectedNode: function (setting, node) {
  1270. if (!node) {
  1271. return false;
  1272. }
  1273. var list = data.getRoot(setting).curSelectedList,
  1274. i;
  1275. for (i = list.length - 1; i >= 0; i--) {
  1276. if (node === list[i]) {
  1277. return true;
  1278. }
  1279. }
  1280. return false;
  1281. },
  1282. makeDOMNodeIcon: function (html, setting, node) {
  1283. var nameStr = data.nodeName(setting, node),
  1284. name = setting.view.nameIsHTML ? nameStr : nameStr.replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;');
  1285. html.push("<span id='", node.tId, consts.id.ICON,
  1286. "' title='' treeNode", consts.id.ICON, " class='", view.makeNodeIcoClass(setting, node),
  1287. "' style='", view.makeNodeIcoStyle(setting, node), "'></span><span id='", node.tId, consts.id.SPAN,
  1288. "' class='", consts.className.NAME,
  1289. "'>", name, "</span>");
  1290. },
  1291. makeDOMNodeLine: function (html, setting, node) {
  1292. html.push("<span id='", node.tId, consts.id.SWITCH, "' title='' class='", view.makeNodeLineClass(setting, node), "' treeNode", consts.id.SWITCH, "></span>");
  1293. },
  1294. makeDOMNodeMainAfter: function (html, setting, node) {
  1295. html.push("</li>");
  1296. },
  1297. makeDOMNodeMainBefore: function (html, setting, node) {
  1298. html.push("<li id='", node.tId, "' class='", consts.className.LEVEL, node.level, "' tabindex='0' hidefocus='true' treenode>");
  1299. },
  1300. makeDOMNodeNameAfter: function (html, setting, node) {
  1301. html.push("</a>");
  1302. },
  1303. makeDOMNodeNameBefore: function (html, setting, node) {
  1304. var title = data.nodeTitle(setting, node),
  1305. url = view.makeNodeUrl(setting, node),
  1306. fontcss = view.makeNodeFontCss(setting, node),
  1307. nodeClasses = view.makeNodeClasses(setting, node),
  1308. fontStyle = [];
  1309. for (var f in fontcss) {
  1310. fontStyle.push(f, ":", fontcss[f], ";");
  1311. }
  1312. html.push("<a id='", node.tId, consts.id.A, "' class='", consts.className.LEVEL, node.level,
  1313. nodeClasses.add ? ' ' + nodeClasses.add.join(' ') : '',
  1314. "' treeNode", consts.id.A,
  1315. node.click ? " onclick=\"" + node.click + "\"" : "",
  1316. ((url != null && url.length > 0) ? " href='" + url + "'" : ""), " target='", view.makeNodeTarget(node), "' style='", fontStyle.join(''),
  1317. "'");
  1318. if (tools.apply(setting.view.showTitle, [setting.treeId, node], setting.view.showTitle) && title) {
  1319. html.push("title='", title.replace(/'/g, "&#39;").replace(/</g, '&lt;').replace(/>/g, '&gt;'), "'");
  1320. }
  1321. html.push(">");
  1322. },
  1323. makeNodeFontCss: function (setting, node) {
  1324. var fontCss = tools.apply(setting.view.fontCss, [setting.treeId, node], setting.view.fontCss);
  1325. return (fontCss && ((typeof fontCss) != "function")) ? fontCss : {};
  1326. },
  1327. makeNodeClasses: function (setting, node) {
  1328. var classes = tools.apply(setting.view.nodeClasses, [setting.treeId, node], setting.view.nodeClasses);
  1329. return (classes && (typeof classes !== "function")) ? classes : {add:[], remove:[]};
  1330. },
  1331. makeNodeIcoClass: function (setting, node) {
  1332. var icoCss = ["ico"];
  1333. if (!node.isAjaxing) {
  1334. var isParent = data.nodeIsParent(setting, node);
  1335. icoCss[0] = (node.iconSkin ? node.iconSkin + "_" : "") + icoCss[0];
  1336. if (isParent) {
  1337. icoCss.push(node.open ? consts.folder.OPEN : consts.folder.CLOSE);
  1338. } else {
  1339. icoCss.push(consts.folder.DOCU);
  1340. }
  1341. }
  1342. return consts.className.BUTTON + " " + icoCss.join('_');
  1343. },
  1344. makeNodeIcoStyle: function (setting, node) {
  1345. var icoStyle = [];
  1346. if (!node.isAjaxing) {
  1347. var isParent = data.nodeIsParent(setting, node);
  1348. var icon = (isParent && node.iconOpen && node.iconClose) ? (node.open ? node.iconOpen : node.iconClose) : node[setting.data.key.icon];
  1349. if (icon) icoStyle.push("background:url(", icon, ") 0 0 no-repeat;");
  1350. if (setting.view.showIcon == false || !tools.apply(setting.view.showIcon, [setting.treeId, node], true)) {
  1351. icoStyle.push("display:none;");
  1352. }
  1353. }
  1354. return icoStyle.join('');
  1355. },
  1356. makeNodeLineClass: function (setting, node) {
  1357. var lineClass = [];
  1358. if (setting.view.showLine) {
  1359. if (node.level == 0 && node.isFirstNode && node.isLastNode) {
  1360. lineClass.push(consts.line.ROOT);
  1361. } else if (node.level == 0 && node.isFirstNode) {
  1362. lineClass.push(consts.line.ROOTS);
  1363. } else if (node.isLastNode) {
  1364. lineClass.push(consts.line.BOTTOM);
  1365. } else {
  1366. lineClass.push(consts.line.CENTER);
  1367. }
  1368. } else {
  1369. lineClass.push(consts.line.NOLINE);
  1370. }
  1371. if (data.nodeIsParent(setting, node)) {
  1372. lineClass.push(node.open ? consts.folder.OPEN : consts.folder.CLOSE);
  1373. } else {
  1374. lineClass.push(consts.folder.DOCU);
  1375. }
  1376. return view.makeNodeLineClassEx(node) + lineClass.join('_');
  1377. },
  1378. makeNodeLineClassEx: function (node) {
  1379. return consts.className.BUTTON + " " + consts.className.LEVEL + node.level + " " + consts.className.SWITCH + " ";
  1380. },
  1381. makeNodeTarget: function (node) {
  1382. return (node.target || "_blank");
  1383. },
  1384. makeNodeUrl: function (setting, node) {
  1385. var urlKey = setting.data.key.url;
  1386. return node[urlKey] ? node[urlKey] : null;
  1387. },
  1388. makeUlHtml: function (setting, node, html, content) {
  1389. 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"), "'>");
  1390. html.push(content);
  1391. html.push("</ul>");
  1392. },
  1393. makeUlLineClass: function (setting, node) {
  1394. return ((setting.view.showLine && !node.isLastNode) ? consts.line.LINE : "");
  1395. },
  1396. removeChildNodes: function (setting, node) {
  1397. if (!node) return;
  1398. var nodes = data.nodeChildren(setting, node);
  1399. if (!nodes) return;
  1400. for (var i = 0, l = nodes.length; i < l; i++) {
  1401. data.removeNodeCache(setting, nodes[i]);
  1402. }
  1403. data.removeSelectedNode(setting);
  1404. delete node[setting.data.key.children];
  1405. if (!setting.data.keep.parent) {
  1406. data.nodeIsParent(setting, node, false);
  1407. node.open = false;
  1408. var tmp_switchObj = $$(node, consts.id.SWITCH, setting),
  1409. tmp_icoObj = $$(node, consts.id.ICON, setting);
  1410. view.replaceSwitchClass(node, tmp_switchObj, consts.folder.DOCU);
  1411. view.replaceIcoClass(node, tmp_icoObj, consts.folder.DOCU);
  1412. $$(node, consts.id.UL, setting).remove();
  1413. } else {
  1414. $$(node, consts.id.UL, setting).empty();
  1415. }
  1416. },
  1417. scrollIntoView: function (setting, dom) {
  1418. if (!dom) {
  1419. return;
  1420. }
  1421. // support IE 7 / 8
  1422. if (typeof Element === 'undefined' || typeof HTMLElement === 'undefined') {
  1423. var contRect = setting.treeObj.get(0).getBoundingClientRect(),
  1424. findMeRect = dom.getBoundingClientRect();
  1425. if (findMeRect.top < contRect.top || findMeRect.bottom > contRect.bottom
  1426. || findMeRect.right > contRect.right || findMeRect.left < contRect.left) {
  1427. dom.scrollIntoView();
  1428. }
  1429. return;
  1430. }
  1431. // CC-BY jocki84@googlemail.com, https://gist.github.com/jocki84/6ffafd003387179a988e
  1432. if (!Element.prototype.scrollIntoViewIfNeeded) {
  1433. Element.prototype.scrollIntoViewIfNeeded = function (centerIfNeeded) {
  1434. "use strict";
  1435. function makeRange(start, length) {
  1436. return {"start": start, "length": length, "end": start + length};
  1437. }
  1438. function coverRange(inner, outer) {
  1439. if (
  1440. false === centerIfNeeded ||
  1441. (outer.start < inner.end && inner.start < outer.end)
  1442. ) {
  1443. return Math.max(
  1444. inner.end - outer.length,
  1445. Math.min(outer.start, inner.start)
  1446. );
  1447. }
  1448. return (inner.start + inner.end - outer.length) / 2;
  1449. }
  1450. function makePoint(x, y) {
  1451. return {
  1452. "x": x,
  1453. "y": y,
  1454. "translate": function translate(dX, dY) {
  1455. return makePoint(x + dX, y + dY);
  1456. }
  1457. };
  1458. }
  1459. function absolute(elem, pt) {
  1460. while (elem) {
  1461. pt = pt.translate(elem.offsetLeft, elem.offsetTop);
  1462. elem = elem.offsetParent;
  1463. }
  1464. return pt;
  1465. }
  1466. var target = absolute(this, makePoint(0, 0)),
  1467. extent = makePoint(this.offsetWidth, this.offsetHeight),
  1468. elem = this.parentNode,
  1469. origin;
  1470. while (elem instanceof HTMLElement) {
  1471. // Apply desired scroll amount.
  1472. origin = absolute(elem, makePoint(elem.clientLeft, elem.clientTop));
  1473. elem.scrollLeft = coverRange(
  1474. makeRange(target.x - origin.x, extent.x),
  1475. makeRange(elem.scrollLeft, elem.clientWidth)
  1476. );
  1477. elem.scrollTop = coverRange(
  1478. makeRange(target.y - origin.y, extent.y),
  1479. makeRange(elem.scrollTop, elem.clientHeight)
  1480. );
  1481. // Determine actual scroll amount by reading back scroll properties.
  1482. target = target.translate(-elem.scrollLeft, -elem.scrollTop);
  1483. elem = elem.parentNode;
  1484. }
  1485. };
  1486. }
  1487. dom.scrollIntoViewIfNeeded();
  1488. },
  1489. setFirstNode: function (setting, parentNode) {
  1490. var children = data.nodeChildren(setting, parentNode);
  1491. if (children.length > 0) {
  1492. children[0].isFirstNode = true;
  1493. }
  1494. },
  1495. setLastNode: function (setting, parentNode) {
  1496. var children = data.nodeChildren(setting, parentNode);
  1497. if (children.length > 0) {
  1498. children[children.length - 1].isLastNode = true;
  1499. }
  1500. },
  1501. removeNode: function (setting, node) {
  1502. var root = data.getRoot(setting),
  1503. parentNode = (node.parentTId) ? node.getParentNode() : root;
  1504. node.isFirstNode = false;
  1505. node.isLastNode = false;
  1506. node.getPreNode = function () {
  1507. return null;
  1508. };
  1509. node.getNextNode = function () {
  1510. return null;
  1511. };
  1512. if (!data.getNodeCache(setting, node.tId)) {
  1513. return;
  1514. }
  1515. $$(node, setting).remove();
  1516. data.removeNodeCache(setting, node);
  1517. data.removeSelectedNode(setting, node);
  1518. var children = data.nodeChildren(setting, parentNode);
  1519. for (var i = 0, l = children.length; i < l; i++) {
  1520. if (children[i].tId == node.tId) {
  1521. children.splice(i, 1);
  1522. break;
  1523. }
  1524. }
  1525. view.setFirstNode(setting, parentNode);
  1526. view.setLastNode(setting, parentNode);
  1527. var tmp_ulObj, tmp_switchObj, tmp_icoObj,
  1528. childLength = children.length;
  1529. //repair nodes old parent
  1530. if (!setting.data.keep.parent && childLength == 0) {
  1531. //old parentNode has no child nodes
  1532. data.nodeIsParent(setting, parentNode, false);
  1533. parentNode.open = false;
  1534. delete parentNode[setting.data.key.children];
  1535. tmp_ulObj = $$(parentNode, consts.id.UL, setting);
  1536. tmp_switchObj = $$(parentNode, consts.id.SWITCH, setting);
  1537. tmp_icoObj = $$(parentNode, consts.id.ICON, setting);
  1538. view.replaceSwitchClass(parentNode, tmp_switchObj, consts.folder.DOCU);
  1539. view.replaceIcoClass(parentNode, tmp_icoObj, consts.folder.DOCU);
  1540. tmp_ulObj.css("display", "none");
  1541. } else if (setting.view.showLine && childLength > 0) {
  1542. //old parentNode has child nodes
  1543. var newLast = children[childLength - 1];
  1544. tmp_ulObj = $$(newLast, consts.id.UL, setting);
  1545. tmp_switchObj = $$(newLast, consts.id.SWITCH, setting);
  1546. tmp_icoObj = $$(newLast, consts.id.ICON, setting);
  1547. if (parentNode == root) {
  1548. if (children.length == 1) {
  1549. //node was root, and ztree has only one root after move node
  1550. view.replaceSwitchClass(newLast, tmp_switchObj, consts.line.ROOT);
  1551. } else {
  1552. var tmp_first_switchObj = $$(children[0], consts.id.SWITCH, setting);
  1553. view.replaceSwitchClass(children[0], tmp_first_switchObj, consts.line.ROOTS);
  1554. view.replaceSwitchClass(newLast, tmp_switchObj, consts.line.BOTTOM);
  1555. }
  1556. } else {
  1557. view.replaceSwitchClass(newLast, tmp_switchObj, consts.line.BOTTOM);
  1558. }
  1559. tmp_ulObj.removeClass(consts.line.LINE);
  1560. }
  1561. },
  1562. replaceIcoClass: function (node, obj, newName) {
  1563. if (!obj || node.isAjaxing) return;
  1564. var tmpName = obj.attr("class");
  1565. if (tmpName == undefined) return;
  1566. var tmpList = tmpName.split("_");
  1567. switch (newName) {
  1568. case consts.folder.OPEN:
  1569. case consts.folder.CLOSE:
  1570. case consts.folder.DOCU:
  1571. tmpList[tmpList.length - 1] = newName;
  1572. break;
  1573. }
  1574. obj.attr("class", tmpList.join("_"));
  1575. },
  1576. replaceSwitchClass: function (node, obj, newName) {
  1577. if (!obj) return;
  1578. var tmpName = obj.attr("class");
  1579. if (tmpName == undefined) return;
  1580. var tmpList = tmpName.split("_");
  1581. switch (newName) {
  1582. case consts.line.ROOT:
  1583. case consts.line.ROOTS:
  1584. case consts.line.CENTER:
  1585. case consts.line.BOTTOM:
  1586. case consts.line.NOLINE:
  1587. tmpList[0] = view.makeNodeLineClassEx(node) + newName;
  1588. break;
  1589. case consts.folder.OPEN:
  1590. case consts.folder.CLOSE:
  1591. case consts.folder.DOCU:
  1592. tmpList[1] = newName;
  1593. break;
  1594. }
  1595. obj.attr("class", tmpList.join("_"));
  1596. if (newName !== consts.folder.DOCU) {
  1597. obj.removeAttr("disabled");
  1598. } else {
  1599. obj.attr("disabled", "disabled");
  1600. }
  1601. },
  1602. selectNode: function (setting, node, addFlag) {
  1603. if (!addFlag) {
  1604. view.cancelPreSelectedNode(setting, null, node);
  1605. }
  1606. $$(node, consts.id.A, setting).addClass(consts.node.CURSELECTED);
  1607. data.addSelectedNode(setting, node);
  1608. setting.treeObj.trigger(consts.event.SELECTED, [setting.treeId, node]);
  1609. },
  1610. setNodeFontCss: function (setting, treeNode) {
  1611. var aObj = $$(treeNode, consts.id.A, setting),
  1612. fontCss = view.makeNodeFontCss(setting, treeNode);
  1613. if (fontCss) {
  1614. aObj.css(fontCss);
  1615. }
  1616. },
  1617. setNodeClasses: function (setting, treeNode) {
  1618. var aObj = $$(treeNode, consts.id.A, setting),
  1619. classes = view.makeNodeClasses(setting, treeNode);
  1620. if ('add' in classes && classes.add.length) {
  1621. aObj.addClass(classes.add.join(' '));
  1622. }
  1623. if ('remove' in classes && classes.remove.length) {
  1624. aObj.removeClass(classes.remove.join(' '));
  1625. }
  1626. },
  1627. setNodeLineIcos: function (setting, node) {
  1628. if (!node) return;
  1629. var switchObj = $$(node, consts.id.SWITCH, setting),
  1630. ulObj = $$(node, consts.id.UL, setting),
  1631. icoObj = $$(node, consts.id.ICON, setting),
  1632. ulLine = view.makeUlLineClass(setting, node);
  1633. if (ulLine.length == 0) {
  1634. ulObj.removeClass(consts.line.LINE);
  1635. } else {
  1636. ulObj.addClass(ulLine);
  1637. }
  1638. switchObj.attr("class", view.makeNodeLineClass(setting, node));
  1639. if (data.nodeIsParent(setting, node)) {
  1640. switchObj.removeAttr("disabled");
  1641. } else {
  1642. switchObj.attr("disabled", "disabled");
  1643. }
  1644. icoObj.removeAttr("style");
  1645. icoObj.attr("style", view.makeNodeIcoStyle(setting, node));
  1646. icoObj.attr("class", view.makeNodeIcoClass(setting, node));
  1647. },
  1648. setNodeName: function (setting, node) {
  1649. var title = data.nodeTitle(setting, node),
  1650. nObj = $$(node, consts.id.SPAN, setting);
  1651. nObj.empty();
  1652. if (setting.view.nameIsHTML) {
  1653. nObj.html(data.nodeName(setting, node));
  1654. } else {
  1655. nObj.text(data.nodeName(setting, node));
  1656. }
  1657. if (tools.apply(setting.view.showTitle, [setting.treeId, node], setting.view.showTitle)) {
  1658. var aObj = $$(node, consts.id.A, setting);
  1659. aObj.attr("title", !title ? "" : title);
  1660. }
  1661. },
  1662. setNodeTarget: function (setting, node) {
  1663. var aObj = $$(node, consts.id.A, setting);
  1664. aObj.attr("target", view.makeNodeTarget(node));
  1665. },
  1666. setNodeUrl: function (setting, node) {
  1667. var aObj = $$(node, consts.id.A, setting),
  1668. url = view.makeNodeUrl(setting, node);
  1669. if (url == null || url.length == 0) {
  1670. aObj.removeAttr("href");
  1671. } else {
  1672. aObj.attr("href", url);
  1673. }
  1674. },
  1675. switchNode: function (setting, node) {
  1676. if (node.open || !tools.canAsync(setting, node)) {
  1677. view.expandCollapseNode(setting, node, !node.open);
  1678. } else if (setting.async.enable) {
  1679. if (!view.asyncNode(setting, node)) {
  1680. view.expandCollapseNode(setting, node, !node.open);
  1681. return;
  1682. }
  1683. } else if (node) {
  1684. view.expandCollapseNode(setting, node, !node.open);
  1685. }
  1686. }
  1687. };
  1688. // zTree defind
  1689. $.fn.zTree = {
  1690. consts: _consts,
  1691. _z: {
  1692. tools: tools,
  1693. view: view,
  1694. event: event,
  1695. data: data
  1696. },
  1697. getZTreeObj: function (treeId) {
  1698. var o = data.getZTreeTools(treeId);
  1699. return o ? o : null;
  1700. },
  1701. destroy: function (treeId) {
  1702. if (!!treeId && treeId.length > 0) {
  1703. view.destroy(data.getSetting(treeId));
  1704. } else {
  1705. for (var s in settings) {
  1706. view.destroy(settings[s]);
  1707. }
  1708. }
  1709. },
  1710. init: function (obj, zSetting, zNodes) {
  1711. var setting = tools.clone(_setting);
  1712. $.extend(true, setting, zSetting);
  1713. setting.treeId = obj.attr("id");
  1714. setting.treeObj = obj;
  1715. setting.treeObj.empty();
  1716. settings[setting.treeId] = setting;
  1717. //For some older browser,(e.g., ie6)
  1718. if (typeof document.body.style.maxHeight === "undefined") {
  1719. setting.view.expandSpeed = "";
  1720. }
  1721. data.initRoot(setting);
  1722. var root = data.getRoot(setting);
  1723. zNodes = zNodes ? tools.clone(tools.isArray(zNodes) ? zNodes : [zNodes]) : [];
  1724. if (setting.data.simpleData.enable) {
  1725. data.nodeChildren(setting, root, data.transformTozTreeFormat(setting, zNodes));
  1726. } else {
  1727. data.nodeChildren(setting, root, zNodes);
  1728. }
  1729. data.initCache(setting);
  1730. event.unbindTree(setting);
  1731. event.bindTree(setting);
  1732. event.unbindEvent(setting);
  1733. event.bindEvent(setting);
  1734. var zTreeTools = {
  1735. setting: setting,
  1736. addNodes: function (parentNode, index, newNodes, isSilent) {
  1737. if (!parentNode) parentNode = null;
  1738. var isParent = data.nodeIsParent(setting, parentNode);
  1739. if (parentNode && !isParent && setting.data.keep.leaf) return null;
  1740. var i = parseInt(index, 10);
  1741. if (isNaN(i)) {
  1742. isSilent = !!newNodes;
  1743. newNodes = index;
  1744. index = -1;
  1745. } else {
  1746. index = i;
  1747. }
  1748. if (!newNodes) return null;
  1749. var xNewNodes = tools.clone(tools.isArray(newNodes) ? newNodes : [newNodes]);
  1750. function addCallback() {
  1751. view.addNodes(setting, parentNode, index, xNewNodes, (isSilent == true));
  1752. }
  1753. if (tools.canAsync(setting, parentNode)) {
  1754. view.asyncNode(setting, parentNode, isSilent, addCallback);
  1755. } else {
  1756. addCallback();
  1757. }
  1758. return xNewNodes;
  1759. },
  1760. cancelSelectedNode: function (node) {
  1761. view.cancelPreSelectedNode(setting, node);
  1762. },
  1763. destroy: function () {
  1764. view.destroy(setting);
  1765. },
  1766. expandAll: function (expandFlag) {
  1767. expandFlag = !!expandFlag;
  1768. view.expandCollapseSonNode(setting, null, expandFlag, true);
  1769. return expandFlag;
  1770. },
  1771. expandNode: function (node, expandFlag, sonSign, focus, callbackFlag) {
  1772. if (!node || !data.nodeIsParent(setting, node)) return null;
  1773. if (expandFlag !== true && expandFlag !== false) {
  1774. expandFlag = !node.open;
  1775. }
  1776. callbackFlag = !!callbackFlag;
  1777. if (callbackFlag && expandFlag && (tools.apply(setting.callback.beforeExpand, [setting.treeId, node], true) == false)) {
  1778. return null;
  1779. } else if (callbackFlag && !expandFlag && (tools.apply(setting.callback.beforeCollapse, [setting.treeId, node], true) == false)) {
  1780. return null;
  1781. }
  1782. if (expandFlag && node.parentTId) {
  1783. view.expandCollapseParentNode(setting, node.getParentNode(), expandFlag, false);
  1784. }
  1785. if (expandFlag === node.open && !sonSign) {
  1786. return null;
  1787. }
  1788. data.getRoot(setting).expandTriggerFlag = callbackFlag;
  1789. if (!tools.canAsync(setting, node) && sonSign) {
  1790. view.expandCollapseSonNode(setting, node, expandFlag, true, showNodeFocus);
  1791. } else {
  1792. node.open = !expandFlag;
  1793. view.switchNode(this.setting, node);
  1794. showNodeFocus();
  1795. }
  1796. return expandFlag;
  1797. function showNodeFocus() {
  1798. var a = $$(node, consts.id.A, setting).get(0);
  1799. if (a && focus !== false) {
  1800. view.scrollIntoView(setting, a);
  1801. }
  1802. }
  1803. },
  1804. getNodes: function () {
  1805. return data.getNodes(setting);
  1806. },
  1807. getNodeByParam: function (key, value, parentNode) {
  1808. if (!key) return null;
  1809. return data.getNodeByParam(setting, parentNode ? data.nodeChildren(setting, parentNode) : data.getNodes(setting), key, value);
  1810. },
  1811. getNodeByTId: function (tId) {
  1812. return data.getNodeCache(setting, tId);
  1813. },
  1814. getNodesByParam: function (key, value, parentNode) {
  1815. if (!key) return null;
  1816. return data.getNodesByParam(setting, parentNode ? data.nodeChildren(setting, parentNode) : data.getNodes(setting), key, value);
  1817. },
  1818. getNodesByParamFuzzy: function (key, value, parentNode) {
  1819. if (!key) return null;
  1820. return data.getNodesByParamFuzzy(setting, parentNode ? data.nodeChildren(setting, parentNode) : data.getNodes(setting), key, value);
  1821. },
  1822. getNodesByFilter: function (filter, isSingle, parentNode, invokeParam) {
  1823. isSingle = !!isSingle;
  1824. if (!filter || (typeof filter != "function")) return (isSingle ? null : []);
  1825. return data.getNodesByFilter(setting, parentNode ? data.nodeChildren(setting, parentNode) : data.getNodes(setting), filter, isSingle, invokeParam);
  1826. },
  1827. getNodeIndex: function (node) {
  1828. if (!node) return null;
  1829. var parentNode = (node.parentTId) ? node.getParentNode() : data.getRoot(setting);
  1830. var children = data.nodeChildren(setting, parentNode);
  1831. for (var i = 0, l = children.length; i < l; i++) {
  1832. if (children[i] == node) return i;
  1833. }
  1834. return -1;
  1835. },
  1836. getSelectedNodes: function () {
  1837. var r = [], list = data.getRoot(setting).curSelectedList;
  1838. for (var i = 0, l = list.length; i < l; i++) {
  1839. r.push(list[i]);
  1840. }
  1841. return r;
  1842. },
  1843. isSelectedNode: function (node) {
  1844. return data.isSelectedNode(setting, node);
  1845. },
  1846. reAsyncChildNodesPromise: function (parentNode, reloadType, isSilent) {
  1847. var promise = new Promise(function (resolve, reject) {
  1848. try {
  1849. zTreeTools.reAsyncChildNodes(parentNode, reloadType, isSilent, function () {
  1850. resolve(parentNode);
  1851. });
  1852. } catch (e) {
  1853. reject(e);
  1854. }
  1855. });
  1856. return promise;
  1857. },
  1858. reAsyncChildNodes: function (parentNode, reloadType, isSilent, callback) {
  1859. if (!this.setting.async.enable) return;
  1860. var isRoot = !parentNode;
  1861. if (isRoot) {
  1862. parentNode = data.getRoot(setting);
  1863. }
  1864. if (reloadType == "refresh") {
  1865. var children = data.nodeChildren(setting, parentNode);
  1866. for (var i = 0, l = children ? children.length : 0; i < l; i++) {
  1867. data.removeNodeCache(setting, children[i]);
  1868. }
  1869. data.removeSelectedNode(setting);
  1870. data.nodeChildren(setting, parentNode, []);
  1871. if (isRoot) {
  1872. this.setting.treeObj.empty();
  1873. } else {
  1874. var ulObj = $$(parentNode, consts.id.UL, setting);
  1875. ulObj.empty();
  1876. }
  1877. }
  1878. view.asyncNode(this.setting, isRoot ? null : parentNode, !!isSilent, callback);
  1879. },
  1880. refresh: function () {
  1881. this.setting.treeObj.empty();
  1882. var root = data.getRoot(setting),
  1883. nodes = data.nodeChildren(setting, root);
  1884. data.initRoot(setting);
  1885. data.nodeChildren(setting, root, nodes);
  1886. data.initCache(setting);
  1887. view.createNodes(setting, 0, data.nodeChildren(setting, root), null, -1);
  1888. },
  1889. removeChildNodes: function (node) {
  1890. if (!node) return null;
  1891. var nodes = data.nodeChildren(setting, node);
  1892. view.removeChildNodes(setting, node);
  1893. return nodes ? nodes : null;
  1894. },
  1895. removeNode: function (node, callbackFlag) {
  1896. if (!node) return;
  1897. callbackFlag = !!callbackFlag;
  1898. if (callbackFlag && tools.apply(setting.callback.beforeRemove, [setting.treeId, node], true) == false) return;
  1899. view.removeNode(setting, node);
  1900. if (callbackFlag) {
  1901. this.setting.treeObj.trigger(consts.event.REMOVE, [setting.treeId, node]);
  1902. }
  1903. },
  1904. selectNode: function (node, addFlag, isSilent) {
  1905. if (!node) return;
  1906. if (tools.uCanDo(setting)) {
  1907. addFlag = setting.view.selectedMulti && addFlag;
  1908. if (node.parentTId) {
  1909. view.expandCollapseParentNode(setting, node.getParentNode(), true, false, showNodeFocus);
  1910. } else if (!isSilent) {
  1911. try {
  1912. $$(node, setting).focus().blur();
  1913. } catch (e) {
  1914. }
  1915. }
  1916. view.selectNode(setting, node, addFlag);
  1917. }
  1918. function showNodeFocus() {
  1919. if (isSilent) {
  1920. return;
  1921. }
  1922. var a = $$(node, setting).get(0);
  1923. view.scrollIntoView(setting, a);
  1924. }
  1925. },
  1926. transformTozTreeNodes: function (simpleNodes) {
  1927. return data.transformTozTreeFormat(setting, simpleNodes);
  1928. },
  1929. transformToArray: function (nodes) {
  1930. return data.transformToArrayFormat(setting, nodes);
  1931. },
  1932. updateNode: function (node, checkTypeFlag) {
  1933. if (!node) return;
  1934. var nObj = $$(node, setting);
  1935. if (nObj.get(0) && tools.uCanDo(setting)) {
  1936. view.setNodeName(setting, node);
  1937. view.setNodeTarget(setting, node);
  1938. view.setNodeUrl(setting, node);
  1939. view.setNodeLineIcos(setting, node);
  1940. view.setNodeFontCss(setting, node);
  1941. view.setNodeClasses(setting, node);
  1942. }
  1943. }
  1944. };
  1945. root.treeTools = zTreeTools;
  1946. data.setZTreeTools(setting, zTreeTools);
  1947. var children = data.nodeChildren(setting, root);
  1948. if (children && children.length > 0) {
  1949. view.createNodes(setting, 0, children, null, -1);
  1950. } else if (setting.async.enable && setting.async.url && setting.async.url !== '') {
  1951. view.asyncNode(setting);
  1952. }
  1953. return zTreeTools;
  1954. }
  1955. };
  1956. var zt = $.fn.zTree,
  1957. $$ = tools.$,
  1958. consts = zt.consts;
  1959. })(jQuery);