PHPackages                             jakharbek/yii2-datamanager - 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. [Framework](/categories/framework)
4. /
5. jakharbek/yii2-datamanager

ActiveYii2-extension[Framework](/categories/framework)

jakharbek/yii2-datamanager
==========================

yii2 datamanager

0644PHP

Since May 10Pushed 8y agoCompare

[ Source](https://github.com/jakharbek/yii2-datamanager)[ Packagist](https://packagist.org/packages/jakharbek/yii2-datamanager)[ RSS](/packages/jakharbek-yii2-datamanager/feed)WikiDiscussions master Synced yesterday

READMEChangelogDependenciesVersions (1)Used By (0)

Data manager
============

[](#data-manager)

yii2 datamanager

Installation
------------

[](#installation)

The preferred way to install this extension is through [composer](http://getcomposer.org/download/).

Either run

```
php composer.phar require --prefer-dist jakharbek/yii2-datamanager "*"

```

or add

```
"jakharbek/yii2-datamanager": "*"

```

to the require section of your `composer.json` file.

Usage
-----

[](#usage)

Для начало успользованеи данного расширение вам нужно будет настроить все связи перед темь как начать работу.

После в модель которую вы собираетесь использовать применити поведение:

```
jakharbek\datamanager\behaviors\DataModelBehavior
```

Для примера мы будем использовать модель Постов (Posts) и модель Персон (Persons) и сделаем связь между постами и персонами

пример:

```
class Posts{

    private $_personsdata;

    public function behaviors()
    {
        return [
                    'data_persons_model' => [
                        'class' => \jakharbek\datamanager\behaviors\DataModelBehavior::className(),
                        'attribute' => 'personsdata',
                        'relation_name' => 'persons',
                        'relation_model' => new Persons(),
                    ]
                ];

   }

   public function getPersonsdata(){
        return $this->_personsdata;
   }
   public function setPersonsdata($value){
        return $this->_personsdata = $value;
   }
 }
```

Action
------

[](#action)

После того вам нужно подключть "действие" для того что расширение могла узнать где искать данные

```
jakharbek\datamanager\actions\Action
```

свойство

```
 /**
     * @var string имя таблица по который нужно произвести поиск
     */
    public $table = "posts";
    /**
     * @var string имя первичного ключа
     */
    public $primaryColumn = "post_id";
    /**
     * @var string имя поля по которому нужно искать
     */
    public $textColumn = "title";
    /**
     * @var string другие поля который нужно вернуть через пробел как и в SQL
     */
    public $otherColumns = '';
```

пример

```
class Posts{

    public function actions(){
        return [
            'getdata' => [
                'class' => 'jakharbek\datamanager\actions\Action',
                'table' => 'posts',
                'primaryColumn' => 'post_id',
                'textColumn' => 'title'
            ],
        ];
    }

}
```

после того как вы настроили модель вам нужно вывести виджет

- model\_db - имя текушей модели
- name - имя инпута формы.
- attribute - имя атрибута который присваемваться данные
- attribute\_id - имя поля первичного ключа в базе данных связанный таблице
- attribute\_text - имя поля по название в базе данных связанный таблице

```
 echo jakharbek\datamanager\widgets\InputWidget::widget([
                    'model_db' => $model,
                    'name' => 'Posts[personsdata]',
                    'attribute' => 'personsdata',
                    'attribute_id' => 'person_id',
                    'attribute_text' => 'title',
                    'relation_name' => 'persons',
                    'url' => '/posts/posts/getdata/',
            ]);
```

###  Health Score

22

—

LowBetter than 22% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity13

Limited adoption so far

Community6

Small or concentrated contributor base

Maturity41

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.

### Community

Maintainers

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

---

Top Contributors

[![jakharbek](https://avatars.githubusercontent.com/u/31648260?v=4)](https://github.com/jakharbek "jakharbek (2 commits)")

### Embed Badge

![Health badge](/badges/jakharbek-yii2-datamanager/health.svg)

```
[![Health](https://phpackages.com/badges/jakharbek-yii2-datamanager/health.svg)](https://phpackages.com/packages/jakharbek-yii2-datamanager)
```

###  Alternatives

[laravel/telescope

An elegant debug assistant for the Laravel framework.

5.2k67.8M192](/packages/laravel-telescope)[spiral/roadrunner

RoadRunner: High-performance PHP application server and process manager written in Go and powered with plugins

8.4k12.2M84](/packages/spiral-roadrunner)[nolimits4web/swiper

Most modern mobile touch slider and framework with hardware accelerated transitions

41.8k177.2k1](/packages/nolimits4web-swiper)[laravel/dusk

Laravel Dusk provides simple end-to-end testing and browser automation.

1.9k36.7M259](/packages/laravel-dusk)[laravel/prompts

Add beautiful and user-friendly forms to your command-line applications.

708181.8M596](/packages/laravel-prompts)[cakephp/chronos

A simple API extension for DateTime.

1.4k47.7M121](/packages/cakephp-chronos)

PHPackages © 2026

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