class LtiToolProviderProvisionSettingsForm in LTI Tool Provider 8
Same name and namespace in other branches
- 2.x modules/lti_tool_provider_provision/src/Form/LtiToolProviderProvisionSettingsForm.php \Drupal\lti_tool_provider_provision\Form\LtiToolProviderProvisionSettingsForm
Hierarchy
- class \Drupal\Core\Form\FormBase implements ContainerInjectionInterface, FormInterface uses DependencySerializationTrait, LoggerChannelTrait, MessengerTrait, LinkGeneratorTrait, RedirectDestinationTrait, UrlGeneratorTrait, StringTranslationTrait
- class \Drupal\Core\Form\ConfigFormBase uses ConfigFormBaseTrait
- class \Drupal\lti_tool_provider_provision\Form\LtiToolProviderProvisionSettingsForm
- class \Drupal\Core\Form\ConfigFormBase uses ConfigFormBaseTrait
Expanded class hierarchy of LtiToolProviderProvisionSettingsForm
1 string reference to 'LtiToolProviderProvisionSettingsForm'
- lti_tool_provider_provision.routing.yml in modules/
lti_tool_provider_provision/ lti_tool_provider_provision.routing.yml - modules/lti_tool_provider_provision/lti_tool_provider_provision.routing.yml
File
- modules/
lti_tool_provider_provision/ src/ Form/ LtiToolProviderProvisionSettingsForm.php, line 10
Namespace
Drupal\lti_tool_provider_provision\FormView source
class LtiToolProviderProvisionSettingsForm extends ConfigFormBase {
/**
* {@inheritdoc}
*/
public function getFormId() : string {
return 'lti_tool_provider_provision_settings';
}
/**
* {@inheritdoc}
*/
protected function getEditableConfigNames() : array {
return [
'lti_tool_provider_provision.settings',
];
}
/**
* {@inheritdoc}
*/
public function buildForm(array $form, FormStateInterface $form_state, $filter = '') : array {
$settings = $this
->config('lti_tool_provider_provision.settings');
$lti_roles = $this
->config('lti_tool_provider.settings')
->get('lti_roles');
$entityType = $form_state
->getValue('entity_type') ? $form_state
->getValue('entity_type') : $settings
->get('entity_type');
$entityBundle = $form_state
->getValue('entity_bundle') ? $form_state
->getValue('entity_bundle') : $settings
->get('entity_bundle');
$entityRedirect = $form_state
->getValue('entity_redirect') ? $form_state
->getValue('entity_redirect') : $settings
->get('entity_redirect');
$entityDefaults = $form_state
->getValue('entity_defaults') ? $form_state
->getValue('entity_defaults') : $settings
->get('entity_defaults');
$entitySync = $form_state
->getValue('entity_sync') ? $form_state
->getValue('entity_sync') : $settings
->get('entity_sync');
$allowedRolesEnabled = $form_state
->getValue('allowed_roles_enabled') ? $form_state
->getValue('allowed_roles_enabled') : $settings
->get('allowed_roles_enabled');
$allowedRoles = $form_state
->getValue('allowed_roles') ? $form_state
->getValue('allowed_roles') : $settings
->get('allowed_roles');
$form['#attributes']['id'] = uniqid($this
->getFormId());
$options = [];
$definitions = Drupal::entityTypeManager()
->getDefinitions();
foreach ($definitions as $definition) {
if ($definition instanceof ContentEntityType) {
$options[$definition
->id()] = $definition
->getLabel();
}
}
$form['entity_type'] = [
'#type' => 'select',
'#title' => $this
->t('Default entity type'),
'#description' => $this
->t('Select the entity type to use as the default entity provision.'),
'#default_value' => $entityType,
'#empty_value' => '',
'#empty_option' => '- Select an entity type -',
'#options' => $options,
'#ajax' => [
'callback' => '::getEntityBundles',
'event' => 'change',
'wrapper' => $form['#attributes']['id'],
'progress' => [
'type' => 'throbber',
],
],
];
if ($entityType) {
$options = [];
$bundles = Drupal::service('entity_type.bundle.info')
->getBundleInfo($entityType);
foreach ($bundles as $key => $bundleInfo) {
$options[$key] = $bundleInfo['label'];
}
$form['entity_bundle'] = [
'#type' => 'select',
'#title' => $this
->t('Default entity bundle'),
'#description' => $this
->t('Select the entity bundle to use as the default entity provision.'),
'#default_value' => $entityBundle,
'#empty_value' => '',
'#empty_option' => '- Select an entity type -',
'#options' => $options,
'#ajax' => [
'callback' => '::getEntityBundles',
'event' => 'change',
'wrapper' => $form['#attributes']['id'],
'progress' => [
'type' => 'throbber',
],
],
];
}
$form['entity_redirect'] = [
'#type' => 'checkbox',
'#title' => $this
->t('Always redirect to entity upon launch.'),
'#default_value' => $entityRedirect,
];
if ($entityBundle) {
$lti_launch = $this
->config('lti_tool_provider.settings')
->get('lti_launch');
$form['entity_defaults'] = [
'#type' => 'fieldset',
'#title' => 'Entity defaults',
'#tree' => true,
];
/* @var $entityManager Drupal\Core\Entity\EntityFieldManagerInterface */
$entityManager = Drupal::service('entity_field.manager');
$userFieldDefinitions = $entityManager
->getFieldDefinitions($entityType, $entityBundle);
foreach ($userFieldDefinitions as $key => $field) {
$type = $field
->getType();
if ($type === 'string') {
$form['entity_defaults'][$key] = [
'name' => [
'#type' => 'item',
'#title' => $field
->getLabel(),
],
'lti_attribute' => [
'#type' => 'select',
'#required' => false,
'#empty_option' => t('None'),
'#empty_value' => true,
'#default_value' => $entityDefaults[$key],
'#options' => array_combine($lti_launch, $lti_launch),
],
];
}
}
$form['entity_sync'] = [
'#type' => 'checkbox',
'#title' => $this
->t('Always sync entity fields from context during launch.'),
'#default_value' => $entitySync,
];
}
$form['allowed_roles_enabled'] = [
'#type' => 'checkbox',
'#title' => $this
->t('Restrict entity provision to specific LTI roles.'),
'#default_value' => $allowedRolesEnabled,
];
$form['allowed_roles'] = [
'#type' => 'details',
'#title' => 'Allowed Roles',
'#description' => $this
->t('If enabled above, allow only specific LTI roles to provision entities.'),
'#tree' => true,
'#open' => false,
];
foreach ($lti_roles as $ltiRole) {
$form['allowed_roles'][$ltiRole] = [
'#type' => 'checkbox',
'#title' => $this
->t($ltiRole),
'#default_value' => $allowedRoles[$ltiRole],
];
}
return parent::buildForm($form, $form_state);
}
/**
* {@inheritdoc}
*/
public function submitForm(array &$form, FormStateInterface $form_state) {
$settings = $this
->config('lti_tool_provider_provision.settings');
$lti_launch = $this
->config('lti_tool_provider.settings')
->get('lti_launch');
$entityType = $form_state
->getValue('entity_type');
$entityBundle = $form_state
->getValue('entity_bundle');
$entityRedirect = $form_state
->getValue('entity_redirect');
$entitySync = $form_state
->getValue('entity_sync');
$allowedRolesEnabled = $form_state
->getValue('allowed_roles_enabled');
$settings
->set('entity_type', $entityType)
->save();
$settings
->set('entity_bundle', $entityBundle)
->save();
$settings
->set('entity_redirect', $entityRedirect)
->save();
$settings
->set('entity_sync', $entitySync)
->save();
$settings
->set('allowed_roles_enabled', $allowedRolesEnabled)
->save();
$entityDefaults = [];
foreach ($form_state
->getValue('entity_defaults') as $key => $value) {
if (in_array($value['lti_attribute'], $lti_launch)) {
$entityDefaults[$key] = $value['lti_attribute'];
}
}
$settings
->set('entity_defaults', $entityDefaults)
->save();
$allowedRoles = [];
foreach ($form_state
->getValue('allowed_roles') as $key => $value) {
$allowedRoles[$key] = $value;
}
$settings
->set('allowed_roles', $allowedRoles)
->save();
parent::submitForm($form, $form_state);
}
/**
* @param array $form
* @return array
*/
public function getEntityBundles(array $form) : array {
return $form;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ConfigFormBase:: |
public static | function |
Instantiates a new instance of this class. Overrides FormBase:: |
13 |
ConfigFormBase:: |
public | function | Constructs a \Drupal\system\ConfigFormBase object. | 11 |
ConfigFormBaseTrait:: |
protected | function | Retrieves a configuration object. | |
DependencySerializationTrait:: |
protected | property | An array of entity type IDs keyed by the property name of their storages. | |
DependencySerializationTrait:: |
protected | property | An array of service IDs keyed by property name used for serialization. | |
DependencySerializationTrait:: |
public | function | 1 | |
DependencySerializationTrait:: |
public | function | 2 | |
FormBase:: |
protected | property | The config factory. | 1 |
FormBase:: |
protected | property | The request stack. | 1 |
FormBase:: |
protected | property | The route match. | |
FormBase:: |
protected | function | Gets the config factory for this form. | 1 |
FormBase:: |
private | function | Returns the service container. | |
FormBase:: |
protected | function | Gets the current user. | |
FormBase:: |
protected | function | Gets the request object. | |
FormBase:: |
protected | function | Gets the route match. | |
FormBase:: |
protected | function | Gets the logger for a specific channel. | |
FormBase:: |
protected | function |
Returns a redirect response object for the specified route. Overrides UrlGeneratorTrait:: |
|
FormBase:: |
public | function | Resets the configuration factory. | |
FormBase:: |
public | function | Sets the config factory for this form. | |
FormBase:: |
public | function | Sets the request stack object to use. | |
FormBase:: |
public | function |
Form validation handler. Overrides FormInterface:: |
62 |
LinkGeneratorTrait:: |
protected | property | The link generator. | 1 |
LinkGeneratorTrait:: |
protected | function | Returns the link generator. | |
LinkGeneratorTrait:: |
protected | function | Renders a link to a route given a route name and its parameters. | |
LinkGeneratorTrait:: |
public | function | Sets the link generator service. | |
LoggerChannelTrait:: |
protected | property | The logger channel factory service. | |
LoggerChannelTrait:: |
protected | function | Gets the logger for a specific channel. | |
LoggerChannelTrait:: |
public | function | Injects the logger channel factory. | |
LtiToolProviderProvisionSettingsForm:: |
public | function |
Form constructor. Overrides ConfigFormBase:: |
|
LtiToolProviderProvisionSettingsForm:: |
protected | function |
Gets the configuration names that will be editable. Overrides ConfigFormBaseTrait:: |
|
LtiToolProviderProvisionSettingsForm:: |
public | function | ||
LtiToolProviderProvisionSettingsForm:: |
public | function |
Returns a unique string identifying the form. Overrides FormInterface:: |
|
LtiToolProviderProvisionSettingsForm:: |
public | function |
Form submission handler. Overrides ConfigFormBase:: |
|
MessengerTrait:: |
protected | property | The messenger. | 29 |
MessengerTrait:: |
public | function | Gets the messenger. | 29 |
MessengerTrait:: |
public | function | Sets the messenger. | |
RedirectDestinationTrait:: |
protected | property | The redirect destination service. | 1 |
RedirectDestinationTrait:: |
protected | function | Prepares a 'destination' URL query parameter for use with \Drupal\Core\Url. | |
RedirectDestinationTrait:: |
protected | function | Returns the redirect destination service. | |
RedirectDestinationTrait:: |
public | function | Sets the redirect destination service. | |
StringTranslationTrait:: |
protected | property | The string translation service. | 1 |
StringTranslationTrait:: |
protected | function | Formats a string containing a count of items. | |
StringTranslationTrait:: |
protected | function | Returns the number of plurals supported by a given language. | |
StringTranslationTrait:: |
protected | function | Gets the string translation service. | |
StringTranslationTrait:: |
public | function | Sets the string translation service to use. | 2 |
StringTranslationTrait:: |
protected | function | Translates a string to the current language or to a given language. | |
UrlGeneratorTrait:: |
protected | property | The url generator. | |
UrlGeneratorTrait:: |
protected | function | Returns the URL generator service. | |
UrlGeneratorTrait:: |
public | function | Sets the URL generator service. | |
UrlGeneratorTrait:: |
protected | function | Generates a URL or path for a specific route based on the given parameters. |