ILIAS  trunk Revision v12.0_alpha-1221-g4e438232683
ILIAS\User\Settings\SettingsImplementation Class Reference
+ Inheritance diagram for ILIAS\User\Settings\SettingsImplementation:
+ Collaboration diagram for ILIAS\User\Settings\SettingsImplementation:

Public Member Functions

 __construct (private readonly Language $lng, private readonly \ilSetting $settings, private readonly UIFactory $ui_factory, private readonly Refinery $refinery, private readonly ConfigurationRepository $user_settings_configuration_repository, private readonly DataRepository $user_settings_data_repository)
 
 buildFormInputs (array $pages, Context $context, ?\ilObjUser $user)
 
 addSectionsToLegacyForm (\ilPropertyFormGUI $form, array $pages, Context $context, ?\ilObjUser $user)
 
 performAdditionalChecks (\ilGlobalTemplateInterface $tpl, \ilPropertyFormGUI $form)
 
 saveForm (\ilPropertyFormGUI|array $form, array $pages, Context $context, \ilObjUser $user)
 If it is possible to set the preference on the user, this is what will be done, the user needs to be updated/stored after calling this function. More...
 
 getSettingByDefinitionClass (string $definition_class)
 
 getValueFromLegacyFormByDefinitionClass (string $definition_class, \ilPropertyFormGUI $form)
 
 settingAvailableToUser (string $definition_class)
 
 getSettingValueFor (int $user_id, string $key)
 
 getExportableSettings ()
 
 getSettingByDefinitionClass (string $definition_class)
 
 getValueFromLegacyFormByDefinitionClass (string $definition_class, \ilPropertyFormGUI $form)
 
 settingAvailableToUser (string $definition_class)
 
 getSettingValueFor (int $user_id, string $key)
 

Private Member Functions

 getSettingsForPagesBySections (array $pages)
 
 reorderSections (array $sections)
 
 buildInputsForSection (array $settings, ?\ilObjUser $user)
 
 addSectionToLegacyForm (\ilPropertyFormGUI $form, ?\ilObjUser $user, array $section)
 
 addDefaultInputsToLegacyForm (\ilPropertyFormGUI $form, ?\ilObjUser $user, array $section)
 
 addAdditionalInputsToLegacyForm (\ilPropertyFormGUI $form, ?\ilObjUser $user, array $section)
 
 buildSectionKey (Setting $setting)
 
 filterSettingsInSectionForAvailability (Context $context, array $settings)
 
 retrieveValuefromInputs (\ilPropertyFormGUI|array $form, Setting $setting)
 
 checkStartingPointValue (\ilGlobalTemplateInterface $tpl, \ilPropertyFormGUI $form)
 

Detailed Description

Definition at line 28 of file SettingsImplementation.php.

Constructor & Destructor Documentation

◆ __construct()

ILIAS\User\Settings\SettingsImplementation::__construct ( private readonly Language  $lng,
private readonly \ilSetting  $settings,
private readonly UIFactory  $ui_factory,
private readonly Refinery  $refinery,
private readonly ConfigurationRepository  $user_settings_configuration_repository,
private readonly DataRepository  $user_settings_data_repository 
)

Definition at line 30 of file SettingsImplementation.php.

37 {
38 }

Member Function Documentation

◆ addAdditionalInputsToLegacyForm()

ILIAS\User\Settings\SettingsImplementation::addAdditionalInputsToLegacyForm ( \ilPropertyFormGUI  $form,
?\ilObjUser  $user,
array  $section 
)
private

Definition at line 301 of file SettingsImplementation.php.

306 $section_key = $this->buildSectionKey($section[0]);
307 $values = array_reduce(
308 $section,
309 function (array $c, Setting $v) use ($user): array {
310 $input = $v->getLegacyInput($this->lng, $this->settings, $user);
311 $input->setPostVar($v->getIdentifier());
312 $c['checkbox']->addSubItem($input);
313 $c['defaults'] .= "{$v->getLabel($this->lng)}: "
314 . "{$v->getDefaultValueForDisplay($this->lng, $this->settings)}; ";
315 if ($v->hasUserPersonalizedSetting($this->settings, $user)) {
316 $c['has_personalization'] = true;
317 }
318 return $c;
319 },
320 [
321 'checkbox' => new \ilCheckboxInputGUI(
322 $this->lng->txt("personalise_{$section_key}"),
323 $section_key
324 ),
325 'defaults' => "{$this->lng->txt('default')}<br>",
326 'has_personalization' => false
327 ]
328 );
329 $values['checkbox']->setInfo(trim($values['defaults']));
330 $values['checkbox']->setChecked($values['has_personalization']);
331
332 $form->addItem($values['checkbox']);
333
334 return $form;
335 }
hasUserPersonalizedSetting(\ilSetting $settings, ?\ilObjUser $user)
Definition: Setting.php:152
getLegacyInput(Language $lng, \ilSetting $settings, ?\ilObjUser $user=null)
Definition: Setting.php:104
This class represents a property form user interface.
$c
Definition: deliver.php:25
if(!file_exists('../ilias.ini.php'))

References $c, ILIAS\User\Settings\Setting\getIdentifier(), ILIAS\User\Settings\Setting\getLegacyInput(), ILIAS\User\Settings\Setting\hasUserPersonalizedSetting(), if, ILIAS\Repository\lng(), and ILIAS\Repository\settings().

+ Here is the call graph for this function:

◆ addDefaultInputsToLegacyForm()

ILIAS\User\Settings\SettingsImplementation::addDefaultInputsToLegacyForm ( \ilPropertyFormGUI  $form,
?\ilObjUser  $user,
array  $section 
)
private

Definition at line 285 of file SettingsImplementation.php.

290 return array_reduce(
291 $section,
292 function (\ilPropertyFormGUI $c, Setting $v) use ($user): \ilPropertyFormGUI {
293 $input = $v->getLegacyInput($this->lng, $this->settings, $user);
294 $c->addItem($input);
295 return $c;
296 },
297 $form
298 );
299 }

◆ addSectionsToLegacyForm()

ILIAS\User\Settings\SettingsImplementation::addSectionsToLegacyForm ( \ilPropertyFormGUI  $form,
array  $pages,
Context  $context,
?\ilObjUser  $user 
)
Parameters
array<ILIAS

User\Settings\AvailablePages> $pages

Definition at line 89 of file SettingsImplementation.php.

95 return array_reduce(
96 $this->getSettingsForPagesBySections($pages),
98 $c,
99 $user,
100 $this->filterSettingsInSectionForAvailability($context, $v)
101 ),
102 $form
103 );
104 }
addSectionToLegacyForm(\ilPropertyFormGUI $form, ?\ilObjUser $user, array $section)
filterSettingsInSectionForAvailability(Context $context, array $settings)

◆ addSectionToLegacyForm()

ILIAS\User\Settings\SettingsImplementation::addSectionToLegacyForm ( \ilPropertyFormGUI  $form,
?\ilObjUser  $user,
array  $section 
)
private

Definition at line 268 of file SettingsImplementation.php.

273 if ($section === []) {
274 return $form;
275 }
276
277 if ($section[0]->getSettingsPage() === AvailablePages::MainSettings
278 && $section[0]->getSection() === AvailableSections::Main) {
279 return $this->addDefaultInputsToLegacyForm($form, $user, $section);
280 }
281
282 return $this->addAdditionalInputsToLegacyForm($form, $user, $section);
283 }
addAdditionalInputsToLegacyForm(\ilPropertyFormGUI $form, ?\ilObjUser $user, array $section)
addDefaultInputsToLegacyForm(\ilPropertyFormGUI $form, ?\ilObjUser $user, array $section)

◆ buildFormInputs()

ILIAS\User\Settings\SettingsImplementation::buildFormInputs ( array  $pages,
Context  $context,
?\ilObjUser  $user 
)
Parameters
array<ILIAS

User\Settings\AvailablePages> $pages

Definition at line 43 of file SettingsImplementation.php.

47 : array {
48 return array_reduce(
49 $this->getSettingsForPagesBySections($pages),
50 function (array $c, array $v) use ($pages, $context, $user): array {
51 $settings = $this->filterSettingsInSectionForAvailability($context, $v);
52 if ($settings === []) {
53 return $c;
54 }
55
56 $page = $settings[0]->getSettingsPage();
57 $section = $settings[0]->getSection();
58 $section_key = $this->buildSectionKey($settings[0]);
59
60 ['inputs' => $inputs, 'byline' => $byline, 'personalized' => $personalized] = $this->buildInputsForSection(
61 $settings,
62 $user
63 );
64
65 if (!in_array(AvailablePages::MainSettings, $pages)
66 || $page === AvailablePages::MainSettings && $section === AvailableSections::Main) {
67 return $c + $inputs;
68 }
69
70 $c[$section_key] = $this->ui_factory->input()->field()->optionalGroup(
71 $inputs,
72 $this->lng->txt("personalise_{$section_key}"),
73 $byline
74 );
75
76 if (!$personalized) {
77 $c[$section_key] = $c[$section_key]->withValue(null);
78 }
79
80 return $c;
81 },
82 []
83 );
84 }
buildInputsForSection(array $settings, ?\ilObjUser $user)

