2017 © Pedro Peláez
 

yii2-extension sortable

Yii2 component to manage items order (sorting)

image

serj/sortable

Yii2 component to manage items order (sorting)

  • Friday, December 15, 2017
  • by __serj
  • Repository
  • 1 Watchers
  • 0 Stars
  • 23 Installations
  • PHP
  • 1 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 6 Versions
  • 0 % Grown

The README.md

Sortable - Yii2 component to maintain sort column in relational database table.

Installation

To import the component to your project, put the following line to the require section of your composer.json file:, (*1)

"serj/sortable": "~1.2.0"

or run the command, (*2)

$ composer require serj/sortable "~1.2.0"

Config

Let's assume a table of the following structure:, (*3)

cartoons

 id |        title        | category_id | sort_local | sort_general | archived | color
----+---------------------+-------------+------------+--------------+----------+-------
  1 | Fiddlesticks        |          14 |       1000 |         7000 | t        | t
  2 | Trolley Troubles,   |          14 |       2000 |         8000 | f        | f
  3 | Fantasmagorie       |          14 |       3000 |         9000 | t        | f
  4 | Winnie the pooh     |          15 |       3000 |         3000 | f        | t
  5 | Kolobok (The loaf)  |          15 |       1000 |         2000 | f        | t
  6 | Hedgehog in the fog |          15 |       2000 |         1000 | f        | t
  7 | South Park          |          16 |       1000 |         4000 | f        | t
  8 | Futurama            |          16 |       2000 |         5000 | f        | t
  9 | Rick and Morty      |          16 |       3000 |         6000 | f        | t

When you want to query items in the sorted order, you must assume that items with lower sort values go first (ASC)., (*4)

To initialize component via app config, with minimal required settings, (*5)

'components' => [
    //...
    'sortableCartoons' => [
        'class' => 'serj\sortable\Sortable',
        'targetTable' => 'cartoons',
        'srtColumn' => 'sort_inner'
    ]
]

Let's look at more interesting scenario. Our table has 2 columns to maintain items order. sort_inner - for sorting in bounds of a category, sort_general - for sorting through out the entire table., (*6)

To maintain both columns we need two instances of the component, each one for its respective column., (*7)

'components' => [
    'sortInSingleCat' => [
        'class' => 'serj\sortable\Sortable',
        'targetTable' => 'cartoons',
        'grpColumn' => 'category_id',
        'pkColumn' => 'id',
        'srtColumn' => 'sort_inner',
        'skipRows' => [
            'archived' => true,
            'color' => false
        ]
    ],
    'sortThroughAllCat' => [
        'class' => 'serj\sortable\Sortable',
        'targetTable' => 'cartoons',
        'pkColumn' => 'id',
        'srtColumn' => 'sort_general',
        'skipRows' => [
            'archived' => true,
            'color' => false
        ]
    ]
]

Or if you want to use it directly without config, (*8)

$sortThroughAllCat = new \serj\sortable\Sortable([
    'targetTable' => 'cartoons',
    'pkColumn' => 'id',
    'srtColumn' => 'sort_general',
    'skipRows' => [
        'archived' => true,
        'color' => false
    ]
]);

Usage

To get sort value for an item to be inserted after id:5, (*9)

$sortValLocal = \Yii::$app->sortInSingleCat->getSortVal(5, 'after', 15);
$sortValGeneral = \Yii::$app->sortThroughAllCat->getSortVal(5, 'after');

To get sort value for an item to be inserted before id:5, (*10)

$sortValLocal = \Yii::$app->sortInSingleCat->getSortVal(5, 'before', 15);
$sortValGeneral = \Yii::$app->sortThroughAllCat->getSortVal(5, 'before');

Then, if you use ActiveRecord, you may insert a new record like this, (*11)

(new Cartoon)->setAttributes([
    'title' => 'Some title',
    'category_id' => 15,
    'sort_local' => $sortValLocal,
    'sort_general' => $sortValGeneral
])->save();

To get sort value for an item to be inserted before all items, (*12)

// 15 is a category_id (srtColumn)
$sortValLocal = \Yii::$app->sortInSingleCat->getSortValBeforeAll(15);
$sortValGeneral = \Yii::$app->sortThroughAllCat->getSortValBeforeAll();

To get sort value for an item to be inserted after all items (in terms of specific category), (*13)

// 15 is a category_id (srtColumn)
$sortValLocal = \Yii::$app->sortableCartoons->getSortValAfterAll(15);
$sortValGeneral = \Yii::$app->sortThroughAllCat->getSortValAfterAll();

If you created a new category, say category_id:17 and there are no items yet, (*14)

$sortValLocal = \Yii::$app->sortableCartoons->getIniSortVal();

//to insert to the end of the list in terms of the entire table
$sortValGeneral = \Yii::$app->sortThroughAllCat->getSortValAfterAll();

If you table have a column or columns representing a state of a record (e.g. deleted, archived) which means you no longer use those records, or you just what to ignore them, you can specify it in the config as skipRows. In this particular case those are archived, color., (*15)

    'skipRows' => [
        'archived' => true,
        'color' => false
    ]

Thus, all tuples that have archived = true and color = false wont be taken in account. There is a gotcha: these states must be persistent, so once set they must not be reverted back. If you switch it back and forth, then do not use this option., (*16)

Alternative database connection

By default the component uses \Yii::$app->db, if you have to use another connection, (*17)

$connection = new \yii\db\Connection($config)
\Yii::$app->sortableCartoons->setDb($connection);

Or set it up in the component config, (*18)

'components' => [
    'anotherDb' => [
        'class' => 'yii\db\Connection',
        ...
    ],
    ...
    'sortInSingleCat' => [
        'class' => 'serj\sortable\Sortable',
        'dbComponentId' => 'anotherDb'
        ...
    ],
    ...
]

Using with MySql database (by default it's Postgres)

'components' => [
    'sortInSingleCat' => [
        'class' => 'serj\sortable\Sortable',
        'databaseDriver' => serj\sortable\Sortable::DB_DRIVER_MYSQL
        ...
    ],
    ...
]

The Versions

15/12 2017

dev-master

9999999-dev

Yii2 component to manage items order (sorting)

  Sources   Download

MIT

The Requires

 

by Sergey Onishchenko

component extension yii2 yii yii 2 sort items order database sort manage sort column

15/12 2017

v1.2.1

1.2.1.0

Yii2 component to manage items order (sorting)

  Sources   Download

MIT

The Requires

 

by Sergey Onishchenko

component extension yii2 yii yii 2 sort items order database sort manage sort column

04/12 2017

v1.2.0

1.2.0.0

Yii2 component to manage items order (sorting)

  Sources   Download

MIT

The Requires

 

by Sergey Onishchenko

component extension yii2 yii yii 2 sort items order database sort namage sort column

01/12 2017

v1.1.0

1.1.0.0

Yii2 component to manage items order (sorting)

  Sources   Download

MIT

The Requires

 

by Sergey Onishchenko

component extension yii2 yii yii 2 sort items order database sort

12/11 2017

v1.0.1

1.0.1.0

Yii2 component to manage items order (sorting)

  Sources   Download

The Requires

  • php >=5.6.4

 

by Sergey Onishchenko

12/11 2017

v1.0.0

1.0.0.0

Yii2 component to manage items order (sorting)

  Sources   Download

The Requires

  • php >=5.6.4

 

by Sergey Onishchenko