Code Coverage |
||||||||||
Classes and Traits |
Functions and Methods |
Lines |
||||||||
Total | |
0.00% |
0 / 1 |
|
0.00% |
0 / 7 |
CRAP | |
0.00% |
0 / 101 |
LanguageAddForm | |
0.00% |
0 / 1 |
|
0.00% |
0 / 7 |
210 | |
0.00% |
0 / 101 |
getFormId | |
0.00% |
0 / 1 |
2 | |
0.00% |
0 / 2 |
|||
form | |
0.00% |
0 / 1 |
2 | |
0.00% |
0 / 49 |
|||
save | |
0.00% |
0 / 1 |
6 | |
0.00% |
0 / 9 |
|||
actions | |
0.00% |
0 / 1 |
2 | |
0.00% |
0 / 2 |
|||
validateCustom | |
0.00% |
0 / 1 |
12 | |
0.00% |
0 / 11 |
|||
validatePredefined | |
0.00% |
0 / 1 |
12 | |
0.00% |
0 / 10 |
|||
copyFormValuesToEntity | |
0.00% |
0 / 1 |
12 | |
0.00% |
0 / 18 |
<?php | |
/** | |
* @file | |
* Contains \Drupal\language\Form\LanguageAddForm. | |
*/ | |
namespace Drupal\language\Form; | |
use Drupal\Core\Entity\EntityInterface; | |
use Drupal\Core\Form\FormStateInterface; | |
use Drupal\Core\Language\LanguageManager; | |
use Drupal\language\Entity\ConfigurableLanguage; | |
/** | |
* Controller for language addition forms. | |
*/ | |
class LanguageAddForm extends LanguageFormBase { | |
/** | |
* {@inheritdoc} | |
*/ | |
public function getFormId() { | |
// @todo Remove in favour of base method. | |
return 'language_admin_add_form'; | |
} | |
/** | |
* {@inheritdoc} | |
*/ | |
public function form(array $form, FormStateInterface $form_state) { | |
$form['#title'] = $this->t('Add language'); | |
$predefined_languages = $this->languageManager->getStandardLanguageListWithoutConfigured(); | |
$predefined_languages['custom'] = $this->t('Custom language...'); | |
$predefined_default = $form_state->getValue('predefined_langcode', key($predefined_languages)); | |
$form['predefined_langcode'] = array( | |
'#type' => 'select', | |
'#title' => $this->t('Language name'), | |
'#default_value' => $predefined_default, | |
'#options' => $predefined_languages, | |
); | |
$form['predefined_submit'] = array( | |
'#type' => 'submit', | |
'#value' => $this->t('Add language'), | |
'#name' => 'add_language', | |
'#limit_validation_errors' => array(array('predefined_langcode'), array('predefined_submit')), | |
'#states' => array( | |
'invisible' => array( | |
'select#edit-predefined-langcode' => array('value' => 'custom'), | |
), | |
), | |
'#validate' => array('::validatePredefined'), | |
'#submit' => array('::submitForm', '::save'), | |
'#button_type' => 'primary', | |
); | |
$custom_language_states_conditions = array( | |
'select#edit-predefined-langcode' => array('value' => 'custom'), | |
); | |
$form['custom_language'] = array( | |
'#type' => 'container', | |
'#states' => array( | |
'visible' => $custom_language_states_conditions, | |
), | |
); | |
$this->commonForm($form['custom_language']); | |
$form['custom_language']['langcode']['#states'] = array( | |
'required' => $custom_language_states_conditions, | |
); | |
$form['custom_language']['label']['#states'] = array( | |
'required' => $custom_language_states_conditions, | |
); | |
$form['custom_language']['submit'] = array( | |
'#type' => 'submit', | |
'#value' => $this->t('Add custom language'), | |
'#name' => 'add_custom_language', | |
'#validate' => array('::validateCustom'), | |
'#submit' => array('::submitForm', '::save'), | |
); | |
return $form; | |
} | |
/** | |
* {@inheritdoc} | |
*/ | |
public function save(array $form, FormStateInterface $form_state) { | |
parent::save($form, $form_state); | |
$t_args = array('%language' => $this->entity->label(), '%langcode' => $this->entity->id()); | |
$this->logger('language')->notice('The %language (%langcode) language has been created.', $t_args); | |
drupal_set_message($this->t('The language %language has been created and can now be used.', $t_args)); | |
if ($this->moduleHandler->moduleExists('block')) { | |
// Tell the user they have the option to add a language switcher block | |
// to their theme so they can switch between the languages. | |
drupal_set_message($this->t('Use one of the language switcher blocks to allow site visitors to switch between languages. You can enable these blocks on the <a href=":block-admin">block administration page</a>.', array(':block-admin' => $this->url('block.admin_display')))); | |
} | |
$form_state->setRedirectUrl($this->entity->urlInfo('collection')); | |
} | |
/** | |
* {@inheritdoc} | |
*/ | |
public function actions(array $form, FormStateInterface $form_state) { | |
// No actions needed. | |
return array(); | |
} | |
/** | |
* Validates the language addition form on custom language button. | |
*/ | |
public function validateCustom(array $form, FormStateInterface $form_state) { | |
if ($form_state->getValue('predefined_langcode') == 'custom') { | |
$langcode = $form_state->getValue('langcode'); | |
// Reuse the editing form validation routine if we add a custom language. | |
$this->validateCommon($form['custom_language'], $form_state); | |
if ($language = $this->languageManager->getLanguage($langcode)) { | |
$form_state->setErrorByName('langcode', $this->t('The language %language (%langcode) already exists.', array('%language' => $language->getName(), '%langcode' => $langcode))); | |
} | |
} | |
else { | |
$form_state->setErrorByName('predefined_langcode', $this->t('Use the <em>Add language</em> button to save a predefined language.')); | |
} | |
} | |
/** | |
* Element specific validator for the Add language button. | |
*/ | |
public function validatePredefined($form, FormStateInterface $form_state) { | |
$langcode = $form_state->getValue('predefined_langcode'); | |
if ($langcode == 'custom') { | |
$form_state->setErrorByName('predefined_langcode', $this->t('Fill in the language details and save the language with <em>Add custom language</em>.')); | |
} | |
else { | |
if ($language = $this->languageManager->getLanguage($langcode)) { | |
$form_state->setErrorByName('predefined_langcode', $this->t('The language %language (%langcode) already exists.', array('%language' => $language->getName(), '%langcode' => $langcode))); | |
} | |
} | |
} | |
/** | |
* {@inheritdoc} | |
*/ | |
protected function copyFormValuesToEntity(EntityInterface $entity, array $form, FormStateInterface $form_state) { | |
$langcode = $form_state->getValue('predefined_langcode'); | |
if ($langcode == 'custom') { | |
$langcode = $form_state->getValue('langcode'); | |
$label = $form_state->getValue('label'); | |
$direction = $form_state->getValue('direction'); | |
} | |
else { | |
$standard_languages = LanguageManager::getStandardLanguageList(); | |
$label = $standard_languages[$langcode][0]; | |
$direction = isset($standard_languages[$langcode][2]) ? $standard_languages[$langcode][2] : ConfigurableLanguage::DIRECTION_LTR; | |
} | |
$entity->set('id', $langcode); | |
$entity->set('label', $label); | |
$entity->set('direction', $direction); | |
// There is no weight on the edit form. Fetch all configurable languages | |
// ordered by weight and set the new language to be placed after them. | |
$languages = \Drupal::languageManager()->getLanguages(ConfigurableLanguage::STATE_CONFIGURABLE); | |
$last_language = end($languages); | |
$entity->setWeight($last_language->getWeight() + 1); | |
} | |
} |