feat(nuxt): custom history and routes for app/router.options.ts (#7129)

Co-authored-by: Pooya Parsa <pooya@pi0.io>
This commit is contained in:
Daniel Roe 2022-09-04 08:42:47 +01:00 committed by GitHub
parent 0180a33abc
commit 720506d263
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 55 additions and 14 deletions

View File

@ -327,19 +327,56 @@ Learn more about [`<NuxtLink>`](/api/components/nuxt-link) usage.
## Router Options ## Router Options
It is possible to set default [vue-router options](https://router.vuejs.org/api/interfaces/routeroptions.html). It is possible to cutomize [vue-router options](https://router.vuejs.org/api/interfaces/routeroptions.html).
**Note:** `history` and `routes` options will be always overridden by Nuxt.
### Using `app/router.options` ### Using `app/router.options`
This is the recommended way to specify router options. This is the recommended way to specify router options.
```js [app/router.options.ts] ```js [app/router.options.ts]
import type { RouterConfig } from '@nuxt/schema' import type { RouterOptions } from '@nuxt/schema'
// https://router.vuejs.org/api/interfaces/routeroptions.html // https://router.vuejs.org/api/interfaces/routeroptions.html
export default <RouterConfig>{ export default <RouterOptions> {
}
```
#### Custom Routes
:StabilityEdge{title="custom routes"}
You can optionally override routes using a function that accepts scanned routes and returns customized routes.
If returning `null` or `undefined`, Nuxt will fallback to the default routes. (useful to modify input array)
```js [app/router.options.ts]
import type { RouterOptions } from '@nuxt/schema'
// https://router.vuejs.org/api/interfaces/routeroptions.html
export default <RouterOptions> {
routes: (_routes) => [
{
name: 'home',
route: '/',
component: () => import('~/pages/home.vue')
}
],
}
```
#### Custom History (advanced)
:StabilityEdge{title="custom history"}
You can optionally override history mode using a function that accepts base url and returns history mode.
If returning `null` or `undefined`, Nuxt will fallback to the default history.
```js [app/router.options.ts]
import type { RouterOptions } from '@nuxt/schema'
import { createWebHashHistory } from 'vue-router'
// https://router.vuejs.org/api/interfaces/routeroptions.html
export default <RouterOptions> {
history: (base) => process.client ? createWebHashHistory(base) : null /* use default */
} }
``` ```

View File

@ -11,7 +11,7 @@ import { withoutBase, isEqual } from 'ufo'
import NuxtPage from './page' import NuxtPage from './page'
import { callWithNuxt, defineNuxtPlugin, useRuntimeConfig, showError, clearError, navigateTo, useError, useState } from '#app' import { callWithNuxt, defineNuxtPlugin, useRuntimeConfig, showError, clearError, navigateTo, useError, useState } from '#app'
// @ts-ignore // @ts-ignore
import routes from '#build/routes' import _routes from '#build/routes'
// @ts-ignore // @ts-ignore
import routerOptions from '#build/router.options' import routerOptions from '#build/router.options'
// @ts-ignore // @ts-ignore
@ -55,14 +55,16 @@ export default defineNuxtPlugin(async (nuxtApp) => {
nuxtApp.vueApp.component('NuxtChild', NuxtPage) nuxtApp.vueApp.component('NuxtChild', NuxtPage)
const baseURL = useRuntimeConfig().app.baseURL const baseURL = useRuntimeConfig().app.baseURL
const routerHistory = process.client
? createWebHistory(baseURL) const history = routerOptions.history?.(baseURL) ??
: createMemoryHistory(baseURL) (process.client ? createWebHistory(baseURL) : createMemoryHistory(baseURL))
const routes = routerOptions.routes?.(_routes) ?? _routes
const initialURL = process.server ? nuxtApp.ssrContext!.url : createCurrentLocation(baseURL, window.location) const initialURL = process.server ? nuxtApp.ssrContext!.url : createCurrentLocation(baseURL, window.location)
const router = createRouter({ const router = createRouter({
...routerOptions, ...routerOptions,
history: routerHistory, history,
routes routes
}) })
nuxtApp.vueApp.use(router) nuxtApp.vueApp.use(router)

View File

@ -1,10 +1,12 @@
import type { RouterOptions as _RouterOptions } from 'vue-router' import type { RouterOptions as _RouterOptions, RouterHistory } from 'vue-router'
export type RouterConfig = Partial<Omit<_RouterOptions, 'history' | 'routes'>> export type RouterOptions = Partial<Omit<_RouterOptions, 'history' | 'routes'>> & {
history?: (baseURL?: string) => RouterHistory
routes?: (_routes: _RouterOptions['routes']) => _RouterOptions['routes']
}
/** @deprecated Use RouterConfig instead */ export type RouterConfig = RouterOptions
export type RouterOptions = RouterConfig
/** /**
* Only JSON serializable router options are configurable from nuxt config * Only JSON serializable router options are configurable from nuxt config