personal_area_php/common/models/Company.php
2024-04-24 18:02:58 +03:00

126 lines
2.8 KiB
PHP
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<?php
namespace common\models;
use Yii;
use yii\behaviors\TimestampBehavior;
use yii\db\Expression;
/**
* This is the model class for table "company".
*
* @property int $id
* @property string $inn
* @property int $user_id
* @property string $name
* @property string|null $address
* @property int|null $created_at
* @property int|null $updated_at
* @property int|null $status
*
* @property Addresses[] $addresses
* @property Check[] $checks
* @property Product[] $products
*/
class Company extends \yii\db\ActiveRecord
{
const STATUS_ACTIVE = 1;
const STATUS_INACTIVE = 0;
/**
* @return string[]
*/
public static function getStatus(): array
{
return [
self::STATUS_ACTIVE => 'Активна',
self::STATUS_INACTIVE => 'Не активна',
];
}
/**
* {@inheritdoc}
*/
public static function tableName()
{
return 'company';
}
public function behaviors()
{
return [
[
'class' => TimestampBehavior::class,
'createdAtAttribute' => 'created_at',
'updatedAtAttribute' => 'updated_at',
'value' => new Expression('NOW()'),
],
];
}
/**
* {@inheritdoc}
*/
public function rules()
{
return [
[['inn', 'name', 'user_id'], 'required'],
[['created_at', 'updated_at'], 'safe'],
[['status', 'user_id'], 'integer'],
[['name', 'address', 'inn'], 'string', 'max' => 255],
];
}
/**
* {@inheritdoc}
*/
public function attributeLabels()
{
return [
'id' => 'ID',
'inn' => 'ИНН',
'name' => 'Название',
'address' => 'Адрес',
'created_at' => 'Дата создания',
'updated_at' => 'Дата редактирования',
'status' => 'Статус',
'user_id' => 'Пользователь',
];
}
/**
* Gets query for [[Addresses]].
*
* @return \yii\db\ActiveQuery
*/
public function getAddresses()
{
return $this->hasMany(Addresses::class, ['company_id' => 'id']);
}
/**
* Gets query for [[Checks]].
*
* @return \yii\db\ActiveQuery
*/
public function getChecks()
{
return $this->hasMany(Check::class, ['company_id' => 'id']);
}
/**
* Gets query for [[Products]].
*
* @return \yii\db\ActiveQuery
*/
public function getProducts()
{
return $this->hasMany(Product::class, ['company_id' => 'id']);
}
public static function getMyCompany()
{
$companies = self::find()->where(['user_id' => Yii::$app->user->id])->all();
}
}