awful.menu: add keyboard navigation feature
This commit is contained in:
parent
031ebc6d98
commit
effb03a976
|
@ -17,7 +17,8 @@ local capi =
|
||||||
{
|
{
|
||||||
screen = screen,
|
screen = screen,
|
||||||
mouse = mouse,
|
mouse = mouse,
|
||||||
client = client
|
client = client,
|
||||||
|
keygrabber = keygrabber
|
||||||
}
|
}
|
||||||
local util = require("awful.util")
|
local util = require("awful.util")
|
||||||
local tags = require("awful.tag")
|
local tags = require("awful.tag")
|
||||||
|
@ -27,6 +28,8 @@ local tonumber = tonumber
|
||||||
--- Menu module for awful
|
--- Menu module for awful
|
||||||
module("awful.menu")
|
module("awful.menu")
|
||||||
|
|
||||||
|
local cur_menu
|
||||||
|
|
||||||
local function load_theme(custom)
|
local function load_theme(custom)
|
||||||
local theme = {}
|
local theme = {}
|
||||||
local beautiful
|
local beautiful
|
||||||
|
@ -72,6 +75,13 @@ function hide(menu)
|
||||||
menu.active_child = nil
|
menu.active_child = nil
|
||||||
end
|
end
|
||||||
menu.sel = nil
|
menu.sel = nil
|
||||||
|
|
||||||
|
if cur_menu == menu then
|
||||||
|
cur_menu = cur_menu.parent
|
||||||
|
end
|
||||||
|
if not cur_menu and menu.keygrabber then
|
||||||
|
capi.keygrabber.stop()
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Get the elder parent so for example when you kill
|
-- Get the elder parent so for example when you kill
|
||||||
|
@ -115,6 +125,7 @@ local function item_enter(menu, num, mouse_event)
|
||||||
menu.items[num].wibox.fg = menu.theme.fg_focus
|
menu.items[num].wibox.fg = menu.theme.fg_focus
|
||||||
menu.items[num].wibox.bg = menu.theme.bg_focus
|
menu.items[num].wibox.bg = menu.theme.bg_focus
|
||||||
menu.sel = num
|
menu.sel = num
|
||||||
|
cur_menu = menu
|
||||||
|
|
||||||
if menu.auto_expand and mouse_event then
|
if menu.auto_expand and mouse_event then
|
||||||
if menu.active_child then
|
if menu.active_child then
|
||||||
|
@ -128,6 +139,29 @@ local function item_enter(menu, num, mouse_event)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local function grabber(mod, key, event)
|
||||||
|
if event == "release" then
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
|
||||||
|
local sel = cur_menu.sel or 0
|
||||||
|
if key == "Up" then
|
||||||
|
local sel_new = sel-1 < 1 and #cur_menu.items or sel-1
|
||||||
|
item_enter(cur_menu, sel_new)
|
||||||
|
elseif key == "Down" then
|
||||||
|
local sel_new = sel+1 > #cur_menu.items and 1 or sel+1
|
||||||
|
item_enter(cur_menu, sel_new)
|
||||||
|
elseif sel > 0 and (key == "Return" or key == "Right") then
|
||||||
|
exec(cur_menu, sel)
|
||||||
|
elseif key == "Left" then
|
||||||
|
cur_menu:hide()
|
||||||
|
elseif key == "Escape" then
|
||||||
|
get_parents(cur_menu):hide()
|
||||||
|
end
|
||||||
|
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
|
||||||
local function add_item(data, num, item_info)
|
local function add_item(data, num, item_info)
|
||||||
local item = wibox({
|
local item = wibox({
|
||||||
position = "floating",
|
position = "floating",
|
||||||
|
@ -234,8 +268,8 @@ local function set_coords(menu, screen_idx)
|
||||||
local m_coords = capi.mouse.coords()
|
local m_coords = capi.mouse.coords()
|
||||||
local m_w = menu.w
|
local m_w = menu.w
|
||||||
|
|
||||||
menu.y = m_coords.y < s_geometry.y and s_geometry.y or m_coords.y
|
menu.y = m_coords.y+1 < s_geometry.y and s_geometry.y or m_coords.y+1
|
||||||
menu.x = m_coords.x < s_geometry.x and s_geometry.x or m_coords.x
|
menu.x = m_coords.x+1 < s_geometry.x and s_geometry.x or m_coords.x+1
|
||||||
|
|
||||||
menu.y = menu.y + m_h > screen_h and screen_h - m_h or menu.y
|
menu.y = menu.y + m_h > screen_h and screen_h - m_h or menu.y
|
||||||
menu.x = menu.x + m_w > screen_w and screen_w - m_w or menu.x
|
menu.x = menu.x + m_w > screen_w and screen_w - m_w or menu.x
|
||||||
|
@ -244,7 +278,8 @@ end
|
||||||
|
|
||||||
--- Show a menu.
|
--- Show a menu.
|
||||||
-- @param menu The menu to show.
|
-- @param menu The menu to show.
|
||||||
function show(menu)
|
-- @param keygrabber A boolean enabling or not the keyboard navigation.
|
||||||
|
function show(menu, keygrabber)
|
||||||
local screen_index = capi.mouse.screen
|
local screen_index = capi.mouse.screen
|
||||||
set_coords(menu, screen_index)
|
set_coords(menu, screen_index)
|
||||||
for num, item in pairs(menu.items) do
|
for num, item in pairs(menu.items) do
|
||||||
|
@ -257,15 +292,29 @@ function show(menu)
|
||||||
})
|
})
|
||||||
wibox.screen = screen_index
|
wibox.screen = screen_index
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if menu.parent then
|
||||||
|
menu.keygrabber = menu.parent.keygrab
|
||||||
|
elseif keygrabber ~= nil then
|
||||||
|
menu.keygrabber = keygrabber
|
||||||
|
else
|
||||||
|
menu.keygrabber = false
|
||||||
|
end
|
||||||
|
|
||||||
|
if not cur_menu and menu.keygrabber then
|
||||||
|
capi.keygrabber.run(grabber)
|
||||||
|
end
|
||||||
|
cur_menu = menu
|
||||||
end
|
end
|
||||||
|
|
||||||
--- Toggle menu visibility.
|
--- Toggle menu visibility.
|
||||||
-- @param menu The menu to show if it's hidden, or to hide if it's shown.
|
-- @param menu The menu to show if it's hidden, or to hide if it's shown.
|
||||||
function toggle(menu)
|
-- @param keygrabber A boolean enabling or not the keyboard navigation.
|
||||||
|
function toggle(menu, keygrabber)
|
||||||
if menu.items[1] and menu.items[1].wibox.screen then
|
if menu.items[1] and menu.items[1].wibox.screen then
|
||||||
hide(menu)
|
hide(menu)
|
||||||
else
|
else
|
||||||
show(menu)
|
show(menu, keygrabber)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue