X-Git-Url: https://git.madduck.net/etc/awesome.git/blobdiff_plain/8d3868d7ce528cfc075e246c8935bae2724e0868..f76d33e8cd5bc84f44758e8047294227deb3f29d:/widget/imap.lua diff --git a/widget/imap.lua b/widget/imap.lua index 1049d03..7e83d36 100644 --- a/widget/imap.lua +++ b/widget/imap.lua @@ -1,24 +1,22 @@ - --[[ - - Licensed under GNU General Public License v2 - * (c) 2013, Luke Bonham - + + Licensed under GNU General Public License v2 + * (c) 2013, Luca CPZ + --]] -local helpers = require("lain.helpers") -local naughty = require("naughty") -local wibox = require("wibox") -local string = { format = string.format, - gsub = string.gsub } -local type = type -local tonumber = tonumber -local setmetatable = setmetatable +local helpers = require("lain.helpers") +local naughty = require("naughty") +local wibox = require("wibox") +local awful = require("awful") +local string = string +local type = type +local tonumber = tonumber -- Mail IMAP check -- lain.widget.imap -local function worker(args) +local function factory(args) local imap = { widget = wibox.widget.textbox() } local args = args or {} local server = args.server @@ -28,6 +26,7 @@ local function worker(args) local timeout = args.timeout or 60 local is_plain = args.is_plain or false local followtag = args.followtag or false + local notify = args.notify or "on" local settings = args.settings or function() end local head_command = "curl --connect-timeout 3 -fsm 3" @@ -55,23 +54,18 @@ local function worker(args) mail_notification_preset.screen = awful.screen.focused() end - curl = string.format("%s --url imaps://%s:%s/INBOX -u %s:%q %s -k", - head_command, server, port, mail, password, request) + local curl = string.format("%s --url imaps://%s:%s/INBOX -u %s:%q %s -k", + head_command, server, port, mail, password, request) helpers.async(curl, function(f) - _, mailcount = string.gsub(f, "%d+", "") - _ = nil - + mailcount = tonumber(f:match("UNSEEN (%d+)")) widget = imap.widget settings() - if mailcount >= 1 and mailcount > helpers.get_map(mail) then - if mailcount == 1 then - nt = mail .. " has one new message" - else - nt = mail .. " has " .. mailcount .. " new messages" - end - naughty.notify({ preset = mail_notification_preset, text = nt }) + if notify == "on" and mailcount and mailcount >= 1 and mailcount > helpers.get_map(mail) then + local nt = mail .. " has " .. mailcount .. " new message" + if mailcount >= 1 then nt = nt .. "s" end + naughty.notify { preset = mail_notification_preset, text = nt } end helpers.set_map(mail, mailcount) @@ -84,4 +78,4 @@ local function worker(args) return imap end -return setmetatable({}, { __call = function(_, ...) return worker(...) end }) +return factory