2022-05-25 19:03:29 -03:00
< template >
< div >
< label class = "label" > Escribí el nombre de tu familia o grupo de convivencia < / label >
< div class = "columns" >
< div class = "column is-two-thirds" >
< div class = "field" >
< div class = "control" >
2022-06-08 20:32:50 -03:00
< input class = "input" @input ="onType" v -model = " subpedido " / >
2022-05-25 19:03:29 -03:00
< / div >
< p class = "help" > Debe ser claro para que tus compas del barrio te identifiquen . < / p >
< / div >
< / div >
< div class = "column is-one-third buttons" >
< button class = "button is-danger" v-show ="!botonCrearDesabilitado" @click="submit" > Crear nuevo pedido < / button >
< / div >
< / div >
2022-06-08 20:32:50 -03:00
< div v-if ="subpedidosExistentes.length" class="block" >
< label class = "label" > Si ya comenzaste a hacer tu pedido este mes , elegilo en esta lista : < / label >
< p class = "help" > Podés seguir escribiendo en el campo de arriba para refinar la búsqueda . < / p >
2022-10-21 19:17:52 -03:00
< div class = "columns is-mobile" v-for ="(subpedidoExistente, index) in subpedidosExistentes" :class="{'has-background-grey-lighter': index % 2}" :key ="index" >
2022-06-08 20:32:50 -03:00
< div class = "column is-half-mobile is-two-thirds-desktop is-two-thirds-tablet" >
< p style = "padding-top: calc(.5em - 1px); margin-bottom: .5rem" v-text ="subpedidoExistente.nombre" > < / p >
< / div >
< div class = "buttons column is-half-mobile is-one-third-desktop is-one-third-tablet" >
< button class = "button is-danger" @click ="elegirSubpedido(subpedidoExistente)" > Continuar pedido < / button >
< / div >
< / div >
< / div >
< / div >
2022-05-25 19:03:29 -03:00
< / template >
< script >
export default {
data ( ) {
return {
subpedido : null ,
subpedidosExistentes : [ ]
}
} ,
computed : {
nombresDeSubpedidos : function ( ) {
return this . subpedidosExistentes . map ( a => a . nombre . toLowerCase ( ) )
} ,
botonCrearDesabilitado : function ( ) {
return ! this . subpedido || this . nombresDeSubpedidos . includes ( this . subpedido . toLowerCase ( ) )
}
} ,
props : [ "gdcid" ] ,
mounted ( ) {
console . log ( "ready" ) ;
} ,
methods : {
onType ( ) {
if ( ! this . subpedido ) {
this . subpedidosExistentes = [ ] ;
return ;
}
axios . get ( "/api/subpedidos" , {
params : {
nombre : this . subpedido ,
grupo _de _compra : this . gdcid
}
} ) . then ( response => {
this . subpedidosExistentes = response . data
} ) ;
} ,
submit ( ) {
axios . post ( "/api/subpedidos" , {
nombre : this . subpedido ,
grupo _de _compra _id : this . gdcid
} ) . then ( response => {
2023-05-27 20:08:55 -03:00
//se creo el subpedido
this . elegirSubpedido ( response . data ) ;
2022-05-25 19:03:29 -03:00
} ) ;
} ,
elegirSubpedido ( subpedido ) {
//lo guardamos en sesion
this . guardarSubpedidoEnSesion ( subpedido ) ;
} ,
guardarSubpedidoEnSesion ( subpedido ) {
axios . post ( "/subpedidos/guardar_sesion" , {
2024-07-11 19:00:31 -03:00
subpedido : subpedido ,
grupo _de _compra _id : this . gdcid
2023-05-27 20:08:55 -03:00
} ) . then ( _ => {
Event . $emit ( 'obtener-sesion' )
2022-05-25 19:03:29 -03:00
window . location . href = 'productos' ;
} ) ;
}
}
}
2022-06-08 20:32:50 -03:00
< / script >