-
Notifications
You must be signed in to change notification settings - Fork 12k
Route-specific app-shell: prerendering dynamic parameterized pages #29425
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Comments
It sounds like you're looking to implement an app shell with more granular control, where specific app shells can be assigned to individual routes instead of relying on a single app shell for the entire application. At the moment, this level of control is not something we support out of the box. |
This feature request is now candidate for our backlog! In the next phase, the community has 60 days to upvote. If the request receives more than 20 upvotes, we'll move it to our consideration list. You can find more details about the feature request process in our documentation. |
@vzarskus we have a similar problem/approach. I've made a small reproduction on how we render separate components on the server vs. on the client. It might be able to help you out. The trick is to provide different routes for server routing than on client in combination with hybrid rendering. Repo is here: https://github.com/martyganz/hybrid-demo |
@martyganz the problem is with parameterized routes. |
Which @angular/* package(s) are relevant/related to the feature request?
platform-server
Description
We have a use case, where we would like to always show the same prerendered page skeleton/carcass on a route that has dynamic parameters.
Looking at the new Angular server documentation, I do not see such option https://angular.dev/guide/hybrid-rendering#parameterized-routes.
Basically we would like
posts/:id
to return a single prerendered page for any:id
parameter.This page would show a loading skeleton and would let the browser handle the exact
:id
and the logic related to it.Proposed solution
Add a wildcard
**
route option that would indicate to Angular that this prerendered page handles any dynamic route parameters.These wildcards could be used as the dynamic parameter in the build time when prerendering happens. It would be the component's responsibility to correctly handle the
**
parameter and show some parameter-agnostic content (loaders/skeletons) that would then be prerendered by Angular and served by the server accordingly.How it could look in
app.routes.server.ts
:Excerpt from the imaginary
post.component.ts
:Alternatives considered
I am currently considering:
server.ts
with a middleware that runs before any middleware generated by Angular CLI.app.routes.server.ts
:server.ts
:I have tested this approach and it works fine, however, it feels pretty hacky.
The text was updated successfully, but these errors were encountered: