Here is my store.js
export default {
user: {
name: null
}
}
And here is my api call from my dashboard.<script>
export default {
mounted() {
axios.get('/api/getAuthUser')
.then(response => {
this.$store.user.name = response.data.name;
});
}
}
</script>
This works fine and it will set the user name in store to the user name i get from my api call.But if the first visit to my site is not the dashboard then there is no api call and the name is not set in the store. But I need that name at different places in my app.
I don't wont to call my api from every component. Is it possible to call the api only once directly from my store? How can I do that or is there any better solution?
Thanks!
// UPDATE
Is there any way to make a direct call from the store.js?
export default {
user: {
name: null
},
ready () {
axios.get('/api/getAuthUser')
.then(response => {
this.user.name = response.data.name;
});
}
}
This does not work. name is still null// Update 2
import axios from 'axios'
axios.defaults.headers.common = {
'X-CSRF-TOKEN': Laravel.csrfToken,
'X-Requested-With': 'XMLHttpRequest'
};
export default {
user: {
name: null
},
setUser() {
axios.get('/api/getAuthUser')
.then(response => {
this.user.name = response.data.name;
});
}}
This is my complete store.js but it seems that setUser() does not get executed.via user3382438