2001-11-22 06:23:56 +00:00
|
|
|
<?PHP // $Id$
|
|
|
|
|
|
|
|
$RATING = array ("3" => "Outstanding",
|
|
|
|
"2" => "Satisfactory",
|
|
|
|
"1" => "Not satisfactory");
|
|
|
|
|
2002-07-25 13:48:14 +00:00
|
|
|
|
|
|
|
function journal_user_summary($course, $user, $mod, $journal) {
|
|
|
|
global $CFG;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function journal_user_outline($course, $user, $mod, $journal) {
|
|
|
|
if ($entry = get_record_sql("SELECT * FROM journal_entries
|
|
|
|
WHERE user='$user->id' AND journal='$journal->id'")) {
|
|
|
|
|
|
|
|
$numwords = count(preg_split("/\w\b/", $entry->text)) - 1;
|
|
|
|
|
|
|
|
$result->info = "$numwords words";
|
|
|
|
$result->time = $entry->modified;
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function journal_user_complete($course, $user, $mod, $journal) {
|
|
|
|
global $CFG, $THEME;
|
|
|
|
|
|
|
|
if ($entry = get_record_sql("SELECT * FROM journal_entries
|
|
|
|
WHERE user='$user->id' AND journal='$journal->id'")) {
|
|
|
|
|
|
|
|
print_simple_box_start();
|
|
|
|
if ($entry->modified) {
|
|
|
|
echo "<P><FONT SIZE=1>Last edited: ".userdate($entry->modified)."</FONT></P>";
|
|
|
|
}
|
|
|
|
if ($entry->text) {
|
|
|
|
echo text_to_html($entry->text);
|
|
|
|
}
|
|
|
|
if ($entry->teacher) {
|
|
|
|
$teacher = get_record("user", "id", $entry->teacher);
|
|
|
|
|
|
|
|
echo "\n<BR CLEAR=ALL>";
|
|
|
|
echo "<TABLE><TR>";
|
|
|
|
echo "<TD WIDTH=35 VALIGN=TOP>";
|
|
|
|
print_user_picture($entry->teacher, $course->id, $teacher->picture);
|
|
|
|
echo "<TD BGCOLOR=\"$THEME->cellheading\">".$RATING[$entry->rating];
|
|
|
|
if ($entry->timemarked) {
|
|
|
|
echo " <FONT SIZE=1>".userdate($entry->timemarked)."</FONT>";
|
|
|
|
}
|
|
|
|
echo "<P ALIGN=RIGHT><FONT SIZE=-1><I>";
|
|
|
|
if ($RATING[$entry->rating]) {
|
|
|
|
echo "Overall rating: ";
|
|
|
|
echo $RATING[$entry->rating];
|
|
|
|
} else {
|
|
|
|
echo "No rating given";
|
|
|
|
}
|
|
|
|
echo "</I></FONT></P>";
|
|
|
|
|
|
|
|
echo "<BR><FONT COLOR=#000055>";
|
|
|
|
echo text_to_html($entry->comment);
|
|
|
|
echo "</FONT><BR>";
|
|
|
|
echo "</TD></TR></TABLE>";
|
|
|
|
}
|
|
|
|
print_simple_box_end();
|
|
|
|
|
|
|
|
} else {
|
|
|
|
echo "No entry";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2002-07-27 06:58:39 +00:00
|
|
|
|
|
|
|
function journal_cron () {
|
|
|
|
// Function to be run periodically according to the moodle cron
|
|
|
|
// Finds all journal notifications that have yet to be mailed out, and mails them
|
|
|
|
|
|
|
|
global $CFG;
|
|
|
|
|
|
|
|
echo "Processing journals...\n";
|
|
|
|
|
|
|
|
$cutofftime = time() - $CFG->maxeditingtime;
|
|
|
|
|
2002-07-27 07:22:20 +00:00
|
|
|
if ($entries = get_records_sql("SELECT e.*, j.course, j.name
|
2002-07-27 06:58:39 +00:00
|
|
|
FROM journal_entries e, journal j
|
2002-07-27 07:22:20 +00:00
|
|
|
WHERE e.mailed = '0'
|
|
|
|
AND e.timemarked < '$cutofftime' AND e.timemarked > 0
|
2002-07-27 06:58:39 +00:00
|
|
|
AND e.journal = j.id")) {
|
|
|
|
$timenow = time();
|
|
|
|
|
|
|
|
foreach ($entries as $entry) {
|
|
|
|
|
|
|
|
echo "Processing journal entry $entry->id\n";
|
|
|
|
|
|
|
|
if (! $user = get_record("user", "id", "$entry->user")) {
|
|
|
|
echo "Could not find user $post->user\n";
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2002-07-27 07:22:20 +00:00
|
|
|
if (! $course = get_record("course", "id", "$entry->course")) {
|
|
|
|
echo "Could not find course $entry->course\n";
|
2002-07-27 06:58:39 +00:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2002-07-27 07:22:20 +00:00
|
|
|
if (! isstudent($course->id, $user->id) and !isteacher($course->id, $user->id)) {
|
|
|
|
continue; // Not an active participant
|
|
|
|
}
|
|
|
|
|
|
|
|
if (! $teacher = get_record("user", "id", "$entry->teacher")) {
|
|
|
|
echo "Could not find teacher $entry->teacher\n";
|
2002-07-27 06:58:39 +00:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2002-07-27 07:22:20 +00:00
|
|
|
|
2002-07-27 06:58:39 +00:00
|
|
|
if (! $mod = get_coursemodule_from_instance("journal", $entry->journal, $course->id)) {
|
|
|
|
echo "Could not find course module for journal id $entry->journal\n";
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
$postsubject = "$course->shortname: Journal feedback: $entry->name";
|
|
|
|
$posttext = "$course->shortname -> Journals -> $entry->name\n";
|
|
|
|
$posttext .= "---------------------------------------------------------------------\n";
|
|
|
|
$posttext .= "$teacher->firstname $teacher->lastname has posted some feedback on your\n";
|
|
|
|
$posttext .= "journal entry for '$entry->name'\n\n";
|
|
|
|
$posttext .= "You can see it appended to your journal entry:\n";
|
|
|
|
$posttext .= " $CFG->wwwroot/mod/journal/view.php?id=$mod->id\n";
|
|
|
|
$posttext .= "---------------------------------------------------------------------\n";
|
|
|
|
if ($user->mailformat == 1) { // HTML
|
|
|
|
$posthtml = "<P><FONT FACE=sans-serif>".
|
|
|
|
"<A HREF=\"$CFG->wwwroot/course/view.php?id=$course->id\">$course->shortname</A> ->".
|
|
|
|
"<A HREF=\"$CFG->wwwroot/mod/journal/index.php?id=$course->id\">Journals</A> ->".
|
|
|
|
"<A HREF=\"$CFG->wwwroot/mod/journal/view.php?id=$mod->id\">$entry->name</A></FONT></P>";
|
|
|
|
$posthtml .= "<HR><FONT FACE=sans-serif>";
|
|
|
|
$posthtml .= "<P>$teacher->firstname $teacher->lastname has posted some feedback on your";
|
|
|
|
$posthtml .= " journal entry for '<B>$entry->name</B>'</P>";
|
|
|
|
$posthtml .= "<P>You can see it <A HREF=\"$CFG->wwwroot/mod/journal/view.php?id=$mod->id\">";
|
|
|
|
$posthtml .= "appended to your journal entry</A>.</P></FONT><HR>";
|
|
|
|
} else {
|
|
|
|
$posthtml = "";
|
|
|
|
}
|
|
|
|
|
|
|
|
if (! email_to_user($user, $teacher, $postsubject, $posttext, $posthtml)) {
|
|
|
|
echo "Error: Journal cron: Could not send out mail for id $entry->id to user $user->id ($user->email)\n";
|
|
|
|
}
|
|
|
|
if (! set_field("journal_entries", "mailed", "1", "id", "$entry->id")) {
|
|
|
|
echo "Could not update the mailed field for id $entry->id\n";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2002-07-29 07:21:36 +00:00
|
|
|
function journal_get_users_done($course, $journal) {
|
|
|
|
return get_records_sql("SELECT u.* FROM user u, user_students s, user_teachers t, journal_entries j
|
|
|
|
WHERE ((s.course = '$course->id' AND s.user = u.id) OR
|
|
|
|
(t.course = '$course->id' AND t.user = u.id))
|
|
|
|
AND u.id = j.user AND j.journal = '$journal->id'
|
|
|
|
ORDER BY j.modified DESC");
|
|
|
|
}
|
|
|
|
|
|
|
|
function journal_print_user_entry($course, $user, $entry, $teachers) {
|
|
|
|
global $THEME;
|
|
|
|
|
|
|
|
echo "\n<TABLE BORDER=1 CELLSPACING=0 valign=top cellpadding=10>";
|
|
|
|
|
|
|
|
echo "\n<TR>";
|
|
|
|
echo "\n<TD ROWSPAN=2 BGCOLOR=\"$THEME->body\" WIDTH=35 VALIGN=TOP>";
|
|
|
|
print_user_picture($user->id, $course->id, $user->picture);
|
|
|
|
echo "</TD>";
|
|
|
|
echo "<TD NOWRAP WIDTH=100% BGCOLOR=\"$THEME->cellheading\">$user->firstname $user->lastname";
|
|
|
|
if ($entry) {
|
|
|
|
echo " <FONT SIZE=1>Last edited: ".userdate($entry->modified)."</FONT>";
|
|
|
|
}
|
|
|
|
echo "</TR>";
|
|
|
|
|
|
|
|
echo "\n<TR><TD WIDTH=100% BGCOLOR=\"$THEME->cellcontent\">";
|
|
|
|
if ($entry) {
|
|
|
|
echo text_to_html($entry->text);
|
|
|
|
} else {
|
|
|
|
echo "No entry";
|
|
|
|
}
|
|
|
|
echo "</TD></TR>";
|
|
|
|
|
|
|
|
if ($entry) {
|
|
|
|
echo "\n<TR>";
|
|
|
|
echo "<TD WIDTH=35 VALIGN=TOP>";
|
|
|
|
if (!$entry->teacher) {
|
|
|
|
$entry->teacher = $USER->id;
|
|
|
|
}
|
|
|
|
print_user_picture($entry->teacher, $course->id, $teachers[$entry->teacher]->picture);
|
|
|
|
echo "<TD BGCOLOR=\"$THEME->cellheading\">Teacher Feedback:";
|
|
|
|
choose_from_menu($RATING, "r$entry->id", $entry->rating, "Rate...");
|
|
|
|
if ($entry->timemarked) {
|
|
|
|
echo " <FONT SIZE=1>".userdate($entry->timemarked)."</FONT>";
|
|
|
|
}
|
2002-07-29 07:26:59 +00:00
|
|
|
echo "<BR><TEXTAREA NAME=\"c$entry->id\" ROWS=6 COLS=60 WRAP=virtual>";
|
2002-07-29 07:21:36 +00:00
|
|
|
p($entry->comment);
|
|
|
|
echo "</TEXTAREA><BR>";
|
|
|
|
echo "</TD></TR>";
|
|
|
|
}
|
|
|
|
echo "</TABLE><BR CLEAR=ALL>\n";
|
|
|
|
}
|
2002-07-27 06:58:39 +00:00
|
|
|
|
2001-11-22 06:23:56 +00:00
|
|
|
?>
|