Pequeno projeto para gerenciar coleções usando PHP.
Não é de hoje que várias extensões e módulos do PHP tem sua implementação discutida. Com a crescente convergência entre o que as linguagens entregam alguns aspectos foram ficado cada vez mais evidentes.
As funções do PHP de manipulação de arrays estão sempre em algum lugar dessa discussão e a imutabilidade e a nomenclatura usadas estão entre os pontos mais discutidos.
Para ajudar a lidar com arrays e coleções apresentamos este pacote que pode ser usado com as estruturas a seguir:
O pack é uma abstração do array que tem métodos que trabalham com imutabilidade e outros que modificam a estrutura do array. Ele é útil para centralizar e encadear mutações no array original.
Temos pontos importantes a serem vistos quando o volume de dados gerenciados é grande. O PHP suporta cargas incríveis em arrays associativos, mas o mesmo não ocorre quando os arrays são compostos por objetos.
Usando o fetch é possível recuperar uma massa de dados de centenas de milhares de linhas usando o fetch para array associativo e "extrair" instâncias de objetos à medida que for sendo necessário.
$ composer require php-brasil/collection
require 'vendor/autoload.php';
use PhpBrasil\Collection\Pack;
$array = Pack::create([['name' => 'PHP']]);
foreach ($array as $item) {
echo 'item ~> ', $item, ';', PHP_EOL;
}
# item ~> PHP;
require 'vendor/autoload.php';
use PhpBrasil\Collection\Pack;
$pack = Pack::create([
['id' => 3, 'amount' => 60],
['id' => 2, 'amount' => 20],
['id' => 3, 'amount' => 125],
]);
$reduced = $pack->reduce(function($accumulator, $value) {
$id = prop($value, 'id');
$amount = prop($value, 'amount');
if (!isset($accumulator[$id])) {
$accumulator[$id] = [
'id' => $id,
'amount' => 0,
];
}
$accumulator[$id]['amount'] = $accumulator[$id]['amount'] + $amount;
return $accumulator;
}, []);
echo stringify($reduced);
require '/vendor/autoload.php';
use function PhpBrasil\Collection\pack;
$array = pack([['name' => 'PHP']]);
echo 'with-pluck ~> ', $array->pluck('name'), ';', PHP_EOL;
echo 'original ~> ', $array, ';', PHP_EOL;
# [
# "PHP"
# ];
# [
# [
# "name" => "PHP"
# ]
# ];
echo Pack::create(['A', '', 'C'])->filter();
# [
# 0 => "A",
# 2 => "C"
# ];
$statement = $pdo->prepare("SELECT id, name FROM users WHERE name = ?");
$statement->execute([get('name')]);
$users = Fetch::create($statement->fetchAll(PDO::FETCH_ASSOC), User::class);
$first = $users->current();
echo get_class($first);
echo $first->id;
# User
# 1