Blame view

common/modules/blog/models/Article.php 4.21 KB
777eb8ff   Yarik   Добален блог v 0....
1
2
3
4
  <?php
  
  namespace common\modules\blog\models;
  
ecf03367   Yarik   TEst
5
  use common\models\ActiveRecordRule;
777eb8ff   Yarik   Добален блог v 0....
6
7
8
9
10
11
12
13
14
  use common\models\Media;
  use common\models\User;
  use common\modules\blog\behaviors\Autocomplete;
  use Yii;
  use yii\db\Query;
  
  /**
   * This is the model class for table "article".
   *
e3105834   Yarik   Стандартизация
15
   * @property integer $article_id
777eb8ff   Yarik   Добален блог v 0....
16
   * @property integer $sort
e3105834   Yarik   Стандартизация
17
18
   * @property string $date_add
   * @property string $date_update
777eb8ff   Yarik   Добален блог v 0....
19
   * @property string $code
e3105834   Yarik   Стандартизация
20
21
22
23
24
25
   * @property integer $user_id
   * @property string $tag
   * @property integer $article_pid
   * @property integer $status
   * @property integer $comment
   * @property integer $vote
777eb8ff   Yarik   Добален блог v 0....
26
27
28
   *
   * @property Article $parent
   * @property Article[] $articles
e3105834   Yarik   Стандартизация
29
   * @property User $user
777eb8ff   Yarik   Добален блог v 0....
30
31
32
33
34
   * @property ArticleLang[] $articleLangs
   * @property ArticleMedia[] $articleMedia
   * @property ArticleToCategory[] $articleToCategories
   * @property Media[] $media
   */
ecf03367   Yarik   TEst
35
  class Article extends ActiveRecordRule
777eb8ff   Yarik   Добален блог v 0....
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
  {
      /**
       * @inheritdoc
       */
      public static function tableName()
      {
          return 'article';
      }
  
      public function behaviors()
      {
          return [
              [
                  'class' => Autocomplete::className(),
                  'attributes' => [
                      'translit' => ['code'],
                  ]
              ]
          ];
      }
      /**
       * @inheritdoc
       */
      public function rules()
      {
          return [
e3105834   Yarik   Стандартизация
62
63
              [['sort', 'article_pid', 'status', 'comment', 'vote'], 'integer'],
              [['date_add', 'date_update'], 'safe'],
777eb8ff   Yarik   Добален блог v 0....
64
              [['code'], 'required'],
e3105834   Yarik   Стандартизация
65
              [['code', 'tag'], 'string']
777eb8ff   Yarik   Добален блог v 0....
66
67
68
69
70
71
72
73
74
          ];
      }
  
      /**
       * @inheritdoc
       */
      public function attributeLabels()
      {
          return [
e3105834   Yarik   Стандартизация
75
              'article_id' => Yii::t('app', 'ID'),
777eb8ff   Yarik   Добален блог v 0....
76
              'sort' => Yii::t('app', 'Sort'),
e3105834   Yarik   Стандартизация
77
78
              'date_add' => Yii::t('app', 'Create At'),
              'date_update' => Yii::t('app', 'Update At'),
777eb8ff   Yarik   Добален блог v 0....
79
              'code' => Yii::t('app', 'Code'),
e3105834   Yarik   Стандартизация
80
81
82
83
84
85
              'user_id' => Yii::t('app', 'Author'),
              'tag' => Yii::t('app', 'Tags'),
              'article_pid' => Yii::t('app', 'Parent ID'),
              'status' => Yii::t('app', 'Active'),
              'comment' => Yii::t('app', 'Comments'),
              'vote' => Yii::t('app', 'Voting'),
777eb8ff   Yarik   Добален блог v 0....
86
87
88
89
90
91
92
93
          ];
      }
  
      /**
       * @return \yii\db\ActiveQuery
       */
      public function getParent()
      {
e3105834   Yarik   Стандартизация
94
          return $this->hasOne(Article::className(), ['article_id' => 'article_pid']);
777eb8ff   Yarik   Добален блог v 0....
95
96
97
98
99
100
101
      }
  
      /**
       * @return \yii\db\ActiveQuery
       */
      public function getArticles()
      {
e3105834   Yarik   Стандартизация
102
          return $this->hasMany(Article::className(), ['article_pid' => 'article_id']);
777eb8ff   Yarik   Добален блог v 0....
103
104
105
106
107
      }
  
      /**
       * @return \yii\db\ActiveQuery
       */
e3105834   Yarik   Стандартизация
108
      public function getUser()
777eb8ff   Yarik   Добален блог v 0....
109
      {
e3105834   Yarik   Стандартизация
110
          return $this->hasOne(User::className(), ['id' => 'user_id']);
777eb8ff   Yarik   Добален блог v 0....
111
112
113
114
115
116
117
      }
  
      /**
       * @return \yii\db\ActiveQuery
       */
      public function getArticleLangs()
      {
e3105834   Yarik   Стандартизация
118
          return $this->hasMany(ArticleLang::className(), ['article_id' => 'article_id']);
777eb8ff   Yarik   Добален блог v 0....
119
120
121
122
123
124
125
      }
  
      /**
       * @return \yii\db\ActiveQuery
       */
      public function getArticleMedia()
      {
e3105834   Yarik   Стандартизация
126
          return $this->hasMany(ArticleMedia::className(), ['article_id' => 'article_id']);
777eb8ff   Yarik   Добален блог v 0....
127
128
129
130
      }
  
      public function getMedia()
      {
e3105834   Yarik   Стандартизация
131
          return $this->hasMany(Media::className(), ['article_id' => 'media_id'])->via('articleMedia');
777eb8ff   Yarik   Добален блог v 0....
132
133
134
135
136
137
      }
      /**
       * @return \yii\db\ActiveQuery
       */
      public function getArticleToCategories()
      {
e3105834   Yarik   Стандартизация
138
          return $this->hasMany(ArticleToCategory::className(), ['article_id' => 'article_id']);
777eb8ff   Yarik   Добален блог v 0....
139
140
141
142
      }
  
      public function getArticleCategories()
      {
e3105834   Yarik   Стандартизация
143
          return $this->hasMany(ArticleCategory::className(), ['article_category_id' => 'article_category_id'])->viaTable('article_to_category', ['article_id' => 'article_category_id']);
777eb8ff   Yarik   Добален блог v 0....
144
145
146
147
148
      }
  
      public static function findArticleDropdown($id)
      {
          $query = new Query();
e3105834   Yarik   Стандартизация
149
          return $query->select(['l.name', 'a.article_id'])
777eb8ff   Yarik   Добален блог v 0....
150
              ->from(['article a'])
e3105834   Yarik   Стандартизация
151
152
153
154
              ->leftJoin(['article_lang l'], 'a.article_id = l.article_id')
              ->where(['l.language_id' => 0, 'a.status' => 1])
              ->andWhere(['not', ['a.article_id' => $id]])
              ->indexBy('article_id')
777eb8ff   Yarik   Добален блог v 0....
155
156
157
158
159
              ->column();
      }
  
      public function getArticleCategoriesArray()
      {
e3105834   Yarik   Стандартизация
160
          return $this->getArticleToCategories()->select('article_category_id')->column();
777eb8ff   Yarik   Добален блог v 0....
161
      }
ecf03367   Yarik   TEst
162
  
777eb8ff   Yarik   Добален блог v 0....
163
  }