PHPackages                             mdmsoft/yii2-format-converter - 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. [Utility &amp; Helpers](/categories/utility)
4. /
5. mdmsoft/yii2-format-converter

ActiveYii2-extension[Utility &amp; Helpers](/categories/utility)

mdmsoft/yii2-format-converter
=============================

Yii2 AR attribute converter

1.2(10y ago)1122.1k↑166.7%10BSD-3-ClausePHP

Since Nov 2Pushed 9y ago3 watchersCompare

[ Source](https://github.com/mdmsoft/yii2-format-converter)[ Packagist](https://packagist.org/packages/mdmsoft/yii2-format-converter)[ RSS](/packages/mdmsoft-yii2-format-converter/feed)WikiDiscussions master Synced 1mo ago

READMEChangelog (3)Dependencies (1)Versions (4)Used By (0)

yii2-format-converter
=====================

[](#yii2-format-converter)

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

[](#installation)

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

Either run

```
php composer.phar require mdmsoft/yii2-format-converter "~1.0"

```

or add

```
"mdmsoft/yii2-format-converter": "~1.0"

```

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

Usage
-----

[](#usage)

Once the extension is installed, simply modify your ActiveRecord class:

DateConverter Behavior
======================

[](#dateconverter-behavior)

Use to convert date format from database format to logical format

```
public function behaviors()
{
    return [
        [
            'class' => 'mdm\converter\DateConverter',
            'type' => 'date', // 'date', 'time', 'datetime'
            'logicalFormat' => 'php:d/m/Y', // default to locale format
            'physicalFormat' => 'php:Y-m-d', // database level format, default to 'Y-m-d'
            'attributes' => [
                'Date' => 'date', // date is original attribute
            ]
        ],
        ...
    ]
}
```

then add attribute `Date` to your model rules.

```
// in view view.php
echo DetailView::widget([
	'options' => ['class' => 'table table-striped detail-view', 'style' => 'padding:0px;'],
	'model' => $model,
	'attributes' => [
		'sales_num',
		'supplier.name',
		'Date', // use attribute 'Date' instead of 'sales_date'
		'nmStatus',
	],
]);

// in view _form.php
echo $form->field($model, 'Date')
	->widget('yii\jui\DatePicker', [
		'options' => ['class' => 'form-control', 'style' => 'width:50%'],
		'dateFormat' => 'php:d/m/Y',
]);
```

RelatedConverter Behavior
=========================

[](#relatedconverter-behavior)

Convert `id` to `name` of related model

```
// attach to model
public function behaviors()
{
    return [
        [
            'class' => 'mdm\converter\RelatedConverter',
            'attributes => [
                'supplierName' => ['supplier', 'name'], // use avaliable relation
                'branchName' => [[Branch::className(), 'id' => 'branch_id'], 'name'], // use classname
            ]
        ],
    ];
}

// usage
$model->supplierName = 'Donquixote Family';
$model->branchName = 'North Blue';

// in form
