Project.php 5.87 KB
<?php

    namespace common\models;

    use Yii;
    use yii\behaviors\BlameableBehavior;
    use yii\behaviors\TimestampBehavior;
    use yii\db\Expression;

    /**
     * This is the model class for table "project".
     * @property integer                 $project_id
     * @property integer                 $user_id
     * @property string                  $name
     * @property string                  $link
     * @property integer                 $project_pid
     * @property string                  $date_add
     * @property string                  $date_end
     * @property integer                 $user_add_id
     * @property double                  $view_count
     * @property string                  $budget
     * @property string                  $city
     * @property string                  $street
     * @property string                  $house
     * @property integer                 $payment_variant
     * @property integer                 $deadline
     * @property string                  $description
     * @property integer                 $contractual
     * @property ProjectPayment[]        $projectPayments
     * @property ProjectSpecialization[] $projectSpecializations
     * @property Specialization[]        $specializations
     */
    class Project extends \yii\db\ActiveRecord
    {

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

        /**
         * @inheritdoc
         */
        public function behaviors()
        {
            return [
                [
                    'class'              => BlameableBehavior::className(),
                    'createdByAttribute' => 'user_id',
                    'updatedByAttribute' => false,
                ],
                [
                    'class'              => TimestampBehavior::className(),
                    'createdAtAttribute' => 'date_add',
                    'updatedAtAttribute' => false,
                    'value'              => new Expression('NOW()'),
                ],
            ];
        }

        /**
         * @inheritdoc
         */
        public function rules()
        {
            return [
                [
                    [ 'name' ],
                    'required',
                ],
                [
                    [
                        'project_pid',
                        'payment_variant',
                        'contractual',
                    ],
                    'integer',
                ],
                [
                    [ 'description' ],
                    'string',
                ],
                [
                    [
                        'name',
                        'link',
                        'budget',
                        'city',
                        'street',
                        'house',
                    ],
                    'string',
                    'max' => 255,
                ],
            ];
        }

        /**
         * @inheritdoc
         */
        public function attributeLabels()
        {
            return [
                'project_id'      => Yii::t('app', 'Project ID'),
                'user_id'         => Yii::t('app', 'User ID'),
                'name'            => Yii::t('app', 'Название'),
                'link'            => Yii::t('app', 'URL'),
                'project_pid'     => Yii::t('app', 'Родительский проект'),
                'date_add'        => Yii::t('app', 'Дата добавления'),
                'date_end'        => Yii::t('app', 'Дата окончания'),
                'user_add_id'     => Yii::t('app', 'User Add ID'),
                'view_count'      => Yii::t('app', 'Количество просмотров'),
                'budget'          => Yii::t('app', 'Бюджет'),
                'city'            => Yii::t('app', 'Город'),
                'street'          => Yii::t('app', 'Улица'),
                'house'           => Yii::t('app', 'Дом'),
                'payment_variant' => Yii::t('app', 'Варианты оплаты'),
                'deadline'        => Yii::t('app', 'Deadline'),
                'description'     => Yii::t('app', 'Описание'),
                'contractual'     => Yii::t('app', 'Договорной'),
            ];
        }

        /**
         * @return \yii\db\ActiveQuery
         */
        public function getProjectPayments()
        {
            return $this->hasMany(ProjectPayment::className(), [ 'project_id' => 'project_id' ]);
        }

        public function getPayments()
        {
            return $this->hasMany(Payment::className(), [ 'payment_id' => 'payment_id' ])
                        ->viaTable('project_specialization', [ 'project_id' => 'project_id' ]);
        }

        /**
         * @return \yii\db\ActiveQuery
         */
        public function getProjectSpecializations()
        {
            return $this->hasMany(ProjectSpecialization::className(), [ 'project_id' => 'project_id' ]);
        }

        public function getSpecializations()
        {
            return $this->hasMany(Specialization::className(), [ 'specialization_id' => 'specialization_id' ])
                        ->viaTable('project_specialization', [ 'project_id' => 'project_id' ]);
        }

        public function getSpecializationInput()
        {
            return $this->getSpecializations()
                        ->asArray()
                        ->column();
        }

        public function setSpecializationInput($value) {
            $this->specializationInput = $value;
        }

        public function getPaymentInput()
        {
            return $this->getPayments()
                        ->asArray()
                        ->column();
        }

        public function setPaymentInput($value) {
            $this->paymentInput = $value;
        }
    }