With routes and types generated from TRPC Typescript.
To generate the bindings from your tRPC Router, to be able to generate type-safe queries and mutations, you will need to have a script on your tRPC router's package.json
that runs the generator. You can check this example
bunx trpc-extractor -i src/router.ts -o ../example/lib/routes.json -w
Once the json with all the routes is generated, you will need to install a few dependencies on your flutter/dart project:
dependencies:
trpc_client: ^0.4.0
trpc_client_annotations: ^0.1.1
dev_dependencies:
build_runner: ^2.4.13
trpc_client_generator: ^0.1.7
Then, create a file on your project to run the generator:
import 'package:trpc_client_annotations/trpc_client_annotations.dart';
import 'package:freezed_annotation/freezed_annotation.dart';
import 'package:trpc_client/trpc_client.dart';
part 'trpc.freezed.dart';
part 'trpc.models.dart';
part 'trpc.router.dart';
part 'trpc.g.dart';
@TrpcGenerator(routesFilePath: "routes.json")
class RoutedTrpcClient extends _RTR$Router {
RoutedTrpcClient(super.client);
}
Or using the typescript file that contains the router directly:
import 'package:trpc_client_annotations/trpc_client_annotations.dart'; import 'package:freezed_annotation/freezed_annotation.dart'; import 'package:trpc_client/trpc_client.dart'; part 'trpc.freezed.dart'; part 'trpc.models.dart'; part 'trpc.router.dart'; part 'trpc.g.dart'; @TrpcGenerator(routerFilePath: "../trpc-server/src/router.ts") class RoutedTrpcClient extends _RTR$Router { RoutedTrpcClient(super.client); }
Finally, run the generator:
flutter pub run build_runner build -d
or, if developing and want to see the changes on the fly:
flutter pub run build_runner watch -d