/
BootstrapForm.php
197 lines (170 loc) · 3.85 KB
/
BootstrapForm.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
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
<?php
/**
* Created by PhpStorm
* Author: czubehead (http://petrcech.eu)
* Date: 19.11.16
* Time: 14:37
*/
namespace Czubehead\BootstrapForms;
use Czubehead\BootstrapForms\Traits\AddRowTrait;
use Czubehead\BootstrapForms\Traits\BootstrapContainerTrait;
use Nette\Application\UI\Form;
use Nette\ComponentModel\IContainer;
use Nette\Forms\IFormRenderer;
use Nette\InvalidArgumentException;
use Nette\Utils\Html;
/**
* Class BootstrapForm
* Form rendered using Bootstrap 4
* @package Czubehead\BootstrapForms
* @property bool $ajax
* @property int $renderMode
* @property bool $showValidation If valid fields should explicitly be green if valid
* @property bool $autoShowValidation If true, valid inputs will be explicitly green on unsuccessful submit
*/
class BootstrapForm extends Form
{
use BootstrapContainerTrait;
use AddRowTrait;
/**
* @var string Class to be added if this is ajax. Defaults to 'ajax'
*/
public $ajaxClass = 'ajax';
/**
* @var Html
*/
protected $elementPrototype;
/**
* @var bool
*/
private $isAjax = TRUE;
/**
* @var bool
*/
private $showValidation = FALSE;
/**
* @var bool
*/
private $autoShowValidation = TRUE;
/**
* BootstrapForm constructor.
* @param int|IContainer|null $container
*/
public function __construct($container = NULL)
{
parent::__construct($container);
$this->setRenderer(new BootstrapRenderer);
$prototype = Html::el('form', [
'action' => '',
'method' => self::POST,
'class' => [],
]);
$this->elementPrototype = $prototype;
/**
* @param BootstrapForm $form
*/
$this->onError[] = function ($form) {
$form->showValidation = $this->autoShowValidation;
};
}
public function getElementPrototype()
{
return $this->elementPrototype;
}
/**
* @return \Czubehead\BootstrapForms\BootstrapRenderer|\Nette\Forms\IFormRenderer
*/
public function getRenderer()
{
return parent::getRenderer();
}
/**
* @param IFormRenderer $renderer
* @return static
*/
public function setRenderer(IFormRenderer $renderer = NULL)
{
if (!$renderer instanceof BootstrapRenderer) {
throw new InvalidArgumentException('Must be a BootstrapRenderer');
}
parent::setRenderer($renderer);
return $this;
}
/**
* @return int
*/
public function getRenderMode()
{
return $this->getRenderer()->getMode();
}
/**
* @return bool if form is ajax. True by default.
*/
public function isAjax()
{
return $this->isAjax;
}
/**
* @return bool
*/
public function isAutoShowValidation()
{
return $this->autoShowValidation;
}
/**
* @param bool $autoShowValidation
* @return BootstrapForm
*/
public function setAutoShowValidation($autoShowValidation)
{
$this->autoShowValidation = $autoShowValidation;
return $this;
}
/**
* If valid fields should explicitly be green
* @return bool
*/
public function isShowValidation()
{
return $this->showValidation;
}
/**
* If valid fields should explicitly be green
* @param bool $showValidation
* @return static
*/
public function setShowValidation($showValidation)
{
$this->showValidation = $showValidation;
return $this;
}
/**
* @param bool $isAjax
* @return static
*/
public function setAjax($isAjax = TRUE)
{
$this->isAjax = $isAjax;
BootstrapUtils::standardizeClass($this->getElementPrototype());
$prototypeClass = $this->getElementPrototype()->class;
$present = in_array($this->ajaxClass, $prototypeClass);
if ($present && !$isAjax) {
// remove the class
$prototypeClass = array_diff($prototypeClass, [$this->ajaxClass]);
} elseif (!$present && $isAjax) {
// add class
$prototypeClass[] = $this->ajaxClass;
}
$this->getElementPrototype()->class = $prototypeClass;
return $this;
}
/**
* @param int $renderMode
* @return static
*/
public function setRenderMode($renderMode)
{
$this->getRenderer()->setMode($renderMode);
return $this;
}
}