12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145 |
- <?php
- /* For licensing terms, see /license.txt */
- /**
- * Class CourseCategory
- */
- class CourseCategory
- {
- /**
- * Returns the category fields from the database from an int ID
- * @param int $categoryId The category ID
- * @return array
- */
- public static function getCategoryById($categoryId)
- {
- $tbl_category = Database::get_main_table(TABLE_MAIN_CATEGORY);
- $categoryId = intval($categoryId);
- $sql = "SELECT * FROM $tbl_category WHERE id = $categoryId";
- $result = Database::query($sql);
- if (Database::num_rows($result)) {
- return Database::fetch_array($result, 'ASSOC');
- }
- return [];
- }
- /**
- * Get category details from a simple category code
- * @param string $category The literal category code
- * @return array
- */
- public static function getCategory($category)
- {
- $tbl_category = Database::get_main_table(TABLE_MAIN_CATEGORY);
- $category = Database::escape_string($category);
- $sql = "SELECT * FROM $tbl_category WHERE code ='$category'";
- $result = Database::query($sql);
- if (Database::num_rows($result)) {
- return Database::fetch_array($result, 'ASSOC');
- }
- return [];
- }
- /**
- * @param string $category
- *
- * @return array
- */
- public static function getCategories($category)
- {
- $tbl_category = Database::get_main_table(TABLE_MAIN_CATEGORY);
- $tbl_course = Database::get_main_table(TABLE_MAIN_COURSE);
- $category = Database::escape_string($category);
- $conditions = null;
- $table = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE_CATEGORY);
- $conditions = " INNER JOIN $table a ON (t1.id = a.course_category_id)";
- $whereCondition = " AND a.access_url_id = ".api_get_current_access_url_id();
- $parentIdCondition = " AND (t1.parent_id IS NULL OR t1.parent_id = '' )";
- if (!empty($category)) {
- $parentIdCondition = " AND t1.parent_id = '$category' ";
- }
- $sql = "SELECT
- t1.name,
- t1.code,
- t1.parent_id,
- t1.tree_pos,
- t1.children_count,
- COUNT(DISTINCT t3.code) AS nbr_courses
- FROM $tbl_category t1
- $conditions
- LEFT JOIN $tbl_category t2
- ON t1.code = t2.parent_id
- LEFT JOIN $tbl_course t3
- ON t3.category_code=t1.code
- WHERE
- 1 = 1
- $parentIdCondition
- $whereCondition
- GROUP BY t1.name,
- t1.code,
- t1.parent_id,
- t1.tree_pos,
- t1.children_count
- ORDER BY t1.tree_pos";
- $result = Database::query($sql);
- $categories = Database::store_result($result);
- return $categories;
- }
- /**
- * @param string $code
- * @param string $name
- * @param string $canHaveCourses
- * @param int $parent_id
- *
- * @return bool
- */
- public static function addNode($code, $name, $canHaveCourses, $parent_id)
- {
- $tbl_category = Database::get_main_table(TABLE_MAIN_CATEGORY);
- $code = trim($code);
- $name = trim($name);
- $parent_id = trim($parent_id);
- $code = CourseManager::generate_course_code($code);
- $sql = "SELECT 1 FROM $tbl_category
- WHERE code = '".Database::escape_string($code)."'";
- $result = Database::query($sql);
- if (Database::num_rows($result)) {
- return false;
- }
- $result = Database::query("SELECT MAX(tree_pos) AS maxTreePos FROM $tbl_category");
- $row = Database::fetch_array($result);
- $tree_pos = $row['maxTreePos'] + 1;
- $params = [
- 'name' => $name,
- 'code' => $code,
- 'parent_id' => empty($parent_id) ? null : $parent_id,
- 'tree_pos' => $tree_pos,
- 'children_count' => 0,
- 'auth_course_child' => $canHaveCourses,
- 'auth_cat_child' => 'TRUE'
- ];
- $categoryId = Database::insert($tbl_category, $params);
- self::updateParentCategoryChildrenCount($parent_id, 1);
- self::addToUrl($categoryId);
- return $categoryId;
- }
- /**
- * Recursive function that updates the count of children in the parent
- * @param string $categoryId Category ID
- * @param int $delta The number to add or delete (1 to add one, -1 to remove one)
- */
- public static function updateParentCategoryChildrenCount($categoryId, $delta = 1)
- {
- $tbl_category = Database::get_main_table(TABLE_MAIN_CATEGORY);
- $categoryId = Database::escape_string($categoryId);
- $delta = intval($delta);
- // First get to the highest level possible in the tree
- $result = Database::query("SELECT parent_id FROM $tbl_category WHERE code = '$categoryId'");
- $row = Database::fetch_array($result);
- if ($row !== false and $row['parent_id'] != 0) {
- // if a parent was found, enter there to see if he's got one more parent
- self::updateParentCategoryChildrenCount($row['parent_id'], $delta);
- }
- // Now we're at the top, get back down to update each child
- //$children_count = courseCategoryChildrenCount($categoryId);
- if ($delta >= 0) {
- $sql = "UPDATE $tbl_category SET children_count = (children_count + $delta)
- WHERE code = '$categoryId'";
- } else {
- $sql = "UPDATE $tbl_category SET children_count = (children_count - ".abs($delta).")
- WHERE code = '$categoryId'";
- }
- Database::query($sql);
- }
- /**
- * @param string $node
- */
- public static function deleteNode($node)
- {
- $tbl_course = Database::get_main_table(TABLE_MAIN_COURSE);
- $tbl_category = Database::get_main_table(TABLE_MAIN_CATEGORY);
- $node = Database::escape_string($node);
- $result = Database::query("SELECT parent_id, tree_pos FROM $tbl_category WHERE code='$node'");
- if ($row = Database::fetch_array($result)) {
- if (!empty($row['parent_id'])) {
- Database::query(
- "UPDATE $tbl_course SET category_code = '".$row['parent_id']."' WHERE category_code='$node'"
- );
- Database::query("UPDATE $tbl_category SET parent_id='".$row['parent_id']."' WHERE parent_id='$node'");
- } else {
- Database::query("UPDATE $tbl_course SET category_code='' WHERE category_code='$node'");
- Database::query("UPDATE $tbl_category SET parent_id=NULL WHERE parent_id='$node'");
- }
- Database::query("UPDATE $tbl_category SET tree_pos=tree_pos-1 WHERE tree_pos > '".$row['tree_pos']."'");
- Database::query("DELETE FROM $tbl_category WHERE code='$node'");
- if (!empty($row['parent_id'])) {
- self::updateParentCategoryChildrenCount($row['parent_id'], -1);
- }
- }
- }
- /**
- * @param string $code
- * @param string $name
- * @param string $canHaveCourses
- * @param string $old_code
- * @return bool
- */
- public static function editNode($code, $name, $canHaveCourses, $old_code)
- {
- $tbl_course = Database::get_main_table(TABLE_MAIN_COURSE);
- $tbl_category = Database::get_main_table(TABLE_MAIN_CATEGORY);
- $code = trim(Database::escape_string($code));
- $name = trim(Database::escape_string($name));
- $old_code = Database::escape_string($old_code);
- $canHaveCourses = Database::escape_string($canHaveCourses);
- $code = CourseManager::generate_course_code($code);
- // Updating category
- $sql = "UPDATE $tbl_category SET
- name='$name',
- code='$code',
- auth_course_child = '$canHaveCourses'
- WHERE code = '$old_code'";
- Database::query($sql);
- // Updating children
- $sql = "UPDATE $tbl_category SET parent_id = '$code'
- WHERE parent_id = '$old_code'";
- Database::query($sql);
- // Updating course category
- $sql = "UPDATE $tbl_course SET category_code = '$code'
- WHERE category_code = '$old_code' ";
- Database::query($sql);
- return true;
- }
- /**
- * Move a node up on display
- * @param string $code
- * @param int $tree_pos
- * @param string $parent_id
- *
- * @return bool
- */
- public static function moveNodeUp($code, $tree_pos, $parent_id)
- {
- $tbl_category = Database::get_main_table(TABLE_MAIN_CATEGORY);
- $code = Database::escape_string($code);
- $tree_pos = intval($tree_pos);
- $parent_id = Database::escape_string($parent_id);
- $parentIdCondition = " AND (parent_id IS NULL OR parent_id = '' )";
- if (!empty($parent_id)) {
- $parentIdCondition = " AND parent_id = '$parent_id' ";
- }
- $sql = "SELECT code,tree_pos
- FROM $tbl_category
- WHERE
- tree_pos < $tree_pos
- $parentIdCondition
- ORDER BY tree_pos DESC
- LIMIT 0,1";
- $result = Database::query($sql);
- if (!$row = Database::fetch_array($result)) {
- $sql = "SELECT code, tree_pos
- FROM $tbl_category
- WHERE
- tree_pos > $tree_pos
- $parentIdCondition
- ORDER BY tree_pos DESC
- LIMIT 0,1";
- $result2 = Database::query($sql);
- if (!$row = Database::fetch_array($result2)) {
- return false;
- }
- }
- $sql = "UPDATE $tbl_category
- SET tree_pos ='".$row['tree_pos']."'
- WHERE code='$code'";
- Database::query($sql);
- $sql = "UPDATE $tbl_category
- SET tree_pos = '$tree_pos'
- WHERE code= '".$row['code']."'";
- Database::query($sql);
- return true;
- }
- /**
- * Counts the number of children categories a category has
- * @param int $categoryId The ID of the category of which we want to count the children
- *
- * @return mixed The number of subcategories this category has
- */
- public static function courseCategoryChildrenCount($categoryId)
- {
- $tbl_category = Database::get_main_table(TABLE_MAIN_CATEGORY);
- $categoryId = intval($categoryId);
- $count = 0;
- if (empty($categoryId)) {
- return 0;
- }
- $sql = "SELECT id, code FROM $tbl_category
- WHERE parent_id = $categoryId";
- $result = Database::query($sql);
- while ($row = Database::fetch_array($result)) {
- $count += self::courseCategoryChildrenCount($row['id']);
- }
- $sql = "UPDATE $tbl_category SET
- children_count = $count
- WHERE id = $categoryId";
- Database::query($sql);
- return $count + 1;
- }
- /**
- * @param string $categoryCode
- *
- * @return array
- */
- public static function getChildren($categoryCode)
- {
- $tbl_category = Database::get_main_table(TABLE_MAIN_CATEGORY);
- $categoryCode = Database::escape_string($categoryCode);
- $sql = "SELECT code, id FROM $tbl_category
- WHERE parent_id = '$categoryCode'";
- $result = Database::query($sql);
- $children = [];
- while ($row = Database::fetch_array($result, 'ASSOC')) {
- $children[] = $row;
- $subChildren = self::getChildren($row['code']);
- $children = array_merge($children, $subChildren);
- }
- return $children;
- }
- /**
- * @param string $categoryCode
- *
- * @return array
- */
- public static function getParents($categoryCode)
- {
- if (empty($categoryCode)) {
- return [];
- }
- $tbl_category = Database::get_main_table(TABLE_MAIN_CATEGORY);
- $categoryCode = Database::escape_string($categoryCode);
- $sql = "SELECT code, parent_id FROM $tbl_category
- WHERE code = '$categoryCode'";
- $result = Database::query($sql);
- $children = [];
- while ($row = Database::fetch_array($result, 'ASSOC')) {
- $parent = self::getCategory($row['parent_id']);
- $children[] = $row;
- $subChildren = self::getParents($parent ? $parent['code'] : null);
- $children = array_merge($children, $subChildren);
- }
- return $children;
- }
- /**
- * @param string $categoryCode
- * @return null|string
- */
- public static function getParentsToString($categoryCode)
- {
- $parents = self::getParents($categoryCode);
- if (!empty($parents)) {
- $parents = array_reverse($parents);
- $categories = [];
- foreach ($parents as $category) {
- $categories[] = $category['code'];
- }
- $categoriesInString = implode(' > ', $categories).' > ';
- return $categoriesInString;
- }
- return null;
- }
- /**
- * @param string $categorySource
- *
- * @return string
- */
- public static function listCategories($categorySource)
- {
- $categorySource = isset($categorySource) ? $categorySource : null;
- $categories = self::getCategories($categorySource);
- if (count($categories) > 0) {
- $table = new HTML_Table(array('class' => 'data_table'));
- $column = 0;
- $row = 0;
- $headers = array(
- get_lang('Category'),
- get_lang('SubCat'),
- get_lang('Courses'),
- get_lang('Actions')
- );
- foreach ($headers as $header) {
- $table->setHeaderContents($row, $column, $header);
- $column++;
- }
- $row++;
- $mainUrl = api_get_path(WEB_CODE_PATH).'admin/course_category.php?category='.$categorySource;
- $editIcon = Display::return_icon(
- 'edit.png',
- get_lang('EditNode'),
- null,
- ICON_SIZE_SMALL
- );
- $deleteIcon = Display::return_icon(
- 'delete.png',
- get_lang('DeleteNode'),
- null,
- ICON_SIZE_SMALL
- );
- $moveIcon = Display::return_icon(
- 'up.png',
- get_lang('UpInSameLevel'),
- null,
- ICON_SIZE_SMALL
- );
- foreach ($categories as $category) {
- $editUrl = $mainUrl.'&id='.$category['code'].'&action=edit';
- $moveUrl = $mainUrl.'&id='.$category['code'].'&action=moveUp&tree_pos='.$category['tree_pos'];
- $deleteUrl = $mainUrl.'&id='.$category['code'].'&action=delete';
- $actions = Display::url($editIcon, $editUrl).
- Display::url($moveIcon, $moveUrl).
- Display::url($deleteIcon, $deleteUrl);
- $url = api_get_path(WEB_CODE_PATH).'admin/course_category.php?category='.$category['code'];
- $title = Display::url(
- Display::return_icon(
- 'folder_document.gif',
- get_lang('OpenNode'),
- null,
- ICON_SIZE_SMALL
- ).' '.$category['name'],
- $url
- );
- $content = array(
- $title,
- $category['children_count'],
- $category['nbr_courses'],
- $actions
- );
- $column = 0;
- foreach ($content as $value) {
- $table->setCellContents($row, $column, $value);
- $column++;
- }
- $row++;
- }
- return $table->toHtml();
- } else {
- return Display::return_message(get_lang("NoCategories"), 'warning');
- }
- }
- /**
- * @return array
- */
- public static function getCategoriesToDisplayInHomePage()
- {
- $tbl_category = Database::get_main_table(TABLE_MAIN_CATEGORY);
- $sql = "SELECT name FROM $tbl_category
- WHERE parent_id IS NULL
- ORDER BY tree_pos";
- return Database::store_result(Database::query($sql));
- }
- /**
- * @param int $id
- *
- * @return bool
- */
- public static function addToUrl($id)
- {
- UrlManager::addCourseCategoryListToUrl(
- array($id),
- array(api_get_current_access_url_id())
- );
- }
- /**
- * @param string $categoryCode
- *
- * @return array
- */
- public static function getCategoriesCanBeAddedInCourse($categoryCode)
- {
- $table = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE_CATEGORY);
- $conditions = " INNER JOIN $table a ON (c.id = a.course_category_id)";
- $whereCondition = " AND a.access_url_id = ".api_get_current_access_url_id();
- $tbl_category = Database::get_main_table(TABLE_MAIN_CATEGORY);
- $sql = "SELECT code, name
- FROM $tbl_category c
- $conditions
- WHERE (auth_course_child = 'TRUE' OR code = '".Database::escape_string($categoryCode)."')
- $whereCondition
- ORDER BY tree_pos";
- $res = Database::query($sql);
- $categories[''] = '-';
- while ($cat = Database::fetch_array($res)) {
- $categories[$cat['code']] = '('.$cat['code'].') '.$cat['name'];
- ksort($categories);
- }
- return $categories;
- }
- /**
- * @return array
- */
- public static function browseCourseCategories()
- {
- $tbl_category = Database::get_main_table(TABLE_MAIN_CATEGORY);
- $conditions = null;
- $table = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE_CATEGORY);
- $conditions = " INNER JOIN $table a ON (c.id = a.course_category_id)";
- $whereCondition = " WHERE a.access_url_id = ".api_get_current_access_url_id();
- $sql = "SELECT c.* FROM $tbl_category c
- $conditions
- $whereCondition
- ORDER BY tree_pos ASC";
- $result = Database::query($sql);
- $url_access_id = 1;
- if (api_is_multiple_url_enabled()) {
- $url_access_id = api_get_current_access_url_id();
- }
- $countCourses = CourseManager::countAvailableCourses($url_access_id);
- $categories = [];
- $categories[0][0] = array(
- 'id' => 0,
- 'name' => get_lang('DisplayAll'),
- 'code' => 'ALL',
- 'parent_id' => null,
- 'tree_pos' => 0,
- 'count_courses' => $countCourses
- );
- while ($row = Database::fetch_array($result)) {
- $count_courses = self::countCoursesInCategory($row['code']);
- $row['count_courses'] = $count_courses;
- if (!isset($row['parent_id'])) {
- $categories[0][$row['tree_pos']] = $row;
- } else {
- $categories[$row['parent_id']][$row['tree_pos']] = $row;
- }
- }
- $count_courses = self::countCoursesInCategory();
- $categories[0][count($categories[0]) + 1] = array(
- 'id' => 0,
- 'name' => get_lang('None'),
- 'code' => 'NONE',
- 'parent_id' => null,
- 'tree_pos' => $row['tree_pos'] + 1,
- 'children_count' => 0,
- 'auth_course_child' => true,
- 'auth_cat_child' => true,
- 'count_courses' => $count_courses
- );
- return $categories;
- }
- /**
- * @param string $category_code
- * @param string $searchTerm
- * @return int
- */
- public static function countCoursesInCategory($category_code = '', $searchTerm = '')
- {
- $tbl_course = Database::get_main_table(TABLE_MAIN_COURSE);
- $categoryCode = Database::escape_string($category_code);
- $searchTerm = Database::escape_string($searchTerm);
- $specialCourseList = CourseManager::get_special_course_list();
- $without_special_courses = '';
- if (!empty($specialCourseList)) {
- $without_special_courses = ' AND course.id NOT IN ("'.implode('","', $specialCourseList).'")';
- }
- $visibilityCondition = CourseManager::getCourseVisibilitySQLCondition('course', true);
- $categoryFilter = '';
- if ($categoryCode === 'ALL') {
- // Nothing to do
- } elseif ($categoryCode === 'NONE') {
- $categoryFilter = ' AND category_code = "" ';
- } else {
- $categoryFilter = ' AND category_code = "'.$categoryCode.'" ';
- }
- $searchFilter = '';
- if (!empty($searchTerm)) {
- $searchFilter = ' AND (code LIKE "%'.$searchTerm.'%"
- OR title LIKE "%'.$searchTerm.'%"
- OR tutor_name LIKE "%'.$searchTerm.'%") ';
- }
- $sql = "SELECT * FROM $tbl_course
- WHERE
- visibility != '0' AND
- visibility != '4'
- $categoryFilter
- $searchFilter
- $without_special_courses
- $visibilityCondition
- ";
- // Showing only the courses of the current portal access_url_id.
- if (api_is_multiple_url_enabled()) {
- $url_access_id = api_get_current_access_url_id();
- if ($url_access_id != -1) {
- $tbl_url_rel_course = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE);
- $sql = "SELECT * FROM $tbl_course as course
- INNER JOIN $tbl_url_rel_course as url_rel_course
- ON (url_rel_course.c_id = course.id)
- WHERE
- access_url_id = $url_access_id AND
- course.visibility != '0' AND
- course.visibility != '4' AND
- category_code = '$category_code'
- $searchFilter
- $without_special_courses
- $visibilityCondition
- ";
- }
- }
- return Database::num_rows(Database::query($sql));
- }
- /**
- * @param string $category_code
- * @param int $random_value
- * @param array $limit will be used if $random_value is not set.
- * This array should contains 'start' and 'length' keys
- * @return array
- */
- public static function browseCoursesInCategory($category_code, $random_value = null, $limit = [])
- {
- $tbl_course = Database::get_main_table(TABLE_MAIN_COURSE);
- $specialCourseList = CourseManager::get_special_course_list();
- $without_special_courses = '';
- if (!empty($specialCourseList)) {
- $without_special_courses = ' AND course.id NOT IN ("'.implode('","', $specialCourseList).'")';
- }
- $visibilityCondition = CourseManager::getCourseVisibilitySQLCondition('course', true);
- if (!empty($random_value)) {
- $random_value = intval($random_value);
- $sql = "SELECT COUNT(*) FROM $tbl_course";
- $result = Database::query($sql);
- list($num_records) = Database::fetch_row($result);
- if (api_is_multiple_url_enabled()) {
- $url_access_id = api_get_current_access_url_id();
- $tbl_url_rel_course = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE);
- $sql = "SELECT COUNT(*) FROM $tbl_course course
- INNER JOIN $tbl_url_rel_course as url_rel_course
- ON (url_rel_course.c_id = course.id)
- WHERE access_url_id = $url_access_id ";
- $result = Database::query($sql);
- list($num_records) = Database::fetch_row($result);
- $sql = "SELECT course.id FROM $tbl_course course
- INNER JOIN $tbl_url_rel_course as url_rel_course
- ON (url_rel_course.c_id = course.id)
- WHERE
- access_url_id = $url_access_id AND
- RAND()*$num_records< $random_value
- $without_special_courses
- $visibilityCondition
- ORDER BY RAND()
- LIMIT 0, $random_value";
- } else {
- $sql = "SELECT id FROM $tbl_course course
- WHERE
- RAND()*$num_records< $random_value
- $without_special_courses
- $visibilityCondition
- ORDER BY RAND()
- LIMIT 0, $random_value";
- }
- $result = Database::query($sql);
- $id_in = null;
- while (list($id) = Database::fetch_row($result)) {
- if ($id_in) {
- $id_in .= ",$id";
- } else {
- $id_in = "$id";
- }
- }
- if ($id_in === null) {
- return [];
- }
- $sql = "SELECT * FROM $tbl_course WHERE id IN($id_in)";
- } else {
- $limitFilter = self::getLimitFilterFromArray($limit);
- $category_code = Database::escape_string($category_code);
- if (empty($category_code) || $category_code == "ALL") {
- $sql = "SELECT * FROM $tbl_course
- WHERE
- 1=1
- $without_special_courses
- $visibilityCondition
- ORDER BY title $limitFilter ";
- } else {
- if ($category_code == 'NONE') {
- $category_code = '';
- }
- $sql = "SELECT * FROM $tbl_course
- WHERE
- category_code='$category_code'
- $without_special_courses
- $visibilityCondition
- ORDER BY title $limitFilter ";
- }
- // Showing only the courses of the current Chamilo access_url_id
- if (api_is_multiple_url_enabled()) {
- $url_access_id = api_get_current_access_url_id();
- $tbl_url_rel_course = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE);
- if ($category_code != "ALL") {
- $sql = "SELECT * FROM $tbl_course as course
- INNER JOIN $tbl_url_rel_course as url_rel_course
- ON (url_rel_course.c_id = course.id)
- WHERE
- access_url_id = $url_access_id AND
- category_code='$category_code'
- $without_special_courses
- $visibilityCondition
- ORDER BY title $limitFilter";
- } else {
- $sql = "SELECT * FROM $tbl_course as course
- INNER JOIN $tbl_url_rel_course as url_rel_course
- ON (url_rel_course.c_id = course.id)
- WHERE
- access_url_id = $url_access_id
- $without_special_courses
- $visibilityCondition
- ORDER BY title $limitFilter";
- }
- }
- }
- $result = Database::query($sql);
- $courses = [];
- while ($row = Database::fetch_array($result)) {
- $row['registration_code'] = !empty($row['registration_code']);
- $count_users = CourseManager::get_users_count_in_course($row['code']);
- $count_connections_last_month = Tracking::get_course_connections_count(
- $row['id'],
- 0,
- api_get_utc_datetime(time() - (30 * 86400))
- );
- if ($row['tutor_name'] == '0') {
- $row['tutor_name'] = get_lang('NoManager');
- }
- $point_info = CourseManager::get_course_ranking($row['id'], 0);
- $courses[] = array(
- 'real_id' => $row['id'],
- 'point_info' => $point_info,
- 'code' => $row['code'],
- 'directory' => $row['directory'],
- 'visual_code' => $row['visual_code'],
- 'title' => $row['title'],
- 'tutor' => $row['tutor_name'],
- 'subscribe' => $row['subscribe'],
- 'unsubscribe' => $row['unsubscribe'],
- 'registration_code' => $row['registration_code'],
- 'creation_date' => $row['creation_date'],
- 'visibility' => $row['visibility'],
- 'category' => $row['category_code'],
- 'count_users' => $count_users,
- 'count_connections' => $count_connections_last_month
- );
- }
- return $courses;
- }
- /**
- * create recursively all categories as option of the select passed in parameter.
- *
- * @param HTML_QuickForm_Element $element
- * @param string $defaultCode the option value to select by default (used mainly for edition of courses)
- * @param string $parentCode the parent category of the categories added (default=null for root category)
- * @param string $padding the indent param (you shouldn't indicate something here)
- */
- public static function setCategoriesInForm($element, $defaultCode = null, $parentCode = null, $padding = null)
- {
- $tbl_category = Database::get_main_table(TABLE_MAIN_CATEGORY);
- $table = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE_CATEGORY);
- $conditions = " INNER JOIN $table a ON (c.id = a.course_category_id)";
- $whereCondition = " AND a.access_url_id = ".api_get_current_access_url_id();
- $sql = "SELECT code, name, auth_course_child, auth_cat_child
- FROM $tbl_category c
- $conditions
- WHERE parent_id ".(empty($parentCode) ? "IS NULL" : "='".Database::escape_string($parentCode)."'")."
- $whereCondition
- ORDER BY name, code";
- $res = Database::query($sql);
- while ($cat = Database::fetch_array($res, 'ASSOC')) {
- $params = $cat['auth_course_child'] == 'TRUE' ? '' : 'disabled';
- $params .= ($cat['code'] == $defaultCode) ? ' selected' : '';
- $option = $padding.' '.$cat['name'].' ('.$cat['code'].')';
- $element->addOption($option, $cat['code'], $params);
- if ($cat['auth_cat_child'] == 'TRUE') {
- self::setCategoriesInForm($element, $defaultCode, $cat['code'], $padding.' - ');
- }
- }
- }
- /**
- * @param array $list
- * @return array
- */
- public static function getCourseCategoryNotInList($list)
- {
- $table = Database::get_main_table(TABLE_MAIN_CATEGORY);
- if (empty($list)) {
- $sql = "SELECT * FROM $table
- WHERE (parent_id IS NULL) ";
- $result = Database::query($sql);
- return Database::store_result($result, 'ASSOC');
- }
- $list = array_map('intval', $list);
- $listToString = implode("','", $list);
- $sql = "SELECT * FROM $table
- WHERE id NOT IN ('$listToString') AND (parent_id IS NULL) ";
- $result = Database::query($sql);
- return Database::store_result($result, 'ASSOC');
- }
- /**
- * @param string $keyword
- * @return array|null
- */
- public static function searchCategoryByKeyword($keyword)
- {
- if (empty($keyword)) {
- return null;
- }
- $tableCategory = Database::get_main_table(TABLE_MAIN_CATEGORY);
- $table = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE_CATEGORY);
- $conditions = " INNER JOIN $table a ON (c.id = a.course_category_id)";
- $whereCondition = " AND a.access_url_id = ".api_get_current_access_url_id();
- $keyword = Database::escape_string($keyword);
- $sql = "SELECT c.*, c.name as text
- FROM $tableCategory c $conditions
- WHERE
- (
- c.code LIKE '%$keyword%' OR name LIKE '%$keyword%'
- ) AND auth_course_child = 'TRUE'
- $whereCondition ";
- $result = Database::query($sql);
- return Database::store_result($result, 'ASSOC');
- }
- /**
- * @param array $list
- * @return array
- */
- public static function searchCategoryById($list)
- {
- if (empty($list)) {
- return [];
- } else {
- $list = array_map('intval', $list);
- $list = implode("','", $list);
- }
- $tableCategory = Database::get_main_table(TABLE_MAIN_CATEGORY);
- $table = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE_CATEGORY);
- $conditions = " INNER JOIN $table a ON (c.id = a.course_category_id)";
- $whereCondition = " AND a.access_url_id = ".api_get_current_access_url_id();
- $sql = "SELECT c.*, c.name as text FROM $tableCategory c $conditions
- WHERE c.id IN $list $whereCondition";
- $result = Database::query($sql);
- return Database::store_result($result, 'ASSOC');
- }
- /**
- * @return array
- */
- public static function getLimitArray()
- {
- $pageCurrent = isset($_REQUEST['pageCurrent']) ? intval($_GET['pageCurrent']) : 1;
- $pageLength = isset($_REQUEST['pageLength']) ? intval($_GET['pageLength']) : 12;
- return array(
- 'start' => ($pageCurrent - 1) * $pageLength,
- 'current' => $pageCurrent,
- 'length' => $pageLength
- );
- }
- /**
- * Return LIMIT to filter SQL query
- * @param array $limit
- * @return string
- */
- public static function getLimitFilterFromArray($limit)
- {
- $limitFilter = '';
- if (!empty($limit) && is_array($limit)) {
- $limitStart = isset($limit['start']) ? $limit['start'] : 0;
- $limitLength = isset($limit['length']) ? $limit['length'] : 12;
- $limitFilter = 'LIMIT '.$limitStart.', '.$limitLength;
- }
- return $limitFilter;
- }
- /**
- * Get Pagination HTML div
- * @param $pageCurrent
- * @param $pageLength
- * @param $pageTotal
- * @return string
- */
- public static function getCatalogPagination($pageCurrent, $pageLength, $pageTotal)
- {
- // Start empty html
- $pageDiv = '';
- $html = '';
- $pageBottom = max(1, $pageCurrent - 3);
- $pageTop = min($pageTotal, $pageCurrent + 3);
- if ($pageBottom > 1) {
- $pageDiv .= self::getPageNumberItem(1, $pageLength);
- if ($pageBottom > 2) {
- $pageDiv .= self::getPageNumberItem($pageBottom - 1, $pageLength, null, '...');
- }
- }
- // For each page add its page button to html
- for ($i = $pageBottom; $i <= $pageTop; $i++) {
- if ($i === $pageCurrent) {
- $pageItemAttributes = array('class' => 'active');
- } else {
- $pageItemAttributes = [];
- }
- $pageDiv .= self::getPageNumberItem($i, $pageLength, $pageItemAttributes);
- }
- // Check if current page is the last page
- if ($pageTop < $pageTotal) {
- if ($pageTop < ($pageTotal - 1)) {
- $pageDiv .= self::getPageNumberItem($pageTop + 1, $pageLength, null, '...');
- }
- $pageDiv .= self::getPageNumberItem($pageTotal, $pageLength);
- }
- // Complete pagination html
- $pageDiv = Display::tag('ul', $pageDiv, array('class' => 'pagination'));
- $html .= '<nav>'.$pageDiv.'</nav>';
- return $html;
- }
- /**
- * Return URL to course catalog
- * @param int $pageCurrent
- * @param int $pageLength
- * @param string $categoryCode
- * @param int $hiddenLinks
- * @param string $action
- * @return string
- */
- public static function getCourseCategoryUrl(
- $pageCurrent,
- $pageLength,
- $categoryCode = null,
- $hiddenLinks = null,
- $action = null
- ) {
- $requestAction = isset($_REQUEST['action']) ? Security::remove_XSS($_REQUEST['action']) : null;
- $action = isset($action) ? Security::remove_XSS($action) : $requestAction;
- $searchTerm = isset($_REQUEST['search_term']) ? Security::remove_XSS($_REQUEST['search_term']) : null;
- if ($action === 'subscribe_user_with_password') {
- $action = 'subscribe';
- }
- $categoryCodeRequest = isset($_REQUEST['category_code']) ? Security::remove_XSS($_REQUEST['category_code']) : null;
- $categoryCode = isset($categoryCode) ? Security::remove_XSS($categoryCode) : $categoryCodeRequest;
- $hiddenLinksRequest = isset($_REQUEST['hidden_links']) ? Security::remove_XSS($_REQUEST['hidden_links']) : null;
- $hiddenLinks = isset($hiddenLinks) ? Security::remove_XSS($hiddenLinksRequest) : $categoryCodeRequest;
- // Start URL with params
- $pageUrl = api_get_self().
- '?action='.$action.
- '&category_code='.$categoryCode.
- '&hidden_links='.$hiddenLinks.
- '&pageCurrent='.$pageCurrent.
- '&pageLength='.$pageLength;
- switch ($action) {
- case 'subscribe':
- // for search
- $pageUrl .=
- '&search_term='.$searchTerm.
- '&search_course=1'.
- '&sec_token='.$_SESSION['sec_token'];
- break;
- case 'display_courses':
- // No break
- default:
- break;
- }
- return $pageUrl;
- }
- /**
- * Get li HTML of page number
- * @param $pageNumber
- * @param $pageLength
- * @param array $liAttributes
- * @param string $content
- * @return string
- */
- public static function getPageNumberItem(
- $pageNumber,
- $pageLength,
- $liAttributes = [],
- $content = ''
- ) {
- // Get page URL
- $url = self::getCourseCategoryUrl(
- $pageNumber,
- $pageLength
- );
- // If is current page ('active' class) clear URL
- if (isset($liAttributes) && is_array($liAttributes) && isset($liAttributes['class'])) {
- if (strpos('active', $liAttributes['class']) !== false) {
- $url = '';
- }
- }
- $content = !empty($content) ? $content : $pageNumber;
- return Display::tag(
- 'li',
- Display::url(
- $content,
- $url
- ),
- $liAttributes
- );
- }
- /**
- * Return the name tool by action
- * @param string $action
- * @return string
- */
- public static function getCourseCatalogNameTools($action)
- {
- $nameTools = get_lang('SortMyCourses');
- if (empty($action)) {
- return $nameTools; //should never happen
- }
- switch ($action) {
- case 'createcoursecategory':
- $nameTools = get_lang('CreateCourseCategory');
- break;
- case 'subscribe':
- $nameTools = get_lang('CourseManagement');
- break;
- case 'subscribe_user_with_password':
- $nameTools = get_lang('CourseManagement');
- break;
- case 'display_random_courses':
- // No break
- case 'display_courses':
- $nameTools = get_lang('CourseManagement');
- break;
- case 'display_sessions':
- $nameTools = get_lang('Sessions');
- break;
- default:
- // Nothing to do
- break;
- }
- return $nameTools;
- }
- }
|