Merge pull request #158 from teto/multiple_mail_accounts

[RFC] Display per backend unread emails
This commit is contained in:
enkore 2015-01-09 19:19:05 +01:00
commit 03dd6c276f
3 changed files with 27 additions and 5 deletions

1
.gitignore vendored
View File

@ -5,4 +5,5 @@ build/*
dist/*
*.egg-info/*
*~
.i3pystatus-*
ci-build

View File

@ -6,6 +6,11 @@ class Backend(SettingsBase):
"""Handles the details of checking for mail"""
unread = 0
settings = ("account", "Account name")
# required = ("account", )
account = "Default account"
"""Number of unread mails
You'll probably implement that as a property"""
@ -34,11 +39,15 @@ class Mail(IntervalModule):
color = "#ffffff"
color_unread = "#ff0000"
format = "{unread} new email"
format_plural = "{unread} new emails"
format_plural = "{account} : {current_unread}/{unread} new emails"
hide_if_null = True
email_client = None
on_leftclick = "open_client"
on_upscroll = ["scroll_backend", 1]
on_downscroll = ["scroll_backend", -1]
current_backend = 0
def init(self):
for backend in self.backends:
@ -48,8 +57,13 @@ class Mail(IntervalModule):
"""
Returns the sum of unread messages across all registered backends
"""
unread = sum(map(lambda backend: backend.unread, self.backends))
unread = 0
current_unread = 0
for id, backend in enumerate(self.backends):
temp = backend.unread
unread = unread + backend.unread
if id == self.current_backend:
current_unread = temp
if not unread:
color = self.color
@ -65,12 +79,17 @@ class Mail(IntervalModule):
if unread > 1:
format = self.format_plural
account_name = getattr(self.backends[self.current_backend], "account", "No name")
self.output = {
"full_text": format.format(unread=unread),
"full_text": format.format(unread=unread, current_unread=current_unread, account=account_name),
"urgent": urgent,
"color": color,
}
def scroll_backend(self, step):
self.current_backend = (self.current_backend + step) % len(self.backends)
def open_client(self):
if self.email_client:
retcode, _, stderr = run_through_shell(self.email_client)

View File

@ -18,9 +18,11 @@ class Notmuch(Backend):
settings = (
("db_path", "Path to the directory of your notmuch database"),
("query", "Same query notmuch would accept, by default 'tag:unread and tag:inbox'"),
)
db_path = None
query = "tag:unread and tag:inbox"
def init(self):
if not self.db_path:
@ -38,7 +40,7 @@ class Notmuch(Backend):
@property
def unread(self):
db = notmuch.Database(self.db_path)
result = notmuch.Query(db, "tag:unread and tag:inbox").count_messages()
result = notmuch.Query(db, self.query).count_messages()
db.close()
return result