mirror of
https://github.com/moodle/moodle.git
synced 2025-01-19 06:18:28 +01:00
ebc3bd2b24
Moodle tables. ie user -> userid in many tables, plus in user_students start -> starttime and end -> endtime I've just done all this as carefully as I could ... I don't think I missed anything but it's pretty intensive work and I'd be fooling myself if I didn't think I'd missed a couple. Note that this version should pretty much be able to bootstrap itself using PostgreSQL now ... but this is untested
188 lines
6.2 KiB
PHP
188 lines
6.2 KiB
PHP
<?PHP // $Id$
|
|
// Admin-only script to assign teachers to courses
|
|
|
|
require("../config.php");
|
|
require("../user/lib.php");
|
|
|
|
optional_variable($id); // course id
|
|
|
|
if (! $site = get_site()) {
|
|
redirect("$CFG->wwwroot/admin/");
|
|
}
|
|
|
|
require_login();
|
|
|
|
if (!isadmin()) {
|
|
error("You must be an administrator to use this page.");
|
|
}
|
|
|
|
$strassignteachers = get_string("assignteachers");
|
|
$stradministration = get_string("administration");
|
|
$strexistingteachers = get_string("existingteachers");
|
|
$strnoexistingteachers = get_string("noexistingteachers");
|
|
$strpotentialteachers = get_string("potentialteachers");
|
|
$strnopotentialteachers = get_string("nopotentialteachers");
|
|
$straddteacher = get_string("addteacher");
|
|
$strremoveteacher = get_string("removeteacher");
|
|
$strsearch = get_string("search");
|
|
$strsearchagain = get_string("searchagain");
|
|
$strtoomanytoshow = get_string("toomanytoshow");
|
|
|
|
if (!$id) {
|
|
print_header("$site->shortname: $strassignteachers", "$site->fullname",
|
|
"<A HREF=\"$CFG->wwwroot/admin\">$stradministration</A> -> $strassignteachers");
|
|
|
|
if ($courses = get_courses()) {
|
|
|
|
print_heading(get_string("choosecourse"));
|
|
print_simple_box_start("CENTER");
|
|
foreach ($courses as $course) {
|
|
echo "<A HREF=\"teacher.php?id=$course->id\">$course->fullname</A><BR>";
|
|
}
|
|
print_simple_box_end();
|
|
} else {
|
|
print_heading(get_string("nocoursesyet"));
|
|
print_continue("$CFG->wwwroot/admin/");
|
|
}
|
|
print_footer();
|
|
exit;
|
|
}
|
|
|
|
if (! $course = get_record("course", "id", $id)) {
|
|
error("Course ID was incorrect (can't find it)");
|
|
}
|
|
|
|
|
|
print_header("$site->shortname: $course->shortname: $strassignteachers",
|
|
"$site->fullname",
|
|
"<A HREF=\"$CFG->wwwroot/admin\">$stradministration</A> ->
|
|
<A HREF=\"teacher.php\">$strassignteachers</A> ->
|
|
$course->shortname", "");
|
|
print_heading("<A HREF=\"$CFG->wwwroot/course/view.php?id=$course->id\">$course->fullname</A>");
|
|
|
|
|
|
/// Get all existing teachers for this course.
|
|
$teachers = get_course_teachers($course->id);
|
|
|
|
/// Add a teacher if one is specified
|
|
|
|
if ($add) {
|
|
if (! $user = get_record("user", "id", $add)) {
|
|
error("That teacher (id = $add) doesn't exist", "teacher.php?id=$course->id");
|
|
}
|
|
|
|
if ($teachers) {
|
|
foreach ($teachers as $tt) {
|
|
if ($tt->id == $user->id) {
|
|
error("That user is already a teacher for this course.", "teacher.php?id=$course->id");
|
|
}
|
|
}
|
|
}
|
|
|
|
$teacher->userid = $user->id;
|
|
$teacher->course = $course->id;
|
|
if ($teachers) {
|
|
$teacher->authority = 2;
|
|
} else {
|
|
$teacher->authority = 1; // First teacher is the main teacher
|
|
}
|
|
$teacher->id = insert_record("user_teachers", $teacher);
|
|
if (! $teacher->id) {
|
|
error("Could not add that teacher to this course!");
|
|
}
|
|
$teachers[] = $user;
|
|
}
|
|
|
|
/// Remove a teacher if one is specified.
|
|
|
|
if ($remove) {
|
|
if (! $user = get_record("user", "id", $remove)) {
|
|
error("That teacher (id = $remove) doesn't exist", "teacher.php?id=$course->id");
|
|
}
|
|
if ($teachers) {
|
|
foreach ($teachers as $key => $tt) {
|
|
if ($tt->id == $user->id) {
|
|
remove_teacher($user->id, $course->id);
|
|
unset($teachers[$key]);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
/// Print the lists of existing and potential teachers
|
|
|
|
echo "<TABLE CELLPADDING=2 CELLSPACING=10 ALIGN=CENTER>";
|
|
echo "<TR><TH WIDTH=50%>$strexistingteachers</TH><TH WIDTH=50%>$strpotentialteachers</TH></TR>";
|
|
echo "<TR><TD WIDTH=50% NOWRAP VALIGN=TOP>";
|
|
|
|
/// First, show existing teachers for this course
|
|
|
|
if (! $teachers) {
|
|
echo "<P ALIGN=CENTER>$strnoexistingteachers</A>";
|
|
|
|
} else {
|
|
foreach ($teachers as $teacher) {
|
|
echo "<P ALIGN=right>$teacher->firstname $teacher->lastname, $teacher->email <A HREF=\"teacher.php?id=$course->id&remove=$teacher->id\" TITLE=\"$strremoveteacher\"><IMG SRC=\"../pix/t/right.gif\" BORDER=0></A></P>";
|
|
}
|
|
}
|
|
|
|
echo "<TD WIDTH=50% NOWRAP VALIGN=TOP>";
|
|
|
|
/// Print list of potential teachers
|
|
|
|
if ($search) {
|
|
$users = get_users_search($search);
|
|
} else {
|
|
$users = get_users_confirmed();
|
|
}
|
|
|
|
|
|
if ($users) {
|
|
foreach ($users as $user) { // Remove users who are already teachers
|
|
if ($teachers) {
|
|
foreach ($teachers as $teacher) {
|
|
if ($teacher->id == $user->id) {
|
|
continue 2;
|
|
}
|
|
}
|
|
}
|
|
$potential[] = $user;
|
|
}
|
|
}
|
|
|
|
if (! $potential) {
|
|
echo "<P ALIGN=CENTER>$strnopotentialteachers</A>";
|
|
if ($search) {
|
|
echo "<FORM ACTION=teacher.php METHOD=GET>";
|
|
echo "<INPUT TYPE=hidden NAME=id VALUE=\"$course->id\">";
|
|
echo "<INPUT TYPE=text NAME=search SIZE=20>";
|
|
echo "<INPUT TYPE=submit VALUE=\"$strsearchagain\">";
|
|
echo "</FORM>";
|
|
}
|
|
|
|
} else {
|
|
if ($search) {
|
|
echo "<P ALIGN=CENTER>($strsearchresults)</P>";
|
|
}
|
|
if (count($potential) <= 20) {
|
|
foreach ($potential as $user) {
|
|
echo "<P ALIGN=LEFT><A HREF=\"teacher.php?id=$course->id&add=$user->id\" TITLE=\"$straddteacher\"><IMG SRC=\"../pix/t/left.gif\" BORDER=0></A> $user->firstname $user->lastname, $user->email";
|
|
}
|
|
} else {
|
|
echo "<P ALIGN=CENTER>There are too many users to show.<BR>";
|
|
echo "Enter a search word here.";
|
|
echo "<FORM ACTION=teacher.php METHOD=GET>";
|
|
echo "<INPUT TYPE=hidden NAME=id VALUE=\"$course->id\">";
|
|
echo "<INPUT TYPE=text NAME=search SIZE=20>";
|
|
echo "<INPUT TYPE=submit VALUE=\"$strsearch\">";
|
|
echo "</FORM>";
|
|
}
|
|
}
|
|
|
|
echo "</TR></TABLE>";
|
|
|
|
print_footer();
|
|
|
|
?>
|