moodle/mod/glossary/sql.php

110 lines
3.8 KiB
PHP

<?php
/**
* SQL.PHP
* This file is include from view.php and print.php
* @copyright 2003
**/
/**
* This file defines, or redefines, the following variables:
*
* bool $userispivot Whether the user is the pivot.
* bool $fullpivot Whether the pivot should be displayed in full.
* bool $printpivot Whether the pivot should be displayed.
* string $pivotkey The property of the record at which the pivot is.
* int $count The number of records matching the request.
* array $allentries The entries matching the request.
* mixed $field Unset in this file.
* mixed $entry Unset in this file.
* mixed $canapprove Unset in this file.
*
* It relies on the following variables:
*
* object $glossary The glossary object.
* context $context The glossary context.
* mixed $hook The hook for the selected tab.
* string $sortkey The key to sort the records.
* string $sortorder The order of the sorting.
* int $offset The number of records to skip.
* int $pagelimit The number of entries on this page, or 0 if unlimited.
* string $mode The mode of browsing.
* string $tab The tab selected.
*/
$userispivot = false;
$fullpivot = true;
$pivotkey = 'concept';
switch ($tab) {
case GLOSSARY_AUTHOR_VIEW:
$userispivot = true;
$pivotkey = 'userid';
$field = ($sortkey == 'LASTNAME' ? 'LASTNAME' : 'FIRSTNAME');
list($allentries, $count) = glossary_get_entries_by_author($glossary, $context, $hook,
$field, $sortorder, $offset, $pagelimit);
unset($field);
break;
case GLOSSARY_CATEGORY_VIEW:
$hook = (int) $hook; // Make sure it's properly casted to int.
list($allentries, $count) = glossary_get_entries_by_category($glossary, $context, $hook, $offset, $pagelimit);
$pivotkey = 'categoryname';
if ($hook != GLOSSARY_SHOW_ALL_CATEGORIES) {
$printpivot = false;
}
break;
case GLOSSARY_DATE_VIEW:
$printpivot = false;
$field = ($sortkey == 'CREATION' ? 'CREATION' : 'UPDATE');
list($allentries, $count) = glossary_get_entries_by_date($glossary, $context, $field, $sortorder,
$offset, $pagelimit);
unset($field);
break;
case GLOSSARY_APPROVAL_VIEW:
$fullpivot = false;
$printpivot = false;
list($allentries, $count) = glossary_get_entries_to_approve($glossary, $context, $hook, $sortkey, $sortorder,
$offset, $pagelimit);
break;
case GLOSSARY_STANDARD_VIEW:
default:
$fullpivot = false;
switch ($mode) {
case 'search':
list($allentries, $count) = glossary_get_entries_by_search($glossary, $context, $hook, $fullsearch,
$sortkey, $sortorder, $offset, $pagelimit);
break;
case 'term':
$printpivot = false;
list($allentries, $count) = glossary_get_entries_by_term($glossary, $context, $hook, $offset, $pagelimit);
break;
case 'entry':
$printpivot = false;
$entry = glossary_get_entry_by_id($hook);
$canapprove = has_capability('mod/glossary:approve', $context);
if ($entry && ($entry->glossaryid == $glossary->id || $entry->sourceglossaryid != $glossary->id)
&& (!empty($entry->approved) || $entry->userid == $USER->id || $canapprove)) {
$count = 1;
$allentries = array($entry);
} else {
$count = 0;
$allentries = array();
}
unset($entry, $canapprove);
break;
case 'letter':
default:
list($allentries, $count) = glossary_get_entries_by_letter($glossary, $context, $hook, $offset, $pagelimit);
break;
}
break;
}