pcpuma_unam_operador/components/admin/AdminInstitucion.vue
2022-07-13 18:30:48 -05:00

218 lines
6.3 KiB
Vue

<template>
<div class="column is-4">
<h3 class="is-size-4 mb-4">Alta del administrador</h3>
<div class="columns">
<div class="column">
<b-field
label="Responsable"
v-show="admin.tipoUsuario.id_tipo_usuario === 2"
>
<b-input
type="text"
@keyup.enter.native="actualizarDatos()"
:placeholder="institucion.responsable"
:disabled="!institucion.id_institucion"
v-model="responsable"
/>
</b-field>
<b-field
label="Correo"
v-show="admin.tipoUsuario.id_tipo_usuario === 2"
>
<b-input
type="email"
@keyup.enter.native="actualizarDatos()"
:placeholder="institucion.correo"
:disabled="!institucion.id_institucion"
v-model="correo"
/>
</b-field>
<b-field
label="Telefono"
v-show="admin.tipoUsuario.id_tipo_usuario === 2"
>
<b-input
type="tel"
@keyup.enter.native="actualizarDatos()"
:placeholder="institucion.telefono"
:disabled="!institucion.id_institucion"
v-model="telefono"
/>
</b-field>
<b-field
label="Ubicación"
v-show="admin.tipoUsuario.id_tipo_usuario === 2"
>
<b-input
type="text"
@keyup.enter.native="actualizarDatos()"
:placeholder="institucion.ubicacion"
:disabled="!institucion.id_institucion"
v-model="ubicacion"
/>
</b-field>
<b-field
label="Dominio"
v-show="admin.tipoUsuario.id_tipo_usuario === 3"
>
<b-input
type="text"
@keyup.enter.native="actualizarDatos()"
:placeholder="institucion.dominio"
:disabled="!institucion.id_institucion"
v-model="dominio"
/>
</b-field>
<b-field
label="Días de multa por retraso"
v-show="admin.tipoUsuario.id_tipo_usuario === 3"
>
<b-input
type="number"
@keyup.enter.native="actualizarDatos()"
:placeholder="institucion.dias_multa_retraso"
:disabled="!institucion.id_institucion"
v-model="diasMultaRetraso"
/>
</b-field>
<b-field
label="Tiempo para recoger equipo"
v-show="admin.tipoUsuario.id_tipo_usuario === 3"
>
<b-input
type="number"
@keyup.enter.native="actualizarDatos()"
:placeholder="institucion.tiempo_recoger"
:disabled="!institucion.id_institucion"
v-model="tiempoRecoger"
/>
</b-field>
<b-field
label="Tiempo para entregar equipo"
v-show="admin.tipoUsuario.id_tipo_usuario === 3"
>
<b-input
type="number"
@keyup.enter.native="actualizarDatos()"
:placeholder="institucion.tiempo_entrega"
:disabled="!institucion.id_institucion"
v-model="tiempoEntrega"
/>
</b-field>
<b-field
label="Tiempo de prestamo"
v-show="admin.tipoUsuario.id_tipo_usuario === 3"
>
<b-input
type="number"
@keyup.enter.native="actualizarDatos()"
:placeholder="institucion.tiempo_prestamo"
:disabled="!institucion.id_institucion"
v-model="tiempoPrestamo"
/>
</b-field>
<b-field>
<b-button
type="is-info"
:disabled="
responsable ||
correo ||
telefono ||
ubicacion ||
dominio ||
diasMultaRetraso ||
tiempoPrestamo ||
tiempoRecoger ||
tiempoEntrega
? false
: true
"
@click="actualizarDatos()"
expanded
>
Guardar
</b-button>
</b-field>
</div>
</div>
</div>
</template>
<script>
import axios from 'axios'
export default {
props: {
buscar: { type: Function, required: true },
updateIsLoading: { type: Function, required: true },
admin: { type: Object, required: true },
institucion: { type: Object, required: true },
},
data() {
return {
correo: '',
responsable: '',
telefono: '',
ubicacion: '',
dominio: '',
diasMultaRetraso: '',
tiempoRecoger: '',
tiempoEntrega: '',
tiempoPrestamo: '',
}
},
methods: {
actualizarDatos() {
const data = { id_institucion: this.institucion.id_institucion }
this.updateIsLoading(true)
if (this.correo) data.correo = this.correo
if (this.responsable) data.responsable = this.responsable
if (this.telefono) data.telefono = this.telefono
if (this.ubicacion) data.ubicacion = this.ubicacion
if (this.dominio) {
data.email_institucional = true
data.dominio = this.dominio
}
if (this.diasMultaRetraso)
this.data.dias_multa_retraso = this.diasMultaRetraso
if (this.tiempoRecoger) this.data.tiempo_recoger = this.tiempoRecoger
if (this.tiempoEntrega) this.data.tiempo_entrega = this.tiempoEntrega
if (this.tiempoPrestamo) this.data.tiempo_prestamo = this.tiempoPrestamo
axios
.put(`${process.env.api}/institucion`, data)
.then((res) => {
if (this.correo) this.correo = ''
if (this.responsable) this.responsable = ''
if (this.telefono) this.telefono = ''
if (this.dominio) this.dominio = ''
if (this.ubicacion) this.ubicacion = ''
if (this.diasMultaRetraso) this.diasMultaRetraso = ''
if (this.tiempoRecoger) this.tiempoRecoger = ''
if (this.tiempoEntrega) this.tiempoEntrega = ''
if (this.tiempoPrestamo) this.tiempoPrestamo = ''
this.updateIsLoading(false)
this.buscar()
this.$alertsGenericos.imprimirMensaje(this.$buefy, res.data.message)
})
.catch((err) => {
this.updateIsLoading(false)
this.$alertsGenericos.imprimirError(this.$buefy, err.response.data)
})
},
},
}
</script>
<style></style>