mirror of
https://github.com/moodle/moodle.git
synced 2025-02-18 23:05:30 +01:00
This check-in removes about 400 lines of code. I hope I have not screwed anything up. I would be grateful if people could review this change, and keep an eye on the navigation bar in modules. Any navigation bar bugs you find in the near future, feel free to file them in the tracker and assign them to me. Thanks. If not to many problems are found, I think I would like to backport this to 1.9 stable, but I am not sure that is a good idea. Opinions to the General Developer Forum please. I am about to start a thread there.
353 lines
15 KiB
PHP
Executable File
353 lines
15 KiB
PHP
Executable File
<?php // $Id$
|
|
///////////////////////////////////////////////////////////////////////////
|
|
// //
|
|
// NOTICE OF COPYRIGHT //
|
|
// //
|
|
// Moodle - Modular Object-Oriented Dynamic Learning Environment //
|
|
// http://moodle.org //
|
|
// //
|
|
// Copyright (C) 2005 Martin Dougiamas http://dougiamas.com //
|
|
// //
|
|
// This program 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 2 of the License, or //
|
|
// (at your option) any later version. //
|
|
// //
|
|
// This program 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: //
|
|
// //
|
|
// http://www.gnu.org/copyleft/gpl.html //
|
|
// //
|
|
///////////////////////////////////////////////////////////////////////////
|
|
|
|
require_once('../../config.php');
|
|
require_once('lib.php');
|
|
require_once("$CFG->libdir/rsslib.php");
|
|
|
|
$id = optional_param('id', 0, PARAM_INT); // course module id
|
|
$d = optional_param('d', 0, PARAM_INT); // database id
|
|
$rid = optional_param('rid', 0, PARAM_INT); //record id
|
|
$import = optional_param('import', 0, PARAM_INT); // show import form
|
|
$cancel = optional_param('cancel', ''); // cancel an add
|
|
$mode ='addtemplate'; //define the mode for this page, only 1 mode available
|
|
|
|
if ($id) {
|
|
if (! $cm = get_coursemodule_from_id('data', $id)) {
|
|
error('Course Module ID was incorrect');
|
|
}
|
|
if (! $course = get_record('course', 'id', $cm->course)) {
|
|
error('Course is misconfigured');
|
|
}
|
|
if (! $data = get_record('data', 'id', $cm->instance)) {
|
|
error('Course module is incorrect');
|
|
}
|
|
|
|
} else {
|
|
if (! $data = get_record('data', 'id', $d)) {
|
|
error('Data ID is incorrect');
|
|
}
|
|
if (! $course = get_record('course', 'id', $data->course)) {
|
|
error('Course is misconfigured');
|
|
}
|
|
if (! $cm = get_coursemodule_from_instance('data', $data->id, $course->id)) {
|
|
error('Course Module ID was incorrect');
|
|
}
|
|
}
|
|
|
|
require_login($course->id, false, $cm);
|
|
|
|
if (!isloggedin() or isguest()) {
|
|
redirect('view.php?d='.$data->id);
|
|
}
|
|
|
|
$context = get_context_instance(CONTEXT_MODULE, $cm->id);
|
|
|
|
/// If it's hidden then it doesn't show anything. :)
|
|
if (empty($cm->visible) and !has_capability('moodle/course:viewhiddenactivities', $context)) {
|
|
$strdatabases = get_string("modulenameplural", "data");
|
|
|
|
$navigation = build_navigation('', $cm);
|
|
print_header_simple(format_string($data->name), "", $navigation, "", "", true, '', navmenu($course, $cm));
|
|
notice(get_string("activityiscurrentlyhidden"));
|
|
}
|
|
|
|
/// Can't use this if there are no fields
|
|
if (has_capability('mod/data:managetemplates', $context)) {
|
|
if (!record_exists('data_fields','dataid',$data->id)) { // Brand new database!
|
|
redirect($CFG->wwwroot.'/mod/data/field.php?d='.$data->id); // Redirect to field entry
|
|
}
|
|
}
|
|
|
|
if ($rid) { // So do you have access?
|
|
if (!(has_capability('mod/data:manageentries', $context) or data_isowner($rid)) or !confirm_sesskey() ) {
|
|
error(get_string('noaccess','data'));
|
|
}
|
|
}
|
|
|
|
if ($cancel) {
|
|
redirect('view.php?d='.$data->id);
|
|
}
|
|
|
|
|
|
/// RSS and CSS and JS meta
|
|
$meta = '';
|
|
if (!empty($CFG->enablerssfeeds) && !empty($CFG->data_enablerssfeeds) && $data->rssarticles > 0) {
|
|
$rsspath = rss_get_url($course->id, $USER->id, 'data', $data->id);
|
|
$meta .= '<link rel="alternate" type="application/rss+xml" ';
|
|
$meta .= 'title ="'. format_string($course->shortname) .': %fullname%" href="'.$rsspath.'" />';
|
|
}
|
|
if ($data->csstemplate) {
|
|
$meta .= '<link rel="stylesheet" type="text/css" href="'.$CFG->wwwroot.'/mod/data/css.php?d='.$data->id.'" /> ';
|
|
}
|
|
if ($data->jstemplate) {
|
|
$meta .= '<script type="text/javascript" src="'.$CFG->wwwroot.'/mod/data/js.php?d='.$data->id.'"></script>';
|
|
}
|
|
|
|
|
|
/// Print the page header
|
|
$strdata = get_string('modulenameplural','data');
|
|
|
|
$navigation = build_navigation('', $cm);
|
|
print_header_simple($data->name, '', $navigation,
|
|
'', $meta, true, update_module_button($cm->id, $course->id, get_string('modulename', 'data')),
|
|
navmenu($course, $cm), '', '');
|
|
|
|
/// Check to see if groups are being used here
|
|
groups_print_activity_menu($cm, 'edit.php?d='.$data->id);
|
|
$currentgroup = groups_get_activity_group($cm);
|
|
$groupmode = groups_get_activity_groupmode($cm);
|
|
|
|
print_heading(format_string($data->name));
|
|
|
|
if ($currentgroup) {
|
|
$groupselect = " AND groupid = '$currentgroup'";
|
|
$groupparam = "&groupid=$currentgroup";
|
|
} else {
|
|
$groupselect = "";
|
|
$groupparam = "";
|
|
$currentgroup = 0;
|
|
}
|
|
|
|
/// Print the tabs
|
|
|
|
$currenttab = 'add';
|
|
if ($rid) {
|
|
$editentry = true; //used in tabs
|
|
}
|
|
include('tabs.php');
|
|
|
|
|
|
/// Process incoming data for adding/updating records
|
|
|
|
if ($datarecord = data_submitted($CFG->wwwroot.'/mod/data/edit.php') and confirm_sesskey()) {
|
|
|
|
$ignorenames = array('MAX_FILE_SIZE','sesskey','d','rid','saveandview','cancel'); // strings to be ignored in input data
|
|
|
|
if ($rid) { /// Update some records
|
|
|
|
/// All student edits are marked unapproved by default
|
|
$record = get_record('data_records','id',$rid);
|
|
|
|
/// reset approved flag after student edit
|
|
if (!has_capability('mod/data:approve', $context)) {
|
|
$record->approved = 0;
|
|
}
|
|
|
|
$record->groupid = $currentgroup;
|
|
$record->timemodified = time();
|
|
update_record('data_records',$record);
|
|
|
|
/// Update all content
|
|
$field = NULL;
|
|
foreach ($datarecord as $name => $value) {
|
|
if (!in_array($name, $ignorenames)) {
|
|
$namearr = explode('_',$name); // Second one is the field id
|
|
if (empty($field->field) || ($namearr[1] != $field->field->id)) { // Try to reuse classes
|
|
$field = data_get_field_from_id($namearr[1], $data);
|
|
}
|
|
if ($field) {
|
|
$field->update_content($rid, $value, $name);
|
|
}
|
|
}
|
|
}
|
|
|
|
add_to_log($course->id, 'data', 'update', "view.php?d=$data->id&rid=$rid", $data->id, $cm->id);
|
|
|
|
redirect($CFG->wwwroot.'/mod/data/view.php?d='.$data->id.'&rid='.$rid);
|
|
|
|
} else { /// Add some new records
|
|
|
|
if (!data_user_can_add_entry($data, $currentgroup, $groupmode)) {
|
|
error('Can not add entries!');
|
|
}
|
|
|
|
/// Check if maximum number of entry as specified by this database is reached
|
|
/// Of course, you can't be stopped if you are an editting teacher! =)
|
|
|
|
if (data_atmaxentries($data) and !has_capability('mod/data:manageentries',$context)){
|
|
notify (get_string('atmaxentry','data'));
|
|
print_footer($course);
|
|
exit;
|
|
}
|
|
|
|
///Empty form checking - you can't submit an empty form!
|
|
|
|
$emptyform = true; // assume the worst
|
|
|
|
foreach ($datarecord as $name => $value) {
|
|
if (!in_array($name, $ignorenames)) {
|
|
$namearr = explode('_', $name); // Second one is the field id
|
|
if (empty($field->field) || ($namearr[1] != $field->field->id)) { // Try to reuse classes
|
|
$field = data_get_field_from_id($namearr[1], $data);
|
|
}
|
|
if ($field->notemptyfield($value, $name)) {
|
|
$emptyform = false;
|
|
break; // if anything has content, this form is not empty, so stop now!
|
|
}
|
|
}
|
|
}
|
|
|
|
if ($emptyform){ //nothing gets written to database
|
|
notify(get_string('emptyaddform','data'));
|
|
}
|
|
|
|
if (!$emptyform && $recordid = data_add_record($data, $currentgroup)) { //add instance to data_record
|
|
|
|
/// Insert a whole lot of empty records to make sure we have them
|
|
$fields = get_records('data_fields','dataid',$data->id);
|
|
foreach ($fields as $field) {
|
|
$content->recordid = $recordid;
|
|
$content->fieldid = $field->id;
|
|
insert_record('data_content',$content);
|
|
}
|
|
|
|
//for each field in the add form, add it to the data_content.
|
|
foreach ($datarecord as $name => $value){
|
|
if (!in_array($name, $ignorenames)) {
|
|
$namearr = explode('_', $name); // Second one is the field id
|
|
if (empty($field->field) || ($namearr[1] != $field->field->id)) { // Try to reuse classes
|
|
$field = data_get_field_from_id($namearr[1], $data);
|
|
}
|
|
if ($field) {
|
|
$field->update_content($recordid, $value, $name);
|
|
}
|
|
}
|
|
}
|
|
|
|
add_to_log($course->id, 'data', 'add', "view.php?d=$data->id&rid=$recordid", $data->id, $cm->id);
|
|
|
|
notify(get_string('entrysaved','data'));
|
|
|
|
if (!empty($datarecord->saveandview)) {
|
|
redirect($CFG->wwwroot.'/mod/data/view.php?d='.$data->id.'&rid='.$recordid);
|
|
}
|
|
}
|
|
}
|
|
} // End of form processing
|
|
|
|
/// Print the browsing interface
|
|
|
|
$patterns = array(); //tags to replace
|
|
$replacement = array(); //html to replace those yucky tags
|
|
|
|
//form goes here first in case add template is empty
|
|
echo '<form enctype="multipart/form-data" action="edit.php" method="post">';
|
|
echo '<div>';
|
|
echo '<input name="d" value="'.$data->id.'" type="hidden" />';
|
|
echo '<input name="rid" value="'.$rid.'" type="hidden" />';
|
|
echo '<input name="sesskey" value="'.sesskey().'" type="hidden" />';
|
|
print_simple_box_start('center','80%');
|
|
|
|
if (!$rid){
|
|
print_heading(get_string('newentry','data'), '', 2);
|
|
}
|
|
|
|
/******************************************
|
|
* Regular expression replacement section *
|
|
******************************************/
|
|
if ($data->addtemplate){
|
|
$possiblefields = get_records('data_fields','dataid',$data->id,'id');
|
|
|
|
///then we generate strings to replace
|
|
foreach ($possiblefields as $eachfield){
|
|
$field = data_get_field($eachfield, $data);
|
|
$patterns[]="[[".$field->field->name."]]";
|
|
$replacements[] = $field->display_add_field($rid);
|
|
$patterns[]="[[".$field->field->name."#id]]";
|
|
$replacements[] = 'field_'.$field->field->id;
|
|
}
|
|
$newtext = str_ireplace($patterns, $replacements, $data->{$mode});
|
|
|
|
} else { //if the add template is not yet defined, print the default form!
|
|
echo data_generate_default_template($data, 'addtemplate', $rid, true, false);
|
|
$newtext = '';
|
|
}
|
|
|
|
echo $newtext;
|
|
echo '<div style="text-align:center"><input type="submit" name="saveandview" value="'.get_string('saveandview','data').'" />';
|
|
if ($rid) {
|
|
echo ' <input type="submit" name="cancel" value="'.get_string('cancel').'" onclick="javascript:history.go(-1)" />';
|
|
} else {
|
|
echo '<input type="submit" value="'.get_string('saveandadd','data').'" />';
|
|
}
|
|
echo '</div>';
|
|
print_simple_box_end();
|
|
echo '</div></form>';
|
|
|
|
|
|
/// Upload records section. Only for teachers and the admin.
|
|
|
|
if (has_capability('mod/data:manageentries',$context)) {
|
|
if ($import) {
|
|
print_simple_box_start('center','80%');
|
|
print_heading(get_string('uploadrecords', 'data'), '', 3);
|
|
|
|
$maxuploadsize = get_max_upload_file_size();
|
|
echo '<div style="text-align:center">';
|
|
echo '<form enctype="multipart/form-data" action="import.php" method="post">';
|
|
echo '<input type="hidden" name="MAX_FILE_SIZE" value="'.$maxuploadsize.'" />';
|
|
echo '<input name="d" value="'.$data->id.'" type="hidden" />';
|
|
echo '<input name="sesskey" value="'.sesskey().'" type="hidden" />';
|
|
echo '<table align="center" cellspacing="0" cellpadding="2" border="0">';
|
|
echo '<tr>';
|
|
echo '<td align="right">'.get_string('csvfile', 'data').':</td>';
|
|
echo '<td><input type="file" name="recordsfile" size="30" />';
|
|
helpbutton('importcsv', get_string('csvimport', 'data'), 'data', true, false);
|
|
echo '</td><tr>';
|
|
echo '<td align="right">'.get_string('fielddelimiter', 'data').':</td>';
|
|
echo '<td><input type="text" name="fielddelimiter" size="6" />';
|
|
echo get_string('defaultfielddelimiter', 'data').'</td>';
|
|
echo '</tr>';
|
|
echo '<td align="right">'.get_string('fieldenclosure', 'data').':</td>';
|
|
echo '<td><input type="text" name="fieldenclosure" size="6" />';
|
|
echo get_string('defaultfieldenclosure', 'data').'</td>';
|
|
echo '</tr>';
|
|
echo '</table>';
|
|
echo '<input type="submit" value="'.get_string('uploadfile', 'data').'" />';
|
|
echo '</form>';
|
|
echo '</div>';
|
|
print_simple_box_end();
|
|
} else {
|
|
echo '<div style="text-align:center">';
|
|
echo '<a href="edit.php?d='.$data->id.'&import=1">'.get_string('uploadrecords', 'data').'</a>';
|
|
echo '</div>';
|
|
}
|
|
}
|
|
|
|
|
|
/// Finish the page
|
|
|
|
// Print the stuff that need to come after the form fields.
|
|
if (!$fields = get_records('data_fields', 'dataid', $data->id)) {
|
|
error(get_string('nofieldindatabase', 'data'));
|
|
}
|
|
foreach ($fields as $eachfield) {
|
|
$field = data_get_field($eachfield, $data);
|
|
$field->print_after_form();
|
|
}
|
|
|
|
print_footer($course);
|
|
?>
|