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