class AjaxFormsTestSimpleForm

Same name in other branches
  1. 8.9.x core/modules/system/tests/modules/ajax_forms_test/src/Form/AjaxFormsTestSimpleForm.php \Drupal\ajax_forms_test\Form\AjaxFormsTestSimpleForm
  2. 10 core/modules/system/tests/modules/ajax_forms_test/src/Form/AjaxFormsTestSimpleForm.php \Drupal\ajax_forms_test\Form\AjaxFormsTestSimpleForm
  3. 11.x core/modules/system/tests/modules/ajax_forms_test/src/Form/AjaxFormsTestSimpleForm.php \Drupal\ajax_forms_test\Form\AjaxFormsTestSimpleForm

Form builder: Builds a form that triggers a simple AJAX callback.

@internal

Hierarchy

Expanded class hierarchy of AjaxFormsTestSimpleForm

1 string reference to 'AjaxFormsTestSimpleForm'
ajax_forms_test.routing.yml in core/modules/system/tests/modules/ajax_forms_test/ajax_forms_test.routing.yml
core/modules/system/tests/modules/ajax_forms_test/ajax_forms_test.routing.yml

File

core/modules/system/tests/modules/ajax_forms_test/src/Form/AjaxFormsTestSimpleForm.php, line 14

Namespace

Drupal\ajax_forms_test\Form
View source
class AjaxFormsTestSimpleForm extends FormBase {
    
    /**
     * {@inheritdoc}
     */
    public function getFormId() {
        return 'ajax_forms_test_simple_form';
    }
    
    /**
     * {@inheritdoc}
     */
    public function buildForm(array $form, FormStateInterface $form_state) {
        $object = new Callbacks();
        $form = [];
        $form['select'] = [
            '#title' => $this->t('Color'),
            '#type' => 'select',
            '#options' => [
                'red' => 'red',
                'green' => 'green',
                'blue' => 'blue',
            ],
            '#ajax' => [
                'callback' => [
                    $object,
                    'selectCallback',
                ],
            ],
            '#suffix' => '<div id="ajax_selected_color">No color yet selected</div>',
        ];
        $form['checkbox'] = [
            '#type' => 'checkbox',
            '#title' => $this->t('Test checkbox'),
            '#ajax' => [
                'callback' => [
                    $object,
                    'checkboxCallback',
                ],
            ],
            '#suffix' => '<div id="ajax_checkbox_value">No action yet</div>',
        ];
        $form['submit'] = [
            '#type' => 'submit',
            '#value' => $this->t('submit'),
        ];
        // This is for testing invalid callbacks that should return a 500 error in
        // \Drupal\Core\Form\FormAjaxResponseBuilderInterface::buildResponse().
        $invalid_callbacks = [
            'null' => NULL,
            'empty' => '',
            'nonexistent' => 'some_function_that_does_not_exist',
        ];
        foreach ($invalid_callbacks as $key => $value) {
            $form['select_' . $key . '_callback'] = [
                '#type' => 'select',
                '#title' => $this->t('Test %key callbacks', [
                    '%key' => $key,
                ]),
                '#options' => [
                    'red' => 'red',
                    'green' => 'green',
                ],
                '#ajax' => [
                    'callback' => $value,
                ],
            ];
        }
        $form['test_group'] = [
            '#type' => 'details',
            '#title' => $this->t('Test group'),
            '#open' => TRUE,
        ];
        // Test ajax element in a #group.
        $form['checkbox_in_group_wrapper'] = [
            '#type' => 'container',
            '#attributes' => [
                'id' => 'checkbox-wrapper',
            ],
            '#group' => 'test_group',
            'checkbox_in_group' => [
                '#type' => 'checkbox',
                '#title' => $this->t('AJAX checkbox in a group'),
                '#ajax' => [
                    'callback' => [
                        $object,
                        'checkboxGroupCallback',
                    ],
                    'wrapper' => 'checkbox-wrapper',
                ],
            ],
            'nested_group' => [
                '#type' => 'details',
                '#title' => $this->t('Nested group'),
                '#open' => TRUE,
            ],
            'checkbox_in_nested' => [
                '#type' => 'checkbox',
                '#group' => 'nested_group',
                '#title' => $this->t('AJAX checkbox in a nested group'),
                '#ajax' => [
                    'callback' => [
                        $object,
                        'checkboxGroupCallback',
                    ],
                    'wrapper' => 'checkbox-wrapper',
                ],
            ],
        ];
        $form['another_checkbox_in_nested'] = [
            '#type' => 'checkbox',
            '#group' => 'nested_group',
            '#title' => $this->t('Another AJAX checkbox in a nested group'),
        ];
        return $form;
    }
    
