protected function ContentEntityForm::initFormLangcodes in Drupal 8
Same name and namespace in other branches
- 9 core/lib/Drupal/Core/Entity/ContentEntityForm.php \Drupal\Core\Entity\ContentEntityForm::initFormLangcodes()
Initializes form language code values.
Parameters
\Drupal\Core\Form\FormStateInterface $form_state: The current state of the form.
3 calls to ContentEntityForm::initFormLangcodes()
- ContentEntityForm::getFormLangcode in core/lib/ Drupal/ Core/ Entity/ ContentEntityForm.php 
- Gets the code identifying the active form language.
- ContentEntityForm::init in core/lib/ Drupal/ Core/ Entity/ ContentEntityForm.php 
- Initializes the form state and the entity before the first form build.
- ContentEntityForm::isDefaultFormLangcode in core/lib/ Drupal/ Core/ Entity/ ContentEntityForm.php 
- Checks whether the current form language matches the entity one.
File
- core/lib/ Drupal/ Core/ Entity/ ContentEntityForm.php, line 300 
Class
- ContentEntityForm
- Entity form variant for content entity types.
Namespace
Drupal\Core\EntityCode
protected function initFormLangcodes(FormStateInterface $form_state) {
  // Store the entity default language to allow checking whether the form is
  // dealing with the original entity or a translation.
  if (!$form_state
    ->has('entity_default_langcode')) {
    $form_state
      ->set('entity_default_langcode', $this->entity
      ->getUntranslated()
      ->language()
      ->getId());
  }
  // This value might have been explicitly populated to work with a particular
  // entity translation. If not we fall back to the most proper language based
  // on contextual information.
  if (!$form_state
    ->has('langcode')) {
    // Imply a 'view' operation to ensure users edit entities in the same
    // language they are displayed. This allows to keep contextual editing
    // working also for multilingual entities.
    $form_state
      ->set('langcode', $this->entityRepository
      ->getTranslationFromContext($this->entity)
      ->language()
      ->getId());
  }
}