<?php
namespace common\modules\registration\models;
use backend\modules\event\models\Event;
use backend\modules\profile\models\Profile;
use backend\modules\registration\models\query\RegEventQuery;
use common\models\User;
use common\modules\registration\Registration;
use Yii;
use yii\behaviors\TimestampBehavior;
use yii\helpers\ArrayHelper;
/**
* This is the model class for table "reg_event".
*
* @property int $id
* @property int $number Номер участника
* @property int $user_id
* @property int $event_id
* @property int $rang_id
* @property int $discipline_id
* @property int $nomination_id
* @property int $category_id
* @property int $status Не оплачено, Оплачено, Отменено
* @property int $visit Посетил, не посетил
* @property int $created_at
* @property int $updated_at
*
* @property RegEventCategory $category
* @property RegEventDiscipline $discipline
* @property Event $event
* @property RegEventNomination $nomination
* @property RegEventRang $rang
* @property Profile $profile
* @property User $user
* @property RegEventPrice $price
* @property RegEventMusic $music
*/
class RegEvent extends \yii\db\ActiveRecord
{
const STATUS_NOT_PAID = 0;
const STATUS_PAID = 1;
const STATUS_CANCEL = 3;
const VISIT_TRUE = 1;
const VISIT_FALSE = 0;
private $messageUniqueValidator = 'Такая регистрация уже существует!';
public $musicFile;
/**
* {@inheritdoc}
*/
public static function tableName()
{
return 'reg_event';
}
/**
* @inheritdoc
*/
public function behaviors()
{
return [
'timestamp' => [
'class' => TimestampBehavior::className(),
],
];
}
/**
* {@inheritdoc}
*/
public function rules()
{
return [
[['user_id', 'visit'], 'required'],
[['number', 'user_id', 'event_id', 'rang_id', 'discipline_id', 'nomination_id', 'category_id', 'receipt_id', 'status'], 'integer'],
[['created_at', 'updated_at'], 'safe'],
[['created_at'], 'default', 'value' => time()], [['visit'], 'default', 'value' => self::VISIT_FALSE],
[['status'], 'default', 'value' => self::STATUS_NOT_PAID],
[['number'], 'default', 'value' => self::setNumber()],
[['event_id'], 'default', 'value' => self::getEventId()],
[['category_id'], 'required', 'skipOnError' => false, 'when' => function (){
return $this->rang_id || $this->discipline_id || $this->nomination_id;
}],
[['nomination_id'], 'required', 'skipOnError' => false, 'when' => function (){
return $this->rang_id || $this->discipline_id;
}],
[['discipline_id'], 'required', 'skipOnError' => false, 'when' => function (){
return $this->rang_id;
}],
[['category_id'], 'required', 'skipOnError' => false, 'when' => function (){
return !$this->rang_id || !$this->discipline_id || !$this->nomination_id;
}],
[['user_id'], 'unique', 'skipOnEmpty' => false, 'targetAttribute' => ['event_id', 'user_id','rang_id', 'discipline_id', 'nomination_id', 'category_id'], 'message' => $this->messageUniqueValidator],
/*[['user_id'], 'unique', 'targetAttribute' => ['event_id', 'discipline_id', 'nomination_id', 'category_id'], 'message' => $this->messageUniqueValidator, 'when' => function (){
return !$this->rang_id;
}],*/
/*[['user_id'], 'unique', 'targetAttribute' => ['event_id', 'user_id', 'nomination_id', 'category_id'], 'message' => $this->messageUniqueValidator, 'when' => function (){
return !$this->rang_id && !$this->discipline_id;
}],
[['user_id'], 'unique', 'targetAttribute' => ['event_id', 'user_id', 'category_id'], 'message' => $this->messageUniqueValidator, 'when' => function (){
return !$this->rang_id && !$this->discipline_id && !$this->nomination_id;
}],*/
[['receipt_id'], 'exist', 'skipOnError' => true, 'targetClass' => RegEventReceipt::className(), 'targetAttribute' => ['receipt_id' => 'id']],
[['category_id'], 'exist', 'skipOnError' => true, 'targetClass' => RegEventCategory::className(), 'targetAttribute' => ['category_id' => 'id']],
[['discipline_id'], 'exist', 'skipOnError' => true, 'targetClass' => RegEventDiscipline::className(), 'targetAttribute' => ['discipline_id' => 'id']],
[['event_id'], 'exist', 'skipOnError' => true, 'targetClass' => Event::className(), 'targetAttribute' => ['event_id' => 'id']],
[['nomination_id'], 'exist', 'skipOnError' => true, 'targetClass' => RegEventNomination::className(), 'targetAttribute' => ['nomination_id' => 'id']],
[['event_id'], 'exist', 'skipOnError' => true, 'targetClass' => RegEventRang::className(), 'targetAttribute' => ['event_id' => 'id']],
[['user_id'], 'exist', 'skipOnError' => true, 'targetClass' => Profile::className(), 'targetAttribute' => ['user_id' => 'user_id']],
[['user_id'], 'exist', 'skipOnError' => true, 'targetClass' => User::className(), 'targetAttribute' => ['user_id' => 'id']],
];
}
/**
* {@inheritdoc}
*/
public function attributeLabels()
{
return [
'id' => Registration::t('reg-event', 'ID'),
'number' => Registration::t('reg-event', 'Number'),
'user_id' => Registration::t('reg-event', 'User ID'),
'profile.fullName' => Registration::t('reg-event', 'User ID'),
'event_id' => Registration::t('reg-event', 'Event ID'),
'event.name' => Registration::t('reg-event', 'Event ID'),
'rang_id' => Registration::t('reg-event', 'Rang ID'),
'rang.shortName' => Registration::t('reg-event', 'Rang ID'),
'discipline_id' => Registration::t('reg-event', 'Discipline ID'),
'discipline.shortName' => Registration::t('reg-event', 'Discipline ID'),
'nomination_id' => Registration::t('reg-event', 'Nomination ID'),
'nomination.shortName' => Registration::t('reg-event', 'Nomination ID'),
'category_id' => Registration::t('reg-event', 'Category ID'),
'category.shortName' => Registration::t('reg-event', 'Category ID'),
'receipt_id' => Registration::t('reg-event', 'Receipt ID'),
'status' => Registration::t('reg-event', 'Status'),
'visit' => Registration::t('reg-event', 'Visit'),
'music' => Registration::t('reg-event', 'Music'),
'price' => Registration::t('reg-event', 'Price'),
'price.cost' => Registration::t('reg-event', 'Price'),
'statusName' => Registration::t('reg-event', 'Status'),
'created_at' => Registration::t('reg-event', 'Created At'),
'updated_at' => Registration::t('reg-event', 'Updated At'),
];
}
/**
* @return \yii\db\ActiveQuery
*/
public function getReceipt()
{
return $this->hasOne(RegEventReceipt::className(), ['id' => 'receipt_id']);
}
/**
* @return \yii\db\ActiveQuery
*/
public function getCategory()
{
return $this->hasOne(RegEventCategory::className(), ['id' => 'category_id']);
}
/**
* @return \yii\db\ActiveQuery
*/
public function getDiscipline()
{
return $this->hasOne(RegEventDiscipline::className(), ['id' => 'discipline_id']);
}
/**
* @return \yii\db\ActiveQuery
*/
public function getEvent()
{
return $this->hasOne(Event::className(), ['id' => 'event_id']);
}
/**
* @return \yii\db\ActiveQuery
*/
public function getNomination()
{
return $this->hasOne(RegEventNomination::className(), ['id' => 'nomination_id']);
}
/**
* @return \yii\db\ActiveQuery
*/
public function getRang()
{
return $this->hasOne(RegEventRang::className(), ['id' => 'rang_id']);
}
/**
* @return \yii\db\ActiveQuery
*/
public function getProfile()
{
return $this->hasOne(Profile::className(), ['user_id' => 'user_id']);
}
/**
* @return \yii\db\ActiveQuery
*/
public function getMusic()
{
return $this->hasOne(RegEventMusic::className(), ['number' => 'number']);
}
/**
* @return \yii\db\ActiveQuery
*/
public function getUser()
{
return $this->hasOne(User::className(), ['id' => 'user_id']);
}
/**
* @return \yii\db\ActiveQuery
*/
public function getPrice()
{
return $this->hasOne(RegEventPrice::className(), ['event_id' => 'event_id'])
->andWhere(['rang_id' => $this->rang_id, 'discipline_id' => $this->discipline_id, 'nomination_id' => $this->nomination_id, ])
->orWhere(['discipline_id' => $this->discipline_id, 'nomination_id' => $this->nomination_id, ]);
}
/**
* {@inheritdoc}
* @return RegEventQuery the active query used by this AR class.
*/
public static function find()
{
return new RegEventQuery(get_called_class());
}
/**
* Статусы для регистрации
* @return array
*/
public static function getStatusList()
{
return [
self::STATUS_NOT_PAID => 'Не оплачено',
self::STATUS_PAID => 'Оплачено',
self::STATUS_CANCEL => 'Отменена'
];
}
/**
* Cтатус регистрации
* @return mixed
*/
public function getStatusName()
{
return ArrayHelper::getValue(self::getStatusList(),$this->status);
}
/**
* Визит для регистрации
* @return array
*/
public static function getVisitList()
{
return [
self::VISIT_TRUE => 'Пришел',
self::VISIT_FALSE => 'Не пришел',
];
}
/**
* Визит регистрации
* @return mixed
*/
public function getVisitName()
{
return ArrayHelper::getValue(self::getVisitList(), $this->visit);
}
/**
* Список цветов для статусов
* @return array
*/
public static function getStatusOptionsList()
{
return [
self::STATUS_NOT_PAID => [
'style' => 'background: #f3d0c9',
'class' => 'danger'
],
self::STATUS_PAID => [
'style' => 'background: #dff0d8',
'class' => 'success'
],
self::STATUS_CANCEL => [
'style' => 'background: #eee; color: #b6b6b6; text-decoration: line-through;',
'class' => 'default'
],
];
}
/**
* @return mixed
*/
public function getStatusOptions()
{
return ArrayHelper::getValue(self::getStatusOptionsList(), $this->status);
}
/**
* Добавить номер
* @return mixed
*/
public static function setNumber()
{
return self::find()->where(['event_id' => self::getEventId()])->max('number') + 1; }
/**
* Получение текущего мероприятия
* @return mixed
*/
public static function getEventId($id = null)
{
return Yii::$app->getModule('registration')->EventSelect->getEventId($id);
}
public function getMusicExists()
{
return $this->music ? true : false ;
}
}
<?php

