(function() {
    var Event = YAHOO.util.Event,
        Dom   = YAHOO.util.Dom,
        lang  = YAHOO.lang,
        slider, 
        bg="slider-bg", thumb="slider-thumb", 
        valuearea="slider-value", textfield="slider-converted-value",
        treenav="tree_wrap_inner"
		
    // The slider can move XXX pixels up
    var topConstraint = 0;

    // The slider can move XXX pixels down
    var bottomConstraint = 437;

    // Custom scale factor for converting the pixel offset into a real value
    var scaleFactor = 1.2;

    // The amount the slider moves when the value is changed with the arrow
    // keys
    var keyIncrement = 20;

    Event.onDOMReady(function() {
    	
    	// calculate spill height to determine converstion factor
    	var spill_height = 0;
    	var wrap_height = document.getElementById(treenav).offsetHeight;
    	if (wrap_height > 450) {
    		spill_height = wrap_height - 450;
    		scaleFactor = spill_height/435;
    	}
    	
    	// show scrollbar only if there is spill
    	if (spill_height > 0) {
    		document.getElementById("slider-bg").style.display = "block";
    	} 
    	
        slider = YAHOO.widget.Slider.getVertSlider(bg, 
                         thumb, topConstraint, bottomConstraint);

        slider.getRealValue = function() {
            return Math.round(this.getValue() * scaleFactor);
        }

        slider.subscribe("change", function(offsetFromStart) {

            //var valnode = Dom.get(valuearea);
            //var fld = Dom.get(textfield);
            var tree = Dom.get(treenav);

            // Display the pixel value of the control
            //valnode.innerHTML = offsetFromStart;

            // use the scale factor to convert the pixel offset into a real
            // value
            var actualValue = slider.getRealValue();
			
			// set cookie value
			YAHOO.util.Cookie.set("slider_pos", this.getValue());
			YAHOO.util.Cookie.set("category", YAHOO.util.History.getQueryStringParameter("cid"));
			
            // update the text box with the actual value
            //fld.value = actualValue;
            
            // update scroll
            //alert(document.getElementById(treenav).offsetHeight);
            document.getElementById(treenav).style.top = '-'+actualValue+'px';
           
            // Update the title attribute on the background.  This helps assistive
            // technology to communicate the state change
            //Dom.get(bg).title = "slider value = " + actualValue;

        });

        slider.subscribe("slideStart", function() {
                YAHOO.log("slideStart fired", "warn");
            });

        slider.subscribe("slideEnd", function() {
                YAHOO.log("slideEnd fired", "warn");
            });

        // set an initial value if in same category to cookie value
        if (YAHOO.util.History.getQueryStringParameter("cid") == YAHOO.util.Cookie.get("category")) {
        	slider.setValue(parseInt(YAHOO.util.Cookie.get("slider_pos")));
        } else {
        	slider.setValue(0);
        }
       

        // Listen for keystrokes on the form field that displays the
        // control's value.  While not provided by default, having a
        // form field with the slider is a good way to help keep your
        // application accessible.
        Event.on(textfield, "keydown", function(e) {

            // set the value when the 'return' key is detected
            if (Event.getCharCode(e) === 13) {
                var v = parseFloat(this.value, 10);
                v = (lang.isNumber(v)) ? v : 0;

                // convert the real value into a pixel offset
                slider.setValue(Math.round(v/scaleFactor));
            }
        });
        
        // Use setValue to reset the value to white:
        Event.on("putval", "click", function(e) {
            slider.setValue(100, false); //false here means to animate if possible
        });
        
        // Use the "get" method to get the current offset from the slider's start
        // position in pixels.  By applying the scale factor, we can translate this
        // into a "real value
        Event.on("getval", "click", function(e) {
            YAHOO.log("Current value: "   + slider.getValue() + "\n" + 
                      "Converted value: " + slider.getRealValue(), "info", "example"); 
        });
    });// end onload/domready
})();
