gl-website-deployer/admin/phpMyAdmin/libraries/classes/Properties/Options/OptionsPropertyGroup.php

102 lines
2.2 KiB
PHP
Raw Normal View History

2024-11-23 20:45:29 +01:00
<?php
/**
* Superclass for the Property Group classes.
*/
declare(strict_types=1);
namespace PhpMyAdmin\Properties\Options;
use Countable;
use function array_diff;
use function count;
use function in_array;
/**
* Parents group property items and provides methods to manage groups of
* properties.
*
* @todo modify descriptions if needed, when the options are integrated
*/
abstract class OptionsPropertyGroup extends OptionsPropertyItem implements Countable
{
/**
* Holds a group of properties (PhpMyAdmin\Properties\Options\OptionsPropertyItem instances)
*
* @var array
*/
private $properties;
/**
* Adds a property to the group of properties
*
* @param OptionsPropertyItem $property the property instance to be added
* to the group
*/
public function addProperty($property): void
{
if (! $this->getProperties() == null && in_array($property, $this->getProperties(), true)) {
return;
}
$this->properties[] = $property;
}
/**
* Removes a property from the group of properties
*
* @param OptionsPropertyItem $property the property instance to be removed
* from the group
*/
public function removeProperty($property): void
{
$this->properties = array_diff(
$this->getProperties(),
[$property]
);
}
/* ~~~~~~~~~~~~~~~~~~~~ Getters and Setters ~~~~~~~~~~~~~~~~~~~~ */
/**
* Gets the instance of the class
*
* @return OptionsPropertyGroup
*/
public function getGroup()
{
return $this;
}
/**
* Gets the group of properties
*
* @return array
*/
public function getProperties()
{
return $this->properties;
}
/**
* Gets the number of properties
*/
public function getNrOfProperties(): int
{
if ($this->properties === null) {
return 0;
}
return count($this->properties);
}
/**
* Countable interface implementation.
*/
public function count(): int
{
return $this->getNrOfProperties();
}
}