Datagrid Simple Con Paginado

De KumbiaPHP Framework Wiki

Partials para crear de forma simple un datagrid con paginado

En el controlador

Para efecto del ejemplo tenemos el siguiente controller, pero puede ser cualquiera

 <?php
class ClienteController extends ApplicationController {
 
	public function page($page=1){
        // Paso el resultado de la consulta que sera mostrada en el datagrid
        $this->page = Load::model('cliente')->paginate('per_page: 20', "page: $page");
       
       /* paso un array con los campos que quiero mostrar en la datagrid
        *  El key de cada campo del ser el nombre a mostrarse en el tr de la tabla
        *  El value el campo de la tabla
        */ 
	$this->campos = array('Codigo' => 'id',
			      'Nombre' => 'nombre',
			      'Telefono' => 'telefono',
			      'Direccion' => 'direccion'));

        // Nombre del Partial de paginado que utiliza KumbiaPHP
        $this->paginator = 'extended';
        /// Url que utilizara el Paginado de kumbia, por defecto utiliza la accion page 
        $this->url  = null ;

	}
 
}
//  Se maneja todo desde la vista

Mas Informacion referida a los Partial de Paginación disponibles en KumbiaPHP

En la vista

/app/view/cliente/page.phtml

      <? View::partial('datagrid/paginado', false,array('Model'=>$page, 'Campos'=>$campos, 'Paginator'=>$paginator, 'Url'=>$url )) ?>

Partials

/app/view/partials/datagrid/paginado.phtml

<?php
/**
 * Renderiza una tabla en base a un modelo.
 *
 * @author Andres Hal
 * 
 * @param array $Modelo modelo con los resultados a mostrar
 * @param array $Campos array con los que se quieren mostrar de la tabla
 * @return partial
 */
?>
 
	<div id="datagrid">
		<table  border="1px" class="paginado">"
		<thead><tr>
			<?php foreach( $Campos  as $titulo => $valor): ?>
				<th> <?php echo $titulo >?</th>
			<?php endforeach; ?>
		</tr></thead>
                <tbody>
		       <? foreach( $Model->items as $model):
				echo tr_color_class( 'tr_primary', 'tr_secondary' );
					foreach($Campos as  $campos): ?>
					    <td><?php echo $model->$campos ?></td>
				       <?php endforeach; ?>
				</tr>
			<?php endforeach; ?>
		</tbody></table>
        	<?php	View::partial('paginators/'. $Paginator, false, array('page' => $Model ,'url' => $Url)); ?>
	</div>