Update to Drupal 8.0.0 beta 14. For more information, see https://drupal.org/node/2544542
This commit is contained in:
parent
3b2511d96d
commit
81ccda77eb
2155 changed files with 54307 additions and 46870 deletions
|
@ -7,11 +7,13 @@
|
|||
|
||||
namespace Drupal\language\EventSubscriber;
|
||||
|
||||
use Drupal\Core\Config\ConfigFactoryInterface;
|
||||
use Drupal\Core\Language\Language;
|
||||
use Drupal\Core\Language\LanguageDefault;
|
||||
use Drupal\Core\Language\LanguageManagerInterface;
|
||||
use Drupal\Core\PhpStorage\PhpStorageFactory;
|
||||
use Drupal\Core\Config\ConfigCrudEvent;
|
||||
use Drupal\Core\Config\ConfigEvents;
|
||||
use Drupal\language\ConfigurableLanguageManager;
|
||||
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
|
||||
|
||||
/**
|
||||
|
@ -33,6 +35,13 @@ class ConfigSubscriber implements EventSubscriberInterface {
|
|||
*/
|
||||
protected $languageDefault;
|
||||
|
||||
/**
|
||||
* The configuration factory.
|
||||
*
|
||||
* @var \Drupal\Core\Config\ConfigFactoryInterface
|
||||
*/
|
||||
protected $configFactory;
|
||||
|
||||
/**
|
||||
* Constructs a new class object.
|
||||
*
|
||||
|
@ -40,31 +49,58 @@ class ConfigSubscriber implements EventSubscriberInterface {
|
|||
* The language manager.
|
||||
* @param \Drupal\Core\Language\LanguageDefault $language_default
|
||||
* The default language.
|
||||
* @param \Drupal\Core\Config\ConfigFactoryInterface $config_factory
|
||||
* The configuration factory.
|
||||
*/
|
||||
public function __construct(LanguageManagerInterface $language_manager, LanguageDefault $language_default) {
|
||||
public function __construct(LanguageManagerInterface $language_manager, LanguageDefault $language_default, ConfigFactoryInterface $config_factory) {
|
||||
$this->languageManager = $language_manager;
|
||||
$this->languageDefault = $language_default;
|
||||
$this->configFactory = $config_factory;
|
||||
}
|
||||
|
||||
/**
|
||||
* Causes the container to be rebuilt on the next request.
|
||||
*
|
||||
* This event subscriber assumes that the new default langcode and old default
|
||||
* langcode are valid langcodes. If the schema definition of either
|
||||
* system.site:default_langcode or language.negotiation::url.prefixes changes
|
||||
* then this event must be changed to work with both the old and new schema
|
||||
* definition so this event is update safe.
|
||||
*
|
||||
* @param ConfigCrudEvent $event
|
||||
* The configuration event.
|
||||
*/
|
||||
public function onConfigSave(ConfigCrudEvent $event) {
|
||||
$saved_config = $event->getConfig();
|
||||
if ($saved_config->getName() == 'system.site' && $event->isChanged('default_langcode')) {
|
||||
$language = $this->languageManager->getLanguage($saved_config->get('default_langcode'));
|
||||
$new_default_langcode = $saved_config->get('default_langcode');
|
||||
$default_language = $this->configFactory->get('language.entity.' . $new_default_langcode);
|
||||
// During an import the language might not exist yet.
|
||||
if ($language) {
|
||||
$this->languageDefault->set($language);
|
||||
if (!$default_language->isNew()) {
|
||||
$this->languageDefault->set(new Language($default_language->get()));
|
||||
$this->languageManager->reset();
|
||||
language_negotiation_url_prefixes_update();
|
||||
|
||||
// Directly update language negotiation settings instead of calling
|
||||
// language_negotiation_url_prefixes_update() to ensure that the code
|
||||
// obeys the hook_update_N() restrictions.
|
||||
$negotiation_config = $this->configFactory->getEditable('language.negotiation');
|
||||
$negotiation_changed = FALSE;
|
||||
$url_prefixes = $negotiation_config->get('url.prefixes');
|
||||
$old_default_langcode = $saved_config->getOriginal('default_langcode');
|
||||
if (empty($url_prefixes[$old_default_langcode])) {
|
||||
$negotiation_config->set('url.prefixes.' . $old_default_langcode, $old_default_langcode);
|
||||
$negotiation_changed = TRUE;
|
||||
}
|
||||
if (empty($url_prefixes[$new_default_langcode])) {
|
||||
$negotiation_config->set('url.prefixes.' . $new_default_langcode, '');
|
||||
$negotiation_changed = TRUE;
|
||||
}
|
||||
if ($negotiation_changed) {
|
||||
$negotiation_config->save(TRUE);
|
||||
}
|
||||
}
|
||||
// Trigger a container rebuild on the next request by deleting compiled
|
||||
// from PHP storage.
|
||||
PhpStorageFactory::get('service_container')->deleteAll();
|
||||
// Trigger a container rebuild on the next request by invalidating it.
|
||||
ConfigurableLanguageManager::rebuildServices();
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Reference in a new issue