cakephp Crear un buscador personalizado
Bueno, he creado un buscador personalizado que nos permite usar una o varias formas de búsqueda de datos simultaneamente de una forma muy sencilla tanto de usar como de programar:
En este ejemplo creare un buscador que me facilitara encontrar cotizaciones, permitiéndome buscar por el nombre del cliente, por el estado de la cotización, y por el nombre del vendedor encargado de dicha cotización. Para lo cual necesitaremos crear un modelo, una vista y un controlador (MVC).
Usaremos una tabla cotizaciones, usuarios y productos para el ejemplo.
como una de las modalidades de búsqueda sera por vendedor, desde el controlador le enviaremos la consulta de la base de datos donde estan registrados los vendedores, para colocarlas en un select. por medio de un switch case seleccionamos las opciones por las cuales devolveremos los resultados a la vista.
controlador para el buscador.
<?php
class SearchsController extends AppController {
var $name = 'Searchs';
var $uses = array('Quote','QuoteProduct','User','Product');
var $helpers = array('Html','Time','Ajax','Javascript','Paginator');
var $paginate = array(
'limit' => 10,
'order'=>array('Quote.id' => 'desc')
);
function index(){
$this->set('sellers', $this->User->find('list',
array('fields'=>'User.name')));
if((isset($_POST['mode']) && ($_POST['mode'] == 'search')) || is_array($this->Session->read('QuoteSearch')) ){
$this->Session->write('QuoteSearch', $this->data);
if($this->data['Quote']['nameCustomer'] != null){
switch($this->data['Quote']['customer'])
{
case 0:default:
$conditions[] = array('Quote.name LIKE' => '%'.$this->data['Quote']['nameCustomer'].'%');
break;
case 1:
$conditions[] = array('Quote.name NOT LIKE' => '%'.$this->data['Quote']['nameCustomer'].'%');
break;
case 2:
$conditions[] = array('Quote.name LIKE' => $this->data['Quote']['nameCustomer'].'%');
break;
case 3:
$conditions[] = array('Quote.name LIKE' => '%'.$this->data['Quote']['nameCustomer']);
break;
case 4:
$conditions[] = array('Quote.name' => $this->data['Quote']['nameCustomer']);
break;
case 5:
$conditions[] = array('Quote.name NOT' => $this->data['Quote']['nameCustomer']);
break;
}
}
if($this->data['Quote']['seller'] != null){
$conditions[] = array('Quote.users_id' => $this->data['Quote']['seller']);
}
if(isset($this->data['Quote']['status'])){
$conditions[] = array('Quote.status' => $this->data['Quote']['status']);
}
}
$data = $this->paginate('Quote',$conditions);
$this->set(compact('data'));
}
}
?>
Aqui tenemos la creación de la vista, en la cual tendremos un formulario que nos da la posibilidad de añadir los 3 opciones de búsqueda avanzada en nuestro sistema. por vendedor seleccionando el nombre con un select, por el nombre del cliente segun si contiene, comienza o termina con determinadas letras, y por el estado de las cotizaciones que en nuestro caso son nueva, guardada, en edición, enviada y descartada.
<?php
//Creando el formulario de busqueda echo $form->create('uses');
echo "Filtrar por".$form->select('FilterFor',array('Status' => 'Estado','Customer' =>'Cliente',
'User' => 'Vendedor')).
"<input type='button' name='Añadir' value='Añadir'onClick='showFilter()'><br/><hr/>";
echo $form->create(null,array('url' => array('controller' => 'admin/quotes', 'action' => 'index')));
?>
<input type="hidden" name="mode" value="search">
<div id="Filters">
<div id="Status"style="display:none"><?php
echo "Estado";
echo "<br/><input type='radio' name='data[Quote][status]' value='0'/>Nueva<br/>
<input type='radio' name='data[Quote][status]' value='1'/>Guardada<br/>
<input type='radio' name='data[Quote][status]' value='2'/>Enviada<br/>
<input type='radio' name='data[Quote][status]' value='3'/>En edición<br/>
<label for='Descartada'>Descartada</label><input type='radio' name='data[Quote][status]' value='4' /><br/>";
?>
<br/><a id="hide0"href="javascript:hideFilter('Status')">Quitar filtro</a>
</div>
<div id="Customer"style="display:none"><?php
echo "Cliente".$form->select('customer',array('contiene','no contiene','empieza con','termina con','es','no es'));
echo $form->input('nameCustomer',array('label'=>''));
?>
<a id="hide1"href="javascript:hideFilter('Customer')">Quitar filtro</a>
</div>
<div id="User" style="display:none"><?
echo $form->select('seller',array($sellers));
?>
<a id="hide3"href="javascript:hideFilter('User')">Quitar filtro</a>
</div>
</div>
<?php echo $form->submit('Buscar');?>
<script type="text/javascript">
function showFilter()
{
filter = jQuery('#FilterFor').val();
jQuery('#'+filter).show("normal");
}
function hideFilter( id)
{
jQuery('#'+id).hide("normal");
jQuery('#QuoteName'+id).val("");
jQuery('#Quote'+id).val("");
}
//FINDE MI CODIGO
</script>
con la ayuda del script añadido en la vista podremos usar uno o mas tipos de busqueda.
La vista de nuestro buscador sera algo como esto:

Mayo 12th, 2009 at 12:28
Como aplicarias esto por ejemplo para buscar en una seccion especifica
Mayo 22nd, 2009 at 16:36
Mil gracias tu código me ayudo mucho para saber utilizar la condición con LIKE busque en miles de sitios web pero al verlo implementado en tu código fue la unica forma de aprenderlo, lo tendre en cuenta por si necesito un buscador…
Muchas gracias