moodle/mod/glossary/print.php
willcast ea14e78373 - Cosmetic changes... Changing the Add Entry button for a new tab
- Creating two new tabs for the future export/import features.
- Improving a little the Printer-Friendly version (now it shows what you were watching in the previous frame)
2003-11-03 02:26:44 +00:00

166 lines
5.7 KiB
PHP

<?php
require_once("../../config.php");
require_once("lib.php");
global $CFG;
require_variable($id); // Course Module ID
require_variable($tab,GLOSSARY_STANDARD_VIEW); // format to show the entries
optional_variable($sortkey,"UPDATE"); // Sorting key if TAB = GLOSSARY_DATE_VIEW
optional_variable($sortorder,"asc"); // Sorting order if TAB = GLOSSARY_DATE_VIEW
optional_variable($l,"ALL");
optional_variable($eid);
optional_variable($search);
optional_variable($cat,GLOSSARY_SHOW_ALL_CATEGORIES);
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 (isguest()) {
error("You must be logged to use this page.");
}
if ( $eid ) {
$l = '';
$tab = GLOSSARY_STANDARD_VIEW;
}
/// Generating the SQL based on the format to show
switch ($tab) {
case GLOSSARY_CATEGORY_VIEW:
$where = '';
if ($cat) {
if ( $cat != GLOSSARY_SHOW_ALL_CATEGORIES and $cat != GLOSSARY_SHOW_NOT_CATEGORISED ) {
$where = 'and c.id = ' . $cat;
}
}
$entries = get_records_sql("SELECT c.name pivot, e.*
FROM {$CFG->prefix}glossary_entries e,
{$CFG->prefix}glossary_entries_categories ec,
{$CFG->prefix}glossary_categories as c
WHERE e.id = ec.entryid AND ec.categoryid = c.id AND
(e.glossaryid = $glossary->id or e.sourceglossaryid = $glossary->id)
AND e.approved != 0 $where
ORDER BY c.name, e.concept");
break;
case GLOSSARY_DATE_VIEW:
//// Valid sorting values
switch ($sortkey) {
case 'CREATION':
$sortkey = 'timecreated';
break;
case 'UPDATE':
default:
$sortkey = 'timemodified';
break;
}
if ($sortorder != 'asc' and $sortorder != 'desc') {
$sortorder = 'asc';
}
$entries = get_records_sql("SELECT e.timemodified pivot, e.*
FROM {$CFG->prefix}glossary_entries e
WHERE (e.glossaryid = $glossary->id or e.sourceglossaryid = $glossary->id)
AND e.approved != 0
ORDER BY e.$sortkey $sortorder");
break;
case GLOSSARY_STANDARD_VIEW:
default:
switch ($CFG->dbtype) {
case "postgres7":
$pivot = "substring(e.concept, 1,1)";
break;
case "mysql":
$pivot = "left(e.concept,1)";
break;
default:
$pivot = "e.concept";
break;
}
if ( $l ) {
if ($l != 'ALL' and $l != 'SPECIAL') {
switch ($CFG->dbtype) {
case 'postgres7':
$where = 'and substr(ucase(concept),1,' . strlen($l) . ') = \'' . strtoupper($l) . '\'';
break;
case 'mysql':
$where = 'and left(ucase(concept),' . strlen($l) . ") = '$l'";
break;
default:
$where = '';
}
}
} elseif ($eid) {
$where = " and e.id = $eid";
}
$entries = get_records_sql("SELECT $pivot pivot, e.*
FROM {$CFG->prefix}glossary_entries e
WHERE (e.glossaryid = $glossary->id or e.sourceglossaryid = $glossary->id)
AND e.approved != 0 $where
ORDER BY e.concept $sortorder");
break;
}
echo '<p><STRONG>' . get_string("course") . ': <i>' . $course->fullname . '</i><br />';
echo get_string("modulename","glossary") . ': <i>' . $glossary->name . '</i></STRONG></p>';
$groupheader = '';
$tableisopen = 0;
foreach ($entries as $entry) {
$pivot = $entry->pivot;
if ( $CFG->dbtype != "postgres7" and $CFG->dbtype != "mysql" and $tab != GLOSSARY_CATEGORY_VIEW) {
$pivot = $pivot[0];
}
if ($tab != GLOSSARY_DATE_VIEW) {
if ($groupheader != $pivot) {
/// Printing th eheader of the group
if ($tableisopen) {
echo '</table>';
echo '</center>';
$tableisopen = 0;
}
$groupheader = $pivot;
echo '<p align="center"><STRONG><font size="4" color="#0000FF">' . $groupheader . '</font></STRONG></p>';
}
}
if ( !$tableisopen ) {
echo '<center>';
echo '<table border="1" cellpadding="5" cellspacing="0" width="95%">';
$tableisopen = 1;
}
echo '<tr>';
echo '<td width="25%" align="right" valign="top"><b>'. $entry->concept . ': </b></td>';
echo '<td width="75%">';
if ( $entry->attachment) {
glossary_print_entry_attachment($entry);
}
echo format_text("<nolink>$entry->definition</nolink>",$entry->format);
echo '</tr>';
}
if ($tableisopen) {
echo '</table>';
echo '</center>';
}
?>