From 111f5098d532b4eba47f2a496ed02d2203077690 Mon Sep 17 00:00:00 2001 From: alecpl <alec@alec.pl> Date: Mon, 23 Apr 2012 03:13:29 -0400 Subject: [PATCH] - Implement set/get helper methods in rcube_message_header class --- plugins/subscriptions_option/subscriptions_option.php | 57 ++++++++++++++++++++++++++++++--------------------------- 1 files changed, 30 insertions(+), 27 deletions(-) diff --git a/plugins/subscriptions_option/subscriptions_option.php b/plugins/subscriptions_option/subscriptions_option.php index 488146a..28f8262 100644 --- a/plugins/subscriptions_option/subscriptions_option.php +++ b/plugins/subscriptions_option/subscriptions_option.php @@ -19,23 +19,23 @@ * 'dont_override' list and the global option has changed, don't expect * to see the change until the folder list cache is refreshed. * - * @version 1.0 + * @version @package_version@ * @author Ziba Scott */ class subscriptions_option extends rcube_plugin { public $task = 'mail|settings'; - + function init() { $this->add_texts('localization/', false); $dont_override = rcmail::get_instance()->config->get('dont_override', array()); if (!in_array('use_subscriptions', $dont_override)) { - $this->add_hook('user_preferences', array($this, 'settings_blocks')); - $this->add_hook('save_preferences', array($this, 'save_prefs')); + $this->add_hook('preferences_list', array($this, 'settings_blocks')); + $this->add_hook('preferences_save', array($this, 'save_prefs')); } - $this->add_hook('list_mailboxes', array($this, 'list_mailboxes')); - $this->add_hook('manage_folders', array($this, 'manage_folders')); + $this->add_hook('storage_folders', array($this, 'mailboxes_list')); + $this->add_hook('folders_list', array($this, 'folders_list')); } function settings_blocks($args) @@ -45,10 +45,10 @@ $field_id = 'rcmfd_use_subscriptions'; $checkbox = new html_checkbox(array('name' => '_use_subscriptions', 'id' => $field_id, 'value' => 1)); - $args['blocks']['main']['options'][] = array( - 'title' => html::label($field_id, Q($this->gettext('useimapsubscriptions'))), + $args['blocks']['main']['options']['use_subscriptions'] = array( + 'title' => html::label($field_id, Q($this->gettext('useimapsubscriptions'))), 'content' => $checkbox->show($use_subscriptions?1:0), - ); + ); } return $args; @@ -57,31 +57,34 @@ function save_prefs($args) { if ($args['section'] == 'server') { - $rcmail = rcmail::get_instance(); + $rcmail = rcmail::get_instance(); $use_subscriptions = $rcmail->config->get('use_subscriptions'); - $args['prefs']['use_subscriptions'] = isset($_POST['_use_subscriptions']) ? true : false; + $args['prefs']['use_subscriptions'] = isset($_POST['_use_subscriptions']) ? true : false; - // if the use_subscriptions preference changes, flush the folder cache - if (($use_subscriptions && !isset($_POST['_use_subscriptions'])) || - (!$use_subscriptions && isset($_POST['_use_subscriptions']))) { - $rcmail->imap_init(true); - $rcmail->imap->clear_cache('mailboxes'); - } - } - return $args; - } - - function list_mailboxes($args) - { - $rcmail = rcmail::get_instance(); - if (!$rcmail->config->get('use_subscriptions', true)) { - $args['folders'] = iil_C_ListMailboxes($rcmail->imap->conn, $rcmail->imap->mod_mailbox($args['root']), $args['filter']); + // if the use_subscriptions preference changes, flush the folder cache + if (($use_subscriptions && !isset($_POST['_use_subscriptions'])) || + (!$use_subscriptions && isset($_POST['_use_subscriptions']))) { + $storage = $rcmail->get_storage(); + $storage->clear_cache('mailboxes'); + } } return $args; } - function manage_folders($args) + function mailboxes_list($args) + { + $rcmail = rcmail::get_instance(); + if (!$rcmail->config->get('use_subscriptions', true)) { + $storage = $rcmail->get_storage(); + if ($storage->check_connection()) { + $args['folders'] = $storage->conn->listMailboxes($args['root'], $args['name']); + } + } + return $args; + } + + function folders_list($args) { $rcmail = rcmail::get_instance(); if (!$rcmail->config->get('use_subscriptions', true)) { -- Gitblit v1.9.1