mirror of https://github.com/lcpz/lain.git
version 1.0
This commit is contained in:
parent
046b0279b0
commit
fb3da82d10
419
README.md
419
README.md
|
@ -1,419 +0,0 @@
|
||||||
VAin agaIN
|
|
||||||
==========
|
|
||||||
|
|
||||||
Author: Luke Bonham <dada [at] archlinux [dot] info>
|
|
||||||
|
|
||||||
Source: https://github.com/copycat-killer/vain
|
|
||||||
|
|
||||||
Version: 1.9.9
|
|
||||||
|
|
||||||
Release version: 2.0
|
|
||||||
|
|
||||||
**Please note**: until release version, this documentation will be not updated.
|
|
||||||
|
|
||||||
Foreword
|
|
||||||
--------
|
|
||||||
|
|
||||||
Based on a port of [awesome-vain](https://github.com/vain/awesome-vain), this
|
|
||||||
costantly evolving module provides new layouts, a set of widgets and
|
|
||||||
utility functions in order to improve Awesome usability and configurability.
|
|
||||||
|
|
||||||
This work is licensed under [GNU GPLv2 License](http://www.gnu.org/licenses/gpl-2.0.html).
|
|
||||||
Installation
|
|
||||||
============
|
|
||||||
|
|
||||||
Simply clone this repository into your Awesome directory.
|
|
||||||
|
|
||||||
Widgets
|
|
||||||
=======
|
|
||||||
|
|
||||||
systemload
|
|
||||||
----------
|
|
||||||
|
|
||||||
Show the current system load in a textbox. Read it directly from
|
|
||||||
`/proc/loadavg`.
|
|
||||||
|
|
||||||
mysysload = vain.widgets.systemload()
|
|
||||||
|
|
||||||
A click on the widget will call `htop` in your `terminal`.
|
|
||||||
|
|
||||||
The function takes a table as an optional argument. That table may
|
|
||||||
contain:
|
|
||||||
|
|
||||||
* `.refresh_timeout`: Default to 10 seconds.
|
|
||||||
* `.show_all`: Show all three values (`true`) or only the first one (`false`). Default to `false`.
|
|
||||||
* `.color`: Default to beautiful.bg_normal or "#FFFFFF".
|
|
||||||
|
|
||||||
cpu
|
|
||||||
--------
|
|
||||||
|
|
||||||
Shows the average CPU usage percent for a given amount of time.
|
|
||||||
|
|
||||||
mycpuusage = vain.widgets.cpu()
|
|
||||||
|
|
||||||
A click on the widget will call `htop` in your `terminal`.
|
|
||||||
|
|
||||||
The function takes a table as optional argument, which can contain:
|
|
||||||
|
|
||||||
Variable | Meaning | Type | Default
|
|
||||||
--- | --- | --- | ---
|
|
||||||
`refresh_timeout` | Refresh timeout seconds | int | 10
|
|
||||||
`header` | Text to show before value | string | " Vol "
|
|
||||||
`header_color` | Header color | string | `beautiful.fg_normal` or "#FFFFFF"
|
|
||||||
`color` | Value color | string | `beautiful.fg_focus` or "#FFFFFF"
|
|
||||||
`footer` | Text to show after value | string | "%"
|
|
||||||
|
|
||||||
**Note**: `footer` color is `color`.
|
|
||||||
|
|
||||||
memusage
|
|
||||||
--------
|
|
||||||
|
|
||||||
Show used memory and total memory in MiB.
|
|
||||||
|
|
||||||
mymem = vain.widgets.mem()
|
|
||||||
|
|
||||||
|
|
||||||
The function takes a table as an optional argument. That table may
|
|
||||||
contain:
|
|
||||||
|
|
||||||
Variable | Meaning | Type | Default
|
|
||||||
--- | --- | --- | ---
|
|
||||||
`refresh_timeout` | Refresh timeout seconds | int | 10
|
|
||||||
`show_swap` | Show amount of used swap space? | boolean | false
|
|
||||||
`show_total` | Show amout of total memory? | boolean | false
|
|
||||||
`header` | Text to show before value | string | " Vol "
|
|
||||||
`header_color` | Header color | string | `beautiful.fg_normal` or "#FFFFFF"
|
|
||||||
`color` | Value color | string | `beautiful.fg_focus` or "#FFFFFF"
|
|
||||||
`footer` | Text to show after value | string | "MB"
|
|
||||||
|
|
||||||
**Note**: `footer` color is `color`.
|
|
||||||
|
|
||||||
mailcheck
|
|
||||||
---------
|
|
||||||
Checks maildirs and shows the result in a textbox.
|
|
||||||
Maildirs are structured as follows:
|
|
||||||
|
|
||||||
~/Mail
|
|
||||||
.
|
|
||||||
|-- arch
|
|
||||||
| |-- cur
|
|
||||||
| |-- new
|
|
||||||
| `-- tmp
|
|
||||||
|-- gmail
|
|
||||||
| |-- cur
|
|
||||||
| |-- new
|
|
||||||
| `-- tmp
|
|
||||||
.
|
|
||||||
.
|
|
||||||
.
|
|
||||||
|
|
||||||
therefore `mailcheck` checks whether there are files in the `new`
|
|
||||||
directories. To do so, it calls `find`. If there's new mail, the textbox
|
|
||||||
will say something like "mail: bugs(3), system(1)", otherwise it says
|
|
||||||
"no mail".
|
|
||||||
|
|
||||||
mymailcheck = vain.widgets.mailcheck("/path/to/my/maildir")
|
|
||||||
|
|
||||||
The function takes a table as an optional argument. That table may
|
|
||||||
contain:
|
|
||||||
|
|
||||||
* `.mailprogram`: Your favourite mail program. Clicking on the widget will
|
|
||||||
spawn it. Default is `mutt`.
|
|
||||||
* `.refresh_timeout`: Default to 60 seconds.
|
|
||||||
* `.mailpath`: Path to your maildir, default is `~/Mail`.
|
|
||||||
* `.ignore_boxes`: Another table which lists boxes (just the last part,
|
|
||||||
like `lists`) to ignore. Default to an empty table.
|
|
||||||
* `.initial_update`: Check for mail when starting Awesome (`true`) or
|
|
||||||
wait for the first refresh timeout (`false`)? Default to `false`.
|
|
||||||
* `.header_text`: Text to show along with output, default is "Mail".
|
|
||||||
* `.header_text_color`: Default to "#9E9E9E".
|
|
||||||
* `.color_newmail`: Default to "#D4D4D4".
|
|
||||||
* `.color_nomail`: Default to "#9E9E9E".
|
|
||||||
* `.shadow`: Hides widget when there are no mails. Default is `false`.
|
|
||||||
|
|
||||||
imapcheck
|
|
||||||
---------
|
|
||||||
|
|
||||||
Check new mails over imap protocol.
|
|
||||||
|
|
||||||
Dependencies:
|
|
||||||
|
|
||||||
* Python3
|
|
||||||
|
|
||||||
Since [luasec](https://github.com/brunoos/luasec/) is still not officially
|
|
||||||
supported in lua 5.2, writing a pure lua solution would have meant too many
|
|
||||||
hacks and dependencies, resulting in a very big and not efficient-proven submodule.
|
|
||||||
|
|
||||||
That's why I chose Python.
|
|
||||||
|
|
||||||
Python offers [imaplib](http://docs.python.org/2/library/imaplib.html), a simple yet powerful IMAP4 client library which provides encrypted communication over SSL sockets.
|
|
||||||
|
|
||||||
Basically, `imapcheck` calls ``vain/scripts/checkmail`` and parse its output in a widget. New mails are also notified through Naughty, with a popup like this:
|
|
||||||
|
|
||||||
+---------------------------------------------------+
|
|
||||||
| +---+ |
|
|
||||||
| |\ /| donald@disney.org has 3 new messages |
|
|
||||||
| +---+ |
|
|
||||||
| Latest From: Mickey Mouse <boss@disney.org> |
|
|
||||||
| Subject: Re: Vacation Day |
|
|
||||||
| |
|
|
||||||
| Not after what you did yesterday. |
|
|
||||||
| Daisy told me everything [...] |
|
|
||||||
| |
|
|
||||||
+---------------------------------------------------+
|
|
||||||
|
|
||||||
Text will be cut if the mail is too long.
|
|
||||||
|
|
||||||
myimapcheck = vain.widgets.mailcheck(args)
|
|
||||||
|
|
||||||
The function takes a table as argument. Required table parameters are:
|
|
||||||
|
|
||||||
* `.server`: You email server. Example: `imap.gmail.com`.
|
|
||||||
* `.mail`: Your email.
|
|
||||||
* `.password`: Your email password.
|
|
||||||
|
|
||||||
while the optional are:
|
|
||||||
|
|
||||||
* `.port`: Imap port. Default is `993`.
|
|
||||||
* `.refresh_timeout`: Default to 60 seconds.
|
|
||||||
* `.notify_timeout`: Notification timeout. Default to 8 seconds.
|
|
||||||
* `.notify_position`: Notification position. Default is "top_left". Check
|
|
||||||
[Naughty position parameter](http://awesome.naquadah.org/doc/api/modules/naughty.html) for a list of other possible values.
|
|
||||||
* `.mailprogram`: Your favourite mail program. Clicking on the widget will
|
|
||||||
spawn it. Default is `mutt`.
|
|
||||||
* `.mail_encoding`: If you wish to set an encoding. Default is `nil`.
|
|
||||||
* `.initial_update`: Check for mail when starting Awesome (`true`) or
|
|
||||||
wait for the first refresh timeout (`false`)? Default to `false`.
|
|
||||||
* `.header_text`: Text to show along with output, default is "Mail".
|
|
||||||
* `.header_text_color`: Default to "#9E9E9E".
|
|
||||||
* `.color_newmail`: Default to "#D4D4D4".
|
|
||||||
* `.color_nomail`: Default to "#9E9E9E".
|
|
||||||
* `.shadow`: Hides widget when there are no mails. Default is `false`.
|
|
||||||
* `.maxlen`: Maximum mail length. If mail is longer, it will be cut. Default is
|
|
||||||
`100`.
|
|
||||||
* `.is_plain`: Define whether `.password` field is a plain password (`true`) or a function that retrieves it (`false`). Default to `false`.
|
|
||||||
|
|
||||||
Let's focus better on `.is_plain` parameter.
|
|
||||||
|
|
||||||
You can just easily set your password like this:
|
|
||||||
|
|
||||||
args.is_plain = false
|
|
||||||
args.password = "mypassword"
|
|
||||||
|
|
||||||
and you'll have the same security provided by `~/.netrc`. (In this case, it's
|
|
||||||
better to set your `rc.lua` permissions to 700 or 600)
|
|
||||||
|
|
||||||
**Or**, you can use a keyring, like gnome's:
|
|
||||||
|
|
||||||
args.password = "gnome-keyring-query get password"
|
|
||||||
|
|
||||||
(`gnome-keyring-query` is not in gnome-keyring pkg, you have to download it
|
|
||||||
separately)
|
|
||||||
|
|
||||||
or the very light [python keyring](https://pypi.python.org/pypi/keyring).
|
|
||||||
|
|
||||||
When `.is_plain` is `false`, it *executes* `.password` before using it, so you can also use whatever password fetching solution you want.
|
|
||||||
|
|
||||||
You can also define your icon for the naughty notification. Just set `vain_mail_notify` into your ``theme.lua``.
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
mpd
|
|
||||||
---
|
|
||||||
|
|
||||||
Provides a `table` with 2 elements:
|
|
||||||
|
|
||||||
* `table["widget"]` is a textbox displaying current song in play.
|
|
||||||
|
|
||||||
* `table["force"]` is a function to *force* the widget to update, exactly
|
|
||||||
like `vicious.force()`.
|
|
||||||
|
|
||||||
Also, a notification is shown when a new song is playing.
|
|
||||||
|
|
||||||
Dependencies:
|
|
||||||
|
|
||||||
* libnotify
|
|
||||||
* imagemagick
|
|
||||||
|
|
||||||
|
|
||||||
mpdwidget = vain.widgets.mpd()
|
|
||||||
...
|
|
||||||
right_layout:add(mpdwidget["widget"])
|
|
||||||
|
|
||||||
The function takes a table as an optional argument. That table may
|
|
||||||
contain:
|
|
||||||
|
|
||||||
* `.password`: Mpd password. Default is unset.
|
|
||||||
* `.host`: Mpd host. Default is "127.0.0.1" (localhost).
|
|
||||||
* `.port`: Mpd port. Default is "6600".
|
|
||||||
* `.music_dir`: Your music directory. Default is "~/Music". If you have to
|
|
||||||
change this, be sure to write the absolute path.
|
|
||||||
* `.refresh_timeout`: Widget refresh timeout. Default is `1`.
|
|
||||||
* `.notify_timeout`: Notification timeout. Default is `5`.
|
|
||||||
* `.color_artist`: Artist name color. Default is `#9E9E9E`.
|
|
||||||
* `.color_song`: Song name color. Default is `#EBEBFF`.
|
|
||||||
* `.musicplr`: Your favourite music player. Clicking on the widget will spawn
|
|
||||||
it. Default is `ncmpcpp`.
|
|
||||||
* `.shadow`: Hides widget when no song is playing. Default is `false`.
|
|
||||||
|
|
||||||
You can use `table["force"]` to make your mpd keybindings immediate.
|
|
||||||
Example usage:
|
|
||||||
|
|
||||||
globalkeys = awful.util.table.join(
|
|
||||||
...
|
|
||||||
-- Music control
|
|
||||||
awful.key({ altkey, "Control" }, "Up", function ()
|
|
||||||
awful.util.spawn_with_shell( "mpc toggle || ncmpcpp toggle || ncmpc toggle || pms toggle", false )
|
|
||||||
mpdwidget["force"]()
|
|
||||||
end),
|
|
||||||
awful.key({ altkey, "Control" }, "Down", function ()
|
|
||||||
awful.util.spawn_with_shell( "mpc stop || ncmpcpp stop || ncmpc stop || pms stop", false )
|
|
||||||
mpdwidget["force"]()
|
|
||||||
end ),
|
|
||||||
awful.key({ altkey, "Control" }, "Left", function ()
|
|
||||||
awful.util.spawn_with_shell( "mpc prev || ncmpcpp prev || ncmpc prev || pms prev", false )
|
|
||||||
mpdwidget["force"]()
|
|
||||||
end ),
|
|
||||||
awful.key({ altkey, "Control" }, "Right", function ()
|
|
||||||
awful.util.spawn_with_shell( "mpc next || ncmpcpp next || ncmpc next || pms next", false )
|
|
||||||
mpdwidget["force"]()
|
|
||||||
end ),
|
|
||||||
|
|
||||||
net
|
|
||||||
---
|
|
||||||
|
|
||||||
Monitors network interfaces and shows current traffic in a textbox. If
|
|
||||||
the interface is not present or if there's not enough data yet, you'll
|
|
||||||
see `wlan0: -` or similar. Otherwise, the current traffic is shown in
|
|
||||||
kilobytes per second as `eth0: ↑(00,010.2), ↓(01,037.8)` or similar.
|
|
||||||
|
|
||||||
neteth0 = vain.widgets.net()
|
|
||||||
|
|
||||||
The function takes a table as an optional argument. That table may
|
|
||||||
contain:
|
|
||||||
|
|
||||||
* `.iface`: Default to `eth0`.
|
|
||||||
* `.refresh_timeout`: Default to 2 seconds.
|
|
||||||
* `.color`: Default to beautiful.bg_normal or "#FFFFFF".
|
|
||||||
|
|
||||||
gitodo
|
|
||||||
------
|
|
||||||
|
|
||||||
This is an integration of [gitodo](https://github.com/vain/gitodo) into
|
|
||||||
Awesome.
|
|
||||||
|
|
||||||
todolist = vain.widgets.gitodo()
|
|
||||||
|
|
||||||
The function takes a table as an optional argument. That table may
|
|
||||||
contain:
|
|
||||||
|
|
||||||
* `.refresh_timeout`: Default to 120 seconds.
|
|
||||||
* `.initial_update`: Check for todo items when starting Awesome (`true`)
|
|
||||||
or wait for the first refresh timeout (`false`)? Default to `true`.
|
|
||||||
|
|
||||||
`beautiful.gitodo_normal` is used as the color for non-outdated items,
|
|
||||||
`beautiful.gitodo_warning` for those items close to their deadline and
|
|
||||||
`beautiful.gitodo_outdated` is the color of outdated items.
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Utility functions
|
|
||||||
=================
|
|
||||||
|
|
||||||
I'll only explain the more complex functions. See the source code for
|
|
||||||
the others.
|
|
||||||
|
|
||||||
menu\_clients\_current\_tags
|
|
||||||
----------------------------
|
|
||||||
|
|
||||||
Similar to `awful.menu.clients()`, but this menu only shows the clients
|
|
||||||
of currently visible tags. Use it like this:
|
|
||||||
|
|
||||||
globalkeys = awful.util.table.join(
|
|
||||||
...
|
|
||||||
awful.key({ "Mod1" }, "Tab", function()
|
|
||||||
awful.menu.menu_keys.down = { "Down", "Alt_L", "Tab", "j" }
|
|
||||||
awful.menu.menu_keys.up = { "Up", "k" }
|
|
||||||
vain.util.menu_clients_current_tags({ width = 350 }, { keygrabber = true })
|
|
||||||
end),
|
|
||||||
...
|
|
||||||
)
|
|
||||||
|
|
||||||
magnify\_client
|
|
||||||
---------------
|
|
||||||
|
|
||||||
Set a client to floating and resize it in the same way the "magnifier"
|
|
||||||
layout does it. Place it on the "current" screen (derived from the mouse
|
|
||||||
position). This allows you to magnify any client you wish, regardless of
|
|
||||||
the currently used layout. Use it with a client keybinding like this:
|
|
||||||
|
|
||||||
clientkeys = awful.util.table.join(
|
|
||||||
...
|
|
||||||
awful.key({ modkey, "Control" }, "m", vain.util.magnify_client),
|
|
||||||
...
|
|
||||||
)
|
|
||||||
|
|
||||||
If you want to "de-magnify" it, just reset the clients floating state to
|
|
||||||
`false` (hit `Mod4`+`CTRL`+`Space`, for example).
|
|
||||||
|
|
||||||
niceborder\_{focus, unfocus}
|
|
||||||
----------------------------
|
|
||||||
|
|
||||||
By default, your `rc.lua` contains something like this:
|
|
||||||
|
|
||||||
client.connect_signal("focus", function(c) c.border_color = beautiful.border_focus end)
|
|
||||||
client.connect_signal("unfocus", function(c) c.border_color = beautiful.border_normal end)
|
|
||||||
|
|
||||||
You can change it to this:
|
|
||||||
|
|
||||||
client.connect_signal("focus", vain.util.niceborder_focus(c))
|
|
||||||
client.connect_signal("unfocus", vain.util.niceborder_unfocus(c))
|
|
||||||
|
|
||||||
Now, when a client is focused or unfocused, Awesome will look up its
|
|
||||||
nice value in `/proc/<pid>/stat`. If it's less than 0, the client is
|
|
||||||
classified as "high priority"; if it's greater than 0, the client is
|
|
||||||
classified as "low priority". If it's equal to 0, nothing special
|
|
||||||
happens.
|
|
||||||
|
|
||||||
This requires to define additional colors in your `theme.lua`. For example:
|
|
||||||
|
|
||||||
theme.border_focus_highprio = "#FF0000"
|
|
||||||
theme.border_normal_highprio = "#A03333"
|
|
||||||
|
|
||||||
theme.border_focus_lowprio = "#3333FF"
|
|
||||||
theme.border_normal_lowprio = "#333366"
|
|
||||||
|
|
||||||
tag\_view\_nonempty
|
|
||||||
------------------------------
|
|
||||||
|
|
||||||
This function lets you jump to the next/previous non-empty tag.
|
|
||||||
It takes two arguments:
|
|
||||||
|
|
||||||
* `direction`: `1` for next non-empty tag, `-1` for previous.
|
|
||||||
* `sc`: Screen in which the taglist is. Default is `mouse.screen` or `1`. This
|
|
||||||
argument is optional.
|
|
||||||
|
|
||||||
Usage example:
|
|
||||||
|
|
||||||
globalkeys = awful.util.table.join(
|
|
||||||
...
|
|
||||||
-- Non-empty tag browsing
|
|
||||||
awful.key({ altkey }, "Left", function () vain.util.tag_view_nonempty(-1)
|
|
||||||
end),
|
|
||||||
awful.key({ altkey }, "Right", function () vain.util.tag_view_nonempty(1) end),
|
|
||||||
...
|
|
||||||
|
|
||||||
prompt\_rename\_tag
|
|
||||||
-------------------
|
|
||||||
|
|
||||||
This function enables you to dynamically rename the current tag you have
|
|
||||||
focused.
|
|
||||||
Usage example:
|
|
||||||
|
|
||||||
globalkeys = awful.util.table.join(
|
|
||||||
..
|
|
||||||
-- Dynamic tag renaming
|
|
||||||
awful.key({ modkey, "Shift" }, "r", function () vain.util.prompt_rename_tag(mypromptbox) end),
|
|
||||||
...
|
|
||||||
|
|
||||||
Credits goes to [minism](https://bbs.archlinux.org/viewtopic.php?pid=1315135#p1315135).
|
|
|
@ -0,0 +1,25 @@
|
||||||
|
Lain
|
||||||
|
====
|
||||||
|
|
||||||
|
---------------------------------------------
|
||||||
|
Layouts, widgets and utilities for Awesome WM
|
||||||
|
---------------------------------------------
|
||||||
|
|
||||||
|
Author: Luke Bonham <dada [at] archlinux [dot] info>
|
||||||
|
Version: 1.0-git
|
||||||
|
License: GNU-GPLv2_
|
||||||
|
Source: https://github.com/copycat-killer/vain
|
||||||
|
|
||||||
|
Based on a port of awesome-vain_, this costantly evolving module provides new layouts, a set of widgets and utility functions in order to improve Awesome usability and
|
||||||
|
configurability.
|
||||||
|
|
||||||
|
Read the wiki_ for all the info.
|
||||||
|
|
||||||
|
Screenshots
|
||||||
|
-----------
|
||||||
|
|
||||||
|
.. image::
|
||||||
|
|
||||||
|
.. _GNU-GPLv2: http://www.gnu.org/licenses/gpl-2.0.html
|
||||||
|
.. _awesome-vain: https://github.com/vain/awesome-vain
|
||||||
|
.. _wiki: https://github.com/copycat-killer/lain/wiki
|
|
@ -19,39 +19,6 @@ local markup = {}
|
||||||
local fg = {}
|
local fg = {}
|
||||||
local bg = {}
|
local bg = {}
|
||||||
|
|
||||||
--[[ clean this as soon as you document it
|
|
||||||
|
|
||||||
+-- markup
|
|
||||||
|
|
|
||||||
|`-- bold() Set bold.
|
|
||||||
|`-- italic() Set italicized text.
|
|
||||||
|`-- strike() Set strikethrough text.
|
|
||||||
|`-- underline() Set underlined text.
|
|
||||||
|`-- monospace() Set monospaced text.
|
|
||||||
|`-- big() Set bigger text.
|
|
||||||
|`-- small() Set smaller text.
|
|
||||||
|`-- font() Set the font of the text.
|
|
||||||
|
|
|
||||||
|`--+ bg
|
|
||||||
| |
|
|
||||||
| |`-- color() Set background color.
|
|
||||||
| |`-- focus() Set focus background color.
|
|
||||||
| |`-- normal() Set normal background color.
|
|
||||||
| `-- urgent() Set urgent background color.
|
|
||||||
|
|
|
||||||
|`--+ fg
|
|
||||||
| |
|
|
||||||
| |`-- color() Set foreground color.
|
|
||||||
| |`-- focus() Set focus foreground color.
|
|
||||||
| |`-- normal() Set normal foreground color.
|
|
||||||
| `-- urgent() Set urgent foreground color.
|
|
||||||
|
|
|
||||||
|`-- focus() Set both foreground and background focus colors.
|
|
||||||
|`-- normal() Set both foreground and background normal colors.
|
|
||||||
`-- urgent() Set both foreground and background urgent colors.
|
|
||||||
|
|
||||||
]]
|
|
||||||
|
|
||||||
-- Convenience tags.
|
-- Convenience tags.
|
||||||
function markup.bold(text) return '<b>' .. tostring(text) .. '</b>' end
|
function markup.bold(text) return '<b>' .. tostring(text) .. '</b>' end
|
||||||
function markup.italic(text) return '<i>' .. tostring(text) .. '</i>' end
|
function markup.italic(text) return '<i>' .. tostring(text) .. '</i>' end
|
||||||
|
|
|
@ -33,11 +33,10 @@ function worker(args)
|
||||||
local port = args.port or "6600"
|
local port = args.port or "6600"
|
||||||
local music_dir = args.music_dir or os.getenv("HOME") .. "/Music"
|
local music_dir = args.music_dir or os.getenv("HOME") .. "/Music"
|
||||||
local refresh_timeout = args.refresh_timeout or 1
|
local refresh_timeout = args.refresh_timeout or 1
|
||||||
local notify_timeout = args.notify_timeout or 5
|
|
||||||
local color_artist = args.color_artist or beautiful.fg_normal or "#FFFFFF"
|
local color_artist = args.color_artist or beautiful.fg_normal or "#FFFFFF"
|
||||||
local color_song = args.color_song or beautiful.fg_focus or "#FFFFFF"
|
local color_song = args.color_song or beautiful.fg_focus or "#FFFFFF"
|
||||||
local spr = args.spr or ""
|
local spr = args.spr or " "
|
||||||
local musicplr = args.musicplr or "ncmpcpp"
|
local app = args.app or "ncmpcpp"
|
||||||
local shadow = args.shadow or false
|
local shadow = args.shadow or false
|
||||||
|
|
||||||
local mpdcover = helpers.scripts_dir .. "mpdcover"
|
local mpdcover = helpers.scripts_dir .. "mpdcover"
|
||||||
|
@ -100,18 +99,18 @@ function worker(args)
|
||||||
icon = "/tmp/mpdcover.png",
|
icon = "/tmp/mpdcover.png",
|
||||||
fg = beautiful.fg_focus or "#FFFFFF",
|
fg = beautiful.fg_focus or "#FFFFFF",
|
||||||
bg = beautiful.bg_normal or "#000000" ,
|
bg = beautiful.bg_normal or "#000000" ,
|
||||||
timeout = notify_timeout,
|
timeout = 6,
|
||||||
replaces_id = mpd.id
|
replaces_id = mpd.id
|
||||||
}).id
|
}).id
|
||||||
end
|
end
|
||||||
mympd:set_markup(markup(color_artist, " " .. mpd_state["{Artist}"])
|
mympd:set_markup(markup(color_artist, " " .. mpd_state["{Artist}"])
|
||||||
.. spr ..
|
.. spr ..
|
||||||
markup(color_song, " " .. mpd_state["{Title}"] .. " "))
|
markup(color_song, mpd_state["{Title}"] .. " "))
|
||||||
elseif mpd_state["{state}"] == "pause"
|
elseif mpd_state["{state}"] == "pause"
|
||||||
then
|
then
|
||||||
mympd:set_markup(markup(color_artist, " mpd")
|
mympd:set_markup(markup(color_artist, " mpd")
|
||||||
.. spr ..
|
.. spr ..
|
||||||
markup(color_song, " paused "))
|
markup(color_song, "paused "))
|
||||||
else
|
else
|
||||||
helpers.set_map("current mpd track", nil)
|
helpers.set_map("current mpd track", nil)
|
||||||
set_nompd()
|
set_nompd()
|
||||||
|
@ -126,7 +125,7 @@ function worker(args)
|
||||||
mympd:buttons(awful.util.table.join(
|
mympd:buttons(awful.util.table.join(
|
||||||
awful.button({}, 0,
|
awful.button({}, 0,
|
||||||
function()
|
function()
|
||||||
helpers.run_in_terminal(musicplr)
|
helpers.run_in_terminal(app)
|
||||||
end)
|
end)
|
||||||
))
|
))
|
||||||
|
|
||||||
|
|
|
@ -29,7 +29,7 @@ local net = {
|
||||||
last_r = {}
|
last_r = {}
|
||||||
}
|
}
|
||||||
|
|
||||||
local unit = {
|
net.units = {
|
||||||
["b"] = 1,
|
["b"] = 1,
|
||||||
["kb"] = 1024,
|
["kb"] = 1024,
|
||||||
["mb"] = 1024^2,
|
["mb"] = 1024^2,
|
||||||
|
@ -52,12 +52,12 @@ function worker(args)
|
||||||
local args = args or {}
|
local args = args or {}
|
||||||
local iface = args.iface or net.get_device()
|
local iface = args.iface or net.get_device()
|
||||||
local delta = args.refresh_timeout or 2
|
local delta = args.refresh_timeout or 2
|
||||||
local unit = args.unit or unit["kb"]
|
local units = args.units or net.units["kb"]
|
||||||
local spr = args.spr or " "
|
local spr = args.spr or " "
|
||||||
local header = args.header or iface
|
local header = args.header or iface
|
||||||
local header_color = args.header_color or beautiful.fg_normal or "#FFFFFF"
|
local header_color = args.header_color or beautiful.fg_normal or "#FFFFFF"
|
||||||
local color_up = args.color_up or beautiful.fg_focus or header_color
|
local color_up = args.color_up or beautiful.fg_focus or "#FFFFFF"
|
||||||
local color_down = args.color_down or beautiful.fg_focus or header_color
|
local color_down = args.color_down or beautiful.fg_focus or "#FFFFFF"
|
||||||
local app = args.app or "sudo wifi-menu"
|
local app = args.app or "sudo wifi-menu"
|
||||||
|
|
||||||
helpers.set_map(iface, true)
|
helpers.set_map(iface, true)
|
||||||
|
@ -113,8 +113,8 @@ function worker(args)
|
||||||
|
|
||||||
if net.last_t[iface] and net.last_t[iface]
|
if net.last_t[iface] and net.last_t[iface]
|
||||||
then
|
then
|
||||||
net.send = tostring((now_t - net.last_t[iface]) / delta / unit)
|
net.send = tostring((now_t - net.last_t[iface]) / delta / units)
|
||||||
net.recv = tostring((now_r - net.last_r[iface]) / delta / unit)
|
net.recv = tostring((now_r - net.last_r[iface]) / delta / units)
|
||||||
|
|
||||||
text = text
|
text = text
|
||||||
.. '<span color="' .. color_up .. '">'
|
.. '<span color="' .. color_up .. '">'
|
||||||
|
|
|
@ -30,7 +30,7 @@ function worker(args)
|
||||||
local show_all = args.show_all or false
|
local show_all = args.show_all or false
|
||||||
local header = args.header or " Load "
|
local header = args.header or " Load "
|
||||||
local header_color = args.header_color or beautiful.fg_normal or "#FFFFFF"
|
local header_color = args.header_color or beautiful.fg_normal or "#FFFFFF"
|
||||||
local color = args.color or beautiful.fg_focus or header_color
|
local color = args.color or beautiful.fg_focus or "#FFFFFF"
|
||||||
local app = args.app or "top"
|
local app = args.app or "top"
|
||||||
|
|
||||||
local mysysload = wibox.widget.textbox()
|
local mysysload = wibox.widget.textbox()
|
||||||
|
|
Loading…
Reference in New Issue