import Vue from "vue"; import Router from "vue-router"; Vue.use(Router); /* Xeslint-disable */ // scrollBehavior: // - only available in html5 history mode // - defaults to no scroll behavior // - return false to prevent scroll const scrollBehavior = function(to, from, savedPosition) { if (savedPosition) { // savedPosition is only available for popstate navigations. return savedPosition; } else { const position = {}; // scroll to anchor by returning the selector if (to.hash) { position.selector = to.hash; // specify offset of the element if (to.hash === "#anchor2") { position.offset = { y: 100 }; } if (document.querySelector(to.hash)) { return position; } // if the returned position is falsy or an empty object, // will retain current scroll position. return false; } // eslint-disable-next-line return new Promise((resolve) => { // check if any matched route config has meta that requires scrolling to top // eslint-disable-next-line if (to.matched.some((m) => m.meta.scrollToTop)) { // coords will be used if no selector is provided, // or if the selector didn't match any element. position.x = 0; position.y = 0; } // wait for the out transition to complete (if necessary) this.app.$root.$once("triggerScroll", () => { // if the resolved position is falsy or an empty object, // will retain current scroll position. resolve(position); }); }); } }; /** * https://router.vuejs.org/guide/advanced/lazy-loading.html#grouping-components-in-the-same-chunk * * */ export default new Router({ mode: "history", base: process.env.BASE_URL, scrollBehavior, routes: [ //########################## GENERAL / COMMON GROUP ################################### { path: "/open/:ayatype/:recordid", name: "ay-open", component: () => import(/* webpackChunkName: "ay-common" */ "./views/ay-open.vue") }, { path: "/about", name: "ay-about", // route level code-splitting // this generates a separate chunk (about.[hash].js) for this route // which is lazy-loaded when the route is visited. component: () => import(/* webpackChunkName: "ay-common" */ "./views/ay-about.vue") }, { path: "/applog", name: "ay-log", component: () => import(/* webpackChunkName: "ay-common" */ "./views/ay-log.vue") }, { path: "/customize/:formCustomTemplateKey", name: "ay-customize", component: () => import(/* webpackChunkName: "ay-common" */ "./views/ay-customize.vue") }, { path: "/data-list-column-view/:dataListKey", name: "ay-data-list-column-view", component: () => import( /* webpackChunkName: "ay-common" */ "./views/ay-data-list-column-view.vue" ) }, { path: "/history/:ayatype/:recordid/:userlog?", name: "ay-history", component: () => import(/* webpackChunkName: "ay-common" */ "./views/ay-history.vue") }, { path: "/login", name: "login", meta: { scrollToTop: true }, //KEEP THIS AS AN EXAMPLE OF HOW TO USE WITH CODE ABOVE component: () => import(/* webpackChunkName: "ay-common" */ "./views/login.vue") }, { path: "/home-dashboard", name: "home-dashboard", component: () => import(/* webpackChunkName: "ay-common" */ "./views/home-dashboard.vue") }, { path: "/home-search/:ayatype?", name: "home-search", component: () => import(/* webpackChunkName: "ay-common" */ "./views/home-search.vue") }, { path: "/", redirect: "/login" }, //If someone goes blindly to the root of the app, then it should go to login { path: "/home-schedule", name: "home-schedule", component: () => import(/* webpackChunkName: "ay-common" */ "./views/home-schedule.vue") }, { path: "/home-memos", name: "home-memos", component: () => import(/* webpackChunkName: "ay-common" */ "./views/home-memos.vue") }, { path: "/home-memos/:recordid", name: "memo-edit", component: () => import(/* webpackChunkName: "ay-common" */ "./views/home-memo.vue") }, { path: "/home-notifications", name: "home-notifications", component: () => import( /* webpackChunkName: "ay-common" */ "./views/home-notifications.vue" ) }, { path: "/home-notify-direct/:userIdList?", name: "home-notify-direct", component: () => import( /* webpackChunkName: "ay-common" */ "./views/home-notify-direct.vue" ) }, { path: "/home-reminders", name: "home-reminders", component: () => import(/* webpackChunkName: "ay-common" */ "./views/home-reminders.vue") }, { path: "/home-reminders/:recordid", name: "reminder-edit", component: () => import(/* webpackChunkName: "ay-common" */ "./views/home-reminder.vue") }, { path: "/home-reviews/:objectType?/:objectId?", name: "home-reviews", component: () => import(/* webpackChunkName: "ay-common" */ "./views/home-reviews.vue") }, { path: "/home-reviews/:recordid/:objectType?/:objectId?", name: "review-edit", component: () => import(/* webpackChunkName: "ay-common" */ "./views/home-review.vue") }, { path: "/home-user-settings", name: "home-user-settings", component: () => import( /* webpackChunkName: "ay-common" */ "./views/home-user-settings.vue" ) }, { path: "/home-reset", name: "home-reset", component: () => import(/* webpackChunkName: "ay-common" */ "./views/home-reset.vue") }, { path: "/home-password", name: "home-password", component: () => import(/* webpackChunkName: "ay-common" */ "./views/home-password.vue") }, { path: "/home-security", name: "home-security", component: () => import(/* webpackChunkName: "ay-common" */ "./views/home-security.vue") }, { path: "/home-notify-subscriptions", name: "home-notify-subscriptions", component: () => import( /* webpackChunkName: "ay-common" */ "./views/home-notify-subscriptions.vue" ) }, { path: "/home-notify-subscriptions/:recordid", name: "home-notify-subscription", component: () => import( /* webpackChunkName: "ay-common" */ "./views/home-notify-subscription.vue" ) }, //####################### CUSTOMERS GROUP ############################## { path: "/cust-customers", name: "cust-customers", component: () => import(/* webpackChunkName: "cust" */ "./views/cust-customers.vue") }, { path: "/cust-customers/:recordid", name: "customer-edit", component: () => import(/* webpackChunkName: "cust" */ "./views/cust-customer.vue") }, { path: "/cust-customer-notes/:customerid", name: "customer-notes", component: () => import(/* webpackChunkName: "cust" */ "./views/cust-customer-notes.vue") }, { path: "/cust-customer-note/:recordid", name: "customer-note-edit", component: () => import(/* webpackChunkName: "cust" */ "./views/cust-customer-note.vue") }, { path: "/cust-users", name: "cust-users", component: () => import(/* webpackChunkName: "cust" */ "./views/cust-users.vue") }, { path: "/cust-users/:recordid", name: "cust-user", component: () => import(/* webpackChunkName: "cust" */ "./views/cust-user.vue") }, { path: "/cust-head-offices", name: "cust-head-offices", component: () => import(/* webpackChunkName: "cust" */ "./views/cust-head-offices.vue") }, { path: "/cust-head-offices/:recordid", name: "head-office-edit", component: () => import(/* webpackChunkName: "cust" */ "./views/cust-head-office.vue") }, //####################### SERVICE GROUP ############################## { path: "/svc-schedule", name: "svc-schedule", component: () => import(/* webpackChunkName: "svc" */ "./views/svc-schedule.vue") }, { path: "/svc-workorders", name: "svc-workorders", component: () => import(/* webpackChunkName: "svc" */ "./views/svc-workorders.vue") }, { path: "/svc-workorder-templates", name: "svc-workorder-templates", component: () => import( /* webpackChunkName: "svc" */ "./views/svc-workorder-templates.vue" ) }, { path: "/svc-quotes", name: "svc-quotes", component: () => import(/* webpackChunkName: "svc" */ "./views/svc-quotes.vue") }, { path: "/svc-quote-templates", name: "svc-quote-templates", component: () => import(/* webpackChunkName: "svc" */ "./views/svc-quote-templates.vue") }, { path: "/svc-pm-list", name: "svc-pm-list", component: () => import(/* webpackChunkName: "svc" */ "./views/svc-pm-list.vue") }, { path: "/svc-pm-templates", name: "svc-pm-templates", component: () => import(/* webpackChunkName: "svc" */ "./views/svc-pm-templates.vue") }, { path: "/svc-units", name: "svc-units", component: () => import(/* webpackChunkName: "svc" */ "./views/svc-units.vue") }, { path: "/svc-units/:recordid", name: "unit-edit", component: () => import(/* webpackChunkName: "svc" */ "./views/svc-unit.vue") }, { path: "/svc-unit-models", name: "svc-unit-models", component: () => import(/* webpackChunkName: "svc" */ "./views/svc-unit-models.vue") }, { path: "/svc-unit-models/:recordid", name: "unit-model-edit", component: () => import(/* webpackChunkName: "svc" */ "./views/svc-unit-model.vue") }, { path: "/svc-loaners", name: "svc-loaners", component: () => import(/* webpackChunkName: "svc" */ "./views/svc-loaners.vue") }, { path: "/svc-loaners/:recordid", name: "loan-unit-edit", component: () => import(/* webpackChunkName: "svc" */ "./views/svc-loaner.vue") }, { path: "/svc-contracts", name: "svc-contracts", component: () => import(/* webpackChunkName: "svc" */ "./views/svc-contracts.vue") }, { path: "/svc-contracts/:recordid", name: "contract-edit", component: () => import(/* webpackChunkName: "svc" */ "./views/svc-contract.vue") }, { path: "/svc-projects", name: "svc-projects", component: () => import(/* webpackChunkName: "svc" */ "./views/svc-projects.vue") }, { path: "/svc-projects/:recordid", name: "project-edit", component: () => import(/* webpackChunkName: "svc" */ "./views/svc-project.vue") }, { path: "/svc-csr", name: "svc-csr", component: () => import(/* webpackChunkName: "svc" */ "./views/svc-csrs.vue") }, { path: "/svc-csr/:recordid", name: "csr-edit", component: () => import(/* webpackChunkName: "svc" */ "./views/svc-csr.vue") }, //######################### INVENTORY GROUP ############################## { path: "/inv-parts", name: "inv-parts", component: () => import(/* webpackChunkName: "inv" */ "./views/inv-parts.vue") }, { path: "/inv-parts/:recordid", name: "inv-part", component: () => import(/* webpackChunkName: "inv" */ "./views/inv-part.vue") }, { path: "/inv-part-warehouses", name: "inv-part-warehouses", component: () => import(/* webpackChunkName: "inv" */ "./views/inv-part-warehouses.vue") }, { path: "/inv-part-warehouses/:recordid", name: "inv-part-warehouse", component: () => import(/* webpackChunkName: "inv" */ "./views/inv-part-warehouse.vue") }, { path: "/inv-part-serials/:recordid", name: "inv-part-serials", component: () => import(/* webpackChunkName: "inv" */ "./views/inv-part-serials.vue") }, { path: "/inv-part-stock-levels/:recordid", name: "inv-part-stock-levels", component: () => import( /* webpackChunkName: "inv" */ "./views/inv-part-stock-levels.vue" ) }, { path: "/inv-part-assemblies", name: "inv-part-assemblies", component: () => import(/* webpackChunkName: "inv" */ "./views/inv-part-assemblies.vue") }, { path: "/inv-part-assemblies/:recordid", name: "part-assembly-edit", component: () => import(/* webpackChunkName: "inv" */ "./views/inv-part-assembly.vue") }, { path: "/inv-part-inventory", name: "inv-part-inventory", component: () => import(/* webpackChunkName: "inv" */ "./views/inv-part-inventory.vue") }, { path: "/inv-part-inventory-transactions", name: "inv-part-inventory-transactions", component: () => import( /* webpackChunkName: "inv" */ "./views/inv-part-inventory-transactions.vue" ) }, { path: "/inv-part-adjustment", name: "inv-part-adjustment", component: () => import(/* webpackChunkName: "inv" */ "./views/inv-part-adjustment.vue") }, // { // path: "/inv-part-requests", // name: "inv-part-requests", // component: () => // import(/* webpackChunkName: "inv" */ "./views/inv-part-requests.vue") // }, // { // path: "/inv-part-restocks", // name: "inv-part-restocks", // component: () => // import(/* webpackChunkName: "inv" */ "./views/inv-part-restocks.vue") // }, { path: "/inv-purchase-orders", name: "inv-purchase-orders", component: () => import(/* webpackChunkName: "inv" */ "./views/inv-purchase-orders.vue") }, { path: "/inv-purchase-orders/:recordid", name: "inv-purchase-order", component: () => import(/* webpackChunkName: "inv" */ "./views/inv-purchase-order.vue") }, //####################### VENDORS GROUP ############################## { path: "/vendors", name: "vendors", component: () => import(/* webpackChunkName: "vend" */ "./views/vendors.vue") }, { path: "/vendors/:recordid", name: "vendor-edit", component: () => import(/* webpackChunkName: "vend" */ "./views/vendor.vue") }, //###################### ACCOUNTING GROUP ########################## { path: "/acc-service-rates", name: "service-rates", component: () => import(/* webpackChunkName: "acc" */ "./views/acc-service-rates.vue") }, { path: "/acc-service-rates/:recordid", name: "service-rate-edit", component: () => import(/* webpackChunkName: "acc" */ "./views/acc-service-rate.vue") }, { path: "/acc-travel-rates", name: "travel-rates", component: () => import(/* webpackChunkName: "acc" */ "./views/acc-travel-rates.vue") }, { path: "/acc-travel-rates/:recordid", name: "travel-rate-edit", component: () => import(/* webpackChunkName: "acc" */ "./views/acc-travel-rate.vue") }, { path: "/acc-tax-codes", name: "tax-codes", component: () => import(/* webpackChunkName: "acc" */ "./views/acc-tax-codes.vue") }, { path: "/acc-tax-codes/:recordid", name: "tax-code-edit", component: () => import(/* webpackChunkName: "acc" */ "./views/acc-tax-code.vue") }, { path: "/acc-service-banks/:objectType?/:objectId?", name: "service-banks", component: () => import(/* webpackChunkName: "acc" */ "./views/acc-service-banks.vue") }, { path: "/acc-service-banks/:recordid/:objectType?/:objectId?", name: "service-bank-edit", component: () => import(/* webpackChunkName: "acc" */ "./views/acc-service-bank.vue") }, //######################### ADMINISTRATION GROUP ##################################### { path: "/adm-global-settings", name: "adm-global-settings", component: () => import(/* webpackChunkName: "adm" */ "./views/adm-global-settings.vue") }, { path: "/adm-global-select-templates", name: "adm-global-select-templates", component: () => import( /* webpackChunkName: "adm" */ "./views/adm-global-select-templates.vue" ) }, { path: "/adm-global-logo", name: "adm-global-logo", component: () => import(/* webpackChunkName: "adm" */ "./views/adm-global-logo.vue") }, { path: "/adm-license", name: "adm-license", component: () => import(/* webpackChunkName: "adm" */ "./views/adm-license.vue") }, { path: "/adm-users", name: "adm-users", component: () => import(/* webpackChunkName: "adm" */ "./views/adm-users.vue") }, { path: "/adm-users/:recordid", name: "adm-user", component: () => import(/* webpackChunkName: "adm" */ "./views/adm-user.vue") }, { path: "/adm-translations", name: "adm-translations", component: () => import(/* webpackChunkName: "adm" */ "./views/adm-translations.vue") }, { path: "/adm-translations/:recordid", name: "adm-translation", component: () => import(/* webpackChunkName: "adm" */ "./views/adm-translation.vue") }, { path: "/adm-report-templates", name: "adm-report-templates", component: () => import(/* webpackChunkName: "adm" */ "./views/adm-report-templates.vue") }, { path: "/report-edit/:recordid", //Route to edit a report template name: "ay-report-edit", component: () => import( //it gets it's own chunk name because it's huge and rarely used /* webpackChunkName: "ay-report-edit" */ "./views/ay-report-edit.vue" ) }, { path: "/adm-attachments", name: "adm-attachments", component: () => import(/* webpackChunkName: "adm" */ "./views/adm-attachments.vue") }, { path: "/adm-history", name: "adm-history", component: () => import(/* webpackChunkName: "adm" */ "./views/adm-history.vue") }, { path: "/adm-import", name: "adm-import", component: () => import(/* webpackChunkName: "adm" */ "./views/adm-import.vue") }, //########################## OPERATIONS GROUP ############################ { path: "/ops-backup", name: "ops-backup", component: () => import(/* webpackChunkName: "ops" */ "./views/ops-backup.vue") }, { path: "/ops-server-state", name: "ops-server-state", component: () => import(/* webpackChunkName: "ops" */ "./views/ops-server-state.vue") }, { path: "/ops-jobs", name: "ops-jobs", component: () => import(/* webpackChunkName: "ops" */ "./views/ops-jobs.vue") }, { path: "/ops-log", name: "ops-log", component: () => import(/* webpackChunkName: "ops" */ "./views/ops-log.vue") }, { path: "/ops-view-configuration", name: "ops-view-configuration", component: () => import( /* webpackChunkName: "ops" */ "./views/ops-view-configuration.vue" ) }, { path: "/ops-metrics", name: "ops-metrics", component: () => import(/* webpackChunkName: "ops" */ "./views/ops-metrics.vue") }, { path: "/ops-profile", name: "ops-profile", component: () => import(/* webpackChunkName: "ops" */ "./views/ops-profile.vue") }, { path: "/ops-notify-queue", name: "ops-notify-queue", component: () => import(/* webpackChunkName: "ops" */ "./views/ops-notify-queue.vue") }, { path: "/ops-notification-settings", name: "ops-notification-settings", component: () => import( /* webpackChunkName: "ops" */ "./views/ops-notification-settings.vue" ) }, //######################### CUSTOMER USER GROUP ###################################### { path: "/customer-workorders", name: "customer-workorders", component: () => import( /* webpackChunkName: "customer" */ "./views/customer-workorders.vue" ) }, { path: "/customer-csr-list", name: "customer-csr-list", component: () => import( /* webpackChunkName: "customer" */ "./views/customer-csr-list.vue" ) }, //############################## SPECIAL ROUTES ############################### { //REPORT VIEW FROM URL path: "/viewreport", beforeEnter: async (to, from, next) => { //open report links have a query string /viewreport?oid=[objectid]&rid=[reportid] let objectId = parseInt(to.query.oid); let reportId = parseInt(to.query.rid); let res = await window.$gz.api.renderReport(objectId, reportId, true); if (res.error) { //log the error and do a popup for it let msg = `/viewReport, query ${JSON.stringify( to.query )}, server error: ${JSON.stringify(res.error)}`; // window.$gz.store.commit("logItem", msg); window.$gz.eventBus.$emit("notify-error", msg); next("/applog"); } next(false); } }, //TEST TEST TEST TEST TEST { //NEW TEST GZ DATA TABLE path: "/widgets", name: "widget-list", component: () => import(/* webpackChunkName: "widget" */ "./views/widgets.vue") }, { //TEST WIDGET EDIT FORM path: "/widgets/:recordid", name: "widget-edit", component: () => import(/* webpackChunkName: "widget" */ "./views/widget.vue") }, { path: "/ay-evaluate", name: "ay-evaluate", component: () => import(/* webpackChunkName: "evaluate" */ "./views/ay-evaluate.vue") }, { //404 404 404 404 404 404 404 404 404 404 404 404 404 404 404 404 404 404 404 404 404 404 404 404 path: "*", name: "notfound", component: () => import(/* webpackChunkName: "ay-common" */ "./views/notfound.vue") } ] });