NEW MODULE FROM MOODLE.COM - DATABASE !
Finally, we have an early version good enough for everyone to
start banging on to help us polish it up and find bugs.
Please take a look and file bugs in the bug tracker under "Database module".
We urgently need
- new icons for existing field types
- testing on PostgreSQL install
Coming soon (?):
- Many more field types: calculation, checkbox, relation, date, datetime,
time, email, group, list, user, number, richtext
(Please let us know if you are interested in developing any of these)
- A way to save and restore "presets", which are field/template sets
- Backup/Restore support
- Groups Support
- RSS support
Many thanks to Yu for all the hard work under my whip.
2005-12-02 07:50:26 +00:00
|
|
|
<?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');
|
|
|
|
|
2006-02-28 02:51:31 +00:00
|
|
|
|
2006-03-27 08:37:17 +00:00
|
|
|
$id = optional_param('id', 0, PARAM_INT); // course module id
|
|
|
|
$d = optional_param('d', 0, PARAM_INT); // database id
|
|
|
|
$fid = optional_param('fid', 0 , PARAM_INT); // update field id
|
|
|
|
$newtype = optional_param('newtype','',PARAM_ALPHA); // type of the new field
|
|
|
|
$mode = optional_param('mode','',PARAM_ALPHA);
|
|
|
|
$defaultsort = optional_param('defaultsort', 0, PARAM_INT);
|
|
|
|
$defaultsortdir = optional_param('defaultsortdir', 0, PARAM_INT);
|
|
|
|
$cancel = optional_param('cancel', '');
|
2006-03-25 14:00:54 +00:00
|
|
|
|
|
|
|
if ($cancel) {
|
|
|
|
$mode = 'list';
|
|
|
|
}
|
|
|
|
|
2006-03-22 08:44:26 +00:00
|
|
|
|
NEW MODULE FROM MOODLE.COM - DATABASE !
Finally, we have an early version good enough for everyone to
start banging on to help us polish it up and find bugs.
Please take a look and file bugs in the bug tracker under "Database module".
We urgently need
- new icons for existing field types
- testing on PostgreSQL install
Coming soon (?):
- Many more field types: calculation, checkbox, relation, date, datetime,
time, email, group, list, user, number, richtext
(Please let us know if you are interested in developing any of these)
- A way to save and restore "presets", which are field/template sets
- Backup/Restore support
- Groups Support
- RSS support
Many thanks to Yu for all the hard work under my whip.
2005-12-02 07:50:26 +00:00
|
|
|
if ($id) {
|
|
|
|
if (! $cm = get_record('course_modules', 'id', $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');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2006-03-30 04:37:16 +00:00
|
|
|
require_course_login($course, true, $cm);
|
|
|
|
|
NEW MODULE FROM MOODLE.COM - DATABASE !
Finally, we have an early version good enough for everyone to
start banging on to help us polish it up and find bugs.
Please take a look and file bugs in the bug tracker under "Database module".
We urgently need
- new icons for existing field types
- testing on PostgreSQL install
Coming soon (?):
- Many more field types: calculation, checkbox, relation, date, datetime,
time, email, group, list, user, number, richtext
(Please let us know if you are interested in developing any of these)
- A way to save and restore "presets", which are field/template sets
- Backup/Restore support
- Groups Support
- RSS support
Many thanks to Yu for all the hard work under my whip.
2005-12-02 07:50:26 +00:00
|
|
|
if (!isteacheredit($course->id)){
|
|
|
|
error(get_string('noaccess','data'));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/************************************
|
|
|
|
* Data Processing *
|
|
|
|
***********************************/
|
2006-03-22 13:38:29 +00:00
|
|
|
switch ($mode) {
|
NEW MODULE FROM MOODLE.COM - DATABASE !
Finally, we have an early version good enough for everyone to
start banging on to help us polish it up and find bugs.
Please take a look and file bugs in the bug tracker under "Database module".
We urgently need
- new icons for existing field types
- testing on PostgreSQL install
Coming soon (?):
- Many more field types: calculation, checkbox, relation, date, datetime,
time, email, group, list, user, number, richtext
(Please let us know if you are interested in developing any of these)
- A way to save and restore "presets", which are field/template sets
- Backup/Restore support
- Groups Support
- RSS support
Many thanks to Yu for all the hard work under my whip.
2005-12-02 07:50:26 +00:00
|
|
|
|
|
|
|
case 'add': ///add a new field
|
2006-03-24 02:44:05 +00:00
|
|
|
if (confirm_sesskey() and $fieldinput = data_submitted($CFG->wwwroot.'/mod/data/field.php')){
|
NEW MODULE FROM MOODLE.COM - DATABASE !
Finally, we have an early version good enough for everyone to
start banging on to help us polish it up and find bugs.
Please take a look and file bugs in the bug tracker under "Database module".
We urgently need
- new icons for existing field types
- testing on PostgreSQL install
Coming soon (?):
- Many more field types: calculation, checkbox, relation, date, datetime,
time, email, group, list, user, number, richtext
(Please let us know if you are interested in developing any of these)
- A way to save and restore "presets", which are field/template sets
- Backup/Restore support
- Groups Support
- RSS support
Many thanks to Yu for all the hard work under my whip.
2005-12-02 07:50:26 +00:00
|
|
|
|
2006-06-06 09:35:15 +00:00
|
|
|
$fieldinput->name = clean_param($fieldinput->name, PARAM_NOTAGS);
|
|
|
|
$fieldinput->name = trim($fieldinput->name);
|
|
|
|
|
2006-03-22 08:07:26 +00:00
|
|
|
/// Only store this new field if it doesn't already exist.
|
2006-06-06 09:35:15 +00:00
|
|
|
if (($fieldinput->name == '') or data_fieldname_exists($fieldinput->name, $data->id)) {
|
2006-03-22 08:07:26 +00:00
|
|
|
|
2006-03-22 09:49:29 +00:00
|
|
|
$displaynoticebad = get_string('invalidfieldname','data');
|
2006-03-22 08:07:26 +00:00
|
|
|
|
|
|
|
} else {
|
2006-02-06 09:13:37 +00:00
|
|
|
|
2006-03-22 08:07:26 +00:00
|
|
|
/// Check for arrays and convert to a comma-delimited string
|
|
|
|
data_convert_arrays_to_strings($fieldinput);
|
|
|
|
|
|
|
|
/// Create a field object to collect and store the data safely
|
|
|
|
$type = required_param('type', PARAM_FILE);
|
|
|
|
$field = data_get_field_new($type, $data);
|
|
|
|
|
|
|
|
$field->define_field($fieldinput);
|
|
|
|
$field->insert_field();
|
|
|
|
|
|
|
|
/// Update some templates
|
|
|
|
data_append_new_field_to_templates($data, $field->field->name);
|
2006-02-27 04:13:03 +00:00
|
|
|
|
2006-03-22 08:07:26 +00:00
|
|
|
add_to_log($course->id, 'data', 'fields add',
|
2006-03-24 02:44:05 +00:00
|
|
|
"field.php?d=$data->id&mode=display&fid=$fid", $fid, $cm->id);
|
2006-02-06 09:13:37 +00:00
|
|
|
|
2006-03-22 09:49:29 +00:00
|
|
|
$displaynoticegood = get_string('fieldadded','data');
|
NEW MODULE FROM MOODLE.COM - DATABASE !
Finally, we have an early version good enough for everyone to
start banging on to help us polish it up and find bugs.
Please take a look and file bugs in the bug tracker under "Database module".
We urgently need
- new icons for existing field types
- testing on PostgreSQL install
Coming soon (?):
- Many more field types: calculation, checkbox, relation, date, datetime,
time, email, group, list, user, number, richtext
(Please let us know if you are interested in developing any of these)
- A way to save and restore "presets", which are field/template sets
- Backup/Restore support
- Groups Support
- RSS support
Many thanks to Yu for all the hard work under my whip.
2005-12-02 07:50:26 +00:00
|
|
|
}
|
2006-03-22 08:07:26 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case 'update': ///update a field
|
2006-03-24 02:44:05 +00:00
|
|
|
if (confirm_sesskey() and $fieldinput = data_submitted($CFG->wwwroot.'/mod/data/field.php')){
|
2006-03-22 08:07:26 +00:00
|
|
|
|
2006-06-06 09:35:15 +00:00
|
|
|
$fieldinput->name = clean_param($fieldinput->name, PARAM_NOTAGS);
|
|
|
|
$fieldinput->name = trim($fieldinput->name);
|
2006-03-22 08:07:26 +00:00
|
|
|
|
2006-06-06 09:35:15 +00:00
|
|
|
if (($fieldinput->name == '') or data_fieldname_exists($fieldinput->name, $data->id, $fieldinput->fid)) {
|
|
|
|
|
2006-03-22 09:49:29 +00:00
|
|
|
$displaynoticebad = get_string('invalidfieldname','data');
|
2006-03-22 08:07:26 +00:00
|
|
|
|
|
|
|
} else {
|
|
|
|
/// Check for arrays and convert to a comma-delimited string
|
|
|
|
data_convert_arrays_to_strings($fieldinput);
|
|
|
|
|
|
|
|
/// Create a field object to collect and store the data safely
|
|
|
|
$field = data_get_field_from_id($fid, $data);
|
|
|
|
$oldfieldname = $field->field->name;
|
2006-03-24 14:34:00 +00:00
|
|
|
|
|
|
|
$field->field->name = $fieldinput->name;
|
|
|
|
$field->field->description = $fieldinput->description;
|
|
|
|
|
|
|
|
for ($i=1; $i<=10; $i++) {
|
|
|
|
if (isset($fieldinput->{'param'.$i})) {
|
|
|
|
$field->field->{'param'.$i} = $fieldinput->{'param'.$i};
|
|
|
|
} else {
|
|
|
|
$field->field->{'param'.$i} = '';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$field->update_field();
|
2006-03-22 08:07:26 +00:00
|
|
|
|
|
|
|
/// Update the templates.
|
|
|
|
data_replace_field_in_templates($data, $oldfieldname, $field->field->name);
|
|
|
|
|
|
|
|
add_to_log($course->id, 'data', 'fields update',
|
2006-03-24 02:44:05 +00:00
|
|
|
"field.php?d=$data->id&mode=display&fid=$fid", $fid, $cm->id);
|
2006-03-22 08:07:26 +00:00
|
|
|
|
2006-03-22 09:49:29 +00:00
|
|
|
$displaynoticegood = get_string('fieldupdated','data');
|
NEW MODULE FROM MOODLE.COM - DATABASE !
Finally, we have an early version good enough for everyone to
start banging on to help us polish it up and find bugs.
Please take a look and file bugs in the bug tracker under "Database module".
We urgently need
- new icons for existing field types
- testing on PostgreSQL install
Coming soon (?):
- Many more field types: calculation, checkbox, relation, date, datetime,
time, email, group, list, user, number, richtext
(Please let us know if you are interested in developing any of these)
- A way to save and restore "presets", which are field/template sets
- Backup/Restore support
- Groups Support
- RSS support
Many thanks to Yu for all the hard work under my whip.
2005-12-02 07:50:26 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
2006-03-22 08:07:26 +00:00
|
|
|
|
2006-02-06 09:13:37 +00:00
|
|
|
case 'delete': // Delete a field
|
NEW MODULE FROM MOODLE.COM - DATABASE !
Finally, we have an early version good enough for everyone to
start banging on to help us polish it up and find bugs.
Please take a look and file bugs in the bug tracker under "Database module".
We urgently need
- new icons for existing field types
- testing on PostgreSQL install
Coming soon (?):
- Many more field types: calculation, checkbox, relation, date, datetime,
time, email, group, list, user, number, richtext
(Please let us know if you are interested in developing any of these)
- A way to save and restore "presets", which are field/template sets
- Backup/Restore support
- Groups Support
- RSS support
Many thanks to Yu for all the hard work under my whip.
2005-12-02 07:50:26 +00:00
|
|
|
if (confirm_sesskey()){
|
2006-03-22 13:38:29 +00:00
|
|
|
|
2006-02-06 09:13:37 +00:00
|
|
|
if ($confirm = optional_param('confirm', 0, PARAM_INT)) {
|
|
|
|
|
2006-03-22 13:38:29 +00:00
|
|
|
|
2006-03-22 08:07:26 +00:00
|
|
|
// Delete the field completely
|
2006-03-22 09:53:13 +00:00
|
|
|
if ($field = data_get_field_from_id($fid, $data)) {
|
|
|
|
$field->delete_field();
|
|
|
|
|
|
|
|
// Update the templates.
|
|
|
|
data_replace_field_in_templates($data, $field->field->name, '');
|
2006-03-27 08:37:17 +00:00
|
|
|
|
|
|
|
// Update the default sort field
|
|
|
|
if ($fid == $data->defaultsort) {
|
|
|
|
unset($rec);
|
|
|
|
$rec->id = $data->id;
|
|
|
|
$rec->defaultsort = 0;
|
|
|
|
$rec->defaultsortdir = 0;
|
|
|
|
if (!update_record('data', $rec)) {
|
|
|
|
error('There was an error updating the database');
|
|
|
|
}
|
|
|
|
}
|
2006-03-22 09:53:13 +00:00
|
|
|
|
|
|
|
add_to_log($course->id, 'data', 'fields delete',
|
2006-03-24 02:44:05 +00:00
|
|
|
"field.php?d=$data->id", $field->field->name, $cm->id);
|
2006-03-22 09:53:13 +00:00
|
|
|
|
|
|
|
$displaynoticegood = get_string('fielddeleted', 'data');
|
|
|
|
}
|
2006-03-22 08:07:26 +00:00
|
|
|
|
|
|
|
} else {
|
2006-03-22 13:38:29 +00:00
|
|
|
|
|
|
|
data_fields_print_header($course,$cm,$data, false);
|
|
|
|
|
2006-02-06 09:13:37 +00:00
|
|
|
// Print confirmation message.
|
2006-03-22 08:07:26 +00:00
|
|
|
$field = data_get_field_from_id($fid, $data);
|
|
|
|
|
2006-03-22 09:43:10 +00:00
|
|
|
notice_yesno('<strong>'.$field->name().': '.$field->field->name.'</strong><br /><br />'. get_string('confirmdeletefield','data'),
|
2006-03-24 02:44:05 +00:00
|
|
|
'field.php?d='.$data->id.'&mode=delete&fid='.$fid.'&sesskey='.sesskey().'&confirm=1',
|
|
|
|
'field.php?d='.$data->id);
|
2006-03-22 09:43:10 +00:00
|
|
|
|
NEW MODULE FROM MOODLE.COM - DATABASE !
Finally, we have an early version good enough for everyone to
start banging on to help us polish it up and find bugs.
Please take a look and file bugs in the bug tracker under "Database module".
We urgently need
- new icons for existing field types
- testing on PostgreSQL install
Coming soon (?):
- Many more field types: calculation, checkbox, relation, date, datetime,
time, email, group, list, user, number, richtext
(Please let us know if you are interested in developing any of these)
- A way to save and restore "presets", which are field/template sets
- Backup/Restore support
- Groups Support
- RSS support
Many thanks to Yu for all the hard work under my whip.
2005-12-02 07:50:26 +00:00
|
|
|
print_footer($course);
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
2006-03-27 08:37:17 +00:00
|
|
|
|
|
|
|
case 'sort': // Set the default sort parameters
|
|
|
|
if (confirm_sesskey()) {
|
|
|
|
$rec->id = $data->id;
|
|
|
|
$rec->defaultsort = $defaultsort;
|
|
|
|
$rec->defaultsortdir = $defaultsortdir;
|
|
|
|
|
|
|
|
if (update_record('data', $rec)) {
|
|
|
|
redirect($CFG->wwwroot.'/mod/data/field.php?d='.$data->id, get_string('changessaved'), 2);
|
|
|
|
} else {
|
|
|
|
error('There was an error updating the database');
|
|
|
|
}
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
NEW MODULE FROM MOODLE.COM - DATABASE !
Finally, we have an early version good enough for everyone to
start banging on to help us polish it up and find bugs.
Please take a look and file bugs in the bug tracker under "Database module".
We urgently need
- new icons for existing field types
- testing on PostgreSQL install
Coming soon (?):
- Many more field types: calculation, checkbox, relation, date, datetime,
time, email, group, list, user, number, richtext
(Please let us know if you are interested in developing any of these)
- A way to save and restore "presets", which are field/template sets
- Backup/Restore support
- Groups Support
- RSS support
Many thanks to Yu for all the hard work under my whip.
2005-12-02 07:50:26 +00:00
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/// Print the browsing interface
|
|
|
|
|
|
|
|
///get the list of possible fields (plugins)
|
|
|
|
$directories = get_list_of_plugins('mod/data/field/');
|
|
|
|
$menufield = array();
|
|
|
|
|
|
|
|
foreach ($directories as $directory){
|
|
|
|
$menufield[$directory] = get_string($directory,'data'); //get from language files
|
|
|
|
}
|
|
|
|
asort($menufield); //sort in alphabetical order
|
|
|
|
|
|
|
|
|
2006-03-27 08:37:17 +00:00
|
|
|
if (($mode == 'new') && (!empty($newtype)) && confirm_sesskey()) { /// Adding a new field
|
2006-03-22 13:38:29 +00:00
|
|
|
$CFG->pagepath='mod/data/field/'.$newtype;
|
|
|
|
data_fields_print_header($course,$cm,$data);
|
|
|
|
|
2006-03-22 08:07:26 +00:00
|
|
|
$field = data_get_field_new($newtype, $data);
|
|
|
|
$field->display_edit_field();
|
NEW MODULE FROM MOODLE.COM - DATABASE !
Finally, we have an early version good enough for everyone to
start banging on to help us polish it up and find bugs.
Please take a look and file bugs in the bug tracker under "Database module".
We urgently need
- new icons for existing field types
- testing on PostgreSQL install
Coming soon (?):
- Many more field types: calculation, checkbox, relation, date, datetime,
time, email, group, list, user, number, richtext
(Please let us know if you are interested in developing any of these)
- A way to save and restore "presets", which are field/template sets
- Backup/Restore support
- Groups Support
- RSS support
Many thanks to Yu for all the hard work under my whip.
2005-12-02 07:50:26 +00:00
|
|
|
|
2006-03-22 08:07:26 +00:00
|
|
|
} else if ($mode == 'display' && confirm_sesskey()) { /// Display/edit existing field
|
2006-03-22 13:38:29 +00:00
|
|
|
$CFG->pagepath='mod/data/field/'.$newtype;
|
|
|
|
data_fields_print_header($course,$cm,$data);
|
|
|
|
|
2006-03-22 08:07:26 +00:00
|
|
|
$field = data_get_field_from_id($fid, $data);
|
|
|
|
$field->display_edit_field();
|
|
|
|
|
|
|
|
} else { /// Display the main listing of all fields
|
2006-03-22 13:38:29 +00:00
|
|
|
|
|
|
|
$CFG->pagepath='mod/data/field/'.$newtype;
|
|
|
|
data_fields_print_header($course,$cm,$data);
|
2006-03-22 09:14:44 +00:00
|
|
|
|
NEW MODULE FROM MOODLE.COM - DATABASE !
Finally, we have an early version good enough for everyone to
start banging on to help us polish it up and find bugs.
Please take a look and file bugs in the bug tracker under "Database module".
We urgently need
- new icons for existing field types
- testing on PostgreSQL install
Coming soon (?):
- Many more field types: calculation, checkbox, relation, date, datetime,
time, email, group, list, user, number, richtext
(Please let us know if you are interested in developing any of these)
- A way to save and restore "presets", which are field/template sets
- Backup/Restore support
- Groups Support
- RSS support
Many thanks to Yu for all the hard work under my whip.
2005-12-02 07:50:26 +00:00
|
|
|
|
2006-03-22 08:07:26 +00:00
|
|
|
if (!record_exists('data_fields','dataid',$data->id)) {
|
2006-03-22 09:53:13 +00:00
|
|
|
notify(get_string('nofieldindatabase','data')); // nothing in database
|
2006-03-22 08:07:26 +00:00
|
|
|
|
|
|
|
} else { //else print quiz style list of fields
|
2006-03-22 09:33:29 +00:00
|
|
|
|
2006-03-26 06:00:28 +00:00
|
|
|
$table->head = array(get_string('fieldname','data'), get_string('type','data'), get_string('fielddescription', 'data'), get_string('action','data'));
|
|
|
|
$table->align = array('left','left','left', 'center');
|
2006-03-25 14:00:54 +00:00
|
|
|
$table->wrap = array(false,false,false,false);
|
NEW MODULE FROM MOODLE.COM - DATABASE !
Finally, we have an early version good enough for everyone to
start banging on to help us polish it up and find bugs.
Please take a look and file bugs in the bug tracker under "Database module".
We urgently need
- new icons for existing field types
- testing on PostgreSQL install
Coming soon (?):
- Many more field types: calculation, checkbox, relation, date, datetime,
time, email, group, list, user, number, richtext
(Please let us know if you are interested in developing any of these)
- A way to save and restore "presets", which are field/template sets
- Backup/Restore support
- Groups Support
- RSS support
Many thanks to Yu for all the hard work under my whip.
2005-12-02 07:50:26 +00:00
|
|
|
|
2006-03-24 14:34:00 +00:00
|
|
|
if ($fff = get_records('data_fields','dataid',$data->id,'id')){
|
2006-03-22 08:07:26 +00:00
|
|
|
foreach ($fff as $ff) {
|
2006-03-27 08:37:17 +00:00
|
|
|
|
2006-03-22 08:07:26 +00:00
|
|
|
$field = data_get_field($ff, $data);
|
NEW MODULE FROM MOODLE.COM - DATABASE !
Finally, we have an early version good enough for everyone to
start banging on to help us polish it up and find bugs.
Please take a look and file bugs in the bug tracker under "Database module".
We urgently need
- new icons for existing field types
- testing on PostgreSQL install
Coming soon (?):
- Many more field types: calculation, checkbox, relation, date, datetime,
time, email, group, list, user, number, richtext
(Please let us know if you are interested in developing any of these)
- A way to save and restore "presets", which are field/template sets
- Backup/Restore support
- Groups Support
- RSS support
Many thanks to Yu for all the hard work under my whip.
2005-12-02 07:50:26 +00:00
|
|
|
|
2006-03-22 09:33:29 +00:00
|
|
|
$table->data[] = array(
|
NEW MODULE FROM MOODLE.COM - DATABASE !
Finally, we have an early version good enough for everyone to
start banging on to help us polish it up and find bugs.
Please take a look and file bugs in the bug tracker under "Database module".
We urgently need
- new icons for existing field types
- testing on PostgreSQL install
Coming soon (?):
- Many more field types: calculation, checkbox, relation, date, datetime,
time, email, group, list, user, number, richtext
(Please let us know if you are interested in developing any of these)
- A way to save and restore "presets", which are field/template sets
- Backup/Restore support
- Groups Support
- RSS support
Many thanks to Yu for all the hard work under my whip.
2005-12-02 07:50:26 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
2006-03-24 02:44:05 +00:00
|
|
|
'<a href="field.php?mode=display&d='.$data->id.
|
2006-04-05 07:37:48 +00:00
|
|
|
'&fid='.$field->field->id.'&sesskey='.sesskey().'">'.$field->field->name.'</a>',
|
NEW MODULE FROM MOODLE.COM - DATABASE !
Finally, we have an early version good enough for everyone to
start banging on to help us polish it up and find bugs.
Please take a look and file bugs in the bug tracker under "Database module".
We urgently need
- new icons for existing field types
- testing on PostgreSQL install
Coming soon (?):
- Many more field types: calculation, checkbox, relation, date, datetime,
time, email, group, list, user, number, richtext
(Please let us know if you are interested in developing any of these)
- A way to save and restore "presets", which are field/template sets
- Backup/Restore support
- Groups Support
- RSS support
Many thanks to Yu for all the hard work under my whip.
2005-12-02 07:50:26 +00:00
|
|
|
|
|
|
|
|
2006-03-25 14:00:54 +00:00
|
|
|
$field->image().' '.get_string($field->type, 'data'),
|
|
|
|
|
2006-03-26 06:00:28 +00:00
|
|
|
shorten_text($field->field->description, 30),
|
|
|
|
|
|
|
|
'<a href="field.php?d='.$data->id.'&mode=display&fid='.$field->field->id.'&sesskey='.sesskey().'">'.
|
|
|
|
'<img src="'.$CFG->pixpath.'/t/edit.gif" height="11" width="11" border="0" alt="'.get_string('edit').'" /></a>'.
|
|
|
|
' '.
|
|
|
|
'<a href="field.php?d='.$data->id.'&mode=delete&fid='.$field->field->id.'&sesskey='.sesskey().'">'.
|
|
|
|
'<img src="'.$CFG->pixpath.'/t/delete.gif" height="11" width="11" border="0" alt="'.get_string('delete').'" /></a>'
|
2006-03-25 14:00:54 +00:00
|
|
|
|
|
|
|
);
|
NEW MODULE FROM MOODLE.COM - DATABASE !
Finally, we have an early version good enough for everyone to
start banging on to help us polish it up and find bugs.
Please take a look and file bugs in the bug tracker under "Database module".
We urgently need
- new icons for existing field types
- testing on PostgreSQL install
Coming soon (?):
- Many more field types: calculation, checkbox, relation, date, datetime,
time, email, group, list, user, number, richtext
(Please let us know if you are interested in developing any of these)
- A way to save and restore "presets", which are field/template sets
- Backup/Restore support
- Groups Support
- RSS support
Many thanks to Yu for all the hard work under my whip.
2005-12-02 07:50:26 +00:00
|
|
|
}
|
|
|
|
}
|
2006-03-22 09:33:29 +00:00
|
|
|
print_table($table);
|
|
|
|
}
|
NEW MODULE FROM MOODLE.COM - DATABASE !
Finally, we have an early version good enough for everyone to
start banging on to help us polish it up and find bugs.
Please take a look and file bugs in the bug tracker under "Database module".
We urgently need
- new icons for existing field types
- testing on PostgreSQL install
Coming soon (?):
- Many more field types: calculation, checkbox, relation, date, datetime,
time, email, group, list, user, number, richtext
(Please let us know if you are interested in developing any of these)
- A way to save and restore "presets", which are field/template sets
- Backup/Restore support
- Groups Support
- RSS support
Many thanks to Yu for all the hard work under my whip.
2005-12-02 07:50:26 +00:00
|
|
|
|
2006-03-27 09:08:09 +00:00
|
|
|
|
2006-03-22 09:53:13 +00:00
|
|
|
echo '<div class="fieldadd" align="center">';
|
|
|
|
echo get_string('newfield','data').': ';
|
2006-03-27 09:08:09 +00:00
|
|
|
popup_form($CFG->wwwroot.'/mod/data/field.php?d='.$data->id.'&mode=new&sesskey='.
|
|
|
|
sesskey().'&newtype=', $menufield, 'fieldform', '', 'choose');
|
2006-03-22 09:53:13 +00:00
|
|
|
helpbutton('fields', get_string('addafield','data'), 'data');
|
|
|
|
echo '</div>';
|
2006-03-27 08:37:17 +00:00
|
|
|
|
|
|
|
echo '<div class="sortdefault" align="center">';
|
|
|
|
echo '<form name="sortdefault" action="'.$CFG->wwwroot.'/mod/data/field.php" method="get">';
|
|
|
|
echo '<input type="hidden" name="d" value="'.$data->id.'" />';
|
|
|
|
echo '<input type="hidden" name="mode" value="sort" />';
|
|
|
|
echo '<input type="hidden" name="sesskey" value="'.sesskey().'" />';
|
2006-03-27 09:08:09 +00:00
|
|
|
echo ' '.get_string('defaultsortfield','data').':';
|
2006-03-27 08:37:17 +00:00
|
|
|
$fields = get_records('data_fields','dataid',$data->id);
|
|
|
|
echo '<select name="defaultsort"><option value="0">'.get_string('dateentered','data').'</option>';
|
|
|
|
foreach ($fields as $field) {
|
|
|
|
if ($field->id == $data->defaultsort) {
|
|
|
|
echo '<option value="'.$field->id.'" selected="selected">'.$field->name.'</option>';
|
|
|
|
} else {
|
|
|
|
echo '<option value="'.$field->id.'">'.$field->name.'</option>';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
echo '</select>';
|
2006-03-27 09:08:09 +00:00
|
|
|
|
|
|
|
echo ' ';
|
2006-03-22 09:53:13 +00:00
|
|
|
|
2006-03-27 08:37:17 +00:00
|
|
|
$options = array(0 => get_string('ascending', 'data'),
|
|
|
|
1 => get_string('descending', 'data'));
|
|
|
|
choose_from_menu($options, 'defaultsortdir', $data->defaultsortdir, '');
|
2006-03-27 09:08:09 +00:00
|
|
|
echo '<input type="submit" value="'.get_string('go').'" />';
|
|
|
|
|
2006-03-27 08:37:17 +00:00
|
|
|
echo '</form>';
|
|
|
|
echo '</div>';
|
|
|
|
|
|
|
|
|
NEW MODULE FROM MOODLE.COM - DATABASE !
Finally, we have an early version good enough for everyone to
start banging on to help us polish it up and find bugs.
Please take a look and file bugs in the bug tracker under "Database module".
We urgently need
- new icons for existing field types
- testing on PostgreSQL install
Coming soon (?):
- Many more field types: calculation, checkbox, relation, date, datetime,
time, email, group, list, user, number, richtext
(Please let us know if you are interested in developing any of these)
- A way to save and restore "presets", which are field/template sets
- Backup/Restore support
- Groups Support
- RSS support
Many thanks to Yu for all the hard work under my whip.
2005-12-02 07:50:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/// Finish the page
|
|
|
|
print_footer($course);
|
|
|
|
|
2006-03-22 13:38:29 +00:00
|
|
|
|
|
|
|
function data_fields_print_header($course,$cm,$data,$showtabs=true) {
|
|
|
|
|
|
|
|
global $CFG, $displaynoticegood, $displaynoticebad;
|
|
|
|
|
|
|
|
$strdata = get_string('modulenameplural','data');
|
|
|
|
|
|
|
|
print_header_simple($data->name, '', "<a href='index.php?id=$course->id'>$strdata</a> -> $data->name",
|
|
|
|
'', '', true, '', navmenu($course, $cm));
|
|
|
|
|
|
|
|
print_heading(format_string($data->name));
|
|
|
|
|
|
|
|
/// Print the tabs
|
|
|
|
|
|
|
|
if ($showtabs) {
|
|
|
|
$currenttab = 'fields';
|
2006-03-24 14:34:00 +00:00
|
|
|
include_once('tabs.php');
|
2006-03-22 13:38:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/// Print any notices
|
|
|
|
|
|
|
|
if (!empty($displaynoticegood)) {
|
|
|
|
notify($displaynoticegood, 'notifysuccess'); // good (usually green)
|
|
|
|
} else if (!empty($displaynoticebad)) {
|
|
|
|
notify($displaynoticebad); // bad (usuually red)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2006-03-22 08:07:26 +00:00
|
|
|
?>
|