Blame view

common/modules/blog/models/ArticleCategory.php 3.67 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\modules\blog\behaviors\Autocomplete;
  use Yii;
  use yii\behaviors\TimestampBehavior;
  use yii\db\ActiveRecord;
  use yii\db\Query;
  
  /**
   * This is the model class for table "article_category".
   *
e3105834   Yarik   Стандартизация
14
15
   * @property integer $article_category_id
   * @property integer $status
777eb8ff   Yarik   Добален блог v 0....
16
17
   * @property integer $sort
   * @property string $code
e3105834   Yarik   Стандартизация
18
19
20
21
   * @property string $date_add
   * @property string $date_update
   * @property string $tag
   * @property integer $artucle_category_pid
777eb8ff   Yarik   Добален блог v 0....
22
23
24
25
26
27
28
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
   *
   * @property Article[] $articles
   * @property ArticleCategory $parent
   * @property ArticleCategory[] $articleCategories
   * @property ArticleCategoryLang[] $articleCategoryLangs
   * @property ArticleCategoryMedia[] $articleCategoryMedia
   */
  class ArticleCategory extends ActiveRecord
  {
      /**
       * @inheritdoc
       */
      public static function tableName()
      {
          return 'article_category';
      }
  
      public function behaviors()
      {
          return [
              [
                  'class' => Autocomplete::className(),
                  'attributes' => [
                      'translit' => ['code'],
                  ]
              ]
          ];
      }
      /**
       * @inheritdoc
       */
      public function rules()
      {
          return [
e3105834   Yarik   Стандартизация
56
              [['status', 'sort', 'article_category_pid'], 'integer'],
777eb8ff   Yarik   Добален блог v 0....
57
              [['code'], 'required'],
e3105834   Yarik   Стандартизация
58
59
60
              [['code', 'tag'], 'string'],
              [['date_add', 'date_update'], 'safe'],
              [['status'], 'boolean'],
777eb8ff   Yarik   Добален блог v 0....
61
62
63
64
65
66
67
68
69
          ];
      }
  
      /**
       * @inheritdoc
       */
      public function attributeLabels()
      {
          return [
e3105834   Yarik   Стандартизация
70
71
              'article_category_id' => Yii::t('app', 'ID'),
              'status' => Yii::t('app', 'Active'),
777eb8ff   Yarik   Добален блог v 0....
72
73
              'sort' => Yii::t('app', 'Sort'),
              'code' => Yii::t('app', 'Code'),
e3105834   Yarik   Стандартизация
74
75
76
77
              'date_add' => Yii::t('app', 'Created At'),
              'date_update' => Yii::t('app', 'Updated At'),
              'tag' => Yii::t('app', 'Tags'),
              'article_category_pid' => Yii::t('app', 'Parent ID'),
777eb8ff   Yarik   Добален блог v 0....
78
79
80
81
82
83
84
85
          ];
      }
  
      /**
       * @return \yii\db\ActiveQuery
       */
      public function getArticles()
      {
e3105834   Yarik   Стандартизация
86
          return $this->hasMany(Article::className(), ['article_id' => 'article_id'])->viaTable('article_to_category', ['article_category_id' => 'article_category_id']) ;
777eb8ff   Yarik   Добален блог v 0....
87
88
89
90
91
92
93
      }
  
      /**
       * @return \yii\db\ActiveQuery
       */
      public function getParent()
      {
e3105834   Yarik   Стандартизация
94
          return $this->hasOne(ArticleCategory::className(), ['article_category_id' => 'article_category_pid']);
777eb8ff   Yarik   Добален блог v 0....
95
96
97
98
99
100
101
      }
  
      /**
       * @return \yii\db\ActiveQuery
       */
      public function getArticleCategories()
      {
e3105834   Yarik   Стандартизация
102
          return $this->hasMany(ArticleCategory::className(), ['article_category_pid' => 'article_category_id']);
777eb8ff   Yarik   Добален блог v 0....
103
104
105
106
107
108
109
      }
  
      /**
       * @return \yii\db\ActiveQuery
       */
      public function getArticleCategoryLangs()
      {
e3105834   Yarik   Стандартизация
110
          return $this->hasMany(ArticleCategoryLang::className(), ['article_category_id' => 'article_category_id']);
777eb8ff   Yarik   Добален блог v 0....
111
112
113
114
115
116
117
      }
  
      /**
       * @return \yii\db\ActiveQuery
       */
      public function getArticleCategoryMedia()
      {
e3105834   Yarik   Стандартизация
118
          return $this->hasMany(ArticleCategoryMedia::className(), ['article_category_id' => 'article_category_id']);
777eb8ff   Yarik   Добален блог v 0....
119
120
121
122
123
      }
  
      public static function findArticleCategoryDropdown($id)
      {
          $query = new Query();
e3105834   Yarik   Стандартизация
124
          return $query->select(['l.name', 'c.article_category_id'])
777eb8ff   Yarik   Добален блог v 0....
125
                          ->from(['article_category c'])
e3105834   Yarik   Стандартизация
126
127
128
129
                          ->leftJoin(['article_category_lang l'], 'c.article_category_id = l.article_category_id')
                          ->where(['l.language_id' => 0, 'c.status' => 1])
                          ->andWhere(['not', ['c.article_category_id' => $id]])
                          ->indexBy('article_category_id')
777eb8ff   Yarik   Добален блог v 0....
130
131
132
133
                          ->column();
      }
  
  }