Seditio Source
Root |
./othercms/dotclear-2.22/inc/libs/clearbricks/html.form/class.form.fieldset.php
<?php

declare(strict_types=1);

/**
 * @class formFieldset
 * @brief HTML Forms fieldset creation helpers
 *
 * @package Clearbricks
 * @subpackage html.form
 *
 * @since 1.2 First time this was introduced.
 *
 * @copyright Olivier Meunier & Association Dotclear
 * @copyright GPL-2.0-only
 */
class formFieldset extends formComponent
{
    private const
DEFAULT_ELEMENT = 'fieldset';

   
/**
     * Constructs a new instance.
     *
     * @param      null|string  $id       The identifier
     * @param      null|string  $element  The element
     */
   
public function __construct(?string $id = null, ?string $element = null)
    {
       
parent::__construct(__CLASS__, $element ?? self::DEFAULT_ELEMENT);
        if (
$id !== null) {
           
$this
               
->id($id)
                ->
name($id);
        }
    }

   
/**
     * Attaches the legend to this fieldset.
     *
     * @param      formLegend|null  $legend  The legend
     */
   
public function attachLegend(?formLegend $legend)
    {
        if (
$legend) {
           
$this->legend($legend);
        } elseif (isset(
$this->legend)) {
            unset(
$this->legend);
        }
    }

   
/**
     * Detaches the legend.
     */
   
public function detachLegend()
    {
        if (isset(
$this->legend)) {
            unset(
$this->legend);
        }
    }

   
/**
     * Renders the HTML component (including the associated legend if any).
     *
     * @return     string
     */
   
public function render(): string
   
{
       
$buffer = '<' . ($this->getElement() ?? self::DEFAULT_ELEMENT) . $this->renderCommonAttributes() . '>' . "\n";

        if (isset(
$this->legend)) {
           
$buffer .= $this->legend->render();
        }

        if (isset(
$this->fields)) {
            if (
is_array($this->fields)) {
                foreach (
$this->fields as $field) {
                    if (isset(
$this->legend) && $field->getDefaultElement() === 'legend') {
                       
// Do not put more than one legend in fieldset
                       
continue;
                    }
                   
$buffer .= $field->render();
                }
            }
        }

       
$buffer .= "\n" . '</' . ($this->getElement() ?? self::DEFAULT_ELEMENT) . '>' . "\n";

        return
$buffer;
    }

   
/**
     * Gets the default element.
     *
     * @return     string  The default element.
     */
   
public function getDefaultElement(): string
   
{
        return
self::DEFAULT_ELEMENT;
    }
}