moodle/mod/glossary/view.php
willcast c76e673ab5 - Cleaning a lot of code in edit.php and view.php
- Removing more notices when debug is ON
- Added a new feature: Now the entries have a default approval status... Not approved entries are shown on a teachers-only frame from which they can be approved or not prior to be visible by everyone.
2003-10-21 04:55:22 +00:00

402 lines
16 KiB
PHP
Raw Blame History

<?php // $Id$
/// This page prints a particular instance of glossary
require_once("../../config.php");
require_once("lib.php");
require_variable($id); // Course Module ID
optional_variable($l,""); // letter to look for
optional_variable($eid); // Entry ID
optional_variable($search, ""); // search string
optional_variable($includedefinition); // include definition in search function?
optional_variable($tab); // browsing entries by categories?
optional_variable($cat); // categoryID
optional_variable($sortkey,""); // Sorted view: CREATION or UPDATE
optional_variable($sortorder,""); // it define the order of the sorting (ASC or DESC)
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 (! $glossary = get_record("glossary", "id", $cm->instance)) {
error("Course module is incorrect");
}
require_login($course->id);
if (!$cm->visible and !isteacher($course->id)) {
notice(get_string("activityiscurrentlyhidden"));
}
add_to_log($course->id, "glossary", "view", "view.php?id=$cm->id", "$glossary->id");
/// checking for valid values for sortorder and sortkey
if ( $sortorder = strtolower($sortorder) ) {
if ($sortorder != "asc" and $sortorder != "desc") {
$sortorder = "";
} else {
$l = "";
$search ="";
}
}
if ( $sortkey = strtoupper($sortkey) ) {
if ($sortkey != "CREATION" and $sortkey != "UPDATE") {
$sortkey = "";
}
}
if ( $sortkey or $glossary->displayformat == GLOSSARY_FORMAT_CONTINUOUS) {
if ( !$sortkey and $glossary->displayformat == GLOSSARY_FORMAT_CONTINUOUS) {
$sortkey = "CREATION";
$sortorder = "asc";
}
if ( !$sortorder ) {
$sortorder = "asc";
}
if ($sortkey == "CREATION") {
$orderby = "timecreated $sortorder";
} else {
$orderby = "timemodified $sortorder";
}
} else {
$orderby = "concept ASC";
}
// creating matrix of words to search if apply
$search = trim(strip_tags($search));
if ($search and !$eid) {
$l = "";
$searchterms = explode(" ", $search); // Search for words independently
foreach ($searchterms as $key => $searchterm) {
if (strlen($searchterm) < 2) {
unset($searchterms[$key]);
}
}
$search = trim(implode(" ", $searchterms));
$tab = GLOSSARY_STANDARD_VIEW;
} elseif ($eid) {
$search = "";
}
$alphabet = explode("|", get_string("alphabet","glossary"));
if ($l == "" and $search == "" and $sortkey == "" and !$eid) {
// if the user is just entering the glossary...
$l = $alphabet[0];
} elseif ($eid) {
$l = "";
}
$category = "";
if ($tab == GLOSSARY_CATEGORY_VIEW) {
$l = "";
if ($cat > 0) {
$category = get_record("glossary_categories", "id", $cat);
if (!$category) {
$cat = "";
}
}
}
/// Printing the page header
if ($course->category) {
$navigation = "<a href=\"../../course/view.php?id=$course->id\">$course->shortname</a> ->";
}
$strglossaries = get_string("modulenameplural", "glossary");
$strglossary = get_string("modulename", "glossary");
$strallcategories = get_string("allcategories", "glossary");
$straddentry = get_string("addentry", "glossary");
$strnoentries = get_string("noentries", "glossary");
$strsearchconcept = get_string("searchconcept", "glossary");
$strsearchindefinition = get_string("searchindefinition", "glossary");
$strsearch = get_string("search");
print_header(strip_tags("$course->shortname: $glossary->name"), "$course->fullname",
"$navigation <A HREF=index.php?id=$course->id>$strglossaries</A> -> $glossary->name",
"", "", true, update_module_button($cm->id, $course->id, $strglossary),
navmenu($course, $cm));
print_heading($glossary->name);
/// Info box
if ( $glossary->intro ) {
print_simple_box_start("center","70%");
echo '<p align="center">';
echo $glossary->intro;
echo '</p>';
print_simple_box_end();
}
/// Add button
if (!isguest()) {
if ( isteacher($course->id) or $glossary->studentcanpost ) {
$options = array ("id" => "$cm->id");
echo '<center><p>';
print_single_button("edit.php", $options, $straddentry);
echo '</p></center><p>';
}
}
/// Search box
print_simple_box_start("center", "", $THEME->cellheading);
echo '<p>';
echo '<form method="POST" action="view.php">';
echo '<input type="submit" value="'.$strsearch.'" name="searchbutton"> ';
echo '<input type="text" name="search" size="20" value=""> ';
echo '<input type="checkbox" name="includedefinition" value="1">';
echo $strsearchindefinition;
echo '<input type="hidden" name="id" value="'.$cm->id.'">';
echo '</form>';
echo '</p>';
print_simple_box_end();
/// Tabbed browsing sections
$glossary_tCFG->TabTableBGColor = $THEME->cellheading;
$glossary_tCFG->ActiveTabColor = $THEME->cellheading;
$glossary_tCFG->InactiveTabColor = $THEME->cellcontent2;
$glossary_tCFG->InactiveFontColor= $THEME->hidden;
$glossary_tCFG->TabTableWidth = "70%";
$glossary_tCFG->TabsPerRow = 5;
$glossary_tCFG->TabSeparation = 4;
echo '<p align="center">';
$data[0]->link = "view.php?id=$id";
$data[0]->caption = get_string("standardview", "glossary");
$data[1]->link = "view.php?id=$id&tab=".GLOSSARY_CATEGORY_VIEW;
$data[1]->caption = get_string("categoryview", "glossary");
if (isteacher($course->id)) {
$data[2]->link = "view.php?id=$id&tab=".GLOSSARY_APPROVAL_VIEW;
$data[2]->caption = get_string("waitingapproval", "glossary");
}
if ($tab == GLOSSARY_APPROVAL_VIEW and !isteacher($course->id)) {
$tab = GLOSSARY_STANDARD_VIEW;
}
/// printing header of the current tab
echo "<center>";
glossary_print_tabbed_table_start($data, $tab, $glossary_tCFG);
switch ($tab) {
case GLOSSARY_CATEGORY_VIEW:
glossary_print_categories_menu($course, $cm, $glossary, $cat, $category);
break;
case GLOSSARY_APPROVAL_VIEW:
glossary_print_approval_menu($cm, $glossary, $l, $sortkey, $sortorder,$tab);
break;
case GLOSSARY_STANDARD_VIEW:
default:
glossary_print_alphabet_menu($cm, $glossary, $l, $sortkey, $sortorder,$tab);
if ($search) {
echo "<h3>$strsearch: $search</h3>";
}
break;
}
echo "<hr>";
/// Printing the entries
switch ($tab) {
case GLOSSARY_CATEGORY_VIEW:
if ($cat == GLOSSARY_SHOW_ALL_CATEGORIES) {
$sql = "SELECT gec.id gecid, gc.name, gc.id CID, ge.*
FROM {$CFG->prefix}glossary_entries ge,
{$CFG->prefix}glossary_entries_categories gec,
{$CFG->prefix}glossary_categories gc
WHERE (ge.glossaryid = '$glossary->id' or ge.sourceglossaryid = '$glossary->id') AND
gec.entryid = ge.id AND
gc.id = gec.categoryid";
if ( $glossary->displayformat == GLOSSARY_FORMAT_CONTINUOUS ) {
$sql .= " ORDER BY gc.name, ge.timecreated";
} else {
$sql .= " ORDER BY gc.name, ge.concept";
}
$allentries = get_records_sql($sql);
} else {
if ( $cat == GLOSSARY_SHOW_NOT_CATEGORISED ) {
$allentries = glossary_get_entries_sorted($glossary, "",$orderby);
} else {
$allentries = glossary_get_entries_by_category($glossary, $cat, "",$orderby);
}
}
$currentcategory = "";
break;
case GLOSSARY_APPROVAL_VIEW:
$allentries = glossary_get_entries_sorted($glossary, "approved = 0",$orderby);
$currentletter = "";
break;
case GLOSSARY_STANDARD_VIEW:
if ($search) { // looking for a term
$allentries = glossary_search_entries($searchterms, $glossary, $includedefinition);
} elseif ($eid) { // looking for an entry
$allentries = get_records_select("glossary_entries", "id = $eid");
} elseif ( $l or $sortkey ) {
$where = "";
if ($l != "ALL" and $l != "SPECIAL") {
switch ($CFG->dbtype) {
case "postgres7":
$where = "substr(ucase(concept),1," . strlen($l) . ") = '" . strtoupper($l) . "'";
break;
case "mysql":
$where = "left(ucase(concept)," . strlen($l) . ") = '$l'";
break;
default:
$where = "";
}
}
$allentries = glossary_get_entries_sorted($glossary, $where,$orderby);
}
$currentletter = "";
break;
}
$dumpeddefinitions = 0;
if ($allentries) {
if ($glossary->displayformat == GLOSSARY_FORMAT_CONTINUOUS) {
echo "<table border=0 cellspacing=0 width=95% valign=top cellpadding=5><tr><td align=left bgcolor=\"#FFFFFF\">";
}
foreach ($allentries as $entry) {
$dumptoscreen = 0;
$firstletter = strtoupper(substr(ltrim($entry->concept), 0, strlen($l)));
if ($l) {
if ($l == "ALL" or $sortkey == "CREATION" or $sortkey == "UPDATE" or $firstletter == $l) {
if ($currentletter != $firstletter[0]) {
if ($entry->approved or $USER->id == $entry->userid or $tab == GLOSSARY_APPROVAL_VIEW) {
$currentletter = $firstletter[0];
if ($glossary->displayformat == GLOSSARY_FORMAT_SIMPLE) {
if ($dumpeddefinitions > 0) {
echo "</table></center><p>";
}
echo "\n<center><table border=0 cellspacing=0 width=95% valign=top cellpadding=5><tr><td align=center bgcolor=\"$THEME->cellheading2\">";
}
if ($l == "ALL" and $glossary->displayformat != GLOSSARY_FORMAT_CONTINUOUS) {
echo "<b>$currentletter</b>";
}
if ($glossary->displayformat == GLOSSARY_FORMAT_SIMPLE) {
echo "\n</center></td></tr></table></center>";
if ($dumpeddefinitions > 0) {
echo "\n<center><table border=0 cellspacing=0 width=95% valign=top cellpadding=5>";
}
}
}
$dumptoscreen = 1;
}
} elseif ($l == "SPECIAL" and ord($firstletter) != ord("<EFBFBD>") and
(ord($firstletter) < ord("A") or ord($firstletter) > ord("Z"))) {
$dumptoscreen = 1;
}
} else {
if ($tab == GLOSSARY_CATEGORY_VIEW) {
if ($category) { // if we are browsing a category
$dumptoscreen = 1;
} else {
if ($cat == GLOSSARY_SHOW_NOT_CATEGORISED) { // Not categorized
if (! record_exists("glossary_entries_categories", "entryid", $entry->id)) {
$dumptoscreen = 1;
}
} else { // All categories
if ($currentcategory != $entry->CID) {
if ($entry->approved or $USER->id == $entry->userid or $tab == GLOSSARY_APPROVAL_VIEW) {
$currentcategory = $entry->CID;
if ($glossary->displayformat == GLOSSARY_FORMAT_SIMPLE) {
if ($dumpeddefinitions > 0) {
echo "</table></center><p>";
}
echo "\n<center><table border=0 cellspacing=0 width=95% valign=top cellpadding=10><tr><td align=center bgcolor=\"$THEME->cellheading2\">";
}
if ( $glossary->displayformat == GLOSSARY_FORMAT_CONTINUOUS ) {
echo "<center>";
}
echo "<b>$entry->name</b>";
if ( $glossary->displayformat == GLOSSARY_FORMAT_CONTINUOUS ) {
echo "</center><p>";
}
$dumptoscreen = 1;
}
}
if ($glossary->displayformat == GLOSSARY_FORMAT_SIMPLE) {
echo "\n</center></td></tr></table></center>";
if ($dumpeddefinitions > 0) {
echo "\n<center><table border=1 cellspacing=0 width=95% valign=top cellpadding=10>";
}
}
$dumptoscreen = 1;
}
}
} else {
$dumptoscreen = 1;
}
}
if ($dumptoscreen) {
$dumpeddefinitions++;
$concept = $entry->concept;
$definition = $entry->definition;
if ($dumpeddefinitions == 1) {
if ($glossary->displayformat == GLOSSARY_FORMAT_SIMPLE) {
echo "\n<center><table border=1 cellspacing=0 width=95% valign=top cellpadding=10>";
}
}
if ($search) {
$entry->concept = highlight($search, $concept);
$entry->definition = highlight($search, $definition);
}
glossary_print_entry($course, $cm, $glossary, $entry, $tab, $cat);
if ($glossary->displayformat != GLOSSARY_FORMAT_SIMPLE) {
echo "<p>";
}
}
}
}
if (! $dumpeddefinitions) {
print_simple_box_start("center", "70%", "$THEME->cellheading2");
if (!$search) {
echo "<center>$strnoentries</center>";
} else {
echo "<center>";
print_string("searchhelp");
echo "</center>";
}
print_simple_box_end();
} else {
switch ($glossary->displayformat) {
case GLOSSARY_FORMAT_CONTINUOUS:
echo "</td></tr></table>";
break;
case GLOSSARY_FORMAT_SIMPLE:
echo "\n</table></center>";
break;
}
}
echo "</center>";
glossary_print_tabbed_table_end();
/// Finish the page
print_footer($course);
?>