Our review
Generates TypeScript functions and types for Laravel controllers and routes, ensuring synchronization between backend and frontend code.
Strengths
- Strong typing between backend and frontend
- Automatic route synchronization after generation
- Support for HTTP methods, forms, and route parameters
- Tree-shaking optimization via named imports
Limitations
- Requires Laravel and the Wayfinder package installation
- Must be regenerated after each route change
- Does not cover all advanced Laravel routing cases
When building frontend features for a Laravel application that needs typed and safe route management.
For non-Laravel projects or when the frontend does not require advanced route synchronization with the backend.
Security analysis
SafeThe skill contains only development guidance for using a Laravel code-generation package, with no executable commands, no data exfiltration, and no destructive actions. It is purely instructional for frontend development practices.
No concerns found
Examples
I've added a new route in my Laravel `routes/web.php`. Please run the Wayfinder generation command and show me how to use the new route in a React component with type safety.I need to create a form in my Laravel Inertia app using the Wayfinder package. Show me how to generate the form action and method automatically.name: wayfinder description: How to work effectively with Laravel Wayfinder, always use when developing frontend features
Wayfinder
Instructions
Wayfinder generates TypeScript functions and types for Laravel controllers and routes which you can import into your client side code. It provides type safety and automatic synchronization between backend routes and frontend code.
Development Guidelines
- Always Prefer named imports for tree-shaking (e.g.,
import { show } from '@/actions/...') - Avoid default controller imports (prevents tree-shaking)
- Run
php artisan wayfinder:generateafter route changes if there are any errors
Feature Overview
- Form Support: Use
.form()with--with-formflag for HTML form attributes —<form {...store.form()}>→action="/posts" method="post" - HTTP Methods: Call
.get(),.post(),.patch(),.put(),.delete()for specific methods —show.head(1)→{ url: "/posts/1", method: "head" } - Invokable Controllers: Import and invoke directly as functions. For example,
import StorePost from '@/actions/.../StorePostController'; StorePost() - Named Routes: Import from
@/routes/for non-controller routes. For example,import { show } from '@/routes/post'; show(1)for route namepost.show - Parameter Binding: Detects route keys (e.g.,
{post:slug}) and accepts matching object properties —show("my-post")orshow({ slug: "my-post" }) - Query Merging: Use
mergeQueryto merge withwindow.location.search, set values tonullto remove —show(1, { mergeQuery: { page: 2, sort: null } }) - Query Parameters: Pass
{ query: {...} }in options to append params —show(1, { query: { page: 1 } })→"/posts/1?page=1" - Route Objects: Functions return
{ url, method }shaped objects —show(1)→{ url: "/posts/1", method: "get" } - URL Extraction: Use
.url()to get URL string —show.url(1)→"/posts/1"
Examples
<code-snippet name="Wayfinder Basic Usage" lang="typescript"> // Import controller methods (tree-shakable) import { show, store, update } from '@/actions/App/Http/Controllers/PostController'// Get route object with URL and method...
show(1) // { url: "/posts/1", method: "get" }
// Get just the URL...
show.url(1) // "/posts/1"
// Use specific HTTP methods...
show.get(1) // { url: "/posts/1", method: "get" }
show.head(1) // { url: "/posts/1", method: "head" }
// Import named routes...
import { show as postShow } from '@/routes/post' // For route name 'post.show'
postShow(1) // { url: "/posts/1", method: "get" }
</code-snippet>
Wayfinder + Inertia
If your application uses the <Form> component from Inertia, you can use Wayfinder to generate form action and method automatically.
<code-snippet name="Wayfinder Form Component (React)" lang="typescript">
Next.js App Router Expert
Development
A skill that turns Claude into a Next.js App Router expert.
README Generator
Development
Creates professional and comprehensive README.md files for your projects.
API Documentation Writer
Development
Generates comprehensive API documentation in OpenAPI/Swagger format.