| Current Path : /var/www/clients/client3/web2/web/vendor/magento/framework/Data/Form/Element/ |
| Current File : /var/www/clients/client3/web2/web/vendor/magento/framework/Data/Form/Element/Collection.php |
<?php
/**
* Copyright © Magento, Inc. All rights reserved.
* See COPYING.txt for license details.
*/
namespace Magento\Framework\Data\Form\Element;
use Magento\Framework\Data\Form;
use Magento\Framework\Data\Form\AbstractForm;
/**
* Form element collection
*
* @author Magento Core Team <core@magentocommerce.com>
*/
class Collection implements \ArrayAccess, \IteratorAggregate, \Countable
{
/**
* Elements storage
*
* @var array
*/
private $_elements;
/**
* Elements container
*
* @var AbstractForm
*/
private $_container;
/**
* Class constructor
*
* @param AbstractForm $container
*/
public function __construct(AbstractForm $container)
{
$this->_elements = [];
$this->_container = $container;
}
/**
* Implementation of \IteratorAggregate::getIterator()
*
* @return \ArrayIterator
*/
public function getIterator()
{
return new \ArrayIterator($this->_elements);
}
/**
* Implementation of \ArrayAccess:offsetSet()
*
* @param mixed $key
* @param mixed $value
* @return void
*/
public function offsetSet($key, $value)
{
$this->_elements[$key] = $value;
}
/**
* Implementation of \ArrayAccess:offsetGet()
*
* @param mixed $key
* @return AbstractElement
*/
public function offsetGet($key)
{
return $this->_elements[$key];
}
/**
* Implementation of \ArrayAccess:offsetUnset()
*
* @param mixed $key
* @return void
*/
public function offsetUnset($key)
{
unset($this->_elements[$key]);
}
/**
* Implementation of \ArrayAccess:offsetExists()
*
* @param mixed $key
* @return boolean
*/
public function offsetExists($key)
{
return isset($this->_elements[$key]);
}
/**
* Add element to collection
*
* @todo get it straight with $after
* @param AbstractElement $element
* @param bool|string $after
* @return AbstractElement
*/
public function add(AbstractElement $element, $after = false)
{
// Set the Form for the node
if ($this->_container->getForm() instanceof Form) {
$element->setContainer($this->_container);
$element->setForm($this->_container->getForm());
}
if ($after === false) {
$this->_elements[] = $element;
} elseif ($after === '^') {
array_unshift($this->_elements, $element);
} elseif (is_string($after)) {
$newOrderElements = [];
foreach ($this->_elements as $index => $currElement) {
if ($currElement->getId() == $after) {
$newOrderElements[] = $currElement;
$newOrderElements[] = $element;
$this->_elements = array_merge($newOrderElements, array_slice($this->_elements, $index + 1));
return $element;
}
$newOrderElements[] = $currElement;
}
$this->_elements[] = $element;
}
return $element;
}
/**
* Sort elements by values using a user-defined comparison function
*
* @param mixed $callback
* @return $this
*/
public function usort($callback)
{
usort($this->_elements, $callback);
return $this;
}
/**
* Remove element from collection
*
* @param mixed $elementId
* @return $this
*/
public function remove($elementId)
{
foreach ($this->_elements as $index => $element) {
if ($elementId == $element->getId()) {
unset($this->_elements[$index]);
}
}
// Renumber elements for further correct adding and removing other elements
$this->_elements = array_merge($this->_elements, []);
return $this;
}
/**
* Count elements in collection
*
* @return int
*/
public function count()
{
return count($this->_elements);
}
/**
* Find element by ID
*
* @param mixed $elementId
* @return AbstractElement
*/
public function searchById($elementId)
{
foreach ($this->_elements as $element) {
if ($element->getId() == $elementId) {
return $element;
}
}
return null;
}
}