window.Event = new Vue(); Vue.component('nav-bar', { template: ` `, data() { return { isActive: false, subpedido: null } }, methods: { toggleState() { this.isActive = !this.isActive; }, actualizarSubpedido(){ axios.get("/api/subpedidos/" + this.subpedido.id) .then(response => { this.subpedido = response.data.data; }); }, toggleChismosa(){ Event.$emit("toggle-chismosa"); } }, mounted() { axios.get("/subpedidos/obtener_sesion").then(response => { this.subpedido = response.data.subpedido; this.actualizarSubpedido() }); //Emitir un evento subpedido-actualizado al agregar o eliminar un producto del subpedido para que el total de la chismosa se muestre correctamente Event.$on('sync-subpedido', (cantidad, id) => { axios.post("/api/subpedidos/"+this.subpedido.id+"/sync", { cantidad: cantidad, producto_id: id }).then(() => { bulmaToast.toast({ message: 'Pedido actualizado exitosamente', duration: 1000, type: 'is-danger', position: 'bottom-center', animate: { in: 'fadeIn', out: 'fadeOut' } }); this.actualizarSubpedido(); }); }); } }); Vue.component('nav-migas', { data() { return { migas: [] } }, computed: { visible: function() { return this.migas.length > 0 } }, mounted() { Event.$on('migas-setear-como-inicio', (miga) => { this.migas = []; this.migas.push(miga); }); Event.$on('migas-agregar', (miga) => { this.migas.push(miga); }); Event.$on('migas-reset', () => { this.migas = []; }); Event.$on('migas-pop', () => { this.migas.pop(); }); } }); new Vue({ el: '#app' });