diff --git a/app/resources/views/inmobiliarias/proveedores/edit_modal.blade.php b/app/resources/views/inmobiliarias/proveedores/edit_modal.blade.php
index 8471a83..b987431 100644
--- a/app/resources/views/inmobiliarias/proveedores/edit_modal.blade.php
+++ b/app/resources/views/inmobiliarias/proveedores/edit_modal.blade.php
@@ -22,25 +22,24 @@
@@ -78,13 +77,13 @@
form.querySelector(this.props.digito).textContent = Rut.digitoVerificador(this.data.rut)
form.querySelector(this.props.nombre).value = this.data.nombre
form.querySelector(this.props.razon).value = this.data.razon
- form.querySelector(this.props.contacto.rut).value = this.data.contacto.rut
- form.querySelector(this.props.contacto.digito).textContent = Rut.digitoVerificador(this.data.contacto.rut)
- form.querySelector(this.props.contacto.nombres).value = this.data.contacto.nombres
- form.querySelector(this.props.contacto.apellido_paterno).value = this.data.contacto.apellidoPaterno
- form.querySelector(this.props.contacto.apellido_materno).value = this.data.contacto.apellidoMaterno
- form.querySelector(this.props.contacto.email).value = this.data.contacto.datos.email
- form.querySelector(this.props.contacto.telefono).value = this.data.contacto.datos.telefono
+ form.querySelector(this.props.contacto.rut).value = (this.data.contacto) ? this.data.contacto.rut : ''
+ form.querySelector(this.props.contacto.digito).textContent = (this.data.contact) ? Rut.digitoVerificador(this.data.contacto.rut) : ''
+ form.querySelector(this.props.contacto.nombres).value = (this.data.contact) ? this.data.contacto.nombres : ''
+ form.querySelector(this.props.contacto.apellido_paterno).value = (this.data.contact) ? this.data.contacto.apellidoPaterno : ''
+ form.querySelector(this.props.contacto.apellido_materno).value = (this.data.contact) ? this.data.contacto.apellidoMaterno : ''
+ form.querySelector(this.props.contacto.email).value = (this.data.contact) ? this.data.contacto.datos.email : ''
+ form.querySelector(this.props.contacto.telefono).value = (this.data.contact) ? this.data.contacto.datos.telefono : ''
$(this.props.modal).modal('show')
})
@@ -97,7 +96,7 @@
}
edit() {
const form = document.getElementById(this.props.form)
- const data = {
+ let data = {
rut: form.querySelector(this.props.rut).value.replace(/\D/g, ''),
digito: form.querySelector(this.props.digito).textContent,
nombre: form.querySelector(this.props.nombre).value,
diff --git a/app/src/Controller/API/Contabilidad/Movimientos.php b/app/src/Controller/API/Contabilidad/Movimientos.php
index 6a65d1f..fb290fc 100644
--- a/app/src/Controller/API/Contabilidad/Movimientos.php
+++ b/app/src/Controller/API/Contabilidad/Movimientos.php
@@ -126,6 +126,20 @@ class Movimientos extends Ideal\Controller
} catch (EmptyResult) {}
return $this->withJson($response, $output);
}
+ public function findRut(ServerRequestInterface $request, ResponseInterface $response,
+ Service\Contabilidad\Movimiento $movimientoService, int $rut): ResponseInterface
+ {
+ $output = [
+ 'rut' => $rut,
+ 'model' => null,
+ 'success' => false
+ ];
+ try {
+ $output['model'] = $movimientoService->findRut($rut);
+ $output['success'] = true;
+ } catch (EmptyResult) {}
+ return $this->withJson($response, $output);
+ }
protected function movimientosToArray(array $movimientos): array
{
diff --git a/app/src/Model/Contabilidad/Movimiento/Auxiliar.php b/app/src/Model/Contabilidad/Movimiento/Auxiliar.php
deleted file mode 100644
index afbfe0a..0000000
--- a/app/src/Model/Contabilidad/Movimiento/Auxiliar.php
+++ /dev/null
@@ -1,36 +0,0 @@
-detalles)) {
- try {
- $this->detalles = $this->runFactory('detalles');
- } catch (Implement\Exception\EmptyResult) {
- $this->detalles = null;
- }
- }
- return $this->detalles;
- }
-
- public function jsonSerialize(): mixed
- {
- return array_merge(parent::jsonSerialize(), [
- 'movimiento_id' => $this->movimiento->id,
- 'cargo' => $this->cargo,
- 'abono' => $this->abono,
- 'detalles' => $this->getDetalles()
- ]);
- }
-}
diff --git a/app/src/Model/Contabilidad/Movimiento/Auxiliar/Detalle.php b/app/src/Model/Contabilidad/Movimiento/Auxiliar/Detalle.php
deleted file mode 100644
index ea2e854..0000000
--- a/app/src/Model/Contabilidad/Movimiento/Auxiliar/Detalle.php
+++ /dev/null
@@ -1,39 +0,0 @@
-rut . '-' . $this->digito;
- }
- public function rutFormatted(): string
- {
- return number_format($this->rut, 0, ',', '.') . '-' . $this->digito;
- }
-
- public function jsonSerialize(): mixed
- {
- return [
- 'auxiliar_id' => $this->auxiliar->id,
- 'centro_costo' => $this->centroCosto,
- 'rut' => $this->rut,
- 'digito' => $this->digito,
- 'nombre' => $this->nombre,
- 'categoria' => $this->categoria,
- 'detalle' => $this->detalle,
- 'rutFormatted' => $this->rutFormatted(),
- ];
- }
-}
diff --git a/app/src/Model/Contabilidad/Movimiento/Detalle.php b/app/src/Model/Contabilidad/Movimiento/Detalle.php
index 8fabd68..fed5b85 100644
--- a/app/src/Model/Contabilidad/Movimiento/Detalle.php
+++ b/app/src/Model/Contabilidad/Movimiento/Detalle.php
@@ -1,6 +1,7 @@
rut, 0, ',', '.') . '-' . $this->digito;
}
+ public ?Define\Model $relacionado;
+ public ?string $relacionadoType;
+
public function jsonSerialize(): mixed
{
return [
@@ -35,7 +39,9 @@ class Detalle extends Ideal\Model
'categoria' => $this->categoria,
'detalle' => $this->detalle,
'identificador' => $this->identificador,
- 'rutFormatted' => $this->rutFormatted()
+ 'rutFormatted' => $this->rutFormatted(),
+ 'relacionado' => $this->relacionado ?? null,
+ 'relacionadoType' => $this->relacionadoType ?? null
];
}
}
diff --git a/app/src/Repository/Contabilidad/Movimiento/Auxiliar.php b/app/src/Repository/Contabilidad/Movimiento/Auxiliar.php
deleted file mode 100644
index 065a792..0000000
--- a/app/src/Repository/Contabilidad/Movimiento/Auxiliar.php
+++ /dev/null
@@ -1,62 +0,0 @@
-setTable('movimientos_auxiliares');
- }
-
- public function create(?array $data = null): Model\Contabilidad\Movimiento\Auxiliar
- {
- $map = (new Implement\Repository\MapperParser(['cargo', 'abono']))
- ->register('movimiento_id', (new Implement\Repository\Mapper())
- ->setProperty('movimiento')
- ->setFunction(function($data) {
- return $this->movimientoRepository->fetchById($data['movimiento_id']);
- }));
- return $this->parseData(new Model\Contabilidad\Movimiento\Auxiliar(), $data, $map);
- }
- public function save(Define\Model $model): Model\Contabilidad\Movimiento\Auxiliar
- {
- $model->id = $this->saveNew([
- 'movimiento_id',
- 'cargo',
- 'abono'
- ],[
- $model->movimiento->id,
- $model->cargo,
- $model->abono
- ]);
- return $model;
- }
- public function edit(Define\Model $model, array $new_data): Model\Contabilidad\Movimiento\Auxiliar
- {
- return $this->update($model, [
- 'movimiento_id',
- 'cargo',
- 'abono'
- ], $new_data);
- }
-
- /**
- * @throws EmptyResult
- */
- public function fetchByMovimiento(int $movimiento_id): array
- {
- $query = $this->connection->getQueryBuilder()
- ->select()
- ->from($this->getTable())
- ->where('movimiento_id = :movimiento_id');
- return $this->fetchMany($query, ['movimiento_id' => $movimiento_id]);
- }
-}
diff --git a/app/src/Repository/Contabilidad/Movimiento/Auxiliar/Detalle.php b/app/src/Repository/Contabilidad/Movimiento/Auxiliar/Detalle.php
deleted file mode 100644
index 77c0b2e..0000000
--- a/app/src/Repository/Contabilidad/Movimiento/Auxiliar/Detalle.php
+++ /dev/null
@@ -1,72 +0,0 @@
-setTable('auxiliar_detalles');
- }
-
- public function create(?array $data = null): Model\Contabilidad\Movimiento\Auxiliar\Detalle
- {
- $map = (new Implement\Repository\MapperParser(['rut', 'digito', 'nombre', 'categoria', 'detalle']))
- ->register('auxiliar_id', (new Implement\Repository\Mapper())
- ->setProperty('auxiliar')
- ->setFunction(function($data) {
- return $this->auxiliarRepository->fetchById($data['auxiliar_id']);
- }))
- ->register('centro_costo_id', (new Implement\Repository\Mapper())
- ->setProperty('centroCosto')
- ->setFunction(function($data) {
- return $this->centroCostoRepository->fetchById($data['centro_costo_id']);
- })
- ->setDefault(null));
- return $this->parseData(new Model\Contabilidad\Movimiento\Auxiliar\Detalle(), $data, $map);
- }
- public function save(Define\Model $model): Model\Contabilidad\Movimiento\Auxiliar\Detalle
- {
- $this->saveNew([
- 'auxiliar_id',
- 'rut',
- 'digito',
- 'nombre',
- 'categoria',
- 'detalle'
- ], [
- $model->auxiliar->id,
- $model->rut,
- $model->digito,
- $model->nombre,
- $model->categoria,
- $model->detalle
- ]);
- return $model;
- }
- public function edit(Define\Model $model, array $new_data): Model\Contabilidad\Movimiento\Auxiliar\Detalle
- {
- return $this->update($model, ['rut', 'digito', 'nombre', 'categoria', 'detalle'], $new_data);
- }
-
- /**
- * @throws EmptyResult
- */
- public function fetchByAuxiliar(int $auxiliar_id): array
- {
- $query = $this->connection->getQueryBuilder()
- ->select()
- ->from($this->getTable())
- ->where('auxiliar_id = :auxiliar_id');
- return $this->fetchMany($query, ['auxiliar_id' => $auxiliar_id]);
- }
-}
diff --git a/app/src/Repository/Inmobiliaria/Proveedor.php b/app/src/Repository/Inmobiliaria/Proveedor.php
index 16d25f1..f337a9c 100644
--- a/app/src/Repository/Inmobiliaria/Proveedor.php
+++ b/app/src/Repository/Inmobiliaria/Proveedor.php
@@ -20,15 +20,18 @@ class Proveedor extends Ideal\Repository
public function create(?array $data = null): Model\Inmobiliaria\Proveedor
{
$map = (new Implement\Repository\MapperParser(['rut', 'digito', 'nombre', 'razon']))
- ->register('contacto_rut', (new Implement\Repository\Mapper())->setProperty('contacto')->setFunction(function($data) {
- return $this->personaService->getById($data['contacto_rut']);
- }));
+ ->register('contacto_rut', (new Implement\Repository\Mapper())
+ ->setProperty('contacto')
+ ->setFunction(function($data) {
+ return $this->personaService->getById($data['contacto_rut']);
+ })
+ ->setDefault(null));
return $this->parseData(new Model\Inmobiliaria\Proveedor(), $data, $map);
}
public function save(Define\Model $model): Model\Inmobiliaria\Proveedor
{
$this->saveNew(['rut', 'digito', 'nombre', 'razon', 'contacto_rut'], [
- $model->rut, $model->digito, $model->nombre, $model->razon, $model->contacto->rut
+ $model->rut, $model->digito, $model->nombre, $model->razon, $model->contacto?->rut
]);
return $model;
}
diff --git a/app/src/Service/Contabilidad/Movimiento.php b/app/src/Service/Contabilidad/Movimiento.php
index ea86519..8e4ee2e 100644
--- a/app/src/Service/Contabilidad/Movimiento.php
+++ b/app/src/Service/Contabilidad/Movimiento.php
@@ -2,8 +2,10 @@
namespace Incoviba\Service\Contabilidad;
use DateTimeInterface;
+use Incoviba\Common\Define;
use Incoviba\Common\Ideal\Service;
use Incoviba\Common\Implement;
+use Incoviba\Common\Implement\Exception\EmptyResult;
use Incoviba\Model;
use Incoviba\Repository;
use Psr\Log\LoggerInterface;
@@ -13,7 +15,7 @@ class Movimiento extends Service
public function __construct(LoggerInterface $logger,
protected Repository\Contabilidad\Movimiento $movimientoRepository,
protected Repository\Contabilidad\Movimiento\Detalle $detalleRepository,
- protected Movimiento\Auxiliar $auxiliarService)
+ protected Movimiento\Detalle $detalleService)
{
parent::__construct($logger);
}
@@ -76,12 +78,20 @@ class Movimiento extends Service
$this->movimientoRepository->remove($movimiento);
}
+ /**
+ * @throws EmptyResult
+ */
+ public function findRut(int $rut): Define\Model
+ {
+ return $this->detalleService->findRut($rut);
+ }
+
public function process(Model\Contabilidad\Movimiento $movimiento): Model\Contabilidad\Movimiento
{
$movimiento->addFactory('detalles', (new Implement\Repository\Factory())
->setCallable(function(int $movimiento_id) {
try {
- return $this->detalleRepository->fetchByMovimiento($movimiento_id);
+ return $this->detalleService->getByMovimiento($movimiento_id);
} catch (Implement\Exception\EmptyResult) {
return null;
}
diff --git a/app/src/Service/Contabilidad/Movimiento/Auxiliar.php b/app/src/Service/Contabilidad/Movimiento/Auxiliar.php
deleted file mode 100644
index 23fba55..0000000
--- a/app/src/Service/Contabilidad/Movimiento/Auxiliar.php
+++ /dev/null
@@ -1,42 +0,0 @@
-auxiliarRepository->fetchByMovimiento($movimiento_id));
- } catch (Implement\Exception\EmptyResult) {
- return null;
- }
- }
-
- protected function process(Model\Contabilidad\Movimiento\Auxiliar $auxiliar): Model\Contabilidad\Movimiento\Auxiliar
- {
- $auxiliar->addFactory('detalles', (new Implement\Repository\Factory())
- ->setCallable(function(int $auxiliar_id) {
- try {
- return $this->detalleRepository->fetchByAuxiliar($auxiliar_id);
- } catch (Implement\Exception\EmptyResult) {
- return null;
- }
- })
- ->setArgs(['auxiliar_id' => $auxiliar->id]));
- return $auxiliar;
- }
-}
diff --git a/app/src/Service/Contabilidad/Movimiento/Detalle.php b/app/src/Service/Contabilidad/Movimiento/Detalle.php
new file mode 100644
index 0000000..3460cd8
--- /dev/null
+++ b/app/src/Service/Contabilidad/Movimiento/Detalle.php
@@ -0,0 +1,63 @@
+process($this->detalleRepository->fetchByMovimiento($movimiento_id));
+ } catch (Implement\Exception\EmptyResult) {
+ return null;
+ }
+ }
+
+ /**
+ * @throws EmptyResult
+ */
+ public function findRut(int $rut): Define\Model
+ {
+ try {
+ return $this->inmobiliariaRepository->fetchById($rut);
+ } catch (Implement\Exception\EmptyResult) {}
+ try {
+ return $this->proveedorRepository->fetchById($rut);
+ } catch (Implement\Exception\EmptyResult) {}
+ try {
+ return $this->propietarioRepository->fetchById($rut);
+ } catch (Implement\Exception\EmptyResult) {}
+
+ throw new Implement\Exception\EmptyResult("{$rut} no encontrado.");
+ }
+
+ protected function process(Model\Contabilidad\Movimiento\Detalle $detalle): Model\Contabilidad\Movimiento\Detalle
+ {
+ if (empty($detalle->rut)) {
+ return $detalle;
+ }
+
+ try {
+ $detalle->relacionado = $this->findRut($detalle->rut);
+ $detalle->relacionadoType = strtolower(last(explode('\\', get_class($detalle->relacionado))));
+ } catch (Implement\Exception\EmptyResult) {}
+
+ return $detalle;
+ }
+}
diff --git a/app/src/Service/Inmobiliaria/Proveedor.php b/app/src/Service/Inmobiliaria/Proveedor.php
index 219997c..e7dedad 100644
--- a/app/src/Service/Inmobiliaria/Proveedor.php
+++ b/app/src/Service/Inmobiliaria/Proveedor.php
@@ -42,14 +42,16 @@ class Proveedor extends Ideal\Service
$filteredData = $this->proveedorRepository->filterData($data);
try {
$proveedor = $this->process($this->proveedorRepository->fetchByNombre($filteredData['nombre']));
- if ($proveedor->contacto->rut !== $data['contacto']['rut']) {
+ if (!empty($data['contacto']['rut']) and $proveedor->contacto->rut !== $data['contacto']['rut']) {
$contacto = $this->contactoService->add($data['contacto']);
return $this->proveedorRepository->edit($proveedor, ['contacto_rut' => $contacto->rut]);
}
return $proveedor;
} catch (Implement\Exception\EmptyResult) {
- $contacto = $this->contactoService->add($data['contacto']);
- $filteredData['contacto_rut'] = $contacto->rut;
+ if (!empty($data['contacto']['rut'])) {
+ $contacto = $this->contactoService->add($data['contacto']);
+ $filteredData['contacto_rut'] = $contacto->rut;
+ }
$proveedor = $this->proveedorRepository->create($filteredData);
return $this->process($this->proveedorRepository->save($proveedor));
}
@@ -61,12 +63,15 @@ class Proveedor extends Ideal\Service
*/
public function edit(Model\Inmobiliaria\Proveedor $proveedor, array $data): Model\Inmobiliaria\Proveedor
{
- $filteredData = $this->proveedorRepository->filterData($data);
try {
- if ($proveedor->contacto->rut !== $data['contacto']['rut']) {
+ if (!empty($data['contacto']['rut'])) {
$contacto = $this->contactoService->getById($data['contacto']['rut']);
- $this->contactoService->edit($contacto, $data['contacto']);
+ $contacto = $this->contactoService->edit($contacto, $data['contacto']);
+ $data['contacto_rut'] = $contacto->rut;
+ } elseif ($proveedor->contacto !== null) {
+ $data['contacto_rut'] = $proveedor->contacto->rut;
}
+ $filteredData = $this->proveedorRepository->filterData($data);
return $this->process($this->proveedorRepository->edit($proveedor, $filteredData));
} catch (Implement\Exception\EmptyResult) {
return $proveedor;