diff options
author | Aleksander Machniak <alec@alec.pl> | 2012-05-23 12:56:20 +0200 |
---|---|---|
committer | Aleksander Machniak <alec@alec.pl> | 2012-05-23 12:56:20 +0200 |
commit | 85a6173879bb2486e394fb8e6b8a107a59167374 (patch) | |
tree | 2143181cdaa134e0fab1f9b7dc72bbd89e0d91b0 /plugins/hide_blockquote/hide_blockquote.php | |
parent | 70faa8e5558def0e035ec56fc4e9ca5b56aaa9ce (diff) |
hide_blockquote - a new plugin for hiding citation blocks
Diffstat (limited to 'plugins/hide_blockquote/hide_blockquote.php')
-rw-r--r-- | plugins/hide_blockquote/hide_blockquote.php | 82 |
1 files changed, 82 insertions, 0 deletions
diff --git a/plugins/hide_blockquote/hide_blockquote.php b/plugins/hide_blockquote/hide_blockquote.php new file mode 100644 index 000000000..ca0273a5d --- /dev/null +++ b/plugins/hide_blockquote/hide_blockquote.php @@ -0,0 +1,82 @@ +<?php + +/** + * Quotation block hidding + * + * Plugin that adds a possibility to hide long blocks of cited text in messages. + * + * Configuration: + * // Minimum number of citation lines. Longer citation blocks will be hidden. + * // 0 - no limit (no hidding). + * $rcmail_config['hide_blockquote_limit'] = 0; + * + * @version @package_version@ + * @license GNU GPLv3+ + * @author Aleksander Machniak <alec@alec.pl> + */ +class hide_blockquote extends rcube_plugin +{ + public $task = 'mail|settings'; + + function init() + { + $rcmail = rcmail::get_instance(); + + if ($rcmail->task == 'mail' + && ($rcmail->action == 'preview' || $rcmail->action == 'show') + && ($limit = $rcmail->config->get('hide_blockquote_limit')) + ) { + // include styles + $skin = $rcmail->config->get('skin'); + if (!file_exists($this->home."/skins/$skin/style.css")) { + $skin = 'default'; + } + $this->include_stylesheet("skins/$skin/style.css"); + + // Script and localization + $this->include_script('hide_blockquote.js'); + $this->add_texts('localization', true); + + // set env variable for client + $rcmail->output->set_env('blockquote_limit', $limit); + } + else if ($rcmail->task == 'settings') { + $dont_override = $rcmail->config->get('dont_override', array()); + if (!in_array('hide_blockquote_limit', $dont_override)) { + $this->add_hook('preferences_list', array($this, 'prefs_table')); + $this->add_hook('preferences_save', array($this, 'save_prefs')); + } + } + } + + function prefs_table($args) + { + if ($args['section'] != 'mailview') { + return $args; + } + + $this->add_texts('localization'); + + $rcmail = rcmail::get_instance(); + $limit = (int) $rcmail->config->get('hide_blockquote_limit'); + $field_id = 'hide_blockquote_limit'; + $input = new html_inputfield(array('name' => '_'.$field_id, 'id' => $field_id, 'size' => 5)); + + $args['blocks']['main']['options']['hide_blockquote_limit'] = array( + 'title' => $this->gettext('quotelimit'), + 'content' => $input->show($limit ? $limit : '') + ); + + return $args; + } + + function save_prefs($args) + { + if ($args['section'] == 'mailview') { + $args['prefs']['hide_blockquote_limit'] = (int) get_input_value('_hide_blockquote_limit', RCUBE_INPUT_POST); + } + + return $args; + } + +} |