$this->load->view('header', array('selected_menu' => 'home'));
$main_params['content'] = $this->load->view('catalog/index_view', $data, TRUE);
- $main_params['side'] = $this->load->view('side_default.php', NULL, TRUE);
+ $main_params['side'] = $this->load->view('side_default', NULL, TRUE);
$this->load->view('main', $main_params);
$this->load->view('footer');
// ** LOADING MODEL
// **
// Video Category
- $categories = $this->config->item('categories');
- $category_id = array_search($category_name, $categories);
- $vs_data['category_name'] = $category_name;
- $vs_data['category_id'] = $category_id;
- $vs_data['category_title'] = $category_name ?
- $this->lang->line("ui_categ_$category_name") : $category_name;
+ $vs_data = $this->_get_category_data($category_name);
// Retrieve videos summary.
$this->load->model('videos_model');
$pg_config['base_url'] = site_url("catalog/category/$category_name/");
$pg_config['uri_segment'] = 4;
$pg_config['total_rows'] = $this->videos_model->get_videos_count(
- $category_id);
+ $vs_data['category_id']);
$pg_config['per_page'] = $this->config->item('videos_per_page');
$this->pagination->initialize($pg_config);
$vs_data['pagination'] = $this->pagination->create_links();
// Video Summary
- $data['video_summary'] = $this->load->view('catalog/videos_summary_view',
- $vs_data, TRUE);
+// $data['video_summary'] = $this->load->view('catalog/videos_summary_view',
+// $vs_data, TRUE);
$params = array( 'title' => $this->config->item('site_name'),
'css' => array(
$this->load->view('html_begin', $this->html_head_params);
$this->load->view('header');
- $main_params['content'] = $this->load->view('catalog/category_view', $data, TRUE);
- $main_params['side'] = $this->load->view('side_default.php', NULL, TRUE);
+// $main_params['content'] = $this->load->view('catalog/category_view', $data, TRUE);
+ $main_params['content'] =
+ $this->load->view('catalog/videos_summary_view', $vs_data, TRUE);
+ $main_params['side'] = $this->load->view('side_default', NULL, TRUE);
$this->load->view('main', $main_params);
$this->load->view('footer');
$this->load->view('html_end');
}
- public function search($str_search = "")
+ public function search($search_query = "", $offset = 0, $category_name = NULL)
{
- // TODO get query string from URL.
- if ($str_search === "")
+ // Redirect to an URL which contains search string if data was passed
+ // via POST method and not via URL segments.
+ $str_post_search = $this->input->post('search', TRUE);
+ if ($search_query === "" && $str_post_search !== FALSE)
redirect('catalog/search/'. $this->input->post('search', TRUE));
-
+
// **
// ** LOADING MODEL
// **
- // Video Category
- // TODO
- $vs_data['category_name'] = "";
- $vs_data['category_title'] = "Search Results for «$str_search»";
-
- // Retrieve videos summary.
- $this->load->model('videos_model');
- $vs_data['videos'] = $this->videos_model->search_videos(
- $str_search);
- if ($vs_data['videos'] === NULL)
- $vs_data['videos'] = array();
-
- $vs_data['pagination'] = '';
+ // Category
+ $results_data = $this->_get_category_data($category_name);
+ if ($results_data === NULL)
+ $results_data = array('category_id'=>NULL);
- // Video Summary
- $data['video_summary'] = $this->load->view('catalog/videos_summary_view',
- $vs_data, TRUE);
+ $results_data['search_query'] = $search_query;
+ // Check if search string is valid.
+ if (strlen($search_query) < 4)
+ {
+ $results_data['videos'] = NULL;
+ }
+ else
+ {
+ // Retrieve search results.
+ $this->load->model('videos_model');
+ $results_data['count'] = $this->videos_model->search_videos(
+ $search_query);
+ $results_data['videos'] = $this->videos_model->search_videos(
+ $search_query, intval($offset),
+ $this->config->item('search_results_per_page'),
+ $results_data['category_id']);
+ if ($results_data['videos'] === NULL)
+ $results_data['videos'] = array();
+
+ // Pagination
+ $this->load->library('pagination');
+ $pg_config['base_url'] = site_url("catalog/search/$search_query/");
+ $pg_config['uri_segment'] = 4;
+ $pg_config['total_rows'] = $results_data['count'];
+ $pg_config['per_page'] =
+ $this->config->item('search_results_per_page');
+ $this->pagination->initialize($pg_config);
+ $results_data['pagination'] = $this->pagination->create_links();
+ }
+
$params = array( 'title' => $this->config->item('site_name'),
'css' => array(
'catalog.css'
$this->load->view('html_begin', $this->html_head_params);
$this->load->view('header');
- $main_params['content'] = $this->load->view('catalog/category_view', $data, TRUE);
- $main_params['side'] = $this->load->view('side_default.php', NULL, TRUE);
+ // Search Results
+ $main_params['content'] =
+ $this->load->view('catalog/search_results_view',
+ $results_data, TRUE);
+ $main_params['side'] = $this->load->view('side_default', NULL, TRUE);
$this->load->view('main', $main_params);
$this->load->view('footer');
$this->load->view('html_end');
-
}
+
+ public function _get_category_data($category_name)
+ {
+ if ($category_name === NULL)
+ return NULL;
+
+ $categories = $this->config->item('categories');
+ $category_id = array_search($category_name, $categories);
+ $results_data['category_name'] = $category_name;
+ $results_data['category_id'] = $category_id;
+ $results_data['category_title'] = $category_name ?
+ $this->lang->line("ui_categ_$category_name") : $category_name;
+
+ return $results_data;
+ }
}
/* End of file catalog.php */
$category_id);
if ($query->num_rows() > 0)
- return $row = $query->row()->count;
+ return $query->row()->count;
// Error
return NULL;
return $thumbs;
}
- public function search_videos($str_search)
+ /**
+ * Searches videos in DB based on a search query string and returns an
+ * associative array of results.
+ * If count is zero the function only return the number of results.
+ * @param string $search_query
+ * @param int $offset
+ * @param int $count
+ * @param int $category_id if NULL, all categories are searched
+ * @return array an associative array with the same keys as that from
+ * get_videos_summary's result, but with two additional keys:
+ * description and date.
+ */
+ public function search_videos($search_query, $offset = 0, $count = 0,
+ $category_id = NULL)
{
- // TODO offset, count for search
- $offset = 0;
- $count = 100;
+ if ($count === 0)
+ {
+ $selected_columns = "COUNT(*) count";
+ $limit = "";
+ }
+ else
+ {
+ $selected_columns = "id, name, title, duration, user_id, views, thumbs_count, default_thumb, date, description";
+ $limit = "LIMIT $offset, $count";
+ }
+
+ if ($category_id !== NULL)
+ $category_cond = "category_id = '$category_id' AND ";
+ else
+ $category_cond = "";
- $str_search = trim($str_search);
+ $search_query = trim($search_query);
$query = $this->db->query(
- "SELECT id, name, title, duration, user_id, views, thumbs_count,
- default_thumb
+ "SELECT $selected_columns
FROM `videos`
- WHERE MATCH (title, description, tags) AGAINST (?)
- ORDER BY name
- LIMIT ?, ?",
- array($str_search, $offset, $count));
+ WHERE $category_cond MATCH (title, description, tags) AGAINST (?)
+ $limit",
+ array($search_query));
if ($query->num_rows() > 0)
- $videos = $query->result_array();
+ {
+ if ($count === 0)
+ return $query->row()->count;
+ else
+ $videos = $query->result_array();
+ }
else
return NULL;
--- /dev/null
+<div class="search_results">
+ <h1><?php echo $this->lang->line('ui_search_results_for')
+ . " «$search_query»" ?></h1>
+
+ <p><?php echo "$count ". $this->lang->line('ui_results'); ?></p>
+
+ <?php echo $pagination ?>
+
+ <?php foreach($videos as $video):
+ $thumb_src = $video['thumbs'][ $video['default_thumb'] ];
+ ?>
+ <div class="video-icon">
+ <div class="video-thumb ui-widget-content ui-corner-all">
+ <a href="<?php echo $video['video_url'] ?>">
+ <img src="<?php echo $thumb_src ?>" />
+ <div class="video-duration"><?php echo $video['duration'] ?></div>
+ </a>
+ </div>
+ <div class="video-title">
+ <a href="<?php echo $video['video_url'] ?>">
+ <?php echo $video['shorted_title'] ?></a>
+ </div>
+ <div class="video-views">
+ <?php echo $video['views'] . ' '
+ . ($video['views'] == 1 ?
+ $this->lang->line('ui_view') :
+ $this->lang->line('ui_views') );
+ ?>
+ </div>
+ <div class="video-username">
+ <?php echo $this->lang->line('ui_from') . ' TODO' //TODO ?>
+ </div>
+ </div>
+ <?php endforeach ?>
+
+ <?php echo $pagination ?>
+
+ <div style="clear: both"></div>
+
+</div>
\ No newline at end of file
// Fake JS submit via CI URI segments
var fakeSubmit = function() {
var searchQuery = $('#search').val();
- searchQuery = searchQuery.replace(/\+/g, '%2B'); // +
+ searchQuery = searchQuery.replace(/\*/g, '*2A'); // *
+ searchQuery = searchQuery.replace(/\+/g, '*2B'); // +
searchQuery = searchQuery.replace(/\s/g, '+'); // <white spaces>
- searchQuery = searchQuery.replace(/>/g, '%3E'); // >
- searchQuery = searchQuery.replace(/\</g, '%3C'); // <
- searchQuery = searchQuery.replace(/\(/g, '%28'); // (
- searchQuery = searchQuery.replace(/\)/g, '%29'); // )
- searchQuery = searchQuery.replace(/~/g, '%7E'); // ~
- searchQuery = searchQuery.replace(/\*/g, '%2A'); // *
- searchQuery = searchQuery.replace(/"/g, '%22'); // "
+ searchQuery = searchQuery.replace(/>/g, '*3E'); // >
+ searchQuery = searchQuery.replace(/\</g, '*3C'); // <
+ searchQuery = searchQuery.replace(/\(/g, '*28'); // (
+ searchQuery = searchQuery.replace(/\)/g, '*29'); // )
+ searchQuery = searchQuery.replace(/~/g, '*7E'); // ~
+ searchQuery = searchQuery.replace(/"/g, '*22'); // "
searchQuery = encodeURI(searchQuery);
+ searchQuery = searchQuery.replace(/\*/g, '%'); // *
alert(searchQuery);
- //window.location = "<?php echo site_url('catalog/search') ?>"
- // + searchQuery;
+ window.location = "<?php echo site_url('catalog/search') ?>/"
+ + searchQuery;
};
$('#button-js-quick-search')