Laravel Illuminate collection with objectified properties
pragmarx/coollection is a Laravel package for laravel illuminate collection with objectified properties.
It currently has 94 GitHub stars and 3.462.192 downloads on Packagist (latest version v0.8.1).
Install it with composer require pragmarx/coollection.
Discover more Laravel packages by pragmarx
or browse all Laravel packages to compare alternatives.
Last updated
Coollection is Laravel's Illuminate\Collection repackaged to be used as all properties were objects:
$collection->name
$collection->addresses->first()->street_name
$collection->flatten()->cars->filter(function($car) { return $car->name == 'ferrari' })->last()->model
$countries->where('name.common', 'United States')->first()->currency->name->english;
To be agnostic and have complete idependence from Laravel's, but also to allow it to be used in Laravel applications, this package extends Tightenco\Collect, developed by Matt Stauffer from Tighten.
collect(
collect(
collect(
collect(
$collection['cars']
)->unique('constructor')['models']
)->last()['model']
)['colors']
)->first()['rgb']
or
$collection->cars->unique('constructor')->last()->model->colors->first()->rgb
collect($vimeo)->body->data->first()->metadata->connections->likes->total;
Or you prefer this one?
collect($vimeo)['body']['data'][0]['metadata']['connections']['likes']['total'];
{"pagination":{"perPage":100,"pageNumber":1}}
You collect() it:
$input = coollect($request->all());
And you can just:
$input->pagination->perPage
Instead of:
$input->get('pagination')['perPage']
You can also use "dot notation" to get your items:
$input->get('pagination.perPage')
This is an agnostic PHP package, an extraction of Illuminate\Support\Collection with all needed classes, interfaces and traits. For that if you wish just to use Illuminate's Collection, you just have to import the class Collection:
$collection = new IlluminateExtracted\Support\Collection(['my collection']);
or use the usual helper:
$collection = collect(['my collection']);
It's Laravel's Collection, at full power, so you can check its docs. The only difference is that you can access items (array keys) as properties, like any other PHP object:
$collection->map($mapper)->reduce($reducer)->random()->address->street
$this->sendThanks(
$collection->where('full_name', 'Barack Obama')->addresses->random()
);
$countries->where('name.common', 'United States')->first()->currency->symbol;
Via Composer
$ composer require pragmarx/coollection
Instantiate, the class directly or using the helper:
$c = new Coollection(['first_name' => 'Barack Obama']);
$c = coollect(['first_name' => 'Barack Obama']);
Then you use it as an object:
echo $c->first_name;
// Barack Obama
echo $c->flip()->barak_obama == 'first_name'
? 'true'
: 'false';
// true
One word keys are case insensitive:
echo $c->rio;
echo $c->RIO;
Please see CHANGELOG for more information on what has changed recently.
$ composer test
Please see CONTRIBUTING and CODE_OF_CONDUCT for details.
If you discover any security related issues, please email [email protected] instead of using the issue tracker.
The MIT License (MIT). Please see License File for more information.