ILIAS  trunk Revision v12.0_alpha-1540-g00f839d5fa1
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 305 of file SettingsImplementation.php.

310 $section_key = $this->buildSectionKey($section[0]);
311 $values = array_reduce(
312 $section,
313 function (array $c, Setting $v) use ($user): array {
314 $input = $v->getLegacyInput($this->lng, $this->settings, $user);
315 $input->setPostVar($v->getIdentifier());
316 $c['checkbox']->addSubItem($input);
317 $c['defaults'] .= "{$v->getLabel($this->lng)}: "
318 . "{$v->getDefaultValueForDisplay($this->lng, $this->settings)}; ";
319 if ($v->hasUserPersonalizedSetting($this->settings, $user)) {
320 $c['has_personalization'] = true;
321 }
322 return $c;
323 },
324 [
325 'checkbox' => new \ilCheckboxInputGUI(
326 $this->lng->txt("personalise_{$section_key}"),
327 $section_key
328 ),
329 'defaults' => "{$this->lng->txt('default')}<br>",
330 'has_personalization' => false
331 ]
332 );
333 $values['checkbox']->setInfo(trim($values['defaults']));
334 $values['checkbox']->setChecked($values['has_personalization']);
335
336 $form->addItem($values['checkbox']);
337
338 return $form;
339 }
hasUserPersonalizedSetting(\ilSetting $settings, ?\ilObjUser $user)
Definition: Setting.php:155
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 289 of file SettingsImplementation.php.

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

◆ addSectionsToLegacyForm()

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

Definition at line 90 of file SettingsImplementation.php.

96 return array_reduce(
97 $this->getSettingsForPagesBySections($pages),
99 $c,
100 $user,
101 $this->filterSettingsInSectionForAvailability($context, $v)
102 ),
103 $form
104 );
105 }
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 272 of file SettingsImplementation.php.

277 if ($section === []) {
278 return $form;
279 }
280
281 if ($section[0]->getSettingsPage() === AvailablePages::MainSettings
282 && $section[0]->getSection() === AvailableSections::Main) {
283 return $this->addDefaultInputsToLegacyForm($form, $user, $section);
284 }
285
286 return $this->addAdditionalInputsToLegacyForm($form, $user, $section);
287 }
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<AvailablePages>$pages
Returns
array<string, \ILIAS\UI\Component\Input\Input>

Definition at line 44 of file SettingsImplementation.php.

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

References $c.

◆ buildInputsForSection()

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

Definition at line 243 of file SettingsImplementation.php.

246 : array {
247 return array_reduce(
248 $settings,
249 function (array $c, Setting $v) use ($user): array {
250 $c['inputs'][$v->getIdentifier()] = $v->getInput(
251 $this->ui_factory->input()->field(),
252 $this->lng,
253 $this->refinery,
254 $this->settings,
255 $user
256 );
257 $c['byline'] .= "{$v->getLabel($this->lng)}: "
258 . "{$v->getDefaultValueForDisplay($this->lng, $this->settings)}; ";
259 if ($v->hasUserPersonalizedSetting($this->settings, $user)) {
260 $c['personalized'] = true;
261 }
262 return $c;
263 },
264 [
265 'inputs' => [],
266 'byline' => "{$this->lng->txt('default')}<br>",
267 'personalized' => false
268 ]
269 );
270 }
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 341 of file SettingsImplementation.php.

341 : string
342 {
343 return $setting->getSettingsPage() === AvailablePages::MainSettings
344 ? $setting->getSection()->value
345 : $setting->getSettingsPage()->value;
346 }
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 376 of file SettingsImplementation.php.

379 : bool {
380 return $form->getInput('additional') === ''
381 || $this->user_settings_configuration_repository
382 ->getByIdentifier('starting_point')
383 ->validateUserChoice(
384 $tpl,
385 $this->lng,
386 $form
387 );
388 }

◆ filterSettingsInSectionForAvailability()

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

Definition at line 348 of file SettingsImplementation.php.

351 : array {
352 return array_values(
353 array_filter(
354 $settings,
355 static fn(Setting $v): bool => $context->isSettingAvailable($v)
356 )
357 );
358 }

◆ getExportableSettings()

ILIAS\User\Settings\SettingsImplementation::getExportableSettings ( )
Returns
list<Setting>

Definition at line 190 of file SettingsImplementation.php.

190 : array
191 {
192 $context = Context::Export;
193 return array_filter(
194 $this->user_settings_configuration_repository->get(),
195 static fn(Setting $v): bool => $context->isSettingAvailable($v)
196 );
197 }

◆ getSettingByDefinitionClass()

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

Implements ILIAS\User\Settings\Settings.

Definition at line 155 of file SettingsImplementation.php.

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

◆ getSettingsForPagesBySections()

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

Definition at line 202 of file SettingsImplementation.php.

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

References $c.

◆ getSettingValueFor()

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

Implements ILIAS\User\Settings\Settings.

Definition at line 182 of file SettingsImplementation.php.

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

References $user_id.

◆ getValueFromLegacyFormByDefinitionClass()

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

Implements ILIAS\User\Settings\Settings.

Definition at line 165 of file SettingsImplementation.php.

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

◆ performAdditionalChecks()

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

Definition at line 107 of file SettingsImplementation.php.

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

◆ reorderSections()

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

Definition at line 226 of file SettingsImplementation.php.

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

◆ retrieveValueFromInputs()

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

Definition at line 360 of file SettingsImplementation.php.

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

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<AvailablePages>$pages

Definition at line 123 of file SettingsImplementation.php.

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

◆ settingAvailableToUser()

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

Implements ILIAS\User\Settings\Settings.

Definition at line 174 of file SettingsImplementation.php.

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

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