X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/918dd5679f893313688dc2033fb8f46bf8463c0e..72e33046c80bddc0ca9b1336786dcb4b349137f7:/public/javascripts/menu.js?ds=inline diff --git a/public/javascripts/menu.js b/public/javascripts/menu.js index d4e8bb65a..261517756 100644 --- a/public/javascripts/menu.js +++ b/public/javascripts/menu.js @@ -1,25 +1,43 @@ /* * Open a menu. */ -function openMenu(anchor, menu) { - menu.style.display = "block"; +function openMenu(anchor, menu, align) { + var offset; + + if (align == "left") { + offset = 0; + } else if (align == "right") { + offset = anchor.getWidth() - menu.getWidth(); + } menu.clonePosition(anchor, { setLeft: true, setTop: true, setWidth: false, setHeight: false, - offsetLeft: 0, offsetTop: anchor.getHeight() + offsetLeft: offset, offsetTop: anchor.getHeight() }); + + menu.style.display = "block"; } /* - * Callback called when the mouse enters a menu anchor. + * Close a menu. */ -function enterMenuAnchor(event, anchor, menu, delay) { +function closeMenu(menu) { clearTimeout(menu.timer); + menu.style.display = "none"; +} + +/* + * Callback called when the mouse enters a menu anchor. + */ +function enterMenuAnchor(event, anchor, menu, delay, align) { + if (!anchor.hasClassName("disabled")) { + clearTimeout(menu.timer); - if (delay > 0) { - menu.timer = setTimeout(function () { openMenu(anchor, menu) }, delay); - } else { - openMenu(event, menu); + if (delay > 0) { + menu.timer = setTimeout(function () { openMenu(anchor, menu, align) }, delay); + } else { + openMenu(event, menu, align); + } } } @@ -52,11 +70,13 @@ function leaveMenu(event, anchor, menu) { /* * Setup a menu, triggered by hovering over an anchor for a given time. */ -function createMenu(anchorid, menuid, delay) { +function createMenu(anchorid, menuid, delay, align) { var anchor = $(anchorid); var menu = $(menuid); - anchor.observe("mouseover", function (event) { enterMenuAnchor(anchor, anchor, menu, delay) }); + anchor.observe("mouseup", function (event) { closeMenu(menu) }); + anchor.observe("mouseover", function (event) { enterMenuAnchor(anchor, anchor, menu, delay, align) }); anchor.observe("mouseout", function (event) { leaveMenuAnchor(event, anchor, menu) }); + menu.observe("mouseup", function (event) { closeMenu(menu) }); menu.observe("mouseout", function (event) { leaveMenu(event, anchor, menu) }); }