gbksoft / yii2-multilingual
Multi languages for yii2
Installs: 15
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 3
Forks: 0
Open Issues: 0
Type:yii2-extension
Requires
- yiisoft/yii2: *
Requires (Dev)
This package is not auto-updated.
Last update: 2025-01-18 20:30:17 UTC
README
Start
Скачать composer.
После запустить
php composer.phar require --prefer-dist gbksoft/yii2-multilingual
или добавить в composer.json
"gbksoft/yii2-multilingual": "*"
DB
Languages table
php yii migrate --migrationPath=/path/to/in/yours/project/vendor/gbksoft/yii2-multilingual/src/migrations
Post table
CREATE TABLE `post` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT, `is_active` tinyint(1) unsigned NOT NULL DEFAULT '1', PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci ENGINE=InnoDB
Post translations table
CREATE TABLE `post_translation` ( `post_id` int(10) unsigned NOT NULL, `language_id` int(10) unsigned NOT NULL, `name` varchar(45) NOT NULL, `text` varchar(45) DEFAULT NULL, PRIMARY KEY (`post_id`,`language_id`), KEY `language_id` (`language_id`), CONSTRAINT `fk_post_translation_post` FOREIGN KEY (`post_id`) REFERENCES `post` (`id`) ON DELETE CASCADE ON UPDATE CASCADE, CONSTRAINT `post_translation_ibfk_1` FOREIGN KEY (`language_id`) REFERENCES `language` (`id`) ON DELETE CASCADE ON UPDATE CASCADE ) ENGINE=InnoDB DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci ENGINE=InnoDB
Подключение модуля для редактирования/создания языков
// config.php return [ 'modules' => [ 'language' => [ 'class' => \gbksoft\multilingual\Module::class, ], ] ];
Подключение в entity модель
class Post extends ActiveRecord { /** * @inheritdoc */ public static function tableName() { return '{{%post}}'; } /** * @inheritdoc */ public function behaviors() { return [ 'ml' => [ 'class' => Multilingual::class, 'translationModelName' => PostTranslation::class, 'translationOwnerField' => 'post_id', 'languageField' => 'language_id', ], ]; } }
Модель переводов
/** * Class PostTranslation * * @property integer $post_id * @property integer $language_id * @property string $name * @property string $text */ class PostTranslation extends ActiveRecord { /** * @inheritdoc */ public static function tableName() { return '{{%post_translation}}'; } /** * @inheritdoc */ public function rules() { return [ [['name', 'text', 'post_id', 'language_id'], 'required'], [['post_id', 'language_id'], 'unique', 'targetAttribute' => ['post_id', 'language_id']], [['name', 'text'], 'safe'], ]; } /** * @return \yii\db\ActiveQuery */ public function getPost() { return $this->hasOne(Post::class, ['id' => 'post_id']); } /** * @return \yii\db\ActiveQuery */ public function getLanguage() { return $this->hasOne(Language::class, ['id' => 'language_id']); } }
Использование в котроллере
/* in post array [ 'Post' => [ << model form name ($post->formName()) 'en-EN' => [ 'name' => '999999', 'text' => '9999997777' ], 'ru-RU' => [ 'name' => '777777', 'text' => '8888888' ], ] ] */ $post->saveTranslations(\Yii::$app->request->post()); $post->getTranslation('en-EN')->one(); // en language $post->getTranslation()->one(); // default language (Yii::$app->language) $post->getTranslations()->all(); // all languages