Table
Table Exports
Wire Table can export the current table query as CSV, Excel, or PDF. Exports use the current search, filters, sorting, and visible columns.
Wire Table can export the current table query as CSV, Excel, or PDF. Exports use the current search, filters, sorting, and visible columns.
Basic Export Buttons
Add buttons or menu items that call exportTable() from the Livewire component using WithTable.
<button type="button" wire:click="exportTable('csv')"> Export CSV</button> <button type="button" wire:click="exportTable('xlsx')"> Export Excel</button> <button type="button" wire:click="exportTable('pdf')"> Export PDF</button>
Supported format values:
| Value | File type |
|---|---|
csv |
CSV |
xlsx |
Excel |
pdf |
Configure Export Defaults
Use ExportAction in headerActions() when you want to define export configuration in the table definition.
use NyonCode\WireTable\Export\ExportAction;use NyonCode\WireTable\Export\ExportFormat;use NyonCode\WireTable\Export\TableExport; public function table(Table $table): Table{ return $table ->model(User::class) ->columns([ TextColumn::make('name')->label('Name')->searchable()->sortable(), TextColumn::make('email')->label('Email')->searchable(), TextColumn::make('role')->label('Role'), ]) ->headerActions([ ExportAction::makeExport() ->formats([ExportFormat::Csv, ExportFormat::Excel]) ->exportConfig( TableExport::make() ->fileName('users') ->delimiter(';') ->withHeadings() ), ]);}
The download still happens through exportTable('csv'), exportTable('xlsx'), or exportTable('pdf'). The first ExportAction on the table provides the default export settings.
Exported Columns
By default, exports include table columns that are visible to the current user. User-hidden columns are skipped.
To export a custom column set:
TableExport::make() ->columns([ TextColumn::make('name')->label('Name'), TextColumn::make('email')->label('Email'), ]);
Column labels are used as headings when headings are enabled.
Exported Query
exportTable() starts from the current filtered and sorted table query, without pagination.
To add export-only constraints:
TableExport::make() ->fileName('active-users') ->modifyQueryUsing(fn ($query) => $query->where('active', true));
To export a completely separate query, use TableExport directly:
return TableExport::make() ->fileName('inactive-users') ->query(User::query()->where('active', false)) ->columns([ TextColumn::make('name'), TextColumn::make('email'), ]) ->download();
CSV Options
TableExport::make() ->fileName('users') ->delimiter(';') ->enclosure('"') ->withHeadings();
To remove the heading row:
TableExport::make() ->withHeadings(false);
Excel Export
Excel export uses the xlsx format.
<button type="button" wire:click="exportTable('xlsx')"> Export Excel</button>
Install OpenSpout when your application needs real XLSX files:
composer require openspout/openspout
If OpenSpout is not installed, Wire falls back to CSV output.
PDF Export
PDF export uses the pdf format.
TableExport::make() ->fileName('users') ->orientation('landscape') ->paperSize('A4') ->pdfView('exports.users');
Install Laravel DomPDF when your application needs PDF files:
composer require barryvdh/laravel-dompdf
If DomPDF is not installed, Wire falls back to CSV output.
PDF View Data
When using a custom PDF view, design it as a regular Blade export template. The exporter passes headings, rows, and columns to the view.
{{-- resources/views/exports/users.blade.php --}}<table> @if (! empty($headings)) <thead> <tr> @foreach ($headings as $heading) <th>{{ $heading }}</th> @endforeach </tr> </thead> @endif <tbody> @foreach ($rows as $row) <tr> @foreach ($row as $value) <td>{{ $value }}</td> @endforeach </tr> @endforeach </tbody></table>
Related Docs
| Document | What It Covers |
|---|---|
| Table Overview | Table setup and state |
| Columns | Column labels, visibility, and formatting |
| Filters | Filtered queries used by export |
| Authorization | Restricting export actions by user |