dokeos-admin
[ class tree: dokeos-admin ] [ index: dokeos-admin ] [ all elements ]

Source for file course_list.php

Documentation is available at course_list.php

  1. <?php
  2. // $Id: course_list.php 15245 2008-05-08 16:53:52Z juliomontoya $
  3. /*
  4. ==============================================================================
  5.     Dokeos - elearning and course management software
  6.  
  7.     Copyright (c) 2008 Dokeos SPRL
  8.     Copyright (c) 2003 Ghent University (UGent)
  9.     Copyright (c) 2001 Universite catholique de Louvain (UCL)
  10.     Copyright (c) Olivier Brouckaert
  11.     Copyright (c) Bart Mollet, Hogeschool Gent
  12.  
  13.     For a full list of contributors, see "credits.txt".
  14.     The full license can be read in "license.txt".
  15.  
  16.     This program is free software; you can redistribute it and/or
  17.     modify it under the terms of the GNU General Public License
  18.     as published by the Free Software Foundation; either version 2
  19.     of the License, or (at your option) any later version.
  20.  
  21.     See the GNU General Public License for more details.
  22.  
  23.     Contact address: Dokeos, rue du Corbeau, 108, B-1030 Brussels, Belgium
  24.     Mail: info@dokeos.com
  25. ==============================================================================
  26. */
  27. /**
  28. ==============================================================================
  29. *    @package dokeos.admin
  30. ============================================================================== 
  31. */
  32. /*
  33. ==============================================================================
  34.         INIT SECTION
  35. ==============================================================================
  36. */
  37.  
  38. // name of the language file that needs to be included 
  39. $language_file 'admin';
  40. $cidReset true;
  41. require ('../inc/global.inc.php');
  42. $this_section SECTION_PLATFORM_ADMIN;
  43.  
  44. require_once (api_get_path(LIBRARY_PATH).'course.lib.php');
  45. require_once (api_get_path(LIBRARY_PATH).'formvalidator/FormValidator.class.php');
  46. require_once (api_get_path(LIBRARY_PATH).'sortabletable.class.php');
  47. /**
  48.  * Get the number of courses which will be displayed
  49.  */
  50. {
  51.     $course_table Database :: get_main_table(TABLE_MAIN_COURSE);
  52.     $sql "SELECT COUNT(code) AS total_number_of_items FROM $course_table";
  53.     if (isset ($_GET['keyword']))
  54.     {
  55.         $keyword Database::escape_string($_GET['keyword']);
  56.         $sql .= " WHERE title LIKE '%".$keyword."%' OR code LIKE '%".$keyword."%'";
  57.     }
  58.     elseif (isset ($_GET['keyword_code']))
  59.     {
  60.         $keyword_code Database::escape_string($_GET['keyword_code']);
  61.         $keyword_title Database::escape_string($_GET['keyword_title']);
  62.         $keyword_category Database::escape_string($_GET['keyword_category']);
  63.         $keyword_language Database::escape_string($_GET['keyword_language']);
  64.         $keyword_visibility Database::escape_string($_GET['keyword_visibility']);
  65.         $keyword_subscribe Database::escape_string($_GET['keyword_subscribe']);
  66.         $keyword_unsubscribe Database::escape_string($_GET['keyword_unsubscribe']);
  67.         $sql .= " WHERE code LIKE '%".$keyword_code."%' AND title LIKE '%".$keyword_title."%' AND category_code LIKE '%".$keyword_category."%'  AND course_language LIKE '%".$keyword_language."%'   AND visibility LIKE '%".$keyword_visibility."%'    AND subscribe LIKE '".$keyword_subscribe."'AND unsubscribe LIKE '".$keyword_unsubscribe."'";
  68.     }
  69.     $res api_sql_query($sql__FILE____LINE__);
  70.     $obj Database::fetch_object($res);
  71.     return $obj->total_number_of_items;
  72. }
  73. /**
  74.  * Get course data to display
  75.  */
  76. function get_course_data($from$number_of_items$column$direction)
  77. {
  78.     $course_table Database :: get_main_table(TABLE_MAIN_COURSE);
  79.     $users_table Database :: get_main_table(TABLE_MAIN_USER);
  80.     $course_users_table Database :: get_main_table(TABLE_MAIN_COURSE_USER);
  81.     
  82.     $sql "SELECT code AS col0, visual_code AS col1, title AS col2, course_language AS col3, category_code AS col4, subscribe AS col5, unsubscribe AS col6, code AS col7, tutor_name as col8, code AS col9, visibility AS col10 FROM $course_table";
  83.     if (isset ($_GET['keyword']))
  84.     {
  85.         $keyword Database::escape_string($_GET['keyword']);
  86.         $sql .= " WHERE title LIKE '%".$keyword."%' OR code LIKE '%".$keyword."%'";
  87.     }
  88.     elseif (isset ($_GET['keyword_code']))
  89.     {
  90.         $keyword_code Database::escape_string($_GET['keyword_code']);
  91.         $keyword_title Database::escape_string($_GET['keyword_title']);
  92.         $keyword_category Database::escape_string($_GET['keyword_category']);
  93.         $keyword_language Database::escape_string($_GET['keyword_language']);
  94.         $keyword_visibility Database::escape_string($_GET['keyword_visibility']);
  95.         $keyword_subscribe Database::escape_string($_GET['keyword_subscribe']);
  96.         $keyword_unsubscribe Database::escape_string($_GET['keyword_unsubscribe']);
  97.         $sql .= " WHERE code LIKE '%".$keyword_code."%' AND title LIKE '%".$keyword_title."%' AND category_code LIKE '%".$keyword_category."%'  AND course_language LIKE '%".$keyword_language."%'   AND visibility LIKE '%".$keyword_visibility."%'    AND subscribe LIKE '".$keyword_subscribe."'AND unsubscribe LIKE '".$keyword_unsubscribe."'";
  98.     }
  99.     $sql .= " ORDER BY col$column $direction ";
  100.     $sql .= " LIMIT $from,$number_of_items";
  101.     $res api_sql_query($sql__FILE____LINE__);
  102.     $courses array ();
  103.     while ($course Database::fetch_row($res))
  104.     {
  105.         //place colour icons in front of courses
  106.         $course[1get_course_visibility_icon($course[10]).$course[1];
  107.         $course[5$course[5== SUBSCRIBE_ALLOWED get_lang('Yes'get_lang('No');
  108.         $course[6$course[6== UNSUBSCRIBE_ALLOWED get_lang('Yes'get_lang('No');
  109.         $course[7CourseManager :: is_virtual_course_from_system_code($course[7]get_lang('Yes'get_lang('No');
  110.         $course_rem array($course[0],$course[1],$course[2],$course[3],$course[4],$course[5],$course[6],$course[7],$course[8],$course[9]);
  111.         $courses[$course_rem;
  112.     }
  113.     return $courses;
  114. }
  115. /**
  116.  * Filter to display the edit-buttons
  117.  */
  118. function modify_filter($code)
  119. {
  120.     global $charset;
  121.     return
  122.         '<a href="course_information.php?code='.$code.'"><img src="../img/synthese_view.gif" border="0" style="vertical-align: middle" title="'.get_lang('Info').'" alt="'.get_lang('Info').'"/></a>&nbsp;'.
  123.         '<a href="../course_home/course_home.php?cidReq='.$code.'"><img src="../img/course_home.gif" border="0" style="vertical-align: middle" title="'.get_lang('CourseHomepage').'" alt="'.get_lang('CourseHomepage').'"/></a>&nbsp;'.
  124.         '<a href="../tracking/courseLog.php?cidReq='.$code.'"><img src="../img/statistics.gif" border="0" style="vertical-align: middle" title="'.get_lang('Tracking').'" alt="'.get_lang('Tracking').'"/></a>&nbsp;'.
  125.         '<a href="course_edit.php?course_code='.$code.'"><img src="../img/edit.gif" border="0" style="vertical-align: middle" title="'.get_lang('Edit').'" alt="'.get_lang('Edit').'"/></a>&nbsp;'.
  126.         '<a href="course_list.php?delete_course='.$code.'"  onclick="javascript:if(!confirm('."'".addslashes(htmlentities(get_lang("ConfirmYourChoice"),ENT_QUOTES,$charset))."'".')) return false;"><img src="../img/delete.gif" border="0" style="vertical-align: middle" title="'.get_lang('Delete').'" alt="'.get_lang('Delete').'"/></a>';    
  127. }
  128. /**
  129.  * Return an icon representing the visibility of the course
  130.  */
  131. {
  132.     $path api_get_path(REL_CODE_PATH);
  133.     $style 'style="margin-bottom:-5px;margin-right:5px;"';
  134.     switch($v)
  135.     {
  136.         case 0:
  137.             return '<img src="'.$path.'img/bullet_red.gif" title="'.get_lang('CourseVisibilityClosed').'" '.$style.' />';
  138.             break;
  139.         case 1:
  140.             return '<img src="'.$path.'img/bullet_orange.gif" title="'.get_lang('Private').'" '.$style.' />';
  141.             break;
  142.         case 2:
  143.             return '<img src="'.$path.'img/bullet_green.gif" title="'.get_lang('OpenToThePlatform').'" '.$style.' />';
  144.             break;
  145.         case 3:
  146.             return '<img src="'.$path.'img/bullet_blue.gif" title="'.get_lang('OpenToTheWorld').'" '.$style.' />';
  147.             break;
  148.         default:
  149.             return '';
  150.     }
  151. }
  152.  
  153. if (isset ($_POST['action']))
  154. {
  155.     switch ($_POST['action'])
  156.     {
  157.         // Delete selected courses
  158.         case 'delete_courses' :
  159.             $course_codes $_POST['course'];
  160.             if (count($course_codes0)
  161.             {
  162.                 foreach ($course_codes as $index => $course_code)
  163.                 {
  164.                     CourseManager :: delete_course($course_code);
  165.                 }
  166.             }
  167.             break;
  168.     }
  169. }
  170. if (isset ($_GET['search']&& $_GET['search'== 'advanced')
  171. {
  172.     // Get all course categories
  173.     $table_course_category Database :: get_main_table(TABLE_MAIN_CATEGORY);
  174.     $sql "SELECT code,name FROM ".$table_course_category." WHERE auth_course_child ='TRUE' ORDER BY tree_pos";
  175.     $res api_sql_query($sql__FILE____LINE__);
  176.     $categories['%'get_lang('All');
  177.     while ($cat Database::fetch_array($res))
  178.     {
  179.         $categories[$cat['code']] '('.$cat['code'].') '.$cat['name'];
  180.     }
  181.     $interbreadcrumb[array ("url" => 'index.php'"name" => get_lang('PlatformAdmin'));
  182.     $interbreadcrumb[array ("url" => 'course_list.php'"name" => get_lang('CourseList'));
  183.     $tool_name get_lang('SearchACourse');
  184.     Display :: display_header($tool_name);
  185.     //api_display_tool_title($tool_name);
  186.     $form new FormValidator('advanced_course_search''get');
  187.     $form->add_textfield('keyword_code'get_lang('CourseCode')false);
  188.     $form->add_textfield('keyword_title'get_lang('Title')false);
  189.     $form->addElement('select''keyword_category'get_lang('CourseFaculty')$categories);
  190.     $el $form->addElement('select_language''keyword_language'get_lang('CourseLanguage'));
  191.     $el->addOption(get_lang('All')'%');
  192.     $form->addElement('radio''keyword_visibility'get_lang("CourseAccess")get_lang('OpenToTheWorld')COURSE_VISIBILITY_OPEN_WORLD);
  193.     $form->addElement('radio''keyword_visibility'nullget_lang('OpenToThePlatform')COURSE_VISIBILITY_OPEN_PLATFORM);
  194.     $form->addElement('radio''keyword_visibility'nullget_lang('Private')COURSE_VISIBILITY_REGISTERED);
  195.     $form->addElement('radio''keyword_visibility'nullget_lang('CourseVisibilityClosed')COURSE_VISIBILITY_CLOSED);
  196.     $form->addElement('radio''keyword_visibility'nullget_lang('All')'%');
  197.     $form->addElement('radio''keyword_subscribe'get_lang('Subscription')get_lang('Allowed')1);
  198.     $form->addElement('radio''keyword_subscribe'nullget_lang('Denied')0);
  199.     $form->addElement('radio''keyword_subscribe'nullget_lang('All')'%');
  200.     $form->addElement('radio''keyword_unsubscribe'get_lang('Unsubscription')get_lang('AllowedToUnsubscribe')1);
  201.     $form->addElement('radio''keyword_unsubscribe'nullget_lang('NotAllowedToUnsubscribe')0);
  202.     $form->addElement('radio''keyword_unsubscribe'nullget_lang('All')'%');
  203.     $form->addElement('submit''submit'get_lang('Ok'));
  204.     $defaults['keyword_language''%';
  205.     $defaults['keyword_visibility''%';
  206.     $defaults['keyword_subscribe''%';
  207.     $defaults['keyword_unsubscribe''%';
  208.     $form->setDefaults($defaults);
  209.     $form->display();
  210. }
  211. else
  212. {
  213.     $interbreadcrumb[array ("url" => 'index.php'"name" => get_lang('PlatformAdmin'));
  214.     $tool_name get_lang('CourseList');
  215.     Display :: display_header($tool_name);
  216.     //api_display_tool_title($tool_name);
  217.     if (isset ($_GET['delete_course']))
  218.     {
  219.         CourseManager :: delete_course($_GET['delete_course']);
  220.     }
  221.     // Create a search-box
  222.     $form new FormValidator('search_simple','get','','',null,false);
  223.     $renderer =$form->defaultRenderer();
  224.     $renderer->setElementTemplate('<span>{element}</span> ');
  225.     $form->addElement('text','keyword',get_lang('keyword'));
  226.     $form->addElement('submit','submit',get_lang('Search'));
  227.     $form->addElement('static','search_advanced_link',null,'<a href="course_list.php?search=advanced">'.get_lang('AdvancedSearch').'</a>');
  228.     $form->display();
  229.     // Create a sortable table with the course data
  230.     $table new SortableTable('courses''get_number_of_courses''get_course_data',2);
  231.     $parameters=array();
  232.     $table->set_additional_parameters($parameters);
  233.     $table->set_header(0''false);
  234.     $table->set_header(1get_lang('Code'));
  235.     $table->set_header(2get_lang('Title'));
  236.     $table->set_header(3get_lang('Language'));
  237.     $table->set_header(4get_lang('Category'));
  238.     $table->set_header(5get_lang('SubscriptionAllowed'));
  239.     $table->set_header(6get_lang('UnsubscriptionAllowed'));
  240.     $table->set_header(7get_lang('IsVirtualCourse'));
  241.     $table->set_header(8get_lang('Teacher'));
  242.     $table->set_header(9get_lang('Modify')false,'width="120px"');    
  243.     $table->set_column_filter(9,'modify_filter');    
  244.     $table->set_form_actions(array ('delete_courses' => get_lang('DeleteCourse')),'course');
  245.     $table->display();
  246. }
  247. /*
  248. ==============================================================================
  249.         FOOTER 
  250. ==============================================================================
  251. */
  252. ?>

Documentation generated on Thu, 12 Jun 2008 13:16:20 -0500 by phpDocumentor 1.4.1