GUI Components JavaScript DHTML




Yahoo! UI Library - Tree Control


  



  

Tree Control











/* logger default styles */
/* font size is controlled here: default 77% */
#yui-log {position:absolute;top:1em;right:1em;font-size:77%;text-align:left;}
/* width is controlled here: default 31em */
.yui-log {background-color:#AAA;border:1px solid black;font-family:monospace;z-index:9000;}
.yui-log p {margin:1px;padding:.1em;}
.yui-log button {font-family:monospace;}
.yui-log .yui-log-hd {padding:.5em;background-color:#575757;color:#FFF;}
/* height is controlled here: default 20em*/
.yui-log .yui-log-bd {width:100%;height:20em;background-color:#FFF;border:1px solid gray;overflow:auto;}
.yui-log .yui-log-ft {margin-top:.5em;margin-bottom:1em;}
.yui-log .yui-log-ft .yui-log-categoryfilters {}
.yui-log .yui-log-ft .yui-log-sourcefilters {width:100%;border-top:1px solid #575757;margin-top:.75em;padding-top:.75em;}
.yui-log .yui-log-btns {position:relative;float:right;bottom:.25em;}
.yui-log .yui-log-filtergrp {margin-right:.5em;}
.yui-log .info {background-color:#A7CC25;} /* A7CC25 green */
.yui-log .warn {background-color:#F58516;} /* F58516 orange */
.yui-log .error {background-color:#E32F0B;} /* E32F0B red */
.yui-log .time {background-color:#A6C9D7;} /* A6C9D7 blue */
.yui-log .window {background-color:#F2E886;} /* F2E886 tan */



  
    
      


      
      


      

 


    

    


Examples



 
    
    YAHOO.example.logApp = function() {
        var divId;
        return {
            init: function(p_divId, p_toggleElId, p_clearElId) {
                divId = p_divId
            },
            onload: function() {
                if (YAHOO.widget.Logger) {
                    new YAHOO.widget.LogReader( "logDiv", { height: "400px" } );
                }
            }
        };
    } (); 
    YAHOO.util.Event.on(window, "load", YAHOO.example.logApp.onload);
    
    
    



  
    
  
    

Task List


    


    The check boxes have three states:
    unchecked, partially checked (some sub-tasks are finished), checked (all sub-tasks complete)
    


    
    Expand all
    Collapse all
    Check all
    Uncheck all
    
    
  
  
  
  
      
        
          

 


        
      
    
  



  var tree;
  var nodes = new Array();
  var nodeIndex;
  
  function treeInit() {
    buildRandomTextNodeTree();
  }
  
  function buildRandomTextNodeTree() {
    tree = new YAHOO.widget.TreeView("treeDiv1");
    for (var i = 0; i < Math.floor((Math.random()*4) + 3); i++) {
      var tmpNode = new YAHOO.widget.TaskNode("task-" + i, tree.getRoot(), false);
            tmpNode.onCheckClick = onCheckClick;
      buildRandomTextBranch(tmpNode);
    }
        
    tree.draw();
        // tree.checkClickEvent.subscribe(onCheckClick);
  }
  var callback = null;
  function buildRandomTextBranch(node) {
    if (node.depth < 5) {
      YAHOO.log("buildRandomTextBranch: " + node.index);
      for ( var i = 0; i < Math.floor(Math.random() * 4) ; i++ ) {
        var tmpNode = new YAHOO.widget.TaskNode(node.label + "-" + i, node, false);
                tmpNode.onCheckClick = onCheckClick;
        buildRandomTextBranch(tmpNode);
      }
    } else {
        // tmpNode = new YAHOO.widget.TaskNode(node.label + "-" + i, node, false, true);
        }
  }
    // function onCheckClick(eventType, args, tree) {
    //var node = args[0];
    function onCheckClick(eventType, args, tree) {
        var node = this;
        YAHOO.log(node.label + " check was clicked, new state: " + 
                node.checkState);
    }
    function showTreeState() {
        var out = [];
        for (var i in tree._nodes) {
            var n = tree._nodes[i];
            if (n && "undefined" != typeof n.checkState) {
                out.push(n.data + ": " + n.checkState);
            }
        }
        alert(out.join("\n"));
    }
    function checkAll() {
        var topNodes = tree.getRoot().children;
        for(var i = 0; i <= topNodes.length; ++i) {
            topNodes[i].check();
        }
    }
    function uncheckAll() {
        var topNodes = tree.getRoot().children;
        for(var i = 0; i <= topNodes.length; ++i) {
            topNodes[i].uncheck();
        }
    }
    function showJSON() {
        alert(JSON.stringify(tree._nodes));
    }
    //YAHOO.util.Event.on("showButton", "click", showTreeState);
    // YAHOO.util.Event.on("showButton", "click", showJSON);

  

 
           
         
  
yui.zip( 3,714 k)