forked from FlintLabs/FormMetadataBundle
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathFormMetadata.php
More file actions
69 lines (63 loc) · 1.41 KB
/
FormMetadata.php
File metadata and controls
69 lines (63 loc) · 1.41 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
<?php
/*
* This file is part of the Form Metadata library
*
* (c) Cameron Manderson <camm@flintinteractive.com.au>
*
* For full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace FlintLabs\Bundle\FormMetadataBundle;
use FlintLabs\Bundle\FormMetadataBundle\Configuration\Field;
/**
* The meta data containing the configuration of the form
* @author camm (camm@flintinteractive.com.au), european(info@nils-werner.com)
*/
class FormMetadata
{
/**
* @var array
*/
protected $fields = array();
/**
* @var array
*/
protected $groups = array();
/**
* Add a field configuration
* @param Mapping\Field $field
* @return void
*/
public function addField(Field $field)
{
$this->fields[] = $field;
}
/**
* @return array
*/
public function getFields()
{
return $this->fields;
}
/**
*
* @param FieldGroup $fieldGroup
* @param Field $field
*/
public function addGroup(FieldGroup $fieldGroup, Field $field)
{
if(!empty($this->groups[$fieldGroup->value])) {
$this->groups[$fieldGroup->value][] = $field;
} else {
$this->groups[$fieldGroup->value][] = $field;
}
}
/**
*
* @return array
*/
public function getGroups()
{
return $this->groups;
}
}