diff options
author | thomascube <thomas@roundcube.net> | 2010-03-02 07:54:11 +0000 |
---|---|---|
committer | thomascube <thomas@roundcube.net> | 2010-03-02 07:54:11 +0000 |
commit | 5e9a5661011e64423e1978599c56d47f8b0cfa37 (patch) | |
tree | 9e3bbfb306473dd4fbf644d7f27c0966f80bb07e /program/steps/mail/check_recent.inc | |
parent | ff519ed8c259fa0b39ce47ccc728e62a97b9a911 (diff) |
Fix checking for new mail (#1485794)
Diffstat (limited to 'program/steps/mail/check_recent.inc')
-rw-r--r-- | program/steps/mail/check_recent.inc | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/program/steps/mail/check_recent.inc b/program/steps/mail/check_recent.inc index 753304018..4ae6ad2be 100644 --- a/program/steps/mail/check_recent.inc +++ b/program/steps/mail/check_recent.inc @@ -22,6 +22,17 @@ $a_mailboxes = $IMAP->list_mailboxes(); $check_all = (bool)$RCMAIL->config->get('check_all_folders'); +// check if unread count of INBOX changed and refresh message list if so +if (!empty($_GET['_refresh'])) { + $unread_count = $IMAP->messagecount('INBOX', 'UNSEEN', TRUE); + if ($unread_count > $_SESSION['unseen_count']['INBOX']) { + $OUTPUT->command('set_unread_count', 'INBOX', $unread_count, true); + $OUTPUT->command('list_mailbox', 'INBOX', 1); // let the client switch to INBOX and get the message list + $OUTPUT->send(); + } +} + +// check recent/unseen counts for all mailboxes foreach ($a_mailboxes as $mbox_name) { if ($mbox_name == $IMAP->get_mailbox_name()) { if ($recent_count = $IMAP->messagecount(NULL, 'RECENT', TRUE)) { |