dashboard/shell/config/router.js

448 lines
20 KiB
JavaScript

import Vue from 'vue';
import Router from 'vue-router';
import { normalizeURL } from 'ufo';
import { interopDefault } from '../utils/nuxt';
const emptyFn = () => {};
Vue.use(Router);
export const routerOptions = {
mode: 'history',
// Note: router base comes from the ROUTER_BASE env var
base: process.env.routerBase || '/',
routes: [
{
path: '/',
component: () => interopDefault(import('../components/templates/default.vue')),
children: [
{
path: '',
component: () => interopDefault(import('../pages/index.vue')),
name: 'index'
},
]
},
{
path: '/fail-whale',
component: () => interopDefault(import('../pages/fail-whale.vue')),
name: 'fail-whale'
},
{
path: '',
component: () => interopDefault(import('../components/templates/blank.vue')),
name: 'blank',
children: [
]
},
{
path: '',
component: () => interopDefault(import('../components/templates/home.vue')),
children: [
{
path: '/home',
component: () => interopDefault(import('../pages/home.vue')),
name: 'home'
},
{
path: '/support',
component: () => interopDefault(import('../pages/support/index.vue')),
name: 'support'
},
]
},
{
path: '',
component: () => interopDefault(import('../components/templates/plain.vue')),
name: 'plain',
children: [
{
path: '/about',
component: () => interopDefault(import('../pages/about.vue')),
name: 'about'
},
{
path: '/c/:cluster/uiplugins',
name: 'c-cluster-uiplugins',
component: () => interopDefault(import('../pages/c/_cluster/uiplugins/index.vue')),
},
{
path: '/diagnostic',
component: () => interopDefault(import('../pages/diagnostic.vue')),
name: 'diagnostic'
},
{
path: '/prefs',
component: () => interopDefault(import('../pages/prefs.vue')),
name: 'prefs'
},
{
path: '/account',
component: () => interopDefault(import('../pages/account/index.vue')),
name: 'account'
},
{
path: '/account/create-key',
component: () => interopDefault(import('../pages/account/create-key.vue')),
name: 'account-create-key'
},
{
path: 'auth',
component: () => interopDefault(import('../pages/c/_cluster/auth/index.vue')),
name: 'c-cluster-auth'
},
{
path: 'ecm',
component: () => interopDefault(import('../pages/c/_cluster/ecm/index.vue')),
name: 'c-cluster-ecm'
},
{
path: 'settings',
component: () => interopDefault(import('../pages/c/_cluster/settings/index.vue')),
name: 'c-cluster-settings'
}
]
},
{
path: '',
component: () => interopDefault(import('../components/templates/standalone.vue')),
name: 'standalone',
children: [
]
},
{
path: '',
component: () => interopDefault(import('../components/templates/unauthenticated.vue')),
name: 'unauthenticated',
children: [
{
path: '/auth/login',
component: () => interopDefault(import('../pages/auth/login.vue')),
name: 'auth-login',
},
{
path: '/auth/logout',
component: () => interopDefault(import('../pages/auth/logout.vue')),
name: 'auth-logout'
},
{
path: '/auth/setup',
component: () => interopDefault(import('../pages/auth/setup.vue')),
name: 'auth-setup'
}, {
path: '/auth/verify',
component: () => interopDefault(import('../pages/auth/verify.vue')),
name: 'auth-verify'
},
]
},
{
path: '',
component: () => interopDefault(import('../components/templates/default.vue')),
name: 'default',
children: [
{
path: '/clusters',
component: () => interopDefault(import('../pages/clusters/index.vue')),
name: 'clusters'
},
{
path: '/c/:cluster',
name: 'c-cluster',
component: () => interopDefault(import('../pages/c/_cluster/index.vue')),
},
{
path: '/c/:cluster/apps',
component: () => interopDefault(import('../pages/c/_cluster/apps/index.vue')),
name: 'c-cluster-apps'
},
{
path: '/c/:cluster/explorer',
component: () => interopDefault(import('../pages/c/_cluster/explorer/index.vue')),
name: 'c-cluster-explorer'
}, {
path: '/c/:cluster/backup',
component: () => interopDefault(import('../pages/c/_cluster/backup/index.vue')),
name: 'c-cluster-backup'
}, {
path: '/c/:cluster/cis',
component: () => interopDefault(import('../pages/c/_cluster/cis/index.vue')),
name: 'c-cluster-cis'
}, {
path: '/c/:cluster/fleet',
component: () => interopDefault(import('../pages/c/_cluster/fleet/index.vue')),
name: 'c-cluster-fleet'
}, {
path: '/c/:cluster/gatekeeper',
component: () => interopDefault(import('../pages/c/_cluster/gatekeeper/index.vue')),
name: 'c-cluster-gatekeeper'
}, {
path: '/c/:cluster/istio',
component: () => interopDefault(import('../pages/c/_cluster/istio/index.vue')),
name: 'c-cluster-istio'
}, {
path: '/c/:cluster/legacy',
component: () => interopDefault(import('../pages/c/_cluster/legacy/index.vue')),
name: 'c-cluster-legacy'
}, {
path: '/c/:cluster/logging',
component: () => interopDefault(import('../pages/c/_cluster/logging/index.vue')),
name: 'c-cluster-logging'
}, {
path: '/c/:cluster/longhorn',
component: () => interopDefault(import('../pages/c/_cluster/longhorn/index.vue')),
name: 'c-cluster-longhorn'
}, {
path: '/c/:cluster/manager',
component: () => interopDefault(import('../pages/c/_cluster/manager/index.vue')),
name: 'c-cluster-manager'
}, {
path: '/c/:cluster/mcapps',
component: () => interopDefault(import('../pages/c/_cluster/mcapps/index.vue')),
name: 'c-cluster-mcapps'
}, {
path: '/c/:cluster/monitoring',
component: () => interopDefault(import('../pages/c/_cluster/monitoring/index.vue')),
name: 'c-cluster-monitoring'
}, {
path: '/c/:cluster/neuvector',
component: () => interopDefault(import('../pages/c/_cluster/neuvector/index.vue')),
name: 'c-cluster-neuvector'
}, {
path: '/c/:cluster/apps/charts',
component: () => interopDefault(import('../pages/c/_cluster/apps/charts/index.vue')),
name: 'c-cluster-apps-charts'
},
{
path: '/c/:cluster/apps/charts/install',
component: () => interopDefault(import('../pages/c/_cluster/apps/charts/install.vue')),
name: 'c-cluster-apps-charts-install'
},
{
path: '/c/:cluster/auth/config',
component: () => interopDefault(import('../pages/c/_cluster/auth/config/index.vue')),
name: 'c-cluster-auth-config'
}, {
path: '/c/:cluster/auth/roles',
component: () => interopDefault(import('../pages/c/_cluster/auth/roles/index.vue')),
name: 'c-cluster-auth-roles'
}, {
path: '/c/:cluster/explorer/explorer-utils',
component: () => interopDefault(import('../pages/c/_cluster/explorer/explorer-utils.js')),
name: 'c-cluster-explorer-explorer-utils'
}, {
path: '/c/:cluster/explorer/tools',
component: () => interopDefault(import('../pages/c/_cluster/explorer/tools/index.vue')),
name: 'c-cluster-explorer-tools'
}, {
path: '/c/:cluster/gatekeeper/constraints',
component: () => interopDefault(import('../pages/c/_cluster/gatekeeper/constraints/index.vue')),
name: 'c-cluster-gatekeeper-constraints'
}, {
path: '/c/:cluster/legacy/project',
component: () => interopDefault(import('../pages/c/_cluster/legacy/project/index.vue')),
name: 'c-cluster-legacy-project'
}, {
path: '/c/:cluster/manager/cloudCredential',
component: () => interopDefault(import('../pages/c/_cluster/manager/cloudCredential/index.vue')),
name: 'c-cluster-manager-cloudCredential'
}, {
path: '/c/:cluster/manager/kontainerDriver',
component: () => interopDefault(import('../pages/c/_cluster/manager/drivers/kontainerDriver/index.vue')),
name: 'c-cluster-manager-driver-kontainerdriver'
}, {
path: '/c/:cluster/manager/nodeDriver',
component: () => interopDefault(import('../pages/c/_cluster/manager/drivers/nodeDriver/index.vue')),
name: 'c-cluster-manager-driver-nodedriver'
}, {
path: '/c/:cluster/monitoring/alertmanagerconfig',
component: () => interopDefault(import('../pages/c/_cluster/monitoring/alertmanagerconfig/index.vue')),
name: 'c-cluster-monitoring-alertmanagerconfig'
}, {
path: '/c/:cluster/monitoring/monitor',
component: () => interopDefault(import('../pages/c/_cluster/monitoring/monitor/index.vue')),
name: 'c-cluster-monitoring-monitor'
}, {
path: '/c/:cluster/monitoring/route-receiver',
component: () => interopDefault(import('../pages/c/_cluster/monitoring/route-receiver/index.vue')),
name: 'c-cluster-monitoring-route-receiver'
}, {
path: '/c/:cluster/settings/banners',
component: () => interopDefault(import('../pages/c/_cluster/settings/banners.vue')),
name: 'c-cluster-settings-banners'
}, {
path: '/c/:cluster/settings/brand',
component: () => interopDefault(import('../pages/c/_cluster/settings/brand.vue')),
name: 'c-cluster-settings-brand'
}, {
path: '/c/:cluster/settings/DefaultLinksEditor',
component: () => interopDefault(import('../pages/c/_cluster/settings/DefaultLinksEditor.vue')),
name: 'c-cluster-settings-DefaultLinksEditor'
}, {
path: '/c/:cluster/settings/links',
component: () => interopDefault(import('../pages/c/_cluster/settings/links.vue')),
name: 'c-cluster-settings-links'
}, {
path: '/c/:cluster/settings/performance',
component: () => interopDefault(import('../pages/c/_cluster/settings/performance.vue')),
name: 'c-cluster-settings-performance'
}, {
path: '/c/:cluster/apps/charts/chart',
component: () => interopDefault(import('../pages/c/_cluster/apps/charts/chart.vue')),
name: 'c-cluster-apps-charts-chart'
}, {
path: '/c/:cluster/auth/group.principal/assign-edit',
component: () => interopDefault(import('../pages/c/_cluster/auth/group.principal/assign-edit.vue')),
name: 'c-cluster-auth-group.principal-assign-edit'
}, {
path: '/c/:cluster/legacy/project/pipelines',
component: () => interopDefault(import('../pages/c/_cluster/legacy/project/pipelines.vue')),
name: 'c-cluster-legacy-project-pipelines'
}, {
path: '/c/:cluster/manager/cloudCredential/create',
component: () => interopDefault(import('../pages/c/_cluster/manager/cloudCredential/create.vue')),
name: 'c-cluster-manager-cloudCredential-create'
}, {
path: '/c/:cluster/manager/kontainerDriver/create',
component: () => interopDefault(import('../pages/c/_cluster/manager/drivers/kontainerDriver/create.vue')),
name: 'c-cluster-manager-driver-kontainerdriver-create'
}, {
path: '/c/:cluster/manager/nodeDriver/create',
component: () => interopDefault(import('../pages/c/_cluster/manager/drivers/nodeDriver/create.vue')),
name: 'c-cluster-manager-driver-nodedriver-create'
}, {
path: '/c/:cluster/monitoring/monitor/create',
component: () => interopDefault(import('../pages/c/_cluster/monitoring/monitor/create.vue')),
name: 'c-cluster-monitoring-monitor-create'
}, {
path: '/c/:cluster/monitoring/route-receiver/create',
component: () => interopDefault(import('../pages/c/_cluster/monitoring/route-receiver/create.vue')),
name: 'c-cluster-monitoring-route-receiver-create'
}, {
path: '/c/:cluster/explorer/tools/pages/:page?',
component: () => interopDefault(import('../pages/c/_cluster/explorer/tools/pages/_page.vue')),
name: 'c-cluster-explorer-tools-pages-page'
}, {
path: '/c/:cluster/auth/config/:id',
component: () => interopDefault(import('../pages/c/_cluster/auth/config/_id.vue')),
name: 'c-cluster-auth-config-id'
}, {
path: '/c/:cluster/legacy/pages/:page?',
component: () => interopDefault(import('../pages/c/_cluster/legacy/pages/_page.vue')),
name: 'c-cluster-legacy-pages-page'
}, {
path: '/c/:cluster/legacy/project/:page',
component: () => interopDefault(import('../pages/c/_cluster/legacy/project/_page.vue')),
name: 'c-cluster-legacy-project-page'
}, {
path: '/c/:cluster/manager/cloudCredential/:id',
component: () => interopDefault(import('../pages/c/_cluster/manager/cloudCredential/_id.vue')),
name: 'c-cluster-manager-cloudCredential-id'
}, {
path: '/c/:cluster/manager/kontainerDriver/:id',
component: () => interopDefault(import('../pages/c/_cluster/manager/drivers/kontainerDriver/_id.vue')),
name: 'c-cluster-manager-driver-kontainerdriver-id'
}, {
path: '/c/:cluster/manager/nodeDriver/:id',
component: () => interopDefault(import('../pages/c/_cluster/manager/drivers/nodeDriver/_id.vue')),
name: 'c-cluster-manager-driver-nodedriver-id'
}, {
path: '/c/:cluster/manager/pages/:page?',
component: () => interopDefault(import('../pages/c/_cluster/manager/pages/_page.vue')),
name: 'c-cluster-manager-pages-page'
}, {
path: '/c/:cluster/mcapps/pages/:page?',
component: () => interopDefault(import('../pages/c/_cluster/mcapps/pages/_page.vue')),
name: 'c-cluster-mcapps-pages-page'
}, {
path: '/c/:cluster/monitoring/alertmanagerconfig/:alertmanagerconfigid',
component: () => interopDefault(import('../pages/c/_cluster/monitoring/alertmanagerconfig/_alertmanagerconfigid/index.vue')),
name: 'c-cluster-monitoring-alertmanagerconfig-alertmanagerconfigid'
}, {
path: '/c/:cluster/monitoring/route-receiver/:id?',
component: () => interopDefault(import('../pages/c/_cluster/monitoring/route-receiver/_id.vue')),
name: 'c-cluster-monitoring-route-receiver-id'
}, {
path: '/c/:cluster/auth/roles/:resource/create',
component: () => interopDefault(import('../pages/c/_cluster/auth/roles/_resource/create.vue')),
name: 'c-cluster-auth-roles-resource-create'
}, {
path: '/c/:cluster/monitoring/alertmanagerconfig/:alertmanagerconfigid/receiver',
component: () => interopDefault(import('../pages/c/_cluster/monitoring/alertmanagerconfig/_alertmanagerconfigid/receiver.vue')),
name: 'c-cluster-monitoring-alertmanagerconfig-alertmanagerconfigid-receiver'
}, {
path: '/c/:cluster/auth/roles/:resource/:id?',
component: () => interopDefault(import('../pages/c/_cluster/auth/roles/_resource/_id.vue')),
name: 'c-cluster-auth-roles-resource-id'
}, {
path: '/c/:cluster/monitoring/monitor/:namespace/:id?',
component: () => interopDefault(import('../pages/c/_cluster/monitoring/monitor/_namespace/_id.vue')),
name: 'c-cluster-monitoring-monitor-namespace-id'
}, {
path: '/c/:cluster/navlinks/:group?',
component: () => interopDefault(import('../pages/c/_cluster/navlinks/_group.vue')),
name: 'c-cluster-navlinks-group'
}, {
path: '/c/:cluster/:product',
component: () => interopDefault(import('../pages/c/_cluster/_product/index.vue')),
name: 'c-cluster-product'
}, {
path: '/c/:cluster/:product/members',
component: () => interopDefault(import('../pages/c/_cluster/_product/members/index.vue')),
name: 'c-cluster-product-members'
}, {
path: '/c/:cluster/:product/namespaces',
component: () => interopDefault(import('../pages/c/_cluster/_product/namespaces.vue')),
name: 'c-cluster-product-namespaces'
}, {
path: '/c/:cluster/:product/projectsnamespaces',
component: () => interopDefault(import('../pages/c/_cluster/_product/projectsnamespaces.vue')),
name: 'c-cluster-product-projectsnamespaces'
}, {
path: '/c/:cluster/:product/:resource',
component: () => interopDefault(import('../pages/c/_cluster/_product/_resource/index.vue')),
name: 'c-cluster-product-resource'
}, {
path: '/c/:cluster/:product/:resource/create',
component: () => interopDefault(import('../pages/c/_cluster/_product/_resource/create.vue')),
name: 'c-cluster-product-resource-create'
}, {
path: '/c/:cluster/:product/:resource/:id',
component: () => interopDefault(import('../pages/c/_cluster/_product/_resource/_id.vue')),
name: 'c-cluster-product-resource-id'
}, {
path: '/c/:cluster/:product/:resource/:namespace/:id?',
component: () => interopDefault(import('../pages/c/_cluster/_product/_resource/_namespace/_id.vue')),
name: 'c-cluster-product-resource-namespace-id'
}]
}],
fallback: false
};
export function createRouter(config) {
const base = (config._app && config._app.basePath) || routerOptions.base;
const router = new Router({ ...routerOptions, base });
// TODO: remove in Nuxt 3
const originalPush = router.push;
router.push = function push(location, onComplete = emptyFn, onAbort) {
return originalPush.call(this, location, onComplete, onAbort);
};
const resolve = router.resolve.bind(router);
router.resolve = (to, current, append) => {
if (typeof to === 'string') {
to = normalizeURL(to);
}
return resolve(to, current, append);
};
return router;
}