Add support for passing in a template for the app widget

This commit is contained in:
Ksaper 2023-02-05 02:17:46 +02:00
parent c6a245365b
commit 6f1198e75d
1 changed files with 135 additions and 114 deletions

View File

@ -94,7 +94,7 @@ local function select_app(self, x, y)
if widgets then
self._private.active_widget = widgets[1]
if self._private.active_widget ~= nil then
self._private.active_widget.selected = true
if self.app_template == nil then
self._private.active_widget:get_children_by_id("background_role")[1].bg = self.app_selected_color
local name_widget = self._private.active_widget:get_children_by_id("name_role")[1]
if name_widget then
@ -105,12 +105,15 @@ local function select_app(self, x, y)
generic_name_widget.markup = string.format("<i><span weight='300'foreground='%s'>%s</span></i>", self.app_name_selected_color, generic_name_widget.text)
end
end
self._private.active_widget:emit_signal("selected")
self._private.active_widget.selected = true
end
end
end
local function unselect_app(self)
if self._private.active_widget ~= nil then
self._private.active_widget.selected = false
if self.app_template == nil then
self._private.active_widget:get_children_by_id("background_role")[1].bg = self.app_normal_color
local name_widget = self._private.active_widget:get_children_by_id("name_role")[1]
if name_widget then
@ -120,11 +123,17 @@ local function unselect_app(self)
if generic_name_widget then
generic_name_widget.markup = string.format("<i><span weight='300'foreground='%s'>%s</span></i>", self.app_name_normal_color, generic_name_widget.text)
end
end
self._private.active_widget:emit_signal("unselected")
self._private.active_widget.selected = false
self._private.active_widget = nil
end
end
local function create_app_widget(self, entry)
local function create_app_widget(self, app)
local app_widget = nil
if self.app_template == nil then
local icon = self.app_show_icon == true and
{
widget = wibox.widget.imagebox,
@ -132,7 +141,7 @@ local function create_app_widget(self, entry)
halign = self.app_icon_halign,
forced_width = self.app_icon_width,
forced_height = self.app_icon_height,
image = entry.icon
image = app.icon
} or nil
local name = self.app_show_name == true and
@ -140,18 +149,18 @@ local function create_app_widget(self, entry)
widget = wibox.widget.textbox,
id = "name_role",
font = self.app_name_font,
markup = string.format("<span foreground='%s'>%s</span>", self.app_name_normal_color, entry.name)
markup = string.format("<span foreground='%s'>%s</span>", self.app_name_normal_color, app.name)
} or nil
local generic_name = entry.generic_name ~= nil and self.app_show_generic_name == true and
local generic_name = app.generic_name ~= nil and self.app_show_generic_name == true and
{
widget = wibox.widget.textbox,
id = "generic_name_role",
font = self.app_name_font,
markup = entry.generic_name ~= "" and "<span weight='300'> <i>(" .. entry.generic_name .. ")</i></span>" or ""
markup = app.generic_name ~= "" and "<span weight='300'> <i>(" .. app.generic_name .. ")</i></span>" or ""
} or nil
local app = wibox.widget
app_widget = wibox.widget
{
widget = wibox.container.background,
id = "background_role",
@ -187,53 +196,53 @@ local function create_app_widget(self, entry)
}
}
function app:spawn()
if entry.terminal == true then
awful.spawn.with_shell(AWESOME_SENSIBLE_TERMINAL_PATH .. " -e " .. entry.executable)
else
awful.spawn(entry.executable)
end
if self.hide_on_launch then
self:hide()
end
end
app:connect_signal("mouse::enter", function(_self)
app_widget:connect_signal("mouse::enter", function()
local widget = capi.mouse.current_wibox
if widget then
widget.cursor = "hand2"
end
local app = _self
if app.selected then
app:get_children_by_id("background_role")[1].bg = self.app_selected_hover_color
if app_widget.selected then
app_widget:get_children_by_id("background_role")[1].bg = self.app_selected_hover_color
else
local is_opaque = color.is_opaque(self.app_normal_color)
local is_dark = color.is_dark(self.app_normal_color)
local app_normal_color = color.hex_to_rgba(self.app_normal_color)
local hover_color = (is_dark or is_opaque) and
color.rgba_to_hex(color.multiply(app_normal_color, 2.5)) or
color.rgba_to_hex(color.multiply(app_normal_color, 0.5))
app:get_children_by_id("background_role")[1].bg = self.app_normal_hover_color
app_widget:get_children_by_id("background_role")[1].bg = self.app_normal_hover_color
end
end)
app:connect_signal("mouse::leave", function(_self)
app_widget:connect_signal("mouse::leave", function()
local widget = capi.mouse.current_wibox
if widget then
widget.cursor = "left_ptr"
end
local app = _self
if app.selected then
app:get_children_by_id("background_role")[1].bg = self.app_selected_color
if app_widget.selected then
app_widget:get_children_by_id("background_role")[1].bg = self.app_selected_color
else
app:get_children_by_id("background_role")[1].bg = self.app_normal_color
app_widget:get_children_by_id("background_role")[1].bg = self.app_normal_color
end
end)
else
app_widget = self.app_template(app)
app:connect_signal("button::press", function(app, _, __, button)
local icon = app_widget:get_children_by_id("icon_role")[1]
if icon then
icon.image = app.icon
end
local name = app_widget:get_children_by_id("name_role")[1]
if name then
name.text = app.name
end
local generic_name = app_widget:get_children_by_id("generic_name_role")[1]
if generic_name then
generic_name.text = app.generic_name
end
local command = app_widget:get_children_by_id("command_role")[1]
if command then
command.text = app.executable
end
end
app_widget:connect_signal("button::press", function(app, _, __, button)
if button == 1 then
if self._private.active_widget == app or not self.select_before_spawn then
app:spawn()
@ -248,7 +257,19 @@ local function create_app_widget(self, entry)
end
end)
return app
function app_widget:spawn()
if app.terminal == true then
awful.spawn.with_shell(AWESOME_SENSIBLE_TERMINAL_PATH .. " -e " .. app.executable)
else
awful.spawn(app.executable)
end
if self.hide_on_launch then
self:hide()
end
end
return app_widget
end
local function search(self, text)