silverstripe-framework/forms/FormSchema.php

82 lines
1.8 KiB
PHP
Raw Normal View History

<?php
namespace SilverStripe\Forms\Schema;
use Form;
use FormField;
/**
* Class FormSchema
* @package SilverStripe\Forms\Schema
*
* Represents a {@link Form} as structured data which allows a frontend library to render it.
* Includes information about the form as well as its fields.
* Can create a "schema" (structure only) as well as "state" (data only).
*/
class FormSchema {
/**
* Gets the schema for this form as a nested array.
*
* @param Form $form
2016-02-29 13:50:59 +13:00
* @return array
*/
public function getSchema(Form $form) {
$request = $form->controller()->getRequest();
$schema = [
'name' => $form->getName(),
'id' => $form->FormName(),
'action' => $form->FormAction(),
'method' => $form->FormMethod(),
// @todo Not really reliable. Refactor into action on $this->Link('schema')
'schema_url' => $request->getUrl(),
'attributes' => $form->getAttributes(),
'data' => [],
'fields' => [],
'actions' => []
];
foreach ($form->Actions() as $action) {
/** @var FormField $action */
$schema['actions'][] = $action->getSchemaData();
}
foreach ($form->Fields() as $field) {
/** @var FormField $field */
$schema['fields'][] = $field->getSchemaData();
}
2016-02-29 13:50:59 +13:00
return $schema;
}
/**
* Gets the current state of this form as a nested array.
*
* @param Form $form
2016-02-29 13:50:59 +13:00
* @return array
*/
public function getState(Form $form) {
2016-02-29 13:50:59 +13:00
$state = [
'id' => $form->FormName(),
2016-02-29 13:50:59 +13:00
'fields' => [],
'messages' => []
];
// @todo - Flatten all nested fields for returning state. At the moment, only top
// level fields are returned.
foreach ($form->Fields() as $field) {
$state['fields'][] = $field->getSchemaState();
}
if($form->Message()) {
$state['messages'][] = [
'value' => $form->Message(),
'type' => $form->MessageType(),
];
}
2016-02-29 13:50:59 +13:00
return $state;
}
}