SettingsForm.php in Administer Users by Role 8.3
File
src/Form/SettingsForm.php
View source
<?php
namespace Drupal\administerusersbyrole\Form;
use Drupal\Component\Utility\Html;
use Drupal\Core\Form\ConfigFormBase;
use Drupal\Core\Form\FormStateInterface;
use Drupal\administerusersbyrole\Services\AccessManagerInterface;
use Symfony\Component\DependencyInjection\ContainerInterface;
class SettingsForm extends ConfigFormBase {
protected $accessManager;
public function __construct(AccessManagerInterface $access_manager) {
$this->accessManager = $access_manager;
}
public static function create(ContainerInterface $container) {
return new static($container
->get('administerusersbyrole.access'));
}
public function getFormId() {
return 'administerusersbyrole_settings';
}
protected function getEditableConfigNames() {
return [
'administerusersbyrole.settings',
];
}
public function buildForm(array $form, FormStateInterface $form_state) {
$config = $this
->config('administerusersbyrole.settings');
$form['roles'] = [
'#type' => 'fieldset',
'#title' => $this
->t('Roles'),
];
$options = [
AccessManagerInterface::SAFE => $this
->t('Allowed'),
AccessManagerInterface::UNSAFE => $this
->t('Forbidden'),
AccessManagerInterface::PERM => $this
->t('Custom'),
];
foreach ($this->accessManager
->managedRoles() as $rid => $role) {
$form['roles'][$rid] = [
'#type' => 'select',
'#title' => Html::escape($role
->label()),
'#default_value' => $config
->get("roles.{$rid}"),
'#options' => $options,
'#required' => TRUE,
];
}
return parent::buildForm($form, $form_state);
}
public function submitForm(array &$form, FormStateInterface $form_state) {
$config = $this
->config('administerusersbyrole.settings');
$values = $form_state
->cleanValues()
->getValues();
foreach ($values as $rid => $value) {
$config
->set("roles.{$rid}", $value);
}
$config
->save();
parent::submitForm($form, $form_state);
}
}