PHPackages                             mountainclans/laravel-polymorphic-model - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Database &amp; ORM](/categories/database)
4. /
5. mountainclans/laravel-polymorphic-model

ActiveLibrary[Database &amp; ORM](/categories/database)

mountainclans/laravel-polymorphic-model
=======================================

Пакет, добавляющий возможность хранить в одной таблице модели разных типов, имеющих общего предка

2.0.0(10mo ago)0211MITPHPPHP ^8.2CI passing

Since Jun 30Pushed 10mo agoCompare

[ Source](https://github.com/mountainclans/laravel-polymorphic-model)[ Packagist](https://packagist.org/packages/mountainclans/laravel-polymorphic-model)[ Docs](https://github.com/mountainclans/laravel-polymorphic-model)[ GitHub Sponsors]()[ RSS](/packages/mountainclans-laravel-polymorphic-model/feed)WikiDiscussions main Synced 3w ago

READMEChangelog (5)Dependencies (8)Versions (5)Used By (1)

Laravel Polymorphic Model
=========================

[](#laravel-polymorphic-model)

Пакет, добавляющий возможность хранить в одной таблице модели разных типов, имеющих общего предка

Установка
---------

[](#установка)

Установите пакет при помощи Composer:

```
composer require mountainclans/laravel-polymorphic-model
```

Использование
-------------

[](#использование)

Добавьте в родительский класс использование трейта `PolymorphicModel` и `public static function allowedTypes(): array`, возвращающий массив допустимых типов классов-наследников.

Также для корректного сохранения модели в той же таблице явно укажите в родителе, какую таблицу он использует.

Убедитесь, что в таблице присутствует поле `type`.

```
use MountainClans\LaravelPolymorphicModel\Traits\PolymorphicModel;

class YourParentModel {
    use PolymorphicModel;

    public const TYPE_TOP_BANNER = 'top_banner';
    public const TYPE_ADVANTAGES = 'advantages';

    protected $table = 'your_parent_model';

    public static function allowedTypes(): array
    {
        return [
            self::TYPE_TOP_BANNER => TopBannerSection::class,
            self::TYPE_ADVANTAGES => AdvantagesSection::class,
        ];
    }
}
```

В классах-наследниках переопределите функцию `getInstanceType`, возвращающую тип:

```
use MountainClans\LaravelPolymorphicModel\Traits\PolymorphicModel;

class TopBannerSection extends YourParentModel{
    protected function getInstanceType(): string
    {
        return static::TYPE_TOP_BANNER;
    }
}
```

Теперь Вы можете создавать класс-наследник напрямую и он будет сохранён в родительской таблице.

```
$model = new TopBannerSection();
...
$model->save();
```

Вы можете извлекать в рамках одного запроса любых наследников основной модели:

```
$collection = YourParentModel::withSubclasses()->get();
```

Или извлекать только модели нужного класса:

```
$collection = TopBannerSection::get();
```

Или указать нужные типы в запросе с использованием where и других конструкций:

```
$collection = YourParentModel::whereIn('type', [
    self::TYPE_TOP_BANNER,
    self::TYPE_ADVANTAGES
])->get()
```

**Количество уровней наследования моделей не ограничено.**

### Атрибут RequiresOverride

[](#атрибут-requiresoverride)

Внутри себя трейт PolymorphicModel использует атрибут `#[RequiresOverride]`.

Вы можете использовать его для того, чтобы явно пометить, какие методы ваших моделей должны быть переопределены в классах-наследниках.

Обязательно объявите в классе использование трейта `CheckOverrides`.

```
use MountainClans\LaravelPolymorphicModel\Traits\CheckOverrides;
use MountainClans\LaravelPolymorphicModel\Attributes\RequiresOverride;

class YourModel extends Model {
    use CheckOverrides;

    #[RequiresOverride]
    public function functionForOverride() {

    }
}
```

Если переопределение не сделано, в момент выполнения метода `boot` модели-наследника будет выброшено исключение `RequiredOverrideNotExistsException`.

Тестирование
------------

[](#тестирование)

```
./vendor/bin/pest --stop-on-error
```

Авторы
------

[](#авторы)

- [Vladimir Bajenov](https://github.com/mountainclans)
- [All Contributors](../../contributors)

Лицензия
--------

[](#лицензия)

The MIT License (MIT). Please see [License File](LICENSE.md) for more information.

###  Health Score

32

—

LowBetter than 69% of packages

Maintenance54

Moderate activity, may be stable

Popularity6

Limited adoption so far

Community8

Small or concentrated contributor base

Maturity52

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~14 days

Total

4

Last Release

313d ago

Major Versions

1.0.2 → 2.0.02025-08-14

### Community

Maintainers

![](https://www.gravatar.com/avatar/d363ad351540061c6f38586e772159863da3cfde29cfbd03c9ff5ba8b6b906aa?d=identicon)[VladimirBazhenov](/maintainers/VladimirBazhenov)

---

Top Contributors

[![VladimirBazhenov](https://avatars.githubusercontent.com/u/44696748?v=4)](https://github.com/VladimirBazhenov "VladimirBazhenov (1 commits)")

---

Tags

laravelMountain Clanslaravel-polymorphic-model

###  Code Quality

TestsPest

Code StyleLaravel Pint

### Embed Badge

![Health badge](/badges/mountainclans-laravel-polymorphic-model/health.svg)

```
[![Health](https://phpackages.com/badges/mountainclans-laravel-polymorphic-model/health.svg)](https://phpackages.com/packages/mountainclans-laravel-polymorphic-model)
```

###  Alternatives

[spatie/laravel-pdf

Create PDFs in Laravel apps

1.0k4.3M42](/packages/spatie-laravel-pdf)[wnx/laravel-backup-restore

A package to restore database backups made with spatie/laravel-backup.

213389.8k2](/packages/wnx-laravel-backup-restore)[spatie/laravel-model-flags

Add flags to Eloquent models

4471.2M4](/packages/spatie-laravel-model-flags)[clickbar/laravel-magellan

This package provides functionality for working with the postgis extension in Laravel.

438834.4k1](/packages/clickbar-laravel-magellan)[rawilk/profile-filament-plugin

Profile &amp; MFA starter kit for filament.

3913.7k](/packages/rawilk-profile-filament-plugin)[lacodix/laravel-model-filter

A Laravel package to filter, search and sort models with ease while fetching from database.

17555.1k](/packages/lacodix-laravel-model-filter)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
