123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442 |
- <?php
- require_once __DIR__.'/register_course_widget.class.php';
- class SearchCourseWidget
- {
- const PARAM_ACTION = 'action';
- const ACTION_SUBSCRIBE = 'subscribe';
-
- public static function post($key, $default = '')
- {
- return isset($_POST[$key]) ? $_POST[$key] : $default;
- }
-
- public static function get($key, $default = '')
- {
- return isset($_GET[$key]) ? $_GET[$key] : $default;
- }
- public static function server($key, $default = '')
- {
- return isset($_SERVER[$key]) ? $_SERVER[$key] : $default;
- }
- public static function get_lang($name)
- {
- return SearchCoursePlugin::create()->get_lang($name);
- }
-
- function is_homepage()
- {
- $url = self::server('REQUEST_URI');
- $url = explode('?', $url);
- $url = reset($url);
- $url = self::server('SERVER_NAME').$url;
- $root = api_get_path('WEB_PATH');
- $root = str_replace('https://', '', $root);
- $root = str_replace('http://', '', $root);
- $index_url = $root.'index.php';
- return $url == $index_url || $url == $root;
- }
-
- function is_user_portal()
- {
- $url = self::server('REQUEST_URI');
- $url = explode('?', $url);
- $url = reset($url);
- $url = self::server('SERVER_NAME').$url;
- $root = api_get_path('WEB_PATH');
- $root = str_replace('https://', '', $root);
- $root = str_replace('http://', '', $root);
- $index_url = $root.'user_portal.php';
- return $url == $index_url || $url == $root;
- }
-
- function accept()
- {
- return $this->is_homepage() || $this->is_user_portal();
- }
-
- function run()
- {
- if (!$this->accept())
- {
- return;
- }
- $this->display_header();
- $this->display_form();
- $search_term = self::post('search_term');
- $action = self::get('action');
- $has_content = !empty($search_term) || !empty($action);
- if ($has_content)
- {
- echo '<div class="list">';
- }
- else
- {
- echo '<div>';
- }
- if (RegisterCourseWidget::factory()->run())
- {
- $result = true;
- }
- else
- {
- $result = $this->action_display();
- }
- echo '</div>';
- $this->display_footer();
- return $result;
- }
- function get_url($action = '')
- {
- $self = $_SERVER['PHP_SELF'];
- $parameters = array();
- if ($action)
- {
- $parameters[self::PARAM_ACTION] = $action;
- }
- $parameters = implode('&', $parameters);
- $parameters = $parameters ? '?'.$parameters : '';
- return $self.$parameters;
- }
-
- function action_display()
- {
- global $charset;
- $search_term = self::post('search_term');
- if ($search_term)
- {
- $search_result_for_label = self::get_lang('SearchResultsFor');
- $search_term_html = htmlentities($search_term, ENT_QUOTES, $charset);
- echo "<h5>$search_result_for_label $search_term_html</h5>";
- $courses = $this->retrieve_courses($search_term);
- $this->display_list($courses);
- }
- return true;
- }
- function display_header()
- {
- $search_course_label = self::get_lang('SearchCourse');
- echo <<<EOT
- <div class="well course_search">
- <div class="menusection">
- <h4>$search_course_label</h4>
- EOT;
- }
- function display_footer()
- {
- echo '</div></div>';
- }
-
- function display_form()
- {
- global $stok;
- $search_label = self::get_lang('_search');
- $self = api_get_self();
- $search_term = self::post('search_term');
- $form = <<<EOT
- <form class="course_list" method="post" action="$self">
- <input type="hidden" name="sec_token" value="$stok" />
- <input type="hidden" name="search_course" value="1" />
- <input type="text" name="search_term" class="span2" value="$search_term" />
- <input class="btn btn-default" type="submit" value="$search_label" />
- </form>
- EOT;
- echo $form;
- }
-
- function display_list($courses)
- {
- if (empty($courses)) {
- return false;
- }
- $user_courses = $this->retrieve_user_courses();
- $display_coursecode = (api_get_setting('display_coursecode_in_courselist') == 'true');
- $display_teacher = (api_get_setting('display_teacher_in_courselist') == 'true');
- echo '<table cellpadding="4">';
- foreach ($courses as $key => $course) {
- $details = array();
- if ($display_coursecode) {
- $details[] = $course['visual_code'];
- }
- if ($display_teacher) {
- $details[] = $course['tutor'];
- }
- $details = implode(' - ', $details);
- $title = $course['title'];
- $href = api_get_path(WEB_COURSE_PATH).$course['code'].'/index.php';
- echo '<tr><td><b><a href="'.$href.'">'."$title</a></b><br/>$details</td><td>";
- if (!api_is_anonymous()) {
- if ($course['registration_code']) {
- Display::display_icon(
- 'passwordprotected.png',
- '',
- array('style' => 'float:left;')
- );
- }
- $this->display_subscribe_icon($course, $user_courses);
- }
- echo '</td></tr>';
- }
- echo '</table>';
- return true;
- }
-
- function display_subscribe_icon($current_course, $user_courses)
- {
- global $stok;
-
- $code = $current_course['code'];
- if (isset($user_courses[$code]))
- {
- echo self::get_lang('AlreadySubscribed');
- return false;
- }
-
- if ($current_course['subscribe'] != SUBSCRIBE_ALLOWED) {
- echo self::get_lang('SubscribingNotAllowed');
- return false;
- }
-
- $self = $_SERVER['PHP_SELF'];
- echo <<<EOT
- <form action="$self?action=subscribe" method="post">
- <input type="hidden" name="sec_token" value="$stok" />
- <input type="hidden" name="subscribe" value="$code" />
- EOT;
- $search_term = $this->post('search_term');
- if ($search_term)
- {
- $search_term = Security::remove_XSS($search_term);
- echo <<<EOT
- <input type="hidden" name="search_course" value="1" />
- <input type="hidden" name="search_term" value="$search_term" />
- EOT;
- }
- echo '<input type="image" name="unsub" src="'.Display::returnIconPath('enroll.gif').'" alt="'.get_lang('Subscribe').'" />
- '.get_lang('Subscribe').'
- </form>
- ';
- return true;
- }
-
-
- function retrieve_courses($search_term)
- {
- if (empty($search_term))
- {
- return array();
- }
- $search_term = Database::escape_string($search_term);
- $course_table = Database::get_main_table(TABLE_MAIN_COURSE);
- if (api_is_anonymous())
- {
- $course_fiter = 'visibility = '.COURSE_VISIBILITY_OPEN_WORLD;
- }
- else
- {
- $course_fiter = 'visibility = '.COURSE_VISIBILITY_OPEN_WORLD.' OR ';
- $course_fiter .= 'visibility = '.COURSE_VISIBILITY_OPEN_PLATFORM.' OR ';
- $course_fiter .= '(visibility = '.COURSE_VISIBILITY_REGISTERED.' AND subscribe = 1)';
- }
- $sql = <<<EOT
- SELECT * FROM $course_table
- WHERE ($course_fiter) AND (code LIKE '%$search_term%' OR visual_code LIKE '%$search_term%' OR title LIKE '%$search_term%' OR tutor_name LIKE '%$search_term%')
- ORDER BY title, visual_code ASC
- EOT;
- $result = array();
- $resultset = Database::query($sql);
- while ($row = Database::fetch_array($resultset)) {
- $code = $row['code'];
- $result[$code] = array(
- 'code' => $code,
- 'directory' => $row['directory'],
- 'visual_code' => $row['visual_code'],
- 'title' => $row['title'],
- 'tutor' => $row['tutor_name'],
- 'subscribe' => $row['subscribe'],
- 'unsubscribe' => $row['unsubscribe']
- );
- }
- return $result;
- }
-
- function retrieve_user_courses($user_id = null)
- {
- if (is_null($user_id))
- {
- global $_user;
- $user_id = $_user['user_id'];
- }
- $course_table = Database::get_main_table(TABLE_MAIN_COURSE);
- $user_course_table = Database::get_main_table(TABLE_MAIN_COURSE_USER);
- $user_id = intval($user_id);
- $sql_select_courses = "SELECT course.code k, course.visual_code vc, course.subscribe subscr, course.unsubscribe unsubscr,
- course.title i, course.tutor_name t, course.directory dir, course_rel_user.status status,
- course_rel_user.sort sort, course_rel_user.user_course_cat user_course_cat
- FROM $course_table course, $user_course_table course_rel_user
- WHERE course.id = course_rel_user.c_id
- AND course_rel_user.user_id = $user_id
- ORDER BY course_rel_user.sort ASC";
- $result = array();
- $resultset = Database::query($sql_select_courses);
- while ($row = Database::fetch_array($resultset)) {
- $code = $row['k'];
- $result[$code] = array(
- 'code' => $code,
- 'visual_code' => $row['vc'],
- 'title' => $row['i'],
- 'directory' => $row['dir'],
- 'status' => $row['status'],
- 'tutor' => $row['t'],
- 'subscribe' => $row['subscr'],
- 'unsubscribe' => $row['unsubscr'],
- 'sort' => $row['sort'],
- 'user_course_category' => $row['user_course_cat']);
- }
- return $result;
- }
-
-
- function filter_out_user_courses($courses)
- {
- if (empty($courses))
- {
- return $courses;
- }
- global $_user;
- $user_id = $_user['user_id'];
- $user_courses = $this->retrieve_user_courses($user_id);
- foreach ($user_courses as $key => $value)
- {
- unset($courses[$key]);
- }
- return $courses;
- }
- }
|