-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathTable.php
177 lines (152 loc) · 3.7 KB
/
Table.php
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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
<?php
namespace Tactics\TableBundle;
use Symfony\Component\OptionsResolver\OptionsResolver;
class Table implements \IteratorAggregate, TableInterface
{
/**
* @var array An array of ColumnInterface instances.
*/
protected $columns = array();
/**
* @var array An array of rows.
*/
protected $rows = array();
/**
* @var string The name of the table.
*/
protected $name;
/**
* @var array The options of the table.
*/
protected $options = array();
/**
* Creates a new table with the given name and options.
*
* @param string $name The name of the table.
* @param array $options Options to configure the table.
*/
public function __construct($name, array $options = array())
{
$this->name = $name;
$resolver = new OptionsResolver();
$this->configureOptions($resolver);
$this->options = $resolver->resolve($options);
}
/**
* @inheritDoc
*/
public function add(ColumnInterface $column)
{
$this->columns[$column->getName()] = $column;
return $this;
}
/**
* @inheritDoc
*/
public function setRows($rows)
{
$this->rows = $rows;
return $this;
}
/**
* @inheritDoc
*/
public function getRows()
{
return $this->rows;
}
/**
* Sets the default options for this table.
*
* @param OptionsResolver $resolver The resolver for the options.
*/
protected function configureOptions(OptionsResolver $resolver)
{
$resolver->setDefined('attributes');
}
public function getOptions()
{
return $this->options;
}
public function getOption($name)
{
return isset($this->options[$name]) ? $this->options[$name] : null;
}
/**
* Returns a column by name (implements \ArrayAccess).
*
* @param string $name The column name
*
* @return Column The column
*/
public function offsetGet($offset)
{
return isset($this->columns[$offset]) ? $this->columns[$offset] : null;
}
/**
* Returns whether the given child exists (implements \ArrayAccess).
*
* @param string $name The child name
*
* @return Boolean Whether the child view exists
*/
public function offsetExists($name)
{
return isset($this->columns[$name]);
}
/**
* Implements \ArrayAccess.
*
* @param string $name The column name
* @param Column $column The Column
*/
public function offsetSet($name, $column)
{
if (is_null($name))
{
$this->columns[] = $column;
}
else
{
$this->columns[$name] = $column;
}
}
/**
* Removes a column (implements \ArrayAccess).
*
* @param string $name The column name
*/
public function offsetUnset($name)
{
unset($this->columns[$name]);
}
/**
* Returns an iterator to iterate over columns (implements \IteratorAggregate)
*
* @return \ArrayIterator The iterator
*/
public function getIterator()
{
return new \ArrayIterator($this->columns);
}
/**
* Implements \Countable.
*
* @return integer The number of columns
*/
public function count()
{
return count($this->columns);
}
/**
* Transform the table data.
*
* @param Tactics\TableBundle\DataTransformerInterface $transformer
*
* @return mixed
*/
public function transformData(DataTransformerInterface $transformer)
{
return $transformer->transform($this);
}
}