TreeView.js 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. function TreeView_ToggleExpand (treeId, nodeId) {
  2. var tree = getTree (treeId);
  3. if (tree == null)
  4. return;
  5. var spanId = treeId + "_" + nodeId;
  6. var node = document.getElementById (spanId);
  7. var expand = node.style.display == "none";
  8. if (tree.populateFromClient && expand && node.populated != true && (node.innerHTML.length == 0 || node.hasError)) {
  9. tree.PopulateNode (nodeId);
  10. return;
  11. }
  12. if (!node.hasError)
  13. node.populated = true;
  14. node.style.display = expand ? "block" : "none";
  15. var inputStates = tree.form [treeId + "_ExpandStates"];
  16. TreeView_SetNodeFlag (inputStates, nodeId, expand);
  17. if (tree.showImage) {
  18. var image = document.getElementById (spanId + "_img");
  19. if (expand) image.src = tree.collapseImage;
  20. else image.src = tree.expandImage;
  21. var alt;
  22. if (expand) alt = tree.collapseAlt;
  23. else alt = tree.expandAlt;
  24. if (alt.indexOf ("{0}") != -1) {
  25. var txt = document.getElementById (spanId + "_txt").innerText;
  26. alt = alt.replace ("{0}", txt);
  27. }
  28. image.alt = alt;
  29. }
  30. }
  31. function TreeView_SetNodeFlag (flagInput, nodeId, set)
  32. {
  33. if (!set) flagInput.value = flagInput.value.replace ("|" + nodeId + "|", "|");
  34. else flagInput.value = flagInput.value + nodeId + "|";
  35. }
  36. function TreeView_PopulateCallback (data, ids)
  37. {
  38. var idArray = ids.split (" ");
  39. var tree = getTree (idArray[0]);
  40. if (tree == null)
  41. return;
  42. var spanId = idArray[0] + "_" + idArray[1];
  43. var node = document.getElementById (spanId);
  44. node.populated = true;
  45. if (data != "*") {
  46. node.innerHTML = data;
  47. TreeView_ToggleExpand (idArray[0], idArray[1]);
  48. TreeView_SetNodeFlag (tree.form [idArray[0] + "_PopulatedStates"], idArray[1], true);
  49. } else {
  50. if (tree.showImage && tree.noExpandImage != null) {
  51. var image = document.getElementById (spanId + "_img");
  52. image.src = tree.noExpandImage;
  53. }
  54. }
  55. }
  56. function getTree (treeId) { try { return eval (treeId + "_data"); } catch(e) { return null; } }
  57. function getNodeLink (node) { return node.childNodes[node.childNodes.length - 1]; }
  58. function TreeView_HoverNode (treeId, node)
  59. {
  60. var tree = getTree (treeId);
  61. if (tree == null)
  62. return;
  63. if (tree.hoverClass != null) {
  64. if (node.normalClass == null)
  65. node.normalClass = node.className;
  66. node.className = node.normalClass + " " + tree.hoverClass;
  67. }
  68. if (tree.hoverLinkClass != null) {
  69. var nodeLink = getNodeLink(node);
  70. if (nodeLink.normalClass == null)
  71. nodeLink.normalClass = nodeLink.className;
  72. nodeLink.className = nodeLink.normalClass + " " + tree.hoverLinkClass;
  73. }
  74. }
  75. function TreeView_UnhoverNode (node) {
  76. if (node != null && node.normalClass != null)
  77. node.className = node.normalClass;
  78. var nodeLink = getNodeLink(node);
  79. if (nodeLink != null && nodeLink.normalClass != null)
  80. nodeLink.className = nodeLink.normalClass;
  81. }