2002-08-03 02:29:21 +00:00
|
|
|
<?PHP // $Id$
|
|
|
|
|
2003-01-05 14:19:20 +00:00
|
|
|
require_once("$CFG->dirroot/files/mimetypes.php");
|
2002-08-04 16:19:37 +00:00
|
|
|
|
2002-11-06 08:12:06 +00:00
|
|
|
define("OFFLINE", "0");
|
|
|
|
define("UPLOADSINGLE", "1");
|
|
|
|
|
|
|
|
$ASSIGNMENT_TYPE = array (OFFLINE => get_string("typeoffline", "assignment"),
|
|
|
|
UPLOADSINGLE => get_string("typeuploadsingle", "assignment") );
|
2002-08-04 16:19:37 +00:00
|
|
|
|
2003-10-06 18:02:35 +00:00
|
|
|
if (!isset($CFG->assignment_maxbytes)) {
|
|
|
|
set_config("assignment_maxbytes", 1024000); // Default maximum size for all assignments
|
|
|
|
}
|
|
|
|
|
2002-08-04 16:19:37 +00:00
|
|
|
|
2002-08-03 02:29:21 +00:00
|
|
|
function assignment_add_instance($assignment) {
|
|
|
|
// Given an object containing all the necessary data,
|
|
|
|
// (defined by the form in mod.html) this function
|
|
|
|
// will create a new instance and return the id number
|
|
|
|
// of the new instance.
|
|
|
|
|
|
|
|
$assignment->timemodified = time();
|
2002-08-04 16:19:37 +00:00
|
|
|
|
|
|
|
$assignment->timedue = make_timestamp($assignment->dueyear, $assignment->duemonth, $assignment->dueday,
|
|
|
|
$assignment->duehour, $assignment->dueminute);
|
2002-08-03 02:29:21 +00:00
|
|
|
|
|
|
|
return insert_record("assignment", $assignment);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function assignment_update_instance($assignment) {
|
|
|
|
// Given an object containing all the necessary data,
|
|
|
|
// (defined by the form in mod.html) this function
|
|
|
|
// will update an existing instance with new data.
|
|
|
|
|
|
|
|
$assignment->timemodified = time();
|
2002-08-04 16:19:37 +00:00
|
|
|
$assignment->timedue = make_timestamp($assignment->dueyear, $assignment->duemonth, $assignment->dueday,
|
|
|
|
$assignment->duehour, $assignment->dueminute);
|
2002-08-03 02:29:21 +00:00
|
|
|
$assignment->id = $assignment->instance;
|
|
|
|
|
|
|
|
return update_record("assignment", $assignment);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function assignment_delete_instance($id) {
|
|
|
|
// Given an ID of an instance of this module,
|
|
|
|
// this function will permanently delete the instance
|
|
|
|
// and any data that depends on it.
|
|
|
|
|
|
|
|
if (! $assignment = get_record("assignment", "id", "$id")) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
$result = true;
|
|
|
|
|
|
|
|
if (! delete_records("assignment_submissions", "assignment", "$assignment->id")) {
|
|
|
|
$result = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (! delete_records("assignment", "id", "$assignment->id")) {
|
|
|
|
$result = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
2002-08-04 17:13:49 +00:00
|
|
|
function assignment_user_outline($course, $user, $mod, $assignment) {
|
|
|
|
if ($submission = assignment_get_submission($assignment, $user)) {
|
2002-10-17 08:28:18 +00:00
|
|
|
|
|
|
|
if ($submission->grade) {
|
|
|
|
$result->info = get_string("grade").": $submission->grade";
|
2002-08-04 17:13:49 +00:00
|
|
|
}
|
|
|
|
$result->time = $submission->timemodified;
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
function assignment_user_complete($course, $user, $mod, $assignment) {
|
|
|
|
if ($submission = assignment_get_submission($assignment, $user)) {
|
|
|
|
if ($basedir = assignment_file_area($assignment, $user)) {
|
|
|
|
if ($files = get_directory_list($basedir)) {
|
|
|
|
$countfiles = count($files)." ".get_string("uploadedfiles", "assignment");
|
|
|
|
foreach ($files as $file) {
|
|
|
|
$countfiles .= "; $file";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
print_simple_box_start();
|
2003-07-07 12:45:08 +00:00
|
|
|
echo "<p><font size=1>";
|
2002-08-04 17:13:49 +00:00
|
|
|
echo get_string("lastmodified").": ";
|
|
|
|
echo userdate($submission->timemodified);
|
|
|
|
echo assignment_print_difference($assignment->timedue - $submission->timemodified);
|
2003-07-07 12:45:08 +00:00
|
|
|
echo "</font></p>";
|
2002-08-04 17:13:49 +00:00
|
|
|
|
|
|
|
assignment_print_user_files($assignment, $user);
|
|
|
|
|
2003-07-07 12:45:08 +00:00
|
|
|
echo "<br />";
|
2002-08-04 17:13:49 +00:00
|
|
|
|
2003-07-07 12:45:08 +00:00
|
|
|
if (empty($submission->timemarked)) {
|
|
|
|
print_string("notgradedyet", "assignment");
|
|
|
|
} else {
|
|
|
|
assignment_print_feedback($course, $submission);
|
|
|
|
}
|
2002-08-04 17:13:49 +00:00
|
|
|
|
|
|
|
print_simple_box_end();
|
|
|
|
|
|
|
|
} else {
|
|
|
|
print_string("notsubmittedyet", "assignment");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2002-08-04 16:19:37 +00:00
|
|
|
function assignment_cron () {
|
|
|
|
// Function to be run periodically according to the moodle cron
|
|
|
|
// Finds all assignment notifications that have yet to be mailed out, and mails them
|
|
|
|
|
2002-09-21 08:40:27 +00:00
|
|
|
global $CFG, $USER;
|
2002-08-04 16:19:37 +00:00
|
|
|
|
|
|
|
$cutofftime = time() - $CFG->maxeditingtime;
|
|
|
|
|
2002-12-20 14:44:14 +00:00
|
|
|
if ($submissions = assignment_get_unmailed_submissions($cutofftime)) {
|
2002-08-04 16:19:37 +00:00
|
|
|
$timenow = time();
|
|
|
|
|
|
|
|
foreach ($submissions as $submission) {
|
|
|
|
|
|
|
|
echo "Processing assignment submission $submission->id\n";
|
|
|
|
|
2002-12-23 09:39:26 +00:00
|
|
|
if (! $user = get_record("user", "id", "$submission->userid")) {
|
|
|
|
echo "Could not find user $post->userid\n";
|
2002-08-04 16:19:37 +00:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2002-09-21 07:46:30 +00:00
|
|
|
$USER->lang = $user->lang;
|
|
|
|
|
2002-08-04 16:19:37 +00:00
|
|
|
if (! $course = get_record("course", "id", "$submission->course")) {
|
|
|
|
echo "Could not find course $submission->course\n";
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (! isstudent($course->id, $user->id) and !isteacher($course->id, $user->id)) {
|
2003-11-28 11:06:53 +00:00
|
|
|
echo fullname($user)." not an active participant in $course->shortname\n";
|
2003-03-13 20:59:31 +00:00
|
|
|
continue;
|
2002-08-04 16:19:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (! $teacher = get_record("user", "id", "$submission->teacher")) {
|
|
|
|
echo "Could not find teacher $submission->teacher\n";
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (! $mod = get_coursemodule_from_instance("assignment", $submission->assignment, $course->id)) {
|
|
|
|
echo "Could not find course module for assignment id $submission->assignment\n";
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
$strassignments = get_string("modulenameplural", "assignment");
|
|
|
|
$strassignment = get_string("modulename", "assignment");
|
|
|
|
|
2003-05-13 16:02:08 +00:00
|
|
|
unset($assignmentinfo);
|
2003-11-28 11:06:53 +00:00
|
|
|
$assignmentinfo->teacher = fullname($teacher);
|
2003-05-13 16:02:08 +00:00
|
|
|
$assignmentinfo->assignment = "$submission->name";
|
|
|
|
$assignmentinfo->url = "$CFG->wwwroot/mod/assignment/view.php?id=$mod->id";
|
|
|
|
|
2002-08-04 16:19:37 +00:00
|
|
|
$postsubject = "$course->shortname: $strassignments: $submission->name";
|
|
|
|
$posttext = "$course->shortname -> $strassignments -> $submission->name\n";
|
|
|
|
$posttext .= "---------------------------------------------------------------------\n";
|
2003-05-13 16:02:08 +00:00
|
|
|
$posttext .= get_string("assignmentmail", "assignment", $assignmentinfo);
|
2002-08-04 16:19:37 +00:00
|
|
|
$posttext .= "---------------------------------------------------------------------\n";
|
2003-05-13 16:02:08 +00:00
|
|
|
|
2002-08-04 16:19:37 +00:00
|
|
|
if ($user->mailformat == 1) { // HTML
|
2003-05-13 16:02:08 +00:00
|
|
|
$posthtml = "<p><font face=\"sans-serif\">".
|
|
|
|
"<a href=\"$CFG->wwwroot/course/view.php?id=$course->id\">$course->shortname</a> ->".
|
|
|
|
"<a href=\"$CFG->wwwroot/mod/assignment/index.php?id=$course->id\">$strassignments</a> ->".
|
|
|
|
"<a href=\"$CFG->wwwroot/mod/assignment/view.php?id=$mod->id\">$submission->name</a></font></p>";
|
|
|
|
$posthtml .= "<hr><font face=\"sans-serif\">";
|
|
|
|
$posthtml .= "<p>".get_string("assignmentmailhtml", "assignment", $assignmentinfo)."</p>";
|
|
|
|
$posthtml .= "</font><hr>";
|
2002-08-04 16:19:37 +00:00
|
|
|
} else {
|
2003-05-13 16:02:08 +00:00
|
|
|
$posthtml = "";
|
2002-08-04 16:19:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (! email_to_user($user, $teacher, $postsubject, $posttext, $posthtml)) {
|
|
|
|
echo "Error: assignment cron: Could not send out mail for id $submission->id to user $user->id ($user->email)\n";
|
|
|
|
}
|
|
|
|
if (! set_field("assignment_submissions", "mailed", "1", "id", "$submission->id")) {
|
|
|
|
echo "Could not update the mailed field for id $submission->id\n";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2003-04-26 15:08:34 +00:00
|
|
|
function assignment_print_recent_activity($course, $isteacher, $timestart) {
|
2003-04-26 12:17:30 +00:00
|
|
|
global $CFG;
|
2002-09-22 06:41:56 +00:00
|
|
|
|
|
|
|
$content = false;
|
|
|
|
$assignments = NULL;
|
|
|
|
|
2003-04-26 15:08:34 +00:00
|
|
|
if (!$logs = get_records_select("log", "time > '$timestart' AND ".
|
|
|
|
"course = '$course->id' AND ".
|
|
|
|
"module = 'assignment' AND ".
|
|
|
|
"action = 'upload' ", "time ASC")) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
foreach ($logs as $log) {
|
|
|
|
//Create a temp valid module structure (course,id)
|
|
|
|
$tempmod->course = $log->course;
|
|
|
|
$tempmod->id = $log->info;
|
|
|
|
//Obtain the visible property from the instance
|
|
|
|
$modvisible = instance_is_visible($log->module,$tempmod);
|
|
|
|
|
|
|
|
//Only if the mod is visible
|
|
|
|
if ($modvisible) {
|
|
|
|
$assignments[$log->info] = assignment_log_info($log);
|
|
|
|
$assignments[$log->info]->time = $log->time;
|
|
|
|
$assignments[$log->info]->url = $log->url;
|
2002-09-22 06:41:56 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($assignments) {
|
2003-01-15 10:55:54 +00:00
|
|
|
$strftimerecent = get_string("strftimerecent");
|
2002-09-22 06:41:56 +00:00
|
|
|
$content = true;
|
|
|
|
print_headline(get_string("newsubmissions", "assignment").":");
|
|
|
|
foreach ($assignments as $assignment) {
|
2003-01-15 10:55:54 +00:00
|
|
|
$date = userdate($assignment->time, $strftimerecent);
|
2003-11-28 11:06:53 +00:00
|
|
|
echo "<p><font size=1>$date - ".fullname($assignment)."<br />";
|
2003-04-26 15:08:34 +00:00
|
|
|
echo "\"<a href=\"$CFG->wwwroot/mod/assignment/$assignment->url\">";
|
2002-09-22 06:41:56 +00:00
|
|
|
echo "$assignment->name";
|
2003-04-26 15:08:34 +00:00
|
|
|
echo "</a>\"</font></p>";
|
2002-09-22 06:41:56 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $content;
|
|
|
|
}
|
2002-08-04 16:19:37 +00:00
|
|
|
|
2002-10-17 07:23:51 +00:00
|
|
|
function assignment_grades($assignmentid) {
|
2002-10-17 07:55:54 +00:00
|
|
|
/// Must return an array of grades, indexed by user, and a max grade.
|
2002-10-17 07:23:51 +00:00
|
|
|
|
2003-08-17 12:45:13 +00:00
|
|
|
|
|
|
|
if (!$assignment = get_record("assignment", "id", $assignmentid)) {
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
$grades = get_records_menu("assignment_submissions", "assignment",
|
|
|
|
$assignment->id, "", "userid,grade");
|
|
|
|
|
|
|
|
if ($assignment->grade >= 0) {
|
|
|
|
$return->grades = $grades;
|
2003-08-18 05:33:01 +00:00
|
|
|
$return->maxgrade = $assignment->grade;
|
2003-08-17 12:45:13 +00:00
|
|
|
|
|
|
|
} else {
|
|
|
|
$scaleid = - ($assignment->grade);
|
|
|
|
if ($scale = get_record("scale", "id", $scaleid)) {
|
|
|
|
$scalegrades = make_menu_from_list($scale->scale);
|
2003-11-14 18:34:17 +00:00
|
|
|
if ($grades) {
|
|
|
|
foreach ($grades as $key => $grade) {
|
|
|
|
$grades[$key] = $scalegrades[$grade];
|
|
|
|
}
|
2003-08-17 12:45:13 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
$return->grades = $grades;
|
|
|
|
$return->maxgrade = "";
|
|
|
|
}
|
|
|
|
|
2002-10-17 07:55:54 +00:00
|
|
|
return $return;
|
2002-10-17 07:23:51 +00:00
|
|
|
}
|
|
|
|
|
2003-09-29 15:27:30 +00:00
|
|
|
function assignment_get_participants($assignmentid) {
|
|
|
|
//Returns the users with data in one assignment
|
|
|
|
//(users with records in assignment_submissions, students and teachers)
|
|
|
|
|
|
|
|
global $CFG;
|
|
|
|
|
|
|
|
//Get students
|
|
|
|
$students = get_records_sql("SELECT DISTINCT u.*
|
|
|
|
FROM {$CFG->prefix}user u,
|
|
|
|
{$CFG->prefix}assignment_submissions a
|
|
|
|
WHERE a.assignment = '$assignmentid' and
|
|
|
|
u.id = a.userid");
|
|
|
|
//Get teachers
|
|
|
|
$teachers = get_records_sql("SELECT DISTINCT u.*
|
|
|
|
FROM {$CFG->prefix}user u,
|
|
|
|
{$CFG->prefix}assignment_submissions a
|
|
|
|
WHERE a.assignment = '$assignmentid' and
|
|
|
|
u.id = a.teacher");
|
|
|
|
|
|
|
|
//Add teachers to students
|
|
|
|
if ($teachers) {
|
|
|
|
foreach ($teachers as $teacher) {
|
|
|
|
$students[$teacher->id] = $teacher;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
//Return students array (it contains an array of unique users)
|
|
|
|
return ($students);
|
|
|
|
}
|
|
|
|
|
2002-12-20 14:44:14 +00:00
|
|
|
/// SQL STATEMENTS //////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
function assignment_log_info($log) {
|
|
|
|
global $CFG;
|
|
|
|
return get_record_sql("SELECT a.name, u.firstname, u.lastname
|
|
|
|
FROM {$CFG->prefix}assignment a,
|
|
|
|
{$CFG->prefix}user u
|
|
|
|
WHERE a.id = '$log->info'
|
2002-12-23 09:39:26 +00:00
|
|
|
AND u.id = '$log->userid'");
|
2002-12-20 14:44:14 +00:00
|
|
|
}
|
|
|
|
|
2004-01-30 16:53:01 +00:00
|
|
|
function assignment_count_real_submissions($assignment) {
|
|
|
|
/// Return all real assignment submissions by ENROLLED students (not empty ones)
|
|
|
|
global $CFG;
|
|
|
|
|
|
|
|
return count_records_sql("SELECT count(a.id)
|
|
|
|
FROM {$CFG->prefix}assignment_submissions a,
|
|
|
|
{$CFG->prefix}user_students s,
|
|
|
|
{$CFG->prefix}user u
|
|
|
|
WHERE a.userid = s.userid
|
|
|
|
AND u.id = a.userid
|
|
|
|
AND s.course = '$assignment->course'
|
|
|
|
AND a.assignment = '$assignment->id'
|
|
|
|
AND a.timemodified > 0");
|
|
|
|
}
|
|
|
|
|
2003-04-28 15:52:51 +00:00
|
|
|
function assignment_get_all_submissions($assignment, $sort="", $dir="DESC") {
|
2004-01-30 16:53:01 +00:00
|
|
|
/// Return all assignment submissions by ENROLLED students (even empty)
|
2002-12-20 14:44:14 +00:00
|
|
|
global $CFG;
|
2003-03-21 14:07:25 +00:00
|
|
|
|
|
|
|
if ($sort == "lastname" or $sort == "firstname") {
|
|
|
|
$sort = "u.$sort $dir";
|
|
|
|
} else if (empty($sort)) {
|
|
|
|
$sort = "a.timemodified DESC";
|
|
|
|
} else {
|
|
|
|
$sort = "a.$sort $dir";
|
|
|
|
}
|
2002-12-20 14:44:14 +00:00
|
|
|
return get_records_sql("SELECT a.*
|
|
|
|
FROM {$CFG->prefix}assignment_submissions a,
|
2003-03-21 14:07:25 +00:00
|
|
|
{$CFG->prefix}user_students s,
|
|
|
|
{$CFG->prefix}user u
|
2002-12-23 09:39:26 +00:00
|
|
|
WHERE a.userid = s.userid
|
2003-03-21 14:09:51 +00:00
|
|
|
AND u.id = a.userid
|
2002-12-20 14:44:14 +00:00
|
|
|
AND s.course = '$assignment->course'
|
|
|
|
AND a.assignment = '$assignment->id'
|
2003-03-21 14:07:25 +00:00
|
|
|
ORDER BY $sort");
|
2002-12-20 14:44:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function assignment_get_users_done($assignment) {
|
|
|
|
/// Return list of users who have done an assignment
|
|
|
|
global $CFG;
|
|
|
|
return get_records_sql("SELECT u.*
|
|
|
|
FROM {$CFG->prefix}user u,
|
|
|
|
{$CFG->prefix}user_students s,
|
|
|
|
{$CFG->prefix}assignment_submissions a
|
|
|
|
WHERE s.course = '$assignment->course'
|
2002-12-23 09:39:26 +00:00
|
|
|
AND s.userid = u.id
|
|
|
|
AND u.id = a.userid
|
2002-12-20 14:44:14 +00:00
|
|
|
AND a.assignment = '$assignment->id'
|
|
|
|
ORDER BY a.timemodified DESC");
|
|
|
|
}
|
|
|
|
|
|
|
|
function assignment_get_unmailed_submissions($cutofftime) {
|
2003-03-14 19:58:53 +00:00
|
|
|
/// Return list of marked submissions that have not been mailed out for currently enrolled students
|
2002-12-20 14:44:14 +00:00
|
|
|
global $CFG;
|
|
|
|
return get_records_sql("SELECT s.*, a.course, a.name
|
|
|
|
FROM {$CFG->prefix}assignment_submissions s,
|
2003-03-14 19:58:53 +00:00
|
|
|
{$CFG->prefix}assignment a,
|
|
|
|
{$CFG->prefix}user_students us
|
2002-12-20 14:44:14 +00:00
|
|
|
WHERE s.mailed = 0
|
|
|
|
AND s.timemarked < $cutofftime
|
|
|
|
AND s.timemarked > 0
|
2003-03-14 19:58:53 +00:00
|
|
|
AND s.assignment = a.id
|
|
|
|
AND s.userid = us.userid
|
|
|
|
AND a.course = us.course");
|
2002-12-20 14:44:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2002-08-04 16:19:37 +00:00
|
|
|
//////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
function assignment_file_area_name($assignment, $user) {
|
|
|
|
// Creates a directory file name, suitable for make_upload_directory()
|
2002-08-28 13:07:10 +00:00
|
|
|
global $CFG;
|
|
|
|
|
|
|
|
return "$assignment->course/$CFG->moddata/assignment/$assignment->id/$user->id";
|
2002-08-04 16:19:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function assignment_file_area($assignment, $user) {
|
|
|
|
return make_upload_directory( assignment_file_area_name($assignment, $user) );
|
|
|
|
}
|
|
|
|
|
|
|
|
function assignment_get_submission($assignment, $user) {
|
2003-06-08 06:46:56 +00:00
|
|
|
$submission = get_record("assignment_submissions", "assignment", $assignment->id, "userid", $user->id);
|
|
|
|
if (!empty($submission->timemodified)) {
|
|
|
|
return $submission;
|
2003-06-07 06:23:31 +00:00
|
|
|
}
|
|
|
|
return NULL;
|
2002-08-04 16:19:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function assignment_print_difference($time) {
|
|
|
|
if ($time < 0) {
|
|
|
|
$timetext = get_string("late", "assignment", format_time($time));
|
|
|
|
return " (<FONT COLOR=RED>$timetext</FONT>)";
|
|
|
|
} else {
|
|
|
|
$timetext = get_string("early", "assignment", format_time($time));
|
|
|
|
return " ($timetext)";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function assignment_print_submission($assignment, $user, $submission, $teachers, $grades) {
|
2003-01-06 13:55:37 +00:00
|
|
|
global $THEME, $USER;
|
2002-08-04 16:19:37 +00:00
|
|
|
|
2002-11-06 08:12:06 +00:00
|
|
|
echo "\n<TABLE BORDER=1 CELLSPACING=0 valign=top cellpadding=10 align=center>";
|
2002-08-04 16:19:37 +00:00
|
|
|
|
|
|
|
echo "\n<TR>";
|
2002-11-06 08:12:06 +00:00
|
|
|
if ($assignment->type == OFFLINE) {
|
|
|
|
echo "\n<TD BGCOLOR=\"$THEME->body\" WIDTH=35 VALIGN=TOP>";
|
|
|
|
} else {
|
|
|
|
echo "\n<TD ROWSPAN=2 BGCOLOR=\"$THEME->body\" WIDTH=35 VALIGN=TOP>";
|
|
|
|
}
|
2002-08-04 16:19:37 +00:00
|
|
|
print_user_picture($user->id, $assignment->course, $user->picture);
|
|
|
|
echo "</TD>";
|
2003-11-28 11:06:53 +00:00
|
|
|
echo "<TD NOWRAP BGCOLOR=\"$THEME->cellheading\">".fullname($user, true);
|
2003-11-02 15:11:53 +00:00
|
|
|
if ($assignment->type != OFFLINE and $submission->timemodified) {
|
2002-08-04 16:19:37 +00:00
|
|
|
echo " <FONT SIZE=1>".get_string("lastmodified").": ";
|
|
|
|
echo userdate($submission->timemodified);
|
|
|
|
echo assignment_print_difference($assignment->timedue - $submission->timemodified);
|
|
|
|
echo "</FONT>";
|
|
|
|
}
|
|
|
|
echo "</TR>";
|
|
|
|
|
2002-11-06 08:12:06 +00:00
|
|
|
if ($assignment->type != OFFLINE) {
|
|
|
|
echo "\n<TR><TD BGCOLOR=\"$THEME->cellcontent\">";
|
2002-11-12 05:05:21 +00:00
|
|
|
if ($submission->timemodified) {
|
2002-11-06 08:12:06 +00:00
|
|
|
assignment_print_user_files($assignment, $user);
|
|
|
|
} else {
|
|
|
|
print_string("notsubmittedyet", "assignment");
|
2002-08-04 16:19:37 +00:00
|
|
|
}
|
|
|
|
echo "</TD></TR>";
|
|
|
|
}
|
2002-11-06 08:12:06 +00:00
|
|
|
|
|
|
|
echo "\n<TR>";
|
|
|
|
echo "<TD WIDTH=35 VALIGN=TOP>";
|
|
|
|
if (!$submission->teacher) {
|
|
|
|
$submission->teacher = $USER->id;
|
|
|
|
}
|
|
|
|
print_user_picture($submission->teacher, $assignment->course, $teachers[$submission->teacher]->picture);
|
|
|
|
if ($submission->timemodified > $submission->timemarked) {
|
|
|
|
echo "<TD BGCOLOR=\"$THEME->cellheading2\">";
|
|
|
|
} else {
|
|
|
|
echo "<TD BGCOLOR=\"$THEME->cellheading\">";
|
|
|
|
}
|
2002-12-12 03:14:13 +00:00
|
|
|
echo get_string("feedback", "assignment").":";
|
2003-08-18 04:24:12 +00:00
|
|
|
choose_from_menu($grades, "g$submission->id", $submission->grade, get_string("nograde"));
|
2002-11-06 08:12:06 +00:00
|
|
|
if ($submission->timemarked) {
|
|
|
|
echo " <FONT SIZE=1>".userdate($submission->timemarked)."</FONT>";
|
|
|
|
}
|
|
|
|
echo "<BR><TEXTAREA NAME=\"c$submission->id\" ROWS=6 COLS=60 WRAP=virtual>";
|
|
|
|
p($submission->comment);
|
|
|
|
echo "</TEXTAREA><BR>";
|
|
|
|
echo "</TD></TR>";
|
|
|
|
|
2002-08-04 16:19:37 +00:00
|
|
|
echo "</TABLE><BR CLEAR=ALL>\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
function assignment_print_feedback($course, $submission) {
|
|
|
|
global $CFG, $THEME, $RATING;
|
|
|
|
|
|
|
|
if (! $teacher = get_record("user", "id", $submission->teacher)) {
|
|
|
|
error("Weird assignment error");
|
|
|
|
}
|
|
|
|
|
2002-08-04 17:24:46 +00:00
|
|
|
echo "\n<TABLE BORDER=0 CELLPADDING=1 CELLSPACING=1 ALIGN=CENTER><TR><TD BGCOLOR=#888888>";
|
|
|
|
echo "\n<TABLE BORDER=0 CELLPADDING=3 CELLSPACING=0 VALIGN=TOP>";
|
2002-08-04 16:19:37 +00:00
|
|
|
|
|
|
|
echo "\n<TR>";
|
|
|
|
echo "\n<TD ROWSPAN=3 BGCOLOR=\"$THEME->body\" WIDTH=35 VALIGN=TOP>";
|
|
|
|
print_user_picture($teacher->id, $course->id, $teacher->picture);
|
|
|
|
echo "</TD>";
|
2003-11-28 11:06:53 +00:00
|
|
|
echo "<TD NOWRAP WIDTH=100% BGCOLOR=\"$THEME->cellheading\">".fullname($teacher);
|
2002-08-04 16:19:37 +00:00
|
|
|
echo " <FONT SIZE=2><I>".userdate($submission->timemarked)."</I>";
|
|
|
|
echo "</TR>";
|
|
|
|
|
|
|
|
echo "\n<TR><TD WIDTH=100% BGCOLOR=\"$THEME->cellcontent\">";
|
|
|
|
|
|
|
|
echo "<P ALIGN=RIGHT><FONT SIZE=-1><I>";
|
|
|
|
if ($submission->grade) {
|
|
|
|
echo get_string("grade").": $submission->grade";
|
|
|
|
} else {
|
|
|
|
echo get_string("nograde");
|
|
|
|
}
|
|
|
|
echo "</I></FONT></P>";
|
|
|
|
|
|
|
|
echo text_to_html($submission->comment);
|
|
|
|
echo "</TD></TR></TABLE>";
|
2002-08-04 17:24:46 +00:00
|
|
|
echo "</TD></TR></TABLE>";
|
2002-08-04 16:19:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function assignment_print_user_files($assignment, $user) {
|
|
|
|
// Arguments are objects
|
|
|
|
|
|
|
|
global $CFG;
|
|
|
|
|
|
|
|
$filearea = assignment_file_area_name($assignment, $user);
|
|
|
|
|
|
|
|
if ($basedir = assignment_file_area($assignment, $user)) {
|
|
|
|
if ($files = get_directory_list($basedir)) {
|
|
|
|
foreach ($files as $file) {
|
|
|
|
$icon = mimeinfo("icon", $file);
|
2002-08-26 09:48:00 +00:00
|
|
|
if ($CFG->slasharguments) {
|
|
|
|
$ffurl = "file.php/$filearea/$file";
|
|
|
|
} else {
|
|
|
|
$ffurl = "file.php?file=/$filearea/$file";
|
|
|
|
}
|
|
|
|
|
2004-02-16 09:24:14 +00:00
|
|
|
echo "<img src=\"$CFG->pixpath/f/$icon\" height=16 width=16 border=0 alt=\"file\">";
|
|
|
|
echo " <a target=\"uploadedfile\" href=\"$CFG->wwwroot/$ffurl\">$file</a>";
|
|
|
|
echo "<br />";
|
2002-08-04 16:19:37 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function assignment_delete_user_files($assignment, $user, $exception) {
|
|
|
|
// Deletes all the user files in the assignment area for a user
|
|
|
|
// EXCEPT for any file named $exception
|
|
|
|
|
|
|
|
if ($basedir = assignment_file_area($assignment, $user)) {
|
|
|
|
if ($files = get_directory_list($basedir)) {
|
|
|
|
foreach ($files as $file) {
|
|
|
|
if ($file != $exception) {
|
|
|
|
unlink("$basedir/$file");
|
2004-02-04 09:29:01 +00:00
|
|
|
notify(get_string("existingfiledeleted", "assignment", $file));
|
2002-08-04 16:19:37 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function assignment_print_upload_form($assignment) {
|
|
|
|
// Arguments are objects
|
|
|
|
|
|
|
|
echo "<DIV ALIGN=CENTER>";
|
|
|
|
echo "<FORM ENCTYPE=\"multipart/form-data\" METHOD=\"POST\" ACTION=upload.php>";
|
2003-01-06 13:55:37 +00:00
|
|
|
echo " <INPUT TYPE=hidden NAME=MAX_FILE_SIZE value=\"$assignment->maxbytes\">";
|
2002-08-04 16:19:37 +00:00
|
|
|
echo " <INPUT TYPE=hidden NAME=id VALUE=\"$assignment->id\">";
|
|
|
|
echo " <INPUT NAME=\"newfile\" TYPE=\"file\" size=\"50\">";
|
|
|
|
echo " <INPUT TYPE=submit NAME=save VALUE=\"".get_string("uploadthisfile")."\">";
|
|
|
|
echo "</FORM>";
|
|
|
|
echo "</DIV>";
|
|
|
|
}
|
2002-08-03 02:29:21 +00:00
|
|
|
|
2004-02-20 22:03:57 +00:00
|
|
|
function assignment_get_recent_mod_activity(&$activities, &$index, $sincetime, $courseid, $assignment="0", $user="", $groupid="") {
|
2004-02-15 06:32:54 +00:00
|
|
|
// Returns all assignments since a given time. If assignment is specified then
|
2004-02-06 05:25:34 +00:00
|
|
|
// this restricts the results
|
2004-02-20 22:03:57 +00:00
|
|
|
|
2004-02-06 05:25:34 +00:00
|
|
|
global $CFG;
|
|
|
|
|
|
|
|
if ($assignment) {
|
2004-02-15 06:32:54 +00:00
|
|
|
$assignmentselect = " AND cm.id = '$assignment'";
|
2004-02-06 05:25:34 +00:00
|
|
|
} else {
|
|
|
|
$assignmentselect = "";
|
|
|
|
}
|
|
|
|
if ($user) {
|
|
|
|
$userselect = " AND u.id = '$user'";
|
2004-02-20 22:03:57 +00:00
|
|
|
} else {
|
2004-02-06 05:25:34 +00:00
|
|
|
$userselect = "";
|
|
|
|
}
|
|
|
|
|
2004-02-15 06:32:54 +00:00
|
|
|
$assignments = get_records_sql("SELECT asub.*, u.firstname, u.lastname, u.picture, u.id as userid,
|
2004-02-20 22:03:57 +00:00
|
|
|
a.grade as maxgrade, name, cm.instance, cm.section, a.type
|
2004-02-15 06:32:54 +00:00
|
|
|
FROM {$CFG->prefix}assignment_submissions asub,
|
|
|
|
{$CFG->prefix}user u,
|
|
|
|
{$CFG->prefix}assignment a,
|
|
|
|
{$CFG->prefix}course_modules cm
|
|
|
|
WHERE asub.timemodified > '$sincetime'
|
|
|
|
AND asub.userid = u.id $userselect
|
|
|
|
AND a.id = asub.assignment $assignmentselect
|
|
|
|
AND cm.course = '$courseid'
|
|
|
|
AND cm.instance = a.id
|
|
|
|
ORDER BY asub.timemodified ASC");
|
|
|
|
|
2004-02-20 22:03:57 +00:00
|
|
|
if (empty($assignments))
|
|
|
|
return;
|
2004-02-15 06:32:54 +00:00
|
|
|
|
2004-02-20 22:03:57 +00:00
|
|
|
foreach ($assignments as $assignment) {
|
|
|
|
if (empty($groupid) || ismember($groupid, $assignment->userid)) {
|
|
|
|
|
|
|
|
$tmpactivity->type = "assignment";
|
|
|
|
$tmpactivity->defaultindex = $index;
|
|
|
|
$tmpactivity->instance = $assignment->instance;
|
|
|
|
$tmpactivity->name = $assignment->name;
|
|
|
|
$tmpactivity->section = $assignment->section;
|
2004-02-06 05:25:34 +00:00
|
|
|
|
2004-02-20 22:03:57 +00:00
|
|
|
$tmpactivity->content->grade = $assignment->grade;
|
|
|
|
$tmpactivity->content->maxgrade = $assignment->maxgrade;
|
|
|
|
$tmpactivity->content->type = $assignment->type;
|
2004-02-06 05:25:34 +00:00
|
|
|
|
2004-02-20 22:03:57 +00:00
|
|
|
$tmpactivity->user->userid = $assignment->userid;
|
|
|
|
$tmpactivity->user->fullname = fullname($assignment);
|
|
|
|
$tmpactivity->user->picture = $assignment->picture;
|
2004-02-06 05:25:34 +00:00
|
|
|
|
2004-02-20 22:03:57 +00:00
|
|
|
$tmpactivity->timestamp = $assignment->timemodified;
|
2004-02-15 06:32:54 +00:00
|
|
|
|
2004-02-20 22:03:57 +00:00
|
|
|
$activities[] = $tmpactivity;
|
2004-02-15 06:32:54 +00:00
|
|
|
|
2004-02-20 22:03:57 +00:00
|
|
|
$index++;
|
|
|
|
}
|
|
|
|
}
|
2004-02-15 06:32:54 +00:00
|
|
|
|
2004-02-20 22:03:57 +00:00
|
|
|
return;
|
2004-02-15 06:32:54 +00:00
|
|
|
}
|
|
|
|
|
2004-02-20 22:03:57 +00:00
|
|
|
function assignment_print_recent_mod_activity($activity, $course, $detail=false) {
|
2004-02-06 05:25:34 +00:00
|
|
|
global $CFG, $THEME;
|
|
|
|
|
2004-02-15 06:32:54 +00:00
|
|
|
echo '<table border="0" cellpadding="3" cellspacing="0">';
|
2004-02-06 05:25:34 +00:00
|
|
|
|
2004-02-15 06:32:54 +00:00
|
|
|
echo "<tr><td bgcolor=\"$THEME->cellcontent2\" class=\"forumpostpicture\" width=\"35\" valign=\"top\">";
|
|
|
|
print_user_picture($activity->user->userid, $course, $activity->user->picture);
|
|
|
|
echo "</td><td width=\"100%\"><font size=2>";
|
2004-02-06 05:25:34 +00:00
|
|
|
|
|
|
|
|
2004-02-15 06:32:54 +00:00
|
|
|
if ($detail) {
|
|
|
|
echo "<img src=\"$CFG->modpixpath/$activity->type/icon.gif\" ".
|
|
|
|
"height=16 width=16 alt=\"$activity->type\"> ";
|
|
|
|
echo "<a href=\"$CFG->wwwroot/mod/assignment/view.php?id=" . $activity->instance . "\">"
|
|
|
|
. $activity->name . "</a> - ";
|
2004-02-06 05:25:34 +00:00
|
|
|
|
2004-02-15 06:32:54 +00:00
|
|
|
}
|
2004-02-06 05:25:34 +00:00
|
|
|
|
2004-02-15 06:32:54 +00:00
|
|
|
if (isteacher($USER)) {
|
|
|
|
$grades = "(" . $activity->content->grade . " / " . $activity->content->maxgrade . ") ";
|
2004-02-06 05:25:34 +00:00
|
|
|
|
2004-02-15 06:32:54 +00:00
|
|
|
$assignment->id = $activity->instance;
|
|
|
|
$assignment->course = $course;
|
|
|
|
$user->id = $activity->user->userid;
|
2004-02-06 05:25:34 +00:00
|
|
|
|
2004-02-20 22:03:57 +00:00
|
|
|
echo $grades;
|
|
|
|
if ($activity->content->type == UPLOADSINGLE) {
|
|
|
|
$file = assignment_get_user_file($assignment, $user);
|
|
|
|
echo "<img src=\"$CFG->pixpath/f/$file->icon\" height=16 width=16 border=0 alt=\"file\">";
|
|
|
|
echo " <a target=\"uploadedfile\" HREF=\"$CFG->wwwroot/$file->url\">$file->name</A>";
|
|
|
|
}
|
|
|
|
echo "<br>";
|
2004-02-15 06:32:54 +00:00
|
|
|
}
|
|
|
|
echo "<a href=\"$CFG->wwwroot/user/view.php?id="
|
|
|
|
. $activity->user->userid . "&course=$course\">"
|
|
|
|
. $activity->user->fullname . "</a> ";
|
2004-02-06 05:25:34 +00:00
|
|
|
|
2004-02-15 06:32:54 +00:00
|
|
|
echo " - " . userdate($activity->timestamp);
|
2004-02-06 05:25:34 +00:00
|
|
|
|
2004-02-15 06:32:54 +00:00
|
|
|
echo "</font></td></tr>";
|
|
|
|
echo "</table>";
|
2004-02-06 05:25:34 +00:00
|
|
|
|
2004-02-15 06:32:54 +00:00
|
|
|
return;
|
|
|
|
}
|
2004-02-06 05:25:34 +00:00
|
|
|
|
2004-02-15 06:32:54 +00:00
|
|
|
function assignment_get_user_file($assignment, $user) {
|
|
|
|
global $CFG;
|
|
|
|
|
|
|
|
$tmpfile = "";
|
|
|
|
|
|
|
|
$filearea = assignment_file_area_name($assignment, $user);
|
|
|
|
|
|
|
|
if ($basedir = assignment_file_area($assignment, $user)) {
|
|
|
|
if ($files = get_directory_list($basedir)) {
|
|
|
|
foreach ($files as $file) {
|
|
|
|
$icon = mimeinfo("icon", $file);
|
|
|
|
if ($CFG->slasharguments) {
|
|
|
|
$ffurl = "file.php/$filearea/$file";
|
|
|
|
} else {
|
|
|
|
$ffurl = "file.php?file=/$filearea/$file";
|
|
|
|
}
|
|
|
|
$tmpfile->url = $ffurl;
|
|
|
|
$tmpfile->name = $file;
|
|
|
|
$tmpfile->icon = $icon;
|
|
|
|
}
|
|
|
|
}
|
2004-02-06 05:25:34 +00:00
|
|
|
}
|
2004-02-15 06:32:54 +00:00
|
|
|
return $tmpfile;
|
2004-02-06 05:25:34 +00:00
|
|
|
}
|
2004-02-15 06:32:54 +00:00
|
|
|
|
2002-08-03 02:29:21 +00:00
|
|
|
?>
|