I'm working on a small web app based on the angular universal starter and the pokeapi. Since a lot of the data that I want to show doesn't actually change, I want to use pre-rendered pages to reduce the number of requests made to the API and to improve performance. For my example I have put a list of pokemons on the home page of my app which I retrieve from the API.
export class HomeComponent implements OnInit {
pokemon$: ReplaySubject<ResourceList> = new ReplaySubject<ResourceList>();
constructor(private pokedexService: PokedexService, private state: TransferState) { }
ngOnInit() {
if (this.state.hasKey(STATE_KEY_POKEMON)) {
this.pokemon$.next(this.state.get(STATE_KEY_POKEMON, {} as ResourceList));
}
else {
this.pokedexService.getResourceByCategory(ResourceCategory.POKEMON)
.subscribe((resourceList: ResourceList) => {
this.pokemon$.next(resourceList);
this.state.set(STATE_KEY_POKEMON, resourceList.results);
});
}
}
}
This works fine when I have the client render the page. However, when I attempt to pre-render the app, the build process hangs. Since I'm running a local instance of the API, I can see that a request was made and it returned with a 200 status. The build log looks like this:
npm run build:prerender
> [email protected] build:prerender C:\Users\thijs\Development\pokedex universal\angular-universal-pokedex
> npm run build:client-and-server-bundles && npm run compile:server && npm run generate:prerender
> [email protected] build:client-and-server-bundles C:\Users\thijs\Development\pokedex universal\angular-universal-pokedex
> ng build --prod && ng run ng-universal-demo:server:production
Date: 2018-09-22T16:47:41.687Z
Hash: c49708f1ccb7e73e327a
Time: 8181ms
chunk {0} runtime.6afe30102d8fe7337431.js (runtime) 1.05 kB [entry] [rendered]
chunk {1} styles.34c57ab7888ec1573f9c.css (styles) 0 bytes [initial] [rendered]
chunk {2} polyfills.c174e4dc122f769bd68b.js (polyfills) 64.3 kB [initial] [rendered]
chunk {3} main.19481e4ceb7a5808fe78.js (main) 312 kB [initial] [rendered]
Date: 2018-09-22T16:47:50.816Z
Hash: ee7e30e1f9c277bb5cbf
Time: 5739ms
chunk {main} main.js (main) 38.2 kB [entry] [rendered]
> [email protected] compile:server C:\Users\thijs\Development\pokedex universal\angular-universal-pokedex
> tsc -p server.tsconfig.json
> [email protected] generate:prerender C:\Users\thijs\Development\pokedex universal\angular-universal-pokedex
> cd dist && node prerender
The only way I get the pre-rendering build to complete is by removing the web request. I'm thinking there must still be something running in the background. I tried switching my Observable to a Promise, but that did not change anything. What am I missing?