cetver / yii2-language-selector
Provides the configuration for the language selector for the Yii framework 2.0
Installs: 91 632
Dependents: 0
Suggesters: 0
Security: 0
Stars: 7
Watchers: 1
Forks: 0
Open Issues: 1
Type:yii2-extension
Requires
- yiisoft/yii2: ^2.0.13
Requires (Dev)
- codeception/base: ^2.2.3
- codeception/specify: ~0.4.3
- codeception/verify: ~0.3.1
- satooshi/php-coveralls: ^1.0
This package is auto-updated.
Last update: 2025-02-16 04:49:26 UTC
README
Provides the configuration for the language selector
Installation
The preferred way to install this extension is through composer.
Either run
composer require --prefer-dist cetver/yii2-language-selector
or add
"cetver/yii2-language-selector": "^1.0"
to the require section of your composer.json
file.
Usage
Bootstrap Nav
Yii::$app->language = 'en'; $languageItem = new cetver\LanguageSelector\items\DropDownLanguageItem([ 'languages' => [ 'en' => '<span class="flag-icon flag-icon-us"></span> English', 'ru' => '<span class="flag-icon flag-icon-ru"></span> Russian', 'de' => '<span class="flag-icon flag-icon-de"></span> Deutsch', ], 'options' => ['encode' => false], ]); \yii\bootstrap\NavBar::begin([ 'brandLabel' => 'My Company', 'brandUrl' => Yii::$app->homeUrl, ]); echo \yii\bootstrap\Nav::widget([ 'options' => ['class' => 'navbar-nav navbar-right'], 'items' => [ ['label' => 'Home', 'url' => ['/site/index']], ['label' => 'About', 'url' => ['/site/about']], $languageItem->toArray() ] ]); \yii\bootstrap\NavBar::end();
Bootstrap Drop-Down Button
Yii::$app->language = 'en'; $languageItem = new cetver\LanguageSelector\items\DropDownLanguageItem([ 'languages' => [ 'en' => '<span class="flag-icon flag-icon-us"></span> English', 'ru' => '<span class="flag-icon flag-icon-ru"></span> Russian', 'de' => '<span class="flag-icon flag-icon-de"></span> Deutsch', ], 'options' => ['encode' => false], ]); $languageItem = $languageItem->toArray(); $languageDropdownItems = \yii\helpers\ArrayHelper::remove($languageItem, 'items'); echo \yii\bootstrap\ButtonDropdown::widget([ 'label' => $languageItem['label'], 'encodeLabel' => false, 'options' => ['class' => 'btn-default'], 'dropdown' => [ 'items' => $languageDropdownItems ] ]);
Menu
$languageItems = new cetver\LanguageSelector\items\MenuLanguageItems([ 'languages' => [ 'en' => '<span class="flag-icon flag-icon-us"></span> English', 'ru' => '<span class="flag-icon flag-icon-ru"></span> Russian', 'de' => '<span class="flag-icon flag-icon-de"></span> Deutsch', ], 'options' => ['encode' => false], ]); echo \yii\widgets\Menu::widget([ 'options' => ['class' => 'list-inline'], 'items' => $languageItems->toArray(), ]);
Configuration
Drop-Down
new cetver\LanguageSelector\items\DropDownLanguageItem([ // the list of available languages 'languages' => [ 'en' => 'English', 'ru' => 'Russian', 'de' => 'Deutsch', ], /* or 'languages' => function () { return \app\models\Language::find() ->select(['code', 'name']) ->createCommand() ->queryAll(\PDO::FETCH_KEY_PAIR); }, */ // the drop-down widget item options, excluding "label" and "url" // @see \yii\bootstrap\Nav::$items // @see \yii\bootstrap\Dropdown::$items 'options' => [ 'visible' => true ] ]);
Menu
new cetver\LanguageSelector\items\MenuLanguageItems([ // the list of available languages 'languages' => [ 'en' => 'English', 'ru' => 'Russian', 'de' => 'Deutsch', ], /* or 'languages' => function () { return \app\models\Language::find() ->select(['code', 'name']) ->createCommand() ->queryAll(\PDO::FETCH_KEY_PAIR); }, */ // the menu widget item options, excluding "label", "url" and "active" // @see \yii\widgets\Menu::$items 'options' => [ 'visible' => true ] ]);
Tests
Run the following commands
composer create-project --prefer-source cetver/yii2-language-selector
cd yii2-language-selector
vendor/bin/codecept run unit
For I18N support, take a look at
- https://github.com/cetver/yii2-languages-dispatcher - Sets the web-application language
- https://github.com/cetver/yii2-language-url-manager - Parses and creates URLs containing languages
- https://github.com/cetver/yii2-language-selector - Provides the configuration for the language selector
- https://github.com/creocoder/yii2-translateable - The translatable behavior (Active Record)