diff --git a/frontend/src/router.js b/frontend/src/router.js index 9375a5a..71b3ceb 100644 --- a/frontend/src/router.js +++ b/frontend/src/router.js @@ -8,6 +8,7 @@ import NewSite from "./views/NewSite.vue"; import NewTutor from "./views/NewTutor.vue"; import ViewObservations from "./views/ViewObservations.vue"; import ObservationComplete from "./views/ObservationComplete.vue"; +import DBError from "./views/DatabaseUnavailable.vue" Vue.use(Router); @@ -52,6 +53,11 @@ export default new Router({ path: "/complete", name: "complete", component: ObservationComplete + }, + { + path: "/dberror", + name: "dberror", + component: DBError } ] }); diff --git a/frontend/src/views/DatabaseUnavailable.vue b/frontend/src/views/DatabaseUnavailable.vue new file mode 100644 index 0000000..2e024d3 --- /dev/null +++ b/frontend/src/views/DatabaseUnavailable.vue @@ -0,0 +1,35 @@ + + + + + \ No newline at end of file diff --git a/frontend/src/views/Home.vue b/frontend/src/views/Home.vue index b600cba..eca5b8d 100644 --- a/frontend/src/views/Home.vue +++ b/frontend/src/views/Home.vue @@ -7,7 +7,7 @@ - Start a new observation + Start a new observation diff --git a/frontend/src/views/NewSite.vue b/frontend/src/views/NewSite.vue index 10838ae..9690238 100644 --- a/frontend/src/views/NewSite.vue +++ b/frontend/src/views/NewSite.vue @@ -33,6 +33,20 @@ submissionPassword: "" }; }, + mounted() { + Vue.axios + .get("/site") + .then(response => { + }) + .catch(error => { + if(error.response.status === 404){ + this.$router.push("/dberror"); + return; + } + this.alertText = error.response.data; + this.alertVariant = "danger"; + }); + }, methods: { countDownChanged: function (dismissCountDown) { this.dismissCountDown = dismissCountDown; diff --git a/frontend/src/views/NewTutor.vue b/frontend/src/views/NewTutor.vue index 4ac8a96..0f416b9 100644 --- a/frontend/src/views/NewTutor.vue +++ b/frontend/src/views/NewTutor.vue @@ -43,6 +43,10 @@ export default { this.siteOptions = response.data; }) .catch(error => { + if(error.response.status === 404){ + this.$router.push("/dberror"); + return; + } this.alertText = error.response.data; this.alertVariant = "danger"; }); diff --git a/frontend/src/views/StartNew.vue b/frontend/src/views/StartNew.vue index 82cabd5..2022eb4 100644 --- a/frontend/src/views/StartNew.vue +++ b/frontend/src/views/StartNew.vue @@ -106,6 +106,10 @@ this.loaded = true; }) .catch(error => { + if(error.response.status === 404){ + this.$router.push("/dberror"); + return; + } this.errorStatus = error.response.status; this.errorMessage = error.response.data; this.$refs.errorModal.show(); @@ -136,6 +140,15 @@ Vue.axios.get("/site/" + this.site + "/tutors").then(response => { this.tutorOptions = response.data; this.loadingTutors = false; + }).catch(error => { + if(error.response.status === 404){ + this.$router.push("/dberror"); + return; + + } + this.errorStatus = error.response.status; + this.errorMessage = error.response.data; + this.$refs.errorModal.show(); }); } }, diff --git a/frontend/src/views/Stats.vue b/frontend/src/views/Stats.vue index 00af6c9..4e345d1 100644 --- a/frontend/src/views/Stats.vue +++ b/frontend/src/views/Stats.vue @@ -161,6 +161,10 @@ this.siteOptions = response.data; }) .catch(error => { + if(error.response.status === 404){ + this.$router.push("/dberror"); + return; + } this.errorStatus = error.response.status; this.errorMessage = error.response.data; this.$refs.errorModal.show(); diff --git a/frontend/src/views/ViewObservations.vue b/frontend/src/views/ViewObservations.vue index 5dd159e..6c4094a 100644 --- a/frontend/src/views/ViewObservations.vue +++ b/frontend/src/views/ViewObservations.vue @@ -101,6 +101,10 @@ this.siteOptions = response.data; }) .catch(error => { + if(error.response.status === 404){ + this.$router.push("/dberror"); + return; + } console.log(error); }); },