    /**
     * {@inheritdoc}
     */
    public function submitForm(array &$form, FormStateInterface $form_state) {
    }

}

Members

Title Sort descending Modifiers Object type Summary Overriden Title Overrides
AjaxFormsTestSimpleForm::buildForm public function Form constructor. Overrides FormInterface::buildForm
AjaxFormsTestSimpleForm::getFormId public function Returns a unique string identifying the form. Overrides FormInterface::getFormId
AjaxFormsTestSimpleForm::submitForm public function Form submission handler. Overrides FormInterface::submitForm
DependencySerializationTrait::$_entityStorages protected property
DependencySerializationTrait::$_serviceIds protected property
DependencySerializationTrait::__sleep public function 1
DependencySerializationTrait::__wakeup public function 2
FormBase::$configFactory protected property The config factory. 3
FormBase::$requestStack protected property The request stack. 1
FormBase::$routeMatch protected property The route match.
FormBase::config protected function Retrieves a configuration object.
FormBase::configFactory protected function Gets the config factory for this form. 3
FormBase::container private function Returns the service container.
FormBase::create public static function Instantiates a new instance of this class. Overrides ContainerInjectionInterface::create 105
FormBase::currentUser protected function Gets the current user.
FormBase::getRequest protected function Gets the request object.
FormBase::getRouteMatch protected function Gets the route match.
FormBase::logger protected function Gets the logger for a specific channel.
FormBase::redirect protected function Returns a redirect response object for the specified route.
FormBase::resetConfigFactory public function Resets the configuration factory.
FormBase::setConfigFactory public function Sets the config factory for this form.
FormBase::setRequestStack public function Sets the request stack object to use.
FormBase::validateForm public function Form validation handler. Overrides FormInterface::validateForm 73
LoggerChannelTrait::$loggerFactory protected property The logger channel factory service.
LoggerChannelTrait::getLogger protected function Gets the logger for a specific channel.
LoggerChannelTrait::setLoggerFactory public function Injects the logger channel factory.
MessengerTrait::$messenger protected property The messenger. 17
MessengerTrait::messenger public function Gets the messenger. 17
MessengerTrait::setMessenger public function Sets the messenger.
RedirectDestinationTrait::$redirectDestination protected property The redirect destination service. 1
RedirectDestinationTrait::getDestinationArray protected function Prepares a &#039;destination&#039; URL query parameter for use with \Drupal\Core\Url.
RedirectDestinationTrait::getRedirectDestination protected function Returns the redirect destination service.
RedirectDestinationTrait::setRedirectDestination public function Sets the redirect destination service.
StringTranslationTrait::$stringTranslation protected property The string translation service. 3
StringTranslationTrait::formatPlural protected function Formats a string containing a count of items.
StringTranslationTrait::getNumberOfPlurals protected function Returns the number of plurals supported by a given language.
StringTranslationTrait::getStringTranslation protected function Gets the string translation service.
StringTranslationTrait::setStringTranslation public function Sets the string translation service to use. 2
StringTranslationTrait::t protected function Translates a string to the current language or to a given language.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.