Laravel Filament 3 Export to CSV & Excel 学習メモ
- 2025.04.29
- DEVELOP

目次
Export to CSV & Excel
※Database notifications が動かない(途中)
Filament では、行をCSVまたはXLSXファイルにエクスポートできるビルド済みのアクションが導入されました。トリガーボタンをクリックすると、エクスポートする列とラベルを入力するためのモーダルが表示されます。この機能はジョブバッチとデータベース通知を使用するため、Laravelからこれらのマイグレーションを公開する必要があります。また、Filamentがエクスポートに関する情報を保存するために使用するテーブルのマイグレーションも公開する必要があります。
参考ドキュメント
https://filamentphp.com/docs/3.x/actions/prebuilt-actions/export
sail artisan queue:batches-table
sail artisan notifications:table
sail artisan vendor:publish --tag=filament-actions-migrations

sail artisan migrate
※2025_04_28_090031_create_job_batches_table.php_bk をリネームした。重複のため。

エクスポーターの作成
sail artisan make:filament-exporter User

以下のソースが生成されました。


UserResorce.php (変更)
Users画面にexportボタンをヘッダ部に配置します。
<?php
namespace App\Filament\Resources;
use App\Filament\Resources\UserResource\Pages;
use App\Filament\Resources\UserResource\RelationManagers;
use App\Models\User;
use Filament\Forms;
use Filament\Forms\Form;
use Filament\Resources\Resource;
use Filament\Tables;
use Filament\Tables\Table;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\SoftDeletingScope;
use Filament\Actions\ExportAction;
class UserResource extends Resource
{
protected static ?string $model = User::class;
protected static ?string $navigationIcon = 'heroicon-o-users';
protected static ?string $navigationGroup = "User";
public static function form(Form $form): Form
{
return $form
->schema([
Forms\Components\TextInput::make('name')
->required()
->maxLength(255),
Forms\Components\TextInput::make('email')
->email()
->required()
->maxLength(255),
Forms\Components\Select::make('role')
->options(User::ROLES)
->required(),
]);
}
public static function table(Table $table): Table
{
return $table
->columns([
Tables\Columns\TextColumn::make('name')
->searchable(),
Tables\Columns\TextColumn::make('email')
->searchable(),
Tables\Columns\TextColumn::make('created_at')
->dateTime()
->sortable()
->toggleable(isToggledHiddenByDefault: true),
Tables\Columns\TextColumn::make('updated_at')
->dateTime()
->sortable()
->toggleable(isToggledHiddenByDefault: true),
Tables\Columns\TextColumn::make('role')
->badge()
->color(function(string $state) : string {
// return 'info'; //
// if ($state == 'ADMIN') return 'danger';
// return 'gray';
return match($state) {
'ADMIN' => 'danger', //RED
'EDITOR' => 'info', //BLUE
'USER' => 'success', //GREEN
};
})
->sortable()
->searchable(),
])
->filters([
//
])
->actions([
Tables\Actions\EditAction::make(),
])
->headerActions([
\Filament\Tables\Actions\ExportAction::make()->exporter(\App\Filament\Exports\UserExporter::class)
])
->bulkActions([
Tables\Actions\BulkActionGroup::make([
Tables\Actions\DeleteBulkAction::make(),
]),
]);
}
public static function getRelations(): array
{
return [
//
];
}
public static function getPages(): array
{
return [
'index' => Pages\ListUsers::route('/'),
'create' => Pages\CreateUser::route('/create'),
'edit' => Pages\EditUser::route('/{record}/edit'),
];
}
}
UserExporter.php (新規)
<?php
namespace App\Filament\Exports;
use App\Models\User;
use Filament\Actions\Exports\ExportColumn;
use Filament\Actions\Exports\Exporter;
use Filament\Actions\Exports\Models\Export;
class UserExporter extends Exporter
{
protected static ?string $model = User::class;
public static function getColumns(): array
{
return [
ExportColumn::make('id'),
ExportColumn::make('name'),
ExportColumn::make('email'),
];
}
public static function getCompletedNotificationBody(Export $export): string
{
$body = 'Your user export has completed and ' . number_format($export->successful_rows) . ' ' . str('row')->plural($export->successful_rows) . ' exported.';
if ($failedRowsCount = $export->getFailedRowsCount()) {
$body .= ' ' . number_format($failedRowsCount) . ' ' . str('row')->plural($failedRowsCount) . ' failed to export.';
}
return $body;
}
}



まだ、ダウンロードされない。
AdminPanelProvider.php (変更)
<?php
namespace App\Providers\Filament;
use App\Filament\Widgets\TestWidget;
use App\Filament\Resources\CommentResource\Widgets\LatestCommentsWidget;
use App\Filament\Resources\PostResource\Widgets\PostsPerMonthChart;
use App\Filament\Resources\UserResource\Widgets\UserStatsWidget;
use Filament\Http\Middleware\Authenticate;
use Filament\Http\Middleware\DisableBladeIconComponents;
use Filament\Http\Middleware\DispatchServingFilamentEvent;
use Filament\Pages;
use Filament\Panel;
use Filament\PanelProvider;
use Filament\Support\Colors\Color;
use Filament\Widgets;
use Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse;
use Illuminate\Cookie\Middleware\EncryptCookies;
use Illuminate\Foundation\Http\Middleware\VerifyCsrfToken;
use Illuminate\Routing\Middleware\SubstituteBindings;
use Illuminate\Session\Middleware\AuthenticateSession;
use Illuminate\Session\Middleware\StartSession;
use Illuminate\View\Middleware\ShareErrorsFromSession;
class AdminPanelProvider extends PanelProvider
{
public function panel(Panel $panel): Panel
{
return $panel
->default()
->id('admin')
->path('admin')
->login()
->colors([
'primary' => Color::Amber,
])
->databaseNotifications()
->discoverResources(in: app_path('Filament/Resources'), for: 'App\\Filament\\Resources')
->discoverPages(in: app_path('Filament/Pages'), for: 'App\\Filament\\Pages')
->pages([
\App\Filament\Pages\Dashboard::class,
])
->discoverWidgets(in: app_path('Filament/Widgets'), for: 'App\\Filament\\Widgets')
->widgets([
// UserStatsWidget::class,
// PostsPerMonthChart::class,
// LatestCommentsWidget::class
TestWidget::class,
])
->middleware([
EncryptCookies::class,
AddQueuedCookiesToResponse::class,
StartSession::class,
AuthenticateSession::class,
ShareErrorsFromSession::class,
VerifyCsrfToken::class,
SubstituteBindings::class,
DisableBladeIconComponents::class,
DispatchServingFilamentEvent::class,
])
->authMiddleware([
Authenticate::class,
]);
}
}
Database notifications が動作しない。
storageディレクトリにもエクスポートファイル出力できてない。

notificationsテーブルにも登録されてない。

-
前の記事
EC CUBE 4 サイト運営でおすすめ設定 2025.04.26
-
次の記事
Laravel12 インストール windowsに laravel new でインストール Laravel学習 #1 2025.04.29