UNPKG

@uirouter/core

Version:

UI-Router Core: Framework agnostic, State-based routing for JavaScript Single Page Apps

1,145 lines (692 loc) 110 kB
# 6.1.0 (2023-03-11) [Compare `@uirouter/core` versions 6.0.9 and 6.1.0](https://github.com/ui-router/core/compare/6.0.9...6.1.0) ### Bug Fixes * **angular-compiler:** remove index.metadata.json from uirouter core, ([37b5ebe](https://github.com/ui-router/core/commit/37b5ebe)) ## 6.0.9 (2023-01-12) [Compare `@uirouter/core` versions 6.0.8 and 6.0.9](https://github.com/ui-router/core/compare/6.0.8...6.0.9) ### Bug Fixes * **stateService:** make sure `$state.href` (and by extension `uiSref`) handle state Params `inherit: false` ([#834](https://github.com/ui-router/core/issues/834)) ([12cd951](https://github.com/ui-router/core/commit/12cd951)) ## 6.0.8 (2021-07-13) [Compare `@uirouter/core` versions 6.0.7 and 6.0.8](https://github.com/ui-router/core/compare/6.0.7...6.0.8) ### Fixes * fix circular dependency with rejectFactory (#801) ## 6.0.7 (2020-12-21) [Compare `@uirouter/core` versions 6.0.6 and 6.0.7](https://github.com/ui-router/core/compare/6.0.6...6.0.7) ### Bug Fixes * **array:** Fix decoding of array-type query parameters ([44ebfae](https://github.com/ui-router/core/commit/44ebfae)) ## 6.0.6 (2020-07-17) [Compare `@uirouter/core` versions 6.0.5 and 6.0.6](https://github.com/ui-router/core/compare/6.0.5...6.0.6) ### Bug Fixes * **params:** Bi-directionally en/decode path and search params. Fixes https://github.com/ui-router/angular/issues/340 ([#618](https://github.com/ui-router/core/issues/618)) ([89e99cd](https://github.com/ui-router/core/commit/89e99cd)) ## 6.0.5 (2020-04-29) [Compare `@uirouter/core` versions 6.0.4 and 6.0.5](https://github.com/ui-router/core/compare/6.0.4...6.0.5) ### Bug Fixes * **TargetState:** make isDef check more thorough ([e657cfe](https://github.com/ui-router/core/commit/e657cfe)) ### Features * **urlRuleFactory:** Add support for StateDeclarations in UrlRuleFactory.fromState() ([539d33a](https://github.com/ui-router/core/commit/539d33a)) ## 6.0.4 (2020-01-06) [Compare `@uirouter/core` versions 6.0.3 and 6.0.4](https://github.com/ui-router/core/compare/6.0.3...6.0.4) ### Bug Fixes * **safeConsole:** check if document is defined to avoid issues in node environments ([da29d88](https://github.com/ui-router/core/commit/da29d88)) ## 6.0.3 (2019-12-30) [Compare `@uirouter/core` versions 6.0.2 and 6.0.3](https://github.com/ui-router/core/compare/6.0.2...6.0.3) No code changes. Re-publishing because 6.0.2 was built with the wrong versin of typescript. ## 6.0.2 (2019-12-29) [Compare `@uirouter/core` versions 6.0.1 and 6.0.2](https://github.com/ui-router/core/compare/6.0.1...6.0.2) ### Bug Fixes * **hof:** Rewrite curry from scratch ([fc324c6](https://github.com/ui-router/core/commit/fc324c6)), closes [#350](https://github.com/ui-router/core/issues/350) * **IE9:** Add safeConsole so IE9 doesn't break ([9c8579d](https://github.com/ui-router/core/commit/9c8579d)) ### Features * **stateService:** add transition option 'supercede' so transition can be ignored if one is pending ([6e5a56f](https://github.com/ui-router/core/commit/6e5a56f)) ## 6.0.1 (2019-09-27) [Compare `@uirouter/core` versions 6.0.0 and 6.0.1](https://github.com/ui-router/core/compare/6.0.0...6.0.1) ### Bug Fixes * **resolve:** remove unnecessary generics from CustomAsyncPolicy ([#452](https://github.com/ui-router/core/issues/452)) ([61f4ee9](https://github.com/ui-router/core/commit/61f4ee9)) # 6.0.0 (2019-09-26) [Compare `@uirouter/core` versions 5.0.23 and 6.0.0](https://github.com/ui-router/core/compare/5.0.23...6.0.0) ### Bug Fixes * **travis:** use service: xvfb instead of launching it manually ([1271fcd](https://github.com/ui-router/core/commit/1271fcd)) * **travis:** use service: xvfb instead of launching it manually. install libgconf debian package ([ac1ef4b](https://github.com/ui-router/core/commit/ac1ef4b)) ### Features * **resolve:** Remove RXWAIT async policy in favour of allowing user defined async policy function ([#366](https://github.com/ui-router/core/issues/366)) ([0ad87f6](https://github.com/ui-router/core/commit/0ad87f6)) ### BREAKING CHANGES * **resolve:** RXWAIT async policy has been removed, but it never worked in the first place ## 5.0.23 (2019-01-28) [Compare `@uirouter/core` versions 5.0.22 and 5.0.23](https://github.com/ui-router/core/compare/5.0.22...5.0.23) ### Bug Fixes * **test_downstream_projects:** don't double build core while testing downstreams ([148b16b](https://github.com/ui-router/core/commit/148b16b)) * **typescript:** Fix typing of onChange callback in UrlService ([961ed0f](https://github.com/ui-router/core/commit/961ed0f)), closes [#229](https://github.com/ui-router/core/issues/229) * **typescript:** Mark `params` as optional in StateService.href ([614bfb4](https://github.com/ui-router/core/commit/614bfb4)), closes [#287](https://github.com/ui-router/core/issues/287) * **vanilla:** Fix baseHref parsing with chrome-extension:// urls ([f11be4d](https://github.com/ui-router/core/commit/f11be4d)), closes [#304](https://github.com/ui-router/core/issues/304) ## 5.0.22 (2019-01-10) [Compare `@uirouter/core` versions 5.0.21 and 5.0.22](https://github.com/ui-router/core/compare/5.0.21...5.0.22) ### Bug Fixes * **lazyLoad:** StateBuilder should not mutate the state declaration ([1478a3c](https://github.com/ui-router/core/commit/1478a3c)), closes [/github.com/ui-router/core/commit/3cd5a2a#r31260154](https://github.com//github.com/ui-router/core/commit/3cd5a2a/issues/r31260154) * **state:** Update URL in response to ignored transition due to redirect ([c64c252](https://github.com/ui-router/core/commit/c64c252)) ### Features * **TransitionHook:** Pass in transition to HookMatchCriteria ([#255](https://github.com/ui-router/core/issues/255)) ([926705e](https://github.com/ui-router/core/commit/926705e)) ## 5.0.21 (2018-08-11) [Compare `@uirouter/core` versions 5.0.20 and 5.0.21](https://github.com/ui-router/core/compare/5.0.20...5.0.21) ### Bug Fixes * **dynamic:** Use 'find' from common.ts instead of Array.prototype.find ([66a3244](https://github.com/ui-router/core/commit/66a3244)), closes [#215](https://github.com/ui-router/core/issues/215) * **url:** When using html5Mode and no <base> tag is present, default to '/' ([23742e3](https://github.com/ui-router/core/commit/23742e3)), closes [#223](https://github.com/ui-router/core/issues/223) ## 5.0.20 (2018-07-20) [Compare `@uirouter/core` versions 5.0.19 and 5.0.20](https://github.com/ui-router/core/compare/5.0.19...5.0.20) ### Bug Fixes * **params:** When creating an array parameter from a custom type, copy the `raw` property ([b6dd738](https://github.com/ui-router/core/commit/b6dd738)), closes [#178](https://github.com/ui-router/core/issues/178) ### Features * **dynamic:** Support dynamic flag on a state declaration ([3cd5a2a](https://github.com/ui-router/core/commit/3cd5a2a)) * **transition:** Added transition.paramsChanged() to get added/deleted/changed parameter values for a transition ([10b7fde](https://github.com/ui-router/core/commit/10b7fde)) * **view:** Add _pluginapi._registeredUIView() to get a ui-view by id ([6533b51](https://github.com/ui-router/core/commit/6533b51)) ## 5.0.19 (2018-05-08) [Compare `@uirouter/core` versions 5.0.18 and 5.0.19](https://github.com/ui-router/core/compare/5.0.18...5.0.19) ### Bug Fixes * **enums:** Workaround angular compiler export issue https://github.com/angular/angular/issues/23759 ([38d25fa](https://github.com/ui-router/core/commit/38d25fa)) ## 5.0.18 (2018-04-29) [Compare `@uirouter/core` versions 5.0.17 and 5.0.18](https://github.com/ui-router/core/compare/5.0.17...5.0.18) ### Bug Fixes * **angular:** A hack to force the Angular compiler to import from module index ([d56a2be](https://github.com/ui-router/core/commit/d56a2be)) * **StateRegistry:** Notify listeners of added states when there are orphans in the state queue ([5a9bac9](https://github.com/ui-router/core/commit/5a9bac9)) * **transition:** Fix typing of Transition.params() ([ebea30e](https://github.com/ui-router/core/commit/ebea30e)) * **transition:** Normalize `error()` to always return `Rejection` ([9bcc5db](https://github.com/ui-router/core/commit/9bcc5db)) ## 5.0.17 (2018-02-12) [Compare `@uirouter/core` versions 5.0.16 and 5.0.17](https://github.com/ui-router/core/compare/5.0.16...5.0.17) ### Bug Fixes * **core:** Fix leak of old transitions by mutating pathnode*.resolvables*.data ([0a1f518](https://github.com/ui-router/core/commit/0a1f518)) ## 5.0.16 (2018-01-30) [Compare `@uirouter/core` versions 5.0.15 and 5.0.16](https://github.com/ui-router/core/compare/5.0.15...5.0.16) ### Bug Fixes * **common:** Fix signature of for objects (make target optional) ([61d0afc](https://github.com/ui-router/core/commit/61d0afc)) ## 5.0.15 (2018-01-28) [Compare `@uirouter/core` versions 5.0.14 and 5.0.15](https://github.com/ui-router/core/compare/5.0.14...5.0.15) ### Bug Fixes * **core:** Fix memory leak of resolve data from ALL transitions ever ([7f2aed1](https://github.com/ui-router/core/commit/7f2aed1)) * **pathNode:** add backwards compat for PathNode.clone(). Add retainedWithToParams to treeChanges interface. ([4833a32](https://github.com/ui-router/core/commit/4833a32)) ### Features * **common:** Add map-in-place support to map() ([12bc7d8](https://github.com/ui-router/core/commit/12bc7d8)) * **common:** Add onEvict() callback registry for queues with max length ([c19d007](https://github.com/ui-router/core/commit/c19d007)) ## 5.0.14 (2018-01-10) [Compare `@uirouter/core` versions 5.0.13 and 5.0.14](https://github.com/ui-router/core/compare/5.0.13...5.0.14) ### Bug Fixes * **trace:** Fix null reference in uiview name sort function ([59cb067](https://github.com/ui-router/core/commit/59cb067)) * **treeChanges:** apply toParams to 'retained' path ([#72](https://github.com/ui-router/core/issues/72)) ([cf63d11](https://github.com/ui-router/core/commit/cf63d11)) ## 5.0.13 (2017-12-22) [Compare `@uirouter/core` versions 5.0.12 and 5.0.13](https://github.com/ui-router/core/compare/5.0.12...5.0.13) ### Bug Fixes * **browserLocation:** Use location.pathname (not href) or '/' when no base tag found ([db461d6](https://github.com/ui-router/core/commit/db461d6)) * **browserLocationConfig:** If no base href found, use location.href (not empty string) ([0251424](https://github.com/ui-router/core/commit/0251424)) * **pushStateLocation:** Fix URLs: add slash between base and path when necessary ([bfa5755](https://github.com/ui-router/core/commit/bfa5755)) * **pushStateLocation:** When url is "" or "/", use baseHref for pushState ([042a950](https://github.com/ui-router/core/commit/042a950)) * **resolve:** Add onFinish hook to resolve any dynamicly added resolvables ([7d1ca54](https://github.com/ui-router/core/commit/7d1ca54)) ### Features * **view:** Add onSync callback API to plugin API ([9544ae5](https://github.com/ui-router/core/commit/9544ae5)) ## 5.0.12 (2017-12-18) [Compare `@uirouter/core` versions 5.0.11 and 5.0.12](https://github.com/ui-router/core/compare/5.0.11...5.0.12) ### Bug Fixes * **urlRouter:** Update query params when resetting url via .update() ([7664cd0](https://github.com/ui-router/core/commit/7664cd0)) ## 5.0.11 (2017-10-14) [Compare `@uirouter/core` versions 5.0.10 and 5.0.11](https://github.com/ui-router/core/compare/5.0.10...5.0.11) ### Bug Fixes * **ie9:** make console.bind work in ie9 ([#85](https://github.com/ui-router/core/issues/85)) ([318214b](https://github.com/ui-router/core/commit/318214b)) ## 5.0.10 (2017-10-06) [Compare `@uirouter/core` versions 5.0.9 and 5.0.10](https://github.com/ui-router/core/compare/5.0.9...5.0.10) ### Bug Fixes * **angular/cli:** Use package.json fields: 'typings', 'main', 'jsnext:main' ([74143d9](https://github.com/ui-router/core/commit/74143d9)) * **isomorphic:** Remove use of CustomEvent. Detect root scope (global/window/self) for nodejs, browser, or web-worker. ([2d206ba](https://github.com/ui-router/core/commit/2d206ba)) * **typings:** Use StateObject for parameter to hook criteria functions ([5b58566](https://github.com/ui-router/core/commit/5b58566)) ## 5.0.9 (2017-10-02) [Compare `@uirouter/core` versions 5.0.8 and 5.0.9](https://github.com/ui-router/core/compare/5.0.8...5.0.9) ### Bug Fixes * **redirectTo:** Allow void in RedirectToResult ### Features * **TransitionHook:** Add hook registration option `invokeLimit` to limit the number of times a hook is invoked before being auto-deregistered. ([2cb17ef](https://github.com/ui-router/core/commit/2cb17ef)) ## 5.0.8 (2017-09-30) [Compare `@uirouter/core` versions 5.0.7 and 5.0.8](https://github.com/ui-router/core/compare/5.0.7...5.0.8) ### Bug Fixes * **bundle:** Rollup: Do not warn on THIS_IS_UNDEFINED ([a4581b1](https://github.com/ui-router/core/commit/a4581b1)) * **redirectTo:** Fix typings for redirectTo. Allow a function that returns a target state or a promise for one. ([3904487](https://github.com/ui-router/core/commit/3904487)) ### Features * **TargetState:** Add builder methods .withState, .withParams, and .withOptions ([6b93142](https://github.com/ui-router/core/commit/6b93142)) ## 5.0.7 (2017-09-23) [Compare `@uirouter/core` versions 5.0.6 and 5.0.7](https://github.com/ui-router/core/compare/5.0.6...5.0.7) ### Bug Fixes * **globals:** Use shallow copy to update the globals.params / $state.params object ([e883afc](https://github.com/ui-router/core/commit/e883afc)) * **Injector:** When getting tokens from native injector, only throw on undefined (not on falsey values) ([ada9ca2](https://github.com/ui-router/core/commit/ada9ca2)) * **trace:** Fall back to console.log if .table is unavailable (IE) ([c8110fc](https://github.com/ui-router/core/commit/c8110fc)) * **trace:** Support tracing of object-parameters with circular references ([2f1ae9a](https://github.com/ui-router/core/commit/2f1ae9a)) * **url:** Add CustomEvent polyfill for IE ([a50db21](https://github.com/ui-router/core/commit/a50db21)) * **vanilla:** fix base path handling for vanilla push state ([ad61d74](https://github.com/ui-router/core/commit/ad61d74)) * **vanilla:** Use `self` instead of `window` for webworker compat ([a4629ee](https://github.com/ui-router/core/commit/a4629ee)) ## Changes in `@uirouter/core` between versions [5.0.5 and 5.0.6](https://github.com/ui-router/core/compare/5.0.5...5.0.6) (2017-08-12) ### Bug Fixes * **sourceMaps:** Embed typescript sources in sourcemaps ([10558a3](https://github.com/ui-router/core/commit/10558a3)) * **typescript:** Fix strictNullCheck type error ([0ae585e](https://github.com/ui-router/core/commit/0ae585e)) * **urlRouter:** Fix absolute 'href' generation by using location.hostname (not location.host) ([a28b68a](https://github.com/ui-router/core/commit/a28b68a)) * **urlService:** Fix priority sorting of URL rules ([73a1fe0](https://github.com/ui-router/core/commit/73a1fe0)) ## Changes in `@uirouter/core` between versions [5.0.4 and 5.0.5](https://github.com/ui-router/core/compare/5.0.4...5.0.5) (2017-06-29) ### Bug Fixes * **typescript:** Update to typescript 2.4 ([ce1669b](https://github.com/ui-router/core/commit/ce1669b)) ### Features * **urlMatcher:** add support for multiline urls ([5b11ce0](https://github.com/ui-router/core/commit/5b11ce0)) ### @uirouter/core changes ## [5.0.4](https://github.com/ui-router/core/compare/5.0.3...5.0.4) (2017-06-06) ### Bug Fixes * **future:** Allow future states to specify a `parent:` ([de68fe1](https://github.com/ui-router/core/commit/de68fe1)) * **view:** only sync views which are of the same name *and type* ([49b5594](https://github.com/ui-router/core/commit/49b5594)) ### Features * **invalidTransition:** Better error messaging when param values are invalid ([fd45f44](https://github.com/ui-router/core/commit/fd45f44)) * **trace:** Trace view synchronization. Allow trace.enable(...string) ([29503a0](https://github.com/ui-router/core/commit/29503a0)) ### @uirouter/core changes ## [5.0.3](https://github.com/ui-router/core/compare/5.0.2...5.0.3) (2017-05-07) ### Bug Fixes * **common:** Re-fix implementation of 'pick' using for .. in ([f2da7f4](https://github.com/ui-router/core/commit/f2da7f4)) ### @uirouter/core changes ## [5.0.2](https://github.com/ui-router/core/compare/5.0.1...5.0.2) (2017-05-06) ### Bug Fixes * **common:** Fix implementation of 'pick' -- use hasOwnProperty ([09848a4](https://github.com/ui-router/core/commit/09848a4)) ### Features * **build:** Build and distribute UMD bundles ([0a8da85](https://github.com/ui-router/core/commit/0a8da85)) ### @uirouter/core changes ## [5.0.1](https://github.com/ui-router/core/compare/5.0.0...5.0.1) (2017-05-03) ### Bug Fixes * **transition:** Do not ignore transitions which have states being entered or exited ([175717e](https://github.com/ui-router/core/commit/175717e)) ### @uirouter/core changes # [5.0.0](https://github.com/ui-router/core/compare/4.0.0...v5.0.0) (2017-04-21) ### Bug Fixes * **BrowserLocationConfig:** fixed protocol + port value ([#38](https://github.com/ui-router/core/issues/38)) ([5559382](https://github.com/ui-router/core/commit/5559382)) * **lazyLoad:** Wait for future state to be replaced before registering lazy children ([4bdce47](https://github.com/ui-router/core/commit/4bdce47)) * **noImplicitAny:** Fix noimplicitany compliance ([1a6cdfc](https://github.com/ui-router/core/commit/1a6cdfc)) * **redirect:** Do not update URL after redirect with { location: false } ([652a760](https://github.com/ui-router/core/commit/652a760)) * **tfs:** Rename $q.ts and $injector.ts files, removing leading dollar signs ([cb653ee](https://github.com/ui-router/core/commit/cb653ee)) * **trace:** Re-add transitionStart trace ([b019036](https://github.com/ui-router/core/commit/b019036)) * **transitionHook:** Do not process transition hooks after router has been disposed. ([666c6d7](https://github.com/ui-router/core/commit/666c6d7)) * **TransitionHook:** Transition hooks no longer expose the internal StateObject ([2b0e48b](https://github.com/ui-router/core/commit/2b0e48b)) * **typings:** Allow strictNullChecks for HookMatchCriteria ([d92d4d5](https://github.com/ui-router/core/commit/d92d4d5)) * **ui-sref:** Improve performance of generating hrefs ([c3967bd](https://github.com/ui-router/core/commit/c3967bd)) * **view:** Do not throw when uiView doesn't have a state context ([f76ee2a](https://github.com/ui-router/core/commit/f76ee2a)) * **view:** Update views in order of ui-view depth and also by state depth ([46dea2b](https://github.com/ui-router/core/commit/46dea2b)) ### Features * **abort:** Add API to manually abort/cancel a transition ([39f8a53](https://github.com/ui-router/core/commit/39f8a53)) * **common:** Perf improvements in hot functions: ([4193244](https://github.com/ui-router/core/commit/4193244)) * **core:** Switch to [@uirouter](https://github.com/uirouter)/core npm module ([e3f389f](https://github.com/ui-router/core/commit/e3f389f)) * **decorators:** Add state, resolve and resolve data decorators ([642df0b](https://github.com/ui-router/core/commit/642df0b)) * **defaultErrorHandler:** Do not invoke default error handler for ABORTED transitions ([b07a24b](https://github.com/ui-router/core/commit/b07a24b)) * **Globals:** implement Disposable and delete global transition data ([a794018](https://github.com/ui-router/core/commit/a794018)) * **onBefore:** Run onBefore hooks asynchronously. ([30b82aa](https://github.com/ui-router/core/commit/30b82aa)) * **onEnter/Exit/Retain:** Use onExit/onEnter/onRetain from 56955state(), not state.self ([bc1f554](https://github.com/ui-router/core/commit/bc1f554)) * **Rejection:** Add $id to ease debugging of transition rejections ([d456d54](https://github.com/ui-router/core/commit/d456d54)) * **State:** Support registration of ES6 state classes (as opposed to object literals) ([3a5d055](https://github.com/ui-router/core/commit/3a5d055)) * **State:** Switch Internal State Object to prototypally inherit from the State Declaration ([027c995](https://github.com/ui-router/core/commit/027c995)), closes [#34](https://github.com/ui-router/core/issues/34) * **StateObject:** Rename internal `State` object to `StateObject` ([feceaf9](https://github.com/ui-router/core/commit/feceaf9)) * **StateRegistry:** improve perf for: `.register()` and `StateMatcher.find()` misses ([fdb3ab9](https://github.com/ui-router/core/commit/fdb3ab9)) * **transition:** Ignore duplicate transitions (double clicks) ([bd1bd0b](https://github.com/ui-router/core/commit/bd1bd0b)) * **transition:** Improve supersede logic: Do not supersede if the new trans is aborted before onStart ([3141a8f](https://github.com/ui-router/core/commit/3141a8f)) * **transition:** Run hooks synchronously in current stack, when possible ([953e618](https://github.com/ui-router/core/commit/953e618)) * **Transition:** deprecate `Transition.is()` which was never implemented ([1edff4b](https://github.com/ui-router/core/commit/1edff4b)) * **Transition:** Normalize all transition errors to a Rejection. ([a7464bb](https://github.com/ui-router/core/commit/a7464bb)) * **UrlService:** (`UrlRouter`) improve perf of registering Url Rules and sorting Url Rules ([64fbfff](https://github.com/ui-router/core/commit/64fbfff)) * **UrlService:** Add `rules.initial("/home")` to config initial state (like otherwise) ([bbe4209](https://github.com/ui-router/core/commit/bbe4209)) ### BREAKING CHANGES ## **TransitionHook:** Transition hooks no longer expose the internal `State` object (now named `StateObject`) #### Before: ```js import { State } from "@uirouter/core"; const match = { to: (state: State) => state.data.auth }; transitionsvc.onEnter(match, (trans: Transition, state: State) => { // state is the internal State object if (state.includes["foo"]) { // internal ui-router API return false; } } ``` #### Now: ```js import { StateDeclaration } from "@uirouter/core"; const match = { to: (state: StateDeclaration) => state.data.auth }; transitionsvc.onEnter(match, (trans: Transition, state: StateDeclaration) => { // state === the state object you registered // Access internal ui-router API using $$state() if (state.$$state().includes["foo"]) { return false; } } ``` #### Motivation: The `State` object (now named `StateObject`) is an internal API and should not be exposed via any public APIs. If you depend on the internal APIs, you can still access the internal object by calling `state.$$state()`. #### BC Likelihood How likely is this BC to affect me? Medium: You will likely be affected you 1) have transition hooks, 2) are using typescript and/or 3) use the internal ui-router State API. #### BC Severity How severe is this BC? Low: Access to the internal api is still available using `$$state()`. ## **StateObject:** Renamed internal API `State` object to `StateObject` #### Before: ``` import {State} from "@uirouter/core"; ``` #### Now: ``` import {StateObject} from "@uirouter/core"; ``` #### Motivation: We'd like to use the `State` name/symbol as a public API. It will be an ES7/TS decorator for ES6/TS state definition classes, i.e: ```js @State("foo") export class FooState implements StateDeclaration { url = "/foo"; component = FooComponent; @Resolve({ deps: [FooService] }) fooData(fooService) { return fooService.getFoos(); } } ``` #### BC Likelihood How likely is this to affect me? Low: This only affects code that imports the internal API symbol `State`. You will likely be affected you 1) import that symbol, 2) are using typescript and 3) explicitly typed a variable such as `let internalStateObject = state.$$state();` #### BC Severity How severe is this change? Low: Find all places where `State` is imported and rename to `StateObject` ## **Transition:** All Transition errors are now wrapped in a Rejection object. #### Before: Previously, if a transition hook returned a rejected promise: ```js .onStart({}, () => Promise.reject('reject transition')); ``` In `onError` or `transtion.promise.catch()`, the raw rejection was returned: ```js .onError({}, (trans, err) => err === 'reject transition') ``` #### Now: Now, the error is wrapped in a Rejection object. - The detail (thrown error or rejected value) is still available as `.detail`. ```js .onError({}, (trans, err) => err instanceof Rejection && err.detail === 'reject transition') ``` - The Rejection object indicates the `.type` of transition rejection (ABORTED, ERROR, SUPERSEDED and/or redirection). ```js .onError({}, (trans, err) => { err.type === RejectType.ABORTED === 3 }); ``` #### Motivation: Errors *thrown from* a hook and rejection values *returned from* a hook can now be processed in the same way. #### BC Likelihood How likely is this to affect me? Medium: apps which have onError handlers for rejected values #### BC Severity How severe is this change? Low: Find all error handlers (or .catch/.then chains) that do not understand Rejection. Add `err.detail` processing. ## **onBefore:** `onBefore` hooks are now run asynchronously like all the other hooks. #### Old behavior Previously, the `onBefore` hooks were run in the same stackframe as `transitionTo`. If they threw an error, it could be caught using try/catch. ```js transitionService.onBefore({ to: 'foo' }), () => { throw new Error('doh'); }); try { stateService.go('foo'); } catch (error) { // handle error } ``` #### New behavior Now, `onBefore` hooks are processed asynchronously. To handle errors, use any of the async error handling paradigms: - Chain off the promise ```js transitionService.onBefore({ to: 'foo' }), () => { throw new Error('doh'); }); stateService.go('foo').catch(error => { //handle error }); ``` - Define an error handler ```js transitionService.onBefore({ to: 'foo' }), () => { throw new Error('doh'); }); transitionService.onError({ to: 'foo' }), () => { // handle error }); stateService.go('foo'); ``` - Use the global defaultErrorHandler ```js transitionService.onBefore({ to: 'foo' }), () => { throw new Error('doh'); }); stateService.go('foo'); stateService.defaultErrorHandler(error => { // global error handler }); ``` #### Motivation Why introduce a BC? - No subtle behavior differences by hook type - Simpler code and mental model - Fewer edge cases to account for #### BC Liklihood How likely is this to affect my app? Very Low: Apps that registered onBefore hooks and depend on synchronous execution are affected. #### BC Severity How severe is this BC? Low: Switch to asynchronous handling, such as chaining off the transition promise ## **defaultErrorHandler:** ABORTED transitions do not invoke the `defaultErrorHandler` Returning `false` from a transition hook will abort the transition. #### Old behavior Previously, this case was considered an error and was logged by `defaultErrorHandler`. After your feedback, we agree that this is not typically an error. #### New behavior Now, aborted transitions do not trigger the `defaultErrorHandler` #### Motivation: > Why introduce a BC? Most users do not consider ABORT to be an error. The default error handler should match this assumption. #### BC liklihood > How likely am I to be affected? Low: Most users do not consider ABORT to be an error. For most users this will not be a BC. #### BC severity > How severe is this BC? Low: Users who want to handle all transition rejections can register a `.onError` handler and filter/process accordingly. ### @uirouter/core changes # [4.0.0](https://github.com/ui-router/core/compare/3.1.1...v4.0.0) (2017-01-22) ### Bug Fixes * **resolve:** Allow hook and resolve's state context to be injected as `$state$` ([a06948b](https://github.com/ui-router/core/commit/a06948b)) ### Features * **core:** Export all vanilla.* code from `@uirouter/core` ([f3392d1](https://github.com/ui-router/core/commit/f3392d1)) * **globals:** Removed `UIRouterGlobals` interface. Renamed `Globals` class to `UIRouterGlobals` ([8719334](https://github.com/ui-router/core/commit/8719334)) ### BREAKING CHANGES * BREAKING CHANGE: This change will likely only affect a small subset of typescript users and probably only those using `ui-router-ng2`. If you're injecting the `Globals` class somewhere, e.g.: ``` @Injectable() class MyService { _globals: UIRouterGlobals; constructor(globals: Globals) { this._globals = <UIRouterGlobals> globals; } } ``` you should now inject `UIRouterGlobals`, e.g.: ``` @Injectable() class MyService { constructor(public globals: UIRouterGlobals) { } } ``` Likewise, if you were casting the `UIRouter.globals` object as a `UIRouterGlobals`, it is no longer necessary: ```js function myHook(trans: Transition) { let globals: UIRouterGlobals = trans.router.globals; // cast is no longer necessary } ``` Closes https://github.com/ui-router/core/issues/31 ### @uirouter/core changes ## [3.1.1](https://github.com/ui-router/core/compare/3.1.0...v3.1.1) (2017-01-16) ### Bug Fixes * **lazyLoad:** Allow `lazyLoad` stateBuilder: Get lazyLoad fn from internal State object, not StateDeclaration ([9313880](https://github.com/ui-router/core/commit/9313880)) * **lazyLoad:** Fix `State.lazyLoad` type def ([9313880](https://github.com/ui-router/core/commit/9313880)) * **pushStateLocation:** call listeners in url() ([#24](https://github.com/ui-router/core/issues/24)) ([7c90911](https://github.com/ui-router/core/commit/7c90911)), closes [#23](https://github.com/ui-router/core/issues/23) ### Features * **UIRouter:** Add `trace` global to the `UIRouter` object ([48c5af6](https://github.com/ui-router/core/commit/48c5af6)) * **View:** Allow targeting views on own state using `viewname@.` (normalizeUIViewTarget) ([7078216](https://github.com/ui-router/core/commit/7078216)), closes [#25](https://github.com/ui-router/core/issues/25) ### @uirouter/core changes # [3.1.0](https://github.com/ui-router/core/compare/3.0.0...v3.1.0) (2017-01-09) ### Bug Fixes * **UrlRouter:** Use { location: 'replace' } whenever a url redirect happens ([6cf9b8f](https://github.com/ui-router/core/commit/6cf9b8f)) ### @uirouter/core changes # [3.0.0](https://github.com/ui-router/core/compare/2.0.0...3.0.0) (2017-01-08) ### Bug Fixes * **lazyLoad:** Use UrlService.match() to retry url sync after successful lazy load triggered by url ([8c2461d](https://github.com/ui-router/core/commit/8c2461d)), closes [#19](https://github.com/ui-router/core/issues/19) * **Params:** `params: { foo: { raw: true } }` overrides `ParamType.raw` ([aefeabf](https://github.com/ui-router/core/commit/aefeabf)) * **Params:** Mark all query parameters as optional ([7334d98](https://github.com/ui-router/core/commit/7334d98)) * **Params:** Check for null in `int` param type `is()` check ([aa551e4](https://github.com/ui-router/core/commit/aa551e4)), closes [#3197](https://github.com/ui-router/core/issues/3197) * **Transition:** Use { location: replace } when redirecting a transtition in response to a URL sync ([23e2b78](https://github.com/ui-router/core/commit/23e2b78)) * **UrlService:** Wire urlMatcherFactory and urlRouter functions ([a7b58d6](https://github.com/ui-router/core/commit/a7b58d6)) * **vanilla:** vanilla locations: do not parse "empty string" query key parameter ([f949480](https://github.com/ui-router/core/commit/f949480)) ### Features * (CoreServices) Move `location` and `locationConfig` from `services` to `UIRouter.locationService` and `UIRouter.locationConfig`. ([029fb00](https://github.com/ui-router/core/commit/029fb00)) * Built-in `string` parameter type no longer encodes slashes as `~2F` nor tildes as `~~` ([72bb2d8](https://github.com/ui-router/core/commit/72bb2d8)) * Move `html5Mode` and `hashPrefix` from `LocationServices` to `LocationConfig` interface ([9d316a7](https://github.com/ui-router/core/commit/9d316a7)) * Order URL Matching Rules by priority, not registration order ([eb2f5d7](https://github.com/ui-router/core/commit/eb2f5d7)) * Path/Query parameters no longer default to `string` param type ([72bb2d8](https://github.com/ui-router/core/commit/72bb2d8)) * Remove `getResolveValue` and `getResolvable` methods from `Transition` in favor of `injector().get()` and `injector().getAsync()` ([111d259](https://github.com/ui-router/core/commit/111d259)) * Replace `LocationServices.setUrl` with `LocationServices.url` ([4c39dcb](https://github.com/ui-router/core/commit/4c39dcb)) * Replace UrlRouterProvider/UrlRouter with just UrlRouter ([fddd1e2](https://github.com/ui-router/core/commit/fddd1e2)) * **hash:** Change the hash parameter type (`'#'`) to `inherit: false` so it is cleared out when another transition occurs. ([849f84f](https://github.com/ui-router/core/commit/849f84f)), closes [#3245](https://github.com/ui-router/core/issues/3245) [#3218](https://github.com/ui-router/core/issues/3218) [#3017](https://github.com/ui-router/core/issues/3017) * **LocationServices:** Add a `parts()` method which returns the URL parts as an object ([32e64f0](https://github.com/ui-router/core/commit/32e64f0)) * **Params:** Add `path` and `query` param types ([72bb2d8](https://github.com/ui-router/core/commit/72bb2d8)) * **Params:** add option to use generic type for Transition.params ([#17](https://github.com/ui-router/core/issues/17)) ([eb12ec8](https://github.com/ui-router/core/commit/eb12ec8)), closes [#16](https://github.com/ui-router/core/issues/16) * **Params:** Allow `inherit: false` specified per parameter or type ([849f84f](https://github.com/ui-router/core/commit/849f84f)) * **Resolve:** implement NOWAIT policy: Do not wait for resolves before completing a transition. ([05d4c73](https://github.com/ui-router/core/commit/05d4c73)), closes [#3243](https://github.com/ui-router/core/issues/3243) [#2691](https://github.com/ui-router/core/issues/2691) * **Transition:** Add Transition.originalTransition() to return the initial transition in a chain of redirects ([4fe39e3](https://github.com/ui-router/core/commit/4fe39e3)) * **Transition:** Allow `injector()` to retrieve resolves for the exiting states/path ([df502e8](https://github.com/ui-router/core/commit/df502e8)) * **Transition:** Allow a plain object `ResolvableLiteral` in `Transition.addResolvable` ([ad9ae81](https://github.com/ui-router/core/commit/ad9ae81)) * **Transition:** Make Transition.params() immutable to avoid confusion about mutability ([0162212](https://github.com/ui-router/core/commit/0162212)) * **UrlMatcher:** Add comparison function by UrlMatcher specificity ([eb2f5d7](https://github.com/ui-router/core/commit/eb2f5d7)) * **UrlRouter:** sort url rules by specificity, not by registration order. ([eb2f5d7](https://github.com/ui-router/core/commit/eb2f5d7)) * **UrlService:** allow eager or lazy binding of location objects during construction ([7e0a8af](https://github.com/ui-router/core/commit/7e0a8af)) * **UrlService:** Add `match()`: given a URL, return the best matching Url Rule ([32e64f0](https://github.com/ui-router/core/commit/32e64f0)) ### BREAKING CHANGES * BREAKING CHANGE: Remove `getResolveValue` and `getResolvable` methods from `Transition` in favor of `injector().get()` and `injector().getAsync()` In beta.3, the Transition APIs: `injector()`, `getResolvable`, and `getResolveValue` duplicated functionality. Instead of: ```js trans.getResolveValue('myResolve'); ``` use: ```js trans.injector().get('myResolve') ``` * BREAKING CHANGE: Order URL Matching Rules by priority, not registration order URL Rules can come from registered states' `.url`s, calling `.when()`, or calling `.rule()`. It's possible that two or more URL Rules could match the URL. ### Previously Previously, url rules were matched in the order in which they were registered. The rule which was registered first would handle the URL change. ### Now Now, the URL rules are sorted according to a sort function. More specific rules are preferred over less specific rules ### Why It's possible to have multiple url rules that match a given URL. Consider the following states: - `{ name: 'books', url: '/books/index' }''` - `{ name: 'book', url: '/books/:bookId' }''` Both states match when the url is `/books/index`. Additionally, you might have some custom url rewrite rules such as: `.when('/books/list', '/books/index')`. The `book` state also matches when the rewrite rule is matched. Previously, we simply used the first rule that matched. However, now that lazy loading is officially supported, it can be difficult for developers to ensure the rules are registered in the right order. Instead, we now prioritize url rules by how specific they are. More specific rules are matched earlier than less specific rules. We split the path on `/`. A static segment (such as `index` in the example) is more specific than a parameter (such as`:bookId`). ### More Details The built-in rule sorting function (see `UrlRouter.defaultRuleSortFn`) sorts rules in this order: - Explicit priority: `.when('/foo', '/bar', { priority: 1 })` (default priority is 0) - Rule Type: - UrlMatchers first (registered states and `.when(string, ...)`) - then regular Expressions (`.when(regexp, ...)`) - finally, everything else (`.rule()`) - UrlMatcher specificity: static path segments are more specific than variables (see `UrlMatcher.compare`) - Registration order (except for UrlMatcher based rules) For complete control, a custom sort function can be registered with `UrlService.rules.sort(sortFn)` ### Query params Because query parameters are optional, they are not considered during sorting. For example, both these rules will match when the url is `'/foo/bar'`: ``` .when('/foo/bar', doSomething); .when('/foo/bar?queryparam', doSomethingElse); ``` To choose the most specific rule, we match both rules, then choose the rule with the "best ratio" of matched optional parameters (see `UrlRuleFactory.fromUrlMatcher`) This allows child states to be defined with only query params for a URL. The state only activates when the query parameter is present. ``` .state('parent', { url: '/parent' }); .state('parent.child', { url: '?queryParam' }); ``` ## Restoring the previous behavior For backwards compatibility, register a sort function which sorts by the registration order: ```js myApp.config(function ($urlServiceProvider) { function sortByRegistrationOrder(a, b) { return a.$id - b.$id; } $urlServiceProvider.rules.sort(sortByRegistrationOrder); }); ``` * BREAKING CHANGE: Replace `LocationServices.setUrl` with `LocationServices.url` This makes `url()` a getter/setter. It also adds the optional `state` parameter to pass through to the browser history when using pushstate. End users should not notice this change, but plugin authors may. * BREAKING CHANGE: Replace UrlRouterProvider/UrlRouter with just UrlRouter The configuration functions from the provider object have been integrated into the normal UrlRouter object. The `UIRouter` object no longer has a `uriRouterProvider`, but the equivalent functions can be found on `uiRouter` One difference between the old functions on `urlRouterProvider` and the new ones on `uriRouter` is that new functions do not accept injectable functions. * BREAKING CHANGE: Built-in `string` parameter type no longer encodes slashes as `~2F` nor tildes as `~~` Previously, the `string` parameter type pre-encoded tilde chars (`~`) as two tilde chars (`~~`) and slashes (`/`) as `~2F`. Now, the `string` parameter type does not pre-encode slashes nor tildes. If you rely on the previous encoding, create a custom parameter type that implements the behavior: ```js urlMatcherFactory.type('tildes', { encode: (val: any) => val != null ? val.toString().replace(/(~|\/)/g, m => ({ '~': '~~', '/': '~2F' }[m])) : val; decode: (val: string) => val != null ? val.toString().replace(/(~~|~2F)/g, m => ({ '~~': '~', '~2F': '/' }[m])) : val; pattern: /[^/]*/ }); ``` * BREAKING CHANGE: Path/Query parameters no longer default to `string` param type Previously, if a url parameter's type was not specified (in either the path or query), it defaulted to the `string` type. Now, path parameters default to the new `path` type and query parameters default to the new `query` type. **In Angular 1 only**, the new `path` parameter type retains the old behavior of pre-encoding `~` to `~~` and `/` to `~2F` * BREAKING CHANGE: (CoreServices) Move `location` and `locationConfig` from `services` to `UIRouter.locationService` and `UIRouter.locationConfig`. The core `services` object is a mutable object which each framework was monkey patching. This change removes the requirement to monkey patch a global mutable object. Instead, framework implementors should pass the `LocationServices` and `LocationConfig` implementations into the `UIRouter` constructor. ### End Users End users who were accessing `services.location` or `services.locationConfig` should access these off the `UIRouter` instance instead. * BREAKING CHANGE: Move `html5Mode` and `hashPrefix` from `LocationServices` to `LocationConfig` interface ### End users should not notice ### @uirouter/core changes # [2.0.0](https://github.com/ui-router/core/compare/1.0.1...2.0.0) (2016-12-09) ### Bug Fixes * **lazyLoad:** Sync by URL after nested lazy load triggered by URL ([1c6220c](https://github.com/ui-router/core/commit/1c6220c)) * **redirect:** Do not allow `onBefore` hooks to cause infinite redirect loops ([5c5f7eb](https://github.com/ui-router/core/commit/5c5f7eb)), closes [#6](https://github.com/ui-router/core/issues/6) * **redirectTo:** Do not puke when redirectTo returns undefined ([bde9c0f](https://github.com/ui-router/core/commit/bde9c0f)) * **redirectTo:** fix TS type signature of `redirectTo` ([2c059c4](https://github.com/ui-router/core/commit/2c059c4)) * **StateQueueManager:** Compare parsed url parameters using typed parameters ([beca1f5](https://github.com/ui-router/core/commit/beca1f5)) * **StateRegistry:** Fix error message: State '' is already defined ([f5bd96b](https://github.com/ui-router/core/commit/f5bd96b)) * **StateService:** Compare typed parameters in .is() and .includes() ([b1a5155](https://github.com/ui-router/core/commit/b1a5155)) * **TargetState:** Narrow `name()` return type to `String` ([a02f4a7](https://github.com/ui-router/core/commit/a02f4a7)) * **typescript:** Emit TS 1.8 compatible .d.ts files ([65badf4](https://github.com/ui-router/core/commit/65badf4)) * **view:** Load view prerequisites in `onFinish` ([cc85e76](https://github.com/ui-router/core/commit/cc85e76)) * **view.load:** Allow view.load to return synchronously ([8619cf9](https://github.com/ui-router/core/commit/8619cf9)) ### Features * Create router.dispose() to dispose a router instance and resources. ([0690917](https://github.com/ui-router/core/commit/0690917)) * **assertMap:** Add a [].map() helper that asserts that each element is truthy ([f044f53](https://github.com/ui-router/core/commit/f044f53)) * **futureState:** States with a `.**` name suffix (i.e., `foo.**`) are considered future states ([ec50da4](https://github.com/ui-router/core/commit/ec50da4)), closes [#8](https://github.com/ui-router/core/issues/8) [#4](https://github.com/ui-router/core/issues/4) * **HookBuilder:** Allow custom hook types (to be defined by a plugin) ([3f146e6](https://github.com/ui-router/core/commit/3f146e6)) * **onCreate:** Add onCreate transition hook ([f486ced](https://github.com/ui-router/core/commit/f486ced)) * **plugin:** Allow all plugins to be gotted. ([e324973](https://github.com/ui-router/core/commit/e324973)) * **plugin:** Allow registration by ES6 class, JS constructor fn, JS factory fn ([b9f4541](https://github.com/ui-router/core/commit/b9f4541)) * **plugin:** Create plugin API ([36a5215](https://github.com/ui-router/core/commit/36a5215)), closes [#7](https://github.com/ui-router/core/issues/7) * **Transition:** Support treechange paths in API for Resolve+transition ([beedc82](https://github.com/ui-router/core/commit/beedc82)) * **vanilla:** Implement in-memory-only location api ([f64aace](https://github.com/ui-router/core/commit/f64aace)) ### BREAKING CHANGES * **typescript:** move `ViewService.viewConfigFactory` and `rootContext` to `_pluginapi.*` This BC happened in commit 6c42285 * **futureState:** Previously, a state with a `lazyLoad` function was considered a future state. Now, a state whose name ends with `.**` (i.e., a glob pattern which matches all children) is a future state. ### All future states should be given a name that ends in `.**`. Change your future states from: ``` { name: 'future', url: '/future', lazyLoad: () => ... } ``` to: ``` { name: 'future.**', url: '/future', lazyLoad: () => ... } ``` * **onCreate:** Hook errors are all normalized to a "Rejection" type. To access the detail of the error thrown (`throw "Error 123"`), use `.detail`, i.e.: ### Before ```js $state.go('foo').catch(err => { if (err === "Error 123") .. }); ``` ### New way ```js $state.go('foo').catch(err => { if (err.detail === "Error 123") .. }); ``` <a name="1.0.1"></a> ## [1.0.1](https://github.com/ui-router/core/compare/1.0.0...v1.0.1) (2016-10-24) ### Bug Fixes * **onBefore:** Skip remaining hooks after the ([#2](https://github.com/ui-router/core/issues/2)) ([8a45d04](https://github.com/ui-router/core/commit/8a45d04)) * **typings:** Allow urlRouter.rule to return void ([0b78bdf](https://github.com/ui-router/core/commit/0b78bdf)) <a name="1.0.0"></a> # [1.0.0](https://github.com/ui-router/core/compare/1.0.0-beta.3...1.0.0) (2016-10-20) ### Features - This is the 1.0.0 release of @uirouter/core. - We've moved @uirouter/core to its new home at https://github.com/ui-router/core - @uirouter/core will now follow SemVer. # BREAKING CHANGE commonjs files now output to `/lib` and ES5 + ES6 module now output to `/lib-esm`. No bundles are being created. <a name="1.0.0-beta.3"></a> # [1.0.0-beta.3 commits](https://github.com/angular-ui/ui-router/compare/1.0.0-beta.2...1.0.0-beta.3) (2016-09-23) [Read more on the blog](https://ui-router.github.io/blog/uirouter-1.0.0-beta.3/) This release adds Angular 2.0.0 final support. It changes the NgModule mechanism to use `UIRouterModule.forRoot()` and `UIRouterModule.forChild()`. See the blog and the breaking changes section. ### Bug Fixes This release fixes bugs for both ng1 and ng2 * **common:** Remove `url()` from LocationService interface ([#2990](https://github.com/angular-ui/ui-router/issues/2990)) ([d6c2580](https://github.com/angular-ui/ui-router/commit/d6c2580)) * **lazyLoad:** Always delete the lazy load promise after it settles. ([dd2f101](https://github.com/angular-ui/ui-router/commit/dd2f101)) * **ng1.StateProvider:** Export StateProvider class so type can be used ([167770d](https://github.com/angular-ui/ui-router/commit/167770d)) * **ng1.uiView:** Remove deprecated jquery functions bind/unbind in favor of on/off ([60ebd44](https://github.com/angular-ui/ui-router/commit/60ebd44)) * **ng2:** Angular 2.0.0 final compatibility ([7c54b75](https://github.com/angular-ui/ui-router/commit/7c54b75)), closes [#2991](https://github.com/angular-ui/ui-router/issues/2991) * **ng2.NgModule:** Allow apps with no forChild modules ([d3bd332](https://github.com/angular-ui/ui-router/commit/d3bd332)), closes [#3009](https://github.com/angular-ui/ui-router/issues/3009) * **ng2.uiView:** Use ReflectorReader to get component inputs * **resolve:** Don't re-resolve data when redirected to same state, but only dynamic params changed. ([98cd2d2](https://github.com/angular-ui/ui-router/commit/98cd2d2)), closes [#3033](https://github.com/angular-ui/ui-router/issues/3033) * **trace:** Show function definition during logging of trace.enable('HOOK') ([190d122](https://github.com/angular-ui/ui-router/commit/190d122)) * **transition:** Fail a transition if a new one has started while resolves are loading ([bc87d9e](https://github.com/angular-ui/ui-router/commit/bc87d9e)), closes [#2972](https://github.com/angular-ui/ui-router/issues/2972) * **urlMatcherFactory:** fix tilde edge case with "string" encoding ([#3018](https://github.com/angular-ui/ui-router/issues/3018)) ([a201906](https://github.com/angular-ui/ui-router/commit/a201906)) * **viewService:** Allow root ui-view to be wrapped in ng-if ([32f718a](https://github.com/angular-ui/ui-router/commit/32f718a)), closes [#3004](https://github.com/angular-ui/ui-router/issues/3004) ### Features * **StateBuilder:** Calculate parent state name when ends in two wildcards `**` ([b4621f3](https://github.com/angular-ui/ui-router/commit/b4621f3)) ### BREAKING CHANGES #### BC in Core * Remove `UIInjector.native` infavor of `UIInjector.getNative()` ([d11b7dc](https://github.com/angular-ui/ui-router/commit/d11b7dc)) * Remove `stateProvider` from @uirouter/core. Use `stateRegistry` and `stateService` in 88c6494 * We now enforce states with an explicit `parent:` may NOT ALSO specify a parent state in their name (i.e., `parent.child`) #### BC in Angular 2 Major breaking changes for Angular 2 bootstrap between beta.2 and beta.3 - Removed `@UIRouterModule` decorator. - Added `UIRouterModule.forRoot()` and `UIRouterModule.forChild()` factory methods - See https://ui-router.github.io/docs/latest/classes/ng2.uiroutermodule.html ``` @NgModule({ imports: [ UIRouterModule.forRoot({ states: INITIAL_STATES, useHash: true, configClass: MyUIRouterConfig }), BrowserModule, FeatureModule, ], declarations: INITIAL_COMPONENTS }) class RootAppModule {} @NgModule({ imports: [ UIRouterModule.forChild({ states: FEATURE_STATES, configClass: FeatureConfig }), CommonModule, ], declarations: FEATURE_COMPONENTS }) ``` <a name="1.0.0-beta.2"></a> # [1.0.0-beta.2 commits](https://github.com/angular-ui/ui-router/compare/1.0.0-beta.1...1.0.0-beta.2) (2016-09-09) [Read more on the blog](https://ui-router.github.io/blog/uirouter-1.0.0-beta.2/) ### Features #### Core * **lazyLoad:**