namespace common\modules\registration\models;

use backend\modules\event\models\Event;
use backend\modules\profile\models\Profile;
use backend\modules\registration\models\query\RegEventQuery;
use common\models\User;
use common\modules\registration\Registration;
use Yii;
use yii\behaviors\TimestampBehavior;
use yii\helpers\ArrayHelper;

/**
 * This is the model class for table "reg_event".
 *
 * @property int $id
 * @property int $number Номер участника
 * @property int $user_id
 * @property int $event_id
 * @property int $rang_id
 * @property int $discipline_id
 * @property int $nomination_id
 * @property int $category_id
 * @property int $status Не оплачено, Оплачено, Отменено
 * @property int $visit Посетил, не посетил
 * @property int $created_at
 * @property int $updated_at
 *
 * @property RegEventCategory $category
 * @property RegEventDiscipline $discipline
 * @property Event $event
 * @property RegEventNomination $nomination
 * @property RegEventRang $rang
 * @property Profile $profile
 * @property User $user
 * @property RegEventPrice $price
 * @property RegEventMusic $music
 */
class RegEvent extends \yii\db\ActiveRecord
{

    const STATUS_NOT_PAID = 0;
    const STATUS_PAID = 1;
    const STATUS_CANCEL = 3;

    const VISIT_TRUE = 1;
    const VISIT_FALSE = 0;

