Refactor the icon theme helper
This commit is contained in:
parent
1e694218df
commit
3cfff61ca6
|
@ -1,85 +1,42 @@
|
||||||
|
-------------------------------------------
|
||||||
|
-- @author https://github.com/Kasper24
|
||||||
|
-- @copyright 2021-2022 Kasper24
|
||||||
|
-------------------------------------------
|
||||||
local lgi = require("lgi")
|
local lgi = require("lgi")
|
||||||
local Gio = lgi.Gio
|
local Gio = lgi.Gio
|
||||||
|
local DesktopAppInfo = Gio.DesktopAppInfo
|
||||||
local Gtk = lgi.require("Gtk", "3.0")
|
local Gtk = lgi.require("Gtk", "3.0")
|
||||||
local gobject = require("gears.object")
|
|
||||||
local gtable = require("gears.table")
|
|
||||||
local setmetatable = setmetatable
|
|
||||||
local ipairs = ipairs
|
|
||||||
|
|
||||||
local icon_theme = { mt = {} }
|
local ICON_SIZE = 48
|
||||||
|
local GTK_THEME = Gtk.IconTheme.get_default()
|
||||||
|
|
||||||
local name_lookup =
|
local _icon_theme = {}
|
||||||
{
|
|
||||||
["jetbrains-studio"] = "android-studio"
|
|
||||||
}
|
|
||||||
|
|
||||||
local function get_icon_by_pid_command(self, client, apps)
|
function _icon_theme.get_client_icon_path(client, icon_theme, icon_size)
|
||||||
local pid = client.pid
|
local desktop_app_info_filename = DesktopAppInfo.search(client.class)[1][1]
|
||||||
if pid ~= nil then
|
if desktop_app_info_filename then
|
||||||
local handle = io.popen(string.format("ps -p %d -o comm=", pid))
|
local desktop_app_info = DesktopAppInfo.new(desktop_app_info_filename)
|
||||||
local pid_command = handle:read("*a"):gsub("^%s*(.-)%s*$", "%1")
|
if desktop_app_info then
|
||||||
handle:close()
|
local icon_name = desktop_app_info:get_string("Icon")
|
||||||
|
if icon_name then
|
||||||
for _, app in ipairs(apps) do
|
return _icon_theme.get_icon_path(icon_name, icon_theme, icon_size)
|
||||||
local executable = app:get_executable()
|
|
||||||
if executable and executable:find(pid_command, 1, true) then
|
|
||||||
return self:get_gicon_path(app:get_icon())
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
_icon_theme.choose_icon({"window", "window-manager", "xfwm4-default", "window_list"}, icon_theme, icon_size)
|
||||||
end
|
end
|
||||||
|
|
||||||
local function get_icon_by_icon_name(self, client, apps)
|
function _icon_theme.choose_icon(icons_names, icon_theme, icon_size)
|
||||||
local icon_name = client.icon_name and client.icon_name:lower() or nil
|
if icon_theme then
|
||||||
if icon_name ~= nil then
|
GTK_THEME = Gtk.IconTheme.new()
|
||||||
for _, app in ipairs(apps) do
|
Gtk.IconTheme.set_custom_theme(GTK_THEME, icon_theme);
|
||||||
local name = app:get_name():lower()
|
|
||||||
if name and name:find(icon_name, 1, true) then
|
|
||||||
return self:get_gicon_path(app:get_icon())
|
|
||||||
end
|
end
|
||||||
|
if icon_size then
|
||||||
|
ICON_SIZE = icon_size
|
||||||
end
|
end
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
local function get_icon_by_class(self, client, apps)
|
local icon_info = GTK_THEME:choose_icon(icons_names, ICON_SIZE, 0);
|
||||||
if client.class ~= nil then
|
|
||||||
local class = name_lookup[client.class] or client.class:lower()
|
|
||||||
|
|
||||||
-- Try to remove dashes
|
|
||||||
local class_1 = class:gsub("[%-]", "")
|
|
||||||
|
|
||||||
-- Try to replace dashes with dot
|
|
||||||
local class_2 = class:gsub("[%-]", ".")
|
|
||||||
|
|
||||||
-- Try to match only the first word
|
|
||||||
local class_3 = class:match("(.-)-") or class
|
|
||||||
class_3 = class_3:match("(.-)%.") or class_3
|
|
||||||
class_3 = class_3:match("(.-)%s+") or class_3
|
|
||||||
|
|
||||||
local possible_icon_names = { class, class_3, class_2, class_1 }
|
|
||||||
for _, app in ipairs(apps) do
|
|
||||||
local id = app:get_id():lower()
|
|
||||||
for _, possible_icon_name in ipairs(possible_icon_names) do
|
|
||||||
if id and id:find(possible_icon_name, 1, true) then
|
|
||||||
return self:get_gicon_path(app:get_icon())
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
function icon_theme:get_client_icon_path(client)
|
|
||||||
local apps = Gio.AppInfo.get_all()
|
|
||||||
|
|
||||||
return get_icon_by_pid_command(self, client, apps) or
|
|
||||||
get_icon_by_icon_name(self, client, apps) or
|
|
||||||
get_icon_by_class(self, client, apps) or
|
|
||||||
client.icon or
|
|
||||||
self:choose_icon({"window", "window-manager", "xfwm4-default", "window_list" })
|
|
||||||
end
|
|
||||||
|
|
||||||
function icon_theme:choose_icon(icons_names)
|
|
||||||
local icon_info = self.gtk_theme:choose_icon(icons_names, self.icon_size, 0);
|
|
||||||
if icon_info then
|
if icon_info then
|
||||||
local icon_path = icon_info:get_filename()
|
local icon_path = icon_info:get_filename()
|
||||||
if icon_path then
|
if icon_path then
|
||||||
|
@ -90,12 +47,20 @@ function icon_theme:choose_icon(icons_names)
|
||||||
return ""
|
return ""
|
||||||
end
|
end
|
||||||
|
|
||||||
function icon_theme:get_gicon_path(gicon)
|
function _icon_theme.get_gicon_path(gicon, icon_theme, icon_size)
|
||||||
if gicon == nil then
|
if gicon == nil then
|
||||||
return ""
|
return ""
|
||||||
end
|
end
|
||||||
|
|
||||||
local icon_info = self.gtk_theme:lookup_by_gicon(gicon, self.icon_size, 0);
|
if icon_theme then
|
||||||
|
GTK_THEME = Gtk.IconTheme.new()
|
||||||
|
Gtk.IconTheme.set_custom_theme(GTK_THEME, icon_theme);
|
||||||
|
end
|
||||||
|
if icon_size then
|
||||||
|
ICON_SIZE = icon_size
|
||||||
|
end
|
||||||
|
|
||||||
|
local icon_info = GTK_THEME:lookup_by_gicon(gicon, ICON_SIZE, 0);
|
||||||
if icon_info then
|
if icon_info then
|
||||||
local icon_path = icon_info:get_filename()
|
local icon_path = icon_info:get_filename()
|
||||||
if icon_path then
|
if icon_path then
|
||||||
|
@ -106,8 +71,16 @@ function icon_theme:get_gicon_path(gicon)
|
||||||
return ""
|
return ""
|
||||||
end
|
end
|
||||||
|
|
||||||
function icon_theme:get_icon_path(icon_name)
|
function _icon_theme.get_icon_path(icon_name, icon_theme, icon_size)
|
||||||
local icon_info = self.gtk_theme:lookup_icon(icon_name, self.icon_size, 0)
|
if icon_theme then
|
||||||
|
GTK_THEME = Gtk.IconTheme.new()
|
||||||
|
Gtk.IconTheme.set_custom_theme(GTK_THEME, icon_theme);
|
||||||
|
end
|
||||||
|
if icon_size then
|
||||||
|
ICON_SIZE = icon_size
|
||||||
|
end
|
||||||
|
|
||||||
|
local icon_info = GTK_THEME:lookup_icon(icon_name, ICON_SIZE, 0)
|
||||||
if icon_info then
|
if icon_info then
|
||||||
local icon_path = icon_info:get_filename()
|
local icon_path = icon_info:get_filename()
|
||||||
if icon_path then
|
if icon_path then
|
||||||
|
@ -118,25 +91,4 @@ function icon_theme:get_icon_path(icon_name)
|
||||||
return ""
|
return ""
|
||||||
end
|
end
|
||||||
|
|
||||||
local function new(theme_name, icon_size)
|
return _icon_theme
|
||||||
local ret = gobject{}
|
|
||||||
gtable.crush(ret, icon_theme, true)
|
|
||||||
|
|
||||||
ret.name = theme_name or nil
|
|
||||||
ret.icon_size = icon_size or 48
|
|
||||||
|
|
||||||
if theme_name then
|
|
||||||
ret.gtk_theme = Gtk.IconTheme.new()
|
|
||||||
Gtk.IconTheme.set_custom_theme(ret.gtk_theme, theme_name);
|
|
||||||
else
|
|
||||||
ret.gtk_theme = Gtk.IconTheme.get_default()
|
|
||||||
end
|
|
||||||
|
|
||||||
return ret
|
|
||||||
end
|
|
||||||
|
|
||||||
function icon_theme.mt:__call(...)
|
|
||||||
return new(...)
|
|
||||||
end
|
|
||||||
|
|
||||||
return setmetatable(icon_theme, icon_theme.mt)
|
|
|
@ -2,6 +2,7 @@ return {
|
||||||
client = require(... .. ".client"),
|
client = require(... .. ".client"),
|
||||||
color = require(... .. ".color"),
|
color = require(... .. ".color"),
|
||||||
filesystem = require(... .. ".filesystem"),
|
filesystem = require(... .. ".filesystem"),
|
||||||
|
icon_theme = require(... .. ".icon_theme"),
|
||||||
shape = require(... .. ".shape"),
|
shape = require(... .. ".shape"),
|
||||||
time = require(... .. ".time"),
|
time = require(... .. ".time"),
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,6 +8,7 @@ local wibox = require("wibox")
|
||||||
local beautiful = require("beautiful")
|
local beautiful = require("beautiful")
|
||||||
local color = require(tostring(...):match(".*bling") .. ".helpers.color")
|
local color = require(tostring(...):match(".*bling") .. ".helpers.color")
|
||||||
local prompt = require(... .. ".prompt")
|
local prompt = require(... .. ".prompt")
|
||||||
|
local helpers = require(tostring(path):match(".*bling") .. ".helpers")
|
||||||
local dpi = beautiful.xresources.apply_dpi
|
local dpi = beautiful.xresources.apply_dpi
|
||||||
local string = string
|
local string = string
|
||||||
local table = table
|
local table = table
|
||||||
|
@ -532,14 +533,12 @@ local function generate_apps(self)
|
||||||
end)
|
end)
|
||||||
end
|
end
|
||||||
|
|
||||||
local icon_theme = require(tostring(path):match(".*bling") .. ".helpers.icon_theme")(self.icon_theme, self.icon_size)
|
|
||||||
|
|
||||||
for _, app in ipairs(apps) do
|
for _, app in ipairs(apps) do
|
||||||
if app.should_show(app) then
|
if app.should_show(app) then
|
||||||
local name = app_info.get_name(app)
|
local name = app_info.get_name(app)
|
||||||
local commandline = app_info.get_commandline(app)
|
local commandline = app_info.get_commandline(app)
|
||||||
local executable = app_info.get_executable(app)
|
local executable = app_info.get_executable(app)
|
||||||
local icon = icon_theme:get_gicon_path(app_info.get_icon(app))
|
local icon = helpers.icon_theme.get_gicon_path(app_info.get_icon(app), self.icon_theme, self.icon_size)
|
||||||
|
|
||||||
-- Check if this app should be skipped, depanding on the skip_names / skip_commands table
|
-- Check if this app should be skipped, depanding on the skip_names / skip_commands table
|
||||||
if not has_value(self.skip_names, name) and not has_value(self.skip_commands, commandline) then
|
if not has_value(self.skip_names, name) and not has_value(self.skip_commands, commandline) then
|
||||||
|
@ -547,11 +546,13 @@ local function generate_apps(self)
|
||||||
if icon ~= "" or self.skip_empty_icons == false then
|
if icon ~= "" or self.skip_empty_icons == false then
|
||||||
if icon == "" then
|
if icon == "" then
|
||||||
if self.default_app_icon_name ~= nil then
|
if self.default_app_icon_name ~= nil then
|
||||||
icon = icon_theme:get_icon_path(self.default_app_icon_name)
|
icon = helpers.icon_theme.get_icon_path(self.default_app_icon_name, self.icon_theme, self.icon_size)
|
||||||
elseif self.default_app_icon_path ~= nil then
|
elseif self.default_app_icon_path ~= nil then
|
||||||
icon = self.default_app_icon_path
|
icon = self.default_app_icon_path
|
||||||
else
|
else
|
||||||
icon = icon_theme:choose_icon({"application-all", "application", "application-default-icon", "app"})
|
icon = helpers.icon_theme.choose_icon(
|
||||||
|
{"application-all", "application", "application-default-icon", "app"},
|
||||||
|
self.icon_theme, self.icon_size)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue