Merge pull request #6894 from open-sausages/pulls/4.0/6741-decouple-schema-type-and-type

Pulls/4.0/6741 decouple schema type and type
This commit is contained in:
Chris Joe 2017-05-10 11:24:45 +12:00 committed by GitHub
commit ff35baaeab
14 changed files with 97 additions and 63 deletions

View File

@ -94,6 +94,8 @@ class DateField extends TextField
*/ */
protected $clientLocale = null; protected $clientLocale = null;
protected $inputType = 'date';
/** /**
* Min date * Min date
* *
@ -283,9 +285,10 @@ class DateField extends TextField
$attributes['lang'] = i18n::convert_rfc1766($this->getLocale()); $attributes['lang'] = i18n::convert_rfc1766($this->getLocale());
if ($this->getHTML5()) { if ($this->getHTML5()) {
$attributes['type'] = 'date';
$attributes['min'] = $this->getMinDate(); $attributes['min'] = $this->getMinDate();
$attributes['max'] = $this->getMaxDate(); $attributes['max'] = $this->getMaxDate();
} else {
$attributes['type'] = 'text';
} }
return $attributes; return $attributes;

View File

@ -30,6 +30,8 @@ class DatetimeField extends TextField
*/ */
protected $locale = null; protected $locale = null;
protected $inputType = 'datetime-local';
/** /**
* Min date time * Min date time
* *
@ -94,9 +96,10 @@ class DatetimeField extends TextField
$attributes['lang'] = i18n::convert_rfc1766($this->getLocale()); $attributes['lang'] = i18n::convert_rfc1766($this->getLocale());
if ($this->getHTML5()) { if ($this->getHTML5()) {
$attributes['type'] = 'datetime-local';
$attributes['min'] = $this->internalToFrontend($this->getMinDatetime()); $attributes['min'] = $this->internalToFrontend($this->getMinDatetime());
$attributes['max'] = $this->internalToFrontend($this->getMaxDatetime()); $attributes['max'] = $this->internalToFrontend($this->getMaxDatetime());
} else {
$attributes['type'] = 'text';
} }
return $attributes; return $attributes;

View File

@ -7,6 +7,8 @@ namespace SilverStripe\Forms;
*/ */
class EmailField extends TextField class EmailField extends TextField
{ {
protected $inputType = 'email';
/** /**
* {@inheritdoc} * {@inheritdoc}
*/ */
@ -15,19 +17,6 @@ class EmailField extends TextField
return 'email text'; return 'email text';
} }
/**
* {@inheritdoc}
*/
public function getAttributes()
{
return array_merge(
parent::getAttributes(),
array(
'type' => 'email',
)
);
}
/** /**
* Validates for RFC 2822 compliant email addresses. * Validates for RFC 2822 compliant email addresses.
* *

View File

@ -47,6 +47,8 @@ class FileField extends FormField implements FileHandleField
{ {
use UploadReceiver; use UploadReceiver;
protected $inputType = 'file';
/** /**
* Flag to automatically determine and save a has_one-relationship * Flag to automatically determine and save a has_one-relationship
* on the saved record (e.g. a "Player" has_one "PlayerImage" would * on the saved record (e.g. a "Player" has_one "PlayerImage" would
@ -83,14 +85,6 @@ class FileField extends FormField implements FileHandleField
return parent::Field($properties); return parent::Field($properties);
} }
public function getAttributes()
{
return array_merge(
parent::getAttributes(),
array('type' => 'file')
);
}
/** /**
* @param DataObject|DataObjectInterface $record * @param DataObject|DataObjectInterface $record
*/ */

View File

@ -173,20 +173,23 @@ class FormAction extends FormField
return 'action'; return 'action';
} }
public function getAttributes() public function getInputType()
{ {
if (isset($this->attributes['type'])) { if (isset($this->attributes['type'])) {
$type = $this->attributes['type']; return $this->attributes['type'];
} else { } else {
$type = (isset($this->attributes['src'])) ? 'image' : 'submit'; return (isset($this->attributes['src'])) ? 'image' : 'submit';
} }
}
public function getAttributes()
{
return array_merge( return array_merge(
parent::getAttributes(), parent::getAttributes(),
array( array(
'disabled' => ($this->isReadonly() || $this->isDisabled()), 'disabled' => ($this->isReadonly() || $this->isDisabled()),
'value' => $this->Title(), 'value' => $this->Title(),
'type' => $type, 'type' => $this->getInputType(),
'title' => ($this->useButtonTag) ? $this->description : null, 'title' => ($this->useButtonTag) ? $this->description : null,
) )
); );

View File

@ -89,6 +89,13 @@ class FormField extends RequestHandler
*/ */
protected $form; protected $form;
/**
* This is INPUT's type attribute value.
*
* @var string
*/
protected $inputType = 'text';
/** /**
* @var string * @var string
*/ */
@ -446,6 +453,16 @@ class FormField extends RequestHandler
return $this->name; return $this->name;
} }
/**
* Returns the field input name.
*
* @return string
*/
public function getInputType()
{
return $this->inputType;
}
/** /**
* Returns the field value. * Returns the field value.
* *
@ -678,7 +695,7 @@ class FormField extends RequestHandler
public function getAttributes() public function getAttributes()
{ {
$attributes = array( $attributes = array(
'type' => 'text', 'type' => $this->getInputType(),
'name' => $this->getName(), 'name' => $this->getName(),
'value' => $this->Value(), 'value' => $this->Value(),
'class' => $this->extraClass(), 'class' => $this->extraClass(),
@ -811,6 +828,20 @@ class FormField extends RequestHandler
return $this; return $this;
} }
/**
* Set the field input type.
*
* @param string $type
*
* @return $this
*/
public function setInputType($type)
{
$this->inputType = $type;
return $this;
}
/** /**
* Set the container form. * Set the container form.
* *
@ -1499,7 +1530,8 @@ class FormField extends RequestHandler
return [ return [
'name' => $this->getName(), 'name' => $this->getName(),
'id' => $this->ID(), 'id' => $this->ID(),
'type' => $this->getSchemaDataType(), 'type' => $this->getInputType(),
'schemaType' => $this->getSchemaDataType(),
'component' => $this->getSchemaComponent(), 'component' => $this->getSchemaComponent(),
'holderId' => $this->HolderID(), 'holderId' => $this->HolderID(),
'title' => $this->Title(), 'title' => $this->Title(),

View File

@ -10,6 +10,8 @@ class HiddenField extends FormField
protected $schemaDataType = FormField::SCHEMA_DATA_TYPE_HIDDEN; protected $schemaDataType = FormField::SCHEMA_DATA_TYPE_HIDDEN;
protected $inputType = 'hidden';
/** /**
* @param array $properties * @param array $properties
* @return string * @return string
@ -39,19 +41,6 @@ class HiddenField extends FormField
return true; return true;
} }
/**
* {@inheritdoc}
*/
public function getAttributes()
{
return array_merge(
parent::getAttributes(),
array(
'type' => 'hidden',
)
);
}
function SmallFieldHolder($properties = array()) function SmallFieldHolder($properties = array())
{ {
return $this->FieldHolder($properties); return $this->FieldHolder($properties);

View File

@ -15,6 +15,8 @@ class NumericField extends TextField
protected $schemaDataType = FormField::SCHEMA_DATA_TYPE_DECIMAL; protected $schemaDataType = FormField::SCHEMA_DATA_TYPE_DECIMAL;
protected $inputType = 'number';
/** /**
* Used to determine if the number given is in the correct format when validating * Used to determine if the number given is in the correct format when validating
* *
@ -170,9 +172,11 @@ class NumericField extends TextField
{ {
$attributes = parent::getAttributes(); $attributes = parent::getAttributes();
if ($this->getHTML5()) { if ($this->getHTML5()) {
$attributes['type'] = 'number';
$attributes['step'] = $this->getStep(); $attributes['step'] = $this->getStep();
} else {
$attributes['type'] = 'text';
} }
return $attributes; return $attributes;
} }

View File

@ -17,6 +17,8 @@ class PasswordField extends TextField
*/ */
private static $autocomplete; private static $autocomplete;
protected $inputType = 'password';
/** /**
* Returns an input field. * Returns an input field.
* *
@ -42,9 +44,7 @@ class PasswordField extends TextField
*/ */
public function getAttributes() public function getAttributes()
{ {
$attributes = array( $attributes = array();
'type' => 'password',
);
$autocomplete = $this->config()->get('autocomplete'); $autocomplete = $this->config()->get('autocomplete');

View File

@ -30,6 +30,8 @@ class PopoverField extends FieldGroup
*/ */
protected $popoverTitle = null; protected $popoverTitle = null;
protected $inputType = null;
/** /**
* Placement of the popup box, relative to the element triggering it. * Placement of the popup box, relative to the element triggering it.
* Valid values: bottom, top, left, right. * Valid values: bottom, top, left, right.

View File

@ -28,6 +28,8 @@ class TimeField extends TextField
*/ */
protected $locale = null; protected $locale = null;
protected $inputType = 'time';
/** /**
* Override time format. If empty will default to that used by the current locale. * Override time format. If empty will default to that used by the current locale.
* *
@ -224,8 +226,8 @@ class TimeField extends TextField
{ {
$attributes = parent::getAttributes(); $attributes = parent::getAttributes();
if ($this->getHTML5()) { if (!$this->getHTML5()) {
$attributes['type'] = 'time'; $attributes['type'] = 'text';
} }
return $attributes; return $attributes;

View File

@ -16,7 +16,8 @@
{ {
"id": "Form_TestForm_Name", "id": "Form_TestForm_Name",
"name": "Name", "name": "Name",
"type": "Text", "type": "text",
"schemaType": "Text",
"component": null, "component": null,
"holderId": "Form_TestForm_Name_Holder", "holderId": "Form_TestForm_Name_Holder",
"title": "Name", "title": "Name",
@ -35,7 +36,8 @@
{ {
"id": "Form_TestForm_SecurityID", "id": "Form_TestForm_SecurityID",
"name": "SecurityID", "name": "SecurityID",
"type": "Hidden", "type": "hidden",
"schemaType": "Hidden",
"component": null, "component": null,
"holderId": "Form_TestForm_SecurityID_Holder", "holderId": "Form_TestForm_SecurityID_Holder",
"title": "Security ID", "title": "Security ID",
@ -57,7 +59,8 @@
"id": "Form_TestForm_action_save", "id": "Form_TestForm_action_save",
"title": "Save", "title": "Save",
"name": "action_save", "name": "action_save",
"type": null, "type": "submit",
"schemaType": null,
"component": "FormAction", "component": "FormAction",
"holderId": "Form_TestForm_action_save_Holder", "holderId": "Form_TestForm_action_save_Holder",
"source": null, "source": null,
@ -80,7 +83,8 @@
"id": "Form_TestForm_action_cancel", "id": "Form_TestForm_action_cancel",
"title": "Cancel", "title": "Cancel",
"name": "action_cancel", "name": "action_cancel",
"type": null, "type": "submit",
"schemaType": null,
"component": "FormAction", "component": "FormAction",
"holderId": "Form_TestForm_action_cancel_Holder", "holderId": "Form_TestForm_action_cancel_Holder",
"source": null, "source": null,
@ -103,7 +107,8 @@
"id": "Form_TestForm_Moreoptions", "id": "Form_TestForm_Moreoptions",
"title": "More options", "title": "More options",
"name": "Moreoptions", "name": "Moreoptions",
"type": "Structural", "schemaType": "Structural",
"type": null,
"component": "PopoverField", "component": "PopoverField",
"holderId": "Form_TestForm_Moreoptions_Holder", "holderId": "Form_TestForm_Moreoptions_Holder",
"source": null, "source": null,
@ -133,7 +138,8 @@
"id": "Form_TestForm_action_publish", "id": "Form_TestForm_action_publish",
"title": "Publish record", "title": "Publish record",
"name": "action_publish", "name": "action_publish",
"type": null, "type": "submit",
"schemaType": null,
"component": "FormAction", "component": "FormAction",
"holderId": "Form_TestForm_action_publish_Holder", "holderId": "Form_TestForm_action_publish_Holder",
"source": null, "source": null,
@ -156,7 +162,8 @@
"id": "Form_TestForm_action_archive", "id": "Form_TestForm_action_archive",
"title": "Archive", "title": "Archive",
"name": "action_archive", "name": "action_archive",
"type": null, "type": "submit",
"schemaType": null,
"component": "FormAction", "component": "FormAction",
"holderId": "Form_TestForm_action_archive_Holder", "holderId": "Form_TestForm_action_archive_Holder",
"source": null, "source": null,

View File

@ -16,7 +16,8 @@
{ {
"id": "Form_TestForm_SecurityID", "id": "Form_TestForm_SecurityID",
"name": "SecurityID", "name": "SecurityID",
"type": "Hidden", "type": "hidden",
"schemaType": "Hidden",
"component": null, "component": null,
"holderId": "Form_TestForm_SecurityID_Holder", "holderId": "Form_TestForm_SecurityID_Holder",
"title": "Security ID", "title": "Security ID",
@ -34,4 +35,4 @@
} }
], ],
"actions": [] "actions": []
} }

View File

@ -16,7 +16,8 @@
{ {
"name": "Name", "name": "Name",
"id": "Form_TestForm_Name", "id": "Form_TestForm_Name",
"type": "Text", "type": "text",
"schemaType": "Text",
"component": null, "component": null,
"holderId": "Form_TestForm_Name_Holder", "holderId": "Form_TestForm_Name_Holder",
"title": "Name", "title": "Name",
@ -40,7 +41,8 @@
{ {
"name": "Date", "name": "Date",
"id": "Form_TestForm_Date", "id": "Form_TestForm_Date",
"type": "Date", "type": "date",
"schemaType": "Date",
"component": null, "component": null,
"holderId": "Form_TestForm_Date_Holder", "holderId": "Form_TestForm_Date_Holder",
"title": "Date", "title": "Date",
@ -66,7 +68,8 @@
{ {
"name": "Number", "name": "Number",
"id": "Form_TestForm_Number", "id": "Form_TestForm_Number",
"type": "Decimal", "type": "number",
"schemaType": "Decimal",
"component": null, "component": null,
"holderId": "Form_TestForm_Number_Holder", "holderId": "Form_TestForm_Number_Holder",
"title": "Number", "title": "Number",
@ -87,7 +90,8 @@
{ {
"name": "Money", "name": "Money",
"id": "Form_TestForm_Money", "id": "Form_TestForm_Money",
"type": "Text", "type": "text",
"schemaType": "Text",
"component": null, "component": null,
"holderId": "Form_TestForm_Money_Holder", "holderId": "Form_TestForm_Money_Holder",
"title": "Money", "title": "Money",
@ -108,7 +112,8 @@
{ {
"name": "SecurityID", "name": "SecurityID",
"id": "Form_TestForm_SecurityID", "id": "Form_TestForm_SecurityID",
"type": "Hidden", "type": "hidden",
"schemaType": "Hidden",
"component": null, "component": null,
"holderId": "Form_TestForm_SecurityID_Holder", "holderId": "Form_TestForm_SecurityID_Holder",
"title": "Security ID", "title": "Security ID",
@ -126,4 +131,4 @@
} }
], ],
"actions": [] "actions": []
} }