diff options
Diffstat (limited to 'plugins/help/help.php')
| -rw-r--r-- | plugins/help/help.php | 69 | 
1 files changed, 12 insertions, 57 deletions
| diff --git a/plugins/help/help.php b/plugins/help/help.php index 37fd908a3..4b11dceb3 100644 --- a/plugins/help/help.php +++ b/plugins/help/help.php @@ -1,10 +1,9 @@  <?php  /** - * Roundcube Help Plugin + * Help Plugin   *   * @author Aleksander 'A.L.E.C' Machniak - * @author Thomas Bruederli <thomas@roundcube.net>   * @license GNU GPLv3+   *   * Configuration (see config.inc.php.dist) @@ -22,7 +21,8 @@ class help extends rcube_plugin      function init()      { -        $this->load_config(); +        $rcmail = rcmail::get_instance(); +          $this->add_texts('localization/', false);          // register task @@ -33,8 +33,6 @@ class help extends rcube_plugin          $this->register_action('about', array($this, 'action'));          $this->register_action('license', array($this, 'action')); -        $rcmail = rcmail::get_instance(); -          // add taskbar button          $this->add_button(array(              'command'    => 'help', @@ -44,9 +42,6 @@ class help extends rcube_plugin              'label'      => 'help.help',          ), 'taskbar'); -        $this->include_script('help.js'); -        $rcmail->output->set_env('help_open_extwin', $rcmail->config->get('help_open_extwin', false), true); -          // add style for taskbar button (must be here) and Help UI          $skin_path = $this->local_skin_path();          if (is_file($this->home . "/$skin_path/help.css")) { @@ -58,10 +53,11 @@ class help extends rcube_plugin      {          $rcmail = rcmail::get_instance(); +        $this->load_config(); +          // register UI objects          $rcmail->output->add_handlers(array(              'helpcontent' => array($this, 'content'), -            'tablink' => array($this, 'tablink'),          ));          if ($rcmail->action == 'about') @@ -74,52 +70,20 @@ class help extends rcube_plugin          $rcmail->output->send('help.help');      } -    function tablink($attrib) -    { -        $rcmail = rcmail::get_instance(); -        $attrib['name'] = 'helplink' . $attrib['action']; -        $attrib['href'] = $rcmail->url(array('_action' => $attrib['action'], '_extwin' => !empty($_REQUEST['_extwin']) ? 1 : null)); -        return $rcmail->output->button($attrib); -    } -      function content($attrib)      {          $rcmail = rcmail::get_instance(); -        switch ($rcmail->action) { -            case 'about': -                if (is_readable($this->home . '/content/about.html')) { -                    return @file_get_contents($this->home . '/content/about.html'); -                } -                $default = $rcmail->url(array('_task' => 'settings', '_action' => 'about', '_framed' => 1)); -                $src     = $rcmail->config->get('help_about_url', $default); -                break; - -            case 'license': -                if (is_readable($this->home . '/content/license.html')) { -                    return @file_get_contents($this->home . '/content/license.html'); -                } -                $src = $rcmail->config->get('help_license_url', 'http://www.gnu.org/licenses/gpl-3.0-standalone.html'); -                break; - -            default: -                $src = $rcmail->config->get('help_source'); - -                // resolve task/action for depp linking -                $index_map = $rcmail->config->get('help_index_map', array()); -                $rel = $_REQUEST['_rel']; -                list($task,$action) = explode('/', $rel); -                if ($add = $index_map[$rel]) -                    $src .= $add; -                else if ($add = $index_map[$task]) -                    $src .= $add; -                break; +        if ($rcmail->action == 'about') { +            return @file_get_contents($this->home.'/content/about.html'); +        } +        else if ($rcmail->action == 'license') { +            return @file_get_contents($this->home.'/content/license.html');          }          // default content: iframe -        if (!empty($src)) { -            $attrib['src'] = $this->resolve_language($src); -        } +        if ($src = $rcmail->config->get('help_source')) +            $attrib['src'] = $src;          if (empty($attrib['id']))              $attrib['id'] = 'rcmailhelpcontent'; @@ -129,13 +93,4 @@ class help extends rcube_plugin          return $rcmail->output->frame($attrib);      } - -    private function resolve_language($path) -    { -        // resolve language placeholder -        $rcmail = rcmail::get_instance(); -        $langmap = $rcmail->config->get('help_language_map', array('*' => 'en_US')); -        $lang = !empty($langmap[$_SESSION['language']]) ? $langmap[$_SESSION['language']] : $langmap['*']; -        return str_replace('%l', $lang, $path); -    }  } | 
