import * as angular from 'angular'; const myApp = angular.module('testModule'); myApp.config(($stateProvider: angular.ui.IStateProvider, $stickyStateProvider: angular.ui.IStickyStateProvider) => { const state: angular.ui.IStickyState = { name: 'test', sticky: true, dsr: { default: 'substate', params: ['param1', 'param2'], fn: ($dsr$) => $dsr$.to, }, onInactivate: ($state: angular.ui.IState) => { const iAmInjectedByInjector = $state; }, onReactivate: ($state: angular.ui.IState) => { const iAmInjectedByInjector = $state; }, controller: ($previousState: angular.ui.IPreviousStateService, $deepstateRedirect: angular.ui.IDeepStateRedirectService, $stickyState: angular.ui.IStickyStateService) => { $previousState.memo('test-memo1'); $previousState.memo('test-memo2', 'test-state-name2'); $previousState.memo('test-memo3', 'test-state-name3', {}); $previousState.forget('test-memo3'); $previousState.go('test-memo2', { location: true, notify: true }); $previousState.get(); $previousState.get('test-memo1'); $deepstateRedirect.reset('statename1', { stateParam1: ['value1', 'value2'], stateParam2: 'value' }); $stickyState.getInactiveStates(); $stickyState.reset('state1'); $stickyState.reset('state2', { stateParam1: ['value1', 'value2'], stateParam2: 'value' }); }, views: { // named views are mandatory name1: {} } }; $stickyStateProvider.enableDebug(true); $stateProvider.state(state); $stateProvider.state({ name: 'test', sticky: true, dsr: { default: 'substate', params: ['param1', 'param2'], fn: $dsr$ => $dsr$.to, }, onInactivate: ($state: angular.ui.IState) => { const iAmInjectedByInjector = $state; }, onReactivate: ($state: angular.ui.IState) => { const iAmInjectedByInjector = $state; }, controller: ($previousState: angular.ui.IPreviousStateService, $deepstateRedirect: angular.ui.IDeepStateRedirectService) => { $previousState.memo('test-memo1'); $previousState.memo('test-memo2', 'test-state-name2'); $previousState.memo('test-memo3', 'test-state-name3', {}); $previousState.forget('test-memo3'); $previousState.go('test-memo2', { location: true, notify: true }); $previousState.get(); $previousState.get('test-memo1'); $deepstateRedirect.reset('statename1', { stateParam1: ['value1', 'value2'], stateParam2: 'value' }); }, views: { // named views are mandatory name1: {} } }); $stateProvider.state('name1', { name: 'test', sticky: true, dsr: { default: 'substate', params: ['param1', 'param2'], fn: $dsr$ => $dsr$.to, }, onInactivate: ($state: angular.ui.IState) => { const iAmInjectedByInjector = $state; }, onReactivate: ($state: angular.ui.IState) => { const iAmInjectedByInjector = $state; }, controller: ($previousState: angular.ui.IPreviousStateService, $deepstateRedirect: angular.ui.IDeepStateRedirectService) => { $previousState.memo('test-memo1'); $previousState.memo('test-memo2', 'test-state-name2'); $previousState.memo('test-memo3', 'test-state-name3', {}); $previousState.forget('test-memo3'); $previousState.go('test-memo2', { location: true, notify: true }); $previousState.get(); $previousState.get('test-memo1'); $deepstateRedirect.reset('statename1', { stateParam1: ['value1', 'value2'], stateParam2: 'value' }); }, views: { // named views are mandatory name1: {} } }); }); const templateLoadStateFactory: ng.ui.IFutureStateFactory = ($q: ng.IQService, $timeout: ng.ITimeoutService, futureState: ng.ui.IFutureState) => { const d = $q.defer(); $timeout(() => { const fullUiRouterState = { name: futureState.stateName, url: futureState.url, template: '