mirror of https://github.com/lcpz/lain.git
API change: lain.widget.contrib.tpbat has been rewritten and renamed to lain.widget.contrib.tp_smapi
lain.widget.cal: honour followtag argument lightened calls to libraries
This commit is contained in:
parent
d9d5a464cb
commit
233768f096
|
@ -8,9 +8,7 @@
|
||||||
|
|
||||||
--]]
|
--]]
|
||||||
|
|
||||||
local math = { ceil = math.ceil,
|
local math = math
|
||||||
floor = math.floor,
|
|
||||||
max = math.max }
|
|
||||||
local screen = screen
|
local screen = screen
|
||||||
local tonumber = tonumber
|
local tonumber = tonumber
|
||||||
|
|
||||||
|
|
|
@ -7,14 +7,11 @@
|
||||||
--]]
|
--]]
|
||||||
|
|
||||||
local awful = require("awful")
|
local awful = require("awful")
|
||||||
local capi = { client = client }
|
local client = client
|
||||||
|
local math = math
|
||||||
local math = { floor = math.floor }
|
local string = string
|
||||||
local string = { format = string.format }
|
|
||||||
|
|
||||||
local pairs = pairs
|
local pairs = pairs
|
||||||
local screen = screen
|
local screen = screen
|
||||||
|
|
||||||
local setmetatable = setmetatable
|
local setmetatable = setmetatable
|
||||||
|
|
||||||
-- Quake-like Dropdown application spawn
|
-- Quake-like Dropdown application spawn
|
||||||
|
@ -80,7 +77,7 @@ function quake:display()
|
||||||
client:raise()
|
client:raise()
|
||||||
self.last_tag = self.screen.selected_tag
|
self.last_tag = self.screen.selected_tag
|
||||||
client:tags({self.screen.selected_tag})
|
client:tags({self.screen.selected_tag})
|
||||||
capi.client.focus = client
|
client.focus = client
|
||||||
else
|
else
|
||||||
client.hidden = true
|
client.hidden = true
|
||||||
local ctags = client:tags()
|
local ctags = client:tags()
|
||||||
|
@ -140,12 +137,12 @@ function quake:new(config)
|
||||||
|
|
||||||
local dropdown = setmetatable(conf, { __index = quake })
|
local dropdown = setmetatable(conf, { __index = quake })
|
||||||
|
|
||||||
capi.client.connect_signal("manage", function(c)
|
client.connect_signal("manage", function(c)
|
||||||
if c.instance == dropdown.name and c.screen == dropdown.screen then
|
if c.instance == dropdown.name and c.screen == dropdown.screen then
|
||||||
dropdown:display()
|
dropdown:display()
|
||||||
end
|
end
|
||||||
end)
|
end)
|
||||||
capi.client.connect_signal("unmanage", function(c)
|
client.connect_signal("unmanage", function(c)
|
||||||
if c.instance == dropdown.name and c.screen == dropdown.screen then
|
if c.instance == dropdown.name and c.screen == dropdown.screen then
|
||||||
dropdown.visible = false
|
dropdown.visible = false
|
||||||
end
|
end
|
||||||
|
|
|
@ -9,8 +9,7 @@
|
||||||
local helpers = require("lain.helpers")
|
local helpers = require("lain.helpers")
|
||||||
local shell = require("awful.util").shell
|
local shell = require("awful.util").shell
|
||||||
local wibox = require("wibox")
|
local wibox = require("wibox")
|
||||||
local string = { match = string.match,
|
local string = string
|
||||||
format = string.format }
|
|
||||||
|
|
||||||
-- ALSA volume
|
-- ALSA volume
|
||||||
-- lain.widget.alsa
|
-- lain.widget.alsa
|
||||||
|
|
|
@ -10,8 +10,10 @@ local helpers = require("lain.helpers")
|
||||||
local awful = require("awful")
|
local awful = require("awful")
|
||||||
local naughty = require("naughty")
|
local naughty = require("naughty")
|
||||||
local wibox = require("wibox")
|
local wibox = require("wibox")
|
||||||
|
local math = math
|
||||||
local math, string, type, tonumber = math, string, type, tonumber
|
local string = string
|
||||||
|
local type = type
|
||||||
|
local tonumber = tonumber
|
||||||
|
|
||||||
-- ALSA volume bar
|
-- ALSA volume bar
|
||||||
-- lain.widget.alsabar
|
-- lain.widget.alsabar
|
||||||
|
|
|
@ -79,7 +79,7 @@ local function factory(args)
|
||||||
cal.notification = nil
|
cal.notification = nil
|
||||||
end
|
end
|
||||||
|
|
||||||
function cal.show(timeout, month, year)
|
function cal.show(timeout, month, year, scr)
|
||||||
cal.notification_preset.text = tconcat(cal.build(month, year))
|
cal.notification_preset.text = tconcat(cal.build(month, year))
|
||||||
|
|
||||||
if cal.three then
|
if cal.three then
|
||||||
|
@ -95,6 +95,7 @@ local function factory(args)
|
||||||
cal.hide()
|
cal.hide()
|
||||||
cal.notification = naughty.notify {
|
cal.notification = naughty.notify {
|
||||||
preset = cal.notification_preset,
|
preset = cal.notification_preset,
|
||||||
|
screen = cal.followtag and awful.screen.focused() or scr or 1,
|
||||||
icon = cal.icon,
|
icon = cal.icon,
|
||||||
timeout = timeout or cal.notification_preset.timeout or 5
|
timeout = timeout or cal.notification_preset.timeout or 5
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,9 +11,8 @@ local focused = require("awful.screen").focused
|
||||||
local escape_f = require("awful.util").escape
|
local escape_f = require("awful.util").escape
|
||||||
local naughty = require("naughty")
|
local naughty = require("naughty")
|
||||||
local wibox = require("wibox")
|
local wibox = require("wibox")
|
||||||
local os = { getenv = os.getenv }
|
local os = os
|
||||||
local string = { format = string.format,
|
local string = string
|
||||||
gmatch = string.gmatch }
|
|
||||||
|
|
||||||
-- MOC audio player
|
-- MOC audio player
|
||||||
-- lain.widget.contrib.moc
|
-- lain.widget.contrib.moc
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
--[[
|
--[[
|
||||||
|
|
||||||
Licensed under GNU General Public License v2
|
Licensed under GNU General Public License v2
|
||||||
|
* (c) 2017, Luca CPZ
|
||||||
* (c) 2014, blueluke <http://github.com/blueluke>
|
* (c) 2014, blueluke <http://github.com/blueluke>
|
||||||
|
|
||||||
--]]
|
--]]
|
||||||
|
|
|
@ -0,0 +1,145 @@
|
||||||
|
--[[
|
||||||
|
|
||||||
|
Licensed under GNU General Public License v2
|
||||||
|
* (c) 2018, Luca CPZ
|
||||||
|
* (c) 2013, Conor Heine
|
||||||
|
|
||||||
|
--]]
|
||||||
|
|
||||||
|
local helpers = require("lain.helpers")
|
||||||
|
local focused = require("awful.screen").focused
|
||||||
|
local gears = require("gears")
|
||||||
|
local naughty = require("naughty")
|
||||||
|
local string = string
|
||||||
|
|
||||||
|
-- ThinkPad battery infos and widget creator
|
||||||
|
-- http://www.thinkwiki.org/wiki/Tp_smapi
|
||||||
|
-- lain.widget.contrib.tp_smapi
|
||||||
|
|
||||||
|
local function factory(apipath)
|
||||||
|
local tp_smapi = {
|
||||||
|
path = apipath or "/sys/devices/platform/tp_smapi"
|
||||||
|
}
|
||||||
|
|
||||||
|
function tp_smapi.get(batid, feature)
|
||||||
|
return helpers.first_line(string.format("%s/%s/%s", tp_smapi.path, batid or "BAT0", feature or ""))
|
||||||
|
end
|
||||||
|
|
||||||
|
function tp_smapi.installed(batid)
|
||||||
|
return tp_smapi.get(batid, "installed") == "1"
|
||||||
|
end
|
||||||
|
|
||||||
|
function tp_smapi.status(batid)
|
||||||
|
return tp_smapi.get(batid, "state")
|
||||||
|
end
|
||||||
|
|
||||||
|
function tp_smapi.percentage(batid)
|
||||||
|
return tp_smapi.get("remaining_percent")
|
||||||
|
end
|
||||||
|
|
||||||
|
-- either running or charging time
|
||||||
|
function tp_smapi.time(batid)
|
||||||
|
local status = tp_smapi.status(batid)
|
||||||
|
local mins_left = tp_smapi.get(batid, string.match(string.lower(status), "discharging") and "remaining_running_time" or "remaining_charging_time")
|
||||||
|
if not string.find(mins_left, "^%d+") then return "N/A" end
|
||||||
|
return string.format("%02d:%02d", math.floor(mins_left / 60), mins_left % 60) -- HH:mm
|
||||||
|
end
|
||||||
|
|
||||||
|
function tp_smapi.hide()
|
||||||
|
if not tp_smapi.notification then return end
|
||||||
|
naughty.destroy(tp_smapi.notification)
|
||||||
|
tp_smapi.notification = nil
|
||||||
|
end
|
||||||
|
|
||||||
|
function tp_smapi.show(batid, seconds, scr)
|
||||||
|
if not tp_smapi.installed(batid) then return end
|
||||||
|
|
||||||
|
local mfgr = tp_smapi.get(batid, "manufacturer") or "no_mfgr"
|
||||||
|
local model = tp_smapi.get(batid, "model") or "no_model"
|
||||||
|
local chem = tp_smapi.get(batid, "chemistry") or "no_chem"
|
||||||
|
local status = tp_smapi.get(batid, "state")
|
||||||
|
local time = tp_smapi.time(batid)
|
||||||
|
local msg = ""
|
||||||
|
|
||||||
|
if status and status ~= "idle" then
|
||||||
|
msg = string.format("[%s] %s %s", status, time ~= "N/A" and time or "unknown remaining time",
|
||||||
|
string.lower(status):gsub(" ", ""):gsub("\n", "") == "charging" and " until charged" or " remaining")
|
||||||
|
else
|
||||||
|
msg = "On AC power"
|
||||||
|
end
|
||||||
|
|
||||||
|
tp_smapi.hide()
|
||||||
|
tp_smapi.notification = naughty.notify {
|
||||||
|
title = string.format("%s: %s %s (%s)", batid, mfgr, model, chem),
|
||||||
|
text = msg,
|
||||||
|
timeout = seconds or 0,
|
||||||
|
screen = scr or focused()
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
function tp_smapi.create_widget(args)
|
||||||
|
local args = args or {}
|
||||||
|
local pspath = args.pspath or "/sys/class/power_supply/"
|
||||||
|
local batteries = args.batteries or (args.battery and {args.battery}) or {}
|
||||||
|
local timeout = args.timeout or 30
|
||||||
|
local settings = args.settings or function() end
|
||||||
|
|
||||||
|
if #batteries == 0 then
|
||||||
|
helpers.line_callback("ls -1 " .. pspath, function(line)
|
||||||
|
local bstr = string.match(line, "BAT%w+")
|
||||||
|
if bstr then batteries[#batteries + 1] = bstr end
|
||||||
|
end)
|
||||||
|
end
|
||||||
|
|
||||||
|
local all_batteries_installed = true
|
||||||
|
|
||||||
|
for i, battery in ipairs(batteries) do
|
||||||
|
if not tp_smapi.installed(battery) then
|
||||||
|
naughty.notify {
|
||||||
|
preset = naughty.config.critical,
|
||||||
|
title = "tp_smapi: error while creating widget",
|
||||||
|
text = string.format("battery %s is not installed", battery)
|
||||||
|
}
|
||||||
|
all_batteries_installed = false
|
||||||
|
break
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if not all_batteries_installed then return end
|
||||||
|
|
||||||
|
tpbat = {
|
||||||
|
batteries = batteries,
|
||||||
|
widget = args.widget or wibox.widget.textbox()
|
||||||
|
}
|
||||||
|
|
||||||
|
function tpbat.update()
|
||||||
|
tpbat_now = {
|
||||||
|
n_status = {},
|
||||||
|
n_perc = {},
|
||||||
|
n_time = {},
|
||||||
|
status = "N/A"
|
||||||
|
}
|
||||||
|
|
||||||
|
for i = 1, #batteries do
|
||||||
|
tpbat_now.n_status[i] = tp_smapi.status(batteries[i]) or "N/A"
|
||||||
|
tpbat_now.n_perc[i] = tp_smapi.percentage(batteries[i])
|
||||||
|
tpbat_now.n_time[i] = tp_smapi.time(batteries[i]) or "N/A"
|
||||||
|
|
||||||
|
if not tpbat_now.n_status[i]:lower():match("full") then
|
||||||
|
tpbat_now.status = tpbat_now.n_status[i]
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
widget = tpbat.widget -- backwards compatibility
|
||||||
|
settings()
|
||||||
|
end
|
||||||
|
|
||||||
|
helpers.newtimer("thinkpad-batteries", timeout, tpbat.update)
|
||||||
|
|
||||||
|
return tpbat
|
||||||
|
end
|
||||||
|
|
||||||
|
return tp_smapi
|
||||||
|
end
|
||||||
|
|
||||||
|
return factory
|
|
@ -10,7 +10,7 @@ local markup = require("lain.util").markup
|
||||||
local awful = require("awful")
|
local awful = require("awful")
|
||||||
local naughty = require("naughty")
|
local naughty = require("naughty")
|
||||||
local mouse = mouse
|
local mouse = mouse
|
||||||
local string = { format = string.format, gsub = string.gsub }
|
local string = string
|
||||||
|
|
||||||
-- Taskwarrior notification
|
-- Taskwarrior notification
|
||||||
-- lain.widget.contrib.task
|
-- lain.widget.contrib.task
|
||||||
|
@ -23,11 +23,7 @@ function task.hide()
|
||||||
end
|
end
|
||||||
|
|
||||||
function task.show(scr)
|
function task.show(scr)
|
||||||
if task.followtag then
|
task.notification_preset.screen = task.followtag and awful.screen.focused() or scr or 1
|
||||||
task.notification_preset.screen = awful.screen.focused()
|
|
||||||
elseif scr then
|
|
||||||
task.notification_preset.screen = scr
|
|
||||||
end
|
|
||||||
|
|
||||||
helpers.async({ awful.util.shell, "-c", task.show_cmd }, function(f)
|
helpers.async({ awful.util.shell, "-c", task.show_cmd }, function(f)
|
||||||
local widget_focused = true
|
local widget_focused = true
|
||||||
|
@ -44,12 +40,12 @@ function task.show(scr)
|
||||||
|
|
||||||
if widget_focused then
|
if widget_focused then
|
||||||
task.hide()
|
task.hide()
|
||||||
task.notification = naughty.notify({
|
task.notification = naughty.notify {
|
||||||
preset = task.notification_preset,
|
preset = task.notification_preset,
|
||||||
title = "task next",
|
title = "task next",
|
||||||
text = markup.font(task.notification_preset.font,
|
text = markup.font(task.notification_preset.font,
|
||||||
awful.util.escape(f:gsub("\n*$", "")))
|
awful.util.escape(f:gsub("\n*$", "")))
|
||||||
})
|
}
|
||||||
end
|
end
|
||||||
end)
|
end)
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,163 +0,0 @@
|
||||||
--[[
|
|
||||||
|
|
||||||
tpbat.lua
|
|
||||||
Battery status widget for ThinkPad laptops that use SMAPI
|
|
||||||
lain.widget.contrib.tpbat
|
|
||||||
|
|
||||||
More on tp_smapi: http://www.thinkwiki.org/wiki/Tp_smapi
|
|
||||||
|
|
||||||
Licensed under GNU General Public License v2
|
|
||||||
* (c) 2013, Conor Heine
|
|
||||||
* (c) 2013, Luca CPZ
|
|
||||||
* (c) 2010-2012, Peter Hofmann
|
|
||||||
|
|
||||||
--]]
|
|
||||||
|
|
||||||
local debug = { getinfo = debug.getinfo }
|
|
||||||
local newtimer = require("lain.helpers").newtimer
|
|
||||||
local first_line = require("lain.helpers").first_line
|
|
||||||
local naughty = require("naughty")
|
|
||||||
local wibox = require("wibox")
|
|
||||||
local string = { format = string.format }
|
|
||||||
local math = { floor = math.floor }
|
|
||||||
local tostring = tostring
|
|
||||||
local setmetatable = setmetatable
|
|
||||||
package.path = debug.getinfo(1,"S").source:match[[^@?(.*[\/])[^\/]-$]] .. "?.lua;" .. package.path
|
|
||||||
local smapi = require("smapi")
|
|
||||||
|
|
||||||
-- ThinkPad SMAPI-enabled battery info widget
|
|
||||||
-- lain.widget.contrib.tpbat
|
|
||||||
local tpbat = {}
|
|
||||||
|
|
||||||
function tpbat.hide()
|
|
||||||
if not tpbat.notification then return end
|
|
||||||
naughty.destroy(tpbat.notification)
|
|
||||||
tpbat.notification = nil
|
|
||||||
end
|
|
||||||
|
|
||||||
function tpbat.show(t_out)
|
|
||||||
tpbat.hide()
|
|
||||||
|
|
||||||
local bat = tpbat.bat
|
|
||||||
|
|
||||||
if bat == nil or not bat:installed() then return end
|
|
||||||
|
|
||||||
local t_out = t_out or 0
|
|
||||||
local mfgr = bat:get('manufacturer') or "no_mfgr"
|
|
||||||
local model = bat:get('model') or "no_model"
|
|
||||||
local chem = bat:get('chemistry') or "no_chem"
|
|
||||||
local status = bat:get('state') or "nil"
|
|
||||||
local time = bat:remaining_time()
|
|
||||||
local msg = "\t"
|
|
||||||
|
|
||||||
if status ~= "idle" and status ~= "nil" then
|
|
||||||
if time == "N/A" then
|
|
||||||
msg = "...Calculating time remaining..."
|
|
||||||
else
|
|
||||||
msg = time .. (status == "charging" and " until charged" or " remaining")
|
|
||||||
end
|
|
||||||
else
|
|
||||||
msg = "On AC Power"
|
|
||||||
end
|
|
||||||
|
|
||||||
local str = string.format("%s : %s %s (%s)\n", bat.name, mfgr, model, chem)
|
|
||||||
.. string.format("\n%s \t\t\t %s", status:upper(), msg)
|
|
||||||
|
|
||||||
tpbat.notification = naughty.notify({
|
|
||||||
text = str,
|
|
||||||
timeout = t_out,
|
|
||||||
screen = client.focus and client.focus.screen or 1
|
|
||||||
})
|
|
||||||
end
|
|
||||||
|
|
||||||
function tpbat.register(args)
|
|
||||||
local args = args or {}
|
|
||||||
local timeout = args.timeout or 30
|
|
||||||
local battery = args.battery or "BAT0"
|
|
||||||
local bat_low_perc = args.bat_low_perc or 15
|
|
||||||
local bat_critical_perc = args.bat_critical_perc or 5
|
|
||||||
local settings = args.settings or function() end
|
|
||||||
|
|
||||||
tpbat.bat = smapi:battery(battery) -- Create a new battery
|
|
||||||
local bat = tpbat.bat
|
|
||||||
|
|
||||||
tpbat.widget = wibox.widget.textbox()
|
|
||||||
|
|
||||||
bat_notification_low_preset = {
|
|
||||||
title = "Battery low",
|
|
||||||
text = "Plug the cable!",
|
|
||||||
timeout = 15,
|
|
||||||
fg = "#202020",
|
|
||||||
bg = "#CDCDCD"
|
|
||||||
}
|
|
||||||
|
|
||||||
bat_notification_critical_preset = {
|
|
||||||
title = "Battery exhausted",
|
|
||||||
text = "Shutdown imminent",
|
|
||||||
timeout = 15,
|
|
||||||
fg = "#000000",
|
|
||||||
bg = "#FFFFFF"
|
|
||||||
}
|
|
||||||
|
|
||||||
if bat:get('state') == nil
|
|
||||||
then
|
|
||||||
local n = naughty.notify({
|
|
||||||
preset = bat_notification_low_preset,
|
|
||||||
title = "SMAPI Battery Warning: Unable to read battery state!",
|
|
||||||
text = "This widget is intended for ThinkPads. Is tp_smapi installed? Check your configs & paths.",
|
|
||||||
screen = client.focus and client.focus.screen or 1
|
|
||||||
})
|
|
||||||
end
|
|
||||||
|
|
||||||
function tpbat.update()
|
|
||||||
bat_now = {
|
|
||||||
status = "Not present",
|
|
||||||
perc = "N/A",
|
|
||||||
time = "N/A",
|
|
||||||
watt = "N/A"
|
|
||||||
}
|
|
||||||
|
|
||||||
if bat:installed()
|
|
||||||
then
|
|
||||||
bat_now.status = bat:status() or "N/A"
|
|
||||||
bat_now.perc = bat:percent()
|
|
||||||
bat_now.time = bat:remaining_time()
|
|
||||||
-- bat_now.watt = string.format("%.2fW", (VOLTS * AMPS) / 1e12)
|
|
||||||
|
|
||||||
-- notifications for low and critical states (when discharging)
|
|
||||||
if bat_now.status == "discharging"
|
|
||||||
then
|
|
||||||
if bat_now.perc <= bat_critical_perc
|
|
||||||
then
|
|
||||||
tpbat.id = naughty.notify({
|
|
||||||
preset = bat_notification_critical_preset,
|
|
||||||
replaces_id = tpbat.id,
|
|
||||||
screen = client.focus and client.focus.screen or 1
|
|
||||||
}).id
|
|
||||||
elseif bat_now.perc <= bat_low_perc
|
|
||||||
then
|
|
||||||
tpbat.id = naughty.notify({
|
|
||||||
preset = bat_notification_low_preset,
|
|
||||||
replaces_id = tpbat.id,
|
|
||||||
screen = client.focus and client.focus.screen or 1
|
|
||||||
}).id
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
bat_now.perc = tostring(bat_now.perc)
|
|
||||||
end
|
|
||||||
|
|
||||||
widget = tpbat.widget
|
|
||||||
|
|
||||||
settings()
|
|
||||||
end
|
|
||||||
|
|
||||||
newtimer("tpbat-" .. bat.name, timeout, tpbat.update)
|
|
||||||
|
|
||||||
widget:connect_signal('mouse::enter', function () tpbat.show() end)
|
|
||||||
widget:connect_signal('mouse::leave', function () tpbat.hide() end)
|
|
||||||
|
|
||||||
return tpbat
|
|
||||||
end
|
|
||||||
|
|
||||||
return setmetatable(tpbat, { __call = function(_, ...) return tpbat.register(...) end })
|
|
|
@ -1,98 +0,0 @@
|
||||||
--[[
|
|
||||||
|
|
||||||
smapi.lua
|
|
||||||
Interface with thinkpad battery information
|
|
||||||
|
|
||||||
Licensed under GNU General Public License v2
|
|
||||||
* (c) 2013, Conor Heine
|
|
||||||
|
|
||||||
--]]
|
|
||||||
|
|
||||||
local first_line = require("lain.helpers").first_line
|
|
||||||
|
|
||||||
local string = { format = string.format }
|
|
||||||
local tonumber = tonumber
|
|
||||||
local setmetatable = setmetatable
|
|
||||||
|
|
||||||
local smapi = {}
|
|
||||||
local apipath = "/sys/devices/platform/smapi"
|
|
||||||
|
|
||||||
-- Most are readable values, but some can be written to (not implemented, yet?)
|
|
||||||
local readable = {
|
|
||||||
barcoding = true,
|
|
||||||
charging_max_current = true,
|
|
||||||
charging_max_voltage = true,
|
|
||||||
chemistry = true,
|
|
||||||
current_avg = true,
|
|
||||||
current_now = true,
|
|
||||||
cycle_count = true,
|
|
||||||
design_capacity = true,
|
|
||||||
design_voltage = true,
|
|
||||||
dump = true,
|
|
||||||
first_use_date = true,
|
|
||||||
force_discharge = false,
|
|
||||||
group0_voltage = true,
|
|
||||||
group1_voltage = true,
|
|
||||||
group2_voltage = true,
|
|
||||||
group3_voltage = true,
|
|
||||||
inhibit_charge_minutes = false,
|
|
||||||
installed = true,
|
|
||||||
last_full_capacity = true,
|
|
||||||
manufacture_date = true,
|
|
||||||
manufacturer = true,
|
|
||||||
model = true,
|
|
||||||
power_avg = true,
|
|
||||||
power_now = true,
|
|
||||||
remaining_capacity = true,
|
|
||||||
remaining_charging_time = true,
|
|
||||||
remaining_percent = true,
|
|
||||||
remaining_percent_error = true,
|
|
||||||
remaining_running_time = true,
|
|
||||||
remaining_running_time_now = true,
|
|
||||||
serial = true,
|
|
||||||
start_charge_thresh = false,
|
|
||||||
state = true,
|
|
||||||
stop_charge_thresh = false,
|
|
||||||
temperature = true,
|
|
||||||
voltage = true
|
|
||||||
}
|
|
||||||
|
|
||||||
function smapi:battery(name)
|
|
||||||
local bat = {}
|
|
||||||
|
|
||||||
bat.name = name
|
|
||||||
bat.path = apipath .. "/" .. name
|
|
||||||
|
|
||||||
function bat:get(item)
|
|
||||||
return self.path ~= nil and readable[item] and first_line(self.path .. "/" .. item) or nil
|
|
||||||
end
|
|
||||||
|
|
||||||
function bat:installed()
|
|
||||||
return self:get("installed") == "1"
|
|
||||||
end
|
|
||||||
|
|
||||||
function bat:status()
|
|
||||||
return self:get('state')
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Remaining time can either be time until battery dies or time until charging completes
|
|
||||||
function bat:remaining_time()
|
|
||||||
local time_val = bat_now.status == 'discharging' and 'remaining_running_time' or 'remaining_charging_time'
|
|
||||||
local mins_left = self:get(time_val)
|
|
||||||
|
|
||||||
if not mins_left:find("^%d+") then return "N/A" end
|
|
||||||
|
|
||||||
local hrs = math.floor(mins_left / 60)
|
|
||||||
local min = mins_left % 60
|
|
||||||
|
|
||||||
return string.format("%02d:%02d", hrs, min)
|
|
||||||
end
|
|
||||||
|
|
||||||
function bat:percent()
|
|
||||||
return tonumber(self:get("remaining_percent"))
|
|
||||||
end
|
|
||||||
|
|
||||||
return setmetatable(bat, {__metatable = false, __newindex = false})
|
|
||||||
end
|
|
||||||
|
|
||||||
return smapi
|
|
|
@ -8,9 +8,8 @@
|
||||||
|
|
||||||
local helpers = require("lain.helpers")
|
local helpers = require("lain.helpers")
|
||||||
local wibox = require("wibox")
|
local wibox = require("wibox")
|
||||||
local math = { ceil = math.ceil }
|
local math = math
|
||||||
local string = { format = string.format,
|
local string = string
|
||||||
gmatch = string.gmatch }
|
|
||||||
local tostring = tostring
|
local tostring = tostring
|
||||||
|
|
||||||
-- CPU usage
|
-- CPU usage
|
||||||
|
|
|
@ -66,7 +66,7 @@ local function factory(args)
|
||||||
helpers.async(curl, function(f)
|
helpers.async(curl, function(f)
|
||||||
imap_now = { ["MESSAGES"] = 0, ["RECENT"] = 0, ["UNSEEN"] = 0 }
|
imap_now = { ["MESSAGES"] = 0, ["RECENT"] = 0, ["UNSEEN"] = 0 }
|
||||||
|
|
||||||
for s, d in f:gmatch("(%w+)%s+(%d+)") do imap_now[s] = tonumber(d) end
|
for s,d in f:gmatch("(%w+)%s+(%d+)") do imap_now[s] = tonumber(d) end
|
||||||
mailcount = imap_now["UNSEEN"] -- backwards compatibility
|
mailcount = imap_now["UNSEEN"] -- backwards compatibility
|
||||||
widget = imap.widget
|
widget = imap.widget
|
||||||
|
|
||||||
|
@ -79,7 +79,8 @@ local function factory(args)
|
||||||
text = string.format("%s has <b>%d</b> new message%s", mail, mailcount, mailcount == 1 and "" or "s")
|
text = string.format("%s has <b>%d</b> new message%s", mail, mailcount, mailcount == 1 and "" or "s")
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
helpers.set_map(mail, mailcount)
|
|
||||||
|
helpers.set_map(mail, imap_now["UNSEEN"])
|
||||||
end)
|
end)
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -12,10 +12,8 @@ local escape_f = require("awful.util").escape
|
||||||
local focused = require("awful.screen").focused
|
local focused = require("awful.screen").focused
|
||||||
local naughty = require("naughty")
|
local naughty = require("naughty")
|
||||||
local wibox = require("wibox")
|
local wibox = require("wibox")
|
||||||
local os = { getenv = os.getenv }
|
local os = os
|
||||||
local string = { format = string.format,
|
local string = string
|
||||||
gmatch = string.gmatch,
|
|
||||||
match = string.match }
|
|
||||||
|
|
||||||
-- MPD infos
|
-- MPD infos
|
||||||
-- lain.widget.mpd
|
-- lain.widget.mpd
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
local helpers = require("lain.helpers")
|
local helpers = require("lain.helpers")
|
||||||
local naughty = require("naughty")
|
local naughty = require("naughty")
|
||||||
local wibox = require("wibox")
|
local wibox = require("wibox")
|
||||||
local string = { format = string.format, match = string.match }
|
local string = string
|
||||||
|
|
||||||
-- Network infos
|
-- Network infos
|
||||||
-- lain.widget.net
|
-- lain.widget.net
|
||||||
|
|
|
@ -8,9 +8,7 @@
|
||||||
local helpers = require("lain.helpers")
|
local helpers = require("lain.helpers")
|
||||||
local shell = require("awful.util").shell
|
local shell = require("awful.util").shell
|
||||||
local wibox = require("wibox")
|
local wibox = require("wibox")
|
||||||
local string = { gmatch = string.gmatch,
|
local string = string
|
||||||
match = string.match,
|
|
||||||
format = string.format }
|
|
||||||
local type = type
|
local type = type
|
||||||
|
|
||||||
-- PulseAudio volume
|
-- PulseAudio volume
|
||||||
|
|
|
@ -10,8 +10,10 @@ local helpers = require("lain.helpers")
|
||||||
local awful = require("awful")
|
local awful = require("awful")
|
||||||
local naughty = require("naughty")
|
local naughty = require("naughty")
|
||||||
local wibox = require("wibox")
|
local wibox = require("wibox")
|
||||||
|
local math = math
|
||||||
local math, string, type, tonumber = math, string, type, tonumber
|
local string = string
|
||||||
|
local type = type
|
||||||
|
local tonumber = tonumber
|
||||||
|
|
||||||
-- PulseAudio volume bar
|
-- PulseAudio volume bar
|
||||||
-- lain.widget.pulsebar
|
-- lain.widget.pulsebar
|
||||||
|
|
|
@ -10,8 +10,10 @@ local json = require("lain.util").dkjson
|
||||||
local focused = require("awful.screen").focused
|
local focused = require("awful.screen").focused
|
||||||
local naughty = require("naughty")
|
local naughty = require("naughty")
|
||||||
local wibox = require("wibox")
|
local wibox = require("wibox")
|
||||||
|
local math = math
|
||||||
local math, os, string, tonumber = math, os, string, tonumber
|
local os = os
|
||||||
|
local string = string
|
||||||
|
local tonumber = tonumber
|
||||||
|
|
||||||
-- OpenWeatherMap
|
-- OpenWeatherMap
|
||||||
-- current weather and X-days forecast
|
-- current weather and X-days forecast
|
||||||
|
|
2
wiki
2
wiki
|
@ -1 +1 @@
|
||||||
Subproject commit 39799f8b08f55f567fd3f31db447d35f211bb5ce
|
Subproject commit f52c9068f4e64effe8a3f38e7531beef3fec3388
|
Loading…
Reference in New Issue