Skip to content

Commit

Permalink
[ember__routing] Add types from Router Service RFC (DefinitelyTyped#3…
Browse files Browse the repository at this point in the history
…4199)

* [ember__routing] Add types from Router Service RFC

emberjs/rfcs#95

* [ember__routing] Add `RouteInfo` tests

Also includes tweaks to `RouteInfo` definition and docs
  • Loading branch information
tansongyang authored and alesn committed Apr 23, 2019
1 parent 0e8841d commit 510335d
Show file tree
Hide file tree
Showing 5 changed files with 118 additions and 2 deletions.
49 changes: 49 additions & 0 deletions types/ember__routing/-private/route-info.d.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
// https://api.emberjs.com/ember/3.6/classes/RouteInfo
/**
* A `RouteInfo` is an object that contains metadata about a specific route within a `Transition`.
* It is read-only and internally immutable.
* It is also not observable, because a `Transition` instance is never changed after creation.
*/
export default interface RouteInfo {
/**
* A reference to the childe route's `RouteInfo`.
* This can be used to traverse downward to the leafmost `RouteInfo`.
*/
readonly child: RouteInfo | null;
/**
* The final segment of the fully-qualified name of the route, like "index".
*/
readonly localName: string;
/**
* The dot-separated, fully-qualified name of the route, like "people.index".
*/
readonly name: string;
/**
* The ordered list of the names of the params required for this route.
* It will contain the same strings as `Object.keys(params)`, but here the order is significant.
* This allows users to correctly pass params into routes programmatically.
*/
readonly paramNames: string[];
/**
* The values of the route's parameters.
* These are the same params that are received as arguments to the route's `model` hook.
* Contains only the parameters valid for this route, if any (params for parent or child routes are not merged).
*/
readonly params: { [key: string]: string | undefined };
/**
* A reference to the parent route's `RouteInfo`.
* This can be used to traverse upward to the topmost `RouteInfo`.
*/
readonly parent: RouteInfo | null;
/**
* The values of any query params on this route.
*/
readonly queryParams: { [key: string]: string | undefined };
/**
* Allows you to traverse through the linked list of `RouteInfo`s from the topmost to leafmost.
* Returns the first `RouteInfo` in the linked list for which the callback returns true.
*
* @param callback the callback to execute.
*/
find(callback: (item: RouteInfo) => boolean): RouteInfo | undefined;
}
13 changes: 13 additions & 0 deletions types/ember__routing/-private/transition.d.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,17 @@
import RouteInfo from './route-info';

export default interface Transition {
/**
* This property is a `RouteInfo` object that represents where transition originated from.
* It's important to note that a `RouteInfo` is a linked list and this property is simply the head node of the list.
* In the case of an initial render, `from` will be set to `null`.
*/
readonly from: RouteInfo | null;
/**
* This property is a `RouteInfo` object that represents where the router is transitioning to.
* It's important to note that a `RouteInfo` is a linked list and this property is simply the leafmost route.
*/
readonly to: RouteInfo;
/**
* Aborts the Transition. Note you can also implicitly abort a transition
* by initiating another transition while a previous one is underway.
Expand Down
26 changes: 26 additions & 0 deletions types/ember__routing/router-service.d.ts
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
import RouteInfo from '@ember/routing/-private/route-info';
import Transition from '@ember/routing/-private/transition';
import Service from '@ember/service';

Expand All @@ -10,6 +11,12 @@ type RouteModel = object | string | number;
*/
export default class RouterService extends Service {
//
/**
* A `RouteInfo` that represents the current leaf route.
* It is guaranteed to change whenever a route transition happens
* (even when that transition only changes parameters and doesn't change the active route)
*/
readonly currentRoute: RouteInfo;
/**
* Name of the current route.
* This property represent the logical name of the route,
Expand Down Expand Up @@ -212,4 +219,23 @@ export default class RouterService extends Service {
modelsD: RouteModel,
options?: { queryParams: object }
): string;

// https://api.emberjs.com/ember/3.6/classes/RouterService/events/routeDidChange?anchor=routeDidChange
/**
* Register a callback for an event.
*
* The `routeWillChange` event is fired at the beginning of any attempted transition with a `Transition` object as the sole argument.
* This action can be used for aborting, redirecting, or decorating the transition from the currently active routes.
*
* The `routeDidChange` event only fires once a transition has settled.
* This includes aborts and error substates.
* Like the `routeWillChange` event it recieves a `Transition` as the sole argument.
*
* @param name the name of the event
* @param callback the callback to execute
*/
on(
name: 'routeDidChange' | 'routeWillChange',
callback: (transition: Transition) => void
): RouterService;
}
31 changes: 29 additions & 2 deletions types/ember__routing/test/router.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
import { assertType } from './lib/assert';
import Router from '@ember/routing/router';
import Service, { inject as service } from '@ember/service';
import EmberObject, { get } from '@ember/object';
Expand Down Expand Up @@ -52,5 +51,33 @@ const RouterServiceConsumer = Service.extend({
const model = EmberObject.create();
get(this, 'router')
.transitionTo('index', model, { queryParams: { search: 'ember' }});
}
},
onAndRouteInfo() {
const router = get(this, 'router');
router
.on('routeWillChange', transition => {
const to = transition.to;
to.child; // $ExpectType RouteInfo | null
to.localName; // $ExpectType string
to.name; // $ExpectType string
to.paramNames; // $ExpectType string[]
to.params.foo; // $ExpectType string | undefined
to.parent; // $ExpectType RouteInfo | null
to.queryParams.foo; // $ExpectType string | undefined
to.find(info => info.name === 'foo'); // $ExpectType RouteInfo | undefined
})
.on('routeDidChange', transition => {
const from = transition.from;
if (from) {
from.child; // $ExpectType RouteInfo | null
from.localName; // $ExpectType string
from.name; // $ExpectType string
from.paramNames; // $ExpectType string[]
from.params.foo; // $ExpectType string | undefined
from.parent; // $ExpectType RouteInfo | null
from.queryParams.foo; // $ExpectType string | undefined
from.find(info => info.name === 'foo'); // $ExpectType RouteInfo | undefined
}
});
},
});
1 change: 1 addition & 0 deletions types/ember__routing/tsconfig.json
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@
"router.d.ts",
"types.d.ts",
"-private/router-dsl.d.ts",
"-private/route-info.d.ts",
"-private/transition.d.ts",
"test/lib/assert.ts",
"test/route.ts",
Expand Down

0 comments on commit 510335d

Please sign in to comment.