2011-03-30 23:11:41 +02:00
|
|
|
--------------------------------------------------------------------------------
|
2021-12-21 06:54:15 +01:00
|
|
|
--- Create context menus, optionally with sub-menus.
|
2014-05-20 13:02:39 +02:00
|
|
|
--
|
2008-10-22 14:22:48 +02:00
|
|
|
-- @author Damien Leone <damien.leone@gmail.com>
|
2008-11-07 15:27:35 +01:00
|
|
|
-- @author Julien Danjou <julien@danjou.info>
|
2011-03-30 23:11:41 +02:00
|
|
|
-- @author dodo
|
|
|
|
-- @copyright 2008, 2011 Damien Leone, Julien Danjou, dodo
|
2019-06-08 01:08:05 +02:00
|
|
|
-- @popupmod awful.menu
|
2011-03-30 23:11:41 +02:00
|
|
|
--------------------------------------------------------------------------------
|
2008-10-22 14:22:48 +02:00
|
|
|
|
2011-03-30 23:11:41 +02:00
|
|
|
local wibox = require("wibox")
|
|
|
|
local button = require("awful.button")
|
2017-03-12 00:57:32 +01:00
|
|
|
local gstring = require("gears.string")
|
2017-03-08 21:18:33 +01:00
|
|
|
local gtable = require("gears.table")
|
2015-09-30 00:05:56 +02:00
|
|
|
local spawn = require("awful.spawn")
|
2011-03-30 23:11:41 +02:00
|
|
|
local tags = require("awful.tag")
|
2012-04-30 17:45:48 +02:00
|
|
|
local keygrabber = require("awful.keygrabber")
|
2015-11-04 12:00:41 +01:00
|
|
|
local client_iterate = require("awful.client").iterate
|
2011-03-30 23:11:41 +02:00
|
|
|
local beautiful = require("beautiful")
|
2015-07-15 18:38:57 +02:00
|
|
|
local dpi = require("beautiful").xresources.apply_dpi
|
2011-03-30 23:11:41 +02:00
|
|
|
local object = require("gears.object")
|
2012-05-27 19:20:34 +02:00
|
|
|
local surface = require("gears.surface")
|
2016-02-28 12:28:55 +01:00
|
|
|
local protected_call = require("gears.protected_call")
|
2012-05-27 19:20:34 +02:00
|
|
|
local cairo = require("lgi").cairo
|
2011-03-30 23:11:41 +02:00
|
|
|
local setmetatable = setmetatable
|
|
|
|
local tonumber = tonumber
|
|
|
|
local string = string
|
|
|
|
local ipairs = ipairs
|
2008-10-23 11:19:46 +02:00
|
|
|
local pairs = pairs
|
2011-03-30 23:11:41 +02:00
|
|
|
local print = print
|
2008-10-22 14:22:48 +02:00
|
|
|
local table = table
|
|
|
|
local type = type
|
2011-03-30 23:11:41 +02:00
|
|
|
local math = math
|
|
|
|
local capi = {
|
2009-03-04 19:42:25 +01:00
|
|
|
screen = screen,
|
|
|
|
mouse = mouse,
|
2012-05-27 19:20:34 +02:00
|
|
|
client = client }
|
2015-01-31 16:40:46 +01:00
|
|
|
local screen = require("awful.screen")
|
2011-03-30 23:11:41 +02:00
|
|
|
|
2008-10-22 14:22:48 +02:00
|
|
|
|
2012-06-12 20:13:09 +02:00
|
|
|
local menu = { mt = {} }
|
2008-10-22 14:22:48 +02:00
|
|
|
|
2011-03-30 23:11:41 +02:00
|
|
|
|
|
|
|
local table_update = function (t, set)
|
|
|
|
for k, v in pairs(set) do
|
|
|
|
t[k] = v
|
|
|
|
end
|
|
|
|
return t
|
|
|
|
end
|
|
|
|
|
2016-08-12 08:23:19 +02:00
|
|
|
--- The icon used for sub-menus.
|
|
|
|
-- @beautiful beautiful.menu_submenu_icon
|
2019-06-08 06:15:59 +02:00
|
|
|
-- @tparam string|gears.surface menu_submenu_icon
|
2016-08-12 08:23:19 +02:00
|
|
|
|
2017-08-07 20:36:41 +02:00
|
|
|
--- The menu text font.
|
|
|
|
-- @beautiful beautiful.menu_font
|
|
|
|
-- @param string
|
|
|
|
-- @see string
|
|
|
|
|
2016-08-12 08:23:19 +02:00
|
|
|
--- The item height.
|
|
|
|
-- @beautiful beautiful.menu_height
|
|
|
|
-- @tparam[opt=16] number menu_height
|
|
|
|
|
|
|
|
--- The default menu width.
|
|
|
|
-- @beautiful beautiful.menu_width
|
|
|
|
-- @tparam[opt=100] number menu_width
|
|
|
|
|
|
|
|
--- The menu item border color.
|
|
|
|
-- @beautiful beautiful.menu_border_color
|
|
|
|
-- @tparam[opt=0] number menu_border_color
|
|
|
|
|
|
|
|
--- The menu item border width.
|
|
|
|
-- @beautiful beautiful.menu_border_width
|
|
|
|
-- @tparam[opt=0] number menu_border_width
|
|
|
|
|
|
|
|
--- The default focused item foreground (text) color.
|
|
|
|
-- @beautiful beautiful.menu_fg_focus
|
|
|
|
-- @param color
|
|
|
|
-- @see gears.color
|
|
|
|
|
|
|
|
--- The default focused item background color.
|
|
|
|
-- @beautiful beautiful.menu_bg_focus
|
|
|
|
-- @param color
|
|
|
|
-- @see gears.color
|
|
|
|
|
|
|
|
--- The default foreground (text) color.
|
|
|
|
-- @beautiful beautiful.menu_fg_normal
|
|
|
|
-- @param color
|
|
|
|
-- @see gears.color
|
|
|
|
|
|
|
|
--- The default background color.
|
|
|
|
-- @beautiful beautiful.menu_bg_normal
|
|
|
|
-- @param color
|
|
|
|
-- @see gears.color
|
|
|
|
|
2021-12-21 06:54:15 +01:00
|
|
|
--- The default sub-menu indicator if no `menu_submenu_icon` is provided.
|
2016-08-12 08:23:19 +02:00
|
|
|
-- @beautiful beautiful.menu_submenu
|
|
|
|
-- @tparam[opt="▶"] string menu_submenu The sub-menu text.
|
|
|
|
-- @see beautiful.menu_submenu_icon
|
2011-03-30 23:11:41 +02:00
|
|
|
|
2009-08-21 16:34:41 +02:00
|
|
|
--- Key bindings for menu navigation.
|
2011-05-02 05:30:59 +02:00
|
|
|
-- Keys are: up, down, exec, enter, back, close. Value are table with a list of valid
|
2009-08-21 16:34:41 +02:00
|
|
|
-- keys for the action, i.e. menu_keys.up = { "j", "k" } will bind 'j' and 'k'
|
|
|
|
-- key to up action. This is common to all created menu.
|
|
|
|
-- @class table
|
|
|
|
-- @name menu_keys
|
2014-12-01 00:27:28 +01:00
|
|
|
menu.menu_keys = { up = { "Up", "k" },
|
|
|
|
down = { "Down", "j" },
|
|
|
|
back = { "Left", "h" },
|
2011-05-02 05:30:59 +02:00
|
|
|
exec = { "Return" },
|
2023-11-19 01:37:16 +01:00
|
|
|
enter = { "Right", "l", "KP_Enter" },
|
2009-08-21 16:34:41 +02:00
|
|
|
close = { "Escape" } }
|
2009-03-09 14:14:01 +01:00
|
|
|
|
2008-10-24 22:31:14 +02:00
|
|
|
|
2011-03-30 23:11:41 +02:00
|
|
|
local function load_theme(a, b)
|
|
|
|
a = a or {}
|
|
|
|
b = b or {}
|
|
|
|
local ret = {}
|
|
|
|
local fallback = beautiful.get()
|
|
|
|
if a.reset then b = fallback end
|
|
|
|
if a == "reset" then a = fallback end
|
2019-11-11 02:47:43 +01:00
|
|
|
ret.border = a.border_color or b.menu_border_color or b.border_color_normal or
|
|
|
|
fallback.menu_border_color or fallback.border_color_normal
|
2011-03-30 23:11:41 +02:00
|
|
|
ret.border_width= a.border_width or b.menu_border_width or b.border_width or
|
2017-06-08 17:12:15 +02:00
|
|
|
fallback.menu_border_width or fallback.border_width or dpi(0)
|
2011-03-30 23:11:41 +02:00
|
|
|
ret.fg_focus = a.fg_focus or b.menu_fg_focus or b.fg_focus or
|
|
|
|
fallback.menu_fg_focus or fallback.fg_focus
|
|
|
|
ret.bg_focus = a.bg_focus or b.menu_bg_focus or b.bg_focus or
|
|
|
|
fallback.menu_bg_focus or fallback.bg_focus
|
|
|
|
ret.fg_normal = a.fg_normal or b.menu_fg_normal or b.fg_normal or
|
|
|
|
fallback.menu_fg_normal or fallback.fg_normal
|
|
|
|
ret.bg_normal = a.bg_normal or b.menu_bg_normal or b.bg_normal or
|
|
|
|
fallback.menu_bg_normal or fallback.bg_normal
|
|
|
|
ret.submenu_icon= a.submenu_icon or b.menu_submenu_icon or b.submenu_icon or
|
|
|
|
fallback.menu_submenu_icon or fallback.submenu_icon
|
2011-05-17 22:29:00 +02:00
|
|
|
ret.submenu = a.submenu or b.menu_submenu or b.submenu or
|
|
|
|
fallback.menu_submenu or fallback.submenu or "▶"
|
2011-03-30 23:11:41 +02:00
|
|
|
ret.height = a.height or b.menu_height or b.height or
|
2017-06-08 17:12:15 +02:00
|
|
|
fallback.menu_height or dpi(16)
|
2011-03-30 23:11:41 +02:00
|
|
|
ret.width = a.width or b.menu_width or b.width or
|
2017-06-08 17:12:15 +02:00
|
|
|
fallback.menu_width or dpi(100)
|
2017-08-07 20:36:41 +02:00
|
|
|
ret.font = a.font or b.font or fallback.menu_font or fallback.font
|
2011-03-31 11:56:11 +02:00
|
|
|
for _, prop in ipairs({"width", "height", "menu_width"}) do
|
|
|
|
if type(ret[prop]) ~= "number" then ret[prop] = tonumber(ret[prop]) end
|
|
|
|
end
|
2011-03-30 23:11:41 +02:00
|
|
|
return ret
|
|
|
|
end
|
2008-10-22 14:22:48 +02:00
|
|
|
|
2008-10-24 22:31:14 +02:00
|
|
|
|
2022-07-03 08:10:31 +02:00
|
|
|
local function item_position(self, child)
|
2016-02-07 15:02:25 +01:00
|
|
|
local a, b = "height", "width"
|
2022-07-03 08:10:31 +02:00
|
|
|
local dir = self.layout.dir or "y"
|
2011-03-30 23:11:41 +02:00
|
|
|
if dir == "x" then a, b = b, a end
|
2008-10-22 14:22:48 +02:00
|
|
|
|
2022-07-03 08:10:31 +02:00
|
|
|
local in_dir, other = 0, self[b]
|
|
|
|
local num = gtable.hasitem(self.child, child)
|
2011-03-30 23:11:41 +02:00
|
|
|
if num then
|
|
|
|
for i = 0, num - 1 do
|
2022-07-03 08:10:31 +02:00
|
|
|
local item = self.items[i]
|
2011-03-30 23:11:41 +02:00
|
|
|
if item then
|
|
|
|
other = math.max(other, item[b])
|
|
|
|
in_dir = in_dir + item[a]
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
local w, h = other, in_dir
|
|
|
|
if dir == "x" then w, h = h, w end
|
|
|
|
return w, h
|
|
|
|
end
|
2008-10-22 14:22:48 +02:00
|
|
|
|
|
|
|
|
2022-07-03 08:10:31 +02:00
|
|
|
local function set_coords(self, s, m_coords)
|
2016-02-26 19:08:35 +01:00
|
|
|
local s_geometry = s.workarea
|
2011-03-30 23:11:41 +02:00
|
|
|
local screen_w = s_geometry.x + s_geometry.width
|
|
|
|
local screen_h = s_geometry.y + s_geometry.height
|
|
|
|
|
2022-07-03 08:10:31 +02:00
|
|
|
self.width = self.wibox.width
|
|
|
|
self.height = self.wibox.height
|
2011-03-30 23:11:41 +02:00
|
|
|
|
2022-07-03 08:10:31 +02:00
|
|
|
self.x = self.wibox.x
|
|
|
|
self.y = self.wibox.y
|
2011-03-30 23:11:41 +02:00
|
|
|
|
2022-07-03 08:10:31 +02:00
|
|
|
if self.parent then
|
|
|
|
local w, h = item_position(self.parent, self)
|
|
|
|
w = w + self.parent.theme.border_width
|
2011-03-30 23:11:41 +02:00
|
|
|
|
2022-07-03 08:10:31 +02:00
|
|
|
self.y = self.parent.y + h + self.height > screen_h and
|
|
|
|
screen_h - self.height or self.parent.y + h
|
|
|
|
self.x = self.parent.x + w + self.width > screen_w and
|
|
|
|
self.parent.x - self.width or self.parent.x + w
|
2011-03-30 23:11:41 +02:00
|
|
|
else
|
|
|
|
if m_coords == nil then
|
|
|
|
m_coords = capi.mouse.coords()
|
|
|
|
m_coords.x = m_coords.x + 1
|
|
|
|
m_coords.y = m_coords.y + 1
|
|
|
|
end
|
2022-07-03 08:10:31 +02:00
|
|
|
self.y = m_coords.y < s_geometry.y and s_geometry.y or m_coords.y
|
|
|
|
self.x = m_coords.x < s_geometry.x and s_geometry.x or m_coords.x
|
2008-10-22 14:22:48 +02:00
|
|
|
|
2022-07-03 08:10:31 +02:00
|
|
|
self.y = self.y + self.height > screen_h and
|
|
|
|
screen_h - self.height or self.y
|
|
|
|
self.x = self.x + self.width > screen_w and
|
|
|
|
screen_w - self.width or self.x
|
2009-03-04 19:42:25 +01:00
|
|
|
end
|
2011-03-30 23:11:41 +02:00
|
|
|
|
2022-07-03 08:10:31 +02:00
|
|
|
self.wibox.x = self.x
|
|
|
|
self.wibox.y = self.y
|
2009-03-04 19:42:25 +01:00
|
|
|
end
|
|
|
|
|
2009-03-09 14:14:01 +01:00
|
|
|
|
2022-07-03 08:10:31 +02:00
|
|
|
local function set_size(self)
|
2011-03-30 23:11:41 +02:00
|
|
|
local in_dir, other, a, b = 0, 0, "height", "width"
|
2022-07-03 08:10:31 +02:00
|
|
|
local dir = self.layout.dir or "y"
|
2011-03-30 23:11:41 +02:00
|
|
|
if dir == "x" then a, b = b, a end
|
2022-07-03 08:10:31 +02:00
|
|
|
for _, item in ipairs(self.items) do
|
2011-03-30 23:11:41 +02:00
|
|
|
other = math.max(other, item[b])
|
|
|
|
in_dir = in_dir + item[a]
|
2009-03-09 14:14:01 +01:00
|
|
|
end
|
2022-07-03 08:10:31 +02:00
|
|
|
self[a], self[b] = in_dir, other
|
2011-03-30 23:11:41 +02:00
|
|
|
if in_dir > 0 and other > 0 then
|
2022-07-03 08:10:31 +02:00
|
|
|
self.wibox[a] = in_dir
|
|
|
|
self.wibox[b] = other
|
2011-03-30 23:11:41 +02:00
|
|
|
return true
|
2009-03-09 14:14:01 +01:00
|
|
|
end
|
2011-03-30 23:11:41 +02:00
|
|
|
return false
|
2008-10-22 14:22:48 +02:00
|
|
|
end
|
|
|
|
|
2011-03-30 23:11:41 +02:00
|
|
|
|
2022-07-03 08:10:31 +02:00
|
|
|
local function check_access_key(self, key)
|
|
|
|
for i, item in ipairs(self.items) do
|
2011-03-30 23:11:41 +02:00
|
|
|
if item.akey == key then
|
2022-07-03 08:10:31 +02:00
|
|
|
self:item_enter(i)
|
|
|
|
self:exec(i, { exec = true })
|
2011-03-30 23:11:41 +02:00
|
|
|
return
|
|
|
|
end
|
|
|
|
end
|
2022-07-03 08:10:31 +02:00
|
|
|
if self.parent then
|
|
|
|
check_access_key(self.parent, key)
|
2011-03-30 23:11:41 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
2022-07-03 08:10:31 +02:00
|
|
|
local function grabber(self, _, key, event)
|
2012-03-01 21:43:29 +01:00
|
|
|
if event ~= "press" then return end
|
2011-03-30 23:11:41 +02:00
|
|
|
|
2022-07-03 08:10:31 +02:00
|
|
|
local sel = self.sel or 0
|
2017-03-08 21:18:33 +01:00
|
|
|
if gtable.hasitem(menu.menu_keys.up, key) then
|
2022-07-03 08:10:31 +02:00
|
|
|
local sel_new = sel-1 < 1 and #self.items or sel-1
|
|
|
|
self:item_enter(sel_new)
|
2017-03-08 21:18:33 +01:00
|
|
|
elseif gtable.hasitem(menu.menu_keys.down, key) then
|
2022-07-03 08:10:31 +02:00
|
|
|
local sel_new = sel+1 > #self.items and 1 or sel+1
|
|
|
|
self:item_enter(sel_new)
|
2017-03-08 21:18:33 +01:00
|
|
|
elseif sel > 0 and gtable.hasitem(menu.menu_keys.enter, key) then
|
2022-07-03 08:10:31 +02:00
|
|
|
self:exec(sel)
|
2017-03-08 21:18:33 +01:00
|
|
|
elseif sel > 0 and gtable.hasitem(menu.menu_keys.exec, key) then
|
2022-07-03 08:10:31 +02:00
|
|
|
self:exec(sel, { exec = true })
|
2017-03-08 21:18:33 +01:00
|
|
|
elseif gtable.hasitem(menu.menu_keys.back, key) then
|
2022-07-03 08:10:31 +02:00
|
|
|
self:hide()
|
2017-03-08 21:18:33 +01:00
|
|
|
elseif gtable.hasitem(menu.menu_keys.close, key) then
|
2022-07-03 08:10:31 +02:00
|
|
|
menu.get_root(self):hide()
|
2011-03-30 23:11:41 +02:00
|
|
|
else
|
2022-07-03 08:10:31 +02:00
|
|
|
check_access_key(self, key)
|
2011-03-30 23:11:41 +02:00
|
|
|
end
|
2008-10-22 14:22:48 +02:00
|
|
|
end
|
|
|
|
|
2011-03-30 23:11:41 +02:00
|
|
|
|
2012-11-19 14:09:10 +01:00
|
|
|
function menu:exec(num, opts)
|
2011-05-02 05:30:59 +02:00
|
|
|
opts = opts or {}
|
2012-11-19 14:09:10 +01:00
|
|
|
local item = self.items[num]
|
2011-03-30 23:11:41 +02:00
|
|
|
if not item then return end
|
|
|
|
local cmd = item.cmd
|
2009-02-23 12:04:27 +01:00
|
|
|
if type(cmd) == "table" then
|
2011-05-02 05:30:59 +02:00
|
|
|
local action = cmd.cmd
|
2009-03-30 23:45:29 +02:00
|
|
|
if #cmd == 0 then
|
2011-05-02 05:30:59 +02:00
|
|
|
if opts.exec and action and type(action) == "function" then
|
|
|
|
action()
|
|
|
|
end
|
2009-03-30 23:45:29 +02:00
|
|
|
return
|
|
|
|
end
|
2012-11-19 14:09:10 +01:00
|
|
|
if not self.child[num] then
|
|
|
|
self.child[num] = menu.new(cmd, self)
|
2008-11-10 19:09:20 +01:00
|
|
|
end
|
2011-05-02 05:30:59 +02:00
|
|
|
local can_invoke_action = opts.exec and
|
|
|
|
action and type(action) == "function" and
|
2012-11-19 14:09:10 +01:00
|
|
|
(not opts.mouse or (opts.mouse and (self.auto_expand or
|
|
|
|
(self.active_child == self.child[num] and
|
|
|
|
self.active_child.wibox.visible))))
|
2011-05-02 05:30:59 +02:00
|
|
|
if can_invoke_action then
|
2012-11-19 14:09:10 +01:00
|
|
|
local visible = action(self.child[num], item)
|
2011-05-02 05:30:59 +02:00
|
|
|
if not visible then
|
2012-11-19 14:09:10 +01:00
|
|
|
menu.get_root(self):hide()
|
2011-05-02 05:30:59 +02:00
|
|
|
return
|
|
|
|
else
|
2012-11-19 14:09:10 +01:00
|
|
|
self.child[num]:update()
|
2011-05-02 05:30:59 +02:00
|
|
|
end
|
|
|
|
end
|
2012-11-19 14:09:10 +01:00
|
|
|
if self.active_child and self.active_child ~= self.child[num] then
|
|
|
|
self.active_child:hide()
|
2008-10-30 12:46:49 +01:00
|
|
|
end
|
2012-11-19 14:09:10 +01:00
|
|
|
self.active_child = self.child[num]
|
2016-05-31 20:30:14 +02:00
|
|
|
if not self.active_child.wibox.visible then
|
2012-11-19 14:09:10 +01:00
|
|
|
self.active_child:show()
|
2011-05-02 05:30:59 +02:00
|
|
|
end
|
2009-02-23 12:04:27 +01:00
|
|
|
elseif type(cmd) == "string" then
|
2012-11-19 14:09:10 +01:00
|
|
|
menu.get_root(self):hide()
|
2015-09-30 00:05:56 +02:00
|
|
|
spawn(cmd)
|
2009-02-23 12:04:27 +01:00
|
|
|
elseif type(cmd) == "function" then
|
2012-11-19 14:09:10 +01:00
|
|
|
local visible, action = cmd(item, self)
|
2011-03-30 23:11:41 +02:00
|
|
|
if not visible then
|
2012-11-19 14:09:10 +01:00
|
|
|
menu.get_root(self):hide()
|
2011-03-30 23:11:41 +02:00
|
|
|
else
|
2012-11-19 14:09:10 +01:00
|
|
|
self:update()
|
|
|
|
if self.items[num] then
|
|
|
|
self:item_enter(num, opts)
|
2011-03-30 23:11:41 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
if action and type(action) == "function" then
|
|
|
|
action()
|
|
|
|
end
|
2008-10-22 14:22:48 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-11-19 14:09:10 +01:00
|
|
|
function menu:item_enter(num, opts)
|
2011-05-02 05:30:59 +02:00
|
|
|
opts = opts or {}
|
2012-11-19 14:09:10 +01:00
|
|
|
local item = self.items[num]
|
|
|
|
if num == nil or self.sel == num or not item then
|
2009-03-04 19:42:25 +01:00
|
|
|
return
|
2012-11-19 14:09:10 +01:00
|
|
|
elseif self.sel then
|
|
|
|
self:item_leave(self.sel)
|
2009-03-04 19:42:25 +01:00
|
|
|
end
|
2011-03-30 23:11:41 +02:00
|
|
|
--print("sel", num, menu.sel, item.theme.bg_focus)
|
|
|
|
item._background:set_fg(item.theme.fg_focus)
|
|
|
|
item._background:set_bg(item.theme.bg_focus)
|
2012-11-19 14:09:10 +01:00
|
|
|
self.sel = num
|
2009-03-04 19:42:25 +01:00
|
|
|
|
2012-11-19 14:09:10 +01:00
|
|
|
if self.auto_expand and opts.hover then
|
|
|
|
if self.active_child then
|
|
|
|
self.active_child:hide()
|
|
|
|
self.active_child = nil
|
2009-02-22 16:01:39 +01:00
|
|
|
end
|
|
|
|
|
2011-03-30 23:11:41 +02:00
|
|
|
if type(item.cmd) == "table" then
|
2012-11-19 14:09:10 +01:00
|
|
|
self:exec(num, opts)
|
2009-02-22 16:01:39 +01:00
|
|
|
end
|
|
|
|
end
|
2009-02-23 12:04:27 +01:00
|
|
|
end
|
|
|
|
|
2011-03-30 23:11:41 +02:00
|
|
|
|
2012-11-19 14:09:10 +01:00
|
|
|
function menu:item_leave(num)
|
2011-03-30 23:11:41 +02:00
|
|
|
--print("leave", num)
|
2012-11-19 14:09:10 +01:00
|
|
|
local item = self.items[num]
|
2011-03-30 23:11:41 +02:00
|
|
|
if item then
|
|
|
|
item._background:set_fg(item.theme.fg_normal)
|
|
|
|
item._background:set_bg(item.theme.bg_normal)
|
|
|
|
end
|
2009-11-26 12:47:39 +01:00
|
|
|
end
|
|
|
|
|
2011-03-30 23:11:41 +02:00
|
|
|
|
|
|
|
--- Show a menu.
|
2021-12-21 06:54:15 +01:00
|
|
|
-- @tparam[opt={}] table args The arguments
|
|
|
|
-- @tparam[opt=mouse.coords] table args.coords The menu position. A table with
|
|
|
|
-- `x` and `y` as keys and position (in pixels) as values.
|
2022-07-05 10:37:14 +02:00
|
|
|
-- @noreturn
|
2019-06-08 01:08:05 +02:00
|
|
|
-- @method show
|
2012-11-19 14:09:10 +01:00
|
|
|
function menu:show(args)
|
2011-03-30 23:11:41 +02:00
|
|
|
args = args or {}
|
|
|
|
local coords = args.coords or nil
|
2016-02-26 19:08:35 +01:00
|
|
|
local s = capi.screen[screen.focused()]
|
2011-03-30 23:11:41 +02:00
|
|
|
|
2012-11-19 14:09:10 +01:00
|
|
|
if not set_size(self) then return end
|
2016-02-26 19:08:35 +01:00
|
|
|
set_coords(self, s, coords)
|
2011-03-30 23:11:41 +02:00
|
|
|
|
2012-11-19 14:09:10 +01:00
|
|
|
keygrabber.run(self._keygrabber)
|
|
|
|
self.wibox.visible = true
|
2011-03-30 23:11:41 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
--- Hide a menu popup.
|
2019-06-08 01:08:05 +02:00
|
|
|
-- @method hide
|
2022-07-05 10:37:14 +02:00
|
|
|
-- @noreturn
|
2012-11-19 14:09:10 +01:00
|
|
|
function menu:hide()
|
2011-03-30 23:11:41 +02:00
|
|
|
-- Remove items from screen
|
2012-11-19 14:09:10 +01:00
|
|
|
for i = 1, #self.items do
|
|
|
|
self:item_leave(i)
|
2011-03-30 23:11:41 +02:00
|
|
|
end
|
2012-11-19 14:09:10 +01:00
|
|
|
if self.active_child then
|
|
|
|
self.active_child:hide()
|
|
|
|
self.active_child = nil
|
2011-03-30 23:11:41 +02:00
|
|
|
end
|
2012-11-19 14:09:10 +01:00
|
|
|
self.sel = nil
|
2011-03-30 23:11:41 +02:00
|
|
|
|
2012-11-19 14:09:10 +01:00
|
|
|
keygrabber.stop(self._keygrabber)
|
|
|
|
self.wibox.visible = false
|
2011-03-30 23:11:41 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
--- Toggle menu visibility.
|
2021-12-21 06:54:15 +01:00
|
|
|
-- @tparam table args The arguments.
|
|
|
|
-- @tparam[opt=mouse.coords] table args.coords The menu position. A table with
|
|
|
|
-- `x` and `y` as keys and position (in pixels) as values.
|
2022-07-05 10:37:14 +02:00
|
|
|
-- @noreturn
|
2019-06-08 01:08:05 +02:00
|
|
|
-- @method toggle
|
2012-11-19 14:09:10 +01:00
|
|
|
function menu:toggle(args)
|
|
|
|
if self.wibox.visible then
|
|
|
|
self:hide()
|
2009-11-26 12:47:39 +01:00
|
|
|
else
|
2012-11-19 14:09:10 +01:00
|
|
|
self:show(args)
|
2011-03-30 23:11:41 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-06-08 01:08:05 +02:00
|
|
|
--- Update menu content.
|
|
|
|
-- @method update
|
2022-07-05 10:37:14 +02:00
|
|
|
-- @noreturn
|
2012-11-19 14:09:10 +01:00
|
|
|
function menu:update()
|
|
|
|
if self.wibox.visible then
|
|
|
|
self:show({ coords = { x = self.x, y = self.y } })
|
2009-03-09 14:14:01 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2011-03-30 23:11:41 +02:00
|
|
|
|
|
|
|
--- Get the elder parent so for example when you kill
|
|
|
|
-- it, it will destroy the whole family.
|
2019-06-08 01:08:05 +02:00
|
|
|
-- @method get_root
|
2022-07-05 10:37:14 +02:00
|
|
|
-- @treturn awful.menu The root menu.
|
2012-11-19 14:09:10 +01:00
|
|
|
function menu:get_root()
|
|
|
|
return self.parent and menu.get_root(self.parent) or self
|
2011-03-30 23:11:41 +02:00
|
|
|
end
|
|
|
|
|
2012-11-19 14:09:10 +01:00
|
|
|
--- Add a new menu entry.
|
|
|
|
-- args.* params needed for the menu entry constructor.
|
2021-12-21 06:54:15 +01:00
|
|
|
-- @tparam table args The item params.
|
|
|
|
-- @tparam[opt=awful.menu.entry] function args.new The menu entry constructor.
|
|
|
|
-- @tparam[opt] table args.theme The menu entry theme.
|
|
|
|
-- @tparam[opt] number index The index where the new entry will inserted.
|
2022-07-05 10:37:14 +02:00
|
|
|
-- @treturn table|nil The new item.
|
2019-06-08 01:08:05 +02:00
|
|
|
-- @method add
|
2012-11-19 14:09:10 +01:00
|
|
|
function menu:add(args, index)
|
2011-03-30 23:11:41 +02:00
|
|
|
if not args then return end
|
2012-11-19 14:09:10 +01:00
|
|
|
local theme = load_theme(args.theme or {}, self.theme)
|
2011-03-30 23:11:41 +02:00
|
|
|
args.theme = theme
|
2012-06-12 20:13:09 +02:00
|
|
|
args.new = args.new or menu.entry
|
2016-02-28 12:28:55 +01:00
|
|
|
local item = protected_call(args.new, self, args)
|
|
|
|
if (not item) or (not item.widget) then
|
2011-03-30 23:11:41 +02:00
|
|
|
print("Error while checking menu entry: no property widget found.")
|
|
|
|
return
|
|
|
|
end
|
2012-11-19 14:09:10 +01:00
|
|
|
item.parent = self
|
2011-03-30 23:11:41 +02:00
|
|
|
item.theme = item.theme or theme
|
|
|
|
item.width = item.width or theme.width
|
|
|
|
item.height = item.height or theme.height
|
|
|
|
wibox.widget.base.check_widget(item.widget)
|
2016-05-23 05:56:45 +02:00
|
|
|
item._background = wibox.container.background()
|
2011-03-30 23:11:41 +02:00
|
|
|
item._background:set_widget(item.widget)
|
|
|
|
item._background:set_fg(item.theme.fg_normal)
|
|
|
|
item._background:set_bg(item.theme.bg_normal)
|
|
|
|
|
2008-10-22 14:22:48 +02:00
|
|
|
|
|
|
|
-- Create bindings
|
2018-12-28 09:06:03 +01:00
|
|
|
item._background.buttons = {
|
2012-11-19 14:09:10 +01:00
|
|
|
button({}, 3, function () self:hide() end),
|
2011-03-30 23:11:41 +02:00
|
|
|
button({}, 1, function ()
|
2017-03-08 21:18:33 +01:00
|
|
|
local num = gtable.hasitem(self.items, item)
|
2012-11-19 14:09:10 +01:00
|
|
|
self:item_enter(num, { mouse = true })
|
|
|
|
self:exec(num, { exec = true, mouse = true })
|
2018-12-28 09:06:03 +01:00
|
|
|
end)
|
|
|
|
}
|
2011-03-30 23:11:41 +02:00
|
|
|
|
|
|
|
|
|
|
|
item._mouse = function ()
|
2017-03-08 21:18:33 +01:00
|
|
|
local num = gtable.hasitem(self.items, item)
|
2018-08-13 10:26:10 +02:00
|
|
|
self:item_enter(num, { hover = true, mouse = true })
|
2011-03-30 23:11:41 +02:00
|
|
|
end
|
|
|
|
item.widget:connect_signal("mouse::enter", item._mouse)
|
2008-10-22 14:22:48 +02:00
|
|
|
|
2011-03-30 23:11:41 +02:00
|
|
|
if index then
|
2012-11-19 14:09:10 +01:00
|
|
|
self.layout:reset()
|
|
|
|
table.insert(self.items, index, item)
|
|
|
|
for _, i in ipairs(self.items) do
|
|
|
|
self.layout:add(i._background)
|
2011-03-30 23:11:41 +02:00
|
|
|
end
|
|
|
|
else
|
2012-11-19 14:09:10 +01:00
|
|
|
table.insert(self.items, item)
|
|
|
|
self.layout:add(item._background)
|
2011-03-30 23:11:41 +02:00
|
|
|
end
|
2015-04-18 08:57:15 +02:00
|
|
|
if self.wibox then
|
|
|
|
set_size(self)
|
|
|
|
end
|
2011-03-30 23:11:41 +02:00
|
|
|
return item
|
|
|
|
end
|
|
|
|
|
2019-06-08 01:08:05 +02:00
|
|
|
--- Delete menu entry at given position.
|
2021-12-21 06:54:15 +01:00
|
|
|
-- @tparam table|number num The index in the table of the menu entry to be deleted; can be also the menu entry itself.
|
2022-07-05 10:37:14 +02:00
|
|
|
-- @noreturn
|
2019-06-08 01:08:05 +02:00
|
|
|
-- @method delete
|
2012-11-19 14:09:10 +01:00
|
|
|
function menu:delete(num)
|
2011-03-30 23:11:41 +02:00
|
|
|
if type(num) == "table" then
|
2017-03-08 21:18:33 +01:00
|
|
|
num = gtable.hasitem(self.items, num)
|
2011-03-30 23:11:41 +02:00
|
|
|
end
|
2012-11-19 14:09:10 +01:00
|
|
|
local item = self.items[num]
|
2011-03-30 23:11:41 +02:00
|
|
|
if not item then return end
|
|
|
|
item.widget:disconnect_signal("mouse::enter", item._mouse)
|
2016-05-26 20:25:07 +02:00
|
|
|
item.widget:set_visible(false)
|
2012-11-19 14:09:10 +01:00
|
|
|
table.remove(self.items, num)
|
|
|
|
if self.sel == num then
|
|
|
|
self:item_leave(self.sel)
|
|
|
|
self.sel = nil
|
2012-06-12 20:13:09 +02:00
|
|
|
end
|
2012-11-19 14:09:10 +01:00
|
|
|
self.layout:reset()
|
|
|
|
for _, i in ipairs(self.items) do
|
|
|
|
self.layout:add(i._background)
|
2012-06-12 20:13:09 +02:00
|
|
|
end
|
2012-11-19 14:09:10 +01:00
|
|
|
if self.child[num] then
|
|
|
|
self.child[num]:hide()
|
|
|
|
if self.active_child == self.child[num] then
|
|
|
|
self.active_child = nil
|
2011-03-30 23:11:41 +02:00
|
|
|
end
|
2012-11-19 14:09:10 +01:00
|
|
|
table.remove(self.child, num)
|
2011-03-30 23:11:41 +02:00
|
|
|
end
|
2015-04-18 08:57:15 +02:00
|
|
|
if self.wibox then
|
|
|
|
set_size(self)
|
|
|
|
end
|
2011-03-30 23:11:41 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
--------------------------------------------------------------------------------
|
|
|
|
|
2015-12-12 20:10:27 +01:00
|
|
|
--- Build a popup menu with running clients and show it.
|
|
|
|
-- @tparam[opt] table args Menu table, see `new()` for more information.
|
|
|
|
-- @tparam[opt] table item_args Table that will be merged into each item, see
|
|
|
|
-- `new()` for more information.
|
|
|
|
-- @tparam[opt] func filter A function taking a client as an argument and
|
|
|
|
-- returning `true` or `false` to indicate whether the client should be
|
|
|
|
-- included in the menu.
|
2011-03-30 23:11:41 +02:00
|
|
|
-- @return The menu.
|
2019-06-08 01:08:05 +02:00
|
|
|
-- @constructorfct awful.menu.clients
|
2019-12-01 07:53:12 +01:00
|
|
|
-- @request client activate menu.clients granted When clicking on a clients menu
|
|
|
|
-- element.
|
2015-11-04 12:00:41 +01:00
|
|
|
function menu.clients(args, item_args, filter)
|
2011-03-30 23:11:41 +02:00
|
|
|
local cls_t = {}
|
2015-11-04 12:00:41 +01:00
|
|
|
for c in client_iterate(filter or function() return true end) do
|
2011-03-30 23:11:41 +02:00
|
|
|
cls_t[#cls_t + 1] = {
|
2013-12-26 15:50:10 +01:00
|
|
|
c.name or "",
|
2011-03-30 23:11:41 +02:00
|
|
|
function ()
|
2017-05-11 18:47:06 +02:00
|
|
|
if not c.valid then return end
|
2011-03-30 23:11:41 +02:00
|
|
|
if not c:isvisible() then
|
|
|
|
tags.viewmore(c:tags(), c.screen)
|
|
|
|
end
|
2015-06-19 22:24:12 +02:00
|
|
|
c:emit_signal("request::activate", "menu.clients", {raise=true})
|
2011-03-30 23:11:41 +02:00
|
|
|
end,
|
|
|
|
c.icon }
|
2014-01-11 21:23:23 +01:00
|
|
|
if item_args then
|
|
|
|
if type(item_args) == "function" then
|
2017-03-08 21:18:33 +01:00
|
|
|
gtable.merge(cls_t[#cls_t], item_args(c))
|
2014-01-11 21:23:23 +01:00
|
|
|
else
|
2017-03-08 21:18:33 +01:00
|
|
|
gtable.merge(cls_t[#cls_t], item_args)
|
2014-01-11 21:23:23 +01:00
|
|
|
end
|
|
|
|
end
|
2011-03-30 23:11:41 +02:00
|
|
|
end
|
|
|
|
args = args or {}
|
|
|
|
args.items = args.items or {}
|
2017-03-08 21:18:33 +01:00
|
|
|
gtable.merge(args.items, cls_t)
|
2011-03-30 23:11:41 +02:00
|
|
|
|
2012-06-24 03:04:47 +02:00
|
|
|
local m = menu.new(args)
|
2011-03-30 23:11:41 +02:00
|
|
|
m:show(args)
|
|
|
|
return m
|
|
|
|
end
|
|
|
|
|
2019-01-26 18:19:05 +01:00
|
|
|
local clients_menu = nil
|
|
|
|
|
|
|
|
--- Use menu.clients to build and open the client menu if it isn't already open.
|
|
|
|
-- Close the client menu if it is already open.
|
|
|
|
-- See `awful.menu.clients` for more information.
|
|
|
|
-- @tparam[opt] table args Menu table, see `new()` for more information.
|
|
|
|
-- @tparam[opt] table item_args Table that will be merged into each item, see
|
|
|
|
-- `new()` for more information.
|
|
|
|
-- @tparam[opt] func filter A function taking a client as an argument and
|
|
|
|
-- returning `true` or `false` to indicate whether the client should be
|
|
|
|
-- included in the menu.
|
|
|
|
-- @return The menu.
|
2019-06-08 01:08:05 +02:00
|
|
|
-- @constructorfct awful.menu.client_list
|
2019-01-26 18:19:05 +01:00
|
|
|
function menu.client_list(args, item_args, filter)
|
|
|
|
if clients_menu and clients_menu.wibox.visible then
|
|
|
|
clients_menu:hide()
|
|
|
|
clients_menu = nil
|
|
|
|
else
|
|
|
|
clients_menu = menu.clients(args, item_args, filter)
|
|
|
|
end
|
|
|
|
return clients_menu
|
|
|
|
end
|
|
|
|
|
2011-03-30 23:11:41 +02:00
|
|
|
--------------------------------------------------------------------------------
|
|
|
|
|
2019-06-08 01:08:05 +02:00
|
|
|
--- Default awful.menu.entry constructor.
|
2016-02-07 15:02:25 +01:00
|
|
|
-- @param parent The parent menu (TODO: This is apparently unused)
|
2021-12-21 06:54:15 +01:00
|
|
|
-- @param args The item params
|
|
|
|
-- @return table With 'widget', 'cmd', 'akey' and all the properties the user wants to change
|
2019-06-08 01:08:05 +02:00
|
|
|
-- @constructorfct awful.menu.entry
|
2016-02-07 15:02:25 +01:00
|
|
|
function menu.entry(parent, args) -- luacheck: no unused args
|
2011-03-30 23:11:41 +02:00
|
|
|
args = args or {}
|
|
|
|
args.text = args[1] or args.text or ""
|
|
|
|
args.cmd = args[2] or args.cmd
|
|
|
|
args.icon = args[3] or args.icon
|
|
|
|
local ret = {}
|
2008-12-18 18:02:54 +01:00
|
|
|
-- Create the item label widget
|
2010-10-06 14:21:19 +02:00
|
|
|
local label = wibox.widget.textbox()
|
2009-11-26 12:47:39 +01:00
|
|
|
local key = ''
|
2011-04-14 07:04:48 +02:00
|
|
|
label:set_font(args.theme.font)
|
2011-03-30 23:11:41 +02:00
|
|
|
label:set_markup(string.gsub(
|
2017-03-12 00:57:32 +01:00
|
|
|
gstring.xml_escape(args.text), "&(%w)",
|
2011-03-30 23:11:41 +02:00
|
|
|
function (l)
|
|
|
|
key = string.lower(l)
|
|
|
|
return "<u>" .. l .. "</u>"
|
|
|
|
end, 1))
|
2008-12-18 18:02:54 +01:00
|
|
|
-- Set icon if needed
|
2011-03-30 23:11:41 +02:00
|
|
|
local icon, iconbox
|
2016-05-23 05:56:45 +02:00
|
|
|
local margin = wibox.container.margin()
|
2010-10-06 14:21:19 +02:00
|
|
|
margin:set_widget(label)
|
2011-03-30 23:11:41 +02:00
|
|
|
if args.icon then
|
2012-11-25 21:18:23 +01:00
|
|
|
icon = surface.load(args.icon)
|
2011-03-30 23:11:41 +02:00
|
|
|
end
|
|
|
|
if icon then
|
|
|
|
local iw = icon:get_width()
|
|
|
|
local ih = icon:get_height()
|
|
|
|
if iw > args.theme.width or ih > args.theme.height then
|
2010-09-29 16:06:44 +02:00
|
|
|
local w, h
|
2011-03-30 23:11:41 +02:00
|
|
|
if ((args.theme.height / ih) * iw) > args.theme.width then
|
|
|
|
w, h = args.theme.height, (args.theme.height / iw) * ih
|
2008-12-18 18:02:54 +01:00
|
|
|
else
|
2011-03-30 23:11:41 +02:00
|
|
|
w, h = (args.theme.height / ih) * iw, args.theme.height
|
2008-12-18 18:02:54 +01:00
|
|
|
end
|
2010-09-29 16:06:44 +02:00
|
|
|
-- We need to scale the image to size w x h
|
2012-05-27 19:20:34 +02:00
|
|
|
local img = cairo.ImageSurface(cairo.Format.ARGB32, w, h)
|
|
|
|
local cr = cairo.Context(img)
|
2011-03-30 23:11:41 +02:00
|
|
|
cr:scale(w / iw, h / ih)
|
2012-05-27 19:20:34 +02:00
|
|
|
cr:set_source_surface(icon, 0, 0)
|
2010-09-29 16:06:44 +02:00
|
|
|
cr:paint()
|
|
|
|
icon = img
|
2008-10-23 11:19:46 +02:00
|
|
|
end
|
2010-10-06 14:21:19 +02:00
|
|
|
iconbox = wibox.widget.imagebox()
|
2011-03-30 23:11:41 +02:00
|
|
|
if iconbox:set_image(icon) then
|
2015-07-15 18:38:57 +02:00
|
|
|
margin:set_left(dpi(2))
|
2011-03-30 23:11:41 +02:00
|
|
|
else
|
2011-03-04 22:07:36 +01:00
|
|
|
iconbox = nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
if not iconbox then
|
2015-07-15 18:38:57 +02:00
|
|
|
margin:set_left(args.theme.height + dpi(2))
|
2008-10-22 14:22:48 +02:00
|
|
|
end
|
|
|
|
-- Create the submenu icon widget
|
2011-05-17 22:29:00 +02:00
|
|
|
local submenu
|
2011-03-30 23:11:41 +02:00
|
|
|
if type(args.cmd) == "table" then
|
|
|
|
if args.theme.submenu_icon then
|
2011-05-17 22:29:00 +02:00
|
|
|
submenu = wibox.widget.imagebox()
|
2016-01-15 18:43:10 +01:00
|
|
|
submenu:set_image(args.theme.submenu_icon)
|
2011-05-17 22:29:00 +02:00
|
|
|
else
|
|
|
|
submenu = wibox.widget.textbox()
|
|
|
|
submenu:set_font(args.theme.font)
|
|
|
|
submenu:set_text(args.theme.submenu)
|
2010-10-06 14:21:19 +02:00
|
|
|
end
|
2008-10-22 14:22:48 +02:00
|
|
|
end
|
|
|
|
-- Add widgets to the wibox
|
2010-10-06 14:21:19 +02:00
|
|
|
local left = wibox.layout.fixed.horizontal()
|
2009-08-25 18:13:19 +02:00
|
|
|
if iconbox then
|
2010-10-06 14:21:19 +02:00
|
|
|
left:add(iconbox)
|
|
|
|
end
|
|
|
|
-- This contains the label
|
|
|
|
left:add(margin)
|
|
|
|
|
|
|
|
local layout = wibox.layout.align.horizontal()
|
2013-01-05 16:12:50 +01:00
|
|
|
layout:set_left(left)
|
2011-05-17 22:29:00 +02:00
|
|
|
if submenu then
|
|
|
|
layout:set_right(submenu)
|
2008-10-24 22:31:14 +02:00
|
|
|
end
|
|
|
|
|
2011-03-30 23:11:41 +02:00
|
|
|
return table_update(ret, {
|
|
|
|
label = label,
|
2011-05-17 22:29:00 +02:00
|
|
|
sep = submenu,
|
2011-03-30 23:11:41 +02:00
|
|
|
icon = iconbox,
|
|
|
|
widget = layout,
|
|
|
|
cmd = args.cmd,
|
|
|
|
akey = key,
|
|
|
|
})
|
2008-11-07 15:27:35 +01:00
|
|
|
end
|
2008-10-24 09:10:42 +02:00
|
|
|
|
2011-03-30 23:11:41 +02:00
|
|
|
--------------------------------------------------------------------------------
|
2008-10-24 09:10:42 +02:00
|
|
|
|
2011-03-30 23:11:41 +02:00
|
|
|
--- Create a menu popup.
|
2015-02-20 15:41:19 +01:00
|
|
|
--
|
2021-12-21 06:54:15 +01:00
|
|
|
-- @tparam table args Table containing the menu information.
|
|
|
|
-- @tparam[opt=true] boolean args.auto_expand Controls the submenu auto expand behaviour.
|
|
|
|
-- @tparam table args.items Table containing the displayed items. Each element is a
|
|
|
|
-- table by default (when element 'new' is awful.menu.entry) containing: item
|
|
|
|
-- name, triggered action (submenu table or function), item icon (optional).
|
|
|
|
-- @tparam table args.theme
|
|
|
|
-- @tparam[opt=beautiful.menu_fg_normal] color args.theme.fg_normal
|
|
|
|
-- @tparam[opt=beautiful.menu_bg_normal] color args.theme.bg_normal
|
|
|
|
-- @tparam[opt=beautiful.menu_fg_focus] color args.theme.fg_focus
|
|
|
|
-- @tparam[opt=beautiful.menu_bg_focus] color args.theme.bg_focus
|
|
|
|
-- @tparam[opt=beautiful.menu_border_color] color args.theme.border
|
|
|
|
-- @tparam[opt=beautiful.menu_border_width] integer args.theme.border_width
|
|
|
|
-- @tparam[opt=beautiful.menu_height] integer args.theme.height
|
|
|
|
-- @tparam[opt=beautiful.menu_width] integer args.theme.width
|
|
|
|
-- @tparam[opt=beautiful.menu_font] string args.theme.font
|
|
|
|
-- @tparam[opt=beautiful.menu_submenu_icon] gears.surface|string args.theme.submenu_icon
|
|
|
|
-- @tparam[opt=beautiful.menu_submenu] string args.theme.submenu
|
2008-10-23 11:19:46 +02:00
|
|
|
-- @param parent Specify the parent menu if we want to open a submenu, this value should never be set by the user.
|
2019-06-08 01:08:05 +02:00
|
|
|
-- @constructorfct awful.menu
|
2014-08-28 19:45:46 +02:00
|
|
|
-- @usage -- The following function builds and shows a menu of clients that match
|
|
|
|
-- -- a particular rule.
|
|
|
|
-- -- Bound to a key, it can be used to select from dozens of terminals open on
|
|
|
|
-- -- several tags.
|
2019-10-07 01:24:56 +02:00
|
|
|
-- -- When using @{ruled.client.match_any} instead of @{ruled.client.match},
|
2014-08-28 19:45:46 +02:00
|
|
|
-- -- a menu of clients with different classes could be build.
|
2011-01-26 21:42:58 +01:00
|
|
|
--
|
2014-08-28 19:45:46 +02:00
|
|
|
-- function terminal_menu ()
|
|
|
|
-- terms = {}
|
|
|
|
-- for i, c in pairs(client.get()) do
|
2019-10-07 01:24:56 +02:00
|
|
|
-- if ruled.client.match(c, {class = "URxvt"}) then
|
2014-08-28 19:45:46 +02:00
|
|
|
-- terms[i] =
|
|
|
|
-- {c.name,
|
|
|
|
-- function()
|
2016-04-05 09:02:00 +02:00
|
|
|
-- c.first_tag:view_only()
|
2014-08-28 19:45:46 +02:00
|
|
|
-- client.focus = c
|
|
|
|
-- end,
|
|
|
|
-- c.icon
|
|
|
|
-- }
|
|
|
|
-- end
|
|
|
|
-- end
|
|
|
|
-- awful.menu(terms):show()
|
|
|
|
-- end
|
2012-06-12 20:13:09 +02:00
|
|
|
function menu.new(args, parent)
|
2011-03-30 23:11:41 +02:00
|
|
|
args = args or {}
|
|
|
|
args.layout = args.layout or wibox.layout.flex.vertical
|
2012-06-12 20:13:09 +02:00
|
|
|
local _menu = table_update(object(), {
|
|
|
|
item_enter = menu.item_enter,
|
|
|
|
item_leave = menu.item_leave,
|
|
|
|
get_root = menu.get_root,
|
|
|
|
delete = menu.delete,
|
|
|
|
update = menu.update,
|
|
|
|
toggle = menu.toggle,
|
|
|
|
hide = menu.hide,
|
|
|
|
show = menu.show,
|
|
|
|
exec = menu.exec,
|
|
|
|
add = menu.add,
|
2011-03-30 23:11:41 +02:00
|
|
|
child = {},
|
|
|
|
items = {},
|
|
|
|
parent = parent,
|
|
|
|
layout = args.layout(),
|
|
|
|
theme = load_theme(args.theme or {}, parent and parent.theme) })
|
|
|
|
|
2009-02-23 14:19:49 +01:00
|
|
|
if parent then
|
2012-06-12 20:13:09 +02:00
|
|
|
_menu.auto_expand = parent.auto_expand
|
2011-03-30 23:11:41 +02:00
|
|
|
elseif args.auto_expand ~= nil then
|
2012-06-12 20:13:09 +02:00
|
|
|
_menu.auto_expand = args.auto_expand
|
2009-02-23 14:12:28 +01:00
|
|
|
else
|
2012-06-12 20:13:09 +02:00
|
|
|
_menu.auto_expand = true
|
2009-02-23 14:12:28 +01:00
|
|
|
end
|
2008-10-22 14:22:48 +02:00
|
|
|
|
|
|
|
-- Create items
|
2016-02-07 15:02:25 +01:00
|
|
|
for _, v in ipairs(args) do _menu:add(v) end
|
2011-03-30 23:11:41 +02:00
|
|
|
if args.items then
|
2016-02-07 15:02:25 +01:00
|
|
|
for _, v in pairs(args.items) do _menu:add(v) end
|
2008-10-22 14:22:48 +02:00
|
|
|
end
|
|
|
|
|
2012-06-12 20:13:09 +02:00
|
|
|
_menu._keygrabber = function (...)
|
|
|
|
grabber(_menu, ...)
|
2012-04-30 17:45:48 +02:00
|
|
|
end
|
|
|
|
|
2012-06-12 20:13:09 +02:00
|
|
|
_menu.wibox = wibox({
|
2011-03-30 23:11:41 +02:00
|
|
|
ontop = true,
|
2012-06-12 20:13:09 +02:00
|
|
|
fg = _menu.theme.fg_normal,
|
|
|
|
bg = _menu.theme.bg_normal,
|
|
|
|
border_color = _menu.theme.border,
|
|
|
|
border_width = _menu.theme.border_width,
|
2011-03-30 23:11:41 +02:00
|
|
|
type = "popup_menu" })
|
2012-06-12 20:13:09 +02:00
|
|
|
_menu.wibox.visible = false
|
|
|
|
_menu.wibox:set_widget(_menu.layout)
|
|
|
|
set_size(_menu)
|
2011-03-30 23:11:41 +02:00
|
|
|
|
2012-06-12 20:13:09 +02:00
|
|
|
_menu.x = _menu.wibox.x
|
|
|
|
_menu.y = _menu.wibox.y
|
|
|
|
return _menu
|
2009-04-17 18:08:52 +02:00
|
|
|
end
|
2009-07-15 15:57:31 +02:00
|
|
|
|
2012-06-12 20:13:09 +02:00
|
|
|
function menu.mt:__call(...)
|
|
|
|
return menu.new(...)
|
|
|
|
end
|
|
|
|
|
|
|
|
return setmetatable(menu, menu.mt)
|
2009-07-15 15:57:31 +02:00
|
|
|
|
2011-09-11 16:50:01 +02:00
|
|
|
-- vim: filetype=lua:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:textwidth=80
|