laravel-enso/excel is a Laravel package for excel for laravel enso.
It currently has 0 GitHub stars and 39.618 downloads on Packagist (latest version 3.2.3).
Install it with composer require laravel-enso/excel.
Discover more Laravel packages by laravel-enso
or browse all Laravel packages to compare alternatives.
Last updated
Excel provides a small contract-based .xlsx export service for Laravel and Laravel Enso.
The package delegates spreadsheet writing to OpenSpout and keeps the exporter API intentionally simple: an exporter object declares the workbook filename, the sheet names, the heading row for each sheet, and the data rows for each sheet.
It is used in Enso to generate downloadable or persisted Excel files from domain-specific exporter classes without coupling those exporters to a concrete writer implementation.
Install the package:
composer require laravel-enso/excel
The package does not require service provider registration.
To use it, create a class that implements LaravelEnso\Excel\Contracts\ExportsExcel, then pass that exporter to LaravelEnso\Excel\Services\ExcelExport.
If you want the generated file saved under a custom storage folder, also implement LaravelEnso\Excel\Contracts\SavesToDisk.
.xlsx files through OpenSpout.ExportsExcel contract for exporter classes.SavesToDisk.Define an exporter:
use LaravelEnso\Excel\Contracts\ExportsExcel;
class ContractorStock implements ExportsExcel
{
public function filename(): string
{
return 'stock_report.xlsx';
}
public function heading(string $sheet): array
{
return match ($sheet) {
'stock' => ['Product', 'Quantity'],
'history' => ['Date', 'Product', 'Quantity'],
};
}
public function rows(string $sheet): array
{
return match ($sheet) {
'stock' => [['Panel', 12]],
'history' => [['2026-04-18', 'Panel', 12]],
};
}
public function sheets(): array
{
return ['stock', 'history'];
}
}
Stream the export to the browser:
use LaravelEnso\Excel\Services\ExcelExport;
return (new ExcelExport(new ContractorStock()))->inline();
Save it to disk:
$path = (new ExcelExport(new ContractorStock()))->save();
Use a custom folder by implementing SavesToDisk:
use LaravelEnso\Excel\Contracts\ExportsExcel;
use LaravelEnso\Excel\Contracts\SavesToDisk;
class OrderExport implements ExportsExcel, SavesToDisk
{
public function folder(): string
{
return 'exports/orders';
}
}
::: warning Note
Every sheet name returned by sheets() must have a matching heading() and rows() implementation.
When the exporter does not implement SavesToDisk, files are written under the default temp storage folder.
:::
LaravelEnso\Excel\Contracts\ExportsExcelLaravelEnso\Excel\Contracts\SavesToDiskExportsExcel requires:
filename(): stringheading(string $sheet): arrayrows(string $sheet): arraysheets(): arraySavesToDisk adds:
folder(): stringLaravelEnso\Excel\Services\ExcelExport
Public methods:
__construct(ExportsExcel $exporter)inline(): BinaryFileResponsesave(): stringBehavior:
sheets()inline()LaravelEnso\Excel\Exceptions\ExcelExport
Currently exposes:
missingInterface()Framework dependency:
External dependency:
are welcome. Pull requests are great, but issues are good too.
Thank you to all the people who already contributed to Enso!