class LanguageSwitcherBlock in Open Social 10.0.x
Same name and namespace in other branches
- 8.9 modules/custom/social_language/src/Plugin/Block/LanguageSwitcherBlock.php \Drupal\social_language\Plugin\Block\LanguageSwitcherBlock
- 8.4 modules/custom/social_language/src/Plugin/Block/LanguageSwitcherBlock.php \Drupal\social_language\Plugin\Block\LanguageSwitcherBlock
- 8.5 modules/custom/social_language/src/Plugin/Block/LanguageSwitcherBlock.php \Drupal\social_language\Plugin\Block\LanguageSwitcherBlock
- 8.6 modules/custom/social_language/src/Plugin/Block/LanguageSwitcherBlock.php \Drupal\social_language\Plugin\Block\LanguageSwitcherBlock
- 8.7 modules/custom/social_language/src/Plugin/Block/LanguageSwitcherBlock.php \Drupal\social_language\Plugin\Block\LanguageSwitcherBlock
- 8.8 modules/custom/social_language/src/Plugin/Block/LanguageSwitcherBlock.php \Drupal\social_language\Plugin\Block\LanguageSwitcherBlock
- 10.3.x modules/custom/social_language/src/Plugin/Block/LanguageSwitcherBlock.php \Drupal\social_language\Plugin\Block\LanguageSwitcherBlock
- 10.1.x modules/custom/social_language/src/Plugin/Block/LanguageSwitcherBlock.php \Drupal\social_language\Plugin\Block\LanguageSwitcherBlock
- 10.2.x modules/custom/social_language/src/Plugin/Block/LanguageSwitcherBlock.php \Drupal\social_language\Plugin\Block\LanguageSwitcherBlock
Provides a 'LanguageSwitcherBlock' block.
This replaces the Drupal core language switcher block because that block breaks with the SocialLanguageMetadataBubblingUrlGenerator which is needed to keep users within the same language when viewing content (such as posts) in a language other than their current.
It also customises the look to match that of the Open Social menubar.
Plugin annotation
@Block(
id = "language_switcher_block",
admin_label = @Translation("Language switcher block"),
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
- class \Drupal\Core\Block\BlockBase implements BlockPluginInterface, ContextAwarePluginInterface, PluginWithFormsInterface, PreviewFallbackInterface uses BlockPluginTrait, ContextAwarePluginAssignmentTrait, ContextAwarePluginTrait
- class \Drupal\language\Plugin\Block\LanguageBlock implements ContainerFactoryPluginInterface
- class \Drupal\social_language\Plugin\Block\LanguageSwitcherBlock
- class \Drupal\language\Plugin\Block\LanguageBlock implements ContainerFactoryPluginInterface
- class \Drupal\Core\Block\BlockBase implements BlockPluginInterface, ContextAwarePluginInterface, PluginWithFormsInterface, PreviewFallbackInterface uses BlockPluginTrait, ContextAwarePluginAssignmentTrait, ContextAwarePluginTrait
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
Expanded class hierarchy of LanguageSwitcherBlock
Deprecated
in 8.x will be removed in 9.x.
See also
https://www.drupal.org/project/social/issues/3098046
File
- modules/
custom/ social_language/ src/ Plugin/ Block/ LanguageSwitcherBlock.php, line 26
Namespace
Drupal\social_language\Plugin\BlockView source
class LanguageSwitcherBlock extends LanguageBlock {
/**
* {@inheritdoc}
*/
public function build() {
/** @var \Drupal\Core\Language\Language $currentLanguage */
$currentLanguage = $this->languageManager
->getCurrentLanguage();
// Build the menu.
$block = [
'#attributes' => [
'class' => [
'navbar-user',
],
],
'menu_items' => [
'#theme' => 'item_list',
'#list_type' => 'ul',
'#attributes' => [
'class' => [
'nav',
'navbar-nav',
],
],
'#items' => [],
],
];
// Add `'#icon' => 'language',` to this array to replace the text
// with an icon.
$block['menu_items']['#items']['language'] = [
'#type' => 'account_header_element',
'#title' => $currentLanguage
->getName() . " (" . $currentLanguage
->getId() . ")",
'#label' => $currentLanguage
->getName(),
'#url' => Url::fromRoute('<none>'),
'#wrapper_attributes' => [
'class' => [
'dropdown',
],
],
];
// Generate the routes for the current page.
$route_name = $this->pathMatcher
->isFrontPage() ? '<front>' : '<current>';
$type = $this
->getDerivativeId();
$switchLinks = $this->languageManager
->getLanguageSwitchLinks($type, Url::fromRoute($route_name));
// Use the default URL generator that does not rewrite the language.
$url_generator = \Drupal::service('drupal_core_url_generator');
// Add languages as links.
foreach ($switchLinks->links as $langcode => $link) {
$link['url']
->setOption('language', $this->languageManager
->getLanguage($langcode));
$link['url']
->setUrlGenerator($url_generator);
$block['menu_items']['#items']['language'][$langcode] = [
'#type' => 'link',
'#label' => $link['title'] . " (" . $langcode . ")",
'#title' => $link['title'] . " (" . $langcode . ")",
'#url' => $link['url'],
'#attributes' => [
'class' => [
$langcode === $currentLanguage
->getId() ? 'active' : NULL,
],
],
];
}
return $block;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
BlockBase:: |
public | function |
Form constructor. Overrides PluginFormInterface:: |
2 |
BlockPluginInterface:: |
constant | Indicates the block label (title) should be displayed to end users. | ||
BlockPluginTrait:: |
protected | property | The transliteration service. | |
BlockPluginTrait:: |
public | function | ||
BlockPluginTrait:: |
protected | function | Returns generic default configuration for block plugins. | |
BlockPluginTrait:: |
public | function | 16 | |
BlockPluginTrait:: |
public | function | 13 | |
BlockPluginTrait:: |
public | function | 3 | |
BlockPluginTrait:: |
public | function | Creates a generic configuration form for all block types. Individual block plugins can add elements to this form by overriding BlockBase::blockForm(). Most block plugins should not override this method unless they need to alter the generic form elements. Aliased as: traitBuildConfigurationForm | |
BlockPluginTrait:: |
public | function | ||
BlockPluginTrait:: |
public | function | 19 | |
BlockPluginTrait:: |
public | function | 1 | |
BlockPluginTrait:: |
public | function | 1 | |
BlockPluginTrait:: |
public | function | 3 | |
BlockPluginTrait:: |
public | function | ||
BlockPluginTrait:: |
public | function | ||
BlockPluginTrait:: |
public | function | ||
BlockPluginTrait:: |
public | function | Sets the transliteration service. | |
BlockPluginTrait:: |
public | function | Most block plugins should not override this method. To add submission handling for a specific block type, override BlockBase::blockSubmit(). | |
BlockPluginTrait:: |
protected | function | Wraps the transliteration service. | |
BlockPluginTrait:: |
public | function | Most block plugins should not override this method. To add validation for a specific block type, override BlockBase::blockValidate(). | 1 |
ContextAwarePluginAssignmentTrait:: |
protected | function | Builds a form element for assigning a context to a given slot. | |
ContextAwarePluginAssignmentTrait:: |
protected | function | Wraps the context handler. | |
ContextAwarePluginTrait:: |
protected | property | The data objects representing the context of this plugin. | |
ContextAwarePluginTrait:: |
protected | property | Tracks whether the context has been initialized from configuration. | |
ContextAwarePluginTrait:: |
public | function | 9 | |
ContextAwarePluginTrait:: |
public | function | 4 | |
ContextAwarePluginTrait:: |
public | function | ||
ContextAwarePluginTrait:: |
public | function | ||
ContextAwarePluginTrait:: |
public | function | ||
ContextAwarePluginTrait:: |
public | function | ||
ContextAwarePluginTrait:: |
public | function | ||
ContextAwarePluginTrait:: |
public | function | ||
ContextAwarePluginTrait:: |
public | function | ||
ContextAwarePluginTrait:: |
abstract protected | function | 1 | |
ContextAwarePluginTrait:: |
public | function | 1 | |
ContextAwarePluginTrait:: |
public | function | ||
ContextAwarePluginTrait:: |
public | function | ||
ContextAwarePluginTrait:: |
public | function | ||
DependencySerializationTrait:: |
protected | property | ||
DependencySerializationTrait:: |
protected | property | ||
DependencySerializationTrait:: |
public | function | 2 | |
DependencySerializationTrait:: |
public | function | 2 | |
LanguageBlock:: |
protected | property | The language manager. | |
LanguageBlock:: |
protected | property | The path matcher. | |
LanguageBlock:: |
protected | function |
Indicates whether the block should be shown. Overrides BlockPluginTrait:: |
|
LanguageBlock:: |
public static | function |
Creates an instance of the plugin. Overrides ContainerFactoryPluginInterface:: |
|
LanguageBlock:: |
public | function |
@todo Make cacheable in https://www.drupal.org/node/2232375. Overrides ContextAwarePluginTrait:: |
|
LanguageBlock:: |
public | function |
Constructs a LanguageBlock object. Overrides BlockPluginTrait:: |
|
LanguageSwitcherBlock:: |
public | function |
Builds and returns the renderable array for this block plugin. Overrides LanguageBlock:: |
|
MessengerTrait:: |
protected | property | The messenger. | 27 |
MessengerTrait:: |
public | function | Gets the messenger. | 27 |
MessengerTrait:: |
public | function | Sets the messenger. | |
PluginBase:: |
protected | property | Configuration information passed into the plugin. | 1 |
PluginBase:: |
protected | property | The plugin implementation definition. | 1 |
PluginBase:: |
protected | property | The plugin_id. | |
PluginBase:: |
constant | A string which is used to separate base plugin IDs from the derivative ID. | ||
PluginBase:: |
public | function |
Gets the base_plugin_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the derivative_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface:: |
|
PluginBase:: |
public | function | Determines if the plugin is configurable. | |
PluginWithFormsTrait:: |
public | function | Implements \Drupal\Core\Plugin\PluginWithFormsInterface::getFormClass(). | |
PluginWithFormsTrait:: |
public | function | Implements \Drupal\Core\Plugin\PluginWithFormsInterface::hasFormClass(). | |
StringTranslationTrait:: |
protected | property | The string translation service. | 4 |
StringTranslationTrait:: |
protected | function | Formats a string containing a count of items. | |
StringTranslationTrait:: |
protected | function | Returns the number of plurals supported by a given language. | |
StringTranslationTrait:: |
protected | function | Gets the string translation service. | |
StringTranslationTrait:: |
public | function | Sets the string translation service to use. | 2 |
StringTranslationTrait:: |
protected | function | Translates a string to the current language or to a given language. |