Implemented repository mapper, and venta show

This commit is contained in:
Juan Pablo Vial
2023-08-08 23:53:49 -04:00
parent ef30ae67d2
commit 59825259b6
111 changed files with 2766 additions and 612 deletions

View File

@ -17,8 +17,16 @@ class Format
return $formatter->format($date);
}
public function number(float|string $number, int $decimal_places = 0): string
{
return number_format($number, $decimal_places, ',', '.');
}
public function pesos(string $valor): string
{
return '$' . number_format($valor, 0, ',', '.');
return '$ ' . $this->number($valor);
}
public function ufs(string $valor): string
{
return $this->number($valor, 2) . ' UF';
}
}

View File

@ -0,0 +1,22 @@
<?php
namespace Incoviba\Service\Proyecto;
use Incoviba\Repository;
use Incoviba\Model;
class ProyectoTipoUnidad
{
public function __construct(
protected Repository\Proyecto\ProyectoTipoUnidad $proyectoTipoUnidadRepository,
protected Repository\Proyecto\Tipologia $tipologiaRepository
) {}
public function getById(int $proyecto_tipo_unidad_id): Model\Proyecto\ProyectoTipoUnidad
{
$ptu = $this->proyectoTipoUnidadRepository->fetchById($proyecto_tipo_unidad_id);
if ($ptu->tipoUnidad->descripcion === 'departamento') {
$ptu->tipologias = $this->tipologiaRepository->fetchByProyectoTipoUnidad($proyecto_tipo_unidad_id);
}
return $ptu;
}
}

View File

@ -1,7 +1,9 @@
<?php
namespace Incoviba\Service;
use Incoviba\Common\Implement;
use Incoviba\Repository;
use Incoviba\Model;
class Venta
{
@ -10,6 +12,16 @@ class Venta
protected Repository\Venta\EstadoVenta $estadoVentaRepository
) {}
public function getById(int $venta_id): Model\Venta
{
return ($this->ventaRepository->fetchById($venta_id))
->addFactory('estados', (new Implement\Repository\Factory())
->setCallable([$this->estadoVentaRepository, 'fetchByVenta'])
->setArgs([$venta_id]))
->addFactory('currentEstado', (new Implement\Repository\Factory())
->setCallable([$this->estadoVentaRepository, 'fetchCurrentByVenta'])
->setArgs([$venta_id]));
}
public function getByProyecto(int $proyecto_id): array
{
$ventas = $this->ventaRepository->fetchByProyecto($proyecto_id);
@ -19,4 +31,11 @@ class Venta
}
return $ventas;
}
public function getByProyectoAndUnidad(string $proyecto_nombre, int $unidad_descripcion): Model\Venta
{
$venta = $this->ventaRepository->fetchByProyectoAndUnidad($proyecto_nombre, $unidad_descripcion);
$venta->addFactory('estados', ['callable' => [$this->estadoVentaRepository, 'fetchByVenta'], 'args' => [$venta->id]]);
$venta->addFactory('currentEstado', ['callable' => [$this->estadoVentaRepository, 'fetchCurrentByVenta'], 'args' => [$venta->id]]);
return $venta;
}
}

View File

@ -1,5 +1,5 @@
<?php
namespace Incoviba\Service\Ventas;
namespace Incoviba\Service\Venta;
use Incoviba\Repository;
use Incoviba\Model;

View File

@ -1,5 +1,5 @@
<?php
namespace Incoviba\Service\Ventas;
namespace Incoviba\Service\Venta;
use DateTimeImmutable;
use PDOException;
@ -28,4 +28,11 @@ class Pago
return false;
}
}
public function getById(int $pago_id): Model\Venta\Pago
{
$pago = $this->pagoRepository->fetchById($pago_id);
$pago->estados = $this->estadoPagoRepository->fetchByPago($pago_id);
$pago->currentEstado = $this->estadoPagoRepository->fetchCurrentByPago($pago_id);
return $pago;
}
}

View File

@ -0,0 +1,20 @@
<?php
namespace Incoviba\Service\Venta;
use Incoviba\Repository;
use Incoviba\Model;
class Pie
{
public function __construct(
protected Repository\Venta\Pie $pieRepository,
protected Repository\Venta\Cuota $cuotaRepository
) {}
public function getById(int $pie_id): Model\Venta\Pie
{
$pie = $this->pieRepository->fetchById($pie_id);
$pie->cuotasArray = $this->cuotaRepository->fetchVigenteByPie($pie_id);
return $pie;
}
}

View File

@ -1,5 +1,5 @@
<?php
namespace Incoviba\Service\Ventas;
namespace Incoviba\Service\Venta;
use Incoviba\Repository;
use Incoviba\Model;
@ -17,11 +17,20 @@ class Precio
}
return $precios;
}
public function getByUnidad(int $unidad_id): Model\Venta\Precio
public function getVigenteByUnidad(int $unidad_id): Model\Venta\Precio
{
$precio = $this->precioRepository->fetchByUnidad($unidad_id);
$precio = $this->precioRepository->fetchVigenteByUnidad($unidad_id);
$precio->estados = $this->estadoPrecioRepository->fetchByPrecio($precio->id);
$precio->current = $this->estadoPrecioRepository->fetchCurrentByPrecio($precio->id);
return $precio;
}
public function getByUnidad(int $unidad_id): array
{
$precios = $this->precioRepository->fetchByUnidad($unidad_id);
foreach ($precios as &$precio) {
$precio->estados = $this->estadoPrecioRepository->fetchByPrecio($precio->id);
$precio->current = $this->estadoPrecioRepository->fetchCurrentByPrecio($precio->id);
}
return $precios;
}
}

View File

@ -0,0 +1,49 @@
<?php
namespace Incoviba\Service\Venta;
use Incoviba\Common\Implement\Exception\EmptyResult;
use Incoviba\Repository;
use Incoviba\Service;
use Incoviba\Model;
class Unidad
{
public function __construct(
protected Repository\Venta\Unidad $unidadRepository,
protected Service\Venta\Precio $precioService
) {}
public function getById(int $unidad_id): Model\Venta\Unidad
{
$unidad = $this->unidadRepository->fetchById($unidad_id);
$this->fillPrecios($unidad);
return $unidad;
}
public function getByPropiedad(int $propiedad_id): array
{
$unidades = $this->unidadRepository->fetchByPropiedad($propiedad_id);
array_walk($unidades, [$this, 'fillPrecios']);
return $unidades;
}
public function getByCierre(int $cierre_id): array
{
$unidades = $this->unidadRepository->fetchByCierre($cierre_id);
array_walk($unidades, [$this, 'fillPrecios']);
return $unidades;
}
public function getDisponiblesByProyecto(int $proyecto_id): array
{
$unidades = $this->unidadRepository->fetchDisponiblesByProyecto($proyecto_id);
//array_walk($unidades, [$this, 'fillPrecios']);
return $unidades;
}
protected function fillPrecios(&$unidad): void
{
try {
$unidad->precios = $this->precioService->getByUnidad($unidad->id);
$unidad->currentPrecio = $this->precioService->getVigenteByUnidad($unidad->id);
} catch (EmptyResult) {
}
}
}