Итак, я создал пользовательскую форму, в которой я использую метод GET для извлечения значений, введенных пользователем, в URL.Вот форма, которую я создал:
<!-- Section: Form -->
<?php
$action = 'store/searchPosts';
$attributes = array(
'method' => 'get',
'class' => 'form-horizontal',
'role' => 'form',
);
$hidden = array();
?>
<?= form_open(htmlspecialchars($action), $attributes, $hidden); ?>
<!-- Featured -->
<div class="form-group">
<?php
$label_text = 'Featured';
$id = 'featured';
$attributes = array();
?>
<?= form_label($label_text, $id, $attributes); ?>
<?php
$name = 'featured';
$options = array(
'yes' => 'Yes',
'no' => 'No',
);
$selected = array('yes');
$extra = array(
'id' => 'featured',
'class' => 'form-control',
'value' => set_value('featured'),
);
?>
<?= form_dropdown($name, $options, $selected, $extra); ?>
</div>
<!-- Free -->
<div class="form-group">
<?php
$label_text = 'Free';
$id = 'free';
$attributes = array();
?>
<?= form_label($label_text, $id, $attributes); ?>
<?php
$name = 'free';
$options = array(
'yes' => 'Yes',
'no' => 'No',
);
$selected = array('yes');
$extra = array(
'id' => 'free',
'class' => 'form-control',
'value' => set_value('free'),
);
?>
<?= form_dropdown($name, $options, $selected, $extra); ?>
</div>
<!-- Title -->
<div class="form-group">
<?php
$label_text = 'Title';
$id = 'title';
$attributes = array();
?>
<?= form_label($label_text, $id, $attributes); ?>
<?php
$data = array(
'id' => 'title',
'name' => 'title',
);
$value = set_value('title');
$extra = array(
'class' => 'form-control',
'placeholder' => 'Here goes the title',
);
?>
<?= form_input($data, $value, $extra); ?>
</div>
<!-- Author -->
<div class="form-group">
<?php
$label_text = 'Author';
$id = 'user_id';
$attributes = array();
?>
<?= form_label($label_text, $id, $attributes); ?>
<?php
$name = 'user_id';
$options = $this->userFilter;
$selected = array('1');
$extra = array(
'id' => 'user_id',
'class' => 'form-control',
'value' => set_value('user_id'),
);
?>
<?= form_dropdown($name, $options, $selected, $extra); ?>
</div>
<!-- Words Like -->
<div class="form-group">
<?php
$label_text = 'Contains the words';
$id = 'keyword';
$attributes = array();
?>
<?= form_label($label_text, $id, $attributes); ?>
<?php
$data = array(
'id' => 'keyword',
'name' => 'keyword',
);
$value = set_value('keyword');
$extra = array(
'class' => 'form-control',
'placeholder' => 'Type here',
);
?>
<?= form_input($data, $value, $extra); ?>
</div>
<!-- Price Range -->
<div class="form-group">
<?php
$label_text = 'Minimum Price';
$id = 'price_low';
$attributes = array();
?>
<?= form_label($label_text, $id, $attributes); ?>
<?php
$data = array(
'id' => 'price_low',
'name' => 'price_low',
);
$value = set_value('price_low');
$extra = array(
'data-slider-id' => 'ex1Slider',
'data-slider-min' => '0',
'data-slider-max' => '1000',
'data-slider-step' => '1',
'data-slider-value' => '0',
);
?>
<?= form_input($data, $value, $extra); ?>
<?php
$label_text = 'Maximum Price';
$id = 'price_high';
$attributes = array();
?>
<?= form_label($label_text, $id, $attributes); ?>
<?php
$data = array(
'id' => 'price_high',
'name' => 'price_high',
);
$value = set_value('price_high');
$extra = array(
'data-slider-id' => 'ex1Slider',
'data-slider-min' => '0',
'data-slider-max' => '1000',
'data-slider-step' => '1',
'data-slider-value' => '1000',
);
?>
<?= form_input($data, $value, $extra); ?>
</div>
<!-- Buttons -->
<?php
$data = array(
'id' => 'mysubmit',
'type' => 'submit',
);
$content = 'Submit';
$extra = array(
'class' => 'btn btn-primary',
);
?>
<?= form_button($data, $content, $extra); ?>
<?php
$data = 'myreset';
$value = 'Reset';
$extra = array(
'class' => 'btn btn-default',
);
?>
<?= form_reset($data, $value, $extra); ?>
<?= form_close(); ?>
теперь форма переходит в мой метод searchPost, который находится в контроллере моего магазина:
public function searchPosts(){
// Get Inputs
$featured = $this->input->get('featured');
$free = $this->input->get('free');
$price_high = $this->input->get('price_high');
$price_low = $this->input->get('price_low');
$title = $this->input->get('title');
$userID = $this->input->get('user_id');
$keyword = $this->input->get('keyword');
$minimum = ( int ) str_replace( '.', '', $price_low );
$maximum = ( int ) str_replace( '.', '', $price_high );
// Pagination
$config['base_url'] = base_url('store/searchPosts');
$config['total_rows'] = $this->PublicPagination_model->getStoreSearchCount($featured, $free, $minimum, $maximum, $title, $userID, $keyword);
$config['per_page'] = 6;
$config['uri_segment'] = 3;
$config['full_tag_open'] = '<ul class="pagination">';
$config['full_tag_close'] = '</ul>';
$config['attributes'] = array('class' => 'page-link');
$config['first_link'] = 'First';
$config['last_link'] = 'Last';
$config['first_tag_open'] = '<li>';
$config['first_tag_close'] = '</li>';
$config['prev_link'] = '«';
$config['prev_tag_open'] = '<li class="prev">';
$config['prev_tag_close'] = '</li>';
$config['next_link'] = '»';
$config['next_tag_open'] = '<li>';
$config['next_tag_close'] = '</li>';
$config['last_tag_open'] = '<li>';
$config['last_tag_close'] = '</li>';
$config['cur_tag_open'] = '<li class="page-item active"><a href="#" class="page-link">';
$config['cur_tag_close'] = '<span class="sr-only">(current)</span></a></li>';
$config['num_tag_open'] = '<li>';
$config['num_tag_close'] = '</li>';
$page = ($this->uri->segment(3)) ? $this->uri->segment(3) : 0;
$this->pagination->initialize($config);
$data['pagination'] = $this->pagination->create_links();
$data['posts'] = $this->PublicPagination_model->getStoreSearhCountLimit($featured, $free, $minimum, $maximum, $title, $userID, $keyword, $config["per_page"], $page);
// Get data
// $data['posts'] = $this->PublicStore_model->searchQuery($featured, $free, $minimum, $maximum, $title, $userID, $keyword);
// Get featured
$data['featured'] = $this->PublicStore_model->getFeaturedPosts();
// Get comments
$data['comments'] = $this->PublicStore_model->getSidebarComments();
// Get categories
$data['categories'] = $this->PublicStore_model->getSidebarCategories();
// Get tags
$data['tags'] = $this->PublicStore_model->getSidebarTagCloud();
// Meta data
$data['title'] = $this->settings->title.' | Search Results';
// Load template
$this->template->load('public', 'default', 'store/search', $data);
}
Теперь с чем я борюсьв том, чтобы показать правильные данные и сделать пагинацию доступной в представлении, здесь я помещу оба метода модели, которые я использую для "выборки" данных и пагинации:
public function getStoreSearchCount($featured, $free, $minimum, $maximum, $title, $userID, $keyword){
$this->db->select('*, ci_posts.create_date as date, COUNT(*) as num_row');
$this->db->from($this->posts);
$this->db->join('ci_relationship', 'ci_relationship.post_id = ci_posts.post_id', 'INNER');
$this->db->order_by('ci_relationship.post_id', 'DESC');
$this->db->group_by('ci_relationship.post_id');
$this->db->like('title', $title);
$this->db->or_like('body', $keyword);
$this->db->where('ci_relationship.status', $this->published);
$this->db->where('ci_relationship.type =', $this->productType);
$this->db->or_where('ci_relationship.featured', $featured);
$this->db->or_where('ci_relationship.free', $free);
$this->db->or_where('ci_relationship.price >', $minimum);
$this->db->or_where('ci_relationship.price <', $maximum);
$this->db->or_where('ci_relationship.user_id', $userID);
$query = $this->db->get();
$result = $query->result();
return $result[0]->num_row;
}
public function getStoreSearhCountLimit($featured, $free, $minimum, $maximum, $title, $userID, $keyword, $limit, $start){
$this->db->select('*, ci_posts.create_date as date, COUNT(*) as num_row');
$this->db->from($this->posts);
$this->db->join('ci_relationship', 'ci_relationship.post_id = ci_posts.post_id', 'INNER');
$this->db->order_by('ci_relationship.post_id', 'DESC');
$this->db->group_by('ci_relationship.post_id');
$this->db->like('title', $title);
$this->db->or_like('body', $keyword);
$this->db->where('ci_relationship.status', $this->published);
$this->db->where('ci_relationship.type =', $this->productType);
$this->db->or_where('ci_relationship.featured', $featured);
$this->db->or_where('ci_relationship.free', $free);
$this->db->or_where('ci_relationship.price >', $minimum);
$this->db->or_where('ci_relationship.price <', $maximum);
$this->db->or_where('ci_relationship.user_id', $userID);
$this->db->limit($limit, $start);
$query = $this->db->get();
return $result = $query->result();
}
I 'я пытаюсь получить данные из двух таблиц базы данных.
Спасибо.