References $c.

◆ buildInputsForSection()

ILIAS\User\Settings\SettingsImplementation::buildInputsForSection ( array  $settings,
?\ilObjUser  $user 
)
private

Definition at line 239 of file SettingsImplementation.php.

242 : array {
243 return array_reduce(
244 $settings,
245 function (array $c, Setting $v) use ($user): array {
246 $c['inputs'][$v->getIdentifier()] = $v->getInput(
247 $this->ui_factory->input()->field(),
248 $this->lng,
249 $this->refinery,
250 $this->settings,
251 $user
252 );
253 $c['byline'] .= "{$v->getLabel($this->lng)}: "
254 . "{$v->getDefaultValueForDisplay($this->lng, $this->settings)}; ";
255 if ($v->hasUserPersonalizedSetting($this->settings, $user)) {
256 $c['personalized'] = true;
257 }
258 return $c;
259 },
260 [
261 'inputs' => [],
262 'byline' => "{$this->lng->txt('default')}<br>",
263 'personalized' => false
264 ]
265 );
266 }
getInput(FieldFactory $field_factory, Language $lng, Refinery $refinery, \ilSetting $settings, ?\ilObjUser $user=null)
Definition: Setting.php:94

References $c.

◆ buildSectionKey()

ILIAS\User\Settings\SettingsImplementation::buildSectionKey ( Setting  $setting)
private

Definition at line 337 of file SettingsImplementation.php.

337 : string
338 {
339 return $setting->getSettingsPage() === AvailablePages::MainSettings
340 ? $setting->getSection()->value
341 : $setting->getSettingsPage()->value;
342 }
ilSetting $setting
Definition: class.ilias.php:68

References ILIAS\User\Settings\Setting\getSection(), and ILIAS\User\Settings\Setting\getSettingsPage().

+ Here is the call graph for this function:

◆ checkStartingPointValue()

ILIAS\User\Settings\SettingsImplementation::checkStartingPointValue ( \ilGlobalTemplateInterface  $tpl,
\ilPropertyFormGUI  $form 
)
private

Definition at line 372 of file SettingsImplementation.php.

375 : bool {
376 return $form->getInput('additional') === ''
377 || $this->user_settings_configuration_repository
378 ->getByIdentifier('starting_point')
379 ->validateUserChoice(
380 $tpl,
381 $this->lng,
382 $form
383 );
384 }

◆ filterSettingsInSectionForAvailability()

ILIAS\User\Settings\SettingsImplementation::filterSettingsInSectionForAvailability ( Context  $context,
array  $settings 
)
private

Definition at line 344 of file SettingsImplementation.php.

347 : array {
348 return array_values(
349 array_filter(
350 $settings,
351 static fn(Setting $v): bool => $context->isSettingAvailable($v)
352 )
353 );
354 }

◆ getExportableSettings()

ILIAS\User\Settings\SettingsImplementation::getExportableSettings ( )

Definition at line 186 of file SettingsImplementation.php.

186 : array
187 {
188 $context = Context::Export;
189 return array_filter(
190 $this->user_settings_configuration_repository->get(),
191 fn(Setting $v): bool => $context->isSettingAvailable($v)
192 );
193 }

◆ getSettingByDefinitionClass()

ILIAS\User\Settings\SettingsImplementation::getSettingByDefinitionClass ( string  $definition_class)

Implements ILIAS\User\Settings\Settings.

Definition at line 154 of file SettingsImplementation.php.

156 : Setting {
157 $setting = $this->user_settings_configuration_repository->getByDefinitionClass($definition_class);
158 if ($setting === null) {
159 throw new \UnexpectedValueException('No class by that name');
160 }
161 return $setting;
162 }

◆ getSettingsForPagesBySections()

ILIAS\User\Settings\SettingsImplementation::getSettingsForPagesBySections ( array  $pages)
private
Parameters
array<ILIAS

User\Settings\AvailablePages> $pages

Definition at line 198 of file SettingsImplementation.php.

200 : array {
201 return $this->reorderSections(
202 array_reduce(
203 $this->user_settings_configuration_repository->get(),
204 function (array $c, Setting $v) use ($pages): array {
205 if (!in_array($v->getSettingsPage(), $pages)) {
206 return $c;
207 }
208
209 $section_key = $this->buildSectionKey($v);
210 if (!array_key_exists($section_key, $c)) {
211 $c[$section_key] = [];
212 }
213
214 $c[$section_key][] = $v;
215 return $c;
216 },
217 []
218 )
219 );
220 }

References $c.

