mirror of
https://github.com/wiosna-dev/common-library.git
synced 2026-03-12 09:31:51 +01:00
66 lines
1.6 KiB
PHP
66 lines
1.6 KiB
PHP
<?php
|
|
|
|
/**
|
|
* (c) Meritoo.pl, http://www.meritoo.pl
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
|
|
namespace Meritoo\Common\Traits\Collection;
|
|
|
|
use Meritoo\Common\Collection\BaseCollection;
|
|
|
|
/**
|
|
* Trait for the Collection with add*() methods
|
|
*
|
|
* @author Meritoo <github@meritoo.pl>
|
|
* @copyright Meritoo <http://www.meritoo.pl>
|
|
*/
|
|
trait AddTrait
|
|
{
|
|
/**
|
|
* Adds given element (at the end of collection)
|
|
*
|
|
* @param mixed $element The element to add
|
|
* @param mixed $index (optional) Index / key of the element
|
|
*/
|
|
public function add($element, $index = null): void
|
|
{
|
|
if (!$this->isValidType($element)) {
|
|
return;
|
|
}
|
|
|
|
if (null === $index) {
|
|
$this->elements[] = $element;
|
|
|
|
return;
|
|
}
|
|
|
|
$this->elements[$index] = $element;
|
|
}
|
|
|
|
/**
|
|
* Adds given elements (at the end of collection)
|
|
*
|
|
* @param array|BaseCollection $elements The elements to add
|
|
* @param bool $useIndexes (optional) If is set to true, indexes of given elements will be used in
|
|
* this collection. Otherwise - not.
|
|
*/
|
|
public function addMultiple($elements, bool $useIndexes = false): void
|
|
{
|
|
if (empty($elements)) {
|
|
return;
|
|
}
|
|
|
|
foreach ($elements as $index => $element) {
|
|
if ($useIndexes) {
|
|
$this->add($element, $index);
|
|
|
|
continue;
|
|
}
|
|
|
|
$this->add($element);
|
|
}
|
|
}
|
|
}
|