mirror of
https://github.com/moodle/moodle.git
synced 2025-02-18 23:05:30 +01:00
* Added MoodleQuickForm method closeHeaderBefore($elementName); http://docs.moodle.org/en/Development:lib/formslib.php_Form_Definition#Use_Fieldsets_to_group_Form_Elements * Added moodleform method add_action_buttons(); see http://docs.moodle.org/en/Development:lib/formslib.php_Form_Definition#add_action_buttons.28.24cancel_.3D_true.2C_.24revert_.3D_true.2C_.24submitlabel.3Dnull.29.3B * is_cancelled method added to moodleform http://docs.moodle.org/en/Development:lib/formslib.php_Usage#Basic_Usage_in_A_Normal_Page * added hidden labels to elements within groups such as the date_selector select boxes and other elements in 'groups' * quiz/mod.html migrated to formslib * glossary/edit.html migrated to formslib * extended registerNoSubmitButton() functionality to automatically add js to onclick to bypass client side js input validation. * added no_submit_button_pressed() function that can be used in a similar way to is_cancelled() as a test in the main script to see if some button in the page has been pressed that is a submit button that is used for some dynamic functionality within the form and not to submit the data for the whole form. * added new condition for disabledIf which allows to disable another form element if no options are selected from within a select element. * added default 'action' for moodleform - strip_querystring(qualified_me()) http://docs.moodle.org/en/Development:lib/formslib.php_Usage#Basic_Usage_in_A_Normal_Page
228 lines
7.5 KiB
PHP
228 lines
7.5 KiB
PHP
<?php // $Id$
|
|
|
|
require_once('../../config.php');
|
|
require_once('lib.php');
|
|
require_once('edit_form.php');
|
|
|
|
global $CFG, $USER;
|
|
|
|
$id = required_param('id', PARAM_INT); // Course Module ID
|
|
$e = optional_param('e', 0, PARAM_INT); // EntryID
|
|
$confirm = optional_param('confirm',0, PARAM_INT); // proceed. Edit the edtry
|
|
|
|
$mode = optional_param('mode', '', PARAM_ALPHA); // categories if by category?
|
|
$hook = optional_param('hook', '', PARAM_ALPHANUM); // CategoryID
|
|
|
|
if (! $cm = get_coursemodule_from_id('glossary', $id)) {
|
|
error("Course Module ID was incorrect");
|
|
}
|
|
|
|
$context = get_context_instance(CONTEXT_MODULE, $cm->id);
|
|
|
|
if (! $course = get_record("course", "id", $cm->course)) {
|
|
error("Course is misconfigured");
|
|
}
|
|
|
|
require_login($course->id, false, $cm);
|
|
|
|
if ( isguest() ) {
|
|
error("Guests are not allowed to edit glossaries", $_SERVER["HTTP_REFERER"]);
|
|
}
|
|
|
|
if (! $glossary = get_record("glossary", "id", $cm->instance)) {
|
|
error("Course module is incorrect");
|
|
}
|
|
|
|
if ($e) { // if entry is specified
|
|
require_capability('mod/glossary:manageentries', $context);
|
|
} else { // new entry
|
|
require_capability('mod/glossary:write', $context);
|
|
}
|
|
|
|
$mform =& new glossary_entry_form(null, compact('cm', 'glossary', 'hook', 'mode', 'e', 'context'));
|
|
if ($mform->is_cancelled()){
|
|
if ($e){
|
|
redirect("view.php?id=$cm->id&mode=entry&hook=$e");
|
|
} else {
|
|
redirect("view.php?id=$cm->id");
|
|
}
|
|
|
|
} elseif ($fromform = $mform->data_submitted()) {
|
|
trusttext_after_edit($fromform->definition, $context);
|
|
|
|
if ( !isset($fromform->usedynalink) ) {
|
|
$fromform->usedynalink = 0;
|
|
}
|
|
if ( !isset($fromform->casesensitive) ) {
|
|
$fromform->casesensitive = 0;
|
|
}
|
|
if ( !isset($fromform->fullmatch) ) {
|
|
$fromform->fullmatch = 0;
|
|
}
|
|
$timenow = time();
|
|
|
|
$todb = new object();
|
|
$todb->course = $glossary->course;
|
|
$todb->glossaryid = $glossary->id;
|
|
|
|
$todb->concept = trim($fromform->concept);
|
|
$todb->definition = $fromform->definition;
|
|
$todb->format = $fromform->format;
|
|
$todb->usedynalink = $fromform->usedynalink;
|
|
$todb->casesensitive = $fromform->casesensitive;
|
|
$todb->fullmatch = $fromform->fullmatch;
|
|
$todb->timemodified = $timenow;
|
|
$todb->approved = 0;
|
|
$todb->aliases = "";
|
|
if ( $glossary->defaultapproval or has_capability('mod/glossary:approve', $context) ) {
|
|
$todb->approved = 1;
|
|
}
|
|
|
|
if ($e) {
|
|
/* TODO process file uploads
|
|
$todb->attachment = $_FILES["attachment"];
|
|
if ($newfilename = glossary_add_attachment($todb, 'attachment')) {
|
|
$todb->attachment = $newfilename;
|
|
} else {
|
|
unset($todb->attachment);
|
|
}*/
|
|
$todb->id = $e;
|
|
print_object($todb);
|
|
if (update_record('glossary_entries', $todb)) {
|
|
add_to_log($course->id, "glossary", "update entry",
|
|
"view.php?id=$cm->id&mode=entry&hook=$todb->id",
|
|
$todb->id, $cm->id);
|
|
} else {
|
|
error("Could not update your glossary");
|
|
}
|
|
} else {
|
|
|
|
$todb->userid = $USER->id;
|
|
$todb->timecreated = $timenow;
|
|
$todb->sourceglossaryid = 0;
|
|
$todb->teacherentry = has_capability('mod/glossary:manageentries', $context);
|
|
|
|
|
|
if ($todb->id = insert_record("glossary_entries", $todb)) {
|
|
$e = $todb->id;
|
|
/* TODO process file uploads
|
|
$todb->attachment = $_FILES["attachment"];
|
|
if ($newfilename = glossary_add_attachment($todb, 'attachment')) {
|
|
$todb->attachment = $newfilename;
|
|
} else {
|
|
unset($todb->attachment);
|
|
}
|
|
set_field("glossary_entries", "attachment", $newfilename, "id", $todb->id);*/
|
|
add_to_log($course->id, "glossary", "add entry",
|
|
"view.php?id=$cm->id&mode=entry&hook=$todb->id", $todb->id,$cm->id);
|
|
} else {
|
|
error("Could not insert this new entry");
|
|
}
|
|
|
|
}
|
|
|
|
delete_records("glossary_entries_categories", "entryid", $e);
|
|
delete_records("glossary_alias", "entryid", $e);
|
|
|
|
if (empty($fromform->notcategorised) && isset($fromform->categories)) {
|
|
$newcategory->entryid = $e;
|
|
foreach ($fromform->categories as $category) {
|
|
if ( $category > 0 ) {
|
|
$newcategory->categoryid = $category;
|
|
insert_record("glossary_entries_categories", $newcategory, false);
|
|
} else {
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
if ( isset($fromform->aliases) ) {
|
|
if ( $aliases = explode("\n", $fromform->aliases) ) {
|
|
foreach ($aliases as $alias) {
|
|
$alias = trim($alias);
|
|
if ($alias) {
|
|
unset($newalias);
|
|
$newalias->entryid = $e;
|
|
$newalias->alias = $alias;
|
|
insert_record("glossary_alias", $newalias, false);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
redirect("view.php?id=$cm->id&mode=entry&hook=$todb->id");
|
|
|
|
} else {
|
|
if ($e) {
|
|
$fromdb = get_record("glossary_entries", "id", $e);
|
|
|
|
$toform = new object();
|
|
|
|
if ($categoriesarr = get_records_menu("glossary_entries_categories", "entryid", $e, '', 'id, categoryid')){
|
|
$toform->categories = array_values($categoriesarr);
|
|
} else {
|
|
$toform->categories = array(0);
|
|
}
|
|
$toform->concept = $fromdb->concept;
|
|
$toform->definition = $fromdb->definition;
|
|
$toform->format = $fromdb->format;
|
|
trusttext_prepare_edit($toform->definition, $toform->format, can_use_html_editor(), $context);
|
|
$toform->approved = $glossary->defaultapproval or has_capability('mod/glossary:approve', $context);
|
|
$toform->usedynalink = $fromdb->usedynalink;
|
|
$toform->casesensitive = $fromdb->casesensitive;
|
|
$toform->fullmatch = $fromdb->fullmatch;
|
|
$toform->aliases = '';
|
|
$ineditperiod = ((time() - $fromdb->timecreated < $CFG->maxeditingtime) || $glossary->editalways);
|
|
if ((!$ineditperiod || $USER->id != $fromdb->userid) and !has_capability('mod/glossary:manageentries', $context)) {
|
|
if ( $USER->id != $fromdb->userid ) {
|
|
error(get_string('errcannoteditothers', 'glossary'));
|
|
} elseif (!$ineditperiod) {
|
|
error(get_string('erredittimeexpired', 'glossary'));
|
|
}
|
|
die;
|
|
}
|
|
|
|
if ( $aliases = get_records_menu("glossary_alias", "entryid", $e, '', 'id, alias') ) {
|
|
$toform->aliases = implode("\n", $aliases) . "\n";
|
|
}
|
|
$mform->set_defaults($toform);
|
|
}
|
|
}
|
|
|
|
$strglossary = get_string("modulename", "glossary");
|
|
$strglossaries = get_string("modulenameplural", "glossary");
|
|
$stredit = get_string("edit");
|
|
|
|
|
|
print_header_simple(format_string($glossary->name), "",
|
|
"<a href=\"index.php?id=$course->id\">$strglossaries</a> ->
|
|
<a href=\"view.php?id=$cm->id\">".format_string($glossary->name,true)."</a> -> $stredit", "",
|
|
"", true, "", navmenu($course, $cm));
|
|
|
|
|
|
|
|
print_heading(format_string($glossary->name));
|
|
|
|
/// Info box
|
|
|
|
if ( $glossary->intro ) {
|
|
print_simple_box(format_text($glossary->intro), 'center', '70%', '', 5, 'generalbox', 'intro');
|
|
}
|
|
|
|
echo '<br />';
|
|
|
|
/// Tabbed browsing sections
|
|
$tab = GLOSSARY_ADDENTRY_VIEW;
|
|
include("tabs.html");
|
|
|
|
if (!$e) {
|
|
require_capability('mod/glossary:write', $context);
|
|
}
|
|
|
|
$mform->display();
|
|
|
|
echo '</center>'; //TODO remove center tag from here and tabs.html
|
|
glossary_print_tabbed_table_end();
|
|
|
|
|
|
print_footer($course);
|
|
|
|
?>
|