Proveedores en movimientos
This commit is contained in:
@ -179,7 +179,8 @@
|
|||||||
}
|
}
|
||||||
class Movimiento {
|
class Movimiento {
|
||||||
props
|
props
|
||||||
constructor({sociedad, fecha, glosa, cargo, abono, saldo, categoria, detalle, centro_costo, rut, nombres, identificador}) {
|
constructor({sociedad, fecha, glosa, cargo, abono, saldo, categoria, detalle, centro_costo, rut, nombres,
|
||||||
|
identificador, relacionado, relacionadoType}) {
|
||||||
this.props = {
|
this.props = {
|
||||||
sociedad,
|
sociedad,
|
||||||
fecha,
|
fecha,
|
||||||
@ -192,11 +193,23 @@
|
|||||||
centro_costo,
|
centro_costo,
|
||||||
rut,
|
rut,
|
||||||
nombres,
|
nombres,
|
||||||
identificador
|
identificador,
|
||||||
|
relacionado,
|
||||||
|
relacionadoType
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
draw({formatters}) {
|
draw({formatters}) {
|
||||||
const fecha = new Date(this.props.fecha)
|
const fecha = new Date(this.props.fecha)
|
||||||
|
let nombre = ''
|
||||||
|
if (this.props.nombres) {
|
||||||
|
if (this.props.relacionado) {
|
||||||
|
let type = this.props.relacionadoType
|
||||||
|
type = type.charAt(0).toUpperCase() + type.slice(1)
|
||||||
|
nombre = `<span data-tooltip="${type}">${this.props.nombres}</span>`
|
||||||
|
} else {
|
||||||
|
nombre = this.props.nombres
|
||||||
|
}
|
||||||
|
}
|
||||||
return [
|
return [
|
||||||
'<tr>',
|
'<tr>',
|
||||||
`<td>${this.props.sociedad.sigla}</td>`,
|
`<td>${this.props.sociedad.sigla}</td>`,
|
||||||
@ -209,7 +222,7 @@
|
|||||||
`<td>${this.props.categoria ?? ''}</td>`,
|
`<td>${this.props.categoria ?? ''}</td>`,
|
||||||
`<td>${this.props.detalle ?? ''}</td>`,
|
`<td>${this.props.detalle ?? ''}</td>`,
|
||||||
`<td>${this.props.rut ?? ''}</td>`,
|
`<td>${this.props.rut ?? ''}</td>`,
|
||||||
`<td>${this.props.nombres ?? ''}</td>`,
|
`<td>${nombre}</td>`,
|
||||||
`<td class="center aligned">${this.props.identificador ?? ''}</td>`,
|
`<td class="center aligned">${this.props.identificador ?? ''}</td>`,
|
||||||
'</tr>'
|
'</tr>'
|
||||||
].join("\n")
|
].join("\n")
|
||||||
|
@ -203,6 +203,17 @@
|
|||||||
return `<button class="ui${color} icon button ${className}" data-id="${movimiento.id}" data-index="${movimiento.index}" data-type="movimiento"><i class="${icon} icon"></i></button>`
|
return `<button class="ui${color} icon button ${className}" data-id="${movimiento.id}" data-index="${movimiento.index}" data-type="movimiento"><i class="${icon} icon"></i></button>`
|
||||||
}).join('')
|
}).join('')
|
||||||
|
|
||||||
|
let nombre = ''
|
||||||
|
if (movimiento.detalles) {
|
||||||
|
if (movimiento.detalles.relacionado) {
|
||||||
|
let type = movimiento.detalles.relacionadoType
|
||||||
|
type = type.charAt(0).toUpperCase() + type.slice(1)
|
||||||
|
nombre = `<span data-tooltip="${type}">${movimiento.detalles.nombres}</span>`
|
||||||
|
} else {
|
||||||
|
nombre = movimiento.detalles.nombres
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
const data = {
|
const data = {
|
||||||
Sigla: movimiento.cuenta.inmobiliaria.sigla,
|
Sigla: movimiento.cuenta.inmobiliaria.sigla,
|
||||||
Banco: movimiento.cuenta.banco.nombre,
|
Banco: movimiento.cuenta.banco.nombre,
|
||||||
@ -218,7 +229,7 @@
|
|||||||
Categoria: (movimiento.detalles) ? movimiento.detalles.categoria : '',
|
Categoria: (movimiento.detalles) ? movimiento.detalles.categoria : '',
|
||||||
Detalle: (movimiento.detalles) ? movimiento.detalles.detalle : '',
|
Detalle: (movimiento.detalles) ? movimiento.detalles.detalle : '',
|
||||||
RUT: (movimiento.detalles && movimiento.detalles.digito) ? `${this.props.formatters.number.format(movimiento.detalles.rut)}-${movimiento.detalles.digito}` : '',
|
RUT: (movimiento.detalles && movimiento.detalles.digito) ? `${this.props.formatters.number.format(movimiento.detalles.rut)}-${movimiento.detalles.digito}` : '',
|
||||||
Nombre: (movimiento.detalles) ? movimiento.detalles.nombres : '',
|
Nombre: nombre,
|
||||||
Identificador: (movimiento.detalles) ? movimiento.detalles.identificador : '',
|
Identificador: (movimiento.detalles) ? movimiento.detalles.identificador : '',
|
||||||
Editar: buttonsHTML,
|
Editar: buttonsHTML,
|
||||||
}
|
}
|
||||||
|
@ -18,7 +18,7 @@
|
|||||||
@foreach ($proveedores as $proveedor)
|
@foreach ($proveedores as $proveedor)
|
||||||
<tr>
|
<tr>
|
||||||
<td>{{$proveedor->nombre}}</td>
|
<td>{{$proveedor->nombre}}</td>
|
||||||
<td>{{$proveedor->contacto->nombreCompleto()}}</td>
|
<td>{{$proveedor->contacto?->nombreCompleto()}}</td>
|
||||||
<td class="right aligned">
|
<td class="right aligned">
|
||||||
<button class="ui tertiary icon button" data-proveedor="{{$proveedor->rut}}">
|
<button class="ui tertiary icon button" data-proveedor="{{$proveedor->rut}}">
|
||||||
<i class="edit icon"></i>
|
<i class="edit icon"></i>
|
||||||
|
@ -22,20 +22,19 @@
|
|||||||
<div class="three wide field">
|
<div class="three wide field">
|
||||||
<label for="rut_contacto">RUT</label>
|
<label for="rut_contacto">RUT</label>
|
||||||
<div class="ui right labeled input">
|
<div class="ui right labeled input">
|
||||||
<input type="text" id="rut_contacto" name="rut_contacto" placeholder="RUT" maxlength="10"
|
<input type="text" id="rut_contacto" name="rut_contacto" placeholder="RUT" maxlength="10"/>
|
||||||
required/>
|
|
||||||
<div class="ui basic label">-<span id="dv_contacto"></span></div>
|
<div class="ui basic label">-<span id="dv_contacto"></span></div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="fields">
|
<div class="fields">
|
||||||
<div class="five wide field">
|
<div class="five wide field">
|
||||||
<label for="nombre_contacto">Nombre</label>
|
<label for="nombre_contacto">Nombre</label>
|
||||||
<input type="text" id="nombre_contacto" name="nombre_contacto" placeholder="Nombre" required/>
|
<input type="text" id="nombre_contacto" name="nombre_contacto" placeholder="Nombre" />
|
||||||
</div>
|
</div>
|
||||||
<div class="field">
|
<div class="field">
|
||||||
<label for="apellido_paterno_contacto">Apellido Paterno</label>
|
<label for="apellido_paterno_contacto">Apellido Paterno</label>
|
||||||
<input type="text" id="apellido_paterno_contacto" name="apellido_paterno_contacto"
|
<input type="text" id="apellido_paterno_contacto" name="apellido_paterno_contacto"
|
||||||
placeholder="Apellido Paterno" required/>
|
placeholder="Apellido Paterno"/>
|
||||||
</div>
|
</div>
|
||||||
<div class="field">
|
<div class="field">
|
||||||
<label for="apellido_materno_contacto">Apellido Materno</label>
|
<label for="apellido_materno_contacto">Apellido Materno</label>
|
||||||
|
@ -22,25 +22,24 @@
|
|||||||
<div class="three wide field">
|
<div class="three wide field">
|
||||||
<label for="edit_rut_contacto">RUT</label>
|
<label for="edit_rut_contacto">RUT</label>
|
||||||
<div class="ui right labeled input">
|
<div class="ui right labeled input">
|
||||||
<input type="text" id="edit_rut_contacto" name="rut_contacto" placeholder="RUT" maxlength="10"
|
<input type="text" id="edit_rut_contacto" name="rut_contacto" placeholder="RUT" maxlength="10" />
|
||||||
required/>
|
|
||||||
<div class="ui basic label">-<span id="edit_digito_contacto"></span></div>
|
<div class="ui basic label">-<span id="edit_digito_contacto"></span></div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="fields">
|
<div class="fields">
|
||||||
<div class="five wide field">
|
<div class="five wide field">
|
||||||
<label for="edit_nombre_contacto">Nombre</label>
|
<label for="edit_nombre_contacto">Nombre</label>
|
||||||
<input type="text" id="edit_nombre_contacto" name="nombre_contacto" placeholder="Nombre" required/>
|
<input type="text" id="edit_nombre_contacto" name="nombre_contacto" placeholder="Nombre" />
|
||||||
</div>
|
</div>
|
||||||
<div class="field">
|
<div class="field">
|
||||||
<label for="edit_apellido_paterno_contacto">Apellido Paterno</label>
|
<label for="edit_apellido_paterno_contacto">Apellido Paterno</label>
|
||||||
<input type="text" id="edit_apellido_paterno_contacto" name="apellido_paterno_contacto"
|
<input type="text" id="edit_apellido_paterno_contacto" name="apellido_paterno_contacto"
|
||||||
placeholder="Apellido Paterno" required/>
|
placeholder="Apellido Paterno" />
|
||||||
</div>
|
</div>
|
||||||
<div class="field">
|
<div class="field">
|
||||||
<label for="edit_apellido_materno_contacto">Apellido Materno</label>
|
<label for="edit_apellido_materno_contacto">Apellido Materno</label>
|
||||||
<input type="text" id="edit_apellido_materno_contacto" name="apellido_materno_contacto"
|
<input type="text" id="edit_apellido_materno_contacto" name="apellido_materno_contacto"
|
||||||
placeholder="Apellido Materno"/>
|
placeholder="Apellido Materno" />
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="field">
|
<div class="field">
|
||||||
@ -78,13 +77,13 @@
|
|||||||
form.querySelector(this.props.digito).textContent = Rut.digitoVerificador(this.data.rut)
|
form.querySelector(this.props.digito).textContent = Rut.digitoVerificador(this.data.rut)
|
||||||
form.querySelector(this.props.nombre).value = this.data.nombre
|
form.querySelector(this.props.nombre).value = this.data.nombre
|
||||||
form.querySelector(this.props.razon).value = this.data.razon
|
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.rut).value = (this.data.contacto) ? this.data.contacto.rut : ''
|
||||||
form.querySelector(this.props.contacto.digito).textContent = Rut.digitoVerificador(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.contacto.nombres
|
form.querySelector(this.props.contacto.nombres).value = (this.data.contact) ? this.data.contacto.nombres : ''
|
||||||
form.querySelector(this.props.contacto.apellido_paterno).value = this.data.contacto.apellidoPaterno
|
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.contacto.apellidoMaterno
|
form.querySelector(this.props.contacto.apellido_materno).value = (this.data.contact) ? this.data.contacto.apellidoMaterno : ''
|
||||||
form.querySelector(this.props.contacto.email).value = this.data.contacto.datos.email
|
form.querySelector(this.props.contacto.email).value = (this.data.contact) ? this.data.contacto.datos.email : ''
|
||||||
form.querySelector(this.props.contacto.telefono).value = this.data.contacto.datos.telefono
|
form.querySelector(this.props.contacto.telefono).value = (this.data.contact) ? this.data.contacto.datos.telefono : ''
|
||||||
|
|
||||||
$(this.props.modal).modal('show')
|
$(this.props.modal).modal('show')
|
||||||
})
|
})
|
||||||
@ -97,7 +96,7 @@
|
|||||||
}
|
}
|
||||||
edit() {
|
edit() {
|
||||||
const form = document.getElementById(this.props.form)
|
const form = document.getElementById(this.props.form)
|
||||||
const data = {
|
let data = {
|
||||||
rut: form.querySelector(this.props.rut).value.replace(/\D/g, ''),
|
rut: form.querySelector(this.props.rut).value.replace(/\D/g, ''),
|
||||||
digito: form.querySelector(this.props.digito).textContent,
|
digito: form.querySelector(this.props.digito).textContent,
|
||||||
nombre: form.querySelector(this.props.nombre).value,
|
nombre: form.querySelector(this.props.nombre).value,
|
||||||
|
@ -126,6 +126,20 @@ class Movimientos extends Ideal\Controller
|
|||||||
} catch (EmptyResult) {}
|
} catch (EmptyResult) {}
|
||||||
return $this->withJson($response, $output);
|
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
|
protected function movimientosToArray(array $movimientos): array
|
||||||
{
|
{
|
||||||
|
@ -1,36 +0,0 @@
|
|||||||
<?php
|
|
||||||
namespace Incoviba\Model\Contabilidad\Movimiento;
|
|
||||||
|
|
||||||
use Incoviba\Common\Ideal;
|
|
||||||
use Incoviba\Common\Implement;
|
|
||||||
use Incoviba\Model;
|
|
||||||
|
|
||||||
class Auxiliar extends Ideal\Model
|
|
||||||
{
|
|
||||||
public Model\Contabilidad\Movimiento $movimiento;
|
|
||||||
public int $cargo;
|
|
||||||
public int $abono;
|
|
||||||
|
|
||||||
protected ?Model\Contabilidad\Movimiento\Auxiliar\Detalle $detalles;
|
|
||||||
public function getDetalles(): ?Model\Contabilidad\Movimiento\Auxiliar\Detalle
|
|
||||||
{
|
|
||||||
if (!isset($this->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()
|
|
||||||
]);
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,39 +0,0 @@
|
|||||||
<?php
|
|
||||||
namespace Incoviba\Model\Contabilidad\Movimiento\Auxiliar;
|
|
||||||
|
|
||||||
use Incoviba\Common\Ideal;
|
|
||||||
use Incoviba\Model;
|
|
||||||
|
|
||||||
class Detalle extends Ideal\Model
|
|
||||||
{
|
|
||||||
public Model\Contabilidad\Movimiento\Auxiliar $auxiliar;
|
|
||||||
public ?Model\Contabilidad\CentroCosto $centroCosto;
|
|
||||||
public ?int $rut;
|
|
||||||
public ?string $digito;
|
|
||||||
public ?string $nombre;
|
|
||||||
public ?string $categoria;
|
|
||||||
public ?string $detalle;
|
|
||||||
|
|
||||||
public function rut(): string
|
|
||||||
{
|
|
||||||
return $this->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(),
|
|
||||||
];
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,6 +1,7 @@
|
|||||||
<?php
|
<?php
|
||||||
namespace Incoviba\Model\Contabilidad\Movimiento;
|
namespace Incoviba\Model\Contabilidad\Movimiento;
|
||||||
|
|
||||||
|
use Incoviba\Common\Define;
|
||||||
use Incoviba\Common\Ideal;
|
use Incoviba\Common\Ideal;
|
||||||
use Incoviba\Model;
|
use Incoviba\Model;
|
||||||
|
|
||||||
@ -24,6 +25,9 @@ class Detalle extends Ideal\Model
|
|||||||
return number_format($this->rut, 0, ',', '.') . '-' . $this->digito;
|
return number_format($this->rut, 0, ',', '.') . '-' . $this->digito;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public ?Define\Model $relacionado;
|
||||||
|
public ?string $relacionadoType;
|
||||||
|
|
||||||
public function jsonSerialize(): mixed
|
public function jsonSerialize(): mixed
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
@ -35,7 +39,9 @@ class Detalle extends Ideal\Model
|
|||||||
'categoria' => $this->categoria,
|
'categoria' => $this->categoria,
|
||||||
'detalle' => $this->detalle,
|
'detalle' => $this->detalle,
|
||||||
'identificador' => $this->identificador,
|
'identificador' => $this->identificador,
|
||||||
'rutFormatted' => $this->rutFormatted()
|
'rutFormatted' => $this->rutFormatted(),
|
||||||
|
'relacionado' => $this->relacionado ?? null,
|
||||||
|
'relacionadoType' => $this->relacionadoType ?? null
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,62 +0,0 @@
|
|||||||
<?php
|
|
||||||
namespace Incoviba\Repository\Contabilidad\Movimiento;
|
|
||||||
|
|
||||||
use Incoviba\Common\Define;
|
|
||||||
use Incoviba\Common\Ideal;
|
|
||||||
use Incoviba\Common\Implement;
|
|
||||||
use Incoviba\Common\Implement\Exception\EmptyResult;
|
|
||||||
use Incoviba\Model;
|
|
||||||
use Incoviba\Repository;
|
|
||||||
|
|
||||||
class Auxiliar extends Ideal\Repository
|
|
||||||
{
|
|
||||||
public function __construct(Define\Connection $connection, protected Repository\Contabilidad\Movimiento $movimientoRepository)
|
|
||||||
{
|
|
||||||
parent::__construct($connection);
|
|
||||||
$this->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]);
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,72 +0,0 @@
|
|||||||
<?php
|
|
||||||
namespace Incoviba\Repository\Contabilidad\Movimiento\Auxiliar;
|
|
||||||
|
|
||||||
use Incoviba\Common\Define;
|
|
||||||
use Incoviba\Common\Ideal;
|
|
||||||
use Incoviba\Common\Implement;
|
|
||||||
use Incoviba\Common\Implement\Exception\EmptyResult;
|
|
||||||
use Incoviba\Model;
|
|
||||||
use Incoviba\Repository;
|
|
||||||
|
|
||||||
class Detalle extends Ideal\Repository
|
|
||||||
{
|
|
||||||
public function __construct(Define\Connection $connection,
|
|
||||||
protected Repository\Contabilidad\Movimiento\Auxiliar $auxiliarRepository,
|
|
||||||
protected Repository\Contabilidad\CentroCosto $centroCostoRepository)
|
|
||||||
{
|
|
||||||
parent::__construct($connection);
|
|
||||||
$this->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]);
|
|
||||||
}
|
|
||||||
}
|
|
@ -20,15 +20,18 @@ class Proveedor extends Ideal\Repository
|
|||||||
public function create(?array $data = null): Model\Inmobiliaria\Proveedor
|
public function create(?array $data = null): Model\Inmobiliaria\Proveedor
|
||||||
{
|
{
|
||||||
$map = (new Implement\Repository\MapperParser(['rut', 'digito', 'nombre', 'razon']))
|
$map = (new Implement\Repository\MapperParser(['rut', 'digito', 'nombre', 'razon']))
|
||||||
->register('contacto_rut', (new Implement\Repository\Mapper())->setProperty('contacto')->setFunction(function($data) {
|
->register('contacto_rut', (new Implement\Repository\Mapper())
|
||||||
return $this->personaService->getById($data['contacto_rut']);
|
->setProperty('contacto')
|
||||||
}));
|
->setFunction(function($data) {
|
||||||
|
return $this->personaService->getById($data['contacto_rut']);
|
||||||
|
})
|
||||||
|
->setDefault(null));
|
||||||
return $this->parseData(new Model\Inmobiliaria\Proveedor(), $data, $map);
|
return $this->parseData(new Model\Inmobiliaria\Proveedor(), $data, $map);
|
||||||
}
|
}
|
||||||
public function save(Define\Model $model): Model\Inmobiliaria\Proveedor
|
public function save(Define\Model $model): Model\Inmobiliaria\Proveedor
|
||||||
{
|
{
|
||||||
$this->saveNew(['rut', 'digito', 'nombre', 'razon', 'contacto_rut'], [
|
$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;
|
return $model;
|
||||||
}
|
}
|
||||||
|
@ -2,8 +2,10 @@
|
|||||||
namespace Incoviba\Service\Contabilidad;
|
namespace Incoviba\Service\Contabilidad;
|
||||||
|
|
||||||
use DateTimeInterface;
|
use DateTimeInterface;
|
||||||
|
use Incoviba\Common\Define;
|
||||||
use Incoviba\Common\Ideal\Service;
|
use Incoviba\Common\Ideal\Service;
|
||||||
use Incoviba\Common\Implement;
|
use Incoviba\Common\Implement;
|
||||||
|
use Incoviba\Common\Implement\Exception\EmptyResult;
|
||||||
use Incoviba\Model;
|
use Incoviba\Model;
|
||||||
use Incoviba\Repository;
|
use Incoviba\Repository;
|
||||||
use Psr\Log\LoggerInterface;
|
use Psr\Log\LoggerInterface;
|
||||||
@ -13,7 +15,7 @@ class Movimiento extends Service
|
|||||||
public function __construct(LoggerInterface $logger,
|
public function __construct(LoggerInterface $logger,
|
||||||
protected Repository\Contabilidad\Movimiento $movimientoRepository,
|
protected Repository\Contabilidad\Movimiento $movimientoRepository,
|
||||||
protected Repository\Contabilidad\Movimiento\Detalle $detalleRepository,
|
protected Repository\Contabilidad\Movimiento\Detalle $detalleRepository,
|
||||||
protected Movimiento\Auxiliar $auxiliarService)
|
protected Movimiento\Detalle $detalleService)
|
||||||
{
|
{
|
||||||
parent::__construct($logger);
|
parent::__construct($logger);
|
||||||
}
|
}
|
||||||
@ -76,12 +78,20 @@ class Movimiento extends Service
|
|||||||
$this->movimientoRepository->remove($movimiento);
|
$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
|
public function process(Model\Contabilidad\Movimiento $movimiento): Model\Contabilidad\Movimiento
|
||||||
{
|
{
|
||||||
$movimiento->addFactory('detalles', (new Implement\Repository\Factory())
|
$movimiento->addFactory('detalles', (new Implement\Repository\Factory())
|
||||||
->setCallable(function(int $movimiento_id) {
|
->setCallable(function(int $movimiento_id) {
|
||||||
try {
|
try {
|
||||||
return $this->detalleRepository->fetchByMovimiento($movimiento_id);
|
return $this->detalleService->getByMovimiento($movimiento_id);
|
||||||
} catch (Implement\Exception\EmptyResult) {
|
} catch (Implement\Exception\EmptyResult) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -1,42 +0,0 @@
|
|||||||
<?php
|
|
||||||
namespace Incoviba\Service\Contabilidad\Movimiento;
|
|
||||||
|
|
||||||
use Psr\Log\LoggerInterface;
|
|
||||||
use Incoviba\Common\Ideal;
|
|
||||||
use Incoviba\Common\Implement;
|
|
||||||
use Incoviba\Model;
|
|
||||||
use Incoviba\Repository;
|
|
||||||
use Incoviba\Service;
|
|
||||||
|
|
||||||
class Auxiliar extends Ideal\Service
|
|
||||||
{
|
|
||||||
public function __construct(LoggerInterface $logger,
|
|
||||||
protected Repository\Contabilidad\Movimiento\Auxiliar $auxiliarRepository,
|
|
||||||
protected Repository\Contabilidad\Movimiento\Auxiliar\Detalle $detalleRepository)
|
|
||||||
{
|
|
||||||
parent::__construct($logger);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getByMovimiento(int $movimiento_id): ?array
|
|
||||||
{
|
|
||||||
try {
|
|
||||||
return array_map([$this, 'process'], $this->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;
|
|
||||||
}
|
|
||||||
}
|
|
63
app/src/Service/Contabilidad/Movimiento/Detalle.php
Normal file
63
app/src/Service/Contabilidad/Movimiento/Detalle.php
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
<?php
|
||||||
|
namespace Incoviba\Service\Contabilidad\Movimiento;
|
||||||
|
|
||||||
|
use Incoviba\Common\Implement\Exception\EmptyResult;
|
||||||
|
use Psr\Log\LoggerInterface;
|
||||||
|
use Incoviba\Common\Define;
|
||||||
|
use Incoviba\Common\Ideal;
|
||||||
|
use Incoviba\Common\Implement;
|
||||||
|
use Incoviba\Repository;
|
||||||
|
use Incoviba\Model;
|
||||||
|
|
||||||
|
class Detalle extends Ideal\Service
|
||||||
|
{
|
||||||
|
public function __construct(LoggerInterface $logger,
|
||||||
|
protected Repository\Contabilidad\Movimiento\Detalle $detalleRepository,
|
||||||
|
protected Repository\Venta\Propietario $propietarioRepository,
|
||||||
|
protected Repository\Inmobiliaria\Proveedor $proveedorRepository,
|
||||||
|
protected Repository\Inmobiliaria $inmobiliariaRepository)
|
||||||
|
{
|
||||||
|
parent::__construct($logger);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getByMovimiento(int $movimiento_id): ?Model\Contabilidad\Movimiento\Detalle
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
return $this->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;
|
||||||
|
}
|
||||||
|
}
|
@ -42,14 +42,16 @@ class Proveedor extends Ideal\Service
|
|||||||
$filteredData = $this->proveedorRepository->filterData($data);
|
$filteredData = $this->proveedorRepository->filterData($data);
|
||||||
try {
|
try {
|
||||||
$proveedor = $this->process($this->proveedorRepository->fetchByNombre($filteredData['nombre']));
|
$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']);
|
$contacto = $this->contactoService->add($data['contacto']);
|
||||||
return $this->proveedorRepository->edit($proveedor, ['contacto_rut' => $contacto->rut]);
|
return $this->proveedorRepository->edit($proveedor, ['contacto_rut' => $contacto->rut]);
|
||||||
}
|
}
|
||||||
return $proveedor;
|
return $proveedor;
|
||||||
} catch (Implement\Exception\EmptyResult) {
|
} catch (Implement\Exception\EmptyResult) {
|
||||||
$contacto = $this->contactoService->add($data['contacto']);
|
if (!empty($data['contacto']['rut'])) {
|
||||||
$filteredData['contacto_rut'] = $contacto->rut;
|
$contacto = $this->contactoService->add($data['contacto']);
|
||||||
|
$filteredData['contacto_rut'] = $contacto->rut;
|
||||||
|
}
|
||||||
$proveedor = $this->proveedorRepository->create($filteredData);
|
$proveedor = $this->proveedorRepository->create($filteredData);
|
||||||
return $this->process($this->proveedorRepository->save($proveedor));
|
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
|
public function edit(Model\Inmobiliaria\Proveedor $proveedor, array $data): Model\Inmobiliaria\Proveedor
|
||||||
{
|
{
|
||||||
$filteredData = $this->proveedorRepository->filterData($data);
|
|
||||||
try {
|
try {
|
||||||
if ($proveedor->contacto->rut !== $data['contacto']['rut']) {
|
if (!empty($data['contacto']['rut'])) {
|
||||||
$contacto = $this->contactoService->getById($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));
|
return $this->process($this->proveedorRepository->edit($proveedor, $filteredData));
|
||||||
} catch (Implement\Exception\EmptyResult) {
|
} catch (Implement\Exception\EmptyResult) {
|
||||||
return $proveedor;
|
return $proveedor;
|
||||||
|
Reference in New Issue
Block a user