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
|
}
}
|