# Conflicts:
# config/config.php
... | ... |
@@ -15,4 +15,6 @@ |
15 | 15 |
//$GLOBALS['TL_CSS']['formilicious'] = 'system/modules/eSM_formilicious/assets/css/form.min.css||static'; |
16 | 16 |
$GLOBALS['TL_HOOKS']['loadDataContainer'][] = array('\FormiliciousHooks','eSMLoadDataContainer'); |
17 | 17 |
$GLOBALS['TL_HOOKS']['loadFormField'][] = array('\FormiliciousHooks','eSMLoadFormField'); |
18 |
-$GLOBALS['TL_HOOKS']['getAttributesFromDca'][] = array('\FormiliciousHooks','eSMGetAttributesFromDca'); |
|
19 | 18 |
\ No newline at end of file |
19 |
+$GLOBALS['TL_HOOKS']['getAttributesFromDca'][] = array('\FormiliciousHooks','eSMGetAttributesFromDca'); |
|
20 |
+$GLOBALS['FE_MOD']['user']['registration'] = '\eSM_formilicious\ModuleRegistration'; |
|
21 |
+$GLOBALS['FE_MOD']['user']['personalData'] = '\eSM_formilicious\ModulePersonalData'; |
|
20 | 22 |
\ No newline at end of file |
... | ... |
@@ -30,7 +30,18 @@ namespace eSM_formilicious; |
30 | 30 |
class ModulePersonalData extends \Contao\ModulePersonalData |
31 | 31 |
{ |
32 | 32 |
|
33 |
- /** |
|
33 |
+ public function generate() |
|
34 |
+ { |
|
35 |
+ $this->loadDataContainer('tl_member'); |
|
36 |
+ $originalDca = $GLOBALS['TL_DCA']['tl_member']; |
|
37 |
+ $return = parent::generate(); |
|
38 |
+ $GLOBALS['TL_DCA']['tl_member'] = $originalDca; |
|
39 |
+ |
|
40 |
+ return $return; |
|
41 |
+ } |
|
42 |
+ |
|
43 |
+ |
|
44 |
+ /** |
|
34 | 45 |
* Generate the module |
35 | 46 |
*/ |
36 | 47 |
protected function compile() |
... | ... |
@@ -38,350 +49,31 @@ class ModulePersonalData extends \Contao\ModulePersonalData |
38 | 49 |
/** @var \PageModel $objPage */ |
39 | 50 |
global $objPage; |
40 | 51 |
|
41 |
- $this->import('FrontendUser', 'User'); |
|
42 |
- |
|
43 | 52 |
$GLOBALS['TL_LANGUAGE'] = $objPage->language; |
44 | 53 |
|
45 | 54 |
\System::loadLanguageFile('tl_member'); |
46 | 55 |
$this->loadDataContainer('tl_member'); |
47 | 56 |
|
48 |
- // Call onload_callback (e.g. to check permissions) |
|
49 |
- if (is_array($GLOBALS['TL_DCA']['tl_member']['config']['onload_callback'])) |
|
50 |
- { |
|
51 |
- foreach ($GLOBALS['TL_DCA']['tl_member']['config']['onload_callback'] as $callback) |
|
52 |
- { |
|
53 |
- if (is_array($callback)) |
|
54 |
- { |
|
55 |
- $this->import($callback[0]); |
|
56 |
- $this->{$callback[0]}->{$callback[1]}(); |
|
57 |
- } |
|
58 |
- elseif (is_callable($callback)) |
|
59 |
- { |
|
60 |
- $callback(); |
|
61 |
- } |
|
62 |
- } |
|
63 |
- } |
|
64 |
- |
|
65 |
- // Set the template |
|
66 |
- if ($this->memberTpl != '') |
|
67 |
- { |
|
68 |
- /** @var \FrontendTemplate|object $objTemplate */ |
|
69 |
- $objTemplate = new \FrontendTemplate($this->memberTpl); |
|
70 |
- |
|
71 |
- $this->Template = $objTemplate; |
|
72 |
- $this->Template->setData($this->arrData); |
|
73 |
- } |
|
74 |
- |
|
75 |
- $this->Template->fields = ''; |
|
76 |
- $this->Template->tableless = $this->tableless; |
|
77 |
- |
|
78 |
- $arrFields = array(); |
|
79 |
- $doNotSubmit = false; |
|
80 |
- $hasUpload = false; |
|
81 |
- $row = 0; |
|
82 | 57 |
|
83 |
- // Predefine the group order (other groups will be appended automatically) |
|
84 |
- $arrGroups = array |
|
85 |
- ( |
|
86 |
- 'personal' => array(), |
|
87 |
- 'address' => array(), |
|
88 |
- 'contact' => array(), |
|
89 |
- 'login' => array(), |
|
90 |
- 'profile' => array() |
|
91 |
- ); |
|
92 |
- |
|
93 |
- $blnModified = false; |
|
94 |
- $objMember = \MemberModel::findByPk($this->User->id); |
|
95 |
- $strTable = $objMember->getTable(); |
|
96 |
- |
|
97 |
- // Initialize the versioning (see #7415) |
|
98 |
- $objVersions = new \Versions($strTable, $objMember->id); |
|
99 |
- $objVersions->setUsername($objMember->username); |
|
100 |
- $objVersions->setUserId(0); |
|
101 |
- $objVersions->setEditUrl('contao/main.php?do=member&act=edit&id=%s&rt=1'); |
|
102 |
- $objVersions->initialize(); |
|
103 |
- |
|
104 |
- // Build the form |
|
105 |
- foreach ($this->editable as $fielddata) |
|
58 |
+ $arrEditable = []; |
|
59 |
+ foreach ($this->editable as $key=>$fielddata) |
|
106 | 60 |
{ |
107 | 61 |
// Split formilicious editable data in single vars |
108 |
- list($field,$fieldWidth,$fieldClr,$fieldMandatory) = array_values($fielddata); |
|
109 |
- |
|
110 |
- $arrData = &$GLOBALS['TL_DCA']['tl_member']['fields'][$field]; |
|
111 |
- |
|
112 |
- // Map checkboxWizards to regular checkbox widgets |
|
113 |
- if ($arrData['inputType'] == 'checkboxWizard') |
|
114 |
- { |
|
115 |
- $arrData['inputType'] = 'checkbox'; |
|
116 |
- } |
|
117 |
- |
|
118 |
- // Map fileTrees to upload widgets (see #8091) |
|
119 |
- if ($arrData['inputType'] == 'fileTree') |
|
120 |
- { |
|
121 |
- $arrData['inputType'] = 'upload'; |
|
122 |
- } |
|
123 |
- |
|
124 |
- /** @var \Widget $strClass */ |
|
125 |
- $strClass = $GLOBALS['TL_FFL'][$arrData['inputType']]; |
|
126 |
- |
|
127 |
- // Continue if the class does not exist |
|
128 |
- if (!$arrData['eval']['feEditable'] || !class_exists($strClass)) |
|
129 |
- { |
|
130 |
- continue; |
|
131 |
- } |
|
132 |
- |
|
133 |
- $strGroup = $arrData['eval']['feGroup']; |
|
134 |
- |
|
135 |
- $arrData['eval']['required'] = false; |
|
136 |
- $arrData['eval']['tableless'] = $this->tableless; |
|
137 |
- |
|
138 |
- // Use strlen() here (see #3277) |
|
139 |
- if ($arrData['eval']['mandatory']) |
|
140 |
- { |
|
141 |
- if (is_array($this->User->$field)) |
|
142 |
- { |
|
143 |
- if (empty($this->User->$field)) |
|
144 |
- { |
|
145 |
- $arrData['eval']['required'] = true; |
|
146 |
- } |
|
147 |
- } |
|
148 |
- else |
|
149 |
- { |
|
150 |
- if (!strlen($this->User->$field)) |
|
151 |
- { |
|
152 |
- $arrData['eval']['required'] = true; |
|
153 |
- } |
|
154 |
- } |
|
155 |
- } |
|
156 |
- |
|
157 |
- $varValue = $this->User->$field; |
|
158 |
- |
|
159 |
- // Call the load_callback |
|
160 |
- if (isset($arrData['load_callback']) && is_array($arrData['load_callback'])) |
|
161 |
- { |
|
162 |
- foreach ($arrData['load_callback'] as $callback) |
|
163 |
- { |
|
164 |
- if (is_array($callback)) |
|
165 |
- { |
|
166 |
- $this->import($callback[0]); |
|
167 |
- $varValue = $this->{$callback[0]}->{$callback[1]}($varValue, $this->User, $this); |
|
168 |
- } |
|
169 |
- elseif (is_callable($callback)) |
|
170 |
- { |
|
171 |
- $varValue = $callback($varValue, $this->User, $this); |
|
172 |
- } |
|
173 |
- } |
|
174 |
- } |
|
175 |
- |
|
176 |
- /** @var \Widget $objWidget */ |
|
177 |
- $objWidget = new $strClass($strClass::getAttributesFromDca($arrData, $field, $varValue, $field, $strTable, $this)); |
|
178 |
- |
|
179 |
- $objWidget->storeValues = true; |
|
180 |
- $objWidget->rowClass = 'row_' . $row . (($row == 0) ? ' row_first' : '') . ((($row % 2) == 0) ? ' even' : ' odd'); |
|
181 |
- |
|
182 |
- // Extend with formilicious data |
|
183 |
- $objWidget->eSM_fl_width = $fieldWidth; |
|
184 |
- $objWidget->eSM_fl_clear = $fieldClr; |
|
62 |
+ list($field, $fieldWidth, $fieldClr, $fieldMandatory) = array_values($fielddata); |
|
63 |
+ $GLOBALS['TL_DCA']['tl_member']['fields'][$field]['eval']['eSM_fl_width'] = $fieldWidth; |
|
64 |
+ $GLOBALS['TL_DCA']['tl_member']['fields'][$field]['eval']['eSM_fl_clear'] = $fieldClr; |
|
185 | 65 |
if ($fieldMandatory) |
186 | 66 |
{ |
187 |
- $objWidget->required = $fieldMandatory; |
|
188 |
- $objWidget->mandatory = $fieldMandatory; |
|
67 |
+ $GLOBALS['TL_DCA']['tl_member']['fields'][$field]['eval']['mandatory'] = $fieldMandatory; |
|
189 | 68 |
} else { |
190 |
- $objWidget->required = false; |
|
191 |
- $objWidget->mandatory = false; |
|
192 |
- } |
|
193 |
- if (in_array($arrData['eval']['rgxp'], array('date','time','datim'))) |
|
194 |
- { |
|
195 |
- $strDateFormatFunc = 'getNumeric'.ucfirst($arrData['eval']['rgxp']).'Format'; |
|
196 |
- $objWidget->placeholder = \Date::getInputFormat(\Date::$strDateFormatFunc()); |
|
197 |
- $objWidget->maxlength = strlen($objWidget->placeholder); |
|
198 |
- } |
|
199 |
- |
|
200 |
- // Increase the row count if it is a password field |
|
201 |
- if ($objWidget instanceof \FormPassword) |
|
202 |
- { |
|
203 |
- if ($objMember->password != '') |
|
204 |
- { |
|
205 |
- $objWidget->mandatory = false; |
|
206 |
- } |
|
207 |
- |
|
208 |
- $objWidget->rowClassConfirm = 'row_' . ++$row . ((($row % 2) == 0) ? ' even' : ' odd'); |
|
209 |
- } |
|
210 |
- |
|
211 |
- // Validate the form data |
|
212 |
- if (\Input::post('FORM_SUBMIT') == 'tl_member_' . $this->id) |
|
213 |
- { |
|
214 |
- $objWidget->validate(); |
|
215 |
- $varValue = $objWidget->value; |
|
216 |
- |
|
217 |
- $rgxp = $arrData['eval']['rgxp']; |
|
218 |
- |
|
219 |
- // Convert date formats into timestamps (check the eval setting first -> #3063) |
|
220 |
- if ($varValue != '' && in_array($rgxp, array('date', 'time', 'datim'))) |
|
221 |
- { |
|
222 |
- try |
|
223 |
- { |
|
224 |
- $objDate = new \Date($varValue, \Date::getFormatFromRgxp($rgxp)); |
|
225 |
- $varValue = $objDate->tstamp; |
|
226 |
- } |
|
227 |
- catch (\OutOfBoundsException $e) |
|
228 |
- { |
|
229 |
- $objWidget->addError(sprintf($GLOBALS['TL_LANG']['ERR']['invalidDate'], $varValue)); |
|
230 |
- } |
|
231 |
- } |
|
232 |
- |
|
233 |
- // Make sure that unique fields are unique (check the eval setting first -> #3063) |
|
234 |
- if ($arrData['eval']['unique'] && $varValue != '' && !$this->Database->isUniqueValue('tl_member', $field, $varValue, $this->User->id)) |
|
235 |
- { |
|
236 |
- $objWidget->addError(sprintf($GLOBALS['TL_LANG']['ERR']['unique'], $arrData['label'][0] ?: $field)); |
|
237 |
- } |
|
238 |
- |
|
239 |
- // Trigger the save_callback (see #5247) |
|
240 |
- if ($objWidget->submitInput() && !$objWidget->hasErrors() && is_array($arrData['save_callback'])) |
|
241 |
- { |
|
242 |
- foreach ($arrData['save_callback'] as $callback) |
|
243 |
- { |
|
244 |
- try |
|
245 |
- { |
|
246 |
- if (is_array($callback)) |
|
247 |
- { |
|
248 |
- $this->import($callback[0]); |
|
249 |
- $varValue = $this->{$callback[0]}->{$callback[1]}($varValue, $this->User, $this); |
|
250 |
- } |
|
251 |
- elseif (is_callable($callback)) |
|
252 |
- { |
|
253 |
- $varValue = $callback($varValue, $this->User, $this); |
|
254 |
- } |
|
255 |
- } |
|
256 |
- catch (\Exception $e) |
|
257 |
- { |
|
258 |
- $objWidget->class = 'error'; |
|
259 |
- $objWidget->addError($e->getMessage()); |
|
260 |
- } |
|
261 |
- } |
|
262 |
- } |
|
263 |
- |
|
264 |
- // Do not submit the field if there are errors |
|
265 |
- if ($objWidget->hasErrors()) |
|
266 |
- { |
|
267 |
- $doNotSubmit = true; |
|
268 |
- } |
|
269 |
- elseif ($objWidget->submitInput()) |
|
270 |
- { |
|
271 |
- // Store the form data |
|
272 |
- $_SESSION['FORM_DATA'][$field] = $varValue; |
|
273 |
- |
|
274 |
- // Set the correct empty value (see #6284, #6373) |
|
275 |
- if ($varValue === '') |
|
276 |
- { |
|
277 |
- $varValue = $objWidget->getEmptyValue(); |
|
278 |
- } |
|
279 |
- |
|
280 |
- // Encrypt the value (see #7815) |
|
281 |
- if ($arrData['eval']['encrypt']) |
|
282 |
- { |
|
283 |
- $varValue = \Encryption::encrypt($varValue); |
|
284 |
- } |
|
285 |
- |
|
286 |
- // Set the new value |
|
287 |
- if ($varValue !== $this->User->$field) |
|
288 |
- { |
|
289 |
- $this->User->$field = $varValue; |
|
290 |
- |
|
291 |
- // Set the new field in the member model |
|
292 |
- $blnModified = true; |
|
293 |
- $objMember->$field = $varValue; |
|
294 |
- } |
|
295 |
- } |
|
296 |
- } |
|
297 |
- |
|
298 |
- if ($objWidget instanceof \uploadable) |
|
299 |
- { |
|
300 |
- $hasUpload = true; |
|
301 |
- } |
|
302 |
- |
|
303 |
- $temp = $objWidget->parse(); |
|
69 |
+ $GLOBALS['TL_DCA']['tl_member']['fields'][$field]['eval']['mandatory'] = false; |
|
304 | 70 |
|
305 |
- $this->Template->fields .= $temp; |
|
306 |
- $arrFields[$strGroup][$field] .= $temp; |
|
307 |
- ++$row; |
|
308 |
- } |
|
309 |
- |
|
310 |
- // Save the model |
|
311 |
- if ($blnModified) |
|
312 |
- { |
|
313 |
- $objMember->tstamp = time(); |
|
314 |
- $objMember->save(); |
|
315 |
- |
|
316 |
- // Create a new version |
|
317 |
- if ($GLOBALS['TL_DCA'][$strTable]['config']['enableVersioning']) |
|
318 |
- { |
|
319 |
- $objVersions->create(); |
|
320 |
- } |
|
321 |
- } |
|
322 |
- |
|
323 |
- $this->Template->hasError = $doNotSubmit; |
|
324 |
- |
|
325 |
- // Redirect or reload if there was no error |
|
326 |
- if (\Input::post('FORM_SUBMIT') == 'tl_member_' . $this->id && !$doNotSubmit) |
|
327 |
- { |
|
328 |
- // HOOK: updated personal data |
|
329 |
- if (isset($GLOBALS['TL_HOOKS']['updatePersonalData']) && is_array($GLOBALS['TL_HOOKS']['updatePersonalData'])) |
|
330 |
- { |
|
331 |
- foreach ($GLOBALS['TL_HOOKS']['updatePersonalData'] as $callback) |
|
332 |
- { |
|
333 |
- $this->import($callback[0]); |
|
334 |
- $this->{$callback[0]}->{$callback[1]}($this->User, $_SESSION['FORM_DATA'], $this); |
|
335 |
- } |
|
336 | 71 |
} |
337 |
- |
|
338 |
- // Call the onsubmit_callback |
|
339 |
- if (is_array($GLOBALS['TL_DCA']['tl_member']['config']['onsubmit_callback'])) |
|
340 |
- { |
|
341 |
- foreach ($GLOBALS['TL_DCA']['tl_member']['config']['onsubmit_callback'] as $callback) |
|
342 |
- { |
|
343 |
- if (is_array($callback)) |
|
344 |
- { |
|
345 |
- $this->import($callback[0]); |
|
346 |
- $this->{$callback[0]}->{$callback[1]}($this->User, $this); |
|
347 |
- } |
|
348 |
- elseif (is_callable($callback)) |
|
349 |
- { |
|
350 |
- $callback($this->User, $this); |
|
351 |
- } |
|
352 |
- } |
|
353 |
- } |
|
354 |
- |
|
355 |
- // Check whether there is a jumpTo page |
|
356 |
- if (($objJumpTo = $this->objModel->getRelated('jumpTo')) !== null) |
|
357 |
- { |
|
358 |
- $this->jumpToOrReload($objJumpTo->row()); |
|
359 |
- } |
|
360 |
- |
|
361 |
- \Message::addConfirmation($GLOBALS['TL_LANG']['MSC']['savedData']); |
|
362 |
- $this->reload(); |
|
72 |
+ $arrEditable[$key] = $field; |
|
363 | 73 |
} |
74 |
+ $this->editable = $arrEditable; |
|
364 | 75 |
|
365 |
- $this->Template->loginDetails = $GLOBALS['TL_LANG']['tl_member']['loginDetails']; |
|
366 |
- $this->Template->addressDetails = $GLOBALS['TL_LANG']['tl_member']['addressDetails']; |
|
367 |
- $this->Template->contactDetails = $GLOBALS['TL_LANG']['tl_member']['contactDetails']; |
|
368 |
- $this->Template->personalData = $GLOBALS['TL_LANG']['tl_member']['personalData']; |
|
369 |
- |
|
370 |
- // Add the groups |
|
371 |
- foreach ($arrFields as $k=>$v) |
|
372 |
- { |
|
373 |
- $this->Template->$k = $v; // backwards compatibility |
|
374 |
- |
|
375 |
- $key = $k . (($k == 'personal') ? 'Data' : 'Details'); |
|
376 |
- $arrGroups[$GLOBALS['TL_LANG']['tl_member'][$key]] = $v; |
|
377 |
- } |
|
76 |
+ parent::compile(); |
|
378 | 77 |
|
379 |
- $this->Template->categories = $arrGroups; |
|
380 |
- $this->Template->formId = 'tl_member_' . $this->id; |
|
381 |
- $this->Template->slabel = specialchars($GLOBALS['TL_LANG']['MSC']['saveData']); |
|
382 |
- $this->Template->action = \Environment::get('indexFreeRequest'); |
|
383 |
- $this->Template->enctype = $hasUpload ? 'multipart/form-data' : 'application/x-www-form-urlencoded'; |
|
384 |
- $this->Template->rowLast = 'row_' . $row . ((($row % 2) == 0) ? ' even' : ' odd'); |
|
385 |
- $this->Template->message = \Message::generate(false, true); |
|
386 | 78 |
} |
387 | 79 |
} |
... | ... |
@@ -29,6 +29,16 @@ namespace eSM_formilicious; |
29 | 29 |
*/ |
30 | 30 |
class ModuleRegistration extends \Contao\ModuleRegistration |
31 | 31 |
{ |
32 |
+ public function generate() |
|
33 |
+ { |
|
34 |
+ $this->loadDataContainer('tl_member'); |
|
35 |
+ $originalDca = $GLOBALS['TL_DCA']['tl_member']; |
|
36 |
+ $return = parent::generate(); |
|
37 |
+ $GLOBALS['TL_DCA']['tl_member'] = $originalDca; |
|
38 |
+ |
|
39 |
+ return $return; |
|
40 |
+ } |
|
41 |
+ |
|
32 | 42 |
|
33 | 43 |
/** |
34 | 44 |
* Generate the module |
... | ... |
@@ -43,292 +53,26 @@ class ModuleRegistration extends \Contao\ModuleRegistration |
43 | 53 |
\System::loadLanguageFile('tl_member'); |
44 | 54 |
$this->loadDataContainer('tl_member'); |
45 | 55 |
|
46 |
- // Call onload_callback (e.g. to check permissions) |
|
47 |
- if (is_array($GLOBALS['TL_DCA']['tl_member']['config']['onload_callback'])) |
|
48 |
- { |
|
49 |
- foreach ($GLOBALS['TL_DCA']['tl_member']['config']['onload_callback'] as $callback) |
|
50 |
- { |
|
51 |
- if (is_array($callback)) |
|
52 |
- { |
|
53 |
- $this->import($callback[0]); |
|
54 |
- $this->{$callback[0]}->{$callback[1]}(); |
|
55 |
- } |
|
56 |
- elseif (is_callable($callback)) |
|
57 |
- { |
|
58 |
- $callback(); |
|
59 |
- } |
|
60 |
- } |
|
61 |
- } |
|
62 |
- |
|
63 |
- // Activate account |
|
64 |
- if (\Input::get('token') != '') |
|
65 |
- { |
|
66 |
- $this->activateAcount(); |
|
67 |
- |
|
68 |
- return; |
|
69 |
- } |
|
70 |
- |
|
71 |
- if ($this->memberTpl != '') |
|
72 |
- { |
|
73 |
- /** @var \FrontendTemplate|object $objTemplate */ |
|
74 |
- $objTemplate = new \FrontendTemplate($this->memberTpl); |
|
75 |
- |
|
76 |
- $this->Template = $objTemplate; |
|
77 |
- $this->Template->setData($this->arrData); |
|
78 |
- } |
|
79 |
- |
|
80 |
- $this->Template->fields = ''; |
|
81 |
- $this->Template->tableless = $this->tableless; |
|
82 |
- $objCaptcha = null; |
|
83 |
- $doNotSubmit = false; |
|
84 |
- |
|
85 |
- // Predefine the group order (other groups will be appended automatically) |
|
86 |
- $arrGroups = array |
|
87 |
- ( |
|
88 |
- 'personal' => array(), |
|
89 |
- 'address' => array(), |
|
90 |
- 'contact' => array(), |
|
91 |
- 'login' => array(), |
|
92 |
- 'profile' => array() |
|
93 |
- ); |
|
94 |
- |
|
95 |
- // Captcha |
|
96 |
- if (!$this->disableCaptcha) |
|
97 |
- { |
|
98 |
- $arrCaptcha = array |
|
99 |
- ( |
|
100 |
- 'id' => 'registration', |
|
101 |
- 'label' => $GLOBALS['TL_LANG']['MSC']['securityQuestion'], |
|
102 |
- 'type' => 'captcha', |
|
103 |
- 'mandatory' => true, |
|
104 |
- 'required' => true, |
|
105 |
- 'tableless' => $this->tableless |
|
106 |
- ); |
|
107 |
- |
|
108 |
- /** @var \FormCaptcha $strClass */ |
|
109 |
- $strClass = $GLOBALS['TL_FFL']['captcha']; |
|
110 |
- |
|
111 |
- // Fallback to default if the class is not defined |
|
112 |
- if (!class_exists($strClass)) |
|
113 |
- { |
|
114 |
- $strClass = 'FormCaptcha'; |
|
115 |
- } |
|
116 |
- |
|
117 |
- /** @var \FormCaptcha $objCaptcha */ |
|
118 |
- $objCaptcha = new $strClass($arrCaptcha); |
|
119 |
- |
|
120 |
- if (\Input::post('FORM_SUBMIT') == 'tl_registration') |
|
121 |
- { |
|
122 |
- $objCaptcha->validate(); |
|
123 |
- |
|
124 |
- if ($objCaptcha->hasErrors()) |
|
125 |
- { |
|
126 |
- $doNotSubmit = true; |
|
127 |
- } |
|
128 |
- } |
|
129 |
- } |
|
130 |
- |
|
131 |
- $arrUser = array(); |
|
132 |
- $arrFields = array(); |
|
133 |
- $hasUpload = false; |
|
134 |
- $i = 0; |
|
135 | 56 |
|
136 |
- // Build form |
|
137 |
- foreach ($this->editable as $fielddata) |
|
57 |
+ $arrEditable = []; |
|
58 |
+ foreach ($this->editable as $key=>$fielddata) |
|
138 | 59 |
{ |
139 | 60 |
// Split formilicious editable data in single vars |
140 |
- list($field,$fieldWidth,$fieldClr,$fieldMandatory) = array_values($fielddata); |
|
141 |
- |
|
142 |
- $arrData = $GLOBALS['TL_DCA']['tl_member']['fields'][$field]; |
|
143 |
- |
|
144 |
- // Map checkboxWizards to regular checkbox widgets |
|
145 |
- if ($arrData['inputType'] == 'checkboxWizard') |
|
146 |
- { |
|
147 |
- $arrData['inputType'] = 'checkbox'; |
|
148 |
- } |
|
149 |
- |
|
150 |
- // Map fileTrees to upload widgets (see #8091) |
|
151 |
- if ($arrData['inputType'] == 'fileTree') |
|
152 |
- { |
|
153 |
- $arrData['inputType'] = 'upload'; |
|
154 |
- } |
|
155 |
- |
|
156 |
- /** @var \Widget $strClass */ |
|
157 |
- $strClass = $GLOBALS['TL_FFL'][$arrData['inputType']]; |
|
158 |
- |
|
159 |
- // Continue if the class is not defined |
|
160 |
- if (!class_exists($strClass)) |
|
161 |
- { |
|
162 |
- continue; |
|
163 |
- } |
|
164 |
- |
|
165 |
- $arrData['eval']['tableless'] = $this->tableless; |
|
166 |
- $arrData['eval']['required'] = $arrData['eval']['mandatory']; |
|
167 |
- |
|
168 |
- $objWidget = new $strClass($strClass::getAttributesFromDca($arrData, $field, $arrData['default'], '', '', $this)); |
|
169 |
- |
|
170 |
- $objWidget->storeValues = true; |
|
171 |
- $objWidget->rowClass = 'row_' . $i . (($i == 0) ? ' row_first' : '') . ((($i % 2) == 0) ? ' even' : ' odd'); |
|
172 |
- |
|
173 |
- // Extend with formilicious data |
|
174 |
- $objWidget->eSM_fl_width = $fieldWidth; |
|
175 |
- $objWidget->eSM_fl_clear = $fieldClr; |
|
61 |
+ list($field, $fieldWidth, $fieldClr, $fieldMandatory) = array_values($fielddata); |
|
62 |
+ $GLOBALS['TL_DCA']['tl_member']['fields'][$field]['eval']['eSM_fl_width'] = $fieldWidth; |
|
63 |
+ $GLOBALS['TL_DCA']['tl_member']['fields'][$field]['eval']['eSM_fl_clear'] = $fieldClr; |
|
176 | 64 |
if ($fieldMandatory) |
177 | 65 |
{ |
178 |
- $objWidget->required = $fieldMandatory; |
|
179 |
- $objWidget->mandatory = $fieldMandatory; |
|
66 |
+ $GLOBALS['TL_DCA']['tl_member']['fields'][$field]['eval']['mandatory'] = $fieldMandatory; |
|
180 | 67 |
} else { |
181 |
- $objWidget->required = false; |
|
182 |
- $objWidget->mandatory = false; |
|
183 |
- } |
|
184 |
- if (in_array($arrData['eval']['rgxp'], array('date','time','datim'))) |
|
185 |
- { |
|
186 |
- $strDateFormatFunc = 'getNumeric'.ucfirst($arrData['eval']['rgxp']).'Format'; |
|
187 |
- $objWidget->placeholder = \Date::getInputFormat(\Date::$strDateFormatFunc()); |
|
188 |
- $objWidget->maxlength = strlen($objWidget->placeholder); |
|
189 |
- } |
|
190 |
- |
|
191 |
- // Increase the row count if its a password field |
|
192 |
- if ($objWidget instanceof \FormPassword) |
|
193 |
- { |
|
194 |
- $objWidget->rowClassConfirm = 'row_' . ++$i . ((($i % 2) == 0) ? ' even' : ' odd'); |
|
195 |
- } |
|
196 |
- |
|
197 |
- // Validate input |
|
198 |
- if (\Input::post('FORM_SUBMIT') == 'tl_registration') |
|
199 |
- { |
|
200 |
- $objWidget->validate(); |
|
201 |
- $varValue = $objWidget->value; |
|
202 |
- |
|
203 |
- // Check whether the password matches the username |
|
204 |
- if ($objWidget instanceof \FormPassword && \Encryption::verify(\Input::post('username'), $varValue)) |
|
205 |
- { |
|
206 |
- $objWidget->addError($GLOBALS['TL_LANG']['ERR']['passwordName']); |
|
207 |
- } |
|
208 |
- |
|
209 |
- $rgxp = $arrData['eval']['rgxp']; |
|
210 |
- |
|
211 |
- // Convert date formats into timestamps (check the eval setting first -> #3063) |
|
212 |
- if ($varValue != '' && in_array($rgxp, array('date', 'time', 'datim'))) |
|
213 |
- { |
|
214 |
- try |
|
215 |
- { |
|
216 |
- $objDate = new \Date($varValue, \Date::getFormatFromRgxp($rgxp)); |
|
217 |
- $varValue = $objDate->tstamp; |
|
218 |
- } |
|
219 |
- catch (\OutOfBoundsException $e) |
|
220 |
- { |
|
221 |
- $objWidget->addError(sprintf($GLOBALS['TL_LANG']['ERR']['invalidDate'], $varValue)); |
|
222 |
- } |
|
223 |
- } |
|
224 |
- |
|
225 |
- // Make sure that unique fields are unique (check the eval setting first -> #3063) |
|
226 |
- if ($arrData['eval']['unique'] && $varValue != '' && !$this->Database->isUniqueValue('tl_member', $field, $varValue)) |
|
227 |
- { |
|
228 |
- $objWidget->addError(sprintf($GLOBALS['TL_LANG']['ERR']['unique'], $arrData['label'][0] ?: $field)); |
|
229 |
- } |
|
230 |
- |
|
231 |
- // Save callback |
|
232 |
- if ($objWidget->submitInput() && !$objWidget->hasErrors() && is_array($arrData['save_callback'])) |
|
233 |
- { |
|
234 |
- foreach ($arrData['save_callback'] as $callback) |
|
235 |
- { |
|
236 |
- try |
|
237 |
- { |
|
238 |
- if (is_array($callback)) |
|
239 |
- { |
|
240 |
- $this->import($callback[0]); |
|
241 |
- $varValue = $this->{$callback[0]}->{$callback[1]}($varValue, null); |
|
242 |
- } |
|
243 |
- elseif (is_callable($callback)) |
|
244 |
- { |
|
245 |
- $varValue = $callback($varValue, null); |
|
246 |
- } |
|
247 |
- } |
|
248 |
- catch (\Exception $e) |
|
249 |
- { |
|
250 |
- $objWidget->class = 'error'; |
|
251 |
- $objWidget->addError($e->getMessage()); |
|
252 |
- } |
|
253 |
- } |
|
254 |
- } |
|
68 |
+ $GLOBALS['TL_DCA']['tl_member']['fields'][$field]['eval']['mandatory'] = false; |
|
255 | 69 |
|
256 |
- // Store the current value |
|
257 |
- if ($objWidget->hasErrors()) |
|
258 |
- { |
|
259 |
- $doNotSubmit = true; |
|
260 |
- } |
|
261 |
- elseif ($objWidget->submitInput()) |
|
262 |
- { |
|
263 |
- // Set the correct empty value (see #6284, #6373) |
|
264 |
- if ($varValue === '') |
|
265 |
- { |
|
266 |
- $varValue = $objWidget->getEmptyValue(); |
|
267 |
- } |
|
268 |
- |
|
269 |
- // Encrypt the value (see #7815) |
|
270 |
- if ($arrData['eval']['encrypt']) |
|
271 |
- { |
|
272 |
- $varValue = \Encryption::encrypt($varValue); |
|
273 |
- } |
|
274 |
- |
|
275 |
- // Set the new value |
|
276 |
- $arrUser[$field] = $varValue; |
|
277 |
- } |
|
278 |
- } |
|
279 |
- |
|
280 |
- if ($objWidget instanceof \uploadable) |
|
281 |
- { |
|
282 |
- $hasUpload = true; |
|
283 | 70 |
} |
284 |
- |
|
285 |
- $temp = $objWidget->parse(); |
|
286 |
- |
|
287 |
- $this->Template->fields .= $temp; |
|
288 |
- $arrFields[$arrData['eval']['feGroup']][$field] .= $temp; |
|
289 |
- |
|
290 |
- ++$i; |
|
291 |
- } |
|
292 |
- |
|
293 |
- // Captcha |
|
294 |
- if (!$this->disableCaptcha) |
|
295 |
- { |
|
296 |
- $objCaptcha->rowClass = 'row_'.$i . (($i == 0) ? ' row_first' : '') . ((($i % 2) == 0) ? ' even' : ' odd'); |
|
297 |
- $strCaptcha = $objCaptcha->parse(); |
|
298 |
- |
|
299 |
- $this->Template->fields .= $strCaptcha; |
|
300 |
- $arrFields['captcha']['captcha'] .= $strCaptcha; |
|
301 |
- } |
|
302 |
- |
|
303 |
- $this->Template->rowLast = 'row_' . ++$i . ((($i % 2) == 0) ? ' even' : ' odd'); |
|
304 |
- $this->Template->enctype = $hasUpload ? 'multipart/form-data' : 'application/x-www-form-urlencoded'; |
|
305 |
- $this->Template->hasError = $doNotSubmit; |
|
306 |
- |
|
307 |
- // Create new user if there are no errors |
|
308 |
- if (\Input::post('FORM_SUBMIT') == 'tl_registration' && !$doNotSubmit) |
|
309 |
- { |
|
310 |
- $this->createNewUser($arrUser); |
|
71 |
+ $arrEditable[$key] = $field; |
|
311 | 72 |
} |
73 |
+ $this->editable = $arrEditable; |
|
312 | 74 |
|
313 |
- $this->Template->loginDetails = $GLOBALS['TL_LANG']['tl_member']['loginDetails']; |
|
314 |
- $this->Template->addressDetails = $GLOBALS['TL_LANG']['tl_member']['addressDetails']; |
|
315 |
- $this->Template->contactDetails = $GLOBALS['TL_LANG']['tl_member']['contactDetails']; |
|
316 |
- $this->Template->personalData = $GLOBALS['TL_LANG']['tl_member']['personalData']; |
|
317 |
- $this->Template->captchaDetails = $GLOBALS['TL_LANG']['MSC']['securityQuestion']; |
|
318 |
- |
|
319 |
- // Add the groups |
|
320 |
- foreach ($arrFields as $k=>$v) |
|
321 |
- { |
|
322 |
- $this->Template->$k = $v; // backwards compatibility |
|
323 |
- |
|
324 |
- $key = $k . (($k == 'personal') ? 'Data' : 'Details'); |
|
325 |
- $arrGroups[$GLOBALS['TL_LANG']['tl_member'][$key]] = $v; |
|
326 |
- } |
|
75 |
+ parent::compile(); |
|
327 | 76 |
|
328 |
- $this->Template->categories = $arrGroups; |
|
329 |
- $this->Template->formId = 'tl_registration'; |
|
330 |
- $this->Template->slabel = specialchars($GLOBALS['TL_LANG']['MSC']['register']); |
|
331 |
- $this->Template->action = \Environment::get('indexFreeRequest'); |
|
332 |
- $this->Template->captcha = $arrFields['captcha']['captcha']; // backwards compatibility |
|
333 | 77 |
} |
334 | 78 |
} |