... | ... |
@@ -41,18 +41,11 @@ class Member extends Frontend |
41 | 41 |
|
42 | 42 |
/** |
43 | 43 |
* MemberAvatar file name |
44 |
- * |
|
45 |
- * @var string |
|
46 | 44 |
*/ |
47 |
- protected $avatarName = 'memberAvatar'; |
|
45 |
+ protected string $avatarName = 'memberAvatar'; |
|
48 | 46 |
|
49 | 47 |
/** |
50 | 48 |
* Create avatar for a member | Registration |
51 |
- * |
|
52 |
- * @param int $userId |
|
53 |
- * @param array $arrData |
|
54 |
- * |
|
55 |
- * @return void |
|
56 | 49 |
*/ |
57 | 50 |
public function createAvatar(int $userId, array $arrData): void |
58 | 51 |
{ |
... | ... |
@@ -62,13 +55,8 @@ class Member extends Frontend |
62 | 55 |
|
63 | 56 |
/** |
64 | 57 |
* Update avatar of a member | Login |
65 |
- * |
|
66 |
- * @param FrontendUser $objUser |
|
67 |
- * @param array $arrData |
|
68 |
- * |
|
69 |
- * @return void |
|
70 | 58 |
*/ |
71 |
- public function updateAvatar(FrontendUser $objUser, $arrData): void |
|
59 |
+ public function updateAvatar(FrontendUser $objUser, array $arrData): void |
|
72 | 60 |
{ |
73 | 61 |
$objMember = MemberModel::findById($objUser->id); |
74 | 62 |
$this->processAvatar($objMember, $arrData); |
... | ... |
@@ -76,11 +64,6 @@ class Member extends Frontend |
76 | 64 |
|
77 | 65 |
/** |
78 | 66 |
* Process avatar upload for a member |
79 |
- * |
|
80 |
- * @param MemberModel $objMember |
|
81 |
- * @param array $arrData |
|
82 |
- * |
|
83 |
- * @return void |
|
84 | 67 |
*/ |
85 | 68 |
protected function processAvatar(MemberModel $objMember, ?array $arrData): void |
86 | 69 |
{ |
... | ... |
@@ -173,6 +156,7 @@ class Member extends Frontend |
173 | 156 |
// Upload valid file type with no width and height -> svg |
174 | 157 |
|
175 | 158 |
// Don't upload if no homedir is assigned |
159 |
+ // ToDo: Create homedir? |
|
176 | 160 |
if (!$objMember->assignDir || !$objMember->homeDir) |
177 | 161 |
{ |
178 | 162 |
// ToDo: add error message for no homedir |
... | ... |
@@ -186,7 +170,7 @@ class Member extends Frontend |
186 | 170 |
// The upload folder could not be found |
187 | 171 |
if ($objUploadFolder === null) |
188 | 172 |
{ |
189 |
- throw new \Exception("Invalid upload folder ID $intUploadFolder"); |
|
173 |
+ throw new Exception("Invalid upload folder ID $intUploadFolder"); |
|
190 | 174 |
} |
191 | 175 |
|
192 | 176 |
$strUploadFolder = $objUploadFolder->path; |
... | ... |
@@ -246,7 +230,7 @@ class Member extends Frontend |
246 | 230 |
|
247 | 231 |
// Add a log entry |
248 | 232 |
$logger = System::getContainer()->get('monolog.logger.contao'); |
249 |
- $logger->log(LogLevel::INFO, 'File "' . $strUploadFolder . '/' . $file['name'] . '" has been uploaded', array('contao' => new ContaoContext(__METHOD__, TL_FILES))); |
|
233 |
+ $logger->log(LogLevel::INFO, 'File "' . $strUploadFolder . '/' . $file['name'] . '" has been uploaded', ['contao' => new ContaoContext(__METHOD__, TL_FILES)]); |
|
250 | 234 |
} |
251 | 235 |
|
252 | 236 |
unset($_SESSION['FILES']['avatar']); |
... | ... |
@@ -254,10 +238,8 @@ class Member extends Frontend |
254 | 238 |
|
255 | 239 |
/** |
256 | 240 |
* Return the maximum upload file size in bytes |
257 |
- * |
|
258 |
- * @return string |
|
259 | 241 |
*/ |
260 |
- protected function getMaximumUploadSize() |
|
242 |
+ protected function getMaximumUploadSize(): string |
|
261 | 243 |
{ |
262 | 244 |
if ($this->maxlength > 0) |
263 | 245 |
{ |
... | ... |
@@ -269,13 +251,8 @@ class Member extends Frontend |
269 | 251 |
|
270 | 252 |
/** |
271 | 253 |
* Parses an avatar to the template |
272 |
- * |
|
273 |
- * @param MemberModel|null $objMember |
|
274 |
- * @param $objTemplate |
|
275 |
- * @param $strImgSize |
|
276 |
- * @return void |
|
277 | 254 |
*/ |
278 |
- public static function parseMemberAvatar(?MemberModel $objMember, &$objTemplate, $strImgSize) |
|
255 |
+ public static function parseMemberAvatar(?MemberModel $objMember, &$objTemplate, $strImgSize): void |
|
279 | 256 |
{ |
280 | 257 |
$objTemplate->addImage= true; |
281 | 258 |
|
... | ... |
@@ -305,9 +282,6 @@ class Member extends Frontend |
305 | 282 |
|
306 | 283 |
/** |
307 | 284 |
* Gets the url for a member avatar |
308 |
- * |
|
309 |
- * @param MemberModel|null $objMember |
|
310 |
- * @return string |
|
311 | 285 |
*/ |
312 | 286 |
public static function getMemberAvatarURL(?MemberModel $objMember): string |
313 | 287 |
{ |
... | ... |
@@ -329,9 +303,7 @@ class Member extends Frontend |
329 | 303 |
} |
330 | 304 |
|
331 | 305 |
/** |
332 |
- * @param MemberModel $objMember |
|
333 |
- * |
|
334 |
- * @return void |
|
306 |
+ * Deletes an avatar |
|
335 | 307 |
*/ |
336 | 308 |
public static function deleteAvatar(MemberModel $objMember): void |
337 | 309 |
{ |
... | ... |
@@ -13,21 +13,22 @@ declare(strict_types=1); |
13 | 13 |
* @copyright Oveleon <https://www.oveleon.de/> |
14 | 14 |
*/ |
15 | 15 |
|
16 |
+use Contao\Config; |
|
17 |
+use Contao\CoreBundle\DataContainer\PaletteManipulator; |
|
18 |
+ |
|
16 | 19 |
// Extend the default palette |
17 |
-Contao\CoreBundle\DataContainer\PaletteManipulator::create() |
|
18 |
- ->addField(['avatar'], 'personal_legend', Contao\CoreBundle\DataContainer\PaletteManipulator::POSITION_APPEND) |
|
20 |
+PaletteManipulator::create() |
|
21 |
+ ->addField(['avatar'], 'personal_legend', PaletteManipulator::POSITION_APPEND) |
|
19 | 22 |
->applyToPalette('default', 'tl_member') |
20 | 23 |
; |
21 | 24 |
|
22 | 25 |
// Add global operations |
23 |
-array_insert($GLOBALS['TL_DCA']['tl_member']['list']['global_operations'], 0, [ |
|
24 |
- 'settings' => [ |
|
25 |
- 'label' => &$GLOBALS['TL_LANG']['tl_member']['settings'], |
|
26 |
- 'href' => 'do=member_settings', |
|
27 |
- 'icon' => 'edit.svg', |
|
28 |
- 'attributes' => 'onclick="Backend.getScrollOffset()" accesskey="e"' |
|
29 |
- ] |
|
30 |
-]); |
|
26 |
+$GLOBALS['TL_DCA']['tl_member']['list']['global_operations']['settings'] = [ |
|
27 |
+ 'label' => &$GLOBALS['TL_LANG']['tl_member']['settings'], |
|
28 |
+ 'href' => 'do=member_settings', |
|
29 |
+ 'icon' => 'edit.svg', |
|
30 |
+ 'attributes' => 'onclick="Backend.getScrollOffset()" accesskey="e"' |
|
31 |
+]; |
|
31 | 32 |
|
32 | 33 |
// Add fields to tl_user |
33 | 34 |
$GLOBALS['TL_DCA']['tl_member']['fields']['avatar'] = [ |
... | ... |
@@ -20,13 +20,10 @@ use Contao\System; |
20 | 20 |
System::loadLanguageFile('tl_member_settings'); |
21 | 21 |
|
22 | 22 |
// Add palettes to tl_module |
23 |
-// ToDo: Change to ArrayUtil::arrayInsert in the future |
|
24 |
-array_insert($GLOBALS['TL_DCA']['tl_module']['palettes'], 0, [ |
|
25 |
- 'avatar' => '{title_legend},name,headline,type;{source_legend},imgSize;{template_legend:hide},customTpl;{protected_legend:hide},protected;{expert_legend:hide},guests,cssID', |
|
26 |
- 'deleteAvatar' => '{title_legend},name,headline,type;{template_legend:hide},customTpl;{protected_legend:hide},protected;{expert_legend:hide},guests,cssID', |
|
27 |
- 'memberList' => '{title_legend},name,headline,type;{config_legend},ext_order,ext_orderField,numberOfItems,perPage,ext_groups,memberFields,imgSize;{redirect_legend},jumpTo;{template_legend:hide},customTpl,memberListTpl;{protected_legend:hide},protected;{expert_legend:hide},guests,cssID', |
|
28 |
- 'memberReader' => '{title_legend},name,headline,type;{config_legend},ext_groups,memberFields,imgSize;{template_legend:hide},customTpl,memberReaderTpl;{protected_legend:hide},protected;{expert_legend:hide},guests,cssID' |
|
29 |
-]); |
|
23 |
+$GLOBALS['TL_DCA']['tl_module']['palettes']['avatar'] = '{title_legend},name,headline,type;{source_legend},imgSize;{template_legend:hide},customTpl;{protected_legend:hide},protected;{expert_legend:hide},guests,cssID'; |
|
24 |
+$GLOBALS['TL_DCA']['tl_module']['palettes']['deleteAvatar'] = '{title_legend},name,headline,type;{template_legend:hide},customTpl;{protected_legend:hide},protected;{expert_legend:hide},guests,cssID'; |
|
25 |
+$GLOBALS['TL_DCA']['tl_module']['palettes']['memberList'] = '{title_legend},name,headline,type;{config_legend},ext_order,ext_orderField,numberOfItems,perPage,ext_groups,memberFields,imgSize;{redirect_legend},jumpTo;{template_legend:hide},customTpl,memberListTpl;{protected_legend:hide},protected;{expert_legend:hide},guests,cssID'; |
|
26 |
+$GLOBALS['TL_DCA']['tl_module']['palettes']['memberReader'] = '{title_legend},name,headline,type;{config_legend},ext_groups,memberFields,imgSize;{template_legend:hide},customTpl,memberReaderTpl;{protected_legend:hide},protected;{expert_legend:hide},guests,cssID'; |
|
30 | 27 |
|
31 | 28 |
$GLOBALS['TL_DCA']['tl_module']['fields']['memberListTpl'] = [ |
32 | 29 |
'exclude' => true, |
... | ... |
@@ -90,28 +87,9 @@ class tl_module_extension extends Backend |
90 | 87 |
} |
91 | 88 |
|
92 | 89 |
/** |
93 |
- * Check permissions to edit the table |
|
94 |
- * |
|
95 |
- * @throws Contao\CoreBundle\Exception\AccessDeniedException |
|
96 |
- */ |
|
97 |
- public function checkPermission() |
|
98 |
- { |
|
99 |
- if ($this->User->isAdmin) |
|
100 |
- { |
|
101 |
- return; |
|
102 |
- } |
|
103 |
- |
|
104 |
- if (!$this->User->hasAccess('modules', 'themes')) { |
|
105 |
- throw new Contao\CoreBundle\Exception\AccessDeniedException('Not enough permissions to access the front end modules module.'); |
|
106 |
- } |
|
107 |
- } |
|
108 |
- |
|
109 |
- /** |
|
110 | 90 |
* Return all fields of table tl_member without account data |
111 |
- * |
|
112 |
- * @return array |
|
113 | 91 |
*/ |
114 |
- public function getMemberProperties() |
|
92 |
+ public function getMemberProperties(): array |
|
115 | 93 |
{ |
116 | 94 |
$return = []; |
117 | 95 |
|
... | ... |
@@ -131,11 +109,9 @@ class tl_module_extension extends Backend |
131 | 109 |
|
132 | 110 |
/** |
133 | 111 |
* Return all sortable fields of table tl_member |
134 |
- * |
|
135 |
- * @return array |
|
136 | 112 |
*/ |
137 |
- public function getViewableMemberFields() |
|
138 |
- { |
|
113 |
+ public function getViewableMemberFields(): array |
|
114 |
+ { |
|
139 | 115 |
$return = []; |
140 | 116 |
|
141 | 117 |
Contao\System::loadLanguageFile('tl_member'); |
... | ... |
@@ -143,7 +119,7 @@ class tl_module_extension extends Backend |
143 | 119 |
|
144 | 120 |
foreach ($GLOBALS['TL_DCA']['tl_member']['fields'] as $k=>$v) |
145 | 121 |
{ |
146 |
- if (!empty($v['inputType']) && $v['eval']['feViewable'] === true && $k !== 'avatar') |
|
122 |
+ if (!empty($v['inputType']) && $k !== 'avatar' && isset($v['eval']['feViewable']) && $v['eval']['feViewable'] === true) |
|
147 | 123 |
{ |
148 | 124 |
$return[$k] = $GLOBALS['TL_DCA']['tl_member']['fields'][$k]['label'][0] . ' ['.$k.']'; |
149 | 125 |
} |
... | ... |
@@ -39,47 +39,47 @@ use Contao\System; |
39 | 39 |
class ModuleMemberList extends ModuleMemberExtension |
40 | 40 |
{ |
41 | 41 |
|
42 |
- /** |
|
43 |
- * Template |
|
44 |
- * @var string |
|
45 |
- */ |
|
46 |
- protected $strTemplate = 'mod_memberList'; |
|
47 |
- |
|
48 |
- /** |
|
49 |
- * Template |
|
50 |
- * @var string |
|
51 |
- */ |
|
52 |
- protected $strMemberTemplate = 'memberExtension_list_default'; |
|
53 |
- |
|
54 |
- /** |
|
55 |
- * Return a wildcard in the back end |
|
56 |
- * |
|
57 |
- * @return string |
|
58 |
- */ |
|
59 |
- public function generate() |
|
60 |
- { |
|
42 |
+ /** |
|
43 |
+ * Template |
|
44 |
+ * @var string |
|
45 |
+ */ |
|
46 |
+ protected $strTemplate = 'mod_memberList'; |
|
47 |
+ |
|
48 |
+ /** |
|
49 |
+ * Template |
|
50 |
+ * @var string |
|
51 |
+ */ |
|
52 |
+ protected $strMemberTemplate = 'memberExtension_list_default'; |
|
53 |
+ |
|
54 |
+ /** |
|
55 |
+ * Return a wildcard in the back end |
|
56 |
+ * |
|
57 |
+ * @return string |
|
58 |
+ */ |
|
59 |
+ public function generate() |
|
60 |
+ { |
|
61 | 61 |
$request = System::getContainer()->get('request_stack')->getCurrentRequest(); |
62 | 62 |
|
63 | 63 |
if ($request && System::getContainer()->get('contao.routing.scope_matcher')->isBackendRequest($request)) |
64 | 64 |
{ |
65 | 65 |
$objTemplate = new BackendTemplate('be_wildcard'); |
66 |
- $objTemplate->wildcard = '### ' . mb_strtoupper($GLOBALS['TL_LANG']['FMD']['memberList'][0], 'UTF-8') . ' ###'; |
|
67 |
- $objTemplate->title = $this->headline; |
|
68 |
- $objTemplate->id = $this->id; |
|
69 |
- $objTemplate->link = $this->name; |
|
70 |
- $objTemplate->href = 'contao/main.php?do=themes&table=tl_module&act=edit&id=' . $this->id; |
|
71 |
- |
|
72 |
- return $objTemplate->parse(); |
|
73 |
- } |
|
74 |
- |
|
75 |
- return parent::generate(); |
|
76 |
- } |
|
77 |
- |
|
78 |
- /** |
|
79 |
- * Generate the module |
|
80 |
- */ |
|
81 |
- protected function compile() |
|
82 |
- { |
|
66 |
+ $objTemplate->wildcard = '### ' . mb_strtoupper($GLOBALS['TL_LANG']['FMD']['memberList'][0], 'UTF-8') . ' ###'; |
|
67 |
+ $objTemplate->title = $this->headline; |
|
68 |
+ $objTemplate->id = $this->id; |
|
69 |
+ $objTemplate->link = $this->name; |
|
70 |
+ $objTemplate->href = 'contao/main.php?do=themes&table=tl_module&act=edit&id=' . $this->id; |
|
71 |
+ |
|
72 |
+ return $objTemplate->parse(); |
|
73 |
+ } |
|
74 |
+ |
|
75 |
+ return parent::generate(); |
|
76 |
+ } |
|
77 |
+ |
|
78 |
+ /** |
|
79 |
+ * Generate the module |
|
80 |
+ */ |
|
81 |
+ protected function compile() |
|
82 |
+ { |
|
83 | 83 |
$limit = null; |
84 | 84 |
$offset = 0; |
85 | 85 |
|
... | ... |
@@ -162,7 +162,7 @@ class ModuleMemberList extends ModuleMemberExtension |
162 | 162 |
} |
163 | 163 |
|
164 | 164 |
$this->Template->members = $arrMembers; |
165 |
- } |
|
165 |
+ } |
|
166 | 166 |
|
167 | 167 |
/** |
168 | 168 |
* Checks whether a member is in any given group |
... | ... |
@@ -195,8 +195,8 @@ class ModuleMemberList extends ModuleMemberExtension |
195 | 195 |
*/ |
196 | 196 |
private function getMembers() |
197 | 197 |
{ |
198 |
- $arrOptions = []; |
|
199 | 198 |
$t = MemberModel::getTable(); |
199 |
+ $arrOptions = ['order' => '']; |
|
200 | 200 |
|
201 | 201 |
if (!!$this->ext_orderField) |
202 | 202 |
{ |
... | ... |
@@ -206,7 +206,7 @@ class ModuleMemberList extends ModuleMemberExtension |
206 | 206 |
switch ($this->ext_order) |
207 | 207 |
{ |
208 | 208 |
case 'order_random': |
209 |
- $arrOptions['order'] = "RAND()"; |
|
209 |
+ $arrOptions['order'] .= "RAND()"; |
|
210 | 210 |
break; |
211 | 211 |
|
212 | 212 |
case 'order_desc': |