diff options
author | Frederic Guillot <fred@kanboard.net> | 2015-09-09 22:00:54 -0400 |
---|---|---|
committer | Frederic Guillot <fred@kanboard.net> | 2015-09-09 22:00:54 -0400 |
commit | 726efc93ee7a645966748ff6db88e91f614f311c (patch) | |
tree | ce421f3b3343e4536e98229fcfa3c6193b8252f3 /assets/js/src/Dropdown.js | |
parent | f3a5474e3453064095ad6f83ba15d4737a944cda (diff) |
Avoid dropdown menu to be truncated inside a column with scrolling
Diffstat (limited to 'assets/js/src/Dropdown.js')
-rw-r--r-- | assets/js/src/Dropdown.js | 25 |
1 files changed, 15 insertions, 10 deletions
diff --git a/assets/js/src/Dropdown.js b/assets/js/src/Dropdown.js index 6b40d1fc..e04603d8 100644 --- a/assets/js/src/Dropdown.js +++ b/assets/js/src/Dropdown.js @@ -11,26 +11,31 @@ Dropdown.prototype.listen = function() { $(document).on('click', '.dropdown-menu', function(e) { e.preventDefault(); e.stopImmediatePropagation(); + self.close(); var submenu = $(this).next('ul'); var submenuHeight = 240; + var offset = $(this).offset(); + var height = $(this).height(); + + // Clone the submenu outside of the column to avoid clipping issue with overflow + $("body").append(jQuery("<div>", {"id": "dropdown"})); + submenu.clone().appendTo("#dropdown"); - if (! submenu.is(':visible')) { - self.close(); + var clone = $("#dropdown ul"); + clone.css('left', offset.left); - if ($(this).offset().top + submenuHeight - $(window).scrollTop() > $(window).height()) { - submenu.addClass('dropdown-submenu-open dropdown-submenu-top'); - } - else { - submenu.addClass('dropdown-submenu-open'); - } + if (offset.top + submenuHeight - $(window).scrollTop() > $(window).height()) { + clone.css('top', offset.top - submenuHeight - height); } else { - self.close(); + clone.css('top', offset.top + height); } + + clone.addClass('dropdown-submenu-open'); }); }; Dropdown.prototype.close = function() { - $('.dropdown-submenu-open').removeClass('dropdown-submenu-open'); + $("#dropdown").remove(); }; |