2003-11-15 15:55:47 +00:00
|
|
|
<?php
|
2003-09-16 03:07:21 +00:00
|
|
|
/// This page prints a particular instance of glossary
|
|
|
|
require_once("../../config.php");
|
|
|
|
require_once("lib.php");
|
2003-11-15 15:55:47 +00:00
|
|
|
$debug = 0;
|
|
|
|
|
2003-10-08 03:13:12 +00:00
|
|
|
require_variable($id); // Course Module ID
|
2003-11-15 15:55:47 +00:00
|
|
|
optional_variable($tab,GLOSSARY_NO_VIEW); // browsing entries by categories?
|
2003-10-19 03:40:36 +00:00
|
|
|
|
2003-11-15 15:55:47 +00:00
|
|
|
optional_variable($mode,"letter"); // [ "term" | "entry" | "cat" | "date" |
|
|
|
|
// "letter" | "search" | "author" | "approval" ]
|
|
|
|
optional_variable($hook,""); // the term, entry, cat, etc... to look for based on mode
|
2003-10-19 03:40:36 +00:00
|
|
|
|
2003-11-15 15:55:47 +00:00
|
|
|
optional_variable($fullsearch,0); // full search (concept and definition) when searching?
|
|
|
|
|
|
|
|
optional_variable($sortkey,""); // Sorted view:
|
2003-11-16 17:13:19 +00:00
|
|
|
// [ CREATION | UPDATE | FIRSTNAME | LASTNAME |
|
|
|
|
// concept | timecreated | ... ]
|
2003-11-15 15:55:47 +00:00
|
|
|
optional_variable($sortorder,""); // it defines the order of the sorting (ASC or DESC)
|
|
|
|
|
|
|
|
optional_variable($offset,0); // entries to bypass (for paging purpouses)
|
2003-11-04 18:38:22 +00:00
|
|
|
|
2003-11-16 17:13:19 +00:00
|
|
|
optional_variable($show,""); // [ concept | alias ] => mode=term hook=$show
|
|
|
|
|
|
|
|
if ( $show ) {
|
|
|
|
$mode = 'term';
|
|
|
|
$hook = $show;
|
|
|
|
$show = '';
|
|
|
|
}
|
2003-09-21 17:08:41 +00:00
|
|
|
if (! $cm = get_record("course_modules", "id", $id)) {
|
|
|
|
error("Course Module ID was incorrect");
|
2003-11-15 15:55:47 +00:00
|
|
|
}
|
2003-09-21 17:08:41 +00:00
|
|
|
if (! $course = get_record("course", "id", $cm->course)) {
|
|
|
|
error("Course is misconfigured");
|
2003-11-15 15:55:47 +00:00
|
|
|
}
|
2003-09-21 17:08:41 +00:00
|
|
|
if (! $glossary = get_record("glossary", "id", $cm->instance)) {
|
|
|
|
error("Course module is incorrect");
|
2003-10-08 03:13:12 +00:00
|
|
|
}
|
|
|
|
|
2003-11-15 15:55:47 +00:00
|
|
|
/// redirecting if adding a new entry
|
|
|
|
if ($tab == GLOSSARY_ADDENTRY_VIEW ) {
|
|
|
|
redirect("edit.php?id=$cm->id&mode=$mode");
|
|
|
|
}
|
|
|
|
|
|
|
|
/// setting the defaut number of entries per page if not set
|
|
|
|
global $CFG, $THEME, $USER;
|
|
|
|
|
|
|
|
if ( !$entriesbypage = $glossary->entbypage ) {
|
|
|
|
$entriesbypage = 10;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// setting the right fram for a "Continuous" glossary
|
|
|
|
if ( $glossary->displayformat == GLOSSARY_FORMAT_CONTINUOUS ) {
|
|
|
|
$mode = 'date';
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Processing standard security processes
|
|
|
|
$navigation = "";
|
2003-11-09 03:35:36 +00:00
|
|
|
if ($course->category) {
|
2003-11-15 15:55:47 +00:00
|
|
|
$navigation = "<a href=\"../../course/view.php?id=$course->id\">$course->shortname</a> ->";
|
2003-11-09 03:35:36 +00:00
|
|
|
require_login($course->id);
|
|
|
|
}
|
2003-09-23 12:34:47 +00:00
|
|
|
if (!$cm->visible and !isteacher($course->id)) {
|
2003-09-21 17:08:41 +00:00
|
|
|
notice(get_string("activityiscurrentlyhidden"));
|
2003-10-08 03:13:12 +00:00
|
|
|
}
|
2003-10-22 04:15:08 +00:00
|
|
|
add_to_log($course->id, "glossary", "view", "view.php?id=$cm->id&tab=$tab", "$glossary->id");
|
|
|
|
|
2003-11-15 15:55:47 +00:00
|
|
|
/// stablishing flag variables
|
2003-10-21 04:55:22 +00:00
|
|
|
if ( $sortorder = strtolower($sortorder) ) {
|
2003-10-22 04:15:08 +00:00
|
|
|
if ($sortorder != 'asc' and $sortorder != 'desc') {
|
|
|
|
$sortorder = '';
|
2003-10-19 03:40:36 +00:00
|
|
|
}
|
|
|
|
}
|
2003-10-21 04:55:22 +00:00
|
|
|
if ( $sortkey = strtoupper($sortkey) ) {
|
2003-11-16 17:13:19 +00:00
|
|
|
if ($sortkey != 'CREATION' and
|
|
|
|
$sortkey != 'UPDATE' and
|
|
|
|
$sortkey != 'FIRSTNAME' and
|
|
|
|
$sortkey != 'LASTNAME'
|
|
|
|
) {
|
2003-10-22 04:15:08 +00:00
|
|
|
$sortkey = '';
|
2003-10-21 04:55:22 +00:00
|
|
|
}
|
2003-10-19 03:40:36 +00:00
|
|
|
}
|
2003-10-28 16:10:36 +00:00
|
|
|
|
2003-11-15 15:55:47 +00:00
|
|
|
switch ( $mode = strtolower($mode) ) {
|
|
|
|
case 'search': /// looking for terms containing certain word(s)
|
|
|
|
$tab = GLOSSARY_STANDARD_VIEW;
|
2003-10-21 04:55:22 +00:00
|
|
|
|
2003-11-15 15:55:47 +00:00
|
|
|
$searchterms = explode(' ', $hook); // Search for words independently
|
2003-09-16 03:07:21 +00:00
|
|
|
foreach ($searchterms as $key => $searchterm) {
|
|
|
|
if (strlen($searchterm) < 2) {
|
|
|
|
unset($searchterms[$key]);
|
2003-10-08 03:13:12 +00:00
|
|
|
}
|
|
|
|
}
|
2003-11-15 15:55:47 +00:00
|
|
|
$hook = trim(implode(' ', $searchterms));
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'entry': /// Looking for a certain entry id
|
2003-11-03 02:26:44 +00:00
|
|
|
$tab = GLOSSARY_STANDARD_VIEW;
|
2003-11-15 15:55:47 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case 'cat': /// Looking for a certain cat
|
|
|
|
$tab = GLOSSARY_CATEGORY_VIEW;
|
|
|
|
if ( $hook > 0 ) {
|
|
|
|
$category = get_record("glossary_categories","id",$hook);
|
|
|
|
}
|
|
|
|
break;
|
2003-10-21 04:55:22 +00:00
|
|
|
|
2003-11-15 15:55:47 +00:00
|
|
|
case 'approval': /// Looking for entries waiting for approval
|
|
|
|
$tab = GLOSSARY_APPROVAL_VIEW;
|
|
|
|
if ( !$hook and !$sortkey and !$sortorder) {
|
|
|
|
$hook = 'ALL';
|
2003-10-22 04:15:08 +00:00
|
|
|
}
|
2003-11-15 15:55:47 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case 'term': /// Looking for entries that include certain term in its concept, definition or aliases
|
|
|
|
$tab = GLOSSARY_STANDARD_VIEW;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'date':
|
|
|
|
$tab = GLOSSARY_DATE_VIEW;
|
|
|
|
if ( !$sortkey ) {
|
|
|
|
$sortkey = 'UPDATE';
|
2003-10-08 03:13:12 +00:00
|
|
|
}
|
2003-11-15 15:55:47 +00:00
|
|
|
if ( !$sortorder ) {
|
|
|
|
$sortorder = 'desc';
|
|
|
|
}
|
|
|
|
break;
|
2003-10-08 03:13:12 +00:00
|
|
|
|
2003-11-15 15:55:47 +00:00
|
|
|
case 'author': /// Looking for entries, browsed by author
|
|
|
|
$tab = GLOSSARY_AUTHOR_VIEW;
|
|
|
|
if ( !$hook ) {
|
|
|
|
$hook = 'ALL';
|
|
|
|
}
|
2003-11-16 17:13:19 +00:00
|
|
|
if ( !$sortkey ) {
|
|
|
|
$sortkey = 'FIRSTNAME';
|
|
|
|
}
|
|
|
|
if ( !$sortorder ) {
|
|
|
|
$sortorder = 'asc';
|
|
|
|
}
|
2003-11-15 15:55:47 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case 'letter': /// Looking for entries that begin with a certain letter, ALL or SPECIAL characters
|
|
|
|
default:
|
|
|
|
$tab = GLOSSARY_STANDARD_VIEW;
|
|
|
|
if ( !$hook ) {
|
|
|
|
$hook = 'ALL';
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
switch ( $tab ) {
|
|
|
|
case GLOSSARY_IMPORT_VIEW:
|
|
|
|
case GLOSSARY_EXPORT_VIEW:
|
|
|
|
case GLOSSARY_APPROVAL_VIEW:
|
|
|
|
$isuserframe = 0;
|
|
|
|
break;
|
2003-10-08 03:13:12 +00:00
|
|
|
|
2003-11-15 15:55:47 +00:00
|
|
|
default:
|
|
|
|
$isuserframe = 1;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Printing the heading
|
2003-10-08 03:13:12 +00:00
|
|
|
$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");
|
|
|
|
|
2003-09-29 03:06:30 +00:00
|
|
|
print_header(strip_tags("$course->shortname: $glossary->name"), "$course->fullname",
|
2003-10-08 03:13:12 +00:00
|
|
|
"$navigation <A HREF=index.php?id=$course->id>$strglossaries</A> -> $glossary->name",
|
|
|
|
"", "", true, update_module_button($cm->id, $course->id, $strglossary),
|
|
|
|
navmenu($course, $cm));
|
|
|
|
|
2003-11-01 20:27:21 +00:00
|
|
|
echo '<p align="center"><font size="3"><b>' . stripslashes_safe($glossary->name);
|
2003-11-15 15:55:47 +00:00
|
|
|
if ($isuserframe ) {
|
2003-11-03 02:26:44 +00:00
|
|
|
/// the "Print" icon
|
2003-11-15 15:55:47 +00:00
|
|
|
echo " <a title =\"". get_string("printerfriendly","glossary") . "\" target=\"_blank\" href=\"print.php?id=$cm->id&tab=$tab&mode=$mode&hook=$hook&sortkey=$sortkey&sortorder=$sortorder\">";
|
2003-11-03 02:26:44 +00:00
|
|
|
echo '<img border=0 src="print.gif"/></a>';
|
|
|
|
}
|
2003-11-01 20:27:21 +00:00
|
|
|
echo '</b></font></p>';
|
|
|
|
|
2003-10-15 16:12:38 +00:00
|
|
|
/// Info box
|
|
|
|
if ( $glossary->intro ) {
|
2003-10-22 04:15:08 +00:00
|
|
|
print_simple_box_start('center','70%');
|
2003-10-26 08:06:16 +00:00
|
|
|
echo format_text($glossary->intro);
|
2003-10-15 16:12:38 +00:00
|
|
|
print_simple_box_end();
|
2003-10-21 04:55:22 +00:00
|
|
|
}
|
2003-10-15 16:12:38 +00:00
|
|
|
|
2003-10-08 03:13:12 +00:00
|
|
|
/// Search box
|
2003-11-03 02:26:44 +00:00
|
|
|
echo '<p>';
|
2003-10-08 03:13:12 +00:00
|
|
|
print_simple_box_start("center", "", $THEME->cellheading);
|
|
|
|
echo '<p>';
|
|
|
|
echo '<form method="POST" action="view.php">';
|
|
|
|
echo '<input type="submit" value="'.$strsearch.'" name="searchbutton"> ';
|
2003-11-15 15:55:47 +00:00
|
|
|
echo '<input type="text" name="hook" size="20" value=""> ';
|
|
|
|
echo '<input type="checkbox" name="fullsearch" value="1">';
|
|
|
|
echo '<input type="hidden" name="mode" value="search">';
|
2003-10-08 03:13:12 +00:00
|
|
|
echo '<input type="hidden" name="id" value="'.$cm->id.'">';
|
2003-11-15 15:55:47 +00:00
|
|
|
echo $strsearchindefinition;
|
2003-10-08 03:13:12 +00:00
|
|
|
echo '</form>';
|
|
|
|
echo '</p>';
|
2003-11-15 15:55:47 +00:00
|
|
|
print_simple_box_end();
|
2003-09-21 17:08:41 +00:00
|
|
|
|
2003-11-03 02:26:44 +00:00
|
|
|
include("tabs.html");
|
2003-09-16 03:07:21 +00:00
|
|
|
|
2003-11-15 15:55:47 +00:00
|
|
|
switch ( $sortkey ) {
|
|
|
|
case "CREATION":
|
|
|
|
$sortkey = "timecreated";
|
|
|
|
break;
|
|
|
|
|
|
|
|
case "UPDATE":
|
|
|
|
$sortkey = "timemodified";
|
|
|
|
default:
|
|
|
|
break;
|
2003-10-28 16:10:36 +00:00
|
|
|
}
|
|
|
|
|
2003-11-15 15:55:47 +00:00
|
|
|
/// Creating the SQL statements
|
|
|
|
|
|
|
|
/// Pivot is the field that set the break by groups (category, initial, author name, etc)
|
|
|
|
|
|
|
|
/// fullpivot indicate if the whole pivot should be compared agasint the db or just the first letter
|
|
|
|
/// printpivot indicate if the pivot should be printed or not
|
|
|
|
$fullpivot = 1;
|
|
|
|
$printpivot = 1;
|
|
|
|
|
|
|
|
// global $db;
|
|
|
|
// $db->debug = true;
|
|
|
|
|
2003-10-21 04:55:22 +00:00
|
|
|
switch ($tab) {
|
2003-11-15 15:55:47 +00:00
|
|
|
case GLOSSARY_CATEGORY_VIEW:
|
|
|
|
if ($hook == GLOSSARY_SHOW_ALL_CATEGORIES ) {
|
|
|
|
|
|
|
|
$sqlselect = "SELECT gec.id, gc.name pivot, ge.*";
|
|
|
|
$sqlfrom = "FROM {$CFG->prefix}glossary_entries ge,
|
|
|
|
{$CFG->prefix}glossary_entries_categories gec,
|
|
|
|
{$CFG->prefix}glossary_categories gc";
|
|
|
|
$sqlwhere = "WHERE (ge.glossaryid = '$glossary->id' OR ge.sourceglossaryid = '$glossary->id') AND
|
|
|
|
ge.id = gec.entryid AND gc.id = gec.categoryid AND
|
|
|
|
(ge.approved != 0 OR ge.userid = $USER->id)";
|
2003-11-04 18:38:22 +00:00
|
|
|
|
2003-11-15 15:55:47 +00:00
|
|
|
if ( $glossary->displayformat == GLOSSARY_FORMAT_CONTINUOUS ) {
|
|
|
|
$sqlorderby = ' ORDER BY gc.name, ge.timecreated';
|
2003-10-21 04:55:22 +00:00
|
|
|
} else {
|
2003-11-15 15:55:47 +00:00
|
|
|
$sqlorderby = ' ORDER BY gc.name, ge.concept';
|
|
|
|
}
|
|
|
|
|
|
|
|
} elseif ($hook == GLOSSARY_SHOW_NOT_CATEGORISED ) {
|
|
|
|
|
|
|
|
$printpivot = 0;
|
|
|
|
$sqlselect = "SELECT concept pivot, ge.*";
|
|
|
|
$sqlfrom = "FROM {$CFG->prefix}glossary_entries ge";
|
|
|
|
$sqlwhere = "WHERE (glossaryid = '$glossary->id' OR sourceglossaryid = '$glossary->id') AND
|
|
|
|
(ge.approved != 0 OR ge.userid = $USER->id)";
|
|
|
|
|
|
|
|
|
|
|
|
$sqlorderby = ' ORDER BY concept';
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
$printpivot = 0;
|
|
|
|
$sqlselect = "SELECT ce.id, c.name pivot, ge.*";
|
|
|
|
$sqlfrom = "FROM {$CFG->prefix}glossary_entries ge, {$CFG->prefix}glossary_entries_categories ce, {$CFG->prefix}glossary_categories c";
|
|
|
|
$sqlwhere = "WHERE ge.id = ce.entryid AND ce.categoryid = $hook AND
|
|
|
|
ce.categoryid = c.id AND ge.approved != 0 AND
|
|
|
|
(ge.glossaryid = $glossary->id OR ge.sourceglossaryid = $glossary->id) AND
|
|
|
|
(ge.approved != 0 OR ge.userid = $USER->id)";
|
|
|
|
|
|
|
|
$sqlorderby = ' ORDER BY c.name, ge.concept';
|
|
|
|
|
|
|
|
}
|
|
|
|
$count = count_records_sql("select count(*) $sqlfrom $sqlwhere");
|
|
|
|
$sqllimit = " LIMIT $offset, $entriesbypage";
|
|
|
|
$allentries = get_records_sql("$sqlselect $sqlfrom $sqlwhere $sqlorderby $sqllimit");
|
|
|
|
break;
|
|
|
|
case GLOSSARY_AUTHOR_VIEW:
|
|
|
|
|
|
|
|
$where = '';
|
|
|
|
switch ($CFG->dbtype) {
|
|
|
|
case 'postgres7':
|
2003-11-16 17:13:19 +00:00
|
|
|
$usernametoshow = "u.firstname || ' ' || u.lastname";
|
|
|
|
if ( $sortkey == 'FIRSTNAME' ) {
|
|
|
|
$usernamefield = "u.firstname || ' ' || u.lastname";
|
|
|
|
} else {
|
|
|
|
$usernamefield = "u.lastname || ' ' || u.firstname";
|
|
|
|
}
|
2003-11-15 15:55:47 +00:00
|
|
|
$where = "AND substr(ucase($usernamefield),1," . strlen($hook) . ") = '" . strtoupper($hook) . "'";
|
|
|
|
break;
|
|
|
|
case 'mysql':
|
2003-11-16 17:13:19 +00:00
|
|
|
$usernametoshow = "CONCAT(CONCAT(u.firstname,' '), u.lastname)";
|
|
|
|
if ( $sortkey == 'FIRSTNAME' ) {
|
|
|
|
$usernamefield = "CONCAT(CONCAT(u.firstname,' '), u.lastname)";
|
|
|
|
} else {
|
|
|
|
$usernamefield = "CONCAT(CONCAT(u.lastname,' '), u.firstname)";
|
|
|
|
}
|
2003-11-15 15:55:47 +00:00
|
|
|
$where = "AND left(ucase($usernamefield)," . strlen($hook) . ") = '$hook'";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
if ( $hook == 'ALL' ) {
|
|
|
|
$where = '';
|
|
|
|
}
|
|
|
|
|
2003-11-16 17:13:19 +00:00
|
|
|
$sqlselect = "SELECT ge.id, $usernamefield pivot, $usernametoshow uname, u.id uid, ge.*";
|
2003-11-15 15:55:47 +00:00
|
|
|
$sqlfrom = "FROM {$CFG->prefix}glossary_entries ge, {$CFG->prefix}user u";
|
|
|
|
$sqlwhere = "WHERE ge.userid = u.id AND
|
|
|
|
ge.approved != 0
|
|
|
|
$where AND
|
|
|
|
(ge.glossaryid = $glossary->id OR ge.sourceglossaryid = $glossary->id)";
|
2003-11-16 17:13:19 +00:00
|
|
|
$sqlorderby = "ORDER BY $usernamefield $sortorder, ge.concept";
|
2003-11-15 15:55:47 +00:00
|
|
|
|
|
|
|
$count = count_records_sql("select count(*) $sqlfrom $sqlwhere");
|
|
|
|
$sqllimit = " LIMIT $offset, $entriesbypage";
|
|
|
|
$allentries = get_records_sql("$sqlselect $sqlfrom $sqlwhere $sqlorderby $sqllimit");
|
|
|
|
break;
|
|
|
|
case GLOSSARY_APPROVAL_VIEW:
|
|
|
|
$fullpivot = 0;
|
|
|
|
$printpivot = 0;
|
|
|
|
|
|
|
|
$where = '';
|
|
|
|
if ($hook != 'ALL' and $hook != 'SPECIAL') {
|
|
|
|
switch ($CFG->dbtype) {
|
|
|
|
case 'postgres7':
|
|
|
|
$where = 'AND substr(ucase(concept),1,' . strlen($hook) . ') = \'' . strtoupper($hook) . '\'';
|
|
|
|
break;
|
|
|
|
case 'mysql':
|
|
|
|
$where = 'AND left(ucase(concept),' . strlen($hook) . ") = '$hook'";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$sqlselect = "SELECT ge.concept pivot, ge.*";
|
|
|
|
$sqlfrom = "FROM {$CFG->prefix}glossary_entries ge";
|
|
|
|
$sqlwhere = "WHERE (ge.glossaryid = $glossary->id OR ge.sourceglossaryid = $glossary->id) AND
|
|
|
|
ge.approved = 0 $where";
|
|
|
|
|
|
|
|
if ( $sortkey ) {
|
|
|
|
$sqlorderby = "ORDER BY $sortkey $sortorder";
|
|
|
|
} else {
|
|
|
|
$sqlorderby = "ORDER BY ge.concept";
|
|
|
|
}
|
|
|
|
|
|
|
|
$count = count_records_sql("select count(*) $sqlfrom $sqlwhere");
|
|
|
|
$sqllimit = " LIMIT $offset, $entriesbypage";
|
|
|
|
$allentries = get_records_sql("$sqlselect $sqlfrom $sqlwhere $sqlorderby $sqllimit");
|
|
|
|
break;
|
|
|
|
case GLOSSARY_DATE_VIEW:
|
|
|
|
case GLOSSARY_STANDARD_VIEW:
|
|
|
|
default:
|
|
|
|
$sqlselect = "SELECT ge.concept pivot, ge.*";
|
|
|
|
$sqlfrom = "FROM {$CFG->prefix}glossary_entries ge";
|
|
|
|
|
|
|
|
$where = '';
|
|
|
|
$fullpivot = 0;
|
|
|
|
if ($CFG->dbtype == "postgres7") {
|
|
|
|
$LIKE = "ILIKE"; // case-insensitive
|
|
|
|
} else {
|
|
|
|
$LIKE = "LIKE";
|
|
|
|
}
|
|
|
|
|
|
|
|
switch ( $mode ) {
|
|
|
|
case 'search':
|
|
|
|
$printpivot = 0;
|
|
|
|
$where = "AND ( ge.concept $LIKE '%$hook%'";
|
|
|
|
if ( $fullsearch ) {
|
|
|
|
$where .= "OR ge.definition $LIKE '%$hook%')";
|
|
|
|
} else {
|
|
|
|
$where .= ")";
|
2003-10-19 03:40:36 +00:00
|
|
|
}
|
2003-10-21 04:55:22 +00:00
|
|
|
break;
|
2003-11-15 15:55:47 +00:00
|
|
|
|
|
|
|
case 'term':
|
|
|
|
$printpivot = 0;
|
|
|
|
$sqlfrom .= ", {$CFG->prefix}glossary_alias ga";
|
2003-11-16 17:13:19 +00:00
|
|
|
$where = "AND ge.id = ga.entryid AND
|
|
|
|
(ge.concept = '$hook' OR ga.alias = '$hook' )
|
|
|
|
";
|
|
|
|
// $where = "AND ge.id = ga.entryid AND (
|
|
|
|
// (ge.casesensitive != 0 and ( ge.concept LIKE BINARY '$hook' OR ga.alias LIKE BINARY '$hook' ) ) or
|
|
|
|
// (ge.casesensitive = 0 and ( ucase(ge.concept) = ucase('$hook') OR ucase(ga.alias) = ucase('$hook') ) )
|
|
|
|
// )";
|
2003-10-21 04:55:22 +00:00
|
|
|
break;
|
2003-11-15 15:55:47 +00:00
|
|
|
|
|
|
|
case 'entry':
|
|
|
|
$printpivot = 0;
|
|
|
|
$where = "AND ge.id = $hook";
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'letter':
|
|
|
|
if ($hook != 'ALL' and $hook != 'SPECIAL') {
|
|
|
|
switch ($CFG->dbtype) {
|
|
|
|
case 'postgres7':
|
|
|
|
$where = 'AND substr(ucase(concept),1,' . strlen($hook) . ') = \'' . strtoupper($hook) . '\'';
|
|
|
|
break;
|
|
|
|
case 'mysql':
|
|
|
|
$where = 'AND left(ucase(concept),' . strlen($hook) . ") = '$hook'";
|
|
|
|
break;
|
2003-10-21 04:55:22 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
2003-11-15 15:55:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
$sqlwhere = "WHERE (ge.glossaryid = $glossary->id or ge.sourceglossaryid = $glossary->id) AND
|
|
|
|
(ge.approved != 0 OR ge.userid = $USER->id)
|
|
|
|
$where";
|
|
|
|
switch ( $tab ) {
|
|
|
|
case GLOSSARY_DATE_VIEW:
|
|
|
|
$sqlorderby = "ORDER BY $sortkey $sortorder";
|
|
|
|
break;
|
|
|
|
|
|
|
|
case GLOSSARY_STANDARD_VIEW:
|
|
|
|
$sqlorderby = "ORDER BY ge.concept";
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
$count = count_records_sql("select count(*) $sqlfrom $sqlwhere");
|
|
|
|
$sqllimit = " LIMIT $offset, $entriesbypage";
|
|
|
|
$allentries = get_records_sql("$sqlselect $sqlfrom $sqlwhere $sqlorderby $sqllimit");
|
|
|
|
|
|
|
|
break;
|
2003-10-08 03:13:12 +00:00
|
|
|
}
|
2003-11-15 15:55:47 +00:00
|
|
|
/*
|
|
|
|
print_simple_box_start("center","85%");
|
|
|
|
print_object($allentries);
|
|
|
|
print_simple_box_end();
|
|
|
|
$db->debug=false;
|
|
|
|
*/
|
|
|
|
|
|
|
|
/// printing the entries
|
|
|
|
|
|
|
|
$entriesshown = 0;
|
|
|
|
$currentpivot = '';
|
|
|
|
if ( $hook == 'SPECIAL' ) {
|
|
|
|
$alphabet = explode(",", get_string("alphabet"));
|
|
|
|
}
|
2003-10-08 03:13:12 +00:00
|
|
|
if ($allentries) {
|
2003-11-15 15:55:47 +00:00
|
|
|
/// printing the paging links
|
2003-11-04 18:38:22 +00:00
|
|
|
$paging = '';
|
|
|
|
if ($count > $entriesbypage ) {
|
|
|
|
for ($i = 0; ($i*$entriesbypage) < $count ; $i++ ) {
|
|
|
|
if ( $paging != '' ) {
|
|
|
|
if ($i % 20 == 0) {
|
|
|
|
$paging .= '<br>';
|
|
|
|
} else {
|
|
|
|
$paging .= ' | ';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($offset / $entriesbypage == $i) {
|
|
|
|
$paging .= '<strong>' . ($i + 1 ) . '</strong>';
|
|
|
|
} else {
|
2003-11-15 15:55:47 +00:00
|
|
|
$paging .= "<a href=\"view.php?id=$id&mode=$mode&hook=$hook&offset=" . ($i*$entriesbypage) . "\">" . ($i+1) . '</a>';
|
2003-11-04 18:38:22 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
$paging = "<font size=1><center>" . get_string ("jumpto") . " $paging</center></font>";
|
|
|
|
}
|
2003-11-15 15:55:47 +00:00
|
|
|
echo "$paging";
|
|
|
|
glossary_debug($debug,'<div align=right><font size=1>SELECT normal:' . count($allentries) . '</font></div>',0);
|
|
|
|
glossary_debug($debug,'<div align=right><font size=1>SELECT count(*):' . $count . '</font></div>',0);
|
|
|
|
|
2003-10-19 03:40:36 +00:00
|
|
|
if ($glossary->displayformat == GLOSSARY_FORMAT_CONTINUOUS) {
|
2003-11-15 15:55:47 +00:00
|
|
|
$printpivot = 0;
|
2003-10-19 03:40:36 +00:00
|
|
|
}
|
2003-11-15 15:55:47 +00:00
|
|
|
|
2003-09-16 03:07:21 +00:00
|
|
|
foreach ($allentries as $entry) {
|
2003-11-16 17:13:19 +00:00
|
|
|
/// Setting the pivot for the current entry
|
2003-11-15 15:55:47 +00:00
|
|
|
$pivot = $entry->pivot;
|
|
|
|
if ( !$fullpivot ) {
|
|
|
|
$pivot = $pivot[0];
|
|
|
|
}
|
|
|
|
|
2003-11-16 17:13:19 +00:00
|
|
|
///
|
|
|
|
/// Validating special cases not covered by the SQL statement
|
|
|
|
///
|
|
|
|
|
|
|
|
/// if we're browsing by alphabet and the current concept does not begin with
|
|
|
|
/// the letter we are look for.
|
2003-11-15 15:55:47 +00:00
|
|
|
$showentry = 1;
|
|
|
|
if ( $mode == 'letter' and $hook != 'SPECIAL' and $hook != 'ALL' ) {
|
|
|
|
if ( substr($entry->concept, 0, strlen($hook)) != $hook ) {
|
|
|
|
$showentry = 0;
|
|
|
|
}
|
|
|
|
}
|
2003-11-16 17:13:19 +00:00
|
|
|
|
|
|
|
/// if we're browsing for letter, looking for special characters not covered
|
|
|
|
/// in the alphabet
|
|
|
|
if ( $showentry and $hook == 'SPECIAL' ) {
|
2003-11-15 15:55:47 +00:00
|
|
|
$initial = $entry->concept[0];
|
|
|
|
for ($i = 0; $i < count($alphabet); $i++) {
|
|
|
|
$curletter = $alphabet[$i];
|
|
|
|
if ( $curletter == $initial ) {
|
|
|
|
|
|
|
|
$showentry = 0;
|
|
|
|
break;
|
2003-10-21 04:55:22 +00:00
|
|
|
}
|
2003-11-15 15:55:47 +00:00
|
|
|
}
|
2003-10-08 03:13:12 +00:00
|
|
|
}
|
2003-11-16 17:13:19 +00:00
|
|
|
|
|
|
|
/// if we're browsing categories, looking for entries not categorised.
|
|
|
|
if ( $showentry and $mode == 'cat' and $hook == GLOSSARY_SHOW_NOT_CATEGORISED ) {
|
2003-11-15 15:55:47 +00:00
|
|
|
if ( record_exists("glossary_entries_categories", "entryid", $entry->id)) {
|
|
|
|
$showentry = 0;
|
|
|
|
}
|
|
|
|
}
|
2003-11-16 17:13:19 +00:00
|
|
|
|
|
|
|
/// if the entry is not approved, deal with it based on the current view and
|
|
|
|
/// user.
|
|
|
|
if ( $showentry and $mode != 'approval' ) {
|
2003-11-15 15:55:47 +00:00
|
|
|
if ( !$entry->approved and isteacher($course->id, $entry->userid) ) {
|
|
|
|
$showentry = 0;
|
|
|
|
}
|
|
|
|
}
|
2003-11-16 17:13:19 +00:00
|
|
|
|
2003-11-15 15:55:47 +00:00
|
|
|
/// ok, if it's a valid entry.. Print it.
|
|
|
|
if ( $showentry ) {
|
|
|
|
|
|
|
|
/// if there's a group break
|
2003-11-16 02:53:13 +00:00
|
|
|
if ( $currentpivot != strtoupper($pivot) ) {
|
2003-11-15 15:55:47 +00:00
|
|
|
|
2003-11-16 17:13:19 +00:00
|
|
|
// print the group break if apply
|
2003-11-15 15:55:47 +00:00
|
|
|
if ( $printpivot ) {
|
|
|
|
if ( $tableisopen ) {
|
|
|
|
print_simple_box_end();
|
|
|
|
$tableisopen = 0;
|
|
|
|
}
|
2003-11-16 02:53:13 +00:00
|
|
|
$currentpivot = strtoupper($pivot);
|
2003-11-15 15:55:47 +00:00
|
|
|
|
|
|
|
echo '<p>';
|
|
|
|
echo '<table width="95%" border="0" class="generaltabselected" bgcolor="' . $THEME->cellheading2 . '">';
|
|
|
|
|
|
|
|
echo '<tr>';
|
2003-11-16 17:13:19 +00:00
|
|
|
$pivottoshow = $currentpivot;
|
2003-11-15 15:55:47 +00:00
|
|
|
if ( isset($entry->uid) ) {
|
|
|
|
// printing the user icon if defined (only when browsing authors)
|
|
|
|
echo '<td align="left">';
|
|
|
|
|
|
|
|
$user = get_record("user","id",$entry->uid);
|
|
|
|
print_user_picture($user->id, $course->id, $user->picture);
|
2003-11-16 17:13:19 +00:00
|
|
|
$pivottoshow = $entry->uname;
|
2003-11-15 15:55:47 +00:00
|
|
|
} else {
|
|
|
|
echo '<td align="center">';
|
|
|
|
}
|
|
|
|
|
2003-11-16 17:13:19 +00:00
|
|
|
echo "<strong> $pivottoshow</strong>" ;
|
2003-11-15 15:55:47 +00:00
|
|
|
echo '</td></tr></table>';
|
|
|
|
|
|
|
|
if ($glossary->displayformat == GLOSSARY_FORMAT_CONTINUOUS OR
|
|
|
|
$glossary->displayformat == GLOSSARY_FORMAT_SIMPLE ) {
|
|
|
|
print_simple_box_start("center","95%","#ffffff","5","generalbox");
|
|
|
|
$tableisopen = 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( !$tableisopen ) {
|
|
|
|
if ($glossary->displayformat == GLOSSARY_FORMAT_CONTINUOUS OR
|
|
|
|
$glossary->displayformat == GLOSSARY_FORMAT_SIMPLE) {
|
|
|
|
print_simple_box_start("center","95%","#ffffff","5","generalbox");
|
|
|
|
$tableisopen = 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2003-10-08 03:13:12 +00:00
|
|
|
$concept = $entry->concept;
|
|
|
|
$definition = $entry->definition;
|
|
|
|
|
2003-11-15 15:55:47 +00:00
|
|
|
/// highligh the term if necessary
|
|
|
|
if ($mode == 'search') {
|
|
|
|
$entry->concept = highlight($hook, $concept);
|
|
|
|
$entry->definition = highlight($hook, $definition);
|
2003-10-08 03:13:12 +00:00
|
|
|
}
|
2003-11-15 15:55:47 +00:00
|
|
|
|
|
|
|
/// and finally print the entry.
|
|
|
|
glossary_print_entry($course, $cm, $glossary, $entry, $mode, $hook);
|
|
|
|
$entriesshown++;
|
|
|
|
// echo '<p>';
|
|
|
|
}
|
2003-11-04 18:38:22 +00:00
|
|
|
}
|
2003-11-15 15:55:47 +00:00
|
|
|
if ( $tableisopen ) {
|
|
|
|
if ($glossary->displayformat == GLOSSARY_FORMAT_CONTINUOUS OR
|
|
|
|
$glossary->displayformat == GLOSSARY_FORMAT_SIMPLE ) {
|
|
|
|
print_simple_box_end();
|
|
|
|
$tableisopen = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ( !$entriesshown ) {
|
|
|
|
print_simple_box('<center>' . get_string("noentries","glossary") . '</center>',"center","95%");
|
|
|
|
}
|
|
|
|
|
2003-10-22 04:15:08 +00:00
|
|
|
echo '</center>';
|
2003-10-08 03:13:12 +00:00
|
|
|
glossary_print_tabbed_table_end();
|
2003-11-15 15:55:47 +00:00
|
|
|
if ( $debug ) {
|
|
|
|
echo '<p>';
|
|
|
|
print_simple_box("$sqlselect<br> $sqlfrom<br> $sqlwhere<br> $sqlorderby<br> $sqllimit","center","85%");
|
|
|
|
}
|
2003-09-18 23:36:06 +00:00
|
|
|
|
2003-09-16 03:07:21 +00:00
|
|
|
/// Finish the page
|
|
|
|
print_footer($course);
|
2003-11-15 15:55:47 +00:00
|
|
|
?>
|