Mercurial > hg > isophonics-drupal-site
diff core/modules/views_ui/src/ViewAddForm.php @ 0:4c8ae668cc8c
Initial import (non-working)
author | Chris Cannam |
---|---|
date | Wed, 29 Nov 2017 16:09:58 +0000 |
parents | |
children | 1fec387a4317 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/core/modules/views_ui/src/ViewAddForm.php Wed Nov 29 16:09:58 2017 +0000 @@ -0,0 +1,206 @@ +<?php + +namespace Drupal\views_ui; + +use Drupal\Core\Form\FormStateInterface; +use Drupal\views\Plugin\views\wizard\WizardPluginBase; +use Drupal\views\Plugin\views\wizard\WizardException; +use Drupal\views\Plugin\ViewsPluginManager; +use Symfony\Component\DependencyInjection\ContainerInterface; + +/** + * Form controller for the Views edit form. + */ +class ViewAddForm extends ViewFormBase { + + /** + * The wizard plugin manager. + * + * @var \Drupal\views\Plugin\ViewsPluginManager + */ + protected $wizardManager; + + /** + * Constructs a new ViewEditForm object. + * + * @param \Drupal\views\Plugin\ViewsPluginManager $wizard_manager + * The wizard plugin manager. + */ + public function __construct(ViewsPluginManager $wizard_manager) { + $this->wizardManager = $wizard_manager; + } + + /** + * {@inheritdoc} + */ + public static function create(ContainerInterface $container) { + return new static( + $container->get('plugin.manager.views.wizard') + ); + } + + /** + * {@inheritdoc} + */ + protected function prepareEntity() { + // Do not prepare the entity while it is being added. + } + + /** + * {@inheritdoc} + */ + public function form(array $form, FormStateInterface $form_state) { + $form['#attached']['library'][] = 'views_ui/views_ui.admin'; + $form['#attributes']['class'] = ['views-admin']; + + $form['name'] = [ + '#type' => 'fieldset', + '#title' => t('View basic information'), + '#attributes' => ['class' => ['fieldset-no-legend']], + ]; + + $form['name']['label'] = [ + '#type' => 'textfield', + '#title' => $this->t('View name'), + '#required' => TRUE, + '#size' => 32, + '#default_value' => '', + '#maxlength' => 255, + ]; + $form['name']['id'] = [ + '#type' => 'machine_name', + '#maxlength' => 128, + '#machine_name' => [ + 'exists' => '\Drupal\views\Views::getView', + 'source' => ['name', 'label'], + ], + '#description' => $this->t('A unique machine-readable name for this View. It must only contain lowercase letters, numbers, and underscores.'), + ]; + + $form['name']['description_enable'] = [ + '#type' => 'checkbox', + '#title' => $this->t('Description'), + ]; + $form['name']['description'] = [ + '#type' => 'textfield', + '#title' => $this->t('Provide description'), + '#title_display' => 'invisible', + '#size' => 64, + '#default_value' => '', + '#states' => [ + 'visible' => [ + ':input[name="description_enable"]' => ['checked' => TRUE], + ], + ], + ]; + + // Create a wrapper for the entire dynamic portion of the form. Everything + // that can be updated by AJAX goes somewhere inside here. For example, this + // is needed by "Show" dropdown (below); it changes the base table of the + // view and therefore potentially requires all options on the form to be + // dynamically updated. + $form['displays'] = []; + + // Create the part of the form that allows the user to select the basic + // properties of what the view will display. + $form['displays']['show'] = [ + '#type' => 'fieldset', + '#title' => t('View settings'), + '#tree' => TRUE, + '#attributes' => ['class' => ['container-inline']], + ]; + + // Create the "Show" dropdown, which allows the base table of the view to be + // selected. + $wizard_plugins = $this->wizardManager->getDefinitions(); + $options = []; + foreach ($wizard_plugins as $key => $wizard) { + $options[$key] = $wizard['title']; + } + $form['displays']['show']['wizard_key'] = [ + '#type' => 'select', + '#title' => $this->t('Show'), + '#options' => $options, + ]; + $show_form = &$form['displays']['show']; + $default_value = \Drupal::moduleHandler()->moduleExists('node') ? 'node' : 'users'; + $show_form['wizard_key']['#default_value'] = WizardPluginBase::getSelected($form_state, ['show', 'wizard_key'], $default_value, $show_form['wizard_key']); + // Changing this dropdown updates the entire content of $form['displays'] via + // AJAX. + views_ui_add_ajax_trigger($show_form, 'wizard_key', ['displays']); + + // Build the rest of the form based on the currently selected wizard plugin. + $wizard_key = $show_form['wizard_key']['#default_value']; + $wizard_instance = $this->wizardManager->createInstance($wizard_key); + $form = $wizard_instance->buildForm($form, $form_state); + + return $form; + } + + /** + * {@inheritdoc} + */ + protected function actions(array $form, FormStateInterface $form_state) { + $actions = parent::actions($form, $form_state); + $actions['submit']['#value'] = $this->t('Save and edit'); + // Remove EntityFormController::save() form the submission handlers. + $actions['submit']['#submit'] = [[$this, 'submitForm']]; + $actions['cancel'] = [ + '#type' => 'submit', + '#value' => $this->t('Cancel'), + '#submit' => ['::cancel'], + '#limit_validation_errors' => [], + ]; + return $actions; + } + + /** + * {@inheritdoc} + */ + public function validateForm(array &$form, FormStateInterface $form_state) { + $wizard_type = $form_state->getValue(['show', 'wizard_key']); + $wizard_instance = $this->wizardManager->createInstance($wizard_type); + $form_state->set('wizard', $wizard_instance->getPluginDefinition()); + $form_state->set('wizard_instance', $wizard_instance); + $errors = $wizard_instance->validateView($form, $form_state); + + foreach ($errors as $display_errors) { + foreach ($display_errors as $name => $message) { + $form_state->setErrorByName($name, $message); + } + } + } + + /** + * {@inheritdoc} + */ + public function submitForm(array &$form, FormStateInterface $form_state) { + try { + /** @var $wizard \Drupal\views\Plugin\views\wizard\WizardInterface */ + $wizard = $form_state->get('wizard_instance'); + $this->entity = $wizard->createView($form, $form_state); + } + // @todo Figure out whether it really makes sense to throw and catch exceptions on the wizard. + catch (WizardException $e) { + drupal_set_message($e->getMessage(), 'error'); + $form_state->setRedirect('entity.view.collection'); + return; + } + $this->entity->save(); + drupal_set_message($this->t('The view %name has been saved.', ['%name' => $form_state->getValue('label')])); + $form_state->setRedirectUrl($this->entity->urlInfo('edit-form')); + } + + /** + * Form submission handler for the 'cancel' action. + * + * @param array $form + * An associative array containing the structure of the form. + * @param \Drupal\Core\Form\FormStateInterface $form_state + * The current state of the form. + */ + public function cancel(array $form, FormStateInterface $form_state) { + $form_state->setRedirect('entity.view.collection'); + } + +}