2022-12-11 21:44:52 +00:00
|
|
|
import type { KeepAliveProps, TransitionProps, UnwrapRef } from 'vue'
|
2023-05-03 14:14:12 +00:00
|
|
|
import { getCurrentInstance } from 'vue'
|
2023-05-09 17:08:07 +00:00
|
|
|
import type { RouteLocationNormalized, RouteLocationNormalizedLoaded, RouteRecordRedirectOption } from '#vue-router'
|
2023-05-03 14:14:12 +00:00
|
|
|
import { useRoute } from 'vue-router'
|
2023-08-23 20:38:17 +00:00
|
|
|
import type { NitroRouteConfig } from 'nitropack'
|
2023-11-22 22:40:02 +00:00
|
|
|
import type { NuxtError } from '#app'
|
2022-01-17 18:27:23 +00:00
|
|
|
|
|
|
|
export interface PageMeta {
|
2023-06-22 13:14:21 +00:00
|
|
|
[key: string]: unknown
|
2022-10-10 10:18:20 +00:00
|
|
|
/**
|
|
|
|
* Validate whether a given route can validly be rendered with this page.
|
|
|
|
*
|
|
|
|
* Return true if it is valid, or false if not. If another match can't be found,
|
|
|
|
* this will mean a 404. You can also directly return an object with
|
|
|
|
* statusCode/statusMessage to respond immediately with an error (other matches
|
|
|
|
* will not be checked).
|
|
|
|
*/
|
2023-07-25 16:09:41 +00:00
|
|
|
validate?: (route: RouteLocationNormalized) => boolean | Partial<NuxtError> | Promise<boolean | Partial<NuxtError>>
|
2022-09-22 13:54:34 +00:00
|
|
|
/**
|
|
|
|
* Where to redirect if the route is directly matched. The redirection happens
|
|
|
|
* before any navigation guard and triggers a new navigation with the new
|
|
|
|
* target location.
|
|
|
|
*/
|
|
|
|
redirect?: RouteRecordRedirectOption
|
|
|
|
/**
|
|
|
|
* Aliases for the record. Allows defining extra paths that will behave like a
|
|
|
|
* copy of the record. Allows having paths shorthands like `/users/:id` and
|
|
|
|
* `/u/:id`. All `alias` and `path` values must share the same params.
|
|
|
|
*/
|
|
|
|
alias?: string | string[]
|
2022-02-07 10:17:28 +00:00
|
|
|
pageTransition?: boolean | TransitionProps
|
|
|
|
layoutTransition?: boolean | TransitionProps
|
2022-02-07 11:32:04 +00:00
|
|
|
key?: false | string | ((route: RouteLocationNormalizedLoaded) => string)
|
2022-02-07 10:17:28 +00:00
|
|
|
keepalive?: boolean | KeepAliveProps
|
2022-11-03 14:05:38 +00:00
|
|
|
/** You may define a name for this page's route. */
|
|
|
|
name?: string
|
|
|
|
/** You may define a path matcher, if you have a more complex pattern than can be expressed with the file name. */
|
|
|
|
path?: string
|
2022-10-19 12:43:03 +00:00
|
|
|
/** Set to `false` to avoid scrolling to top on page navigations */
|
2023-07-30 10:07:01 +00:00
|
|
|
scrollToTop?: boolean | ((to: RouteLocationNormalizedLoaded, from: RouteLocationNormalizedLoaded) => boolean)
|
2022-01-17 18:27:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
declare module 'vue-router' {
|
2022-01-26 11:56:24 +00:00
|
|
|
interface RouteMeta extends UnwrapRef<PageMeta> {}
|
2022-01-17 18:27:23 +00:00
|
|
|
}
|
|
|
|
|
2023-09-19 21:26:15 +00:00
|
|
|
const warnRuntimeUsage = (method: string) => {
|
2022-01-17 18:27:23 +00:00
|
|
|
console.warn(
|
|
|
|
`${method}() is a compiler-hint helper that is only usable inside ` +
|
2022-11-14 10:28:31 +00:00
|
|
|
'the script block of a single file component which is also a page. Its arguments should be ' +
|
|
|
|
'compiled away and passing it at runtime has no effect.'
|
2022-01-17 18:27:23 +00:00
|
|
|
)
|
2023-09-19 21:26:15 +00:00
|
|
|
}
|
2022-01-17 18:27:23 +00:00
|
|
|
|
|
|
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
|
|
export const definePageMeta = (meta: PageMeta): void => {
|
2023-08-07 22:03:40 +00:00
|
|
|
if (import.meta.dev) {
|
2023-05-03 14:14:12 +00:00
|
|
|
const component = getCurrentInstance()?.type
|
|
|
|
try {
|
|
|
|
const isRouteComponent = component && useRoute().matched.some(p => Object.values(p.components || {}).includes(component))
|
|
|
|
if (isRouteComponent) {
|
|
|
|
// don't warn if it's being used in a route component
|
|
|
|
return
|
|
|
|
}
|
2023-11-09 17:01:13 +00:00
|
|
|
} catch {
|
|
|
|
// ignore any errors with accessing current instance or route
|
|
|
|
}
|
2022-01-17 18:27:23 +00:00
|
|
|
warnRuntimeUsage('definePageMeta')
|
|
|
|
}
|
|
|
|
}
|
2023-08-23 20:38:17 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* You can define route rules for the current page. Matching route rules will be created, based on the page's _path_.
|
|
|
|
*
|
|
|
|
* For example, a rule defined in `~/pages/foo/bar.vue` will be applied to `/foo/bar` requests. A rule in
|
|
|
|
* `~/pages/foo/[id].vue` will be applied to `/foo/**` requests.
|
|
|
|
*
|
|
|
|
* For more control, such as if you are using a custom `path` or `alias` set in the page's `definePageMeta`, you
|
|
|
|
* should set `routeRules` directly within your `nuxt.config`.
|
|
|
|
*/
|
2023-10-30 21:04:45 +00:00
|
|
|
/*! @__NO_SIDE_EFFECTS__ */
|
2023-08-23 20:38:17 +00:00
|
|
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
|
|
export const defineRouteRules = (rules: NitroRouteConfig): void => {}
|