From 2fe8d6bdebbaa160ee062b18e78fe7e77b430e00 Mon Sep 17 00:00:00 2001 From: thomascube <thomas@roundcube.net> Date: Wed, 06 Oct 2010 04:43:32 -0400 Subject: [PATCH] Copy localization updates for 0.4.2 release --- plugins/subscriptions_option/subscriptions_option.php | 56 ++++++++++++++++++++++++++++++++------------------------ 1 files changed, 32 insertions(+), 24 deletions(-) diff --git a/plugins/subscriptions_option/subscriptions_option.php b/plugins/subscriptions_option/subscriptions_option.php index ba7236c..d9c5ce7 100644 --- a/plugins/subscriptions_option/subscriptions_option.php +++ b/plugins/subscriptions_option/subscriptions_option.php @@ -11,7 +11,7 @@ * The user option can be hidden and set globally by adding 'use_subscriptions' * to the the 'dont_override' configure line: * $rcmail_config['dont_override'] = array('use_subscriptions'); - * and then set the global preference" + * and then set the global preference * $rcmail_config['use_subscriptions'] = true; // or false * * Roundcube caches folder lists. When a user changes this option or visits @@ -24,57 +24,65 @@ */ 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_table')); - $this->add_hook('save_preferences', array($this, 'save_prefs')); + if (!in_array('use_subscriptions', $dont_override)) { + $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('mailboxes_list', array($this, 'mailboxes_list')); + $this->add_hook('folders_list', array($this, 'folders_list')); } - function settings_table($args) + function settings_blocks($args) { if ($args['section'] == 'server') { $use_subscriptions = rcmail::get_instance()->config->get('use_subscriptions'); $field_id = 'rcmfd_use_subscriptions'; - $use_subscriptions = new html_checkbox(array('name' => '_use_subscriptions', 'id' => $field_id, 'value' => 1)); + $checkbox = new html_checkbox(array('name' => '_use_subscriptions', 'id' => $field_id, 'value' => 1)); - $args['table']->add('title', html::label($field_id, Q($this->gettext('useimapsubscriptions')))); - $args['table']->add(null, $use_subscriptions->show($use_subscriptions?1:0)); + $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; } - function save_prefs($args){ - $rcmail = rcmail::get_instance(); - $use_subscriptions = $rcmail->config->get('use_subscriptions'); + function save_prefs($args) + { + if ($args['section'] == 'server') { + $rcmail = rcmail::get_instance(); + $use_subscriptions = $rcmail->config->get('use_subscriptions'); - $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'); + $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_connect(); + $rcmail->imap->clear_cache('mailboxes'); } - + } return $args; } - function list_mailboxes($args){ + function mailboxes_list($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']); + $args['folders'] = $rcmail->imap->conn->listMailboxes($rcmail->imap->mod_mailbox($args['root']), $args['filter']); } return $args; } - function manage_folders($args){ + function folders_list($args) + { $rcmail = rcmail::get_instance(); if (!$rcmail->config->get('use_subscriptions', true)) { $args['table']->remove_column('subscribed'); -- Gitblit v1.9.1