2013-05-26 11:09:03 +12:00
|
|
|
<?php
|
|
|
|
|
2016-08-19 10:51:35 +12:00
|
|
|
namespace SilverStripe\Forms;
|
|
|
|
|
|
|
|
use SilverStripe\Core\Convert;
|
|
|
|
use ReflectionClass;
|
|
|
|
use SilverStripe\Core\Injector\Injectable;
|
|
|
|
|
2013-05-26 11:09:03 +12:00
|
|
|
/**
|
|
|
|
* A helper class for managing {@link Form} and {@link FormField} HTML template
|
|
|
|
* output.
|
|
|
|
*
|
|
|
|
* This primarily exists to maintain backwards compatibility between Form and
|
|
|
|
* FormField template changes since developers may rely on specific HTML output
|
|
|
|
* in their applications. Any core changes to templates (such as changing ID's)
|
|
|
|
* may have the potential to silently prevent websites from working.
|
|
|
|
*
|
|
|
|
* To provide a form with a custom FormTemplateHelper use the following snippet:
|
|
|
|
*
|
|
|
|
* <code>
|
|
|
|
* $form->setTemplateHelper('ClassName');
|
|
|
|
* </code>
|
|
|
|
*
|
|
|
|
* Globally, the FormTemplateHelper can be set via the {@link Injector} API.
|
|
|
|
*/
|
2016-11-29 12:31:16 +13:00
|
|
|
class FormTemplateHelper
|
|
|
|
{
|
|
|
|
use Injectable;
|
2013-05-26 11:09:03 +12:00
|
|
|
|
2016-11-29 12:31:16 +13:00
|
|
|
/**
|
|
|
|
* @param Form $form
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function generateFormID($form)
|
|
|
|
{
|
|
|
|
if ($id = $form->getHTMLID()) {
|
|
|
|
return Convert::raw2htmlid($id);
|
|
|
|
}
|
2013-05-26 11:09:03 +12:00
|
|
|
|
2016-11-29 12:31:16 +13:00
|
|
|
$reflection = new ReflectionClass($form);
|
2022-04-14 13:12:59 +12:00
|
|
|
$shortName = str_replace(['.', '/'], '', $form->getName() ?? '');
|
2016-11-29 12:31:16 +13:00
|
|
|
return Convert::raw2htmlid($reflection->getShortName() . '_' . $shortName);
|
|
|
|
}
|
2013-05-26 11:09:03 +12:00
|
|
|
|
2016-11-29 12:31:16 +13:00
|
|
|
/**
|
|
|
|
* @param FormField $field
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function generateFieldHolderID($field)
|
|
|
|
{
|
|
|
|
return $this->generateFieldID($field) . '_Holder';
|
|
|
|
}
|
2013-05-26 11:09:03 +12:00
|
|
|
|
2016-11-29 12:31:16 +13:00
|
|
|
/**
|
|
|
|
* Generate the field ID value
|
|
|
|
*
|
|
|
|
* @param FormField $field
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function generateFieldID($field)
|
|
|
|
{
|
2019-08-24 17:12:26 +12:00
|
|
|
// Don't include '.'s in IDs, they confused JavaScript
|
2022-04-14 13:12:59 +12:00
|
|
|
$name = str_replace('.', '_', $field->getName() ?? '');
|
2019-08-24 17:12:26 +12:00
|
|
|
|
2016-11-29 12:31:16 +13:00
|
|
|
if ($form = $field->getForm()) {
|
|
|
|
return sprintf(
|
|
|
|
"%s_%s",
|
|
|
|
$this->generateFormID($form),
|
2019-08-24 17:12:26 +12:00
|
|
|
Convert::raw2htmlid($name)
|
2016-11-29 12:31:16 +13:00
|
|
|
);
|
|
|
|
}
|
2013-05-26 11:09:03 +12:00
|
|
|
|
2019-08-24 17:12:26 +12:00
|
|
|
return Convert::raw2htmlid($name);
|
2016-11-29 12:31:16 +13:00
|
|
|
}
|
2013-05-26 11:09:03 +12:00
|
|
|
}
|