- Full Type Safety: Enjoy end-to-end type safety for all your API calls.
- SSR-Ready: Optimized for Angular Universal and Server-Side Rendering (SSR).
- Reactive Streams: Utilize RxJS for handling API responses and WebSocket streams like a pro.
- Subscriptions: Native support for subscriptions using WebSockets, fully integrated with RxJS.
This project was inspired by the amazing work of Dafnik/ngx-trpc
and @analogjs/trpc
. It builds upon the same principles of type-safe API communication and seamless Angular integration, with added features such as WebSocket subscriptions.
Since the REQUEST token is reintroduced in v19, this library is compatible only with that version.
This project is a work in progress. Features and APIs may change as development continues. Use at your own risk, and expect frequent updates. Contributions and feedback are always welcome!
To start using the Angular tRPC Client in your project, install it via npm:
npm i ngx-trpc
First, define a global injection token using the AppRouter
type from your tRPC backend. This will allow you to inject your tRPC client throughout your Angular app.
import { createTrpcInjectionToken } from 'ngx-trpc';
export const TRPC = createTrpcInjectionToken<AppRouter>();
Next, provide the tRPC client and httpClient in your app.config.ts
file. (example)
import { provideTrpc } from 'ngx-trpc';
provideHttpClient(withFetch())
provideTrpc(TRPC, { options })
You can now use the TRPC injection token to call tRPC queries as RxJS observables inside your components. Here's an example of how to call the hello query.
import { TRPC } from '../path/to/injection-token';
@Component({
selector: 'app-demo',
template: '{{ demoQuery$ | async | json }}',
})
export class DemoComponent {
readonly trpc = inject(TRPC);
readonly demoQuery$ = this.trpc.hello.query();
}
-
Headers are not forwarded when performing requests in ssr.
Add this provider to your
app.config.server.ts
file to fix this issue:provideServerRoutesConfig([{path: '**', renderMode: RenderMode.Server}])
- Additional Unit Tests for SSR and WebSocket Subscriptions.
- Improve Error Handling and Logging.
- Handle subscriptions server-side. Currently, subscriptions are only supported client-side.