Skip to content
Snippets Groups Projects
Verified Commit 5c3ac954 authored by Nik | Klampfradler's avatar Nik | Klampfradler
Browse files

Invalidate application state on route request

Routes can define `invalidate: "leave"` or `"enter"` to request
cache eviction when entering/leaving the route.
parent 01160987
No related branches found
No related tags found
1 merge request!1123Resolve "Finalise Vuetify app as SPA"
...@@ -11,14 +11,14 @@ const AleksisVue = {}; ...@@ -11,14 +11,14 @@ const AleksisVue = {};
AleksisVue.install = function (Vue, options) { AleksisVue.install = function (Vue, options) {
/** /**
* The browser title when the app was loaded. * The browser title when the app was loaded.
* *
* Thus, it is injected from Django in the vue_index template. * Thus, it is injected from Django in the vue_index template.
*/ */
Vue.$pageBaseTitle = document.title; Vue.$pageBaseTitle = document.title;
/** /**
* Configure Sentry if desired. * Configure Sentry if desired.
* *
* It depends on Sentry settings being passed as a DOM object by Django * It depends on Sentry settings being passed as a DOM object by Django
* in the vue_index template. * in the vue_index template.
*/ */
...@@ -60,9 +60,9 @@ AleksisVue.install = function (Vue, options) { ...@@ -60,9 +60,9 @@ AleksisVue.install = function (Vue, options) {
/** /**
* Set the page title. * Set the page title.
* *
* This will automatically add the base title discovered at app loading time. * This will automatically add the base title discovered at app loading time.
* *
* @param {string} title Specific title to set, or null. * @param {string} title Specific title to set, or null.
* @param {Object} route Route to discover title from, or null. * @param {Object} route Route to discover title from, or null.
*/ */
...@@ -98,6 +98,27 @@ AleksisVue.install = function (Vue, options) { ...@@ -98,6 +98,27 @@ AleksisVue.install = function (Vue, options) {
} }
}; };
/**
* Invalidate state and force reload from server.
*
* Mostly useful after the user context changes by login/logout/impersonate.
*/
Vue.prototype.$invalidateState = function () {
console.info("Invalidating application state");
this.$apollo
.getClient()
.resetStore()
.then(
function () {
console.info("GraphQL cache cleared");
},
function (error) {
console.error("Could not clear GraphQL cache:", error);
}
);
};
/** /**
* Add navigation guards to account for global loading state and page titles. * Add navigation guards to account for global loading state and page titles.
*/ */
...@@ -120,6 +141,15 @@ AleksisVue.install = function (Vue, options) { ...@@ -120,6 +141,15 @@ AleksisVue.install = function (Vue, options) {
this.$router.afterEach((to, from) => { this.$router.afterEach((to, from) => {
vm.contentLoading = false; vm.contentLoading = false;
}); });
// eslint-disable-next-line no-unused-vars
this.$router.beforeEach((to, from, next) => {
if (from.meta.invalidate === "leave" || to.meta.invalidate === "enter") {
console.debug("Route requests to invalidate state");
vm.$invalidateState();
}
next();
});
}; };
}; };
......
...@@ -20,6 +20,7 @@ const routes = [ ...@@ -20,6 +20,7 @@ const routes = [
icon: "mdi-login-variant", icon: "mdi-login-variant",
titleKey: "accounts.login.menu_title", titleKey: "accounts.login.menu_title",
validators: [notLoggedInValidator], validators: [notLoggedInValidator],
invalidate: "leave",
}, },
}, },
{ {
...@@ -31,6 +32,7 @@ const routes = [ ...@@ -31,6 +32,7 @@ const routes = [
icon: "mdi-account-plus-outline", icon: "mdi-account-plus-outline",
titleKey: "accounts.signup.menu_title", titleKey: "accounts.signup.menu_title",
validators: [notLoggedInValidator], validators: [notLoggedInValidator],
invalidate: "leave",
}, },
}, },
{ {
...@@ -468,6 +470,9 @@ const routes = [ ...@@ -468,6 +470,9 @@ const routes = [
path: "/impersonate/:uid(\\d+)/", path: "/impersonate/:uid(\\d+)/",
component: () => import("./components/LegacyBaseTemplate.vue"), component: () => import("./components/LegacyBaseTemplate.vue"),
name: "impersonate.impersonateByUserPk", name: "impersonate.impersonateByUserPk",
meta: {
invalidate: "leave",
},
}, },
// ACCOUNT MENU // ACCOUNT MENU
...@@ -476,6 +481,9 @@ const routes = [ ...@@ -476,6 +481,9 @@ const routes = [
path: "/impersonate/stop/", path: "/impersonate/stop/",
component: () => import("./components/LegacyBaseTemplate.vue"), component: () => import("./components/LegacyBaseTemplate.vue"),
name: "impersonate.stop", name: "impersonate.stop",
meta: {
invalidate: "leave",
},
}, },
{ {
path: "/person/", path: "/person/",
...@@ -694,6 +702,7 @@ const routes = [ ...@@ -694,6 +702,7 @@ const routes = [
icon: "mdi-logout-variant", icon: "mdi-logout-variant",
permission: "core.logout_rule", permission: "core.logout_rule",
divider: true, divider: true,
invalidate: "leave",
}, },
}, },
{ {
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment