Transliterator Helper transliterates UTF-8 encoded text to US-ASCII.
The preferred way to install this extension is through composer.
Either run
composer require sbs/yii2-transliterator-helper
or add
"sbs/yii2-transliterator-helper": "*"
to the require section of your application's composer.json
file.
Pass to the method process()
the UTF-8 encoded string you wish to transliterate:
use sbs\helpers\TransliteratorHelper;
// will echo AAAAAAAECEEEEIIIIDNOOOOOUUUUYssaaaaaaaeceeeeiiiidnooooouuuuyy
TransliteratorHelper::process('ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖÙÚÛÜÝßàáâãäåæçèéêëìíîïðñòóôõöùúûüýÿ', 'en'));
You can use it as application behavior:
use sbs\behaviors\SlugBehavior;
//...
public function behaviors()
{
return [
//...
[
'class' => SlugBehavior::class,
'attribute' => 'title',
'slugAttribute' => 'slug',
],
];
}
Configurations:
You need a registration controller in your main config file in section controllerMap
:
use sbs\controllers\TransliterationController;
//...
'controllerMap' => [
'transliteration' => [
'class' => TransliterationController::class,
'lowercase' => false //provides transliteration to lower case, true by default.
]
],
//...
Like a widget:
use sbs\widgets\SlugInput;
echo SlugInput::widget([
'name' => 'News[slug]',
'sourceName' => 'News[title]'
]);
Like an ActiveForm widget:
use sbs\widgets\SlugInput;
echo $form->field($model, 'slug')->widget(SlugInput::class, [
'sourceAttribute' => 'title'
]);
That's all. Enjoy.