Skip to content

Commit

Permalink
types: add RouteMeta interface to enable module augmentation (#3385)
Browse files Browse the repository at this point in the history
Co-authored-by: Eduardo San Martin Morote <posva@users.noreply.github.com>
  • Loading branch information
HoldYourWaffle and posva authored Jun 21, 2021
1 parent 306602d commit 260f737
Show file tree
Hide file tree
Showing 4 changed files with 56 additions and 6 deletions.
1 change: 1 addition & 0 deletions types/index.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ export default VueRouter

export {
RouterMode,
RouteMeta,
RawLocation,
RedirectOption,
RouterOptions,
Expand Down
8 changes: 5 additions & 3 deletions types/router.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -126,7 +126,7 @@ interface _RouteConfigBase {
children?: RouteConfig[]
redirect?: RedirectOption
alias?: string | string[]
meta?: any
meta?: RouteMeta
beforeEnter?: NavigationGuard
caseSensitive?: boolean
pathToRegexpOptions?: PathToRegexpOptions
Expand All @@ -153,7 +153,7 @@ export interface RouteRecord {
parent?: RouteRecord
redirect?: RedirectOption
matchAs?: string
meta: any
meta: RouteMeta
beforeEnter?: (
route: Route,
redirect: (location: RawLocation) => void,
Expand Down Expand Up @@ -205,5 +205,7 @@ export interface Route {
fullPath: string
matched: RouteRecord[]
redirectedFrom?: string
meta?: any
meta?: RouteMeta
}

export interface RouteMeta extends Record<string | number | symbol, any> {}
8 changes: 5 additions & 3 deletions types/test/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,9 @@ const Abc = { template: '<div>abc</div>' }
const Async = () => Promise.resolve({ template: '<div>async</div>' })

let err: any
if (VueRouter.isNavigationFailure(err, VueRouter.NavigationFailureType.aborted)) {
if (
VueRouter.isNavigationFailure(err, VueRouter.NavigationFailureType.aborted)
) {
err.from.fullPath.split('/')
}

Expand Down Expand Up @@ -104,7 +106,7 @@ const router = new VueRouter({
abc: Abc,
asyncComponent: Async
},
meta: { auth: true },
meta: { auth: true, nested: { foo: '' } },
beforeEnter(to, from, next) {
to.params
from.params
Expand Down Expand Up @@ -229,7 +231,7 @@ const Components: (
| AsyncComponent
)[] = router.getMatchedComponents()

const match: Route = router.match('/more');
const match: Route = router.match('/more')

const vm = new Vue({
router,
Expand Down
45 changes: 45 additions & 0 deletions types/test/meta.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
import VueRouter from '../index'

const component = { template: '<div>home</div>' }

declare module '../index' {
export interface RouteMeta {
requiresAuth?: boolean
nested: { foo: string }
}
}

const router = new VueRouter({
routes: [
{
path: '/',
component,
meta: {
requiresAuth: true,
// still allowed
other: true,
nested: {
foo: 'bar'
}
}
},
{
path: '/foo',
component,
// @ts-expect-error
meta: {}
}
]
})

router.beforeEach(to => {
// should pass
if (to.meta!.requiresAuth === true) {
}
// still pass because any
if (to.meta!.lol === true) {
}
// @ts-expect-error: nested will never be true
if (to.meta!.nested === true) {
}
})

0 comments on commit 260f737

Please sign in to comment.