Editar propiedad en venta

This commit is contained in:
2023-12-01 15:00:25 -03:00
parent af9c6c51d4
commit 57579a52f1
6 changed files with 127 additions and 8 deletions

View File

@ -45,7 +45,7 @@
<div class="ui modal" id="add_modal">
<div class="content">
<h3 class="header">Agregar</h3>
<div class="ui form" id="add_form">
<form class="ui form" id="add_form">
<div class="field">
<label for="tipo">Tipo</label>
<select id="tipo" name="tipo" class="ui search selection dropdown">
@ -58,8 +58,14 @@
<label for="unidad">Unidad</label>
<select id="unidad" name="unidad" class="ui search selection dropdown" size="4"></select>
</div>
<button class="ui button">Agregar</button>
</div>
<div class="field">
<label for="valor">Valor Venta</label>
<input id="valor" type="text" name="valor" />
</div>
</form>
</div>
<div class="actions">
<button class="ui approve button">Agregar</button>
</div>
</div>
@endsection
@ -72,6 +78,7 @@
{
id: {{$unidad->id}},
tipo: '{{ucwords($unidad->proyectoTipoUnidad->tipoUnidad->descripcion)}}',
tipo_id: {{$unidad->proyectoTipoUnidad->tipoUnidad->id}},
descripcion: '{{$unidad->descripcion}}',
pid: {{$unidad->pu_id}},
valor: {{($unidad->valor > 0) ? $unidad->valor : $unidad->precio($venta->fecha)->valor}}
@ -99,8 +106,51 @@
addUnidad: function() {
$('#add_modal').modal('show')
},
doAddUnidad: function() {
const url = '{{$urls->api}}/ventas/propiedades/unidades/add'
const data = new FormData(document.getElementById('add_form'))
data.set('propiedad', {{$propiedad->id}})
return fetchAPI(url, {method: 'post', body: data}).then(response => {
if (response.ok) {
return response.json()
}
}).then(json => {
if (!json.added) {
return
}
const tipo = json.propiedad_unidad.proyecto_tipo_unidad.tipo_unidad.descripcion
this.unidades.push({
id: json.propiedad_unidad.id,
tipo: tipo.charAt(0).toUpperCase() + tipo.slice(1),
tipo_id: json.propiedad_unidad.proyecto_tipo_unidad.tipo_unidad.id,
descripcion: json.propiedad_unidad.descripcion,
pid: json.propiedad_unidad.pu_id,
valor: parseFloat(json.propiedad_unidad.valor)
})
this.draw()
const idx = this.tipos[json.propiedad_unidad.proyecto_tipo_unidad.tipo_unidad.id].findIndex(unidad => unidad.value === json.propiedad_unidad.id)
this.tipos[json.propiedad_unidad.proyecto_tipo_unidad.tipo_unidad.id].splice(idx,1)
})
},
removeUnidad: function(unidad_id) {
console.debug(unidad_id)
const url = '{{$urls->api}}/ventas/propiedades/unidad/' + unidad_id
return fetchAPI(url, {method: 'delete'}).then(response => {
if (response.ok) {
return response.json()
}
}).then(json => {
if (!json.removed) {
return
}
const idx = this.unidades.findIndex(unidad => unidad.pid === json.propiedad_unidad_id)
const unidad = this.unidades.splice(idx,1)[0]
this.draw()
this.tipos[unidad.tipo_id].push({
value: unidad.id,
text: unidad.descripcion,
name: unidad.descripcion
})
})
},
updatePrecio: function(pid, valor) {
const idx = this.unidades.findIndex(unidad => unidad.pid === pid)
@ -113,7 +163,7 @@
}
const url = '{{$urls->api}}/ventas/propiedades/unidad/' + id + '/edit'
const data = new FormData()
data.set('valor', value)
data.set('valor', valor)
return fetchAPI(url, {method: 'post', body: data}).then(response => {
if (response.ok) {
return response.json()
@ -170,7 +220,11 @@
const unidad_id = $(event.currentTarget).data('pid')
this.removeUnidad(unidad_id)
})
$('#add_modal').modal()
$('#add_modal').modal({
onApprove: ($element) => {
this.doAddUnidad()
}
})
const tipo = $('#tipo')
tipo.dropdown()
tipo.change(event => {
@ -180,7 +234,8 @@
this.changeTipoUnidad(tipo.val())
$('#add_form').submit(event => {
event.preventDefault()
tipo.model('hide')
this.doAddUnidad()
tipo.modal('hide')
return false
})
$('.precio').change(event => {