Blame view

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