Current File : /home/digitaw/www/wp-content/plugins/event-tickets/common/src/Common/Admin/Entities/Container.php
<?php
/**
 * Container element.
 *
 * @since 6.1.0
 */

declare( strict_types=1 );

namespace TEC\Common\Admin\Entities;

use InvalidArgumentException;

/**
 * Class Container.
 *
 * This class is a generic container for elements that contain children. Using this
 * class directly will allow for rending children without any other element
 * wrapping them.
 *
 * @since 6.1.0
 */
class Container extends Base_Entity implements Element_With_Children {

	use Validate_Elements;

	/**
	 * The children of the container.
	 *
	 * @var Element[]
	 */
	protected array $children = [];

	/**
	 * The type of child elements that the container can contain.
	 *
	 * @var string
	 */
	protected string $child_type = Element::class;

	/**
	 * Add a child to the container.
	 *
	 * @since 6.1.0
	 *
	 * @param Element $child The child to add.
	 *
	 * @return static
	 * @throws InvalidArgumentException If the child is not an instance of the child type.
	 */
	public function add_child( $child ) {
		$this->validate_instanceof( $child, $this->child_type );

		$this->children[] = $child;

		return $this;
	}

	/**
	 * Add multiple children to the container.
	 *
	 * @since 6.1.0
	 *
	 * @param Element[] $children The children to add.
	 *
	 * @return static
	 */
	public function add_children( array $children ) {
		foreach ( $children as $child ) {
			$this->add_child( $child );
		}

		return $this;
	}

	/**
	 * Get the children of the container.
	 *
	 * @since 6.1.0
	 *
	 * @return Element[]
	 */
	public function get_children(): array {
		return $this->children;
	}

	/**
	 * Render the children of the container.
	 *
	 * @since 6.1.0
	 *
	 * @return void
	 */
	protected function render_children() {
		foreach ( $this->children as $child ) {
			$child->render();
		}
	}

	/**
	 * Render the element.
	 *
	 * @since 6.1.0
	 *
	 * @return void
	 */
	public function render() {
		$this->render_children();
	}
}