Uso de nuevas estructuras y editar Bono Pie
This commit is contained in:
@ -1,32 +1,76 @@
|
|||||||
<?php
|
<?php
|
||||||
namespace Incoviba\Service\Venta;
|
namespace Incoviba\Service\Venta;
|
||||||
|
|
||||||
use Incoviba\Common\Implement\Exception\EmptyResult;
|
use PDOException;
|
||||||
use Incoviba\Exception\ServiceAction\Read;
|
|
||||||
use Incoviba\Repository;
|
|
||||||
use Incoviba\Model;
|
|
||||||
use Psr\Log\LoggerInterface;
|
use Psr\Log\LoggerInterface;
|
||||||
|
use Incoviba\Common\Ideal;
|
||||||
|
use Incoviba\Common\Implement\Exception\EmptyResult;
|
||||||
|
use Incoviba\Exception\ServiceAction\{Read, Create, Update};
|
||||||
|
use Incoviba\Model;
|
||||||
|
use Incoviba\Repository;
|
||||||
|
use Incoviba\Service;
|
||||||
|
|
||||||
class BonoPie
|
class BonoPie extends Ideal\Service
|
||||||
{
|
{
|
||||||
public function __construct(protected Repository\Venta\BonoPie $bonoPieRepository,
|
public function __construct(LoggerInterface $logger,
|
||||||
protected LoggerInterface $logger,
|
protected Repository\Venta\BonoPie $bonoPieRepository,
|
||||||
protected Pago $pagoService) {}
|
protected Service\Valor $valorService,
|
||||||
|
protected Service\UF $ufService,
|
||||||
|
protected Pago $pagoService)
|
||||||
|
{
|
||||||
|
parent::__construct($logger);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array $data
|
||||||
|
* @return Model\Venta\BonoPie
|
||||||
|
* @throws Create
|
||||||
|
*/
|
||||||
public function add(array $data): Model\Venta\BonoPie
|
public function add(array $data): Model\Venta\BonoPie
|
||||||
{
|
{
|
||||||
|
if (array_key_exists('valor', $data)) {
|
||||||
|
$data['valor'] = $this->valorService->toPesos($this->valorService->clean($data['valor']), $data['fecha'] ?? null, true);
|
||||||
|
}
|
||||||
|
if (!array_key_exists('pago', $data)) {
|
||||||
|
$pago = $this->pagoService->add($data);
|
||||||
|
$data['pago'] = $pago->id;
|
||||||
|
}
|
||||||
$filteredData = $this->bonoPieRepository->filterData($data);
|
$filteredData = $this->bonoPieRepository->filterData($data);
|
||||||
if (!key_exists('pago', $filteredData)) {
|
|
||||||
$pago = $this->pagoService->add($filteredData);
|
|
||||||
$filteredData['pago'] = $pago->id;
|
|
||||||
}
|
|
||||||
try {
|
try {
|
||||||
$bono = $this->bonoPieRepository->fetchByPago($filteredData['pago']);
|
return $this->bonoPieRepository->fetchByPago($filteredData['pago']);
|
||||||
} catch (EmptyResult) {
|
} catch (EmptyResult) {
|
||||||
|
$filteredData['valor'] = $this->valorService->toUF($data['valor'], $data['fecha'] ?? null, true);
|
||||||
$bono = $this->bonoPieRepository->create($filteredData);
|
$bono = $this->bonoPieRepository->create($filteredData);
|
||||||
$bono = $this->bonoPieRepository->save($bono);
|
try {
|
||||||
|
return $this->bonoPieRepository->save($bono);
|
||||||
|
} catch (PDOException $exception) {
|
||||||
|
throw new Create(__CLASS__, $exception);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param Model\Venta\BonoPie $bonoPie
|
||||||
|
* @param array $data
|
||||||
|
* @return Model\Venta\BonoPie
|
||||||
|
* @throws Update
|
||||||
|
*/
|
||||||
|
public function edit(Model\Venta\BonoPie $bonoPie, array $data): Model\Venta\BonoPie
|
||||||
|
{
|
||||||
|
if (array_key_exists('valor', $data)) {
|
||||||
|
$data['valor'] = $this->valorService->toPesos($this->valorService->clean($data['valor']), $data['fecha'] ?? null, true);
|
||||||
|
}
|
||||||
|
if (!array_key_exists('pago', $data)) {
|
||||||
|
$pago = $this->pagoService->edit($bonoPie->pago, $data);
|
||||||
|
$data['pago'] = $pago->id;
|
||||||
|
}
|
||||||
|
$data['valor'] = $this->valorService->toUF($data['valor'], $data['fecha'] ?? null, true);
|
||||||
|
$filteredData = $this->bonoPieRepository->filterData($data);
|
||||||
|
try {
|
||||||
|
return $this->bonoPieRepository->edit($bonoPie, $filteredData);
|
||||||
|
} catch (PDOException | EmptyResult $exception) {
|
||||||
|
throw new Update(__CLASS__, $exception);
|
||||||
}
|
}
|
||||||
return $bono;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Reference in New Issue
Block a user