mirror of
https://github.com/prurigro/hypothetical.git
synced 2024-11-21 23:52:31 -05:00
180 lines
4.3 KiB
JavaScript
180 lines
4.3 KiB
JavaScript
// Import features from Vue
|
|
import { createApp, nextTick } from "vue";
|
|
|
|
// Initialize Vue
|
|
const Vue = createApp({});
|
|
|
|
// Import and configure axios
|
|
import axios from "axios";
|
|
|
|
axios.defaults.headers.common = {
|
|
"X-Requested-With": "XMLHttpRequest",
|
|
"X-CSRF-TOKEN": env.csrfToken
|
|
};
|
|
|
|
Vue.config.globalProperties.$http = axios;
|
|
|
|
// Import plugins
|
|
import { createRouter, createWebHistory } from "vue-router";
|
|
import { createStore } from "vuex";
|
|
|
|
// Import local javascript
|
|
import SupportsWebP from "imports/supports-webp.js";
|
|
|
|
// Import global mixins
|
|
import ImageType from "mixins/image-type.js";
|
|
|
|
// Register global mixins
|
|
Vue.mixin(ImageType);
|
|
|
|
// Import global components
|
|
import NavSection from "sections/nav.vue";
|
|
import FooterSection from "sections/footer.vue";
|
|
import Lang from "partials/lang.vue";
|
|
|
|
// Name the global components
|
|
Vue.component("nav-component", NavSection);
|
|
Vue.component("footer-component", FooterSection);
|
|
Vue.component("lang", Lang);
|
|
|
|
// Import page components
|
|
import HomePage from "pages/home.vue";
|
|
import BlogPage from "pages/blog.vue";
|
|
import ContactPage from "pages/contact.vue";
|
|
import Error404Page from "pages/error404.vue";
|
|
|
|
// Create a router instance
|
|
const router = new createRouter({
|
|
history: createWebHistory(),
|
|
linkActiveClass: "active",
|
|
|
|
routes: [
|
|
{ path: "/", component: HomePage },
|
|
{ path: "/blog", component: BlogPage },
|
|
{ path: "/contact", component: ContactPage },
|
|
{ path: "/:match(.*)", component: Error404Page }
|
|
],
|
|
|
|
scrollBehavior(to, from, savedPosition) {
|
|
if (to.hash) {
|
|
return {
|
|
el: `[id='${to.hash.slice(1)}']`
|
|
};
|
|
} else if (savedPosition) {
|
|
return savedPosition;
|
|
} else {
|
|
return { top: 0 };
|
|
}
|
|
}
|
|
});
|
|
|
|
// Create a vuex store instance
|
|
const store = createStore({
|
|
state: {
|
|
appName: env.appName,
|
|
appLang: env.appLang,
|
|
appDefaultLang: env.appDefaultLang,
|
|
firstLoad: true,
|
|
firstPage: true,
|
|
lastPath: "",
|
|
supportsWebP: null
|
|
},
|
|
|
|
getters: {
|
|
getAppName: state => {
|
|
return state.appName;
|
|
},
|
|
|
|
getAppLang: state => {
|
|
return state.appLang;
|
|
},
|
|
|
|
getAppDefaultLang: state => {
|
|
return state.appDefaultLang;
|
|
},
|
|
|
|
getFirstLoad: state => {
|
|
return state.firstLoad;
|
|
},
|
|
|
|
getFirstPage: state => {
|
|
return state.firstPage;
|
|
},
|
|
|
|
getLastPath: state => {
|
|
return state.lastPath;
|
|
},
|
|
|
|
getSupportsWebP: state => {
|
|
return state.supportsWebP;
|
|
}
|
|
},
|
|
|
|
mutations: {
|
|
setAppLang(state, value) {
|
|
state.appLang = value;
|
|
axios.get(`/language/${value}`);
|
|
},
|
|
|
|
setFirstLoad(state, value) {
|
|
state.firstLoad = value;
|
|
},
|
|
|
|
setFirstPage(state, value) {
|
|
state.firstPage = value;
|
|
},
|
|
|
|
setLastPath(state, value) {
|
|
state.lastPath = value;
|
|
},
|
|
|
|
setSupportsWebP(state, value) {
|
|
state.supportsWebP = value;
|
|
}
|
|
},
|
|
|
|
actions: {
|
|
|
|
}
|
|
});
|
|
|
|
// Detect webp support
|
|
SupportsWebP.detect(store);
|
|
|
|
// Functionality to run before page load and change
|
|
router.beforeEach((to, from, next) => {
|
|
if (to.path !== store.getters.getLastPath) {
|
|
if (store.getters.getFirstLoad) {
|
|
next();
|
|
} else {
|
|
// Unfocused any focused elements
|
|
if ("activeElement" in document) {
|
|
document.activeElement.blur();
|
|
}
|
|
|
|
// Fade the page out and scroll when moving from one page to another
|
|
TweenMax.to("#router-view", 0.25, {
|
|
opacity: 0,
|
|
onComplete: next
|
|
});
|
|
}
|
|
}
|
|
});
|
|
|
|
// Functionality to run on page load and change
|
|
router.afterEach((to, from) => {
|
|
if (to.path !== store.getters.getLastPath) {
|
|
store.commit("setLastPath", to.path);
|
|
|
|
if (store.getters.getFirstLoad) {
|
|
// Set Page.firstLoad to false so we know the initial load has completed
|
|
store.commit("setFirstLoad", false);
|
|
} else {
|
|
nextTick(() => {
|
|
TweenMax.to("#router-view", 0.25, { opacity: 1 });
|
|
});
|
|
}
|
|
}
|
|
});
|
|
|
|
Vue.use(router).use(store).mount("#vue-container");
|