◆ getSettingValueFor()

ILIAS\User\Settings\SettingsImplementation::getSettingValueFor ( int  $user_id,
string  $key 
)

Implements ILIAS\User\Settings\Settings.

Definition at line 181 of file SettingsImplementation.php.

181 : ?string
182 {
183 return $this->user_settings_data_repository->getFor($user_id)[$key] ?? null;
184 }

References $user_id.

◆ getValueFromLegacyFormByDefinitionClass()

ILIAS\User\Settings\SettingsImplementation::getValueFromLegacyFormByDefinitionClass ( string  $definition_class,
\ilPropertyFormGUI  $form 
)

Implements ILIAS\User\Settings\Settings.

Definition at line 164 of file SettingsImplementation.php.

167 : mixed {
168 return $form->getInput(
169 $this->getSettingByDefinitionClass($definition_class)->getIdentifier()
170 );
171 }

◆ performAdditionalChecks()

ILIAS\User\Settings\SettingsImplementation::performAdditionalChecks ( \ilGlobalTemplateInterface  $tpl,
\ilPropertyFormGUI  $form 
)

Definition at line 106 of file SettingsImplementation.php.

109 : bool {
110 return $this->checkStartingPointValue(
111 $tpl,
112 $form
113 );
114 }
checkStartingPointValue(\ilGlobalTemplateInterface $tpl, \ilPropertyFormGUI $form)

◆ reorderSections()

ILIAS\User\Settings\SettingsImplementation::reorderSections ( array  $sections)
private

Definition at line 222 of file SettingsImplementation.php.

224 : array {
225 if (isset($sections[AvailableSections::Main->value])) {
226 $default_section = $sections[AvailableSections::Main->value];
227 unset($sections[AvailableSections::Main->value]);
228 array_unshift($sections, $default_section);
229 }
230
231 if (isset($sections[AvailableSections::Additional->value])) {
232 $additional_section = $sections[AvailableSections::Additional->value];
233 unset($sections[AvailableSections::Additional->value]);
234 $sections[AvailableSections::Additional->value] = $additional_section;
235 }
236 return $sections;
237 }

◆ retrieveValuefromInputs()

ILIAS\User\Settings\SettingsImplementation::retrieveValuefromInputs ( \ilPropertyFormGUI|array  $form,
Setting  $setting 
)
private

Definition at line 356 of file SettingsImplementation.php.

359 : mixed {
360 if ($form instanceof \ilPropertyFormGUI) {
361 return $form->getInput($setting->getIdentifier());
362 }
363
364 $section_key = $this->buildSectionKey($setting);
365
366 if ($section_key === AvailableSections::Main->value) {
367 return $form[$setting->getIdentifier()];
368 }
369 return $form[$section_key][$setting->getIdentifier()];
370 }

References ILIAS\User\Settings\Setting\getIdentifier().

+ Here is the call graph for this function:

◆ saveForm()

ILIAS\User\Settings\SettingsImplementation::saveForm ( \ilPropertyFormGUI|array  $form,
array  $pages,
Context  $context,
\ilObjUser  $user 
)

If it is possible to set the preference on the user, this is what will be done, the user needs to be updated/stored after calling this function.

Parameters
array<ILIAS

User\Settings\AvailablePages> $pages

Definition at line 122 of file SettingsImplementation.php.

127 : \ilObjUser {
128 foreach ($this->getSettingsForPagesBySections($pages) as $section => $settings) {
129 $available_settings = $this->filterSettingsInSectionForAvailability($context, $settings);
130 $set_settings_to_default = false;
131 if ($section !== 0
132 && (
133 is_array($form) && $form[$section] === null
134 || $form instanceof \ilPropertyFormGUI
135 && (($input = $form->getInput($section)) === '' || $input === '0')
136 )
137 ) {
138 $set_settings_to_default = true;
139 }
140 foreach ($available_settings as $setting) {
141 $setting->persistUserInput(
142 $user,
143 $context,
144 $set_settings_to_default ? null : $this->retrieveValueFromInputs($form, $setting),
145 $form instanceof \ilPropertyFormGUI ? $form : null
146 );
147 }
148 }
149
150 $user->update();
151 return $user;
152 }
User class.

◆ settingAvailableToUser()

ILIAS\User\Settings\SettingsImplementation::settingAvailableToUser ( string  $definition_class)

Implements ILIAS\User\Settings\Settings.

Definition at line 173 of file SettingsImplementation.php.

175 : bool {
176 return Context::User->isSettingAvailable(
177 $this->getSettingByDefinitionClass($definition_class)
178 );
179 }

The documentation for this class was generated from the following file: