Automatic TypeScript type generation for Ash resources and actions
Generate type-safe TypeScript clients directly from your Elixir Ash resources, ensuring end-to-end type safety between your backend and frontend. Never write API types manually again.
AshTypescript now generates multiple output files instead of a single monolithic file. Shared types and Zod schemas are extracted into dedicated files (ash_types.ts and ash_zod.ts) that both RPC and controller code import from.
What changed:
- Types and Zod schemas are no longer inlined in
ash_rpc.ts— they live in separate files - Two new config options auto-derive from
output_file:types_output_file(→ash_types.ts) andzod_output_file(→ash_zod.ts) - If you import types directly from the generated RPC file, update imports to use the new shared types file
Migration:
- Run
mix ash_typescript.codegen— new files will be created alongside the existing output - Update any TypeScript imports that referenced types from
ash_rpc.tsto import fromash_types.tsinstead - If you use Zod schemas, update imports to use
ash_zod.ts
No changes are needed if you only import the RPC functions themselves (e.g., import { listTodos } from './ash_rpc').
- Zero-config TypeScript generation - Automatically generates types from Ash resources
- End-to-end type safety - Catch integration errors at compile time, not runtime
- Smart field selection - Request only needed fields with full type inference
- RPC client generation - Type-safe function calls for all action types
- Get actions - Single record retrieval with
get?,get_by, andnot_found_error?options - Phoenix Channel support - Generate channel-based RPC functions for real-time applications
- Lifecycle hooks - Inject custom logic before/after requests (auth, logging, telemetry, error tracking)
- Multitenancy ready - Automatic tenant parameter handling
- Advanced type support - Enums, unions, embedded resources, and calculations
- Action metadata support - Attach and retrieve additional context with action results
- Highly configurable - Custom endpoints, formatting, and output options
- Runtime validation - Zod schemas for runtime type checking and form validation
- Auto-generated filters - Type-safe filtering with comprehensive operator support
- Form validation - Client-side validation functions for all actions
- Typed queries - Pre-configured queries for SSR and optimized data fetching
- Flexible field formatting - Separate input/output formatters (camelCase, snake_case, etc.)
- Custom HTTP clients - Support for custom fetch functions and request options (axios, interceptors, etc.)
- Field/argument name mapping - Map invalid TypeScript identifiers to valid names
Get up and running in under 5 minutes:
# Basic installation
mix igniter.install ash_typescript
# Full-stack Phoenix + React setup
mix igniter.install ash_typescript --framework reactdefmodule MyApp.Todo do
use Ash.Resource,
domain: MyApp.Domain,
extensions: [AshTypescript.Resource]
typescript do
type_name "Todo"
end
attributes do
uuid_primary_key :id
attribute :title, :string, allow_nil?: false
attribute :completed, :boolean, default: false
end
enddefmodule MyApp.Domain do
use Ash.Domain, extensions: [AshTypescript.Rpc]
typescript_rpc do
resource MyApp.Todo do
rpc_action :list_todos, :read
rpc_action :create_todo, :create
rpc_action :get_todo, :get
end
end
endmix ash.codegen --devimport { listTodos, createTodo } from './ash_rpc';
// Fully type-safe API calls
const todos = await listTodos({
fields: ["id", "title", "completed"],
filter: { completed: false }
});
const newTodo = await createTodo({
fields: ["id", "title", { user: ["name", "email"] }],
input: { title: "Learn AshTypescript", priority: "high" }
});That's it! Your TypeScript frontend now has compile-time type safety for your Elixir backend.
For complete setup instructions, see the Installation Guide.
- Installation - Complete installation and setup guide
- Your First RPC Action - Create your first type-safe API call
- Frontend Frameworks - React and other framework integrations
- CRUD Operations - Create, read, update, delete patterns
- Field Selection - Advanced field selection and nested relationships
- Querying Data - Pagination, sorting, and filtering
- Error Handling - Comprehensive error handling strategies
- Form Validation - Client-side validation with Zod schemas
- Lifecycle Hooks - Inject custom logic (auth, logging, telemetry)
- Phoenix Channels - Real-time WebSocket-based RPC actions
- Multitenancy - Multi-tenant application support
- Action Metadata - Attach and retrieve action metadata
- RPC Action Options - Configure action behavior
- Union Types - Type-safe union type handling
- Embedded Resources - Working with embedded data structures
- Custom Fetch Functions - Using custom HTTP clients and request options
- Custom Types - Create custom types with TypeScript integration
- Field Name Mapping - Map invalid field names to TypeScript
- Configuration - Complete configuration options
- Mix Tasks - Available Mix tasks and commands
- Troubleshooting - Common issues and solutions
AshTypescript bridges the gap between Elixir and TypeScript by automatically generating type-safe client code:
- Resource Definition - Define Ash resources with attributes, relationships, and actions
- RPC Configuration - Expose specific actions through your domain's RPC configuration
- Type Generation - Run
mix ash.codegento generate TypeScript types and RPC functions - Frontend Integration - Import and use fully type-safe client functions in your TypeScript code
- Compile-time validation - TypeScript compiler catches API misuse before runtime
- Autocomplete support - Full IntelliSense for all resource fields and actions
- Refactoring safety - Rename fields in Elixir, get TypeScript errors immediately
- Living documentation - Generated types serve as up-to-date API documentation
Check out the AshTypescript Demo by Christian Alexander featuring:
- Complete Phoenix + React + TypeScript integration
- TanStack Query for data fetching
- TanStack Table for data display
- Best practices and patterns
- Elixir 1.15 or later
- Ash 3.0 or later
- Phoenix (for RPC controller integration)
- Node.js 16+ (for TypeScript)
Contributions are welcome! Please:
- Fork the repository
- Create a feature branch (
git checkout -b feature/amazing-feature) - Make your changes with tests
- Ensure all tests pass (
mix test) - Run code formatter (
mix format) - Commit your changes (
git commit -m 'Add amazing feature') - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
Please ensure:
- All tests pass
- Code is formatted with
mix format - Documentation is updated for new features
- Commits follow conventional commit format
This project is licensed under the MIT License - see the LICENSES/MIT.txt file for details.
- Documentation: https://hexdocs.pm/ash_typescript
- GitHub Issues: https://github.com/ash-project/ash_typescript/issues
- Discord: Ash Framework Discord
- Forum: Elixir Forum - Ash Framework
