Customize your own driver

If you would like to customize your own driver, simply write a service that meets the DaffExternalRouterDriverInterface from @daffodil/external-router/driver and provide it.

Parsing and Processing URL

The url passed to the resolve method can and will have extra info such as query parameters, fragments, and leading slashes. Drivers should take care to parse the passed URL into a form that can be resolved by the platform.

Additionally, URLs returned by the driver's resolve method should be in a form that satisfies Angular's Route#path type. Generally, this means that the url should not have leading slashes or other info such as query parameters or fragments.

Example

@Injectable({
 providedIn: 'root',
})
class MyCustomExternalRouterService implements DaffExternalRouterDriverInterface {
  resolve(url: string): Observable<DaffExternallyResolvableUrl> {
    // Your logic would go here
    return {
      /**
      * The URL that will be used for the path of the route inserted into the Angular routing config. Should not contain URL fragments, query parameters, or leading slashes.
      */
      url: "test.html",

      /**
      * The type of the route
      */
      type: "SOME_VALUE";

      /**
      * The HTTP status code for the resolvable route.
      */
      code: 200;

      /**
      * Additional route data. Note that this is not mandatory or guaranteed. It's only available when the driver makes it available.
      */
      data: null;
    };
  }
}

@NgModule({
  providers: [
    provideDaffExternalRouterDriver(MyCustomExternalRouterService),
  ],
})
class AppModule {}
Graycore, LLC © 2018 - 2025. Code licensed under an MIT-style License. Documentation licensed under CC BY 4.0.