Files
oficial/app/src/Repository/Inmobiliaria/Cuenta.php
2024-03-26 09:38:20 -03:00

61 lines
2.3 KiB
PHP

<?php
namespace Incoviba\Repository\Inmobiliaria;
use Incoviba\Common\Define;
use Incoviba\Common\Ideal;
use Incoviba\Common\Implement;
use Incoviba\Model;
use Incoviba\Repository;
class Cuenta extends Ideal\Repository
{
public function __construct(Define\Connection $connection,
protected Repository\Inmobiliaria $inmobiliariaRepository,
protected Repository\Contabilidad\Banco $bancoRepository)
{
parent::__construct($connection);
$this->setTable('cuenta');
}
public function create(?array $data = null): Model\Inmobiliaria\Cuenta
{
$map = (new Implement\Repository\MapperParser(['cuenta']))
->register('inmobiliaria', (new Implement\Repository\Mapper())
->setFunction(function(array $data) {
return $this->inmobiliariaRepository->fetchById($data['inmobiliaria']);
}))
->register('banco', (new Implement\Repository\Mapper())
->setFunction(function(array $data) {
return $this->bancoRepository->fetchById($data['banco']);
}));
return $this->parseData(new Model\Inmobiliaria\Cuenta(), $data, $map);
}
public function save(Define\Model $model): Model\Inmobiliaria\Cuenta
{
$model->id = $this->saveNew(['inmobiliaria', 'banco', 'cuenta'],
[$model->inmobiliaria->rut, $model->banco->id, $model->cuenta]);
return $model;
}
public function edit(Define\Model $model, array $new_data): Model\Inmobiliaria\Cuenta
{
return $this->update($model, ['inmobiliaria', 'banco', 'cuenta'], $new_data);
}
public function fetchByInmobiliaria(int $inmobiliaria_rut): array
{
$query = $this->connection->getQueryBuilder()
->select()
->from($this->getTable())
->where('inmobiliaria = ?');
return $this->fetchMany($query, [$inmobiliaria_rut]);
}
public function fetchByInmobiliariaAndBanco(int $inmobiliaria_rut, int $banco_id): Model\Inmobiliaria\Cuenta
{
$query = $this->connection->getQueryBuilder()
->select()
->from($this->getTable())
->where('inmobiliaria = ? AND banco = ?');
return $this->fetchOne($query, [$inmobiliaria_rut, $banco_id]);
}
}