Diferencia entre revisiones de «Usuario:ManuelRomero/php/smarty/cesta»

De WikiEducator
Saltar a: navegación, buscar
Línea 115: Línea 115:
 
  * ***********************************************************************************************/   
 
  * ***********************************************************************************************/   
 
     public static function obtieneProducto($codigo) {
 
     public static function obtieneProducto($codigo) {
//....
 
</source>
 
<!--
 
  
 
         $valores = array('cod'=>$codigo);
 
         $valores = array('cod'=>$codigo);
Línea 134: Línea 131:
 
     }
 
     }
 
      
 
      
</source>
 
-->
 
 
;cesta.php
 
*Este fichero se ejecutará cada vez que el usuario seleccione un nuevo producto
 
*Lo que hará será añadir un nuevo elemento al objeto de la clase cesta
 
*Este objeto lo deberemos de tener cargado en sesión, para no peder su valor  en las recargas  (cada vez que añadimos un producto recargamos la página
 
*Tendrá que exportar para la plantilla los productos de la cesta y el coste total que llevamos hasta el momento>
 
*El código
 
<source lang=php>
 
<?php
 
require_once('./..(/include/Cesta.php');
 
require_once('Smarty.class.php');
 
 
// Recuperamos la información de la sesión
 
session_start();
 
 
// Y comprobamos que el usuario se haya autentificado
 
if (!isset($_SESSION['usuario']))
 
    die("Error - debe <a href='login.php'>identificarse</a>.<br />");
 
 
// Cargamos la librería de Smarty
 
$smarty = new Smarty;
 
$smarty->template_dir = '/private/web/smarty/tiendaSmarty4/templates/';
 
$smarty->compile_dir = '/private/web/smarty/tiendaSmarty4/templates_c/';
 
$smarty->config_dir = '/private/web/smarty/tiendaSmarty4/configs/';
 
$smarty->cache_dir = '/private/web/smarty/tiendaSmarty4/cache/';
 
 
// Recuperamos la cesta de la compra
 
$cesta = CestaCompra::carga_cesta();
 
 
// Ponemos a disposición de la plantilla los datos necesarios
 
$smarty->assign('usuario', $_SESSION['usuario']);
 
$smarty->assign('productoscesta', $cesta->get_productos());
 
$smarty->assign('coste', $cesta->get_coste());
 
 
// Mostramos la plantilla
 
$smarty->display('cesta.tpl');
 
?>
 
 
</source>
 
</source>
  
Línea 179: Línea 137:
 
*Par ver claro el escenario dibujamos el siguiente diagrama de uso
 
*Par ver claro el escenario dibujamos el siguiente diagrama de uso
  
[[Archivo:usoTiendaCesta.png]]
+
 
 
;listaPorductos,tpl
 
;listaPorductos,tpl
*Esta plantilla es la antigua de producto.tpl, pero ahora cada vez que añadamos un producto ejecutaremos el método
+
*Esta plantilla es la antigua de producto.tpl;
 +
*En ella tenemos un formulario por cada producto
 +
*Cuando presionemos un click, invocaremos al fichero producto.php con la intención de añadir ese producto a la cesta
 +
*Este código se recogerá en el fichero de código producto.php.
 +
<source lang=php>
 +
 
 +
</source>

Revisión de 06:27 14 ene 2015



Cesta

  • Ahora deberemos ver o añadir la cesta
  • Podremos seleccionar o elegir productos y según añadamos se añadirán a la cesta
  • Esto aparecer en la pantalla de productos
  • Para mejorar el código y siguiendo las especificaciones planteadas, vamos crear dos plantillas
  1. listaProductos.tpl
  2. cesta.tpl
  • y ambas plantillas las cargaremos en la plantilla de productos.tpl.
  • La plantilla productos.ptl quedará de la siguiente manera
<!DOCTYPE html>
<html>
<head>
  <meta http-equiv="content-type" content="text/html; charset=UTF-8">
  <title>Listado de Productos con Plantillas</title>
  <link href="tienda.css" rel="stylesheet" type="text/css">
</head>
 
<body class="pagproductos">
 
<div id="contenedor">
  <div id="encabezado">
    <h1>Listado de productos</h1>
  </div>
 
  <!-- Dividir en varios templates -->
  <div id=""contenedor>
     <div id="cesta">      
         {include file="cesta.tpl"}
     </div>
  </div>
  <div id=""contenedor>
     <div id="productos">
        {include file="listaproducto.tpl"}
     </div>
</div>     
 
  <br class="divisor" />
  <div id="pie">
    <form action='logoff.php' method='post'>
        <input type='submit' name='desconectar' value='Desconectar usuario {$usuario}'/>
    </form>        
  </div>
</div>
</body>
</html>

Clases

  • Vamos a crear una clase cesta
  • Una cesta va a ser un conjunto de productos que hemos comprado.
  • Además podremos hacer las siguientes acciones:
  1. nuevo_articulo($codigo) //Añande un nuevo producto a la cesta
  2. get_productos()// Obtiene los artículos en la cesta
  3. coste()// Obtiene el coste total de los artículos en la cesta
  4. vacia // Devuelve true si la cesta está vacía
  5. guarda_cesta()// Guarda la cesta de la compra en la sesión del usuario
  6. carga_cesta() // Recupera la cesta de la compra almacenada en la sesión del usuario

Todos estos métodos los obtenemos a partir de las especificaciones o ejercicio realizado anteriormente

  • El objeto Cesta queda como se expresa en la siguiente imagen

Cesta.png

<?php
require_once('DB.php');
 
class Cesta {
    protected $productos = array();
 
    // Introduce un nuevo artículo en la cesta de la compra
    public function nuevo_articulo($codigo) {
        $producto = DB::obtieneProducto($codigo);
        $this->productos[] = $producto;
    }
 
    // Obtiene los artículos en la cesta
    public function get_productos() { return $this->productos; }
 
    // Obtiene el coste total de los artículos en la cesta
    public function get_coste() {
        $coste = 0;
        foreach($this->productos as $p) $coste += $p->getPVP();
        return $coste;
    }
 
    // Devuelve true si la cesta está vacía
    public function vacia() {
        if(count($this->productos) == 0) return true;
        return false;
    }
 
    // Guarda la cesta de la compra en la sesión del usuario
    public function guarda_cesta() { $_SESSION['cesta'] = $this; }
 
    // Recupera la cesta de la compra almacenada en la sesión del usuario
    public static function carga_cesta() {
        if (!isset($_SESSION['cesta'])) return new CestaCompra();
        else return $_SESSION['cesta'];
    }
}
 
?>
Vemos que hemos usado acceso a la base de datos
  • En el método nuevo artículo necesitamos recuperar los datos de un artículo, para ello creamos el método obtieneProducto($codigo) en la clase DB.php
  • Este método a partir de un código nos retorna un objeto de la clase producto
  • Con ello la clase DB.php definitiva quedaría

DB3 .png

  • El código de este método
 /*======================obtieneProducto ($codigo)======================================
    Accion: obtiene los datos de un determinado producto cuyo codigo pasamos como argumento
    Parámetros: $codigo es el codigo del producto cuyos datos queremos
    Retorna  un objeto de la clase producto con sus datos(cod, nombre_corto y PVP 
 * ***********************************************************************************************/   
    public static function obtieneProducto($codigo) {
 
        $valores = array('cod'=>$codigo);
        $sql = <<<FIN
        SELECT cod, nombre_corto, nombre, PVP
        FROM usuarios 
        WHERE cod = :cod
FIN;
        $resultado = self::ejecutaConsulta ($sql,$valores);
        $producto = null;
	if(isset($resultado)) {
            $row = $resultado->fetch();
            $producto = new Producto($row);
	}
        return $producto;    
    }
Las plantillas
  • Ahora debemos de escribir las plantillas que van a componer la plantilla de producto.tpl
  • Par ver claro el escenario dibujamos el siguiente diagrama de uso


listaPorductos,tpl
  • Esta plantilla es la antigua de producto.tpl;
  • En ella tenemos un formulario por cada producto
  • Cuando presionemos un click, invocaremos al fichero producto.php con la intención de añadir ese producto a la cesta
  • Este código se recogerá en el fichero de código producto.php.