mirror of https://github.com/lcpz/lain.git
Merge remote-tracking branch 'upstream/master'
This commit is contained in:
commit
5e28dd3f9f
|
@ -19,10 +19,7 @@ local function worker(relbox, s, args)
|
|||
local color = args.color or '#FFFFFF'
|
||||
local size = args.size or 1
|
||||
local box = nil
|
||||
local wiboxarg = {
|
||||
position = nil,
|
||||
bg = color
|
||||
}
|
||||
local wiboxarg = { position = nil, bg = color }
|
||||
|
||||
if where == 'top'
|
||||
then
|
||||
|
|
|
@ -0,0 +1,164 @@
|
|||
|
||||
--[[
|
||||
|
||||
Licensed under GNU General Public License v2
|
||||
* (c) 2013, Luke Bonham
|
||||
* (c) 2013, Rman
|
||||
|
||||
--]]
|
||||
|
||||
local newtimer = require("lain.helpers").newtimer
|
||||
local read_pipe = require("lain.helpers").read_pipe
|
||||
|
||||
local awful = require("awful")
|
||||
local beautiful = require("beautiful")
|
||||
local naughty = require("naughty")
|
||||
|
||||
local math = { modf = math.modf }
|
||||
local mouse = mouse
|
||||
local string = { format = string.format,
|
||||
match = string.match,
|
||||
rep = string.rep }
|
||||
local tonumber = tonumber
|
||||
|
||||
local setmetatable = setmetatable
|
||||
|
||||
-- ALSA volume bar
|
||||
-- lain.widgets.pulsebar
|
||||
local pulsebar = {
|
||||
sink = 0,
|
||||
|
||||
colors = {
|
||||
background = beautiful.bg_normal,
|
||||
mute = "#EB8F8F",
|
||||
unmute = "#A4CE8A"
|
||||
},
|
||||
|
||||
mixer = "pavucontrol",
|
||||
|
||||
notifications = {
|
||||
font = beautiful.font:sub(beautiful.font:find(""), beautiful.font:find(" ")),
|
||||
font_size = "11",
|
||||
color = beautiful.fg_normal,
|
||||
bar_size = 18,
|
||||
screen = 1
|
||||
},
|
||||
|
||||
_current_level = 0,
|
||||
_muted = false
|
||||
}
|
||||
|
||||
function pulsebar.notify()
|
||||
pulsebar.update()
|
||||
|
||||
local preset = {
|
||||
title = "",
|
||||
text = "",
|
||||
timeout = 5,
|
||||
screen = pulsebar.notifications.screen,
|
||||
font = pulsebar.notifications.font .. " " ..
|
||||
pulsebar.notifications.font_size,
|
||||
fg = pulsebar.notifications.color
|
||||
}
|
||||
|
||||
if pulsebar._muted
|
||||
then
|
||||
preset.title = "Sink " .. pulsebar.sink .. " - Muted"
|
||||
else
|
||||
preset.title = "Sink " .. pulsebar.sink .. " - " .. pulsebar._current_level .. "%"
|
||||
end
|
||||
|
||||
int = math.modf((pulsebar._current_level / 100) * pulsebar.notifications.bar_size)
|
||||
preset.text = "["
|
||||
.. string.rep("|", int)
|
||||
.. string.rep(" ", pulsebar.notifications.bar_size - int)
|
||||
.. "]"
|
||||
|
||||
if pulsebar.followmouse then
|
||||
preset.screen = mouse.screen
|
||||
end
|
||||
|
||||
if pulsebar._notify ~= nil then
|
||||
pulsebar._notify = naughty.notify ({
|
||||
replaces_id = pulsebar._notify.id,
|
||||
preset = preset,
|
||||
})
|
||||
else
|
||||
pulsebar._notify = naughty.notify ({
|
||||
preset = preset,
|
||||
})
|
||||
end
|
||||
end
|
||||
|
||||
local function worker(args)
|
||||
local args = args or {}
|
||||
local timeout = args.timeout or 5
|
||||
local settings = args.settings or function() end
|
||||
local width = args.width or 63
|
||||
local height = args.heigth or 1
|
||||
local ticks = args.ticks or false
|
||||
local ticks_size = args.ticks_size or 7
|
||||
local vertical = args.vertical or false
|
||||
local scallback = args.scallback
|
||||
|
||||
pulsebar.cmd = args.cmd or string.format("pacmd list-sinks | sed -n -e '0,/*/d' -e '/base volume/d' -e '/volume:/p' -e '/muted:/p'")
|
||||
pulsebar.colors = args.colors or pulsebar.colors
|
||||
pulsebar.notifications = args.notifications or pulsebar.notifications
|
||||
pulsebar.sink = args.sink or 0
|
||||
pulsebar.followmouse = args.followmouse or false
|
||||
|
||||
pulsebar.bar = awful.widget.progressbar()
|
||||
|
||||
pulsebar.bar:set_background_color(pulsebar.colors.background)
|
||||
pulsebar.bar:set_color(pulsebar.colors.unmute)
|
||||
pulsebar.tooltip = awful.tooltip({ objects = { pulsebar.bar } })
|
||||
pulsebar.bar:set_width(width)
|
||||
pulsebar.bar:set_height(height)
|
||||
pulsebar.bar:set_ticks(ticks)
|
||||
pulsebar.bar:set_ticks_size(ticks_size)
|
||||
pulsebar.bar:set_vertical(vertical)
|
||||
|
||||
function pulsebar.update()
|
||||
if scallback then pulseaudio.cmd = scallback() end
|
||||
local s = read_pipe(pulsebar.cmd)
|
||||
|
||||
volume_now = {}
|
||||
volume_now.left = tonumber(string.match(s, ":.-(%d+)%%"))
|
||||
volume_now.right = tonumber(string.match(s, ":.-(%d+)%%"))
|
||||
volume_now.muted = string.match(s, "muted: (%S+)")
|
||||
|
||||
local volu = volume_now.left
|
||||
local mute = volume_now.muted
|
||||
|
||||
if (volu and volu ~= pulsebar._current_level) or (mute and mute ~= pulsebar._muted)
|
||||
then
|
||||
pulsebar._current_level = volu
|
||||
pulsebar.bar:set_value(pulsebar._current_level / 100)
|
||||
if not mute and volu == 0 or mute == "yes"
|
||||
then
|
||||
pulsebar._muted = true
|
||||
pulsebar.tooltip:set_text (" [Muted] ")
|
||||
pulsebar.bar:set_color(pulsebar.colors.mute)
|
||||
else
|
||||
pulsebar._muted = false
|
||||
pulsebar.tooltip:set_text(string.format(" %s:%s ", pulsebar.sink, volu))
|
||||
pulsebar.bar:set_color(pulsebar.colors.unmute)
|
||||
end
|
||||
settings()
|
||||
end
|
||||
end
|
||||
|
||||
pulsebar.bar:buttons (awful.util.table.join (
|
||||
awful.button ({}, 1, function()
|
||||
awful.util.spawn(pulsebar.mixer)
|
||||
end)
|
||||
))
|
||||
|
||||
timer_id = string.format("pulsebar-%s", pulsebar.sink)
|
||||
|
||||
newtimer(timer_id, timeout, pulsebar.update)
|
||||
|
||||
return pulsebar
|
||||
end
|
||||
|
||||
return setmetatable(pulsebar, { __call = function(_, ...) return worker(...) end })
|
|
@ -29,8 +29,7 @@ local function worker(args)
|
|||
|
||||
function update()
|
||||
local f = io.open(tempfile)
|
||||
if f ~= nil
|
||||
then
|
||||
if f then
|
||||
coretemp_now = tonumber(f:read("*all")) / 1000
|
||||
f:close()
|
||||
else
|
||||
|
|
|
@ -18,9 +18,11 @@ local wibox = require("wibox")
|
|||
|
||||
local math = { floor = math.floor }
|
||||
local mouse = mouse
|
||||
local os = { time = os.time }
|
||||
local string = { format = string.format,
|
||||
gsub = string.gsub }
|
||||
|
||||
local tonumber = tonumber
|
||||
local setmetatable = setmetatable
|
||||
|
||||
-- OpenWeatherMap
|
||||
|
@ -36,6 +38,7 @@ local function worker(args)
|
|||
local current_call = args.current_call or "curl -s 'http://api.openweathermap.org/data/2.5/weather?id=%s&units=%s&lang=%s&APPID=%s'"
|
||||
local forecast_call = args.forecast_call or "curl -s 'http://api.openweathermap.org/data/2.5/forecast/daily?id=%s&units=%s&lang=%s&cnt=%s&APPID=%s'"
|
||||
local city_id = args.city_id or 0 -- placeholder
|
||||
local utc = args.utc or 0
|
||||
local units = args.units or "metric"
|
||||
local lang = args.lang or "en"
|
||||
local cnt = args.cnt or 5
|
||||
|
@ -70,10 +73,6 @@ local function worker(args)
|
|||
weather.forecast_update()
|
||||
end
|
||||
|
||||
if not weather.current_text then
|
||||
weather.update()
|
||||
end
|
||||
|
||||
weather.notification = naughty.notify({
|
||||
text = weather.current_text .. weather.notification_text,
|
||||
icon = weather.icon_path,
|
||||
|
@ -121,20 +120,24 @@ local function worker(args)
|
|||
function weather.update()
|
||||
local cmd = string.format(current_call, city_id, units, lang, APPID)
|
||||
async.request(cmd, function(f)
|
||||
local pos, err, sunrise, sunset, current_dt, datetime, icon
|
||||
local pos, err, icon
|
||||
weather_now, pos, err = json.decode(f, 1, nil)
|
||||
weather.current_text=''
|
||||
if not err and weather_now and tonumber(weather_now["cod"]) == 200 then
|
||||
current_dt = os.time()
|
||||
sunrise = weather_now["sys"]["sunrise"]
|
||||
sunset = weather_now["sys"]["sunset"]
|
||||
if current_dt > sunrise and current_dt < sunset then
|
||||
datetime="d"
|
||||
else
|
||||
datetime="n"
|
||||
end
|
||||
-- weather icon based on localtime
|
||||
now = os.time() - (utc * 3600)
|
||||
sunrise = tonumber(weather_now["sys"]["sunrise"])
|
||||
sunset = tonumber(weather_now["sys"]["sunset"])
|
||||
icon = weather_now["weather"][1]["icon"]
|
||||
weather.icon_path = icons_path .. icon:sub(1,2) .. datetime .. ".png"
|
||||
|
||||
if sunrise <= now and now <= sunset then
|
||||
icon = string.gsub(icon, "n", "d")
|
||||
else
|
||||
icon = string.gsub(icon, "d", "n")
|
||||
end
|
||||
|
||||
weather.icon_path = icons_path .. icon .. ".png"
|
||||
|
||||
widget = weather.widget
|
||||
weather.current_text = "Now:" .. weather_now["weather"][1]["description"] .. "\n"
|
||||
settings()
|
||||
|
|
2
wiki
2
wiki
|
@ -1 +1 @@
|
|||
Subproject commit ac3af8c33cc593af15b85f68e20c262e847d566b
|
||||
Subproject commit fea7079ab58cbbea9c18733485f264bc154fe580
|
Loading…
Reference in New Issue