summaryrefslogtreecommitdiff
path: root/fs-widget
diff options
context:
space:
mode:
authorstreetturtle <streetturtle@gmail.com>2021-06-13 21:12:09 -0400
committerstreetturtle <streetturtle@gmail.com>2021-06-13 21:17:50 -0400
commit88e37c2fec87cfd4dba428faaabfb10487ce24f1 (patch)
tree288d6011c860287af37dce4ee8030eaa1f298d91 /fs-widget
parent92a9170d9ce537693b2bdfe566f119b444bbe2e7 (diff)
make beautiful optional in fs-widget
Diffstat (limited to 'fs-widget')
-rw-r--r--fs-widget/fs-widget.lua88
1 files changed, 61 insertions, 27 deletions
diff --git a/fs-widget/fs-widget.lua b/fs-widget/fs-widget.lua
index b5f75f2..6c1ed54 100644
--- a/fs-widget/fs-widget.lua
+++ b/fs-widget/fs-widget.lua
@@ -6,29 +6,65 @@ local gears = require("gears")
local storage_bar_widget = {}
+--- Table with widget configuration, consists of three sections:
+--- - general - general configuration
+--- - widget - configuration of the widget displayed on the wibar
+--- - popup - configuration of the popup
+local config = {}
+
+-- general
+config.mounts = { '/' }
+config.refresh_rate = 60
+
+-- wibar widget
+config.widget_width = 40
+config.widget_bar_color = '#aaaaaa'
+config.widget_onclick_bg = '#ff0000'
+config.widget_border_color = '#535d6c66'
+config.widget_background_color = '#22222233'
+
+-- popup
+config.popup_bg = '#22222233'
+config.popup_border_width = 1
+config.popup_border_color = '#535d6c66'
+config.popup_bar_color = '#aaaaaa'
+config.popup_bar_background_color = '#22222233'
+config.popup_bar_border_color = '#535d6c66'
+
local function worker(user_args)
local args = user_args or {}
- local mounts = args.mounts or { '/' }
- local timeout = args.timeout or 60
+
+ if beautiful ~= nil then
+ config.widget_bar_color = beautiful.fg_normal
+ config.widget_border_color = beautiful.bg_focus
+ config.widget_onclick_bg = beautiful.bg_focus
+ config.widget_background_color = beautiful.bg_normal
+
+ config.popup_bg = beautiful.bg_normal
+ config.popup_border_color = beautiful.bg_focus
+ config.popup_bar_color = beautiful.fg_normal
+ config.popup_bar_border_color = beautiful.bg_focus
+ config.popup_bar_background_color = beautiful.bg_normal
+ config.popup_bar_border_color = beautiful.bg_focus
+ end
+
+ for prop, value in pairs(args) do
+ config[prop] = value
+ end
storage_bar_widget = wibox.widget {
{
id = 'progressbar',
+ color = config.widget_bar_color,
max_value = 100,
forced_height = 20,
- forced_width = 35,
- paddings = 1,
+ forced_width = config.widget_width,
+ paddings = 2,
margins = 4,
border_width = 1,
border_radius = 2,
- border_color = beautiful.fg_normal,
- background_color = beautiful.bg_normal,
- bar_border_width = 1,
- bar_border_color = beautiful.bg_focus,
- color = "linear:150,0:0,0:0,"
- .. beautiful.fg_normal
- .. ":0.3," .. beautiful.bg_urgent .. ":0.6,"
- .. beautiful.fg_normal,
+ border_color = config.widget_border_color,
+ background_color = config.widget_background_color,
widget = wibox.widget.progressbar
},
shape = function(cr, width, height)
@@ -63,11 +99,12 @@ local function worker(user_args)
disk_header:ajust_ratio(1, 0, 0.3, 0.7)
local popup = awful.popup {
+ bg = config.popup_bg,
ontop = true,
visible = false,
shape = gears.shape.rounded_rect,
- border_width = 1,
- border_color = beautiful.bg_normal,
+ border_width = config.popup_border_width,
+ border_color = config.popup_border_color,
maximum_width = 400,
offset = { y = 5 },
widget = {}
@@ -80,7 +117,7 @@ local function worker(user_args)
popup.visible = not popup.visible
storage_bar_widget:set_bg('#00000000')
else
- storage_bar_widget:set_bg(beautiful.bg_focus)
+ storage_bar_widget:set_bg(config.widget_background_color)
popup:move_next_to(mouse.current_widget_geometry)
end
end)
@@ -88,10 +125,11 @@ local function worker(user_args)
)
local disks = {}
- watch([[bash -c "df | tail -n +2"]], timeout,
+ watch([[bash -c "df | tail -n +2"]], config.refresh_rate,
function(widget, stdout)
for line in stdout:gmatch("[^\r\n$]+") do
- local filesystem, size, used, avail, perc, mount = line:match('([%p%w]+)%s+([%d%w]+)%s+([%d%w]+)%s+([%d%w]+)%s+([%d]+)%%%s+([%p%w]+)')
+ local filesystem, size, used, avail, perc, mount =
+ line:match('([%p%w]+)%s+([%d%w]+)%s+([%d%w]+)%s+([%d%w]+)%s+([%d]+)%%%s+([%p%w]+)')
disks[mount] = {}
disks[mount].filesystem = filesystem
@@ -101,12 +139,12 @@ local function worker(user_args)
disks[mount].perc = perc
disks[mount].mount = mount
- if disks[mount].mount == mounts[1] then
+ if disks[mount].mount == config.mounts[1] then
widget:set_value(tonumber(disks[mount].perc))
end
end
- for k, v in ipairs(mounts) do
+ for k, v in ipairs(config.mounts) do
local row = wibox.widget {
{
@@ -115,22 +153,18 @@ local function worker(user_args)
widget = wibox.widget.textbox
},
{
+ color = config.popup_bar_color,
max_value = 100,
value = tonumber(disks[v].perc),
forced_height = 20,
paddings = 1,
margins = 4,
border_width = 1,
- border_color = beautiful.bg_focus,
- background_color = beautiful.bg_normal,
+ border_color = config.popup_bar_border_color,
+ background_color = config.popup_bar_background_color,
bar_border_width = 1,
- bar_border_color = beautiful.bg_focus,
- color = "linear:150,0:0,0:0,"
- .. beautiful.fg_normal
- .. ":0.3," .. beautiful.bg_urgent .. ":0.6,"
- .. beautiful.fg_normal,
+ bar_border_color = config.popup_bar_border_color,
widget = wibox.widget.progressbar,
-
},
{
text = math.floor(disks[v].used / 1024 / 1024)