Skip to content

Implement the Route Manager API (RFC #1169)#21460

Open
evoactivity wants to merge 8 commits into
emberjs:mainfrom
mainmatter:rfc-1169-route-manager
Open

Implement the Route Manager API (RFC #1169)#21460
evoactivity wants to merge 8 commits into
emberjs:mainfrom
mainmatter:rfc-1169-route-manager

Conversation

@evoactivity

@evoactivity evoactivity commented Jun 10, 2026

Copy link
Copy Markdown
Contributor

This is a big PR for a big feature.

Introduces a Route Manager layer between the router and route base classes so the router drives routes through a well-defined manager interface instead of calling classic Route methods directly. This decouples the router from the classic Route and is the stepping stone toward alternative route base classes and a future router. The classic Route behaves exactly as before, there are no changes to app authoring.

Three layers, top to bottom:

  • @ember/routing public re-exports of the authoring API
  • @ember/-internals/routing/route-managers The classic route manager and route manager infrastructure
  • router_js Drives the routes lifecycle through the manager, and owns the route manager contract

Why touch the container?

Route managers need to own route instantiation. The container's route: lookups previously created route instances directly, bypassing the manager, so we intercept them and redirect through router.getRoute(...), which goes through the manager

There are a handful of places internally that use the lookup to find a route, these can be changed but there could be public code in addons and apps that use this.lookup('route:name'). The interception we add means this code will continue to work.

Longer term, looking routes up through the container should be deprecated in favour of going through the router/manager.

Why does the outlet have a legacy path?

A handful of tests directly set the outlet state, one in particular is testing something for liquid-fire. If there are addons or user code that expects to be able to create their own render state, they will not include the route wrapper and invokable we expect from the route manager, the legacy path path lets them continue working.

Query Params

The current implementation of query params is driven by the router, I have gated the parts that directly reach into routes behind the classic interop capability of route managers. I have left the "machinery" in place in the router. When we come to replace the router, a decision will need to be made if we bridge the classic router manager to use whatever new QP implementation we come up with, or if we fully migrate the router.js QP implementation to be fully encapsulated by the classic route manager.


RFC #1169

Introduce a Route Manager layer between the router and route base classes so the router drives routes through a well-defined manager interface instead of calling classic Route methods directly. This decouples the router from the classic Route and is the stepping stone toward alternative route base classes and a future router.

Add the manager interface, capabilities, and registration, implement a ClassicRouteManager that encapsulates today's classic Route behaviour behind it, and make router_js dispatch lifecycle, rendering, model resolution, and the classic-interop surface through the manager.
@evoactivity evoactivity force-pushed the rfc-1169-route-manager branch from 37bd3e6 to 7582a9f Compare June 15, 2026 08:44
johanrd added a commit to johanrd/ember.js that referenced this pull request Jun 15, 2026
…s on emberjs#21460

Reverts the outlet.ts compute-ref guard to the current ember-7.0.0 behavior,
demonstrating that the @model-during-willDestroy instability (emberjs#18987)
still reproduces on top of the Route Manager RFC implementation (emberjs#21460).

The smoke-test job's '@model stability during route transitions' tests are
expected to fail here. Not for merge.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant