Added progress bar hook calls within our EventShow component

master
androiddrew 6 years ago
parent 66b9ffabcd
commit 2c574c549f

@ -1,5 +1,19 @@
# real-world-vue # real-world-vue
## Course Take aways:
- Installation of [NProgress](https://github.com/rstacruz/nprogress) to create a better experience for a user when they are interacting with our application.
- Axios Interceptors
- Not optimal for multiple API calls
- We do not want to show the user the template before the data is available.
- In-component Route Gaurds
- Global and Per-Route Gaurds (Unltimately will use this.)
- Use the `npx json-server -d 1500 --watch ./db.json` command to simulate a slow network response.
- Good reasons to use interceptors:
- On request to set authorization tokens
- On respinse to format or filter data before it reaches into your app
- On response to catch 401 not authorized responses
## Following along? ## Following along?
We encourage you to follow the course on Vue Mastery, and code along with us. This course has tags representing the start and finish of each level, just in case you get stuck. Here's the start and ending code of each lesson, if you'd like to download them. We encourage you to follow the course on Vue Mastery, and code along with us. This course has tags representing the start and finish of each level, just in case you get stuck. Here's the start and ending code of each lesson, if you'd like to download them.
@ -18,7 +32,7 @@ We encourage you to follow the course on Vue Mastery, and code along with us. Th
| 12 - Vuex Mutations & Actions Part 1 | [Starting Code](https://github.com/Code-Pop/real-world-vue/releases/tag/lesson12-mutations%26actions1-start) | [Finished Code](https://github.com/Code-Pop/real-world-vue/releases/tag/lesson12-mutations%26actions1-finish) | | 12 - Vuex Mutations & Actions Part 1 | [Starting Code](https://github.com/Code-Pop/real-world-vue/releases/tag/lesson12-mutations%26actions1-start) | [Finished Code](https://github.com/Code-Pop/real-world-vue/releases/tag/lesson12-mutations%26actions1-finish) |
| 13 - Vuex Mutations & Actions Part 2 | [Starting Code](https://github.com/Code-Pop/real-world-vue/releases/tag/lesson13-mutations%26actions2-start) | [Finished Code](https://github.com/Code-Pop/real-world-vue/releases/tag/lesson13-mutations%26actions2-finish) | | 13 - Vuex Mutations & Actions Part 2 | [Starting Code](https://github.com/Code-Pop/real-world-vue/releases/tag/lesson13-mutations%26actions2-start) | [Finished Code](https://github.com/Code-Pop/real-world-vue/releases/tag/lesson13-mutations%26actions2-finish) |
| 14 - Vuex Modules | [Starting Code](https://github.com/Code-Pop/real-world-vue/releases/tag/lesson14-modules-start) | [Finished Code](https://github.com/Code-Pop/real-world-vue/releases/tag/lesson14-modules-finish) | | 14 - Vuex Modules | [Starting Code](https://github.com/Code-Pop/real-world-vue/releases/tag/lesson14-modules-start) | [Finished Code](https://github.com/Code-Pop/real-world-vue/releases/tag/lesson14-modules-finish) |
| 15 - Success & Error Notifications | [Starting Code](https://github.com/Code-Pop/real-world-vue/releases/tag/lesson15-notifications-start) | [Finished Code](https://github.com/Code-Pop/real-world-vue/releases/tag/lesson15-notifications-finish) | | 15 - Success & Error Notifications | [Starting Code](https://github.com/Code-Pop/real-world-vue/releases/tag/lesson15-notifications-start) | [Finished Code](https://github.com/Code-Pop/real-world-vue/releases/tag/lesson15-notifications-finish) |
## Project setup ## Project setup

5
package-lock.json generated

@ -8547,6 +8547,11 @@
"path-key": "^2.0.0" "path-key": "^2.0.0"
} }
}, },
"nprogress": {
"version": "0.2.0",
"resolved": "https://registry.npmjs.org/nprogress/-/nprogress-0.2.0.tgz",
"integrity": "sha1-y480xTIT2JVyP8urkH6UIq28r7E="
},
"nth-check": { "nth-check": {
"version": "1.0.1", "version": "1.0.1",
"resolved": "https://registry.npmjs.org/nth-check/-/nth-check-1.0.1.tgz", "resolved": "https://registry.npmjs.org/nth-check/-/nth-check-1.0.1.tgz",

@ -11,6 +11,7 @@
"axios": "^0.18.0", "axios": "^0.18.0",
"json-server": "^0.14.2", "json-server": "^0.14.2",
"lodash": "^4.17.11", "lodash": "^4.17.11",
"nprogress": "^0.2.0",
"vue": "^2.5.17", "vue": "^2.5.17",
"vue-router": "^3.0.1", "vue-router": "^3.0.1",
"vuejs-datepicker": "^1.5.3", "vuejs-datepicker": "^1.5.3",

@ -5,6 +5,8 @@ import App from './App.vue'
import router from './router' import router from './router'
import store from './store/store' import store from './store/store'
import BaseIcon from '@/components/BaseIcon' import BaseIcon from '@/components/BaseIcon'
// Here we need the styles for nprogress
import 'nprogress/nprogress.css'
Vue.component('BaseIcon', BaseIcon) Vue.component('BaseIcon', BaseIcon)

@ -1,4 +1,5 @@
import axios from 'axios' import axios from 'axios'
import NProgress from 'nprogress'
const apiClient = axios.create({ const apiClient = axios.create({
baseURL: `http://localhost:3000`, baseURL: `http://localhost:3000`,
@ -9,6 +10,18 @@ const apiClient = axios.create({
} }
}) })
// Interceptor definition. This is like middleware
apiClient.interceptors.request.use(config => {
NProgress.start()
return config
})
apiClient.interceptors.response.use(response => {
NProgress.done()
return response
})
export default { export default {
getEvents(perPage, page) { getEvents(perPage, page) {
return apiClient.get('/events?_limit=' + perPage + '&_page=' + page) return apiClient.get('/events?_limit=' + perPage + '&_page=' + page)

Loading…
Cancel
Save