2004-09-29 18:19:39 +00:00
|
|
|
<?php
|
2010-04-30 09:57:32 +00:00
|
|
|
|
|
|
|
// This file is part of Moodle - http://moodle.org/
|
|
|
|
//
|
|
|
|
// Moodle is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU General Public License as published by
|
|
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
|
|
// (at your option) any later version.
|
|
|
|
//
|
|
|
|
// Moodle is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
|
|
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
2006-08-22 22:04:06 +00:00
|
|
|
/**
|
2010-04-30 09:57:32 +00:00
|
|
|
* Displays help via AJAX call or in a new page
|
2006-08-22 22:04:06 +00:00
|
|
|
*
|
2010-04-30 09:57:32 +00:00
|
|
|
* Use {@link core_renderer::help_icon()} or {@link addHelpButton()} to display
|
|
|
|
* the help icon.
|
2006-08-22 22:04:06 +00:00
|
|
|
*
|
2010-04-30 09:57:32 +00:00
|
|
|
* @copyright 2002 onwards Martin Dougiamas
|
|
|
|
* @package core
|
|
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
2006-08-22 22:04:06 +00:00
|
|
|
*/
|
2010-04-10 09:10:08 +00:00
|
|
|
|
|
|
|
define('NO_MOODLE_COOKIES', true);
|
|
|
|
|
2010-04-30 09:57:32 +00:00
|
|
|
require_once(dirname(__FILE__) . '/config.php');
|
2006-08-22 22:04:06 +00:00
|
|
|
|
2010-04-30 09:57:32 +00:00
|
|
|
$identifier = required_param('identifier', PARAM_STRINGID);
|
2011-09-24 15:07:27 +02:00
|
|
|
$component = required_param('component', PARAM_COMPONENT);
|
2010-07-28 10:57:48 +00:00
|
|
|
$lang = required_param('lang', PARAM_LANG); // TODO: maybe split into separate scripts
|
2010-04-13 21:51:49 +00:00
|
|
|
$ajax = optional_param('ajax', 0, PARAM_BOOL);
|
2010-04-10 09:10:08 +00:00
|
|
|
|
|
|
|
if (!$lang) {
|
|
|
|
$lang = 'en';
|
|
|
|
}
|
|
|
|
$SESSION->lang = $lang; // does not actually modify session because we do not use cookies here
|
2010-04-10 07:24:56 +00:00
|
|
|
|
2010-04-13 21:51:49 +00:00
|
|
|
$sm = get_string_manager();
|
2006-08-22 22:04:06 +00:00
|
|
|
|
2010-04-13 21:51:49 +00:00
|
|
|
$PAGE->set_url('/help.php');
|
2010-04-23 07:46:35 +00:00
|
|
|
$PAGE->set_pagelayout('popup');
|
2012-08-02 11:20:48 +08:00
|
|
|
$PAGE->set_context(context_system::instance());
|
2010-04-13 21:51:49 +00:00
|
|
|
|
|
|
|
if ($ajax) {
|
|
|
|
@header('Content-Type: text/plain; charset=utf-8');
|
2010-04-10 09:10:08 +00:00
|
|
|
}
|
2006-08-22 22:12:17 +00:00
|
|
|
|
2010-06-28 14:37:15 +00:00
|
|
|
if (!$sm->string_exists($identifier.'_help', $component)) {
|
2012-10-10 11:03:00 +01:00
|
|
|
// strings on disk-cache may be dirty - try to rebuild it and check again
|
2010-06-28 14:37:15 +00:00
|
|
|
$sm->load_component_strings($component, current_language(), true);
|
|
|
|
}
|
|
|
|
|
2012-10-10 11:03:00 +01:00
|
|
|
$data = new stdClass();
|
|
|
|
|
2010-04-23 07:46:35 +00:00
|
|
|
if ($sm->string_exists($identifier.'_help', $component)) {
|
2010-09-21 08:44:02 +00:00
|
|
|
$options = new stdClass();
|
2010-04-23 07:46:35 +00:00
|
|
|
$options->trusted = false;
|
|
|
|
$options->noclean = false;
|
|
|
|
$options->smiley = false;
|
|
|
|
$options->filter = false;
|
|
|
|
$options->para = true;
|
|
|
|
$options->newlines = false;
|
2010-11-05 02:53:47 +00:00
|
|
|
$options->overflowdiv = !$ajax;
|
2010-04-23 07:46:35 +00:00
|
|
|
|
2012-10-10 11:03:00 +01:00
|
|
|
$data->heading = format_string(get_string($identifier, $component));
|
2010-04-23 07:46:35 +00:00
|
|
|
// Should be simple wiki only MDL-21695
|
2012-10-10 11:03:00 +01:00
|
|
|
$data->text = format_text(get_string($identifier.'_help', $component), FORMAT_MARKDOWN, $options);
|
2010-04-23 07:46:35 +00:00
|
|
|
|
2012-10-10 11:03:00 +01:00
|
|
|
$helplink = $identifier . '_link';
|
|
|
|
if ($sm->string_exists($helplink, $component)) { // Link to further info in Moodle docs
|
|
|
|
$link = get_string($helplink, $component);
|
2010-04-23 07:46:35 +00:00
|
|
|
$linktext = get_string('morehelp');
|
|
|
|
|
2012-10-10 11:03:00 +01:00
|
|
|
$data->doclink = new stdClass();
|
|
|
|
$url = new moodle_url(get_docs_url($link));
|
|
|
|
$data->doclink->link = $url->out();
|
|
|
|
$data->doclink->linktext = $linktext;
|
|
|
|
$data->doclink->class = ($CFG->doctonewwindow) ? 'helplinkpopup' : '';
|
|
|
|
|
|
|
|
$completedoclink = html_writer::tag('div', $OUTPUT->doc_link($link, $linktext), array('class' => 'helpdoclink'));
|
|
|
|
}
|
2010-04-13 21:51:49 +00:00
|
|
|
} else {
|
2012-10-10 11:03:00 +01:00
|
|
|
$data->text = html_writer::tag('p',
|
|
|
|
html_writer::tag('strong', 'TODO') . ": missing help string [{$identifier}_help, {$component}]");
|
2010-04-13 21:51:49 +00:00
|
|
|
}
|
|
|
|
|
2012-10-10 11:03:00 +01:00
|
|
|
if ($ajax) {
|
|
|
|
echo json_encode($data);
|
|
|
|
} else {
|
|
|
|
echo $OUTPUT->header();
|
|
|
|
if (isset($data->heading)) {
|
|
|
|
echo $OUTPUT->heading($data->heading, 1, 'helpheading');
|
|
|
|
}
|
|
|
|
echo $data->text;
|
|
|
|
if (isset($completedoclink)) {
|
|
|
|
echo $completedoclink;
|
|
|
|
}
|
2010-04-13 21:51:49 +00:00
|
|
|
echo $OUTPUT->footer();
|
|
|
|
}
|