    private $messageUniqueValidator = 'Такая регистрация уже существует!';

    public $musicFile;

    /**
     * {@inheritdoc}
     */
    public static function tableName()
    {
        return 'reg_event';
    }

    /**
     * @inheritdoc
     */
    public function behaviors()
    {
        return [
            'timestamp' => [
                'class' => TimestampBehavior::className(),
            ],
        ];
    }

    /**
     * {@inheritdoc}
     */
    public function rules()
    {
        return [
            [['user_id', 'visit'], 'required'],
            [['number', 'user_id', 'event_id', 'rang_id', 'discipline_id', 'nomination_id', 'category_id', 'receipt_id', 'status'], 'integer'],
            [['created_at', 'updated_at'], 'safe'],

            [['created_at'], 'default', 'value' => time()],
            [['visit'], 'default', 'value' => self::VISIT_FALSE],
            [['status'], 'default', 'value' => self::STATUS_NOT_PAID],

            [['number'], 'default', 'value' => self::setNumber()],
            [['event_id'], 'default', 'value' => self::getEventId()],

            [['category_id'], 'required', 'skipOnError' => false, 'when' => function (){
                return $this->rang_id || $this->discipline_id || $this->nomination_id;
            }],

            [['nomination_id'], 'required', 'skipOnError' => false, 'when' => function (){
                return $this->rang_id || $this->discipline_id;
            }],

            [['discipline_id'], 'required', 'skipOnError' => false, 'when' => function (){
                return $this->rang_id;
            }],

            [['category_id'], 'required', 'skipOnError' => false, 'when' => function (){
                return !$this->rang_id || !$this->discipline_id || !$this->nomination_id;
            }],

            [['user_id'], 'unique',  'skipOnEmpty' => false, 'targetAttribute' => ['event_id', 'user_id','rang_id', 'discipline_id', 'nomination_id', 'category_id'], 'message' => $this->messageUniqueValidator],
            /*[['user_id'], 'unique', 'targetAttribute' => ['event_id', 'discipline_id', 'nomination_id', 'category_id'], 'message' => $this->messageUniqueValidator, 'when' => function (){
                return !$this->rang_id;
            }],*/
            /*[['user_id'], 'unique', 'targetAttribute' => ['event_id', 'user_id', 'nomination_id', 'category_id'], 'message' => $this->messageUniqueValidator, 'when' => function (){
                return !$this->rang_id && !$this->discipline_id;
            }],
            [['user_id'], 'unique', 'targetAttribute' => ['event_id', 'user_id', 'category_id'], 'message' => $this->messageUniqueValidator, 'when' => function (){
                return !$this->rang_id && !$this->discipline_id && !$this->nomination_id;
            }],*/

            [['receipt_id'], 'exist', 'skipOnError' => true, 'targetClass' => RegEventReceipt::className(), 'targetAttribute' => ['receipt_id' => 'id']],
            [['category_id'], 'exist', 'skipOnError' => true, 'targetClass' => RegEventCategory::className(), 'targetAttribute' => ['category_id' => 'id']],
            [['discipline_id'], 'exist', 'skipOnError' => true, 'targetClass' => RegEventDiscipline::className(), 'targetAttribute' => ['discipline_id' => 'id']],
            [['event_id'], 'exist', 'skipOnError' => true, 'targetClass' => Event::className(), 'targetAttribute' => ['event_id' => 'id']],
            [['nomination_id'], 'exist', 'skipOnError' => true, 'targetClass' => RegEventNomination::className(), 'targetAttribute' => ['nomination_id' => 'id']],
            [['event_id'], 'exist', 'skipOnError' => true, 'targetClass' => RegEventRang::className(), 'targetAttribute' => ['event_id' => 'id']],
            [['user_id'], 'exist', 'skipOnError' => true, 'targetClass' => Profile::className(), 'targetAttribute' => ['user_id' => 'user_id']],
            [['user_id'], 'exist', 'skipOnError' => true, 'targetClass' => User::className(), 'targetAttribute' => ['user_id' => 'id']],
        ];
    }

