tao-test/app/tao/helpers/form/class.FormFactory.php

220 lines
7.0 KiB
PHP
Raw Permalink Normal View History

2022-08-29 20:14:13 +02:00
<?php
/**
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; under version 2
* of the License (non-upgradable).
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*
* Copyright (c) 2008-2010 (original work) Deutsche Institut für Internationale Pädagogische Forschung (under the project TAO-TRANSFER);
* 2009-2012 (update and modification) Public Research Centre Henri Tudor (under the project TAO-SUSTAIN & TAO-DEV);
*
*/
use oat\tao\helpers\form\WidgetRegistry;
/**
* The FormFactory enable you to create ready-to-use instances of the Form
* It helps you to get the commonly used instances for the default rendering
* etc.
*
* @access public
* @author Bertrand Chevrier, <bertrand.chevrier@tudor.lu>
* @package tao
*/
class tao_helpers_form_FormFactory
{
// --- ASSOCIATIONS ---
// --- ATTRIBUTES ---
/**
* The rendering mode of the form.
*
* @access protected
* @var string
*/
protected static $renderMode = 'xhtml';
// --- OPERATIONS ---
/**
* Define the rendering mode
*
* @access public
* @author Bertrand Chevrier, <bertrand.chevrier@tudor.lu>
* @param string $renderMode
*/
public static function setRenderMode($renderMode)
{
self::$renderMode = $renderMode;
}
/**
* Factors an instance of Form
*
* @access public
* @author Bertrand Chevrier, <bertrand.chevrier@tudor.lu>
* @param string $name
* @param array $options
* @return tao_helpers_form_Form
* @throws common_Exception
*/
public static function getForm($name = '', array $options = [])
{
$returnValue = null;
//use the right implementation (depending the render mode)
//@todo refactor this and use a FormElementFactory
if (self::$renderMode === 'xhtml') {
$myForm = new tao_helpers_form_xhtml_Form($name, $options);
$myForm->setDecorators([
'element' => new tao_helpers_form_xhtml_TagWrapper(['tag' => 'div']),
'group' => new tao_helpers_form_xhtml_TagWrapper(['tag' => 'div', 'cssClass' => 'form-group']),
'error' => new tao_helpers_form_xhtml_TagWrapper(['tag' => 'div', 'cssClass' => 'form-error']),
'actions-bottom' => new tao_helpers_form_xhtml_TagWrapper(['tag' => 'div', 'cssClass' => 'form-toolbar'])
]);
$myForm->setActions(self::getCommonActions());
} else {
throw new common_Exception(sprintf('render mode {%s} not yet supported', self::$renderMode));
}
$returnValue = $myForm;
return $returnValue;
}
/**
* Create dynamically a Form Element instance of the defined type
*
* @access public
* @author Bertrand Chevrier, <bertrand.chevrier@tudor.lu>
* @param string $name
* @param string $widgetId
* @return tao_helpers_form_FormElement
* @throws common_Exception
* @throws Exception
*/
public static function getElement($name = '', $widgetId = '')
{
$eltClass = null;
$definition = WidgetRegistry::getWidgetDefinitionById($widgetId);
if ($definition === null || !isset($definition['renderers'][self::$renderMode])) {
// could be a "pseudo" widget that has not been registered
$candidates = [
'tao_helpers_form_elements_xhtml_' . $widgetId,
$widgetId
];
foreach ($candidates as $candidate) {
if (class_exists($candidate)) {
$eltClass = $candidate;
break;
}
}
} else {
$eltClass = $definition['renderers'][self::$renderMode];
}
if ($eltClass !== null) {
$returnValue = new $eltClass($name);
if (!$returnValue instanceof tao_helpers_form_FormElement) {
throw new common_Exception(sprintf('%s must be a tao_helpers_form_FormElement', $eltClass));
}
} else {
$returnValue = null;
common_Logger::w(sprintf('Widget type with id %s not yet supported', $widgetId), ['FORM']);
}
return $returnValue;
}
/**
* @param $name
* @param core_kernel_classes_Resource $widget
* @return tao_helpers_form_FormElement
* @throws common_Exception
* @throws common_exception_Error
*/
public static function getElementByWidget($name, core_kernel_classes_Resource $widget)
{
$definition = WidgetRegistry::getWidgetDefinition($widget);
if ($definition === null || !isset($definition['renderers'][self::$renderMode])) {
throw new common_exception_Error(
sprintf('Widget %s not supported in render mode %s', $widget->getUri(), self::$renderMode)
);
}
$eltClass = $definition['renderers'][self::$renderMode];
$returnValue = new $eltClass($name);
if (!$returnValue instanceof tao_helpers_form_FormElement) {
throw new common_Exception("$eltClass must be a tao_helpers_form_FormElement");
}
return $returnValue;
}
/**
* Get an instance of a Validator
*
* @access public
* @author Bertrand Chevrier, <bertrand.chevrier@tudor.lu>
* @param string $name
* @param array $options
* @return tao_helpers_form_Validator
*/
public static function getValidator($name, $options = [])
{
$returnValue = null;
$class = 'tao_helpers_form_validators_' . $name;
if (class_exists($class)) {
$returnValue = new $class($options);
} else {
common_Logger::w('Unknown validator ' . $name, ['TAO', 'FORM']);
}
return $returnValue;
}
/**
* Get the common actions: save and revert
*
* @access public
* @author Bertrand Chevrier, <bertrand.chevrier@tudor.lu>
* @param string $context deprecated
* @param bool $save
* @return array
* @throws common_Exception
*/
public static function getCommonActions($context = 'bottom', $save = true)
{
if (!$save)
{
return [tao_helpers_form_FormFactory::getElement('save', 'Free')];
}
$action = tao_helpers_form_FormFactory::getElement('Save', 'Button');
$action->setIcon('icon-save');
$action->setValue(__('Save'));
$action->setType('submit');
$action->setTestId('save');
$action->addClass('form-submitter btn-success small');
return [$action];
}
}