Download the PHP package spatie/laravel-fractal without Composer
On this page you can find all versions of the php package spatie/laravel-fractal. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download spatie/laravel-fractal
More information about spatie/laravel-fractal
Files in spatie/laravel-fractal
Package laravel-fractal
Short Description An easy to use Fractal integration for Laravel applications
License MIT
Homepage https://github.com/spatie/laravel-fractal
Informations about the package laravel-fractal
An easy to use Fractal wrapper built for Laravel and Lumen applications
The package provides a nice and easy wrapper around Fractal for use in your Laravel applications. If you don't know what Fractal does, take a peek at their intro. Shortly said, Fractal is very useful to transform data before using it in an API.
Using Fractal data can be transformed like this:
This package makes that process a tad easier:
Lovers of facades will be glad to know that a facade is provided:
There's also a very short syntax available to quickly transform data:
You can transform directly from a Laravel collection as well:
Transforming right from a Laravel collection is particularly useful for Eloquent results:
Spatie is a webdesign agency based in Antwerp, Belgium. You'll find an overview of all our open source projects on our website.
Support us
We invest a lot of resources into creating best in class open source packages. You can support us by buying one of our paid products.
We highly appreciate you sending us a postcard from your hometown, mentioning which of our package(s) you are using. You'll find our address on our contact page. We publish all received postcards on our virtual postcard wall.
Installation in Laravel 5.5 and up
You can pull in the package via composer:
The package will automatically register itself.
If you want to change the default serializer,
the default paginator,
or the default fractal class Spatie\Fractal\Fractal
you must publish the config file:
If you're upgrading to Laravel 5.5, the existing config file should be renamed from laravel-fractal.php to fractal.php
This is the contents of the published file:
Usage
Refer to the documentation of spatie/fractalistic
to learn all the methods this package provides.
In all code examples you may use fractal()
instead of Fractal::create()
.
Send a response with transformed data
To return a response with json data you can do this in a Laravel app.
The respond()
method on the Fractal class can make this process a bit more streamlined.
You can pass a response code as the first parameter and optionally some headers as the second
You can pass json encoding options as the third parameter:
You can also set the status code and the headers using a callback:
You can add methods to the Fractal class using Laravel's Macroable trait. Imagine you want to add some stats to the metadata of your request, you can do so without cluttering your code:
Quickly creating a transformer
You can run the make:transformer
command to quickly generate a dummy transformer. By default it will be stored in the app\Transformers
directory.
Upgrading
From v4 to v5
Rename your config file from laravel-fractal
to fractal
From v2 to v3
v3
was introduced to swap out the league/fractal
with spatie/fractalistic
. Support for Lumen was dropped. You should be able to upgrade a Laravel application from v2
to v3
without any code changes.
From v1 to v2
In most cases you can just upgrade to v2
with making none or only minor changes to your code:
resourceName
has been renamed towithResourceName
.
The main reason why v2
of this package was tagged is because v0.14 of the underlying Fractal by the League contains breaking change. If you use the League\Fractal\Serializer\JsonApiSerializer
in v2 the links
key will contain self
, first
, next
and last
.
Changelog
Please see CHANGELOG for more information what has changed recently.
Testing
Contributing
Please see CONTRIBUTING for details.
Security
If you've found a bug regarding security please mail [email protected] instead of using the issue tracker.
Credits
- Freek Van der Herten
- All contributors
License
The MIT License (MIT). Please see License File for more information.
All versions of laravel-fractal with dependencies
illuminate/contracts Version ^8.0|^9.0|^10.0|^11.0
illuminate/support Version ^8.0|^9.0|^10.0|^11.0
league/fractal Version ^0.20.1|^0.20
nesbot/carbon Version ^2.63|^3.0
spatie/fractalistic Version ^2.9.5|^2.9
spatie/laravel-package-tools Version ^1.11