$.fn.droppy = function(doStick) {
  this.each(function() {
    
    var root = this, zIndex = 1000;
    
    function getSubnav(ele) {
      if (ele.nodeName.toLowerCase() == 'li') {
        var subnav = $('> ul', ele);
        return subnav.length ? subnav[0] : null;
      } else {
        return ele;
      }
    }
    
    function getActuator(ele) {
      if (ele.nodeName.toLowerCase() == 'ul') {
        return $(ele).parents('li')[0];
      } else {
        return ele;
      }
    }
    
    function hide() {
      var subnav = getSubnav(this);
      if (!subnav) return;
      if(doStick && $(this).hasClass("sticky")) return;
      $.data(subnav, 'cancelHide', false);
      setTimeout(function() {
        if (!$.data(subnav, 'cancelHide')) {
          $(subnav).slideUp(5).removeClass('showing');
        }
      }, 5);
    }
  
    function show() {
      var subnav = getSubnav(this);
      if (doStick && !subnav) {
        $('.showing').slideUp(5).removeClass('showing');
        return;
      }
      if(doStick && $(subnav).hasClass('showing')) return;
      if(doStick){
            $('.showing').slideUp(5).removeClass('showing');
           }
      $.data(subnav, 'cancelHide', true);
      $(subnav).css({zIndex: zIndex++}).slideDown(5).addClass('showing');
      if (this.nodeName.toLowerCase() == 'ul') {
        $(getActuator(this)).addClass('hover');
      }
    }
    
    $('li.toprow', this).hover(show, hide);
   if(doStick){ 
        $('li.toprow.sticky > a', this).click(function () {
                 var subnav = getSubnav($(this).parent().get(0));
                 $(subnav).slideUp(5).removeClass('showing');
         });
    } 
    $('li', this).hover(
      function() { $(this).addClass('hover'); },
      function() { $(this).removeClass('hover'); }
    );
    
  });
  
};

