pinkcrab/collection

A flexible and extendable Collection

Maintainers

Package info

github.com/Pink-Crab/Collection

Homepage

pkg:composer/pinkcrab/collection

Statistics

Installs: 3 018

Dependents: 2

Suggesters: 0

Stars: 2

Open Issues: 1

1.0.0 2026-04-19 22:29 UTC

This package is auto-updated.

Last update: 2026-04-19 22:30:26 UTC


README

Latest Stable Version Total Downloads License PHP Version Require GitHub contributors GitHub issues

Tests [PHP7.1-8.5]

codecov Scrutinizer Code Quality

Version 1.0.0

This library was extracted from the PinkCrab Plugin Framework (Perique)

Why?

Give access to a basic collection with all expected functionlaity, filtering, mapping, folding, sorting and comparing. But is also extendable for creating custom collections, which can be expanded and typed. A fairly simple, but extendable Collection.

Install

Install via Composer:

composer require pinkcrab/collection

Then include the Composer autoloader in your project:

require_once __DIR__ . '/vendor/autoload.php';

Basic Useage

See ./docs for more details and examples.

$collection = new Collection(['1',2,'3']);
$collection->push(4);
$collection->apply(fn($e) => (string) $e);
var_dump($collection); // ['1','2','3','4'];
$collection = new Collection([1,2,3,4,5,6,7,8,9,10]);
$collection->filter(fn($e) => $e % 2 == 0);
var_dump($collection); // [2,4,6,8,10];

Extendable Traits

The Collection package comes with a few Traits which can be used when creating custom collections. These can either be created on the fly using anonymous classes or through defining them as full classes.

$indexed_collection = new class() extends \PinkCrab\Collection\Collection {
	use \PinkCrab\Collection\Traits\Indexed;
};

$indexed_collection->set( 'key1', 'value1' );
$indexed_collection->has( 'key1' ); //true
var_dump( $indexed_collection );


// As a full class.
class Indexed_Collection extends \PinkCrab\Collection\Collection {
	use \PinkCrab\Collection\Traits\Indexed;
};

$indexed_collection = new Indexed_Collection();
$indexed_collection->set( 'key1', 'value1' );
$indexed_collection->has( 'key1' ); //true
var_dump( $indexed_collection );

Typed & Mapped Collections

<?php

class Post_Collection extends Collection {
	// Filter out anything not matching.
	protected function map_construct( array $data ): array {
		return array_filter(fn($e): bool => is_a($data, \WP_Post::class));
	}
}

$posts = Post_Collection::from([$post1, null, $post2, false, WP_Error]);
var_dump($posts->to_array()); // [$post1, $post2];

$collection->each(function($e){
	print $e->post_title . PHP_EOL;
}); 
// Post Title 1
// Post Title 2

License

MIT License http://www.opensource.org/licenses/mit-license.html

Change Log

  • 1.0.0 - Raised supported PHP range to 7.1–8.5 and modernised the tooling chain (PHPStan 2.x + phpstan stubs so traits are actually analysed, PHPUnit up to 9.6, WPCS-based phpcs). Interface implementations (ArrayAccess, Iterator, JsonSerializable) marked with #[\ReturnTypeWillChange] for PHP 8.1+ without dropping PHP 7.x support. Sequence::sum() now filters non-numeric values to stay compatible with PHP 8.3's stricter array_sum(). Corrected phpdoc types on Has_ArrayAccess::offsetSet (nullable offset) and Is_Iterable::key (nullable return). BC break: public method parameters renamed $function/$callable$callback on apply(), each(), filter(), map(), reduce(), sort(), sorted(), group_by() — positional callers unaffected, named-argument callers need to update.
  • 0.2.0 - Added in option callbacks for diff and intersect, complete with helper functions for checking based on object instance or values/type. Also includes the group_by() method.
  • 0.1.0 - Added Has_ArrayAccess and Is_Iterable traits to allow the implementation of the interfaces. Added docs from existing GitBook repo.
  • 0.0.0 - Extracted from the PinkCrab Plugin Framework as a standalone package.