Skip to content

Yii2 behavior for managing many-to-many (M:N) relationships using ActiveRecord with virtual attributes, auto-syncing, and full test coverage.

License

Notifications You must be signed in to change notification settings

jsas4coding/yii2-m2m-behavior

Repository files navigation

Yii2 Many to Many Behavior

PHP 8.1+ Powered by Yii Framework Packagist Version License

Lint Status Static Analysis Tests Status

Security Status Dependabot Coverage

Total Downloads Open Issues Open Pull Requests

A reusable and robust behavior for managing many-to-many (M2M) relationships in Yii2 ActiveRecord using virtual attributes.

๐Ÿงฉ Inspired by the archived yii2tech/ar-linkmany package by Paul Klimov, now extended with modern improvements, full test coverage, and long-term support.


๐Ÿ“ฆ Installation

composer require jonatas-sas/yii2-m2m-behavior

๐Ÿ“š Documentation


๐Ÿš€ Overview

Yii2 Many to Many Behavior helps you:

  • Manage M2M relations using virtual attributes (e.g. tagIds).
  • Automatically sync relations on insert, update, and delete.
  • Control deletion of junction table rows (deleteOnUnlink).
  • Add extra columns to junction records (e.g. timestamps or metadata).
  • Integrate smoothly into ActiveForm, GridView, and DetailView.

๐Ÿ›  Example Usage (PHP 8.1+)

use yii\db\ActiveRecord;
use yii\db\ActiveQuery;
use odara\yii\behaviors\LinkManyToManyBehavior;

/**
 * @property int        $id
 * @property string     $name
 *
 * @property-read Tag[] $tags
 * @property int[]      $tagIds
 */
class Item extends ActiveRecord
{
    /**
     * @inheritdoc
     */
    public function behaviors()
    {
        return [
            'tags' => [
                'class' => LinkManyToManyBehavior::class,
                'relation' => 'tags',
                'referenceAttribute' => 'tagIds',
                'deleteOnUnlink' => true,
                'extraColumns' => [
                    'source' => 'admin',
                    'created_at' => static fn (): int => time(),
                ],
            ],
        ];
    }

    /**
     * Returns the relation between Item and Tag models.
     *
     * @return ActiveQuery
     */
    public function getTags(): ActiveQuery
    {
        return $this->hasMany(Tag::class, ['id' => 'tag_id'])
            ->viaTable('item_tag', ['item_id' => 'id']);
    }
}

Example Form Field

echo $form->field($model, 'tagIds')->checkboxList(
    Tag::find()
        ->select(['name', 'id'])
        ->indexBy('id')
        ->column()
);

๐Ÿค Contributing

Found a bug or want to suggest an improvement?


๐Ÿ›ก License

Yii2 Many to Many Behavior is released under the MIT License.


๐Ÿ’™ Credits

Maintained by the Yii2 community.
Inspired by the Yii2Tech package and rebuilt with care for modern development.


Yii Framework

About

Yii2 behavior for managing many-to-many (M:N) relationships using ActiveRecord with virtual attributes, auto-syncing, and full test coverage.

Topics

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Packages

No packages published

Contributors 2

  •  
  •  

Languages