chore: add laravel/boost and AI agent configuration files
This commit is contained in:
128
.agents/skills/developing-with-fortify/SKILL.md
Normal file
128
.agents/skills/developing-with-fortify/SKILL.md
Normal file
@@ -0,0 +1,128 @@
|
|||||||
|
---
|
||||||
|
name: developing-with-fortify
|
||||||
|
description: Laravel Fortify headless authentication backend development. Activate when implementing authentication features including login, registration, password reset, email verification, two-factor authentication (2FA/TOTP), profile updates, headless auth, authentication scaffolding, or auth guards in Laravel applications.
|
||||||
|
---
|
||||||
|
|
||||||
|
# Laravel Fortify Development
|
||||||
|
|
||||||
|
Fortify is a headless authentication backend that provides authentication routes and controllers for Laravel applications.
|
||||||
|
|
||||||
|
## Documentation
|
||||||
|
|
||||||
|
Use `search-docs` for detailed Laravel Fortify patterns and documentation.
|
||||||
|
|
||||||
|
## Usage
|
||||||
|
|
||||||
|
- **Routes**: Use `list-routes` with `only_vendor: true` and `action: "Fortify"` to see all registered endpoints
|
||||||
|
- **Actions**: Check `app/Actions/Fortify/` for customizable business logic (user creation, password validation, etc.)
|
||||||
|
- **Config**: See `config/fortify.php` for all options including features, guards, rate limiters, and username field
|
||||||
|
- **Contracts**: Look in `Laravel\Fortify\Contracts\` for overridable response classes (`LoginResponse`, `LogoutResponse`, etc.)
|
||||||
|
- **Views**: All view callbacks are set in `FortifyServiceProvider::boot()` using `Fortify::loginView()`, `Fortify::registerView()`, etc.
|
||||||
|
|
||||||
|
## Available Features
|
||||||
|
|
||||||
|
Enable in `config/fortify.php` features array:
|
||||||
|
|
||||||
|
- `Features::registration()` - User registration
|
||||||
|
- `Features::resetPasswords()` - Password reset via email
|
||||||
|
- `Features::emailVerification()` - Requires User to implement `MustVerifyEmail`
|
||||||
|
- `Features::updateProfileInformation()` - Profile updates
|
||||||
|
- `Features::updatePasswords()` - Password changes
|
||||||
|
- `Features::twoFactorAuthentication()` - 2FA with QR codes and recovery codes
|
||||||
|
|
||||||
|
> Use `search-docs` for feature configuration options and customization patterns.
|
||||||
|
|
||||||
|
## Setup Workflows
|
||||||
|
|
||||||
|
### Two-Factor Authentication Setup
|
||||||
|
|
||||||
|
```
|
||||||
|
- [ ] Add TwoFactorAuthenticatable trait to User model
|
||||||
|
- [ ] Enable feature in config/fortify.php
|
||||||
|
- [ ] If the `*_add_two_factor_columns_to_users_table.php` migration is missing, publish via `php artisan vendor:publish --tag=fortify-migrations` and migrate
|
||||||
|
- [ ] Set up view callbacks in FortifyServiceProvider
|
||||||
|
- [ ] Create 2FA management UI
|
||||||
|
- [ ] Test QR code and recovery codes
|
||||||
|
```
|
||||||
|
|
||||||
|
> Use `search-docs` for TOTP implementation and recovery code handling patterns.
|
||||||
|
|
||||||
|
### Email Verification Setup
|
||||||
|
|
||||||
|
```
|
||||||
|
- [ ] Enable emailVerification feature in config
|
||||||
|
- [ ] Implement MustVerifyEmail interface on User model
|
||||||
|
- [ ] Set up verifyEmailView callback
|
||||||
|
- [ ] Add verified middleware to protected routes
|
||||||
|
- [ ] Test verification email flow
|
||||||
|
```
|
||||||
|
|
||||||
|
> Use `search-docs` for MustVerifyEmail implementation patterns.
|
||||||
|
|
||||||
|
### Password Reset Setup
|
||||||
|
|
||||||
|
```
|
||||||
|
- [ ] Enable resetPasswords feature in config
|
||||||
|
- [ ] Set up requestPasswordResetLinkView callback
|
||||||
|
- [ ] Set up resetPasswordView callback
|
||||||
|
- [ ] Define password.reset named route (if views disabled)
|
||||||
|
- [ ] Test reset email and link flow
|
||||||
|
```
|
||||||
|
|
||||||
|
> Use `search-docs` for custom password reset flow patterns.
|
||||||
|
|
||||||
|
### SPA Authentication Setup
|
||||||
|
|
||||||
|
```
|
||||||
|
- [ ] Set 'views' => false in config/fortify.php
|
||||||
|
- [ ] Install and configure Laravel Sanctum for session-based SPA authentication
|
||||||
|
- [ ] Use the 'web' guard in config/fortify.php (required for session-based authentication)
|
||||||
|
- [ ] Set up CSRF token handling
|
||||||
|
- [ ] Test XHR authentication flows
|
||||||
|
```
|
||||||
|
|
||||||
|
> Use `search-docs` for integration and SPA authentication patterns.
|
||||||
|
|
||||||
|
#### Two-Factor Authentication in SPA Mode
|
||||||
|
|
||||||
|
When `views` is set to `false`, Fortify returns JSON responses instead of redirects.
|
||||||
|
|
||||||
|
If a user attempts to log in and two-factor authentication is enabled, the login request will return a JSON response indicating that a two-factor challenge is required:
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"two_factor": true
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## Best Practices
|
||||||
|
|
||||||
|
### Custom Authentication Logic
|
||||||
|
|
||||||
|
Override authentication behavior using `Fortify::authenticateUsing()` for custom user retrieval or `Fortify::authenticateThrough()` to customize the authentication pipeline. Override response contracts in `AppServiceProvider` for custom redirects.
|
||||||
|
|
||||||
|
### Registration Customization
|
||||||
|
|
||||||
|
Modify `app/Actions/Fortify/CreateNewUser.php` to customize user creation logic, validation rules, and additional fields.
|
||||||
|
|
||||||
|
### Rate Limiting
|
||||||
|
|
||||||
|
Configure via `fortify.limiters.login` in config. Default configuration throttles by username + IP combination.
|
||||||
|
|
||||||
|
## Key Endpoints
|
||||||
|
|
||||||
|
| Feature | Method | Endpoint |
|
||||||
|
|------------------------|----------|---------------------------------------------|
|
||||||
|
| Login | POST | `/login` |
|
||||||
|
| Logout | POST | `/logout` |
|
||||||
|
| Register | POST | `/register` |
|
||||||
|
| Password Reset Request | POST | `/forgot-password` |
|
||||||
|
| Password Reset | POST | `/reset-password` |
|
||||||
|
| Email Verify Notice | GET | `/email/verify` |
|
||||||
|
| Resend Verification | POST | `/email/verification-notification` |
|
||||||
|
| Password Confirm | POST | `/user/confirm-password` |
|
||||||
|
| Enable 2FA | POST | `/user/two-factor-authentication` |
|
||||||
|
| Confirm 2FA | POST | `/user/confirmed-two-factor-authentication` |
|
||||||
|
| 2FA Challenge | POST | `/two-factor-challenge` |
|
||||||
|
| Get QR Code | GET | `/user/two-factor-qr-code` |
|
||||||
|
| Recovery Codes | GET/POST | `/user/two-factor-recovery-codes` |
|
||||||
124
.agents/skills/filament-db-config/SKILL.md
Normal file
124
.agents/skills/filament-db-config/SKILL.md
Normal file
@@ -0,0 +1,124 @@
|
|||||||
|
---
|
||||||
|
name: filament-db-config
|
||||||
|
description: >-
|
||||||
|
Creates database-backed settings pages and config pages with filament-db-config or db-config package.
|
||||||
|
Activates when creating settings page, config page, configuration page, or when user mentions db-config,
|
||||||
|
db_config, DbConfig, database settings, dynamic configuration, runtime config, storing settings in database.
|
||||||
|
ALWAYS use php artisan make:db-config command to scaffold. NEVER create files manually. NEVER create tests.
|
||||||
|
---
|
||||||
|
|
||||||
|
# Filament DB Config
|
||||||
|
|
||||||
|
## When to Apply
|
||||||
|
|
||||||
|
Activate this skill when:
|
||||||
|
|
||||||
|
- Creating settings pages or config pages
|
||||||
|
- Working with db-config, db_config(), DbConfig
|
||||||
|
- User mentions database settings, dynamic configuration
|
||||||
|
- User asks to store configuration in database
|
||||||
|
|
||||||
|
## Documentation
|
||||||
|
|
||||||
|
Use `search-docs` for Filament form components and patterns. Do NOT rely on training data — always check the installed Filament version documentation.
|
||||||
|
|
||||||
|
## Critical Workflow
|
||||||
|
|
||||||
|
STEP 1: Always scaffold with artisan command first:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
php artisan make:db-config HomeSeo --no-interaction
|
||||||
|
```
|
||||||
|
|
||||||
|
IMPORTANT: Only pass the Name. NEVER add a second argument like "admin" or "panel". The command only takes one argument.
|
||||||
|
This generates `app/Filament/Pages/{Name}Settings.php`. The generator automatically adds "Settings" suffix.
|
||||||
|
|
||||||
|
STEP 2: Edit the generated file to add your fields in the `form()` method.
|
||||||
|
|
||||||
|
NEVER create files manually.
|
||||||
|
|
||||||
|
NEVER create tests. Tests are NOT needed for settings pages.
|
||||||
|
|
||||||
|
## After Scaffolding
|
||||||
|
|
||||||
|
Edit the generated page class to customize the `form()` method:
|
||||||
|
|
||||||
|
<code-snippet name="Settings Page Form Example" lang="php">
|
||||||
|
use Filament\Forms\Components\TextInput;
|
||||||
|
use Filament\Forms\Components\Toggle;
|
||||||
|
use Filament\Schemas\Schema;
|
||||||
|
|
||||||
|
public function form(Schema $schema): Schema
|
||||||
|
{
|
||||||
|
return $schema
|
||||||
|
->components([
|
||||||
|
TextInput::make('site_name')->label('Site Name'),
|
||||||
|
TextInput::make('contact_email')->label('Contact Email'),
|
||||||
|
Toggle::make('maintenance_mode')->label('Maintenance Mode'),
|
||||||
|
])
|
||||||
|
->statePath('data');
|
||||||
|
}
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
## Default Values
|
||||||
|
|
||||||
|
Override `getDefaultData()` to pre-fill the form:
|
||||||
|
|
||||||
|
<code-snippet name="Default Values Example" lang="php">
|
||||||
|
public function getDefaultData(): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'posts_per_page' => 10,
|
||||||
|
'allow_comments' => true,
|
||||||
|
];
|
||||||
|
}
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
## Reading Values
|
||||||
|
|
||||||
|
<code-snippet name="Reading db_config Values" lang="php">
|
||||||
|
// Standard helper
|
||||||
|
$siteName = db_config('website.site_name', 'Default');
|
||||||
|
|
||||||
|
// Safe helper (for early boot, migrations, service providers)
|
||||||
|
$siteName = safe_db_config('website.site_name', 'Default');
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
Blade directive:
|
||||||
|
|
||||||
|
<code-snippet name="Blade Directive" lang="blade">
|
||||||
|
<h1>@db_config('website.site_name', 'Default')</h1>
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
## Writing Values
|
||||||
|
|
||||||
|
<code-snippet name="Writing Values Programmatically" lang="php">
|
||||||
|
use Inerba\DbConfig\DbConfig;
|
||||||
|
|
||||||
|
DbConfig::set('website.site_name', 'Acme Inc.');
|
||||||
|
$group = DbConfig::getGroup('website');
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
## IMPORTANT: Do NOT Create Tests
|
||||||
|
|
||||||
|
Do NOT create any test files for db-config settings pages. Tests are NOT needed and NOT wanted unless the user explicitly asks for them.
|
||||||
|
|
||||||
|
## Filament Property Types
|
||||||
|
|
||||||
|
When setting Filament page properties, always use the correct union types:
|
||||||
|
|
||||||
|
<code-snippet name="Correct Property Types" lang="php">
|
||||||
|
protected static string | BackedEnum | null $navigationIcon = 'heroicon-o-cog';
|
||||||
|
protected static ?string $navigationGroup = 'Settings';
|
||||||
|
protected static ?int $navigationSort = 10;
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
NEVER write `protected static string $navigationIcon` — always include `| BackedEnum | null`.
|
||||||
|
|
||||||
|
## Common Mistakes
|
||||||
|
|
||||||
|
- NEVER create files manually — always run `php artisan make:db-config` first
|
||||||
|
- NEVER create tests — no tests for settings pages unless explicitly requested
|
||||||
|
- NEVER use `config()` — always use `db_config()` helper
|
||||||
|
- NEVER forget `statePath('data')` — forms must have `->statePath('data')`
|
||||||
|
- NEVER forget union types — navigationIcon must be `string | BackedEnum | null`
|
||||||
89
.agents/skills/fluxui-development/SKILL.md
Normal file
89
.agents/skills/fluxui-development/SKILL.md
Normal file
@@ -0,0 +1,89 @@
|
|||||||
|
---
|
||||||
|
name: fluxui-development
|
||||||
|
description: "Develops UIs with Flux UI Free components. Activates when creating buttons, forms, modals, inputs, dropdowns, checkboxes, or UI components; replacing HTML form elements with Flux; working with flux: components; or when the user mentions Flux, component library, UI components, form fields, or asks about available Flux components."
|
||||||
|
license: MIT
|
||||||
|
metadata:
|
||||||
|
author: laravel
|
||||||
|
---
|
||||||
|
|
||||||
|
# Flux UI Development
|
||||||
|
|
||||||
|
## When to Apply
|
||||||
|
|
||||||
|
Activate this skill when:
|
||||||
|
|
||||||
|
- Creating UI components or pages
|
||||||
|
- Working with forms, modals, or interactive elements
|
||||||
|
- Checking available Flux components
|
||||||
|
|
||||||
|
## Documentation
|
||||||
|
|
||||||
|
Use `search-docs` for detailed Flux UI patterns and documentation.
|
||||||
|
|
||||||
|
## Basic Usage
|
||||||
|
|
||||||
|
This project uses the free edition of Flux UI, which includes all free components and variants but not Pro components.
|
||||||
|
|
||||||
|
Flux UI is a component library for Livewire built with Tailwind CSS. It provides components that are easy to use and customize.
|
||||||
|
|
||||||
|
Use Flux UI components when available. Fall back to standard Blade components when no Flux component exists for your needs.
|
||||||
|
|
||||||
|
<!-- Basic Button -->
|
||||||
|
```blade
|
||||||
|
<flux:button variant="primary">Click me</flux:button>
|
||||||
|
```
|
||||||
|
|
||||||
|
## Available Components (Free Edition)
|
||||||
|
|
||||||
|
Available: avatar, badge, brand, breadcrumbs, button, callout, checkbox, dropdown, field, heading, icon, input, modal, navbar, otp-input, profile, radio, select, separator, skeleton, switch, text, textarea, tooltip
|
||||||
|
|
||||||
|
## Icons
|
||||||
|
|
||||||
|
Flux includes [Heroicons](https://heroicons.com/) as its default icon set. Search for exact icon names on the Heroicons site - do not guess or invent icon names.
|
||||||
|
|
||||||
|
<!-- Icon Button -->
|
||||||
|
```blade
|
||||||
|
<flux:button icon="arrow-down-tray">Export</flux:button>
|
||||||
|
```
|
||||||
|
|
||||||
|
For icons not available in Heroicons, use [Lucide](https://lucide.dev/). Import the icons you need with the Artisan command:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
php artisan flux:icon crown grip-vertical github
|
||||||
|
```
|
||||||
|
|
||||||
|
## Common Patterns
|
||||||
|
|
||||||
|
### Form Fields
|
||||||
|
|
||||||
|
<!-- Form Field -->
|
||||||
|
```blade
|
||||||
|
<flux:field>
|
||||||
|
<flux:label>Email</flux:label>
|
||||||
|
<flux:input type="email" wire:model="email" />
|
||||||
|
<flux:error name="email" />
|
||||||
|
</flux:field>
|
||||||
|
```
|
||||||
|
|
||||||
|
### Modals
|
||||||
|
|
||||||
|
<!-- Modal -->
|
||||||
|
```blade
|
||||||
|
<flux:modal wire:model="showModal">
|
||||||
|
<flux:heading>Title</flux:heading>
|
||||||
|
<p>Content</p>
|
||||||
|
</flux:modal>
|
||||||
|
```
|
||||||
|
|
||||||
|
## Verification
|
||||||
|
|
||||||
|
1. Check component renders correctly
|
||||||
|
2. Test interactive states
|
||||||
|
3. Verify mobile responsiveness
|
||||||
|
|
||||||
|
## Common Pitfalls
|
||||||
|
|
||||||
|
- Trying to use Pro-only components in the free edition
|
||||||
|
- Not checking if a Flux component exists before creating custom implementations
|
||||||
|
- Forgetting to use the `search-docs` tool for component-specific documentation
|
||||||
|
- Not following existing project patterns for Flux usage
|
||||||
117
.agents/skills/pest-testing/SKILL.md
Normal file
117
.agents/skills/pest-testing/SKILL.md
Normal file
@@ -0,0 +1,117 @@
|
|||||||
|
---
|
||||||
|
name: pest-testing
|
||||||
|
description: "Tests applications using the Pest 3 PHP framework. Activates when writing tests, creating unit or feature tests, adding assertions, testing Livewire components, architecture testing, debugging test failures, working with datasets or mocking; or when the user mentions test, spec, TDD, expects, assertion, coverage, or needs to verify functionality works."
|
||||||
|
license: MIT
|
||||||
|
metadata:
|
||||||
|
author: laravel
|
||||||
|
---
|
||||||
|
|
||||||
|
# Pest Testing 3
|
||||||
|
|
||||||
|
## When to Apply
|
||||||
|
|
||||||
|
Activate this skill when:
|
||||||
|
- Creating new tests (unit or feature)
|
||||||
|
- Modifying existing tests
|
||||||
|
- Debugging test failures
|
||||||
|
- Working with datasets, mocking, or test organization
|
||||||
|
- Writing architecture tests
|
||||||
|
|
||||||
|
## Documentation
|
||||||
|
|
||||||
|
Use `search-docs` for detailed Pest 3 patterns and documentation.
|
||||||
|
|
||||||
|
## Basic Usage
|
||||||
|
|
||||||
|
### Creating Tests
|
||||||
|
|
||||||
|
All tests must be written using Pest. Use `php artisan make:test --pest {name}`.
|
||||||
|
|
||||||
|
### Test Organization
|
||||||
|
|
||||||
|
- Tests live in the `tests/Feature` and `tests/Unit` directories.
|
||||||
|
- Do NOT remove tests without approval - these are core application code.
|
||||||
|
- Test happy paths, failure paths, and edge cases.
|
||||||
|
|
||||||
|
### Basic Test Structure
|
||||||
|
|
||||||
|
<!-- Basic Pest Test Example -->
|
||||||
|
```php
|
||||||
|
it('is true', function () {
|
||||||
|
expect(true)->toBeTrue();
|
||||||
|
});
|
||||||
|
```
|
||||||
|
|
||||||
|
### Running Tests
|
||||||
|
|
||||||
|
- Run minimal tests with filter before finalizing: `php artisan test --compact --filter=testName`.
|
||||||
|
- Run all tests: `php artisan test --compact`.
|
||||||
|
- Run file: `php artisan test --compact tests/Feature/ExampleTest.php`.
|
||||||
|
|
||||||
|
## Assertions
|
||||||
|
|
||||||
|
Use specific assertions (`assertSuccessful()`, `assertNotFound()`) instead of `assertStatus()`:
|
||||||
|
|
||||||
|
<!-- Pest Response Assertion -->
|
||||||
|
```php
|
||||||
|
it('returns all', function () {
|
||||||
|
$this->postJson('/api/docs', [])->assertSuccessful();
|
||||||
|
});
|
||||||
|
```
|
||||||
|
|
||||||
|
| Use | Instead of |
|
||||||
|
|-----|------------|
|
||||||
|
| `assertSuccessful()` | `assertStatus(200)` |
|
||||||
|
| `assertNotFound()` | `assertStatus(404)` |
|
||||||
|
| `assertForbidden()` | `assertStatus(403)` |
|
||||||
|
|
||||||
|
## Mocking
|
||||||
|
|
||||||
|
Import mock function before use: `use function Pest\Laravel\mock;`
|
||||||
|
|
||||||
|
## Datasets
|
||||||
|
|
||||||
|
Use datasets for repetitive tests (validation rules, etc.):
|
||||||
|
|
||||||
|
<!-- Pest Dataset Example -->
|
||||||
|
```php
|
||||||
|
it('has emails', function (string $email) {
|
||||||
|
expect($email)->not->toBeEmpty();
|
||||||
|
})->with([
|
||||||
|
'james' => 'james@laravel.com',
|
||||||
|
'taylor' => 'taylor@laravel.com',
|
||||||
|
]);
|
||||||
|
```
|
||||||
|
|
||||||
|
## Pest 3 Features
|
||||||
|
|
||||||
|
### Architecture Testing
|
||||||
|
|
||||||
|
Pest 3 includes architecture testing to enforce code conventions:
|
||||||
|
|
||||||
|
<!-- Architecture Test Example -->
|
||||||
|
```php
|
||||||
|
arch('controllers')
|
||||||
|
->expect('App\Http\Controllers')
|
||||||
|
->toExtendNothing()
|
||||||
|
->toHaveSuffix('Controller');
|
||||||
|
|
||||||
|
arch('models')
|
||||||
|
->expect('App\Models')
|
||||||
|
->toExtend('Illuminate\Database\Eloquent\Model');
|
||||||
|
|
||||||
|
arch('no debugging')
|
||||||
|
->expect(['dd', 'dump', 'ray'])
|
||||||
|
->not->toBeUsed();
|
||||||
|
```
|
||||||
|
|
||||||
|
### Type Coverage
|
||||||
|
|
||||||
|
Pest 3 provides improved type coverage analysis. Run with `--type-coverage` flag.
|
||||||
|
|
||||||
|
## Common Pitfalls
|
||||||
|
|
||||||
|
- Not importing `use function Pest\Laravel\mock;` before using mock
|
||||||
|
- Using `assertStatus(200)` instead of `assertSuccessful()`
|
||||||
|
- Forgetting datasets for repetitive validation tests
|
||||||
|
- Deleting tests without approval
|
||||||
129
.agents/skills/tailwindcss-development/SKILL.md
Normal file
129
.agents/skills/tailwindcss-development/SKILL.md
Normal file
@@ -0,0 +1,129 @@
|
|||||||
|
---
|
||||||
|
name: tailwindcss-development
|
||||||
|
description: "Styles applications using Tailwind CSS v4 utilities. Activates when adding styles, restyling components, working with gradients, spacing, layout, flex, grid, responsive design, dark mode, colors, typography, or borders; or when the user mentions CSS, styling, classes, Tailwind, restyle, hero section, cards, buttons, or any visual/UI changes."
|
||||||
|
license: MIT
|
||||||
|
metadata:
|
||||||
|
author: laravel
|
||||||
|
---
|
||||||
|
|
||||||
|
# Tailwind CSS Development
|
||||||
|
|
||||||
|
## When to Apply
|
||||||
|
|
||||||
|
Activate this skill when:
|
||||||
|
|
||||||
|
- Adding styles to components or pages
|
||||||
|
- Working with responsive design
|
||||||
|
- Implementing dark mode
|
||||||
|
- Extracting repeated patterns into components
|
||||||
|
- Debugging spacing or layout issues
|
||||||
|
|
||||||
|
## Documentation
|
||||||
|
|
||||||
|
Use `search-docs` for detailed Tailwind CSS v4 patterns and documentation.
|
||||||
|
|
||||||
|
## Basic Usage
|
||||||
|
|
||||||
|
- Use Tailwind CSS classes to style HTML. Check and follow existing Tailwind conventions in the project before introducing new patterns.
|
||||||
|
- Offer to extract repeated patterns into components that match the project's conventions (e.g., Blade, JSX, Vue).
|
||||||
|
- Consider class placement, order, priority, and defaults. Remove redundant classes, add classes to parent or child elements carefully to reduce repetition, and group elements logically.
|
||||||
|
|
||||||
|
## Tailwind CSS v4 Specifics
|
||||||
|
|
||||||
|
- Always use Tailwind CSS v4 and avoid deprecated utilities.
|
||||||
|
- `corePlugins` is not supported in Tailwind v4.
|
||||||
|
|
||||||
|
### CSS-First Configuration
|
||||||
|
|
||||||
|
In Tailwind v4, configuration is CSS-first using the `@theme` directive — no separate `tailwind.config.js` file is needed:
|
||||||
|
|
||||||
|
<!-- CSS-First Config -->
|
||||||
|
```css
|
||||||
|
@theme {
|
||||||
|
--color-brand: oklch(0.72 0.11 178);
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### Import Syntax
|
||||||
|
|
||||||
|
In Tailwind v4, import Tailwind with a regular CSS `@import` statement instead of the `@tailwind` directives used in v3:
|
||||||
|
|
||||||
|
<!-- v4 Import Syntax -->
|
||||||
|
```diff
|
||||||
|
- @tailwind base;
|
||||||
|
- @tailwind components;
|
||||||
|
- @tailwind utilities;
|
||||||
|
+ @import "tailwindcss";
|
||||||
|
```
|
||||||
|
|
||||||
|
### Replaced Utilities
|
||||||
|
|
||||||
|
Tailwind v4 removed deprecated utilities. Use the replacements shown below. Opacity values remain numeric.
|
||||||
|
|
||||||
|
| Deprecated | Replacement |
|
||||||
|
|------------|-------------|
|
||||||
|
| bg-opacity-* | bg-black/* |
|
||||||
|
| text-opacity-* | text-black/* |
|
||||||
|
| border-opacity-* | border-black/* |
|
||||||
|
| divide-opacity-* | divide-black/* |
|
||||||
|
| ring-opacity-* | ring-black/* |
|
||||||
|
| placeholder-opacity-* | placeholder-black/* |
|
||||||
|
| flex-shrink-* | shrink-* |
|
||||||
|
| flex-grow-* | grow-* |
|
||||||
|
| overflow-ellipsis | text-ellipsis |
|
||||||
|
| decoration-slice | box-decoration-slice |
|
||||||
|
| decoration-clone | box-decoration-clone |
|
||||||
|
|
||||||
|
## Spacing
|
||||||
|
|
||||||
|
Use `gap` utilities instead of margins for spacing between siblings:
|
||||||
|
|
||||||
|
<!-- Gap Utilities -->
|
||||||
|
```html
|
||||||
|
<div class="flex gap-8">
|
||||||
|
<div>Item 1</div>
|
||||||
|
<div>Item 2</div>
|
||||||
|
</div>
|
||||||
|
```
|
||||||
|
|
||||||
|
## Dark Mode
|
||||||
|
|
||||||
|
If existing pages and components support dark mode, new pages and components must support it the same way, typically using the `dark:` variant:
|
||||||
|
|
||||||
|
<!-- Dark Mode -->
|
||||||
|
```html
|
||||||
|
<div class="bg-white dark:bg-gray-900 text-gray-900 dark:text-white">
|
||||||
|
Content adapts to color scheme
|
||||||
|
</div>
|
||||||
|
```
|
||||||
|
|
||||||
|
## Common Patterns
|
||||||
|
|
||||||
|
### Flexbox Layout
|
||||||
|
|
||||||
|
<!-- Flexbox Layout -->
|
||||||
|
```html
|
||||||
|
<div class="flex items-center justify-between gap-4">
|
||||||
|
<div>Left content</div>
|
||||||
|
<div>Right content</div>
|
||||||
|
</div>
|
||||||
|
```
|
||||||
|
|
||||||
|
### Grid Layout
|
||||||
|
|
||||||
|
<!-- Grid Layout -->
|
||||||
|
```html
|
||||||
|
<div class="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-6">
|
||||||
|
<div>Card 1</div>
|
||||||
|
<div>Card 2</div>
|
||||||
|
<div>Card 3</div>
|
||||||
|
</div>
|
||||||
|
```
|
||||||
|
|
||||||
|
## Common Pitfalls
|
||||||
|
|
||||||
|
- Using deprecated v3 utilities (bg-opacity-*, flex-shrink-*, etc.)
|
||||||
|
- Using `@tailwind` directives instead of `@import "tailwindcss"`
|
||||||
|
- Trying to use `tailwind.config.js` instead of CSS `@theme` directive
|
||||||
|
- Using margins for spacing between siblings instead of gap utilities
|
||||||
|
- Forgetting to add dark mode variants when the project uses dark mode
|
||||||
96
.agents/skills/volt-development/SKILL.md
Normal file
96
.agents/skills/volt-development/SKILL.md
Normal file
@@ -0,0 +1,96 @@
|
|||||||
|
---
|
||||||
|
name: volt-development
|
||||||
|
description: "Develops single-file Livewire components with Volt. Activates when creating Volt components, converting Livewire to Volt, working with @volt directive, functional or class-based Volt APIs; or when the user mentions Volt, single-file components, functional Livewire, or inline component logic in Blade files."
|
||||||
|
license: MIT
|
||||||
|
metadata:
|
||||||
|
author: laravel
|
||||||
|
---
|
||||||
|
|
||||||
|
# Volt Development
|
||||||
|
|
||||||
|
## When to Apply
|
||||||
|
|
||||||
|
Activate this skill when:
|
||||||
|
|
||||||
|
- Creating Volt single-file components
|
||||||
|
- Converting traditional Livewire components to Volt
|
||||||
|
- Testing Volt components
|
||||||
|
|
||||||
|
## Documentation
|
||||||
|
|
||||||
|
Use `search-docs` for detailed Volt patterns and documentation.
|
||||||
|
|
||||||
|
## Basic Usage
|
||||||
|
|
||||||
|
Create components with `php artisan make:volt [name] [--test] [--pest]`.
|
||||||
|
|
||||||
|
Important: Check existing Volt components to determine if they use functional or class-based style before creating new ones.
|
||||||
|
|
||||||
|
### Functional Components
|
||||||
|
|
||||||
|
<!-- Volt Functional Component -->
|
||||||
|
```php
|
||||||
|
@@volt
|
||||||
|
<?php
|
||||||
|
use function Livewire\Volt\{state, computed};
|
||||||
|
|
||||||
|
state(['count' => 0]);
|
||||||
|
|
||||||
|
$increment = fn () => $this->count++;
|
||||||
|
$double = computed(fn () => $this->count * 2);
|
||||||
|
?>
|
||||||
|
|
||||||
|
<div>
|
||||||
|
<h1>Count: @{{ $count }} (Double: @{{ $this->double }})</h1>
|
||||||
|
<button wire:click="increment">+</button>
|
||||||
|
</div>
|
||||||
|
@@endvolt
|
||||||
|
```
|
||||||
|
|
||||||
|
### Class-Based Components
|
||||||
|
|
||||||
|
<!-- Volt Class-based Component -->
|
||||||
|
```php
|
||||||
|
use Livewire\Volt\Component;
|
||||||
|
|
||||||
|
new class extends Component {
|
||||||
|
public int $count = 0;
|
||||||
|
|
||||||
|
public function increment(): void
|
||||||
|
{
|
||||||
|
$this->count++;
|
||||||
|
}
|
||||||
|
} ?>
|
||||||
|
|
||||||
|
<div>
|
||||||
|
<h1>@{{ $count }}</h1>
|
||||||
|
<button wire:click="increment">+</button>
|
||||||
|
</div>
|
||||||
|
```
|
||||||
|
|
||||||
|
## Testing
|
||||||
|
|
||||||
|
Tests go in existing Volt test directory or `tests/Feature/Volt`:
|
||||||
|
|
||||||
|
<!-- Volt Test Example -->
|
||||||
|
```php
|
||||||
|
use Livewire\Volt\Volt;
|
||||||
|
|
||||||
|
test('counter increments', function () {
|
||||||
|
Volt::test('counter')
|
||||||
|
->assertSee('Count: 0')
|
||||||
|
->call('increment')
|
||||||
|
->assertSee('Count: 1');
|
||||||
|
});
|
||||||
|
```
|
||||||
|
|
||||||
|
## Verification
|
||||||
|
|
||||||
|
1. Check existing components for functional vs class-based style
|
||||||
|
2. Test component with `Volt::test()`
|
||||||
|
|
||||||
|
## Common Pitfalls
|
||||||
|
|
||||||
|
- Not checking existing style (functional vs class-based) before creating
|
||||||
|
- Forgetting `@volt` directive wrapper
|
||||||
|
- Missing `--test` or `--pest` flag when tests are needed
|
||||||
128
.claude/skills/developing-with-fortify/SKILL.md
Normal file
128
.claude/skills/developing-with-fortify/SKILL.md
Normal file
@@ -0,0 +1,128 @@
|
|||||||
|
---
|
||||||
|
name: developing-with-fortify
|
||||||
|
description: Laravel Fortify headless authentication backend development. Activate when implementing authentication features including login, registration, password reset, email verification, two-factor authentication (2FA/TOTP), profile updates, headless auth, authentication scaffolding, or auth guards in Laravel applications.
|
||||||
|
---
|
||||||
|
|
||||||
|
# Laravel Fortify Development
|
||||||
|
|
||||||
|
Fortify is a headless authentication backend that provides authentication routes and controllers for Laravel applications.
|
||||||
|
|
||||||
|
## Documentation
|
||||||
|
|
||||||
|
Use `search-docs` for detailed Laravel Fortify patterns and documentation.
|
||||||
|
|
||||||
|
## Usage
|
||||||
|
|
||||||
|
- **Routes**: Use `list-routes` with `only_vendor: true` and `action: "Fortify"` to see all registered endpoints
|
||||||
|
- **Actions**: Check `app/Actions/Fortify/` for customizable business logic (user creation, password validation, etc.)
|
||||||
|
- **Config**: See `config/fortify.php` for all options including features, guards, rate limiters, and username field
|
||||||
|
- **Contracts**: Look in `Laravel\Fortify\Contracts\` for overridable response classes (`LoginResponse`, `LogoutResponse`, etc.)
|
||||||
|
- **Views**: All view callbacks are set in `FortifyServiceProvider::boot()` using `Fortify::loginView()`, `Fortify::registerView()`, etc.
|
||||||
|
|
||||||
|
## Available Features
|
||||||
|
|
||||||
|
Enable in `config/fortify.php` features array:
|
||||||
|
|
||||||
|
- `Features::registration()` - User registration
|
||||||
|
- `Features::resetPasswords()` - Password reset via email
|
||||||
|
- `Features::emailVerification()` - Requires User to implement `MustVerifyEmail`
|
||||||
|
- `Features::updateProfileInformation()` - Profile updates
|
||||||
|
- `Features::updatePasswords()` - Password changes
|
||||||
|
- `Features::twoFactorAuthentication()` - 2FA with QR codes and recovery codes
|
||||||
|
|
||||||
|
> Use `search-docs` for feature configuration options and customization patterns.
|
||||||
|
|
||||||
|
## Setup Workflows
|
||||||
|
|
||||||
|
### Two-Factor Authentication Setup
|
||||||
|
|
||||||
|
```
|
||||||
|
- [ ] Add TwoFactorAuthenticatable trait to User model
|
||||||
|
- [ ] Enable feature in config/fortify.php
|
||||||
|
- [ ] If the `*_add_two_factor_columns_to_users_table.php` migration is missing, publish via `php artisan vendor:publish --tag=fortify-migrations` and migrate
|
||||||
|
- [ ] Set up view callbacks in FortifyServiceProvider
|
||||||
|
- [ ] Create 2FA management UI
|
||||||
|
- [ ] Test QR code and recovery codes
|
||||||
|
```
|
||||||
|
|
||||||
|
> Use `search-docs` for TOTP implementation and recovery code handling patterns.
|
||||||
|
|
||||||
|
### Email Verification Setup
|
||||||
|
|
||||||
|
```
|
||||||
|
- [ ] Enable emailVerification feature in config
|
||||||
|
- [ ] Implement MustVerifyEmail interface on User model
|
||||||
|
- [ ] Set up verifyEmailView callback
|
||||||
|
- [ ] Add verified middleware to protected routes
|
||||||
|
- [ ] Test verification email flow
|
||||||
|
```
|
||||||
|
|
||||||
|
> Use `search-docs` for MustVerifyEmail implementation patterns.
|
||||||
|
|
||||||
|
### Password Reset Setup
|
||||||
|
|
||||||
|
```
|
||||||
|
- [ ] Enable resetPasswords feature in config
|
||||||
|
- [ ] Set up requestPasswordResetLinkView callback
|
||||||
|
- [ ] Set up resetPasswordView callback
|
||||||
|
- [ ] Define password.reset named route (if views disabled)
|
||||||
|
- [ ] Test reset email and link flow
|
||||||
|
```
|
||||||
|
|
||||||
|
> Use `search-docs` for custom password reset flow patterns.
|
||||||
|
|
||||||
|
### SPA Authentication Setup
|
||||||
|
|
||||||
|
```
|
||||||
|
- [ ] Set 'views' => false in config/fortify.php
|
||||||
|
- [ ] Install and configure Laravel Sanctum for session-based SPA authentication
|
||||||
|
- [ ] Use the 'web' guard in config/fortify.php (required for session-based authentication)
|
||||||
|
- [ ] Set up CSRF token handling
|
||||||
|
- [ ] Test XHR authentication flows
|
||||||
|
```
|
||||||
|
|
||||||
|
> Use `search-docs` for integration and SPA authentication patterns.
|
||||||
|
|
||||||
|
#### Two-Factor Authentication in SPA Mode
|
||||||
|
|
||||||
|
When `views` is set to `false`, Fortify returns JSON responses instead of redirects.
|
||||||
|
|
||||||
|
If a user attempts to log in and two-factor authentication is enabled, the login request will return a JSON response indicating that a two-factor challenge is required:
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"two_factor": true
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## Best Practices
|
||||||
|
|
||||||
|
### Custom Authentication Logic
|
||||||
|
|
||||||
|
Override authentication behavior using `Fortify::authenticateUsing()` for custom user retrieval or `Fortify::authenticateThrough()` to customize the authentication pipeline. Override response contracts in `AppServiceProvider` for custom redirects.
|
||||||
|
|
||||||
|
### Registration Customization
|
||||||
|
|
||||||
|
Modify `app/Actions/Fortify/CreateNewUser.php` to customize user creation logic, validation rules, and additional fields.
|
||||||
|
|
||||||
|
### Rate Limiting
|
||||||
|
|
||||||
|
Configure via `fortify.limiters.login` in config. Default configuration throttles by username + IP combination.
|
||||||
|
|
||||||
|
## Key Endpoints
|
||||||
|
|
||||||
|
| Feature | Method | Endpoint |
|
||||||
|
|------------------------|----------|---------------------------------------------|
|
||||||
|
| Login | POST | `/login` |
|
||||||
|
| Logout | POST | `/logout` |
|
||||||
|
| Register | POST | `/register` |
|
||||||
|
| Password Reset Request | POST | `/forgot-password` |
|
||||||
|
| Password Reset | POST | `/reset-password` |
|
||||||
|
| Email Verify Notice | GET | `/email/verify` |
|
||||||
|
| Resend Verification | POST | `/email/verification-notification` |
|
||||||
|
| Password Confirm | POST | `/user/confirm-password` |
|
||||||
|
| Enable 2FA | POST | `/user/two-factor-authentication` |
|
||||||
|
| Confirm 2FA | POST | `/user/confirmed-two-factor-authentication` |
|
||||||
|
| 2FA Challenge | POST | `/two-factor-challenge` |
|
||||||
|
| Get QR Code | GET | `/user/two-factor-qr-code` |
|
||||||
|
| Recovery Codes | GET/POST | `/user/two-factor-recovery-codes` |
|
||||||
124
.claude/skills/filament-db-config/SKILL.md
Normal file
124
.claude/skills/filament-db-config/SKILL.md
Normal file
@@ -0,0 +1,124 @@
|
|||||||
|
---
|
||||||
|
name: filament-db-config
|
||||||
|
description: >-
|
||||||
|
Creates database-backed settings pages and config pages with filament-db-config or db-config package.
|
||||||
|
Activates when creating settings page, config page, configuration page, or when user mentions db-config,
|
||||||
|
db_config, DbConfig, database settings, dynamic configuration, runtime config, storing settings in database.
|
||||||
|
ALWAYS use php artisan make:db-config command to scaffold. NEVER create files manually. NEVER create tests.
|
||||||
|
---
|
||||||
|
|
||||||
|
# Filament DB Config
|
||||||
|
|
||||||
|
## When to Apply
|
||||||
|
|
||||||
|
Activate this skill when:
|
||||||
|
|
||||||
|
- Creating settings pages or config pages
|
||||||
|
- Working with db-config, db_config(), DbConfig
|
||||||
|
- User mentions database settings, dynamic configuration
|
||||||
|
- User asks to store configuration in database
|
||||||
|
|
||||||
|
## Documentation
|
||||||
|
|
||||||
|
Use `search-docs` for Filament form components and patterns. Do NOT rely on training data — always check the installed Filament version documentation.
|
||||||
|
|
||||||
|
## Critical Workflow
|
||||||
|
|
||||||
|
STEP 1: Always scaffold with artisan command first:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
php artisan make:db-config HomeSeo --no-interaction
|
||||||
|
```
|
||||||
|
|
||||||
|
IMPORTANT: Only pass the Name. NEVER add a second argument like "admin" or "panel". The command only takes one argument.
|
||||||
|
This generates `app/Filament/Pages/{Name}Settings.php`. The generator automatically adds "Settings" suffix.
|
||||||
|
|
||||||
|
STEP 2: Edit the generated file to add your fields in the `form()` method.
|
||||||
|
|
||||||
|
NEVER create files manually.
|
||||||
|
|
||||||
|
NEVER create tests. Tests are NOT needed for settings pages.
|
||||||
|
|
||||||
|
## After Scaffolding
|
||||||
|
|
||||||
|
Edit the generated page class to customize the `form()` method:
|
||||||
|
|
||||||
|
<code-snippet name="Settings Page Form Example" lang="php">
|
||||||
|
use Filament\Forms\Components\TextInput;
|
||||||
|
use Filament\Forms\Components\Toggle;
|
||||||
|
use Filament\Schemas\Schema;
|
||||||
|
|
||||||
|
public function form(Schema $schema): Schema
|
||||||
|
{
|
||||||
|
return $schema
|
||||||
|
->components([
|
||||||
|
TextInput::make('site_name')->label('Site Name'),
|
||||||
|
TextInput::make('contact_email')->label('Contact Email'),
|
||||||
|
Toggle::make('maintenance_mode')->label('Maintenance Mode'),
|
||||||
|
])
|
||||||
|
->statePath('data');
|
||||||
|
}
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
## Default Values
|
||||||
|
|
||||||
|
Override `getDefaultData()` to pre-fill the form:
|
||||||
|
|
||||||
|
<code-snippet name="Default Values Example" lang="php">
|
||||||
|
public function getDefaultData(): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'posts_per_page' => 10,
|
||||||
|
'allow_comments' => true,
|
||||||
|
];
|
||||||
|
}
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
## Reading Values
|
||||||
|
|
||||||
|
<code-snippet name="Reading db_config Values" lang="php">
|
||||||
|
// Standard helper
|
||||||
|
$siteName = db_config('website.site_name', 'Default');
|
||||||
|
|
||||||
|
// Safe helper (for early boot, migrations, service providers)
|
||||||
|
$siteName = safe_db_config('website.site_name', 'Default');
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
Blade directive:
|
||||||
|
|
||||||
|
<code-snippet name="Blade Directive" lang="blade">
|
||||||
|
<h1>@db_config('website.site_name', 'Default')</h1>
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
## Writing Values
|
||||||
|
|
||||||
|
<code-snippet name="Writing Values Programmatically" lang="php">
|
||||||
|
use Inerba\DbConfig\DbConfig;
|
||||||
|
|
||||||
|
DbConfig::set('website.site_name', 'Acme Inc.');
|
||||||
|
$group = DbConfig::getGroup('website');
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
## IMPORTANT: Do NOT Create Tests
|
||||||
|
|
||||||
|
Do NOT create any test files for db-config settings pages. Tests are NOT needed and NOT wanted unless the user explicitly asks for them.
|
||||||
|
|
||||||
|
## Filament Property Types
|
||||||
|
|
||||||
|
When setting Filament page properties, always use the correct union types:
|
||||||
|
|
||||||
|
<code-snippet name="Correct Property Types" lang="php">
|
||||||
|
protected static string | BackedEnum | null $navigationIcon = 'heroicon-o-cog';
|
||||||
|
protected static ?string $navigationGroup = 'Settings';
|
||||||
|
protected static ?int $navigationSort = 10;
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
NEVER write `protected static string $navigationIcon` — always include `| BackedEnum | null`.
|
||||||
|
|
||||||
|
## Common Mistakes
|
||||||
|
|
||||||
|
- NEVER create files manually — always run `php artisan make:db-config` first
|
||||||
|
- NEVER create tests — no tests for settings pages unless explicitly requested
|
||||||
|
- NEVER use `config()` — always use `db_config()` helper
|
||||||
|
- NEVER forget `statePath('data')` — forms must have `->statePath('data')`
|
||||||
|
- NEVER forget union types — navigationIcon must be `string | BackedEnum | null`
|
||||||
89
.claude/skills/fluxui-development/SKILL.md
Normal file
89
.claude/skills/fluxui-development/SKILL.md
Normal file
@@ -0,0 +1,89 @@
|
|||||||
|
---
|
||||||
|
name: fluxui-development
|
||||||
|
description: "Develops UIs with Flux UI Free components. Activates when creating buttons, forms, modals, inputs, dropdowns, checkboxes, or UI components; replacing HTML form elements with Flux; working with flux: components; or when the user mentions Flux, component library, UI components, form fields, or asks about available Flux components."
|
||||||
|
license: MIT
|
||||||
|
metadata:
|
||||||
|
author: laravel
|
||||||
|
---
|
||||||
|
|
||||||
|
# Flux UI Development
|
||||||
|
|
||||||
|
## When to Apply
|
||||||
|
|
||||||
|
Activate this skill when:
|
||||||
|
|
||||||
|
- Creating UI components or pages
|
||||||
|
- Working with forms, modals, or interactive elements
|
||||||
|
- Checking available Flux components
|
||||||
|
|
||||||
|
## Documentation
|
||||||
|
|
||||||
|
Use `search-docs` for detailed Flux UI patterns and documentation.
|
||||||
|
|
||||||
|
## Basic Usage
|
||||||
|
|
||||||
|
This project uses the free edition of Flux UI, which includes all free components and variants but not Pro components.
|
||||||
|
|
||||||
|
Flux UI is a component library for Livewire built with Tailwind CSS. It provides components that are easy to use and customize.
|
||||||
|
|
||||||
|
Use Flux UI components when available. Fall back to standard Blade components when no Flux component exists for your needs.
|
||||||
|
|
||||||
|
<!-- Basic Button -->
|
||||||
|
```blade
|
||||||
|
<flux:button variant="primary">Click me</flux:button>
|
||||||
|
```
|
||||||
|
|
||||||
|
## Available Components (Free Edition)
|
||||||
|
|
||||||
|
Available: avatar, badge, brand, breadcrumbs, button, callout, checkbox, dropdown, field, heading, icon, input, modal, navbar, otp-input, profile, radio, select, separator, skeleton, switch, text, textarea, tooltip
|
||||||
|
|
||||||
|
## Icons
|
||||||
|
|
||||||
|
Flux includes [Heroicons](https://heroicons.com/) as its default icon set. Search for exact icon names on the Heroicons site - do not guess or invent icon names.
|
||||||
|
|
||||||
|
<!-- Icon Button -->
|
||||||
|
```blade
|
||||||
|
<flux:button icon="arrow-down-tray">Export</flux:button>
|
||||||
|
```
|
||||||
|
|
||||||
|
For icons not available in Heroicons, use [Lucide](https://lucide.dev/). Import the icons you need with the Artisan command:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
php artisan flux:icon crown grip-vertical github
|
||||||
|
```
|
||||||
|
|
||||||
|
## Common Patterns
|
||||||
|
|
||||||
|
### Form Fields
|
||||||
|
|
||||||
|
<!-- Form Field -->
|
||||||
|
```blade
|
||||||
|
<flux:field>
|
||||||
|
<flux:label>Email</flux:label>
|
||||||
|
<flux:input type="email" wire:model="email" />
|
||||||
|
<flux:error name="email" />
|
||||||
|
</flux:field>
|
||||||
|
```
|
||||||
|
|
||||||
|
### Modals
|
||||||
|
|
||||||
|
<!-- Modal -->
|
||||||
|
```blade
|
||||||
|
<flux:modal wire:model="showModal">
|
||||||
|
<flux:heading>Title</flux:heading>
|
||||||
|
<p>Content</p>
|
||||||
|
</flux:modal>
|
||||||
|
```
|
||||||
|
|
||||||
|
## Verification
|
||||||
|
|
||||||
|
1. Check component renders correctly
|
||||||
|
2. Test interactive states
|
||||||
|
3. Verify mobile responsiveness
|
||||||
|
|
||||||
|
## Common Pitfalls
|
||||||
|
|
||||||
|
- Trying to use Pro-only components in the free edition
|
||||||
|
- Not checking if a Flux component exists before creating custom implementations
|
||||||
|
- Forgetting to use the `search-docs` tool for component-specific documentation
|
||||||
|
- Not following existing project patterns for Flux usage
|
||||||
117
.claude/skills/pest-testing/SKILL.md
Normal file
117
.claude/skills/pest-testing/SKILL.md
Normal file
@@ -0,0 +1,117 @@
|
|||||||
|
---
|
||||||
|
name: pest-testing
|
||||||
|
description: "Tests applications using the Pest 3 PHP framework. Activates when writing tests, creating unit or feature tests, adding assertions, testing Livewire components, architecture testing, debugging test failures, working with datasets or mocking; or when the user mentions test, spec, TDD, expects, assertion, coverage, or needs to verify functionality works."
|
||||||
|
license: MIT
|
||||||
|
metadata:
|
||||||
|
author: laravel
|
||||||
|
---
|
||||||
|
|
||||||
|
# Pest Testing 3
|
||||||
|
|
||||||
|
## When to Apply
|
||||||
|
|
||||||
|
Activate this skill when:
|
||||||
|
- Creating new tests (unit or feature)
|
||||||
|
- Modifying existing tests
|
||||||
|
- Debugging test failures
|
||||||
|
- Working with datasets, mocking, or test organization
|
||||||
|
- Writing architecture tests
|
||||||
|
|
||||||
|
## Documentation
|
||||||
|
|
||||||
|
Use `search-docs` for detailed Pest 3 patterns and documentation.
|
||||||
|
|
||||||
|
## Basic Usage
|
||||||
|
|
||||||
|
### Creating Tests
|
||||||
|
|
||||||
|
All tests must be written using Pest. Use `php artisan make:test --pest {name}`.
|
||||||
|
|
||||||
|
### Test Organization
|
||||||
|
|
||||||
|
- Tests live in the `tests/Feature` and `tests/Unit` directories.
|
||||||
|
- Do NOT remove tests without approval - these are core application code.
|
||||||
|
- Test happy paths, failure paths, and edge cases.
|
||||||
|
|
||||||
|
### Basic Test Structure
|
||||||
|
|
||||||
|
<!-- Basic Pest Test Example -->
|
||||||
|
```php
|
||||||
|
it('is true', function () {
|
||||||
|
expect(true)->toBeTrue();
|
||||||
|
});
|
||||||
|
```
|
||||||
|
|
||||||
|
### Running Tests
|
||||||
|
|
||||||
|
- Run minimal tests with filter before finalizing: `php artisan test --compact --filter=testName`.
|
||||||
|
- Run all tests: `php artisan test --compact`.
|
||||||
|
- Run file: `php artisan test --compact tests/Feature/ExampleTest.php`.
|
||||||
|
|
||||||
|
## Assertions
|
||||||
|
|
||||||
|
Use specific assertions (`assertSuccessful()`, `assertNotFound()`) instead of `assertStatus()`:
|
||||||
|
|
||||||
|
<!-- Pest Response Assertion -->
|
||||||
|
```php
|
||||||
|
it('returns all', function () {
|
||||||
|
$this->postJson('/api/docs', [])->assertSuccessful();
|
||||||
|
});
|
||||||
|
```
|
||||||
|
|
||||||
|
| Use | Instead of |
|
||||||
|
|-----|------------|
|
||||||
|
| `assertSuccessful()` | `assertStatus(200)` |
|
||||||
|
| `assertNotFound()` | `assertStatus(404)` |
|
||||||
|
| `assertForbidden()` | `assertStatus(403)` |
|
||||||
|
|
||||||
|
## Mocking
|
||||||
|
|
||||||
|
Import mock function before use: `use function Pest\Laravel\mock;`
|
||||||
|
|
||||||
|
## Datasets
|
||||||
|
|
||||||
|
Use datasets for repetitive tests (validation rules, etc.):
|
||||||
|
|
||||||
|
<!-- Pest Dataset Example -->
|
||||||
|
```php
|
||||||
|
it('has emails', function (string $email) {
|
||||||
|
expect($email)->not->toBeEmpty();
|
||||||
|
})->with([
|
||||||
|
'james' => 'james@laravel.com',
|
||||||
|
'taylor' => 'taylor@laravel.com',
|
||||||
|
]);
|
||||||
|
```
|
||||||
|
|
||||||
|
## Pest 3 Features
|
||||||
|
|
||||||
|
### Architecture Testing
|
||||||
|
|
||||||
|
Pest 3 includes architecture testing to enforce code conventions:
|
||||||
|
|
||||||
|
<!-- Architecture Test Example -->
|
||||||
|
```php
|
||||||
|
arch('controllers')
|
||||||
|
->expect('App\Http\Controllers')
|
||||||
|
->toExtendNothing()
|
||||||
|
->toHaveSuffix('Controller');
|
||||||
|
|
||||||
|
arch('models')
|
||||||
|
->expect('App\Models')
|
||||||
|
->toExtend('Illuminate\Database\Eloquent\Model');
|
||||||
|
|
||||||
|
arch('no debugging')
|
||||||
|
->expect(['dd', 'dump', 'ray'])
|
||||||
|
->not->toBeUsed();
|
||||||
|
```
|
||||||
|
|
||||||
|
### Type Coverage
|
||||||
|
|
||||||
|
Pest 3 provides improved type coverage analysis. Run with `--type-coverage` flag.
|
||||||
|
|
||||||
|
## Common Pitfalls
|
||||||
|
|
||||||
|
- Not importing `use function Pest\Laravel\mock;` before using mock
|
||||||
|
- Using `assertStatus(200)` instead of `assertSuccessful()`
|
||||||
|
- Forgetting datasets for repetitive validation tests
|
||||||
|
- Deleting tests without approval
|
||||||
129
.claude/skills/tailwindcss-development/SKILL.md
Normal file
129
.claude/skills/tailwindcss-development/SKILL.md
Normal file
@@ -0,0 +1,129 @@
|
|||||||
|
---
|
||||||
|
name: tailwindcss-development
|
||||||
|
description: "Styles applications using Tailwind CSS v4 utilities. Activates when adding styles, restyling components, working with gradients, spacing, layout, flex, grid, responsive design, dark mode, colors, typography, or borders; or when the user mentions CSS, styling, classes, Tailwind, restyle, hero section, cards, buttons, or any visual/UI changes."
|
||||||
|
license: MIT
|
||||||
|
metadata:
|
||||||
|
author: laravel
|
||||||
|
---
|
||||||
|
|
||||||
|
# Tailwind CSS Development
|
||||||
|
|
||||||
|
## When to Apply
|
||||||
|
|
||||||
|
Activate this skill when:
|
||||||
|
|
||||||
|
- Adding styles to components or pages
|
||||||
|
- Working with responsive design
|
||||||
|
- Implementing dark mode
|
||||||
|
- Extracting repeated patterns into components
|
||||||
|
- Debugging spacing or layout issues
|
||||||
|
|
||||||
|
## Documentation
|
||||||
|
|
||||||
|
Use `search-docs` for detailed Tailwind CSS v4 patterns and documentation.
|
||||||
|
|
||||||
|
## Basic Usage
|
||||||
|
|
||||||
|
- Use Tailwind CSS classes to style HTML. Check and follow existing Tailwind conventions in the project before introducing new patterns.
|
||||||
|
- Offer to extract repeated patterns into components that match the project's conventions (e.g., Blade, JSX, Vue).
|
||||||
|
- Consider class placement, order, priority, and defaults. Remove redundant classes, add classes to parent or child elements carefully to reduce repetition, and group elements logically.
|
||||||
|
|
||||||
|
## Tailwind CSS v4 Specifics
|
||||||
|
|
||||||
|
- Always use Tailwind CSS v4 and avoid deprecated utilities.
|
||||||
|
- `corePlugins` is not supported in Tailwind v4.
|
||||||
|
|
||||||
|
### CSS-First Configuration
|
||||||
|
|
||||||
|
In Tailwind v4, configuration is CSS-first using the `@theme` directive — no separate `tailwind.config.js` file is needed:
|
||||||
|
|
||||||
|
<!-- CSS-First Config -->
|
||||||
|
```css
|
||||||
|
@theme {
|
||||||
|
--color-brand: oklch(0.72 0.11 178);
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### Import Syntax
|
||||||
|
|
||||||
|
In Tailwind v4, import Tailwind with a regular CSS `@import` statement instead of the `@tailwind` directives used in v3:
|
||||||
|
|
||||||
|
<!-- v4 Import Syntax -->
|
||||||
|
```diff
|
||||||
|
- @tailwind base;
|
||||||
|
- @tailwind components;
|
||||||
|
- @tailwind utilities;
|
||||||
|
+ @import "tailwindcss";
|
||||||
|
```
|
||||||
|
|
||||||
|
### Replaced Utilities
|
||||||
|
|
||||||
|
Tailwind v4 removed deprecated utilities. Use the replacements shown below. Opacity values remain numeric.
|
||||||
|
|
||||||
|
| Deprecated | Replacement |
|
||||||
|
|------------|-------------|
|
||||||
|
| bg-opacity-* | bg-black/* |
|
||||||
|
| text-opacity-* | text-black/* |
|
||||||
|
| border-opacity-* | border-black/* |
|
||||||
|
| divide-opacity-* | divide-black/* |
|
||||||
|
| ring-opacity-* | ring-black/* |
|
||||||
|
| placeholder-opacity-* | placeholder-black/* |
|
||||||
|
| flex-shrink-* | shrink-* |
|
||||||
|
| flex-grow-* | grow-* |
|
||||||
|
| overflow-ellipsis | text-ellipsis |
|
||||||
|
| decoration-slice | box-decoration-slice |
|
||||||
|
| decoration-clone | box-decoration-clone |
|
||||||
|
|
||||||
|
## Spacing
|
||||||
|
|
||||||
|
Use `gap` utilities instead of margins for spacing between siblings:
|
||||||
|
|
||||||
|
<!-- Gap Utilities -->
|
||||||
|
```html
|
||||||
|
<div class="flex gap-8">
|
||||||
|
<div>Item 1</div>
|
||||||
|
<div>Item 2</div>
|
||||||
|
</div>
|
||||||
|
```
|
||||||
|
|
||||||
|
## Dark Mode
|
||||||
|
|
||||||
|
If existing pages and components support dark mode, new pages and components must support it the same way, typically using the `dark:` variant:
|
||||||
|
|
||||||
|
<!-- Dark Mode -->
|
||||||
|
```html
|
||||||
|
<div class="bg-white dark:bg-gray-900 text-gray-900 dark:text-white">
|
||||||
|
Content adapts to color scheme
|
||||||
|
</div>
|
||||||
|
```
|
||||||
|
|
||||||
|
## Common Patterns
|
||||||
|
|
||||||
|
### Flexbox Layout
|
||||||
|
|
||||||
|
<!-- Flexbox Layout -->
|
||||||
|
```html
|
||||||
|
<div class="flex items-center justify-between gap-4">
|
||||||
|
<div>Left content</div>
|
||||||
|
<div>Right content</div>
|
||||||
|
</div>
|
||||||
|
```
|
||||||
|
|
||||||
|
### Grid Layout
|
||||||
|
|
||||||
|
<!-- Grid Layout -->
|
||||||
|
```html
|
||||||
|
<div class="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-6">
|
||||||
|
<div>Card 1</div>
|
||||||
|
<div>Card 2</div>
|
||||||
|
<div>Card 3</div>
|
||||||
|
</div>
|
||||||
|
```
|
||||||
|
|
||||||
|
## Common Pitfalls
|
||||||
|
|
||||||
|
- Using deprecated v3 utilities (bg-opacity-*, flex-shrink-*, etc.)
|
||||||
|
- Using `@tailwind` directives instead of `@import "tailwindcss"`
|
||||||
|
- Trying to use `tailwind.config.js` instead of CSS `@theme` directive
|
||||||
|
- Using margins for spacing between siblings instead of gap utilities
|
||||||
|
- Forgetting to add dark mode variants when the project uses dark mode
|
||||||
96
.claude/skills/volt-development/SKILL.md
Normal file
96
.claude/skills/volt-development/SKILL.md
Normal file
@@ -0,0 +1,96 @@
|
|||||||
|
---
|
||||||
|
name: volt-development
|
||||||
|
description: "Develops single-file Livewire components with Volt. Activates when creating Volt components, converting Livewire to Volt, working with @volt directive, functional or class-based Volt APIs; or when the user mentions Volt, single-file components, functional Livewire, or inline component logic in Blade files."
|
||||||
|
license: MIT
|
||||||
|
metadata:
|
||||||
|
author: laravel
|
||||||
|
---
|
||||||
|
|
||||||
|
# Volt Development
|
||||||
|
|
||||||
|
## When to Apply
|
||||||
|
|
||||||
|
Activate this skill when:
|
||||||
|
|
||||||
|
- Creating Volt single-file components
|
||||||
|
- Converting traditional Livewire components to Volt
|
||||||
|
- Testing Volt components
|
||||||
|
|
||||||
|
## Documentation
|
||||||
|
|
||||||
|
Use `search-docs` for detailed Volt patterns and documentation.
|
||||||
|
|
||||||
|
## Basic Usage
|
||||||
|
|
||||||
|
Create components with `php artisan make:volt [name] [--test] [--pest]`.
|
||||||
|
|
||||||
|
Important: Check existing Volt components to determine if they use functional or class-based style before creating new ones.
|
||||||
|
|
||||||
|
### Functional Components
|
||||||
|
|
||||||
|
<!-- Volt Functional Component -->
|
||||||
|
```php
|
||||||
|
@@volt
|
||||||
|
<?php
|
||||||
|
use function Livewire\Volt\{state, computed};
|
||||||
|
|
||||||
|
state(['count' => 0]);
|
||||||
|
|
||||||
|
$increment = fn () => $this->count++;
|
||||||
|
$double = computed(fn () => $this->count * 2);
|
||||||
|
?>
|
||||||
|
|
||||||
|
<div>
|
||||||
|
<h1>Count: @{{ $count }} (Double: @{{ $this->double }})</h1>
|
||||||
|
<button wire:click="increment">+</button>
|
||||||
|
</div>
|
||||||
|
@@endvolt
|
||||||
|
```
|
||||||
|
|
||||||
|
### Class-Based Components
|
||||||
|
|
||||||
|
<!-- Volt Class-based Component -->
|
||||||
|
```php
|
||||||
|
use Livewire\Volt\Component;
|
||||||
|
|
||||||
|
new class extends Component {
|
||||||
|
public int $count = 0;
|
||||||
|
|
||||||
|
public function increment(): void
|
||||||
|
{
|
||||||
|
$this->count++;
|
||||||
|
}
|
||||||
|
} ?>
|
||||||
|
|
||||||
|
<div>
|
||||||
|
<h1>@{{ $count }}</h1>
|
||||||
|
<button wire:click="increment">+</button>
|
||||||
|
</div>
|
||||||
|
```
|
||||||
|
|
||||||
|
## Testing
|
||||||
|
|
||||||
|
Tests go in existing Volt test directory or `tests/Feature/Volt`:
|
||||||
|
|
||||||
|
<!-- Volt Test Example -->
|
||||||
|
```php
|
||||||
|
use Livewire\Volt\Volt;
|
||||||
|
|
||||||
|
test('counter increments', function () {
|
||||||
|
Volt::test('counter')
|
||||||
|
->assertSee('Count: 0')
|
||||||
|
->call('increment')
|
||||||
|
->assertSee('Count: 1');
|
||||||
|
});
|
||||||
|
```
|
||||||
|
|
||||||
|
## Verification
|
||||||
|
|
||||||
|
1. Check existing components for functional vs class-based style
|
||||||
|
2. Test component with `Volt::test()`
|
||||||
|
|
||||||
|
## Common Pitfalls
|
||||||
|
|
||||||
|
- Not checking existing style (functional vs class-based) before creating
|
||||||
|
- Forgetting `@volt` directive wrapper
|
||||||
|
- Missing `--test` or `--pest` flag when tests are needed
|
||||||
11
.gemini/settings.json
Normal file
11
.gemini/settings.json
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
{
|
||||||
|
"mcpServers": {
|
||||||
|
"laravel-boost": {
|
||||||
|
"command": "php",
|
||||||
|
"args": [
|
||||||
|
"artisan",
|
||||||
|
"boost:mcp"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
432
.junie/guidelines.md
Normal file
432
.junie/guidelines.md
Normal file
@@ -0,0 +1,432 @@
|
|||||||
|
<laravel-boost-guidelines>
|
||||||
|
=== foundation rules ===
|
||||||
|
|
||||||
|
# Laravel Boost Guidelines
|
||||||
|
|
||||||
|
The Laravel Boost guidelines are specifically curated by Laravel maintainers for this application. These guidelines should be followed closely to ensure the best experience when building Laravel applications.
|
||||||
|
|
||||||
|
## Foundational Context
|
||||||
|
|
||||||
|
This application is a Laravel application and its main Laravel ecosystems package & versions are below. You are an expert with them all. Ensure you abide by these specific packages & versions.
|
||||||
|
|
||||||
|
- php - 8.4.12
|
||||||
|
- filament/filament (FILAMENT) - v4
|
||||||
|
- laravel/fortify (FORTIFY) - v1
|
||||||
|
- laravel/framework (LARAVEL) - v12
|
||||||
|
- laravel/pint (PINT) - v1
|
||||||
|
- laravel/prompts (PROMPTS) - v0
|
||||||
|
- livewire/flux (FLUXUI_FREE) - v2
|
||||||
|
- livewire/livewire (LIVEWIRE) - v3
|
||||||
|
- livewire/volt (VOLT) - v1
|
||||||
|
- laravel/boost (BOOST) - v2
|
||||||
|
- laravel/mcp (MCP) - v0
|
||||||
|
- laravel/pail (PAIL) - v1
|
||||||
|
- laravel/sail (SAIL) - v1
|
||||||
|
- pestphp/pest (PEST) - v3
|
||||||
|
- phpunit/phpunit (PHPUNIT) - v11
|
||||||
|
- rector/rector (RECTOR) - v2
|
||||||
|
- tailwindcss (TAILWINDCSS) - v4
|
||||||
|
|
||||||
|
## Skills Activation
|
||||||
|
|
||||||
|
This project has domain-specific skills available. You MUST activate the relevant skill whenever you work in that domain—don't wait until you're stuck.
|
||||||
|
|
||||||
|
- `fluxui-development` — Develops UIs with Flux UI Free components. Activates when creating buttons, forms, modals, inputs, dropdowns, checkboxes, or UI components; replacing HTML form elements with Flux; working with flux: components; or when the user mentions Flux, component library, UI components, form fields, or asks about available Flux components.
|
||||||
|
- `volt-development` — Develops single-file Livewire components with Volt. Activates when creating Volt components, converting Livewire to Volt, working with @volt directive, functional or class-based Volt APIs; or when the user mentions Volt, single-file components, functional Livewire, or inline component logic in Blade files.
|
||||||
|
- `pest-testing` — Tests applications using the Pest 3 PHP framework. Activates when writing tests, creating unit or feature tests, adding assertions, testing Livewire components, architecture testing, debugging test failures, working with datasets or mocking; or when the user mentions test, spec, TDD, expects, assertion, coverage, or needs to verify functionality works.
|
||||||
|
- `tailwindcss-development` — Styles applications using Tailwind CSS v4 utilities. Activates when adding styles, restyling components, working with gradients, spacing, layout, flex, grid, responsive design, dark mode, colors, typography, or borders; or when the user mentions CSS, styling, classes, Tailwind, restyle, hero section, cards, buttons, or any visual/UI changes.
|
||||||
|
- `filament-db-config` — Creates database-backed settings pages and config pages with filament-db-config or db-config package. Activates when creating settings page, config page, configuration page, or when user mentions db-config, db_config, DbConfig, database settings, dynamic configuration, runtime config, storing settings in database. ALWAYS use php artisan make:db-config command to scaffold. NEVER create files manually. NEVER create tests.
|
||||||
|
- `developing-with-fortify` — Laravel Fortify headless authentication backend development. Activate when implementing authentication features including login, registration, password reset, email verification, two-factor authentication (2FA/TOTP), profile updates, headless auth, authentication scaffolding, or auth guards in Laravel applications.
|
||||||
|
|
||||||
|
## Conventions
|
||||||
|
|
||||||
|
- You must follow all existing code conventions used in this application. When creating or editing a file, check sibling files for the correct structure, approach, and naming.
|
||||||
|
- Use descriptive names for variables and methods. For example, `isRegisteredForDiscounts`, not `discount()`.
|
||||||
|
- Check for existing components to reuse before writing a new one.
|
||||||
|
|
||||||
|
## Verification Scripts
|
||||||
|
|
||||||
|
- Do not create verification scripts or tinker when tests cover that functionality and prove they work. Unit and feature tests are more important.
|
||||||
|
|
||||||
|
## Application Structure & Architecture
|
||||||
|
|
||||||
|
- Stick to existing directory structure; don't create new base folders without approval.
|
||||||
|
- Do not change the application's dependencies without approval.
|
||||||
|
|
||||||
|
## Frontend Bundling
|
||||||
|
|
||||||
|
- If the user doesn't see a frontend change reflected in the UI, it could mean they need to run `npm run build`, `npm run dev`, or `composer run dev`. Ask them.
|
||||||
|
|
||||||
|
## Documentation Files
|
||||||
|
|
||||||
|
- You must only create documentation files if explicitly requested by the user.
|
||||||
|
|
||||||
|
## Replies
|
||||||
|
|
||||||
|
- Be concise in your explanations - focus on what's important rather than explaining obvious details.
|
||||||
|
|
||||||
|
=== boost rules ===
|
||||||
|
|
||||||
|
# Laravel Boost
|
||||||
|
|
||||||
|
- Laravel Boost is an MCP server that comes with powerful tools designed specifically for this application. Use them.
|
||||||
|
|
||||||
|
## Artisan
|
||||||
|
|
||||||
|
- Use the `list-artisan-commands` tool when you need to call an Artisan command to double-check the available parameters.
|
||||||
|
|
||||||
|
## URLs
|
||||||
|
|
||||||
|
- Whenever you share a project URL with the user, you should use the `get-absolute-url` tool to ensure you're using the correct scheme, domain/IP, and port.
|
||||||
|
|
||||||
|
## Tinker / Debugging
|
||||||
|
|
||||||
|
- You should use the `tinker` tool when you need to execute PHP to debug code or query Eloquent models directly.
|
||||||
|
- Use the `database-query` tool when you only need to read from the database.
|
||||||
|
- Use the `database-schema` tool to inspect table structure before writing migrations or models.
|
||||||
|
|
||||||
|
## Reading Browser Logs With the `browser-logs` Tool
|
||||||
|
|
||||||
|
- You can read browser logs, errors, and exceptions using the `browser-logs` tool from Boost.
|
||||||
|
- Only recent browser logs will be useful - ignore old logs.
|
||||||
|
|
||||||
|
## Searching Documentation (Critically Important)
|
||||||
|
|
||||||
|
- Boost comes with a powerful `search-docs` tool you should use before trying other approaches when working with Laravel or Laravel ecosystem packages. This tool automatically passes a list of installed packages and their versions to the remote Boost API, so it returns only version-specific documentation for the user's circumstance. You should pass an array of packages to filter on if you know you need docs for particular packages.
|
||||||
|
- Search the documentation before making code changes to ensure we are taking the correct approach.
|
||||||
|
- Use multiple, broad, simple, topic-based queries at once. For example: `['rate limiting', 'routing rate limiting', 'routing']`. The most relevant results will be returned first.
|
||||||
|
- Do not add package names to queries; package information is already shared. For example, use `test resource table`, not `filament 4 test resource table`.
|
||||||
|
|
||||||
|
### Available Search Syntax
|
||||||
|
|
||||||
|
1. Simple Word Searches with auto-stemming - query=authentication - finds 'authenticate' and 'auth'.
|
||||||
|
2. Multiple Words (AND Logic) - query=rate limit - finds knowledge containing both "rate" AND "limit".
|
||||||
|
3. Quoted Phrases (Exact Position) - query="infinite scroll" - words must be adjacent and in that order.
|
||||||
|
4. Mixed Queries - query=middleware "rate limit" - "middleware" AND exact phrase "rate limit".
|
||||||
|
5. Multiple Queries - queries=["authentication", "middleware"] - ANY of these terms.
|
||||||
|
|
||||||
|
=== php rules ===
|
||||||
|
|
||||||
|
# PHP
|
||||||
|
|
||||||
|
- Always use curly braces for control structures, even for single-line bodies.
|
||||||
|
|
||||||
|
## Constructors
|
||||||
|
|
||||||
|
- Use PHP 8 constructor property promotion in `__construct()`.
|
||||||
|
- `public function __construct(public GitHub $github) { }`
|
||||||
|
- Do not allow empty `__construct()` methods with zero parameters unless the constructor is private.
|
||||||
|
|
||||||
|
## Type Declarations
|
||||||
|
|
||||||
|
- Always use explicit return type declarations for methods and functions.
|
||||||
|
- Use appropriate PHP type hints for method parameters.
|
||||||
|
|
||||||
|
<!-- Explicit Return Types and Method Params -->
|
||||||
|
```php
|
||||||
|
protected function isAccessible(User $user, ?string $path = null): bool
|
||||||
|
{
|
||||||
|
...
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## Enums
|
||||||
|
|
||||||
|
- Typically, keys in an Enum should be TitleCase. For example: `FavoritePerson`, `BestLake`, `Monthly`.
|
||||||
|
|
||||||
|
## Comments
|
||||||
|
|
||||||
|
- Prefer PHPDoc blocks over inline comments. Never use comments within the code itself unless the logic is exceptionally complex.
|
||||||
|
|
||||||
|
## PHPDoc Blocks
|
||||||
|
|
||||||
|
- Add useful array shape type definitions when appropriate.
|
||||||
|
|
||||||
|
=== tests rules ===
|
||||||
|
|
||||||
|
# Test Enforcement
|
||||||
|
|
||||||
|
- Every change must be programmatically tested. Write a new test or update an existing test, then run the affected tests to make sure they pass.
|
||||||
|
- Run the minimum number of tests needed to ensure code quality and speed. Use `php artisan test --compact` with a specific filename or filter.
|
||||||
|
|
||||||
|
=== laravel/core rules ===
|
||||||
|
|
||||||
|
# Do Things the Laravel Way
|
||||||
|
|
||||||
|
- Use `php artisan make:` commands to create new files (i.e. migrations, controllers, models, etc.). You can list available Artisan commands using the `list-artisan-commands` tool.
|
||||||
|
- If you're creating a generic PHP class, use `php artisan make:class`.
|
||||||
|
- Pass `--no-interaction` to all Artisan commands to ensure they work without user input. You should also pass the correct `--options` to ensure correct behavior.
|
||||||
|
|
||||||
|
## Database
|
||||||
|
|
||||||
|
- Always use proper Eloquent relationship methods with return type hints. Prefer relationship methods over raw queries or manual joins.
|
||||||
|
- Use Eloquent models and relationships before suggesting raw database queries.
|
||||||
|
- Avoid `DB::`; prefer `Model::query()`. Generate code that leverages Laravel's ORM capabilities rather than bypassing them.
|
||||||
|
- Generate code that prevents N+1 query problems by using eager loading.
|
||||||
|
- Use Laravel's query builder for very complex database operations.
|
||||||
|
|
||||||
|
### Model Creation
|
||||||
|
|
||||||
|
- When creating new models, create useful factories and seeders for them too. Ask the user if they need any other things, using `list-artisan-commands` to check the available options to `php artisan make:model`.
|
||||||
|
|
||||||
|
### APIs & Eloquent Resources
|
||||||
|
|
||||||
|
- For APIs, default to using Eloquent API Resources and API versioning unless existing API routes do not, then you should follow existing application convention.
|
||||||
|
|
||||||
|
## Controllers & Validation
|
||||||
|
|
||||||
|
- Always create Form Request classes for validation rather than inline validation in controllers. Include both validation rules and custom error messages.
|
||||||
|
- Check sibling Form Requests to see if the application uses array or string based validation rules.
|
||||||
|
|
||||||
|
## Authentication & Authorization
|
||||||
|
|
||||||
|
- Use Laravel's built-in authentication and authorization features (gates, policies, Sanctum, etc.).
|
||||||
|
|
||||||
|
## URL Generation
|
||||||
|
|
||||||
|
- When generating links to other pages, prefer named routes and the `route()` function.
|
||||||
|
|
||||||
|
## Queues
|
||||||
|
|
||||||
|
- Use queued jobs for time-consuming operations with the `ShouldQueue` interface.
|
||||||
|
|
||||||
|
## Configuration
|
||||||
|
|
||||||
|
- Use environment variables only in configuration files - never use the `env()` function directly outside of config files. Always use `config('app.name')`, not `env('APP_NAME')`.
|
||||||
|
|
||||||
|
## Testing
|
||||||
|
|
||||||
|
- When creating models for tests, use the factories for the models. Check if the factory has custom states that can be used before manually setting up the model.
|
||||||
|
- Faker: Use methods such as `$this->faker->word()` or `fake()->randomDigit()`. Follow existing conventions whether to use `$this->faker` or `fake()`.
|
||||||
|
- When creating tests, make use of `php artisan make:test [options] {name}` to create a feature test, and pass `--unit` to create a unit test. Most tests should be feature tests.
|
||||||
|
|
||||||
|
## Vite Error
|
||||||
|
|
||||||
|
- If you receive an "Illuminate\Foundation\ViteException: Unable to locate file in Vite manifest" error, you can run `npm run build` or ask the user to run `npm run dev` or `composer run dev`.
|
||||||
|
|
||||||
|
=== laravel/v12 rules ===
|
||||||
|
|
||||||
|
# Laravel 12
|
||||||
|
|
||||||
|
- CRITICAL: ALWAYS use `search-docs` tool for version-specific Laravel documentation and updated code examples.
|
||||||
|
- Since Laravel 11, Laravel has a new streamlined file structure which this project uses.
|
||||||
|
|
||||||
|
## Laravel 12 Structure
|
||||||
|
|
||||||
|
- In Laravel 12, middleware are no longer registered in `app/Http/Kernel.php`.
|
||||||
|
- Middleware are configured declaratively in `bootstrap/app.php` using `Application::configure()->withMiddleware()`.
|
||||||
|
- `bootstrap/app.php` is the file to register middleware, exceptions, and routing files.
|
||||||
|
- `bootstrap/providers.php` contains application specific service providers.
|
||||||
|
- The `app\Console\Kernel.php` file no longer exists; use `bootstrap/app.php` or `routes/console.php` for console configuration.
|
||||||
|
- Console commands in `app/Console/Commands/` are automatically available and do not require manual registration.
|
||||||
|
|
||||||
|
## Database
|
||||||
|
|
||||||
|
- When modifying a column, the migration must include all of the attributes that were previously defined on the column. Otherwise, they will be dropped and lost.
|
||||||
|
- Laravel 12 allows limiting eagerly loaded records natively, without external packages: `$query->latest()->limit(10);`.
|
||||||
|
|
||||||
|
### Models
|
||||||
|
|
||||||
|
- Casts can and likely should be set in a `casts()` method on a model rather than the `$casts` property. Follow existing conventions from other models.
|
||||||
|
|
||||||
|
=== pint/core rules ===
|
||||||
|
|
||||||
|
# Laravel Pint Code Formatter
|
||||||
|
|
||||||
|
- If you have modified any PHP files, you must run `vendor/bin/pint --dirty --format agent` before finalizing changes to ensure your code matches the project's expected style.
|
||||||
|
- Do not run `vendor/bin/pint --test --format agent`, simply run `vendor/bin/pint --format agent` to fix any formatting issues.
|
||||||
|
|
||||||
|
=== fluxui-free/core rules ===
|
||||||
|
|
||||||
|
# Flux UI Free
|
||||||
|
|
||||||
|
- Flux UI is the official Livewire component library. This project uses the free edition, which includes all free components and variants but not Pro components.
|
||||||
|
- Use `<flux:*>` components when available; they are the recommended way to build Livewire interfaces.
|
||||||
|
- IMPORTANT: Activate `fluxui-development` when working with Flux UI components.
|
||||||
|
|
||||||
|
=== volt/core rules ===
|
||||||
|
|
||||||
|
# Livewire Volt
|
||||||
|
|
||||||
|
- Single-file Livewire components: PHP logic and Blade templates in one file.
|
||||||
|
- Always check existing Volt components to determine functional vs class-based style.
|
||||||
|
- IMPORTANT: Always use `search-docs` tool for version-specific Volt documentation and updated code examples.
|
||||||
|
- IMPORTANT: Activate `volt-development` every time you're working with a Volt or single-file component-related task.
|
||||||
|
|
||||||
|
=== pest/core rules ===
|
||||||
|
|
||||||
|
## Pest
|
||||||
|
|
||||||
|
- This project uses Pest for testing. Create tests: `php artisan make:test --pest {name}`.
|
||||||
|
- Run tests: `php artisan test --compact` or filter: `php artisan test --compact --filter=testName`.
|
||||||
|
- Do NOT delete tests without approval.
|
||||||
|
- CRITICAL: ALWAYS use `search-docs` tool for version-specific Pest documentation and updated code examples.
|
||||||
|
- IMPORTANT: Activate `pest-testing` every time you're working with a Pest or testing-related task.
|
||||||
|
|
||||||
|
=== tailwindcss/core rules ===
|
||||||
|
|
||||||
|
# Tailwind CSS
|
||||||
|
|
||||||
|
- Always use existing Tailwind conventions; check project patterns before adding new ones.
|
||||||
|
- IMPORTANT: Always use `search-docs` tool for version-specific Tailwind CSS documentation and updated code examples. Never rely on training data.
|
||||||
|
- IMPORTANT: Activate `tailwindcss-development` every time you're working with a Tailwind CSS or styling-related task.
|
||||||
|
|
||||||
|
=== filament/filament rules ===
|
||||||
|
|
||||||
|
## Filament
|
||||||
|
|
||||||
|
- Filament is used by this application. Follow the existing conventions for how and where it is implemented.
|
||||||
|
- Filament is a Server-Driven UI (SDUI) framework for Laravel that lets you define user interfaces in PHP using structured configuration objects. Built on Livewire, Alpine.js, and Tailwind CSS.
|
||||||
|
- Use the `search-docs` tool for official documentation on Artisan commands, code examples, testing, relationships, and idiomatic practices. If `search-docs` is unavailable, refer to https://filamentphp.com/docs.
|
||||||
|
|
||||||
|
### Artisan
|
||||||
|
|
||||||
|
- Always use Filament-specific Artisan commands to create files. Find available commands with the `list-artisan-commands` tool, or run `php artisan --help`.
|
||||||
|
- Always inspect required options before running a command, and always pass `--no-interaction`.
|
||||||
|
|
||||||
|
### Patterns
|
||||||
|
|
||||||
|
Always use static `make()` methods to initialize components. Most configuration methods accept a `Closure` for dynamic values.
|
||||||
|
|
||||||
|
Use `Get $get` to read other form field values for conditional logic:
|
||||||
|
|
||||||
|
<code-snippet name="Conditional form field visibility" lang="php">
|
||||||
|
use Filament\Forms\Components\Select;
|
||||||
|
use Filament\Forms\Components\TextInput;
|
||||||
|
use Filament\Schemas\Components\Utilities\Get;
|
||||||
|
|
||||||
|
Select::make('type')
|
||||||
|
->options(CompanyType::class)
|
||||||
|
->required()
|
||||||
|
->live(),
|
||||||
|
|
||||||
|
TextInput::make('company_name')
|
||||||
|
->required()
|
||||||
|
->visible(fn (Get $get): bool => $get('type') === 'business'),
|
||||||
|
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
Use `state()` with a `Closure` to compute derived column values:
|
||||||
|
|
||||||
|
<code-snippet name="Computed table column value" lang="php">
|
||||||
|
use Filament\Tables\Columns\TextColumn;
|
||||||
|
|
||||||
|
TextColumn::make('full_name')
|
||||||
|
->state(fn (User $record): string => "{$record->first_name} {$record->last_name}"),
|
||||||
|
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
Actions encapsulate a button with an optional modal form and logic:
|
||||||
|
|
||||||
|
<code-snippet name="Action with modal form" lang="php">
|
||||||
|
use Filament\Actions\Action;
|
||||||
|
use Filament\Forms\Components\TextInput;
|
||||||
|
|
||||||
|
Action::make('updateEmail')
|
||||||
|
->schema([
|
||||||
|
TextInput::make('email')
|
||||||
|
->email()
|
||||||
|
->required(),
|
||||||
|
])
|
||||||
|
->action(fn (array $data, User $record) => $record->update($data))
|
||||||
|
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
### Testing
|
||||||
|
|
||||||
|
Always authenticate before testing panel functionality. Filament uses Livewire, so use `Livewire::test()` or `livewire()` (available when `pestphp/pest-plugin-livewire` is in `composer.json`):
|
||||||
|
|
||||||
|
<code-snippet name="Table test" lang="php">
|
||||||
|
use function Pest\Livewire\livewire;
|
||||||
|
|
||||||
|
livewire(ListUsers::class)
|
||||||
|
->assertCanSeeTableRecords($users)
|
||||||
|
->searchTable($users->first()->name)
|
||||||
|
->assertCanSeeTableRecords($users->take(1))
|
||||||
|
->assertCanNotSeeTableRecords($users->skip(1));
|
||||||
|
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
<code-snippet name="Create resource test" lang="php">
|
||||||
|
use function Pest\Laravel\assertDatabaseHas;
|
||||||
|
use function Pest\Livewire\livewire;
|
||||||
|
|
||||||
|
livewire(CreateUser::class)
|
||||||
|
->fillForm([
|
||||||
|
'name' => 'Test',
|
||||||
|
'email' => 'test@example.com',
|
||||||
|
])
|
||||||
|
->call('create')
|
||||||
|
->assertNotified()
|
||||||
|
->assertRedirect();
|
||||||
|
|
||||||
|
assertDatabaseHas(User::class, [
|
||||||
|
'name' => 'Test',
|
||||||
|
'email' => 'test@example.com',
|
||||||
|
]);
|
||||||
|
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
<code-snippet name="Testing validation" lang="php">
|
||||||
|
use function Pest\Livewire\livewire;
|
||||||
|
|
||||||
|
livewire(CreateUser::class)
|
||||||
|
->fillForm([
|
||||||
|
'name' => null,
|
||||||
|
'email' => 'invalid-email',
|
||||||
|
])
|
||||||
|
->call('create')
|
||||||
|
->assertHasFormErrors([
|
||||||
|
'name' => 'required',
|
||||||
|
'email' => 'email',
|
||||||
|
])
|
||||||
|
->assertNotNotified();
|
||||||
|
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
<code-snippet name="Calling actions in pages" lang="php">
|
||||||
|
use Filament\Actions\DeleteAction;
|
||||||
|
use function Pest\Livewire\livewire;
|
||||||
|
|
||||||
|
livewire(EditUser::class, ['record' => $user->id])
|
||||||
|
->callAction(DeleteAction::class)
|
||||||
|
->assertNotified()
|
||||||
|
->assertRedirect();
|
||||||
|
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
<code-snippet name="Calling actions in tables" lang="php">
|
||||||
|
use Filament\Actions\Testing\TestAction;
|
||||||
|
use function Pest\Livewire\livewire;
|
||||||
|
|
||||||
|
livewire(ListUsers::class)
|
||||||
|
->callAction(TestAction::make('promote')->table($user), [
|
||||||
|
'role' => 'admin',
|
||||||
|
])
|
||||||
|
->assertNotified();
|
||||||
|
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
### Correct Namespaces
|
||||||
|
|
||||||
|
- Form fields (`TextInput`, `Select`, etc.): `Filament\Forms\Components\`
|
||||||
|
- Infolist entries (`TextEntry`, `IconEntry`, etc.): `Filament\Infolists\Components\`
|
||||||
|
- Layout components (`Grid`, `Section`, `Fieldset`, `Tabs`, `Wizard`, etc.): `Filament\Schemas\Components\`
|
||||||
|
- Schema utilities (`Get`, `Set`, etc.): `Filament\Schemas\Components\Utilities\`
|
||||||
|
- Actions (`DeleteAction`, `CreateAction`, etc.): `Filament\Actions\`. Never use `Filament\Tables\Actions\`, `Filament\Forms\Actions\`, or any other sub-namespace for actions.
|
||||||
|
- Icons: `Filament\Support\Icons\Heroicon` enum (e.g., `Heroicon::PencilSquare`)
|
||||||
|
|
||||||
|
### Common Mistakes
|
||||||
|
|
||||||
|
- **Never assume public file visibility.** File visibility is `private` by default. Always use `->visibility('public')` when public access is needed.
|
||||||
|
- **Never assume full-width layout.** `Grid`, `Section`, and `Fieldset` do not span all columns by default. Explicitly set column spans when needed.
|
||||||
|
|
||||||
|
=== laravel/fortify rules ===
|
||||||
|
|
||||||
|
# Laravel Fortify
|
||||||
|
|
||||||
|
- Fortify is a headless authentication backend that provides authentication routes and controllers for Laravel applications.
|
||||||
|
- IMPORTANT: Always use the `search-docs` tool for detailed Laravel Fortify patterns and documentation.
|
||||||
|
- IMPORTANT: Activate `developing-with-fortify` skill when working with Fortify authentication features.
|
||||||
|
|
||||||
|
</laravel-boost-guidelines>
|
||||||
11
.junie/mcp/mcp.json
Normal file
11
.junie/mcp/mcp.json
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
{
|
||||||
|
"mcpServers": {
|
||||||
|
"laravel-boost": {
|
||||||
|
"command": "D:\\laragon\\bin\\php\\php-8.4.12-nts-Win32-vs17-x64\\php.exe",
|
||||||
|
"args": [
|
||||||
|
"D:\\laragon\\www\\imail\\artisan",
|
||||||
|
"boost:mcp"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
128
.junie/skills/developing-with-fortify/SKILL.md
Normal file
128
.junie/skills/developing-with-fortify/SKILL.md
Normal file
@@ -0,0 +1,128 @@
|
|||||||
|
---
|
||||||
|
name: developing-with-fortify
|
||||||
|
description: Laravel Fortify headless authentication backend development. Activate when implementing authentication features including login, registration, password reset, email verification, two-factor authentication (2FA/TOTP), profile updates, headless auth, authentication scaffolding, or auth guards in Laravel applications.
|
||||||
|
---
|
||||||
|
|
||||||
|
# Laravel Fortify Development
|
||||||
|
|
||||||
|
Fortify is a headless authentication backend that provides authentication routes and controllers for Laravel applications.
|
||||||
|
|
||||||
|
## Documentation
|
||||||
|
|
||||||
|
Use `search-docs` for detailed Laravel Fortify patterns and documentation.
|
||||||
|
|
||||||
|
## Usage
|
||||||
|
|
||||||
|
- **Routes**: Use `list-routes` with `only_vendor: true` and `action: "Fortify"` to see all registered endpoints
|
||||||
|
- **Actions**: Check `app/Actions/Fortify/` for customizable business logic (user creation, password validation, etc.)
|
||||||
|
- **Config**: See `config/fortify.php` for all options including features, guards, rate limiters, and username field
|
||||||
|
- **Contracts**: Look in `Laravel\Fortify\Contracts\` for overridable response classes (`LoginResponse`, `LogoutResponse`, etc.)
|
||||||
|
- **Views**: All view callbacks are set in `FortifyServiceProvider::boot()` using `Fortify::loginView()`, `Fortify::registerView()`, etc.
|
||||||
|
|
||||||
|
## Available Features
|
||||||
|
|
||||||
|
Enable in `config/fortify.php` features array:
|
||||||
|
|
||||||
|
- `Features::registration()` - User registration
|
||||||
|
- `Features::resetPasswords()` - Password reset via email
|
||||||
|
- `Features::emailVerification()` - Requires User to implement `MustVerifyEmail`
|
||||||
|
- `Features::updateProfileInformation()` - Profile updates
|
||||||
|
- `Features::updatePasswords()` - Password changes
|
||||||
|
- `Features::twoFactorAuthentication()` - 2FA with QR codes and recovery codes
|
||||||
|
|
||||||
|
> Use `search-docs` for feature configuration options and customization patterns.
|
||||||
|
|
||||||
|
## Setup Workflows
|
||||||
|
|
||||||
|
### Two-Factor Authentication Setup
|
||||||
|
|
||||||
|
```
|
||||||
|
- [ ] Add TwoFactorAuthenticatable trait to User model
|
||||||
|
- [ ] Enable feature in config/fortify.php
|
||||||
|
- [ ] If the `*_add_two_factor_columns_to_users_table.php` migration is missing, publish via `php artisan vendor:publish --tag=fortify-migrations` and migrate
|
||||||
|
- [ ] Set up view callbacks in FortifyServiceProvider
|
||||||
|
- [ ] Create 2FA management UI
|
||||||
|
- [ ] Test QR code and recovery codes
|
||||||
|
```
|
||||||
|
|
||||||
|
> Use `search-docs` for TOTP implementation and recovery code handling patterns.
|
||||||
|
|
||||||
|
### Email Verification Setup
|
||||||
|
|
||||||
|
```
|
||||||
|
- [ ] Enable emailVerification feature in config
|
||||||
|
- [ ] Implement MustVerifyEmail interface on User model
|
||||||
|
- [ ] Set up verifyEmailView callback
|
||||||
|
- [ ] Add verified middleware to protected routes
|
||||||
|
- [ ] Test verification email flow
|
||||||
|
```
|
||||||
|
|
||||||
|
> Use `search-docs` for MustVerifyEmail implementation patterns.
|
||||||
|
|
||||||
|
### Password Reset Setup
|
||||||
|
|
||||||
|
```
|
||||||
|
- [ ] Enable resetPasswords feature in config
|
||||||
|
- [ ] Set up requestPasswordResetLinkView callback
|
||||||
|
- [ ] Set up resetPasswordView callback
|
||||||
|
- [ ] Define password.reset named route (if views disabled)
|
||||||
|
- [ ] Test reset email and link flow
|
||||||
|
```
|
||||||
|
|
||||||
|
> Use `search-docs` for custom password reset flow patterns.
|
||||||
|
|
||||||
|
### SPA Authentication Setup
|
||||||
|
|
||||||
|
```
|
||||||
|
- [ ] Set 'views' => false in config/fortify.php
|
||||||
|
- [ ] Install and configure Laravel Sanctum for session-based SPA authentication
|
||||||
|
- [ ] Use the 'web' guard in config/fortify.php (required for session-based authentication)
|
||||||
|
- [ ] Set up CSRF token handling
|
||||||
|
- [ ] Test XHR authentication flows
|
||||||
|
```
|
||||||
|
|
||||||
|
> Use `search-docs` for integration and SPA authentication patterns.
|
||||||
|
|
||||||
|
#### Two-Factor Authentication in SPA Mode
|
||||||
|
|
||||||
|
When `views` is set to `false`, Fortify returns JSON responses instead of redirects.
|
||||||
|
|
||||||
|
If a user attempts to log in and two-factor authentication is enabled, the login request will return a JSON response indicating that a two-factor challenge is required:
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"two_factor": true
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## Best Practices
|
||||||
|
|
||||||
|
### Custom Authentication Logic
|
||||||
|
|
||||||
|
Override authentication behavior using `Fortify::authenticateUsing()` for custom user retrieval or `Fortify::authenticateThrough()` to customize the authentication pipeline. Override response contracts in `AppServiceProvider` for custom redirects.
|
||||||
|
|
||||||
|
### Registration Customization
|
||||||
|
|
||||||
|
Modify `app/Actions/Fortify/CreateNewUser.php` to customize user creation logic, validation rules, and additional fields.
|
||||||
|
|
||||||
|
### Rate Limiting
|
||||||
|
|
||||||
|
Configure via `fortify.limiters.login` in config. Default configuration throttles by username + IP combination.
|
||||||
|
|
||||||
|
## Key Endpoints
|
||||||
|
|
||||||
|
| Feature | Method | Endpoint |
|
||||||
|
|------------------------|----------|---------------------------------------------|
|
||||||
|
| Login | POST | `/login` |
|
||||||
|
| Logout | POST | `/logout` |
|
||||||
|
| Register | POST | `/register` |
|
||||||
|
| Password Reset Request | POST | `/forgot-password` |
|
||||||
|
| Password Reset | POST | `/reset-password` |
|
||||||
|
| Email Verify Notice | GET | `/email/verify` |
|
||||||
|
| Resend Verification | POST | `/email/verification-notification` |
|
||||||
|
| Password Confirm | POST | `/user/confirm-password` |
|
||||||
|
| Enable 2FA | POST | `/user/two-factor-authentication` |
|
||||||
|
| Confirm 2FA | POST | `/user/confirmed-two-factor-authentication` |
|
||||||
|
| 2FA Challenge | POST | `/two-factor-challenge` |
|
||||||
|
| Get QR Code | GET | `/user/two-factor-qr-code` |
|
||||||
|
| Recovery Codes | GET/POST | `/user/two-factor-recovery-codes` |
|
||||||
124
.junie/skills/filament-db-config/SKILL.md
Normal file
124
.junie/skills/filament-db-config/SKILL.md
Normal file
@@ -0,0 +1,124 @@
|
|||||||
|
---
|
||||||
|
name: filament-db-config
|
||||||
|
description: >-
|
||||||
|
Creates database-backed settings pages and config pages with filament-db-config or db-config package.
|
||||||
|
Activates when creating settings page, config page, configuration page, or when user mentions db-config,
|
||||||
|
db_config, DbConfig, database settings, dynamic configuration, runtime config, storing settings in database.
|
||||||
|
ALWAYS use php artisan make:db-config command to scaffold. NEVER create files manually. NEVER create tests.
|
||||||
|
---
|
||||||
|
|
||||||
|
# Filament DB Config
|
||||||
|
|
||||||
|
## When to Apply
|
||||||
|
|
||||||
|
Activate this skill when:
|
||||||
|
|
||||||
|
- Creating settings pages or config pages
|
||||||
|
- Working with db-config, db_config(), DbConfig
|
||||||
|
- User mentions database settings, dynamic configuration
|
||||||
|
- User asks to store configuration in database
|
||||||
|
|
||||||
|
## Documentation
|
||||||
|
|
||||||
|
Use `search-docs` for Filament form components and patterns. Do NOT rely on training data — always check the installed Filament version documentation.
|
||||||
|
|
||||||
|
## Critical Workflow
|
||||||
|
|
||||||
|
STEP 1: Always scaffold with artisan command first:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
php artisan make:db-config HomeSeo --no-interaction
|
||||||
|
```
|
||||||
|
|
||||||
|
IMPORTANT: Only pass the Name. NEVER add a second argument like "admin" or "panel". The command only takes one argument.
|
||||||
|
This generates `app/Filament/Pages/{Name}Settings.php`. The generator automatically adds "Settings" suffix.
|
||||||
|
|
||||||
|
STEP 2: Edit the generated file to add your fields in the `form()` method.
|
||||||
|
|
||||||
|
NEVER create files manually.
|
||||||
|
|
||||||
|
NEVER create tests. Tests are NOT needed for settings pages.
|
||||||
|
|
||||||
|
## After Scaffolding
|
||||||
|
|
||||||
|
Edit the generated page class to customize the `form()` method:
|
||||||
|
|
||||||
|
<code-snippet name="Settings Page Form Example" lang="php">
|
||||||
|
use Filament\Forms\Components\TextInput;
|
||||||
|
use Filament\Forms\Components\Toggle;
|
||||||
|
use Filament\Schemas\Schema;
|
||||||
|
|
||||||
|
public function form(Schema $schema): Schema
|
||||||
|
{
|
||||||
|
return $schema
|
||||||
|
->components([
|
||||||
|
TextInput::make('site_name')->label('Site Name'),
|
||||||
|
TextInput::make('contact_email')->label('Contact Email'),
|
||||||
|
Toggle::make('maintenance_mode')->label('Maintenance Mode'),
|
||||||
|
])
|
||||||
|
->statePath('data');
|
||||||
|
}
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
## Default Values
|
||||||
|
|
||||||
|
Override `getDefaultData()` to pre-fill the form:
|
||||||
|
|
||||||
|
<code-snippet name="Default Values Example" lang="php">
|
||||||
|
public function getDefaultData(): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'posts_per_page' => 10,
|
||||||
|
'allow_comments' => true,
|
||||||
|
];
|
||||||
|
}
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
## Reading Values
|
||||||
|
|
||||||
|
<code-snippet name="Reading db_config Values" lang="php">
|
||||||
|
// Standard helper
|
||||||
|
$siteName = db_config('website.site_name', 'Default');
|
||||||
|
|
||||||
|
// Safe helper (for early boot, migrations, service providers)
|
||||||
|
$siteName = safe_db_config('website.site_name', 'Default');
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
Blade directive:
|
||||||
|
|
||||||
|
<code-snippet name="Blade Directive" lang="blade">
|
||||||
|
<h1>@db_config('website.site_name', 'Default')</h1>
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
## Writing Values
|
||||||
|
|
||||||
|
<code-snippet name="Writing Values Programmatically" lang="php">
|
||||||
|
use Inerba\DbConfig\DbConfig;
|
||||||
|
|
||||||
|
DbConfig::set('website.site_name', 'Acme Inc.');
|
||||||
|
$group = DbConfig::getGroup('website');
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
## IMPORTANT: Do NOT Create Tests
|
||||||
|
|
||||||
|
Do NOT create any test files for db-config settings pages. Tests are NOT needed and NOT wanted unless the user explicitly asks for them.
|
||||||
|
|
||||||
|
## Filament Property Types
|
||||||
|
|
||||||
|
When setting Filament page properties, always use the correct union types:
|
||||||
|
|
||||||
|
<code-snippet name="Correct Property Types" lang="php">
|
||||||
|
protected static string | BackedEnum | null $navigationIcon = 'heroicon-o-cog';
|
||||||
|
protected static ?string $navigationGroup = 'Settings';
|
||||||
|
protected static ?int $navigationSort = 10;
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
NEVER write `protected static string $navigationIcon` — always include `| BackedEnum | null`.
|
||||||
|
|
||||||
|
## Common Mistakes
|
||||||
|
|
||||||
|
- NEVER create files manually — always run `php artisan make:db-config` first
|
||||||
|
- NEVER create tests — no tests for settings pages unless explicitly requested
|
||||||
|
- NEVER use `config()` — always use `db_config()` helper
|
||||||
|
- NEVER forget `statePath('data')` — forms must have `->statePath('data')`
|
||||||
|
- NEVER forget union types — navigationIcon must be `string | BackedEnum | null`
|
||||||
89
.junie/skills/fluxui-development/SKILL.md
Normal file
89
.junie/skills/fluxui-development/SKILL.md
Normal file
@@ -0,0 +1,89 @@
|
|||||||
|
---
|
||||||
|
name: fluxui-development
|
||||||
|
description: "Develops UIs with Flux UI Free components. Activates when creating buttons, forms, modals, inputs, dropdowns, checkboxes, or UI components; replacing HTML form elements with Flux; working with flux: components; or when the user mentions Flux, component library, UI components, form fields, or asks about available Flux components."
|
||||||
|
license: MIT
|
||||||
|
metadata:
|
||||||
|
author: laravel
|
||||||
|
---
|
||||||
|
|
||||||
|
# Flux UI Development
|
||||||
|
|
||||||
|
## When to Apply
|
||||||
|
|
||||||
|
Activate this skill when:
|
||||||
|
|
||||||
|
- Creating UI components or pages
|
||||||
|
- Working with forms, modals, or interactive elements
|
||||||
|
- Checking available Flux components
|
||||||
|
|
||||||
|
## Documentation
|
||||||
|
|
||||||
|
Use `search-docs` for detailed Flux UI patterns and documentation.
|
||||||
|
|
||||||
|
## Basic Usage
|
||||||
|
|
||||||
|
This project uses the free edition of Flux UI, which includes all free components and variants but not Pro components.
|
||||||
|
|
||||||
|
Flux UI is a component library for Livewire built with Tailwind CSS. It provides components that are easy to use and customize.
|
||||||
|
|
||||||
|
Use Flux UI components when available. Fall back to standard Blade components when no Flux component exists for your needs.
|
||||||
|
|
||||||
|
<!-- Basic Button -->
|
||||||
|
```blade
|
||||||
|
<flux:button variant="primary">Click me</flux:button>
|
||||||
|
```
|
||||||
|
|
||||||
|
## Available Components (Free Edition)
|
||||||
|
|
||||||
|
Available: avatar, badge, brand, breadcrumbs, button, callout, checkbox, dropdown, field, heading, icon, input, modal, navbar, otp-input, profile, radio, select, separator, skeleton, switch, text, textarea, tooltip
|
||||||
|
|
||||||
|
## Icons
|
||||||
|
|
||||||
|
Flux includes [Heroicons](https://heroicons.com/) as its default icon set. Search for exact icon names on the Heroicons site - do not guess or invent icon names.
|
||||||
|
|
||||||
|
<!-- Icon Button -->
|
||||||
|
```blade
|
||||||
|
<flux:button icon="arrow-down-tray">Export</flux:button>
|
||||||
|
```
|
||||||
|
|
||||||
|
For icons not available in Heroicons, use [Lucide](https://lucide.dev/). Import the icons you need with the Artisan command:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
php artisan flux:icon crown grip-vertical github
|
||||||
|
```
|
||||||
|
|
||||||
|
## Common Patterns
|
||||||
|
|
||||||
|
### Form Fields
|
||||||
|
|
||||||
|
<!-- Form Field -->
|
||||||
|
```blade
|
||||||
|
<flux:field>
|
||||||
|
<flux:label>Email</flux:label>
|
||||||
|
<flux:input type="email" wire:model="email" />
|
||||||
|
<flux:error name="email" />
|
||||||
|
</flux:field>
|
||||||
|
```
|
||||||
|
|
||||||
|
### Modals
|
||||||
|
|
||||||
|
<!-- Modal -->
|
||||||
|
```blade
|
||||||
|
<flux:modal wire:model="showModal">
|
||||||
|
<flux:heading>Title</flux:heading>
|
||||||
|
<p>Content</p>
|
||||||
|
</flux:modal>
|
||||||
|
```
|
||||||
|
|
||||||
|
## Verification
|
||||||
|
|
||||||
|
1. Check component renders correctly
|
||||||
|
2. Test interactive states
|
||||||
|
3. Verify mobile responsiveness
|
||||||
|
|
||||||
|
## Common Pitfalls
|
||||||
|
|
||||||
|
- Trying to use Pro-only components in the free edition
|
||||||
|
- Not checking if a Flux component exists before creating custom implementations
|
||||||
|
- Forgetting to use the `search-docs` tool for component-specific documentation
|
||||||
|
- Not following existing project patterns for Flux usage
|
||||||
117
.junie/skills/pest-testing/SKILL.md
Normal file
117
.junie/skills/pest-testing/SKILL.md
Normal file
@@ -0,0 +1,117 @@
|
|||||||
|
---
|
||||||
|
name: pest-testing
|
||||||
|
description: "Tests applications using the Pest 3 PHP framework. Activates when writing tests, creating unit or feature tests, adding assertions, testing Livewire components, architecture testing, debugging test failures, working with datasets or mocking; or when the user mentions test, spec, TDD, expects, assertion, coverage, or needs to verify functionality works."
|
||||||
|
license: MIT
|
||||||
|
metadata:
|
||||||
|
author: laravel
|
||||||
|
---
|
||||||
|
|
||||||
|
# Pest Testing 3
|
||||||
|
|
||||||
|
## When to Apply
|
||||||
|
|
||||||
|
Activate this skill when:
|
||||||
|
- Creating new tests (unit or feature)
|
||||||
|
- Modifying existing tests
|
||||||
|
- Debugging test failures
|
||||||
|
- Working with datasets, mocking, or test organization
|
||||||
|
- Writing architecture tests
|
||||||
|
|
||||||
|
## Documentation
|
||||||
|
|
||||||
|
Use `search-docs` for detailed Pest 3 patterns and documentation.
|
||||||
|
|
||||||
|
## Basic Usage
|
||||||
|
|
||||||
|
### Creating Tests
|
||||||
|
|
||||||
|
All tests must be written using Pest. Use `php artisan make:test --pest {name}`.
|
||||||
|
|
||||||
|
### Test Organization
|
||||||
|
|
||||||
|
- Tests live in the `tests/Feature` and `tests/Unit` directories.
|
||||||
|
- Do NOT remove tests without approval - these are core application code.
|
||||||
|
- Test happy paths, failure paths, and edge cases.
|
||||||
|
|
||||||
|
### Basic Test Structure
|
||||||
|
|
||||||
|
<!-- Basic Pest Test Example -->
|
||||||
|
```php
|
||||||
|
it('is true', function () {
|
||||||
|
expect(true)->toBeTrue();
|
||||||
|
});
|
||||||
|
```
|
||||||
|
|
||||||
|
### Running Tests
|
||||||
|
|
||||||
|
- Run minimal tests with filter before finalizing: `php artisan test --compact --filter=testName`.
|
||||||
|
- Run all tests: `php artisan test --compact`.
|
||||||
|
- Run file: `php artisan test --compact tests/Feature/ExampleTest.php`.
|
||||||
|
|
||||||
|
## Assertions
|
||||||
|
|
||||||
|
Use specific assertions (`assertSuccessful()`, `assertNotFound()`) instead of `assertStatus()`:
|
||||||
|
|
||||||
|
<!-- Pest Response Assertion -->
|
||||||
|
```php
|
||||||
|
it('returns all', function () {
|
||||||
|
$this->postJson('/api/docs', [])->assertSuccessful();
|
||||||
|
});
|
||||||
|
```
|
||||||
|
|
||||||
|
| Use | Instead of |
|
||||||
|
|-----|------------|
|
||||||
|
| `assertSuccessful()` | `assertStatus(200)` |
|
||||||
|
| `assertNotFound()` | `assertStatus(404)` |
|
||||||
|
| `assertForbidden()` | `assertStatus(403)` |
|
||||||
|
|
||||||
|
## Mocking
|
||||||
|
|
||||||
|
Import mock function before use: `use function Pest\Laravel\mock;`
|
||||||
|
|
||||||
|
## Datasets
|
||||||
|
|
||||||
|
Use datasets for repetitive tests (validation rules, etc.):
|
||||||
|
|
||||||
|
<!-- Pest Dataset Example -->
|
||||||
|
```php
|
||||||
|
it('has emails', function (string $email) {
|
||||||
|
expect($email)->not->toBeEmpty();
|
||||||
|
})->with([
|
||||||
|
'james' => 'james@laravel.com',
|
||||||
|
'taylor' => 'taylor@laravel.com',
|
||||||
|
]);
|
||||||
|
```
|
||||||
|
|
||||||
|
## Pest 3 Features
|
||||||
|
|
||||||
|
### Architecture Testing
|
||||||
|
|
||||||
|
Pest 3 includes architecture testing to enforce code conventions:
|
||||||
|
|
||||||
|
<!-- Architecture Test Example -->
|
||||||
|
```php
|
||||||
|
arch('controllers')
|
||||||
|
->expect('App\Http\Controllers')
|
||||||
|
->toExtendNothing()
|
||||||
|
->toHaveSuffix('Controller');
|
||||||
|
|
||||||
|
arch('models')
|
||||||
|
->expect('App\Models')
|
||||||
|
->toExtend('Illuminate\Database\Eloquent\Model');
|
||||||
|
|
||||||
|
arch('no debugging')
|
||||||
|
->expect(['dd', 'dump', 'ray'])
|
||||||
|
->not->toBeUsed();
|
||||||
|
```
|
||||||
|
|
||||||
|
### Type Coverage
|
||||||
|
|
||||||
|
Pest 3 provides improved type coverage analysis. Run with `--type-coverage` flag.
|
||||||
|
|
||||||
|
## Common Pitfalls
|
||||||
|
|
||||||
|
- Not importing `use function Pest\Laravel\mock;` before using mock
|
||||||
|
- Using `assertStatus(200)` instead of `assertSuccessful()`
|
||||||
|
- Forgetting datasets for repetitive validation tests
|
||||||
|
- Deleting tests without approval
|
||||||
129
.junie/skills/tailwindcss-development/SKILL.md
Normal file
129
.junie/skills/tailwindcss-development/SKILL.md
Normal file
@@ -0,0 +1,129 @@
|
|||||||
|
---
|
||||||
|
name: tailwindcss-development
|
||||||
|
description: "Styles applications using Tailwind CSS v4 utilities. Activates when adding styles, restyling components, working with gradients, spacing, layout, flex, grid, responsive design, dark mode, colors, typography, or borders; or when the user mentions CSS, styling, classes, Tailwind, restyle, hero section, cards, buttons, or any visual/UI changes."
|
||||||
|
license: MIT
|
||||||
|
metadata:
|
||||||
|
author: laravel
|
||||||
|
---
|
||||||
|
|
||||||
|
# Tailwind CSS Development
|
||||||
|
|
||||||
|
## When to Apply
|
||||||
|
|
||||||
|
Activate this skill when:
|
||||||
|
|
||||||
|
- Adding styles to components or pages
|
||||||
|
- Working with responsive design
|
||||||
|
- Implementing dark mode
|
||||||
|
- Extracting repeated patterns into components
|
||||||
|
- Debugging spacing or layout issues
|
||||||
|
|
||||||
|
## Documentation
|
||||||
|
|
||||||
|
Use `search-docs` for detailed Tailwind CSS v4 patterns and documentation.
|
||||||
|
|
||||||
|
## Basic Usage
|
||||||
|
|
||||||
|
- Use Tailwind CSS classes to style HTML. Check and follow existing Tailwind conventions in the project before introducing new patterns.
|
||||||
|
- Offer to extract repeated patterns into components that match the project's conventions (e.g., Blade, JSX, Vue).
|
||||||
|
- Consider class placement, order, priority, and defaults. Remove redundant classes, add classes to parent or child elements carefully to reduce repetition, and group elements logically.
|
||||||
|
|
||||||
|
## Tailwind CSS v4 Specifics
|
||||||
|
|
||||||
|
- Always use Tailwind CSS v4 and avoid deprecated utilities.
|
||||||
|
- `corePlugins` is not supported in Tailwind v4.
|
||||||
|
|
||||||
|
### CSS-First Configuration
|
||||||
|
|
||||||
|
In Tailwind v4, configuration is CSS-first using the `@theme` directive — no separate `tailwind.config.js` file is needed:
|
||||||
|
|
||||||
|
<!-- CSS-First Config -->
|
||||||
|
```css
|
||||||
|
@theme {
|
||||||
|
--color-brand: oklch(0.72 0.11 178);
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### Import Syntax
|
||||||
|
|
||||||
|
In Tailwind v4, import Tailwind with a regular CSS `@import` statement instead of the `@tailwind` directives used in v3:
|
||||||
|
|
||||||
|
<!-- v4 Import Syntax -->
|
||||||
|
```diff
|
||||||
|
- @tailwind base;
|
||||||
|
- @tailwind components;
|
||||||
|
- @tailwind utilities;
|
||||||
|
+ @import "tailwindcss";
|
||||||
|
```
|
||||||
|
|
||||||
|
### Replaced Utilities
|
||||||
|
|
||||||
|
Tailwind v4 removed deprecated utilities. Use the replacements shown below. Opacity values remain numeric.
|
||||||
|
|
||||||
|
| Deprecated | Replacement |
|
||||||
|
|------------|-------------|
|
||||||
|
| bg-opacity-* | bg-black/* |
|
||||||
|
| text-opacity-* | text-black/* |
|
||||||
|
| border-opacity-* | border-black/* |
|
||||||
|
| divide-opacity-* | divide-black/* |
|
||||||
|
| ring-opacity-* | ring-black/* |
|
||||||
|
| placeholder-opacity-* | placeholder-black/* |
|
||||||
|
| flex-shrink-* | shrink-* |
|
||||||
|
| flex-grow-* | grow-* |
|
||||||
|
| overflow-ellipsis | text-ellipsis |
|
||||||
|
| decoration-slice | box-decoration-slice |
|
||||||
|
| decoration-clone | box-decoration-clone |
|
||||||
|
|
||||||
|
## Spacing
|
||||||
|
|
||||||
|
Use `gap` utilities instead of margins for spacing between siblings:
|
||||||
|
|
||||||
|
<!-- Gap Utilities -->
|
||||||
|
```html
|
||||||
|
<div class="flex gap-8">
|
||||||
|
<div>Item 1</div>
|
||||||
|
<div>Item 2</div>
|
||||||
|
</div>
|
||||||
|
```
|
||||||
|
|
||||||
|
## Dark Mode
|
||||||
|
|
||||||
|
If existing pages and components support dark mode, new pages and components must support it the same way, typically using the `dark:` variant:
|
||||||
|
|
||||||
|
<!-- Dark Mode -->
|
||||||
|
```html
|
||||||
|
<div class="bg-white dark:bg-gray-900 text-gray-900 dark:text-white">
|
||||||
|
Content adapts to color scheme
|
||||||
|
</div>
|
||||||
|
```
|
||||||
|
|
||||||
|
## Common Patterns
|
||||||
|
|
||||||
|
### Flexbox Layout
|
||||||
|
|
||||||
|
<!-- Flexbox Layout -->
|
||||||
|
```html
|
||||||
|
<div class="flex items-center justify-between gap-4">
|
||||||
|
<div>Left content</div>
|
||||||
|
<div>Right content</div>
|
||||||
|
</div>
|
||||||
|
```
|
||||||
|
|
||||||
|
### Grid Layout
|
||||||
|
|
||||||
|
<!-- Grid Layout -->
|
||||||
|
```html
|
||||||
|
<div class="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-6">
|
||||||
|
<div>Card 1</div>
|
||||||
|
<div>Card 2</div>
|
||||||
|
<div>Card 3</div>
|
||||||
|
</div>
|
||||||
|
```
|
||||||
|
|
||||||
|
## Common Pitfalls
|
||||||
|
|
||||||
|
- Using deprecated v3 utilities (bg-opacity-*, flex-shrink-*, etc.)
|
||||||
|
- Using `@tailwind` directives instead of `@import "tailwindcss"`
|
||||||
|
- Trying to use `tailwind.config.js` instead of CSS `@theme` directive
|
||||||
|
- Using margins for spacing between siblings instead of gap utilities
|
||||||
|
- Forgetting to add dark mode variants when the project uses dark mode
|
||||||
96
.junie/skills/volt-development/SKILL.md
Normal file
96
.junie/skills/volt-development/SKILL.md
Normal file
@@ -0,0 +1,96 @@
|
|||||||
|
---
|
||||||
|
name: volt-development
|
||||||
|
description: "Develops single-file Livewire components with Volt. Activates when creating Volt components, converting Livewire to Volt, working with @volt directive, functional or class-based Volt APIs; or when the user mentions Volt, single-file components, functional Livewire, or inline component logic in Blade files."
|
||||||
|
license: MIT
|
||||||
|
metadata:
|
||||||
|
author: laravel
|
||||||
|
---
|
||||||
|
|
||||||
|
# Volt Development
|
||||||
|
|
||||||
|
## When to Apply
|
||||||
|
|
||||||
|
Activate this skill when:
|
||||||
|
|
||||||
|
- Creating Volt single-file components
|
||||||
|
- Converting traditional Livewire components to Volt
|
||||||
|
- Testing Volt components
|
||||||
|
|
||||||
|
## Documentation
|
||||||
|
|
||||||
|
Use `search-docs` for detailed Volt patterns and documentation.
|
||||||
|
|
||||||
|
## Basic Usage
|
||||||
|
|
||||||
|
Create components with `php artisan make:volt [name] [--test] [--pest]`.
|
||||||
|
|
||||||
|
Important: Check existing Volt components to determine if they use functional or class-based style before creating new ones.
|
||||||
|
|
||||||
|
### Functional Components
|
||||||
|
|
||||||
|
<!-- Volt Functional Component -->
|
||||||
|
```php
|
||||||
|
@@volt
|
||||||
|
<?php
|
||||||
|
use function Livewire\Volt\{state, computed};
|
||||||
|
|
||||||
|
state(['count' => 0]);
|
||||||
|
|
||||||
|
$increment = fn () => $this->count++;
|
||||||
|
$double = computed(fn () => $this->count * 2);
|
||||||
|
?>
|
||||||
|
|
||||||
|
<div>
|
||||||
|
<h1>Count: @{{ $count }} (Double: @{{ $this->double }})</h1>
|
||||||
|
<button wire:click="increment">+</button>
|
||||||
|
</div>
|
||||||
|
@@endvolt
|
||||||
|
```
|
||||||
|
|
||||||
|
### Class-Based Components
|
||||||
|
|
||||||
|
<!-- Volt Class-based Component -->
|
||||||
|
```php
|
||||||
|
use Livewire\Volt\Component;
|
||||||
|
|
||||||
|
new class extends Component {
|
||||||
|
public int $count = 0;
|
||||||
|
|
||||||
|
public function increment(): void
|
||||||
|
{
|
||||||
|
$this->count++;
|
||||||
|
}
|
||||||
|
} ?>
|
||||||
|
|
||||||
|
<div>
|
||||||
|
<h1>@{{ $count }}</h1>
|
||||||
|
<button wire:click="increment">+</button>
|
||||||
|
</div>
|
||||||
|
```
|
||||||
|
|
||||||
|
## Testing
|
||||||
|
|
||||||
|
Tests go in existing Volt test directory or `tests/Feature/Volt`:
|
||||||
|
|
||||||
|
<!-- Volt Test Example -->
|
||||||
|
```php
|
||||||
|
use Livewire\Volt\Volt;
|
||||||
|
|
||||||
|
test('counter increments', function () {
|
||||||
|
Volt::test('counter')
|
||||||
|
->assertSee('Count: 0')
|
||||||
|
->call('increment')
|
||||||
|
->assertSee('Count: 1');
|
||||||
|
});
|
||||||
|
```
|
||||||
|
|
||||||
|
## Verification
|
||||||
|
|
||||||
|
1. Check existing components for functional vs class-based style
|
||||||
|
2. Test component with `Volt::test()`
|
||||||
|
|
||||||
|
## Common Pitfalls
|
||||||
|
|
||||||
|
- Not checking existing style (functional vs class-based) before creating
|
||||||
|
- Forgetting `@volt` directive wrapper
|
||||||
|
- Missing `--test` or `--pest` flag when tests are needed
|
||||||
11
.mcp.json
Normal file
11
.mcp.json
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
{
|
||||||
|
"mcpServers": {
|
||||||
|
"laravel-boost": {
|
||||||
|
"command": "php",
|
||||||
|
"args": [
|
||||||
|
"artisan",
|
||||||
|
"boost:mcp"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
432
CLAUDE.md
Normal file
432
CLAUDE.md
Normal file
@@ -0,0 +1,432 @@
|
|||||||
|
<laravel-boost-guidelines>
|
||||||
|
=== foundation rules ===
|
||||||
|
|
||||||
|
# Laravel Boost Guidelines
|
||||||
|
|
||||||
|
The Laravel Boost guidelines are specifically curated by Laravel maintainers for this application. These guidelines should be followed closely to ensure the best experience when building Laravel applications.
|
||||||
|
|
||||||
|
## Foundational Context
|
||||||
|
|
||||||
|
This application is a Laravel application and its main Laravel ecosystems package & versions are below. You are an expert with them all. Ensure you abide by these specific packages & versions.
|
||||||
|
|
||||||
|
- php - 8.4.12
|
||||||
|
- filament/filament (FILAMENT) - v4
|
||||||
|
- laravel/fortify (FORTIFY) - v1
|
||||||
|
- laravel/framework (LARAVEL) - v12
|
||||||
|
- laravel/pint (PINT) - v1
|
||||||
|
- laravel/prompts (PROMPTS) - v0
|
||||||
|
- livewire/flux (FLUXUI_FREE) - v2
|
||||||
|
- livewire/livewire (LIVEWIRE) - v3
|
||||||
|
- livewire/volt (VOLT) - v1
|
||||||
|
- laravel/boost (BOOST) - v2
|
||||||
|
- laravel/mcp (MCP) - v0
|
||||||
|
- laravel/pail (PAIL) - v1
|
||||||
|
- laravel/sail (SAIL) - v1
|
||||||
|
- pestphp/pest (PEST) - v3
|
||||||
|
- phpunit/phpunit (PHPUNIT) - v11
|
||||||
|
- rector/rector (RECTOR) - v2
|
||||||
|
- tailwindcss (TAILWINDCSS) - v4
|
||||||
|
|
||||||
|
## Skills Activation
|
||||||
|
|
||||||
|
This project has domain-specific skills available. You MUST activate the relevant skill whenever you work in that domain—don't wait until you're stuck.
|
||||||
|
|
||||||
|
- `fluxui-development` — Develops UIs with Flux UI Free components. Activates when creating buttons, forms, modals, inputs, dropdowns, checkboxes, or UI components; replacing HTML form elements with Flux; working with flux: components; or when the user mentions Flux, component library, UI components, form fields, or asks about available Flux components.
|
||||||
|
- `volt-development` — Develops single-file Livewire components with Volt. Activates when creating Volt components, converting Livewire to Volt, working with @volt directive, functional or class-based Volt APIs; or when the user mentions Volt, single-file components, functional Livewire, or inline component logic in Blade files.
|
||||||
|
- `pest-testing` — Tests applications using the Pest 3 PHP framework. Activates when writing tests, creating unit or feature tests, adding assertions, testing Livewire components, architecture testing, debugging test failures, working with datasets or mocking; or when the user mentions test, spec, TDD, expects, assertion, coverage, or needs to verify functionality works.
|
||||||
|
- `tailwindcss-development` — Styles applications using Tailwind CSS v4 utilities. Activates when adding styles, restyling components, working with gradients, spacing, layout, flex, grid, responsive design, dark mode, colors, typography, or borders; or when the user mentions CSS, styling, classes, Tailwind, restyle, hero section, cards, buttons, or any visual/UI changes.
|
||||||
|
- `filament-db-config` — Creates database-backed settings pages and config pages with filament-db-config or db-config package. Activates when creating settings page, config page, configuration page, or when user mentions db-config, db_config, DbConfig, database settings, dynamic configuration, runtime config, storing settings in database. ALWAYS use php artisan make:db-config command to scaffold. NEVER create files manually. NEVER create tests.
|
||||||
|
- `developing-with-fortify` — Laravel Fortify headless authentication backend development. Activate when implementing authentication features including login, registration, password reset, email verification, two-factor authentication (2FA/TOTP), profile updates, headless auth, authentication scaffolding, or auth guards in Laravel applications.
|
||||||
|
|
||||||
|
## Conventions
|
||||||
|
|
||||||
|
- You must follow all existing code conventions used in this application. When creating or editing a file, check sibling files for the correct structure, approach, and naming.
|
||||||
|
- Use descriptive names for variables and methods. For example, `isRegisteredForDiscounts`, not `discount()`.
|
||||||
|
- Check for existing components to reuse before writing a new one.
|
||||||
|
|
||||||
|
## Verification Scripts
|
||||||
|
|
||||||
|
- Do not create verification scripts or tinker when tests cover that functionality and prove they work. Unit and feature tests are more important.
|
||||||
|
|
||||||
|
## Application Structure & Architecture
|
||||||
|
|
||||||
|
- Stick to existing directory structure; don't create new base folders without approval.
|
||||||
|
- Do not change the application's dependencies without approval.
|
||||||
|
|
||||||
|
## Frontend Bundling
|
||||||
|
|
||||||
|
- If the user doesn't see a frontend change reflected in the UI, it could mean they need to run `npm run build`, `npm run dev`, or `composer run dev`. Ask them.
|
||||||
|
|
||||||
|
## Documentation Files
|
||||||
|
|
||||||
|
- You must only create documentation files if explicitly requested by the user.
|
||||||
|
|
||||||
|
## Replies
|
||||||
|
|
||||||
|
- Be concise in your explanations - focus on what's important rather than explaining obvious details.
|
||||||
|
|
||||||
|
=== boost rules ===
|
||||||
|
|
||||||
|
# Laravel Boost
|
||||||
|
|
||||||
|
- Laravel Boost is an MCP server that comes with powerful tools designed specifically for this application. Use them.
|
||||||
|
|
||||||
|
## Artisan
|
||||||
|
|
||||||
|
- Use the `list-artisan-commands` tool when you need to call an Artisan command to double-check the available parameters.
|
||||||
|
|
||||||
|
## URLs
|
||||||
|
|
||||||
|
- Whenever you share a project URL with the user, you should use the `get-absolute-url` tool to ensure you're using the correct scheme, domain/IP, and port.
|
||||||
|
|
||||||
|
## Tinker / Debugging
|
||||||
|
|
||||||
|
- You should use the `tinker` tool when you need to execute PHP to debug code or query Eloquent models directly.
|
||||||
|
- Use the `database-query` tool when you only need to read from the database.
|
||||||
|
- Use the `database-schema` tool to inspect table structure before writing migrations or models.
|
||||||
|
|
||||||
|
## Reading Browser Logs With the `browser-logs` Tool
|
||||||
|
|
||||||
|
- You can read browser logs, errors, and exceptions using the `browser-logs` tool from Boost.
|
||||||
|
- Only recent browser logs will be useful - ignore old logs.
|
||||||
|
|
||||||
|
## Searching Documentation (Critically Important)
|
||||||
|
|
||||||
|
- Boost comes with a powerful `search-docs` tool you should use before trying other approaches when working with Laravel or Laravel ecosystem packages. This tool automatically passes a list of installed packages and their versions to the remote Boost API, so it returns only version-specific documentation for the user's circumstance. You should pass an array of packages to filter on if you know you need docs for particular packages.
|
||||||
|
- Search the documentation before making code changes to ensure we are taking the correct approach.
|
||||||
|
- Use multiple, broad, simple, topic-based queries at once. For example: `['rate limiting', 'routing rate limiting', 'routing']`. The most relevant results will be returned first.
|
||||||
|
- Do not add package names to queries; package information is already shared. For example, use `test resource table`, not `filament 4 test resource table`.
|
||||||
|
|
||||||
|
### Available Search Syntax
|
||||||
|
|
||||||
|
1. Simple Word Searches with auto-stemming - query=authentication - finds 'authenticate' and 'auth'.
|
||||||
|
2. Multiple Words (AND Logic) - query=rate limit - finds knowledge containing both "rate" AND "limit".
|
||||||
|
3. Quoted Phrases (Exact Position) - query="infinite scroll" - words must be adjacent and in that order.
|
||||||
|
4. Mixed Queries - query=middleware "rate limit" - "middleware" AND exact phrase "rate limit".
|
||||||
|
5. Multiple Queries - queries=["authentication", "middleware"] - ANY of these terms.
|
||||||
|
|
||||||
|
=== php rules ===
|
||||||
|
|
||||||
|
# PHP
|
||||||
|
|
||||||
|
- Always use curly braces for control structures, even for single-line bodies.
|
||||||
|
|
||||||
|
## Constructors
|
||||||
|
|
||||||
|
- Use PHP 8 constructor property promotion in `__construct()`.
|
||||||
|
- `public function __construct(public GitHub $github) { }`
|
||||||
|
- Do not allow empty `__construct()` methods with zero parameters unless the constructor is private.
|
||||||
|
|
||||||
|
## Type Declarations
|
||||||
|
|
||||||
|
- Always use explicit return type declarations for methods and functions.
|
||||||
|
- Use appropriate PHP type hints for method parameters.
|
||||||
|
|
||||||
|
<!-- Explicit Return Types and Method Params -->
|
||||||
|
```php
|
||||||
|
protected function isAccessible(User $user, ?string $path = null): bool
|
||||||
|
{
|
||||||
|
...
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## Enums
|
||||||
|
|
||||||
|
- Typically, keys in an Enum should be TitleCase. For example: `FavoritePerson`, `BestLake`, `Monthly`.
|
||||||
|
|
||||||
|
## Comments
|
||||||
|
|
||||||
|
- Prefer PHPDoc blocks over inline comments. Never use comments within the code itself unless the logic is exceptionally complex.
|
||||||
|
|
||||||
|
## PHPDoc Blocks
|
||||||
|
|
||||||
|
- Add useful array shape type definitions when appropriate.
|
||||||
|
|
||||||
|
=== tests rules ===
|
||||||
|
|
||||||
|
# Test Enforcement
|
||||||
|
|
||||||
|
- Every change must be programmatically tested. Write a new test or update an existing test, then run the affected tests to make sure they pass.
|
||||||
|
- Run the minimum number of tests needed to ensure code quality and speed. Use `php artisan test --compact` with a specific filename or filter.
|
||||||
|
|
||||||
|
=== laravel/core rules ===
|
||||||
|
|
||||||
|
# Do Things the Laravel Way
|
||||||
|
|
||||||
|
- Use `php artisan make:` commands to create new files (i.e. migrations, controllers, models, etc.). You can list available Artisan commands using the `list-artisan-commands` tool.
|
||||||
|
- If you're creating a generic PHP class, use `php artisan make:class`.
|
||||||
|
- Pass `--no-interaction` to all Artisan commands to ensure they work without user input. You should also pass the correct `--options` to ensure correct behavior.
|
||||||
|
|
||||||
|
## Database
|
||||||
|
|
||||||
|
- Always use proper Eloquent relationship methods with return type hints. Prefer relationship methods over raw queries or manual joins.
|
||||||
|
- Use Eloquent models and relationships before suggesting raw database queries.
|
||||||
|
- Avoid `DB::`; prefer `Model::query()`. Generate code that leverages Laravel's ORM capabilities rather than bypassing them.
|
||||||
|
- Generate code that prevents N+1 query problems by using eager loading.
|
||||||
|
- Use Laravel's query builder for very complex database operations.
|
||||||
|
|
||||||
|
### Model Creation
|
||||||
|
|
||||||
|
- When creating new models, create useful factories and seeders for them too. Ask the user if they need any other things, using `list-artisan-commands` to check the available options to `php artisan make:model`.
|
||||||
|
|
||||||
|
### APIs & Eloquent Resources
|
||||||
|
|
||||||
|
- For APIs, default to using Eloquent API Resources and API versioning unless existing API routes do not, then you should follow existing application convention.
|
||||||
|
|
||||||
|
## Controllers & Validation
|
||||||
|
|
||||||
|
- Always create Form Request classes for validation rather than inline validation in controllers. Include both validation rules and custom error messages.
|
||||||
|
- Check sibling Form Requests to see if the application uses array or string based validation rules.
|
||||||
|
|
||||||
|
## Authentication & Authorization
|
||||||
|
|
||||||
|
- Use Laravel's built-in authentication and authorization features (gates, policies, Sanctum, etc.).
|
||||||
|
|
||||||
|
## URL Generation
|
||||||
|
|
||||||
|
- When generating links to other pages, prefer named routes and the `route()` function.
|
||||||
|
|
||||||
|
## Queues
|
||||||
|
|
||||||
|
- Use queued jobs for time-consuming operations with the `ShouldQueue` interface.
|
||||||
|
|
||||||
|
## Configuration
|
||||||
|
|
||||||
|
- Use environment variables only in configuration files - never use the `env()` function directly outside of config files. Always use `config('app.name')`, not `env('APP_NAME')`.
|
||||||
|
|
||||||
|
## Testing
|
||||||
|
|
||||||
|
- When creating models for tests, use the factories for the models. Check if the factory has custom states that can be used before manually setting up the model.
|
||||||
|
- Faker: Use methods such as `$this->faker->word()` or `fake()->randomDigit()`. Follow existing conventions whether to use `$this->faker` or `fake()`.
|
||||||
|
- When creating tests, make use of `php artisan make:test [options] {name}` to create a feature test, and pass `--unit` to create a unit test. Most tests should be feature tests.
|
||||||
|
|
||||||
|
## Vite Error
|
||||||
|
|
||||||
|
- If you receive an "Illuminate\Foundation\ViteException: Unable to locate file in Vite manifest" error, you can run `npm run build` or ask the user to run `npm run dev` or `composer run dev`.
|
||||||
|
|
||||||
|
=== laravel/v12 rules ===
|
||||||
|
|
||||||
|
# Laravel 12
|
||||||
|
|
||||||
|
- CRITICAL: ALWAYS use `search-docs` tool for version-specific Laravel documentation and updated code examples.
|
||||||
|
- Since Laravel 11, Laravel has a new streamlined file structure which this project uses.
|
||||||
|
|
||||||
|
## Laravel 12 Structure
|
||||||
|
|
||||||
|
- In Laravel 12, middleware are no longer registered in `app/Http/Kernel.php`.
|
||||||
|
- Middleware are configured declaratively in `bootstrap/app.php` using `Application::configure()->withMiddleware()`.
|
||||||
|
- `bootstrap/app.php` is the file to register middleware, exceptions, and routing files.
|
||||||
|
- `bootstrap/providers.php` contains application specific service providers.
|
||||||
|
- The `app\Console\Kernel.php` file no longer exists; use `bootstrap/app.php` or `routes/console.php` for console configuration.
|
||||||
|
- Console commands in `app/Console/Commands/` are automatically available and do not require manual registration.
|
||||||
|
|
||||||
|
## Database
|
||||||
|
|
||||||
|
- When modifying a column, the migration must include all of the attributes that were previously defined on the column. Otherwise, they will be dropped and lost.
|
||||||
|
- Laravel 12 allows limiting eagerly loaded records natively, without external packages: `$query->latest()->limit(10);`.
|
||||||
|
|
||||||
|
### Models
|
||||||
|
|
||||||
|
- Casts can and likely should be set in a `casts()` method on a model rather than the `$casts` property. Follow existing conventions from other models.
|
||||||
|
|
||||||
|
=== pint/core rules ===
|
||||||
|
|
||||||
|
# Laravel Pint Code Formatter
|
||||||
|
|
||||||
|
- If you have modified any PHP files, you must run `vendor/bin/pint --dirty --format agent` before finalizing changes to ensure your code matches the project's expected style.
|
||||||
|
- Do not run `vendor/bin/pint --test --format agent`, simply run `vendor/bin/pint --format agent` to fix any formatting issues.
|
||||||
|
|
||||||
|
=== fluxui-free/core rules ===
|
||||||
|
|
||||||
|
# Flux UI Free
|
||||||
|
|
||||||
|
- Flux UI is the official Livewire component library. This project uses the free edition, which includes all free components and variants but not Pro components.
|
||||||
|
- Use `<flux:*>` components when available; they are the recommended way to build Livewire interfaces.
|
||||||
|
- IMPORTANT: Activate `fluxui-development` when working with Flux UI components.
|
||||||
|
|
||||||
|
=== volt/core rules ===
|
||||||
|
|
||||||
|
# Livewire Volt
|
||||||
|
|
||||||
|
- Single-file Livewire components: PHP logic and Blade templates in one file.
|
||||||
|
- Always check existing Volt components to determine functional vs class-based style.
|
||||||
|
- IMPORTANT: Always use `search-docs` tool for version-specific Volt documentation and updated code examples.
|
||||||
|
- IMPORTANT: Activate `volt-development` every time you're working with a Volt or single-file component-related task.
|
||||||
|
|
||||||
|
=== pest/core rules ===
|
||||||
|
|
||||||
|
## Pest
|
||||||
|
|
||||||
|
- This project uses Pest for testing. Create tests: `php artisan make:test --pest {name}`.
|
||||||
|
- Run tests: `php artisan test --compact` or filter: `php artisan test --compact --filter=testName`.
|
||||||
|
- Do NOT delete tests without approval.
|
||||||
|
- CRITICAL: ALWAYS use `search-docs` tool for version-specific Pest documentation and updated code examples.
|
||||||
|
- IMPORTANT: Activate `pest-testing` every time you're working with a Pest or testing-related task.
|
||||||
|
|
||||||
|
=== tailwindcss/core rules ===
|
||||||
|
|
||||||
|
# Tailwind CSS
|
||||||
|
|
||||||
|
- Always use existing Tailwind conventions; check project patterns before adding new ones.
|
||||||
|
- IMPORTANT: Always use `search-docs` tool for version-specific Tailwind CSS documentation and updated code examples. Never rely on training data.
|
||||||
|
- IMPORTANT: Activate `tailwindcss-development` every time you're working with a Tailwind CSS or styling-related task.
|
||||||
|
|
||||||
|
=== filament/filament rules ===
|
||||||
|
|
||||||
|
## Filament
|
||||||
|
|
||||||
|
- Filament is used by this application. Follow the existing conventions for how and where it is implemented.
|
||||||
|
- Filament is a Server-Driven UI (SDUI) framework for Laravel that lets you define user interfaces in PHP using structured configuration objects. Built on Livewire, Alpine.js, and Tailwind CSS.
|
||||||
|
- Use the `search-docs` tool for official documentation on Artisan commands, code examples, testing, relationships, and idiomatic practices. If `search-docs` is unavailable, refer to https://filamentphp.com/docs.
|
||||||
|
|
||||||
|
### Artisan
|
||||||
|
|
||||||
|
- Always use Filament-specific Artisan commands to create files. Find available commands with the `list-artisan-commands` tool, or run `php artisan --help`.
|
||||||
|
- Always inspect required options before running a command, and always pass `--no-interaction`.
|
||||||
|
|
||||||
|
### Patterns
|
||||||
|
|
||||||
|
Always use static `make()` methods to initialize components. Most configuration methods accept a `Closure` for dynamic values.
|
||||||
|
|
||||||
|
Use `Get $get` to read other form field values for conditional logic:
|
||||||
|
|
||||||
|
<code-snippet name="Conditional form field visibility" lang="php">
|
||||||
|
use Filament\Forms\Components\Select;
|
||||||
|
use Filament\Forms\Components\TextInput;
|
||||||
|
use Filament\Schemas\Components\Utilities\Get;
|
||||||
|
|
||||||
|
Select::make('type')
|
||||||
|
->options(CompanyType::class)
|
||||||
|
->required()
|
||||||
|
->live(),
|
||||||
|
|
||||||
|
TextInput::make('company_name')
|
||||||
|
->required()
|
||||||
|
->visible(fn (Get $get): bool => $get('type') === 'business'),
|
||||||
|
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
Use `state()` with a `Closure` to compute derived column values:
|
||||||
|
|
||||||
|
<code-snippet name="Computed table column value" lang="php">
|
||||||
|
use Filament\Tables\Columns\TextColumn;
|
||||||
|
|
||||||
|
TextColumn::make('full_name')
|
||||||
|
->state(fn (User $record): string => "{$record->first_name} {$record->last_name}"),
|
||||||
|
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
Actions encapsulate a button with an optional modal form and logic:
|
||||||
|
|
||||||
|
<code-snippet name="Action with modal form" lang="php">
|
||||||
|
use Filament\Actions\Action;
|
||||||
|
use Filament\Forms\Components\TextInput;
|
||||||
|
|
||||||
|
Action::make('updateEmail')
|
||||||
|
->schema([
|
||||||
|
TextInput::make('email')
|
||||||
|
->email()
|
||||||
|
->required(),
|
||||||
|
])
|
||||||
|
->action(fn (array $data, User $record) => $record->update($data))
|
||||||
|
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
### Testing
|
||||||
|
|
||||||
|
Always authenticate before testing panel functionality. Filament uses Livewire, so use `Livewire::test()` or `livewire()` (available when `pestphp/pest-plugin-livewire` is in `composer.json`):
|
||||||
|
|
||||||
|
<code-snippet name="Table test" lang="php">
|
||||||
|
use function Pest\Livewire\livewire;
|
||||||
|
|
||||||
|
livewire(ListUsers::class)
|
||||||
|
->assertCanSeeTableRecords($users)
|
||||||
|
->searchTable($users->first()->name)
|
||||||
|
->assertCanSeeTableRecords($users->take(1))
|
||||||
|
->assertCanNotSeeTableRecords($users->skip(1));
|
||||||
|
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
<code-snippet name="Create resource test" lang="php">
|
||||||
|
use function Pest\Laravel\assertDatabaseHas;
|
||||||
|
use function Pest\Livewire\livewire;
|
||||||
|
|
||||||
|
livewire(CreateUser::class)
|
||||||
|
->fillForm([
|
||||||
|
'name' => 'Test',
|
||||||
|
'email' => 'test@example.com',
|
||||||
|
])
|
||||||
|
->call('create')
|
||||||
|
->assertNotified()
|
||||||
|
->assertRedirect();
|
||||||
|
|
||||||
|
assertDatabaseHas(User::class, [
|
||||||
|
'name' => 'Test',
|
||||||
|
'email' => 'test@example.com',
|
||||||
|
]);
|
||||||
|
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
<code-snippet name="Testing validation" lang="php">
|
||||||
|
use function Pest\Livewire\livewire;
|
||||||
|
|
||||||
|
livewire(CreateUser::class)
|
||||||
|
->fillForm([
|
||||||
|
'name' => null,
|
||||||
|
'email' => 'invalid-email',
|
||||||
|
])
|
||||||
|
->call('create')
|
||||||
|
->assertHasFormErrors([
|
||||||
|
'name' => 'required',
|
||||||
|
'email' => 'email',
|
||||||
|
])
|
||||||
|
->assertNotNotified();
|
||||||
|
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
<code-snippet name="Calling actions in pages" lang="php">
|
||||||
|
use Filament\Actions\DeleteAction;
|
||||||
|
use function Pest\Livewire\livewire;
|
||||||
|
|
||||||
|
livewire(EditUser::class, ['record' => $user->id])
|
||||||
|
->callAction(DeleteAction::class)
|
||||||
|
->assertNotified()
|
||||||
|
->assertRedirect();
|
||||||
|
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
<code-snippet name="Calling actions in tables" lang="php">
|
||||||
|
use Filament\Actions\Testing\TestAction;
|
||||||
|
use function Pest\Livewire\livewire;
|
||||||
|
|
||||||
|
livewire(ListUsers::class)
|
||||||
|
->callAction(TestAction::make('promote')->table($user), [
|
||||||
|
'role' => 'admin',
|
||||||
|
])
|
||||||
|
->assertNotified();
|
||||||
|
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
### Correct Namespaces
|
||||||
|
|
||||||
|
- Form fields (`TextInput`, `Select`, etc.): `Filament\Forms\Components\`
|
||||||
|
- Infolist entries (`TextEntry`, `IconEntry`, etc.): `Filament\Infolists\Components\`
|
||||||
|
- Layout components (`Grid`, `Section`, `Fieldset`, `Tabs`, `Wizard`, etc.): `Filament\Schemas\Components\`
|
||||||
|
- Schema utilities (`Get`, `Set`, etc.): `Filament\Schemas\Components\Utilities\`
|
||||||
|
- Actions (`DeleteAction`, `CreateAction`, etc.): `Filament\Actions\`. Never use `Filament\Tables\Actions\`, `Filament\Forms\Actions\`, or any other sub-namespace for actions.
|
||||||
|
- Icons: `Filament\Support\Icons\Heroicon` enum (e.g., `Heroicon::PencilSquare`)
|
||||||
|
|
||||||
|
### Common Mistakes
|
||||||
|
|
||||||
|
- **Never assume public file visibility.** File visibility is `private` by default. Always use `->visibility('public')` when public access is needed.
|
||||||
|
- **Never assume full-width layout.** `Grid`, `Section`, and `Fieldset` do not span all columns by default. Explicitly set column spans when needed.
|
||||||
|
|
||||||
|
=== laravel/fortify rules ===
|
||||||
|
|
||||||
|
# Laravel Fortify
|
||||||
|
|
||||||
|
- Fortify is a headless authentication backend that provides authentication routes and controllers for Laravel applications.
|
||||||
|
- IMPORTANT: Always use the `search-docs` tool for detailed Laravel Fortify patterns and documentation.
|
||||||
|
- IMPORTANT: Activate `developing-with-fortify` skill when working with Fortify authentication features.
|
||||||
|
|
||||||
|
</laravel-boost-guidelines>
|
||||||
432
GEMINI.md
Normal file
432
GEMINI.md
Normal file
@@ -0,0 +1,432 @@
|
|||||||
|
<laravel-boost-guidelines>
|
||||||
|
=== foundation rules ===
|
||||||
|
|
||||||
|
# Laravel Boost Guidelines
|
||||||
|
|
||||||
|
The Laravel Boost guidelines are specifically curated by Laravel maintainers for this application. These guidelines should be followed closely to ensure the best experience when building Laravel applications.
|
||||||
|
|
||||||
|
## Foundational Context
|
||||||
|
|
||||||
|
This application is a Laravel application and its main Laravel ecosystems package & versions are below. You are an expert with them all. Ensure you abide by these specific packages & versions.
|
||||||
|
|
||||||
|
- php - 8.4.12
|
||||||
|
- filament/filament (FILAMENT) - v4
|
||||||
|
- laravel/fortify (FORTIFY) - v1
|
||||||
|
- laravel/framework (LARAVEL) - v12
|
||||||
|
- laravel/pint (PINT) - v1
|
||||||
|
- laravel/prompts (PROMPTS) - v0
|
||||||
|
- livewire/flux (FLUXUI_FREE) - v2
|
||||||
|
- livewire/livewire (LIVEWIRE) - v3
|
||||||
|
- livewire/volt (VOLT) - v1
|
||||||
|
- laravel/boost (BOOST) - v2
|
||||||
|
- laravel/mcp (MCP) - v0
|
||||||
|
- laravel/pail (PAIL) - v1
|
||||||
|
- laravel/sail (SAIL) - v1
|
||||||
|
- pestphp/pest (PEST) - v3
|
||||||
|
- phpunit/phpunit (PHPUNIT) - v11
|
||||||
|
- rector/rector (RECTOR) - v2
|
||||||
|
- tailwindcss (TAILWINDCSS) - v4
|
||||||
|
|
||||||
|
## Skills Activation
|
||||||
|
|
||||||
|
This project has domain-specific skills available. You MUST activate the relevant skill whenever you work in that domain—don't wait until you're stuck.
|
||||||
|
|
||||||
|
- `fluxui-development` — Develops UIs with Flux UI Free components. Activates when creating buttons, forms, modals, inputs, dropdowns, checkboxes, or UI components; replacing HTML form elements with Flux; working with flux: components; or when the user mentions Flux, component library, UI components, form fields, or asks about available Flux components.
|
||||||
|
- `volt-development` — Develops single-file Livewire components with Volt. Activates when creating Volt components, converting Livewire to Volt, working with @volt directive, functional or class-based Volt APIs; or when the user mentions Volt, single-file components, functional Livewire, or inline component logic in Blade files.
|
||||||
|
- `pest-testing` — Tests applications using the Pest 3 PHP framework. Activates when writing tests, creating unit or feature tests, adding assertions, testing Livewire components, architecture testing, debugging test failures, working with datasets or mocking; or when the user mentions test, spec, TDD, expects, assertion, coverage, or needs to verify functionality works.
|
||||||
|
- `tailwindcss-development` — Styles applications using Tailwind CSS v4 utilities. Activates when adding styles, restyling components, working with gradients, spacing, layout, flex, grid, responsive design, dark mode, colors, typography, or borders; or when the user mentions CSS, styling, classes, Tailwind, restyle, hero section, cards, buttons, or any visual/UI changes.
|
||||||
|
- `filament-db-config` — Creates database-backed settings pages and config pages with filament-db-config or db-config package. Activates when creating settings page, config page, configuration page, or when user mentions db-config, db_config, DbConfig, database settings, dynamic configuration, runtime config, storing settings in database. ALWAYS use php artisan make:db-config command to scaffold. NEVER create files manually. NEVER create tests.
|
||||||
|
- `developing-with-fortify` — Laravel Fortify headless authentication backend development. Activate when implementing authentication features including login, registration, password reset, email verification, two-factor authentication (2FA/TOTP), profile updates, headless auth, authentication scaffolding, or auth guards in Laravel applications.
|
||||||
|
|
||||||
|
## Conventions
|
||||||
|
|
||||||
|
- You must follow all existing code conventions used in this application. When creating or editing a file, check sibling files for the correct structure, approach, and naming.
|
||||||
|
- Use descriptive names for variables and methods. For example, `isRegisteredForDiscounts`, not `discount()`.
|
||||||
|
- Check for existing components to reuse before writing a new one.
|
||||||
|
|
||||||
|
## Verification Scripts
|
||||||
|
|
||||||
|
- Do not create verification scripts or tinker when tests cover that functionality and prove they work. Unit and feature tests are more important.
|
||||||
|
|
||||||
|
## Application Structure & Architecture
|
||||||
|
|
||||||
|
- Stick to existing directory structure; don't create new base folders without approval.
|
||||||
|
- Do not change the application's dependencies without approval.
|
||||||
|
|
||||||
|
## Frontend Bundling
|
||||||
|
|
||||||
|
- If the user doesn't see a frontend change reflected in the UI, it could mean they need to run `npm run build`, `npm run dev`, or `composer run dev`. Ask them.
|
||||||
|
|
||||||
|
## Documentation Files
|
||||||
|
|
||||||
|
- You must only create documentation files if explicitly requested by the user.
|
||||||
|
|
||||||
|
## Replies
|
||||||
|
|
||||||
|
- Be concise in your explanations - focus on what's important rather than explaining obvious details.
|
||||||
|
|
||||||
|
=== boost rules ===
|
||||||
|
|
||||||
|
# Laravel Boost
|
||||||
|
|
||||||
|
- Laravel Boost is an MCP server that comes with powerful tools designed specifically for this application. Use them.
|
||||||
|
|
||||||
|
## Artisan
|
||||||
|
|
||||||
|
- Use the `list-artisan-commands` tool when you need to call an Artisan command to double-check the available parameters.
|
||||||
|
|
||||||
|
## URLs
|
||||||
|
|
||||||
|
- Whenever you share a project URL with the user, you should use the `get-absolute-url` tool to ensure you're using the correct scheme, domain/IP, and port.
|
||||||
|
|
||||||
|
## Tinker / Debugging
|
||||||
|
|
||||||
|
- You should use the `tinker` tool when you need to execute PHP to debug code or query Eloquent models directly.
|
||||||
|
- Use the `database-query` tool when you only need to read from the database.
|
||||||
|
- Use the `database-schema` tool to inspect table structure before writing migrations or models.
|
||||||
|
|
||||||
|
## Reading Browser Logs With the `browser-logs` Tool
|
||||||
|
|
||||||
|
- You can read browser logs, errors, and exceptions using the `browser-logs` tool from Boost.
|
||||||
|
- Only recent browser logs will be useful - ignore old logs.
|
||||||
|
|
||||||
|
## Searching Documentation (Critically Important)
|
||||||
|
|
||||||
|
- Boost comes with a powerful `search-docs` tool you should use before trying other approaches when working with Laravel or Laravel ecosystem packages. This tool automatically passes a list of installed packages and their versions to the remote Boost API, so it returns only version-specific documentation for the user's circumstance. You should pass an array of packages to filter on if you know you need docs for particular packages.
|
||||||
|
- Search the documentation before making code changes to ensure we are taking the correct approach.
|
||||||
|
- Use multiple, broad, simple, topic-based queries at once. For example: `['rate limiting', 'routing rate limiting', 'routing']`. The most relevant results will be returned first.
|
||||||
|
- Do not add package names to queries; package information is already shared. For example, use `test resource table`, not `filament 4 test resource table`.
|
||||||
|
|
||||||
|
### Available Search Syntax
|
||||||
|
|
||||||
|
1. Simple Word Searches with auto-stemming - query=authentication - finds 'authenticate' and 'auth'.
|
||||||
|
2. Multiple Words (AND Logic) - query=rate limit - finds knowledge containing both "rate" AND "limit".
|
||||||
|
3. Quoted Phrases (Exact Position) - query="infinite scroll" - words must be adjacent and in that order.
|
||||||
|
4. Mixed Queries - query=middleware "rate limit" - "middleware" AND exact phrase "rate limit".
|
||||||
|
5. Multiple Queries - queries=["authentication", "middleware"] - ANY of these terms.
|
||||||
|
|
||||||
|
=== php rules ===
|
||||||
|
|
||||||
|
# PHP
|
||||||
|
|
||||||
|
- Always use curly braces for control structures, even for single-line bodies.
|
||||||
|
|
||||||
|
## Constructors
|
||||||
|
|
||||||
|
- Use PHP 8 constructor property promotion in `__construct()`.
|
||||||
|
- `public function __construct(public GitHub $github) { }`
|
||||||
|
- Do not allow empty `__construct()` methods with zero parameters unless the constructor is private.
|
||||||
|
|
||||||
|
## Type Declarations
|
||||||
|
|
||||||
|
- Always use explicit return type declarations for methods and functions.
|
||||||
|
- Use appropriate PHP type hints for method parameters.
|
||||||
|
|
||||||
|
<!-- Explicit Return Types and Method Params -->
|
||||||
|
```php
|
||||||
|
protected function isAccessible(User $user, ?string $path = null): bool
|
||||||
|
{
|
||||||
|
...
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## Enums
|
||||||
|
|
||||||
|
- Typically, keys in an Enum should be TitleCase. For example: `FavoritePerson`, `BestLake`, `Monthly`.
|
||||||
|
|
||||||
|
## Comments
|
||||||
|
|
||||||
|
- Prefer PHPDoc blocks over inline comments. Never use comments within the code itself unless the logic is exceptionally complex.
|
||||||
|
|
||||||
|
## PHPDoc Blocks
|
||||||
|
|
||||||
|
- Add useful array shape type definitions when appropriate.
|
||||||
|
|
||||||
|
=== tests rules ===
|
||||||
|
|
||||||
|
# Test Enforcement
|
||||||
|
|
||||||
|
- Every change must be programmatically tested. Write a new test or update an existing test, then run the affected tests to make sure they pass.
|
||||||
|
- Run the minimum number of tests needed to ensure code quality and speed. Use `php artisan test --compact` with a specific filename or filter.
|
||||||
|
|
||||||
|
=== laravel/core rules ===
|
||||||
|
|
||||||
|
# Do Things the Laravel Way
|
||||||
|
|
||||||
|
- Use `php artisan make:` commands to create new files (i.e. migrations, controllers, models, etc.). You can list available Artisan commands using the `list-artisan-commands` tool.
|
||||||
|
- If you're creating a generic PHP class, use `php artisan make:class`.
|
||||||
|
- Pass `--no-interaction` to all Artisan commands to ensure they work without user input. You should also pass the correct `--options` to ensure correct behavior.
|
||||||
|
|
||||||
|
## Database
|
||||||
|
|
||||||
|
- Always use proper Eloquent relationship methods with return type hints. Prefer relationship methods over raw queries or manual joins.
|
||||||
|
- Use Eloquent models and relationships before suggesting raw database queries.
|
||||||
|
- Avoid `DB::`; prefer `Model::query()`. Generate code that leverages Laravel's ORM capabilities rather than bypassing them.
|
||||||
|
- Generate code that prevents N+1 query problems by using eager loading.
|
||||||
|
- Use Laravel's query builder for very complex database operations.
|
||||||
|
|
||||||
|
### Model Creation
|
||||||
|
|
||||||
|
- When creating new models, create useful factories and seeders for them too. Ask the user if they need any other things, using `list-artisan-commands` to check the available options to `php artisan make:model`.
|
||||||
|
|
||||||
|
### APIs & Eloquent Resources
|
||||||
|
|
||||||
|
- For APIs, default to using Eloquent API Resources and API versioning unless existing API routes do not, then you should follow existing application convention.
|
||||||
|
|
||||||
|
## Controllers & Validation
|
||||||
|
|
||||||
|
- Always create Form Request classes for validation rather than inline validation in controllers. Include both validation rules and custom error messages.
|
||||||
|
- Check sibling Form Requests to see if the application uses array or string based validation rules.
|
||||||
|
|
||||||
|
## Authentication & Authorization
|
||||||
|
|
||||||
|
- Use Laravel's built-in authentication and authorization features (gates, policies, Sanctum, etc.).
|
||||||
|
|
||||||
|
## URL Generation
|
||||||
|
|
||||||
|
- When generating links to other pages, prefer named routes and the `route()` function.
|
||||||
|
|
||||||
|
## Queues
|
||||||
|
|
||||||
|
- Use queued jobs for time-consuming operations with the `ShouldQueue` interface.
|
||||||
|
|
||||||
|
## Configuration
|
||||||
|
|
||||||
|
- Use environment variables only in configuration files - never use the `env()` function directly outside of config files. Always use `config('app.name')`, not `env('APP_NAME')`.
|
||||||
|
|
||||||
|
## Testing
|
||||||
|
|
||||||
|
- When creating models for tests, use the factories for the models. Check if the factory has custom states that can be used before manually setting up the model.
|
||||||
|
- Faker: Use methods such as `$this->faker->word()` or `fake()->randomDigit()`. Follow existing conventions whether to use `$this->faker` or `fake()`.
|
||||||
|
- When creating tests, make use of `php artisan make:test [options] {name}` to create a feature test, and pass `--unit` to create a unit test. Most tests should be feature tests.
|
||||||
|
|
||||||
|
## Vite Error
|
||||||
|
|
||||||
|
- If you receive an "Illuminate\Foundation\ViteException: Unable to locate file in Vite manifest" error, you can run `npm run build` or ask the user to run `npm run dev` or `composer run dev`.
|
||||||
|
|
||||||
|
=== laravel/v12 rules ===
|
||||||
|
|
||||||
|
# Laravel 12
|
||||||
|
|
||||||
|
- CRITICAL: ALWAYS use `search-docs` tool for version-specific Laravel documentation and updated code examples.
|
||||||
|
- Since Laravel 11, Laravel has a new streamlined file structure which this project uses.
|
||||||
|
|
||||||
|
## Laravel 12 Structure
|
||||||
|
|
||||||
|
- In Laravel 12, middleware are no longer registered in `app/Http/Kernel.php`.
|
||||||
|
- Middleware are configured declaratively in `bootstrap/app.php` using `Application::configure()->withMiddleware()`.
|
||||||
|
- `bootstrap/app.php` is the file to register middleware, exceptions, and routing files.
|
||||||
|
- `bootstrap/providers.php` contains application specific service providers.
|
||||||
|
- The `app\Console\Kernel.php` file no longer exists; use `bootstrap/app.php` or `routes/console.php` for console configuration.
|
||||||
|
- Console commands in `app/Console/Commands/` are automatically available and do not require manual registration.
|
||||||
|
|
||||||
|
## Database
|
||||||
|
|
||||||
|
- When modifying a column, the migration must include all of the attributes that were previously defined on the column. Otherwise, they will be dropped and lost.
|
||||||
|
- Laravel 12 allows limiting eagerly loaded records natively, without external packages: `$query->latest()->limit(10);`.
|
||||||
|
|
||||||
|
### Models
|
||||||
|
|
||||||
|
- Casts can and likely should be set in a `casts()` method on a model rather than the `$casts` property. Follow existing conventions from other models.
|
||||||
|
|
||||||
|
=== pint/core rules ===
|
||||||
|
|
||||||
|
# Laravel Pint Code Formatter
|
||||||
|
|
||||||
|
- If you have modified any PHP files, you must run `vendor/bin/pint --dirty --format agent` before finalizing changes to ensure your code matches the project's expected style.
|
||||||
|
- Do not run `vendor/bin/pint --test --format agent`, simply run `vendor/bin/pint --format agent` to fix any formatting issues.
|
||||||
|
|
||||||
|
=== fluxui-free/core rules ===
|
||||||
|
|
||||||
|
# Flux UI Free
|
||||||
|
|
||||||
|
- Flux UI is the official Livewire component library. This project uses the free edition, which includes all free components and variants but not Pro components.
|
||||||
|
- Use `<flux:*>` components when available; they are the recommended way to build Livewire interfaces.
|
||||||
|
- IMPORTANT: Activate `fluxui-development` when working with Flux UI components.
|
||||||
|
|
||||||
|
=== volt/core rules ===
|
||||||
|
|
||||||
|
# Livewire Volt
|
||||||
|
|
||||||
|
- Single-file Livewire components: PHP logic and Blade templates in one file.
|
||||||
|
- Always check existing Volt components to determine functional vs class-based style.
|
||||||
|
- IMPORTANT: Always use `search-docs` tool for version-specific Volt documentation and updated code examples.
|
||||||
|
- IMPORTANT: Activate `volt-development` every time you're working with a Volt or single-file component-related task.
|
||||||
|
|
||||||
|
=== pest/core rules ===
|
||||||
|
|
||||||
|
## Pest
|
||||||
|
|
||||||
|
- This project uses Pest for testing. Create tests: `php artisan make:test --pest {name}`.
|
||||||
|
- Run tests: `php artisan test --compact` or filter: `php artisan test --compact --filter=testName`.
|
||||||
|
- Do NOT delete tests without approval.
|
||||||
|
- CRITICAL: ALWAYS use `search-docs` tool for version-specific Pest documentation and updated code examples.
|
||||||
|
- IMPORTANT: Activate `pest-testing` every time you're working with a Pest or testing-related task.
|
||||||
|
|
||||||
|
=== tailwindcss/core rules ===
|
||||||
|
|
||||||
|
# Tailwind CSS
|
||||||
|
|
||||||
|
- Always use existing Tailwind conventions; check project patterns before adding new ones.
|
||||||
|
- IMPORTANT: Always use `search-docs` tool for version-specific Tailwind CSS documentation and updated code examples. Never rely on training data.
|
||||||
|
- IMPORTANT: Activate `tailwindcss-development` every time you're working with a Tailwind CSS or styling-related task.
|
||||||
|
|
||||||
|
=== filament/filament rules ===
|
||||||
|
|
||||||
|
## Filament
|
||||||
|
|
||||||
|
- Filament is used by this application. Follow the existing conventions for how and where it is implemented.
|
||||||
|
- Filament is a Server-Driven UI (SDUI) framework for Laravel that lets you define user interfaces in PHP using structured configuration objects. Built on Livewire, Alpine.js, and Tailwind CSS.
|
||||||
|
- Use the `search-docs` tool for official documentation on Artisan commands, code examples, testing, relationships, and idiomatic practices. If `search-docs` is unavailable, refer to https://filamentphp.com/docs.
|
||||||
|
|
||||||
|
### Artisan
|
||||||
|
|
||||||
|
- Always use Filament-specific Artisan commands to create files. Find available commands with the `list-artisan-commands` tool, or run `php artisan --help`.
|
||||||
|
- Always inspect required options before running a command, and always pass `--no-interaction`.
|
||||||
|
|
||||||
|
### Patterns
|
||||||
|
|
||||||
|
Always use static `make()` methods to initialize components. Most configuration methods accept a `Closure` for dynamic values.
|
||||||
|
|
||||||
|
Use `Get $get` to read other form field values for conditional logic:
|
||||||
|
|
||||||
|
<code-snippet name="Conditional form field visibility" lang="php">
|
||||||
|
use Filament\Forms\Components\Select;
|
||||||
|
use Filament\Forms\Components\TextInput;
|
||||||
|
use Filament\Schemas\Components\Utilities\Get;
|
||||||
|
|
||||||
|
Select::make('type')
|
||||||
|
->options(CompanyType::class)
|
||||||
|
->required()
|
||||||
|
->live(),
|
||||||
|
|
||||||
|
TextInput::make('company_name')
|
||||||
|
->required()
|
||||||
|
->visible(fn (Get $get): bool => $get('type') === 'business'),
|
||||||
|
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
Use `state()` with a `Closure` to compute derived column values:
|
||||||
|
|
||||||
|
<code-snippet name="Computed table column value" lang="php">
|
||||||
|
use Filament\Tables\Columns\TextColumn;
|
||||||
|
|
||||||
|
TextColumn::make('full_name')
|
||||||
|
->state(fn (User $record): string => "{$record->first_name} {$record->last_name}"),
|
||||||
|
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
Actions encapsulate a button with an optional modal form and logic:
|
||||||
|
|
||||||
|
<code-snippet name="Action with modal form" lang="php">
|
||||||
|
use Filament\Actions\Action;
|
||||||
|
use Filament\Forms\Components\TextInput;
|
||||||
|
|
||||||
|
Action::make('updateEmail')
|
||||||
|
->schema([
|
||||||
|
TextInput::make('email')
|
||||||
|
->email()
|
||||||
|
->required(),
|
||||||
|
])
|
||||||
|
->action(fn (array $data, User $record) => $record->update($data))
|
||||||
|
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
### Testing
|
||||||
|
|
||||||
|
Always authenticate before testing panel functionality. Filament uses Livewire, so use `Livewire::test()` or `livewire()` (available when `pestphp/pest-plugin-livewire` is in `composer.json`):
|
||||||
|
|
||||||
|
<code-snippet name="Table test" lang="php">
|
||||||
|
use function Pest\Livewire\livewire;
|
||||||
|
|
||||||
|
livewire(ListUsers::class)
|
||||||
|
->assertCanSeeTableRecords($users)
|
||||||
|
->searchTable($users->first()->name)
|
||||||
|
->assertCanSeeTableRecords($users->take(1))
|
||||||
|
->assertCanNotSeeTableRecords($users->skip(1));
|
||||||
|
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
<code-snippet name="Create resource test" lang="php">
|
||||||
|
use function Pest\Laravel\assertDatabaseHas;
|
||||||
|
use function Pest\Livewire\livewire;
|
||||||
|
|
||||||
|
livewire(CreateUser::class)
|
||||||
|
->fillForm([
|
||||||
|
'name' => 'Test',
|
||||||
|
'email' => 'test@example.com',
|
||||||
|
])
|
||||||
|
->call('create')
|
||||||
|
->assertNotified()
|
||||||
|
->assertRedirect();
|
||||||
|
|
||||||
|
assertDatabaseHas(User::class, [
|
||||||
|
'name' => 'Test',
|
||||||
|
'email' => 'test@example.com',
|
||||||
|
]);
|
||||||
|
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
<code-snippet name="Testing validation" lang="php">
|
||||||
|
use function Pest\Livewire\livewire;
|
||||||
|
|
||||||
|
livewire(CreateUser::class)
|
||||||
|
->fillForm([
|
||||||
|
'name' => null,
|
||||||
|
'email' => 'invalid-email',
|
||||||
|
])
|
||||||
|
->call('create')
|
||||||
|
->assertHasFormErrors([
|
||||||
|
'name' => 'required',
|
||||||
|
'email' => 'email',
|
||||||
|
])
|
||||||
|
->assertNotNotified();
|
||||||
|
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
<code-snippet name="Calling actions in pages" lang="php">
|
||||||
|
use Filament\Actions\DeleteAction;
|
||||||
|
use function Pest\Livewire\livewire;
|
||||||
|
|
||||||
|
livewire(EditUser::class, ['record' => $user->id])
|
||||||
|
->callAction(DeleteAction::class)
|
||||||
|
->assertNotified()
|
||||||
|
->assertRedirect();
|
||||||
|
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
<code-snippet name="Calling actions in tables" lang="php">
|
||||||
|
use Filament\Actions\Testing\TestAction;
|
||||||
|
use function Pest\Livewire\livewire;
|
||||||
|
|
||||||
|
livewire(ListUsers::class)
|
||||||
|
->callAction(TestAction::make('promote')->table($user), [
|
||||||
|
'role' => 'admin',
|
||||||
|
])
|
||||||
|
->assertNotified();
|
||||||
|
|
||||||
|
</code-snippet>
|
||||||
|
|
||||||
|
### Correct Namespaces
|
||||||
|
|
||||||
|
- Form fields (`TextInput`, `Select`, etc.): `Filament\Forms\Components\`
|
||||||
|
- Infolist entries (`TextEntry`, `IconEntry`, etc.): `Filament\Infolists\Components\`
|
||||||
|
- Layout components (`Grid`, `Section`, `Fieldset`, `Tabs`, `Wizard`, etc.): `Filament\Schemas\Components\`
|
||||||
|
- Schema utilities (`Get`, `Set`, etc.): `Filament\Schemas\Components\Utilities\`
|
||||||
|
- Actions (`DeleteAction`, `CreateAction`, etc.): `Filament\Actions\`. Never use `Filament\Tables\Actions\`, `Filament\Forms\Actions\`, or any other sub-namespace for actions.
|
||||||
|
- Icons: `Filament\Support\Icons\Heroicon` enum (e.g., `Heroicon::PencilSquare`)
|
||||||
|
|
||||||
|
### Common Mistakes
|
||||||
|
|
||||||
|
- **Never assume public file visibility.** File visibility is `private` by default. Always use `->visibility('public')` when public access is needed.
|
||||||
|
- **Never assume full-width layout.** `Grid`, `Section`, and `Fieldset` do not span all columns by default. Explicitly set column spans when needed.
|
||||||
|
|
||||||
|
=== laravel/fortify rules ===
|
||||||
|
|
||||||
|
# Laravel Fortify
|
||||||
|
|
||||||
|
- Fortify is a headless authentication backend that provides authentication routes and controllers for Laravel applications.
|
||||||
|
- IMPORTANT: Always use the `search-docs` tool for detailed Laravel Fortify patterns and documentation.
|
||||||
|
- IMPORTANT: Activate `developing-with-fortify` skill when working with Fortify authentication features.
|
||||||
|
|
||||||
|
</laravel-boost-guidelines>
|
||||||
25
boost.json
Normal file
25
boost.json
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
{
|
||||||
|
"agents": [
|
||||||
|
"junie",
|
||||||
|
"gemini",
|
||||||
|
"claude_code"
|
||||||
|
],
|
||||||
|
"guidelines": true,
|
||||||
|
"herd_mcp": false,
|
||||||
|
"mcp": true,
|
||||||
|
"nightwatch_mcp": false,
|
||||||
|
"packages": [
|
||||||
|
"filament/filament",
|
||||||
|
"laravel/fortify",
|
||||||
|
"inerba/filament-db-config"
|
||||||
|
],
|
||||||
|
"sail": false,
|
||||||
|
"skills": [
|
||||||
|
"fluxui-development",
|
||||||
|
"volt-development",
|
||||||
|
"pest-testing",
|
||||||
|
"tailwindcss-development",
|
||||||
|
"filament-db-config",
|
||||||
|
"developing-with-fortify"
|
||||||
|
]
|
||||||
|
}
|
||||||
@@ -16,12 +16,13 @@
|
|||||||
"laravel/framework": "^12.0",
|
"laravel/framework": "^12.0",
|
||||||
"laravel/tinker": "^2.10.1",
|
"laravel/tinker": "^2.10.1",
|
||||||
"livewire/flux": "^2.1.1",
|
"livewire/flux": "^2.1.1",
|
||||||
"livewire/volt": "^1.7.0",
|
"livewire/volt": "^1.10",
|
||||||
"spatie/laravel-activitylog": "^4.10",
|
"spatie/laravel-activitylog": "^4.10",
|
||||||
"spatie/laravel-permission": "^6.21"
|
"spatie/laravel-permission": "^6.21"
|
||||||
},
|
},
|
||||||
"require-dev": {
|
"require-dev": {
|
||||||
"fakerphp/faker": "^1.23",
|
"fakerphp/faker": "^1.23",
|
||||||
|
"laravel/boost": "^2.2",
|
||||||
"laravel/pail": "^1.2.2",
|
"laravel/pail": "^1.2.2",
|
||||||
"laravel/pint": "^1.18",
|
"laravel/pint": "^1.18",
|
||||||
"laravel/sail": "^1.41",
|
"laravel/sail": "^1.41",
|
||||||
@@ -50,7 +51,8 @@
|
|||||||
"@php artisan filament:upgrade"
|
"@php artisan filament:upgrade"
|
||||||
],
|
],
|
||||||
"post-update-cmd": [
|
"post-update-cmd": [
|
||||||
"@php artisan vendor:publish --tag=laravel-assets --ansi --force"
|
"@php artisan vendor:publish --tag=laravel-assets --ansi --force",
|
||||||
|
"@php artisan boost:update --ansi"
|
||||||
],
|
],
|
||||||
"post-root-package-install": [
|
"post-root-package-install": [
|
||||||
"@php -r \"file_exists('.env') || copy('.env.example', '.env');\""
|
"@php -r \"file_exists('.env') || copy('.env.example', '.env');\""
|
||||||
|
|||||||
202
composer.lock
generated
202
composer.lock
generated
@@ -4,7 +4,7 @@
|
|||||||
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
|
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
|
||||||
"This file is @generated automatically"
|
"This file is @generated automatically"
|
||||||
],
|
],
|
||||||
"content-hash": "5f204de64c42fb825f8a047d09cd57fc",
|
"content-hash": "1880ed79157a9c191a8fe0c40ca7e844",
|
||||||
"packages": [
|
"packages": [
|
||||||
{
|
{
|
||||||
"name": "anourvalar/eloquent-serialize",
|
"name": "anourvalar/eloquent-serialize",
|
||||||
@@ -9595,6 +9595,145 @@
|
|||||||
},
|
},
|
||||||
"time": "2025-03-19T14:43:43+00:00"
|
"time": "2025-03-19T14:43:43+00:00"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "laravel/boost",
|
||||||
|
"version": "v2.2.1",
|
||||||
|
"source": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "https://github.com/laravel/boost.git",
|
||||||
|
"reference": "e27f1616177377fef95296620530c44a7dda4df9"
|
||||||
|
},
|
||||||
|
"dist": {
|
||||||
|
"type": "zip",
|
||||||
|
"url": "https://api.github.com/repos/laravel/boost/zipball/e27f1616177377fef95296620530c44a7dda4df9",
|
||||||
|
"reference": "e27f1616177377fef95296620530c44a7dda4df9",
|
||||||
|
"shasum": ""
|
||||||
|
},
|
||||||
|
"require": {
|
||||||
|
"guzzlehttp/guzzle": "^7.9",
|
||||||
|
"illuminate/console": "^11.45.3|^12.41.1",
|
||||||
|
"illuminate/contracts": "^11.45.3|^12.41.1",
|
||||||
|
"illuminate/routing": "^11.45.3|^12.41.1",
|
||||||
|
"illuminate/support": "^11.45.3|^12.41.1",
|
||||||
|
"laravel/mcp": "^0.5.1",
|
||||||
|
"laravel/prompts": "^0.3.10",
|
||||||
|
"laravel/roster": "^0.5.0",
|
||||||
|
"php": "^8.2"
|
||||||
|
},
|
||||||
|
"require-dev": {
|
||||||
|
"laravel/pint": "^1.27.0",
|
||||||
|
"mockery/mockery": "^1.6.12",
|
||||||
|
"orchestra/testbench": "^9.15.0|^10.6",
|
||||||
|
"pestphp/pest": "^2.36.0|^3.8.4|^4.1.5",
|
||||||
|
"phpstan/phpstan": "^2.1.27",
|
||||||
|
"rector/rector": "^2.1"
|
||||||
|
},
|
||||||
|
"type": "library",
|
||||||
|
"extra": {
|
||||||
|
"laravel": {
|
||||||
|
"providers": [
|
||||||
|
"Laravel\\Boost\\BoostServiceProvider"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"branch-alias": {
|
||||||
|
"dev-master": "1.x-dev"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": {
|
||||||
|
"Laravel\\Boost\\": "src/"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"notification-url": "https://packagist.org/downloads/",
|
||||||
|
"license": [
|
||||||
|
"MIT"
|
||||||
|
],
|
||||||
|
"description": "Laravel Boost accelerates AI-assisted development by providing the essential context and structure that AI needs to generate high-quality, Laravel-specific code.",
|
||||||
|
"homepage": "https://github.com/laravel/boost",
|
||||||
|
"keywords": [
|
||||||
|
"ai",
|
||||||
|
"dev",
|
||||||
|
"laravel"
|
||||||
|
],
|
||||||
|
"support": {
|
||||||
|
"issues": "https://github.com/laravel/boost/issues",
|
||||||
|
"source": "https://github.com/laravel/boost"
|
||||||
|
},
|
||||||
|
"time": "2026-02-25T16:07:36+00:00"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "laravel/mcp",
|
||||||
|
"version": "v0.5.9",
|
||||||
|
"source": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "https://github.com/laravel/mcp.git",
|
||||||
|
"reference": "39e8da60eb7bce4737c5d868d35a3fe78938c129"
|
||||||
|
},
|
||||||
|
"dist": {
|
||||||
|
"type": "zip",
|
||||||
|
"url": "https://api.github.com/repos/laravel/mcp/zipball/39e8da60eb7bce4737c5d868d35a3fe78938c129",
|
||||||
|
"reference": "39e8da60eb7bce4737c5d868d35a3fe78938c129",
|
||||||
|
"shasum": ""
|
||||||
|
},
|
||||||
|
"require": {
|
||||||
|
"ext-json": "*",
|
||||||
|
"ext-mbstring": "*",
|
||||||
|
"illuminate/console": "^11.45.3|^12.41.1|^13.0",
|
||||||
|
"illuminate/container": "^11.45.3|^12.41.1|^13.0",
|
||||||
|
"illuminate/contracts": "^11.45.3|^12.41.1|^13.0",
|
||||||
|
"illuminate/http": "^11.45.3|^12.41.1|^13.0",
|
||||||
|
"illuminate/json-schema": "^12.41.1|^13.0",
|
||||||
|
"illuminate/routing": "^11.45.3|^12.41.1|^13.0",
|
||||||
|
"illuminate/support": "^11.45.3|^12.41.1|^13.0",
|
||||||
|
"illuminate/validation": "^11.45.3|^12.41.1|^13.0",
|
||||||
|
"php": "^8.2"
|
||||||
|
},
|
||||||
|
"require-dev": {
|
||||||
|
"laravel/pint": "^1.20",
|
||||||
|
"orchestra/testbench": "^9.15|^10.8|^11.0",
|
||||||
|
"pestphp/pest": "^3.8.5|^4.3.2",
|
||||||
|
"phpstan/phpstan": "^2.1.27",
|
||||||
|
"rector/rector": "^2.2.4"
|
||||||
|
},
|
||||||
|
"type": "library",
|
||||||
|
"extra": {
|
||||||
|
"laravel": {
|
||||||
|
"aliases": {
|
||||||
|
"Mcp": "Laravel\\Mcp\\Server\\Facades\\Mcp"
|
||||||
|
},
|
||||||
|
"providers": [
|
||||||
|
"Laravel\\Mcp\\Server\\McpServiceProvider"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": {
|
||||||
|
"Laravel\\Mcp\\": "src/",
|
||||||
|
"Laravel\\Mcp\\Server\\": "src/Server/"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"notification-url": "https://packagist.org/downloads/",
|
||||||
|
"license": [
|
||||||
|
"MIT"
|
||||||
|
],
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "Taylor Otwell",
|
||||||
|
"email": "taylor@laravel.com"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"description": "Rapidly build MCP servers for your Laravel applications.",
|
||||||
|
"homepage": "https://github.com/laravel/mcp",
|
||||||
|
"keywords": [
|
||||||
|
"laravel",
|
||||||
|
"mcp"
|
||||||
|
],
|
||||||
|
"support": {
|
||||||
|
"issues": "https://github.com/laravel/mcp/issues",
|
||||||
|
"source": "https://github.com/laravel/mcp"
|
||||||
|
},
|
||||||
|
"time": "2026-02-17T19:05:53+00:00"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "laravel/pail",
|
"name": "laravel/pail",
|
||||||
"version": "v1.2.6",
|
"version": "v1.2.6",
|
||||||
@@ -9675,6 +9814,67 @@
|
|||||||
},
|
},
|
||||||
"time": "2026-02-09T13:44:54+00:00"
|
"time": "2026-02-09T13:44:54+00:00"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "laravel/roster",
|
||||||
|
"version": "v0.5.0",
|
||||||
|
"source": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "https://github.com/laravel/roster.git",
|
||||||
|
"reference": "56904a78f4d7360c1c490ced7deeebf9aecb8c0e"
|
||||||
|
},
|
||||||
|
"dist": {
|
||||||
|
"type": "zip",
|
||||||
|
"url": "https://api.github.com/repos/laravel/roster/zipball/56904a78f4d7360c1c490ced7deeebf9aecb8c0e",
|
||||||
|
"reference": "56904a78f4d7360c1c490ced7deeebf9aecb8c0e",
|
||||||
|
"shasum": ""
|
||||||
|
},
|
||||||
|
"require": {
|
||||||
|
"illuminate/console": "^11.0|^12.0|^13.0",
|
||||||
|
"illuminate/contracts": "^11.0|^12.0|^13.0",
|
||||||
|
"illuminate/routing": "^11.0|^12.0|^13.0",
|
||||||
|
"illuminate/support": "^11.0|^12.0|^13.0",
|
||||||
|
"php": "^8.2",
|
||||||
|
"symfony/yaml": "^7.2|^8.0"
|
||||||
|
},
|
||||||
|
"require-dev": {
|
||||||
|
"laravel/pint": "^1.14",
|
||||||
|
"mockery/mockery": "^1.6",
|
||||||
|
"orchestra/testbench": "^9.0|^10.0|^11.0",
|
||||||
|
"pestphp/pest": "^3.0|^4.1",
|
||||||
|
"phpstan/phpstan": "^2.0"
|
||||||
|
},
|
||||||
|
"type": "library",
|
||||||
|
"extra": {
|
||||||
|
"laravel": {
|
||||||
|
"providers": [
|
||||||
|
"Laravel\\Roster\\RosterServiceProvider"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"branch-alias": {
|
||||||
|
"dev-master": "1.x-dev"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": {
|
||||||
|
"Laravel\\Roster\\": "src/"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"notification-url": "https://packagist.org/downloads/",
|
||||||
|
"license": [
|
||||||
|
"MIT"
|
||||||
|
],
|
||||||
|
"description": "Detect packages & approaches in use within a Laravel project",
|
||||||
|
"homepage": "https://github.com/laravel/roster",
|
||||||
|
"keywords": [
|
||||||
|
"dev",
|
||||||
|
"laravel"
|
||||||
|
],
|
||||||
|
"support": {
|
||||||
|
"issues": "https://github.com/laravel/roster/issues",
|
||||||
|
"source": "https://github.com/laravel/roster"
|
||||||
|
},
|
||||||
|
"time": "2026-02-17T17:33:35+00:00"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "laravel/sail",
|
"name": "laravel/sail",
|
||||||
"version": "v1.53.0",
|
"version": "v1.53.0",
|
||||||
|
|||||||
Reference in New Issue
Block a user