    /**
     * {@inheritdoc}
     */
    public function attributeLabels()
    {
        return [
            'id' => Registration::t('reg-event', 'ID'),
            'number' => Registration::t('reg-event', 'Number'),
            'user_id' => Registration::t('reg-event', 'User ID'),
            'profile.fullName' => Registration::t('reg-event', 'User ID'),
            'event_id' => Registration::t('reg-event', 'Event ID'),
            'event.name' => Registration::t('reg-event', 'Event ID'),
            'rang_id' => Registration::t('reg-event', 'Rang ID'),
            'rang.shortName' => Registration::t('reg-event', 'Rang ID'),
            'discipline_id' => Registration::t('reg-event', 'Discipline ID'),
            'discipline.shortName' => Registration::t('reg-event', 'Discipline ID'),
            'nomination_id' => Registration::t('reg-event', 'Nomination ID'),
            'nomination.shortName' => Registration::t('reg-event', 'Nomination ID'),
            'category_id' => Registration::t('reg-event', 'Category ID'),
            'category.shortName' => Registration::t('reg-event', 'Category ID'),
            'receipt_id' => Registration::t('reg-event', 'Receipt ID'),
            'status' => Registration::t('reg-event', 'Status'),
            'visit' => Registration::t('reg-event', 'Visit'),
            'music' => Registration::t('reg-event', 'Music'),
            'price' => Registration::t('reg-event', 'Price'),
            'price.cost' => Registration::t('reg-event', 'Price'),
            'statusName' => Registration::t('reg-event', 'Status'),
            'created_at' => Registration::t('reg-event', 'Created At'),
            'updated_at' => Registration::t('reg-event', 'Updated At'),
        ];
    }

