From eb8a3d2f0ebd599b3b0103ce4793920035ce1cd9 Mon Sep 17 00:00:00 2001 From: alec Date: Tue, 7 Feb 2012 09:36:42 +0000 Subject: - Don;t show notofications for drafts/sent folders (#1488341) git-svn-id: https://svn.roundcube.net/trunk@5859 208e9e7b-5314-0410-a742-e7e81cd9613c --- plugins/newmail_notifier/newmail_notifier.php | 21 +++++++++++++++++++++ plugins/newmail_notifier/package.xml | 5 +++-- 2 files changed, 24 insertions(+), 2 deletions(-) (limited to 'plugins') diff --git a/plugins/newmail_notifier/newmail_notifier.php b/plugins/newmail_notifier/newmail_notifier.php index 742fce83d..bd61e3692 100644 --- a/plugins/newmail_notifier/newmail_notifier.php +++ b/plugins/newmail_notifier/newmail_notifier.php @@ -132,10 +132,31 @@ class newmail_notifier extends rcube_plugin */ function notify($args) { + // Already notified or non-automatic check if ($this->notified || !empty($_GET['_refresh'])) { return $args; } + // Get folders to skip checking for + if (empty($this->exceptions)) { + $this->delimiter = $this->rc->storage->get_hierarchy_delimiter(); + foreach (array('drafts_mbox', 'sent_mbox') as $folder) { + $folder = $this->rc->config->get($folder); + if (strlen($folder) && $folder != 'INBOX') { + $this->exceptions[] = $folder; + } + } + } + + $mbox = $args['mailbox']; + + // Skip exception (sent/drafts) folders (and their subfolders) + foreach ($this->exceptions as $folder) { + if (strpos($mbox.$this->delimiter, $folder.$this->delimiter) === 0) { + return $args; + } + } + $this->notified = true; // Load configuration diff --git a/plugins/newmail_notifier/package.xml b/plugins/newmail_notifier/package.xml index 5ec7dd8a8..d3de25fb3 100644 --- a/plugins/newmail_notifier/package.xml +++ b/plugins/newmail_notifier/package.xml @@ -19,9 +19,9 @@ alec@alec.pl yes - 2011-11-21 + 2012-02-07 - 0.3 + 0.4 0.3 @@ -52,6 +52,7 @@ + -- cgit v1.2.3