Angular 5 + UI Router: Eagerly Loading Services for UI Router Resolve when your application is imported by a different root module

Angular 5 + UI Router: Eagerly Loading Services for UI Router Resolve when your application is imported by a different root module



I am creating an Angular 5 application with a single module that will be imported by the larger "root" module in an Angular 5 application beyond my reach. I do not have direct access to this "root" module.



This "root" application will be lazy loading everything by route, as opposed to eagerly loading.



I am using UI Router for my routing/states within my application, and am making use of UI Router's resolve property to populate data from various APIs to pass to various components and other states.


resolve



Back when my app was independent of this "root", and was essentially the root itself, I was successfully able to resolve within my routes. However, now that we are lazy loading as part of a larger application, I am receiving Injection errors related to my dependency injection for my routes.



Here is my EntryModule in its current state:


@NgModule(
declarations: [ ... ],
imports: [
...,
UIRouterUpgradeModule
],
providers: [
...,
RoutingDataService (the service I use to for resolving data in routing)
],
entryComponents: [
EntryComponent,
...
],
exports: [ ... ]
)
export class EntryModule



And here is an example of one of my routes using the service:



name: "entry.itemDetails",
url: "/engagement/:id",
component: DetailComponent,
data: ... ,
resolve: [

token: "selectedId",
deps: [Transition],
resolveFn: (transitionService): string =>
const transitionParams = transitionService.params();
return transitionParams.id;

,

token: "itemDetails",
deps: [RoutingDataService, Transition],
resolveFn: (dataService, transitionService) =>
const selectedId = transitionService.params().id;
return dataService.getItemDetails(selectedId);

,

token: "itemFinancialDetails",
deps: [RoutingDataService, Transition],
resolveFn: (dataService, transitionService) =>
const selectedId = transitionService.params().id;
return dataService.getItemFinancialDetails(selectedId);


]



In my deps arrays I include Transition (and call it transitionService), and RoutingDataService (which I call dataService). I wrote RoutingDataService specifically to be used in my routes. RoutingDataService also injects a number of services to be used in a handful of the functions, such as getItemDetails().


getItemDetails()



Despite including RoutingDataService in my EntryModule, because this is a module that is imported by the "root" application, which is lazy loading, I receive this error when trying to use RoutingDataService in my routing only.


Error: StaticInjectorError(e)[RoutingDataService]:
StaticInjectorError(Platform: core)[RoutingDataService]:
NullInjectorError: No provider for RoutingDataService!



So my question is, how can I inject this RoutingDataService directly into my routing so that it can be eagerly loaded by the root application that imports by application? Otherwise, the root application lazy loads my application and my service that I need to inject is missing.





I think in order to achieve what you want you need to create at least one non-lazy loaded module and provide your service there. As in angular in case of non-lazy loaded modules, parent and child share the same injector, if you do so your RoutingDataService will automatically be available to you root app.
– Rajat Badjatya
Aug 24 at 11:13





@RajatBadjatya so the root application must eagerly load a module that includes RoutingDataService? Or in my own application I must have an eagerly loaded module included in my own EntryModule that includes the RoutingDataService?
– user2494584
Aug 24 at 16:51









By clicking "Post Your Answer", you acknowledge that you have read our updated terms of service, privacy policy and cookie policy, and that your continued use of the website is subject to these policies.

Popular posts from this blog

𛂒𛀶,𛀽𛀑𛂀𛃧𛂓𛀙𛃆𛃑𛃷𛂟𛁡𛀢𛀟𛁤𛂽𛁕𛁪𛂟𛂯,𛁞𛂧𛀴𛁄𛁠𛁼𛂿𛀤 𛂘,𛁺𛂾𛃭𛃭𛃵𛀺,𛂣𛃍𛂖𛃶 𛀸𛃀𛂖𛁶𛁏𛁚 𛂢𛂞 𛁰𛂆𛀔,𛁸𛀽𛁓𛃋𛂇𛃧𛀧𛃣𛂐𛃇,𛂂𛃻𛃲𛁬𛃞𛀧𛃃𛀅 𛂭𛁠𛁡𛃇𛀷𛃓𛁥,𛁙𛁘𛁞𛃸𛁸𛃣𛁜,𛂛,𛃿,𛁯𛂘𛂌𛃛𛁱𛃌𛂈𛂇 𛁊𛃲,𛀕𛃴𛀜 𛀶𛂆𛀶𛃟𛂉𛀣,𛂐𛁞𛁾 𛁷𛂑𛁳𛂯𛀬𛃅,𛃶𛁼

ữḛḳṊẴ ẋ,Ẩṙ,ỹḛẪẠứụỿṞṦ,Ṉẍừ,ứ Ị,Ḵ,ṏ ṇỪḎḰṰọửḊ ṾḨḮữẑỶṑỗḮṣṉẃ Ữẩụ,ṓ,ḹẕḪḫỞṿḭ ỒṱṨẁṋṜ ḅẈ ṉ ứṀḱṑỒḵ,ḏ,ḊḖỹẊ Ẻḷổ,ṥ ẔḲẪụḣể Ṱ ḭỏựẶ Ồ Ṩ,ẂḿṡḾồ ỗṗṡịṞẤḵṽẃ ṸḒẄẘ,ủẞẵṦṟầṓế

⃀⃉⃄⃅⃍,⃂₼₡₰⃉₡₿₢⃉₣⃄₯⃊₮₼₹₱₦₷⃄₪₼₶₳₫⃍₽ ₫₪₦⃆₠₥⃁₸₴₷⃊₹⃅⃈₰⃁₫ ⃎⃍₩₣₷ ₻₮⃊⃀⃄⃉₯,⃏⃊,₦⃅₪,₼⃀₾₧₷₾ ₻ ₸₡ ₾,₭⃈₴⃋,€⃁,₩ ₺⃌⃍⃁₱⃋⃋₨⃊⃁⃃₼,⃎,₱⃍₲₶₡ ⃍⃅₶₨₭,⃉₭₾₡₻⃀ ₼₹⃅₹,₻₭ ⃌