    /**
     * @return \yii\db\ActiveQuery
     */
    public function getReceipt()
    {
        return $this->hasOne(RegEventReceipt::className(), ['id' => 'receipt_id']);
    }

    /**
     * @return \yii\db\ActiveQuery
     */
    public function getCategory()
    {
        return $this->hasOne(RegEventCategory::className(), ['id' => 'category_id']);
    }

    /**
     * @return \yii\db\ActiveQuery
     */
    public function getDiscipline()
    {
        return $this->hasOne(RegEventDiscipline::className(), ['id' => 'discipline_id']);
    }

    /**
     * @return \yii\db\ActiveQuery
     */
    public function getEvent()
    {
        return $this->hasOne(Event::className(), ['id' => 'event_id']);
    }

    /**
     * @return \yii\db\ActiveQuery
     */
    public function getNomination()
    {
        return $this->hasOne(RegEventNomination::className(), ['id' => 'nomination_id']);
    }

    /**
     * @return \yii\db\ActiveQuery
     */
    public function getRang()
    {
        return $this->hasOne(RegEventRang::className(), ['id' => 'rang_id']);
    }

    /**
     * @return \yii\db\ActiveQuery
     */
    public function getProfile()
    {
        return $this->hasOne(Profile::className(), ['user_id' => 'user_id']);
    }

    /**
     * @return \yii\db\ActiveQuery
     */
    public function getMusic()
    {
        return $this->hasOne(RegEventMusic::className(), ['number' => 'number']);
    }

    /**
     * @return \yii\db\ActiveQuery
     */
    public function getUser()
    {
        return $this->hasOne(User::className(), ['id' => 'user_id']);
    }

    /**
     * @return \yii\db\ActiveQuery
     */
    public function getPrice()
    {
        return $this->hasOne(RegEventPrice::className(), ['event_id' => 'event_id'])
            ->andWhere(['rang_id' => $this->rang_id, 'discipline_id' => $this->discipline_id, 'nomination_id' => $this->nomination_id, ])
            ->orWhere(['discipline_id' => $this->discipline_id, 'nomination_id' => $this->nomination_id, ]);
    }

    /**
     * {@inheritdoc}
     * @return RegEventQuery the active query used by this AR class.
     */
    public static function find()
    {
        return new RegEventQuery(get_called_class());
    }

    /**
     * Статусы для регистрации
     * @return array
     */
    public static function getStatusList()
    {
        return [
            self::STATUS_NOT_PAID => 'Не оплачено',
            self::STATUS_PAID => 'Оплачено',
            self::STATUS_CANCEL => 'Отменена'
        ];
    }

    /**
     * Cтатус регистрации
     * @return mixed
     */
    public function getStatusName()
    {
        return ArrayHelper::getValue(self::getStatusList(),$this->status);
    }

    /**
     * Визит для регистрации
     * @return array
     */
    public static function getVisitList()
    {
        return [
            self::VISIT_TRUE => 'Пришел',
            self::VISIT_FALSE => 'Не пришел',
        ];
    }

    /**
     * Визит регистрации
     * @return mixed
     */
    public function getVisitName()
    {
        return ArrayHelper::getValue(self::getVisitList(), $this->visit);
    }

    /**
     * Список цветов для статусов
     * @return array
     */
    public static function getStatusOptionsList()
    {
        return [
            self::STATUS_NOT_PAID => [
                'style' => 'background: #f3d0c9',
                'class' => 'danger'
            ],
            self::STATUS_PAID => [
                'style' => 'background: #dff0d8',
                'class' => 'success'
            ],
            self::STATUS_CANCEL => [
                'style' => 'background: #eee; color: #b6b6b6; text-decoration: line-through;',
                'class' => 'default'
            ],
        ];
    }

    /**
     * @return mixed
     */
    public function getStatusOptions()
    {
        return ArrayHelper::getValue(self::getStatusOptionsList(), $this->status);
    }

    /**
     * Добавить номер
     * @return mixed
     */
    public static function setNumber()
    {
        return self::find()->where(['event_id' => self::getEventId()])->max('number') + 1;
    }

    /**
     * Получение текущего мероприятия
     * @return mixed
     */
    public static function getEventId($id = null)
    {
        return Yii::$app->getModule('registration')->EventSelect->getEventId($id);
    }

    public function getMusicExists()
    {
        return $this->music ? true : false ;
    }

}
