Permalink
Browse files

Merge branch 'wip-MDL-32018-m22' of git://github.com/samhemelryk/mood…

…le into MOODLE_22_STABLE
  • Loading branch information...
2 parents d0f6d61 + 4b023f2 commit 8c6bc1e000ab347593290b6776ef61e0cab25ced @stronk7 stronk7 committed Apr 3, 2012
@@ -7,9 +7,8 @@
require_once($CFG->dirroot . '/lib/formslib.php');
class mod_wiki_comments_form extends moodleform {
- function definition() {
- $pageid = optional_param('pageid', 0, PARAM_INT);
- $mform =& $this->_form;
+ protected function definition() {
+ $mform = $this->_form;
$current = $this->_customdata['current'];
$commentoptions = $this->_customdata['commentoptions'];
@@ -24,7 +23,7 @@ function definition() {
$mform->setType('id', PARAM_INT);
$mform->addElement('hidden', 'action', '');
- $mform->setType('action', PARAM_ACTION);
+ $mform->setType('action', PARAM_ALPHAEXT);
//-------------------------------------------------------------------------------
// buttons
View
@@ -28,7 +28,7 @@
// page editing page.
$action = optional_param('action', 'new', PARAM_TEXT);
// The title of the new page, can be empty
-$title = optional_param('title', '', PARAM_TEXT);
+$title = optional_param('title', get_string('newpage', 'wiki'), PARAM_TEXT);
$wid = optional_param('wid', 0, PARAM_INT);
$swid = optional_param('swid', 0, PARAM_INT);
$gid = optional_param('gid', 0, PARAM_INT);
@@ -78,9 +78,6 @@
$wikipage->set_uid($uid);
}
-if (empty($title)) {
- $title = get_string('newpage', 'wiki');
-}
$wikipage->set_title($title);
// set page action, and initialise moodle form
View
@@ -29,8 +29,7 @@
class mod_wiki_create_form extends moodleform {
protected function definition() {
- global $CFG;
- $mform =& $this->_form;
+ $mform = $this->_form;
$formats = $this->_customdata['formats'];
$defaultformat = $this->_customdata['defaultformat'];
@@ -43,6 +42,8 @@ protected function definition() {
$textoptions = array('readonly'=>'readonly');
}
$mform->addElement('text', 'pagetitle', get_string('newpagetitle', 'wiki'), $textoptions);
+ $mform->setType('pagetitle', PARAM_TEXT);
+ $mform->addRule('pagetitle', get_string('required'), 'required', null, 'client');
if ($forceformat) {
$mform->addElement('hidden', 'pageformat', $defaultformat);
@@ -60,10 +61,12 @@ protected function definition() {
$mform->addElement('radio', 'pageformat', '', get_string('format'.$format, 'wiki'), $format, $attr);
}
}
+ $mform->setType('pageformat', PARAM_ALPHANUMEXT);
+ $mform->addRule('pageformat', get_string('required'), 'required', null, 'client');
//hiddens
- $mform->addElement('hidden', 'action');
- $mform->setDefault('action', 'create');
+ $mform->addElement('hidden', 'action', 'create');
+ $mform->setType('action', PARAM_ALPHA);
$this->add_action_buttons(false, get_string('createpage', 'wiki'));
}
View
@@ -38,20 +38,26 @@ class mod_wiki_edit_form extends moodleform {
protected function definition() {
global $CFG;
- $mform =& $this->_form;
+ $mform = $this->_form;
$version = $this->_customdata['version'];
- $format = $this->_customdata['format'];
- $tags = !isset($this->_customdata['tags'])?"":$this->_customdata['tags'];
-
- if ($format != 'html') {
- $contextid = $this->_customdata['contextid'];
- $filearea = $this->_customdata['filearea'];
- $fileitemid = $this->_customdata['fileitemid'];
+ $format = $this->_customdata['format'];
+ $pagetitle = $this->_customdata['pagetitle'];
+
+ if (empty($this->_customdata['contextid'])) {
+ // Hack alert
+ // This is being done ONLY to aid those who may have created there own wiki pages. It should be removed sometime
+ // after the release of 2.3 (not creating an issue because this whole thing should be reviewed)
+ debugging('You must always provide mod_wiki_edit_form with a contextid in its custom data', DEBUG_DEVELOPER);
+ global $PAGE;
+ $contextid = $PAGE->context->id;
+ } else {
+ $contextid = $this->_customdata['contextid'];
}
if (isset($this->_customdata['pagetitle'])) {
- $pagetitle = get_string('editingpage', 'wiki', $this->_customdata['pagetitle']);
+ // Page title must be formatted properly here as this is output and not an element.
+ $pagetitle = get_string('editingpage', 'wiki', format_string($pagetitle, true, array('context' => get_context_instance_by_id($contextid, MUST_EXIST))));
} else {
$pagetitle = get_string('editing', 'wiki');
}
@@ -65,7 +71,7 @@ protected function definition() {
$ft = new filetype_parser;
$extensions = $ft->get_extensions('image');
$fs = get_file_storage();
- $tree = $fs->get_area_tree($contextid, 'mod_wiki', 'attachments', $fileitemid);
+ $tree = $fs->get_area_tree($contextid, 'mod_wiki', $this->_customdata['filearea'], $this->_customdata['fileitemid']);
$files = array();
foreach ($tree['files'] as $file) {
$filename = $file->get_filename();
@@ -77,30 +83,34 @@ protected function definition() {
}
$mform->addElement('wikieditor', 'newcontent', $fieldname, array('cols' => 100, 'rows' => 20, 'wiki_format' => $format, 'files'=>$files));
$mform->addHelpButton('newcontent', 'format'.$format, 'wiki');
+ $mform->setType('newcontent', PARAM_RAW); // processed by trust text or cleaned before the display
} else {
$mform->addElement('editor', 'newcontent_editor', $fieldname, null, page_wiki_edit::$attachmentoptions);
$mform->addHelpButton('newcontent_editor', 'formathtml', 'wiki');
+ $mform->setType('newcontent_editor', PARAM_RAW); // processed by trust text or cleaned before the display
}
//hiddens
if ($version >= 0) {
- $mform->addElement('hidden', 'version');
- $mform->setDefault('version', $version);
+ $mform->addElement('hidden', 'version', $version);
+ $mform->setType('version', PARAM_FLOAT);
}
- $mform->addElement('hidden', 'contentformat');
- $mform->setDefault('contentformat', $format);
+ $mform->addElement('hidden', 'contentformat', $format);
+ $mform->setType('contentformat', PARAM_ALPHANUMEXT);
if (!empty($CFG->usetags)) {
+ $tags = !isset($this->_customdata['tags'])?"":$this->_customdata['tags'];
$mform->addElement('header', 'tagshdr', get_string('tags', 'tag'));
$mform->addElement('tags', 'tags', get_string('tags'));
$mform->setDefault('tags', $tags);
+ $mform->setType('tags', PARAM_TEXT);
}
$buttongroup = array();
- $buttongroup[] =& $mform->createElement('submit', 'editoption', get_string('save', 'wiki'), array('id' => 'save'));
- $buttongroup[] =& $mform->createElement('submit', 'editoption', get_string('preview'), array('id' => 'preview'));
- $buttongroup[] =& $mform->createElement('submit', 'editoption', get_string('cancel'), array('id' => 'cancel'));
+ $buttongroup[] = $mform->createElement('submit', 'editoption', get_string('save', 'wiki'), array('id' => 'save'));
+ $buttongroup[] = $mform->createElement('submit', 'editoption', get_string('preview'), array('id' => 'preview'));
+ $buttongroup[] = $mform->createElement('submit', 'editoption', get_string('cancel'), array('id' => 'cancel'));
$mform->addGroup($buttongroup, 'buttonar', '', array(' '), false);
$mform->closeHeaderBefore('buttonar');
@@ -27,15 +27,19 @@
require_once("$CFG->libdir/formslib.php");
class mod_wiki_filesedit_form extends moodleform {
- function definition() {
+ protected function definition() {
$mform = $this->_form;
$data = $this->_customdata['data'];
$options = $this->_customdata['options'];
$mform->addElement('filemanager', 'files_filemanager', get_string('files'), null, $options);
+
$mform->addElement('hidden', 'returnurl', $data->returnurl);
+ $mform->setType('returnurl', PARAM_URL);
+
$mform->addElement('hidden', 'subwiki', $data->subwikiid);
+ $mform->setType('subwiki', PARAM_INT);
$this->add_action_buttons(true, get_string('savechanges'));
View
@@ -320,7 +320,7 @@ function wiki_refresh_page_links($page, $links) {
* @param int $userid
*/
function wiki_create_page($swid, $title, $format, $userid) {
- global $DB, $PAGE;
+ global $DB;
$subwiki = wiki_get_subwiki($swid);
$cm = get_coursemodule_from_instance('wiki', $subwiki->wikiid);
$context = get_context_instance(CONTEXT_MODULE, $cm->id);
@@ -605,10 +605,12 @@ function wiki_parse_content($markup, $pagecontent, $options = array()) {
*
* NOTE: Empty pages and non-existent pages must be print in red color.
*
- * @param link name of a page
- * @param $options
+ * !!!!!! IMPORTANT !!!!!!
+ * It is critical that you call format_string on the content before it is used.
*
- * @return
+ * @param string|page_wiki $link name of a page
+ * @param array $options
+ * @return array Array('content' => string, 'url' => string, 'new' => bool, 'link_info' => array)
*
* @TODO Doc return and options
*/
@@ -1394,9 +1396,9 @@ function wiki_print_upload_table($context, $filearea, $fileitemid, $deleteupload
/**
* Generate wiki's page tree
*
- * @param $page. A wiki page object
- * @param $node. Starting navigation_node
- * @param $keys. An array to store keys
+ * @param page_wiki $page. A wiki page object
+ * @param navigation_node $node. Starting navigation_node
+ * @param array $keys. An array to store keys
* @return an array with all tree nodes
*/
function wiki_build_tree($page, $node, &$keys) {
@@ -1412,6 +1414,7 @@ function wiki_build_tree($page, $node, &$keys) {
array_push($keys, $key);
$l = wiki_parser_link($p);
$link = new moodle_url('/mod/wiki/view.php', array('pageid' => $p->id));
+ // navigation_node::get_content will format the title for us
$nodeaux = $node->add($p->title, $link, null, null, null, $icon);
if ($l['new']) {
$nodeaux->add_class('wiki_newentry');
View
@@ -41,28 +41,24 @@
class mod_wiki_mod_form extends moodleform_mod {
- function definition() {
-
- global $COURSE;
- $mform =& $this->_form;
+ protected function definition() {
+ $mform = $this->_form;
+ $required = get_string('required');
//-------------------------------------------------------------------------------
- /// Adding the "general" fieldset, where all the common settings are showed
+ // Adding the "general" fieldset, where all the common settings are showed
$mform->addElement('header', 'general', get_string('general', 'form'));
- /// Adding the standard "name" field
+
+ // Adding the standard "name" field
$mform->addElement('text', 'name', get_string('wikiname', 'wiki'), array('size' => '64'));
$mform->setType('name', PARAM_TEXT);
- $mform->addRule('name', null, 'required', null, 'client');
- /// Adding the optional "intro" and "introformat" pair of fields
- // $mform->addElement('htmleditor', 'intro', get_string('wikiintro', 'wiki'));
- // $mform->setType('intro', PARAM_RAW);
- // $mform->addRule('intro', get_string('required'), 'required', null, 'client');
- //
- // $mform->addElement('format', 'introformat', get_string('format'));
+ $mform->addRule('name', $required, 'required', null, 'client');
+ // Adding the optional "intro" and "introformat" pair of fields
$this->add_intro_editor(true, get_string('wikiintro', 'wiki'));
+
//-------------------------------------------------------------------------------
- /// Adding the rest of wiki settings, spreeading all them into this fieldset
- /// or adding more fieldsets ('header' elements) if needed for better logic
+ // Adding the rest of wiki settings, spreeading all them into this fieldset
+ // or adding more fieldsets ('header' elements) if needed for better logic
$mform->addElement('header', 'wikifieldset', get_string('wikisettings', 'wiki'));
@@ -75,9 +71,9 @@ function definition() {
$mform->addElement('text', 'firstpagetitle', get_string('firstpagetitle', 'wiki'), $attr);
$mform->addHelpButton('firstpagetitle', 'firstpagetitle', 'wiki');
-
+ $mform->setType('firstpagetitle', PARAM_TEXT);
if (empty($this->_instance)) {
- $mform->addRule('firstpagetitle', null, 'required', null, 'client');
+ $mform->addRule('firstpagetitle', $required, 'required', null, 'client');
}
$wikimodeoptions = array ('collaborative' => get_string('wikimodecollaborative', 'wiki'), 'individual' => get_string('wikimodeindividual', 'wiki'));
@@ -96,6 +92,7 @@ function definition() {
}
$mform->addElement('select', 'defaultformat', get_string('defaultformat', 'wiki'), $editoroptions);
$mform->addHelpButton('defaultformat', 'defaultformat', 'wiki');
+
$mform->addElement('checkbox', 'forceformat', get_string('forceformat', 'wiki'));
$mform->addHelpButton('forceformat', 'forceformat', 'wiki');
Oops, something went wrong.

0 comments on commit 8c6bc1e

Please sign in to comment.