/** * @return News */ private function getVideo() { if (empty($this->video)) { $this->video = News::find()->where(['categoryID' => 49])->orderBy('publishDate DESC')->limit(1)->one(); } return $this->video; }
/** * Creates data provider instance with search query applied * * @param array $params * * @return ActiveDataProvider */ public function search($params) { $query = News::find(); $dataProvider = new ActiveDataProvider(['query' => $query]); $this->load($params); if (!$this->validate()) { // uncomment the following line if you do not want to return any records when validation fails // $query->where('0=1'); return $dataProvider; } $query->andFilterWhere(['id' => $this->id, 'category_id' => $this->category_id, 'created_at' => $this->created_at, 'updated_at' => $this->updated_at]); $query->andFilterWhere(['like', 'title', $this->title])->andFilterWhere(['like', 'description', $this->description])->andFilterWhere(['like', 'content', $this->content]); return $dataProvider; }
/** * Creates data provider instance with search query applied * * @param array $params * * @return ActiveDataProvider */ public function search($params) { $query = News::find(); $dataProvider = new ActiveDataProvider(['query' => $query]); $this->load($params); if (!$this->validate()) { // uncomment the following line if you do not want to return any records when validation fails // $query->where('0=1'); return $dataProvider; } $query->andFilterWhere(['id' => $this->id]); $query->andFilterWhere(['like', 'header', $this->header])->andFilterWhere(['like', 'content', $this->content])->andFilterWhere(['like', 'image', $this->image]); return $dataProvider; }
private function getNews() { $news = News::find(); if ($this->category) { $news->andWhere(['categoryID' => $this->category]); } if ($this->orderBy) { $news->orderBy($this->orderBy); } if ($this->limit) { $news->limit($this->limit); } return $news->with('category')->all(); }
public static function get_news_1() { $options = []; $datas = []; $news_data_r = News::find()->where(['status' => 1])->all(); if (!empty($news_data_r)) { $i = 0; foreach ($news_data_r as $key => $value) { $options[$i]['id'] = $value->id; $options[$i]['title'] = $value->title; $options[$i]['slug'] = $value->slug; $options[$i]['desc'] = $value->desc; $options[$i]['ext_url'] = $value->ext_url; $i++; } } return $options; }
public function getPossibleNews($count, $outcludeIDs = []) { $categoryPossibleNews = ArrayHelper::getColumn(News::find()->select('id')->andWhere(['categoryID' => $this->id])->asArray()->all(), 'id'); $randomNewsCount = ($c = count($categoryPossibleNews)) && $c > $count ? $count * 2 : $c; $randomNews = $randomNewsCount <= 1 ? [0] : array_rand($categoryPossibleNews, $randomNewsCount > $c ? $c : $randomNewsCount); $randomNewsIDs = []; if (!is_array($randomNews)) { $randomNews = [$randomNews]; } foreach ($randomNews as $key) { $randomNewsIDs[] = $categoryPossibleNews[$key]; } if (!empty($outcludeIDs)) { if (!is_array($outcludeIDs)) { $outcludeIDs = [$outcludeIDs]; } $randomNewsIDs = array_diff($randomNewsIDs, $outcludeIDs); } return News::find()->andWhere(['in', 'id', $randomNewsIDs])->with('category')->limit($count)->all(); }
public function search() { $ids = []; $activeDataProvider = new ActiveDataProvider(['sort' => false, 'pagination' => ['pageSize' => 10]]); $solr = new Solr(['rowsCount' => 10000]); $result = $solr->find($this->terms, ['id']); if ($result && ($result = json_decode($result))) { $this->resultsCount = $result->response->numFound; foreach ($result->response->docs as $oneResult) { $ids[] = $oneResult->id; } } $sort = null; $searchQuery = News::find()->where(['in', 'id', $ids]); if ($ids) { switch ($this->order) { case 'newest': $sort = ['defaultOrder' => ['publishDate' => SORT_DESC]]; break; case 'oldest': $sort = ['defaultOrder' => ['publishDate' => SORT_ASC]]; break; case 'popular': $sort = ['defaultOrder' => ['hits' => SORT_DESC]]; break; case 'alphabet': $sort = ['defaultOrder' => ['title' => SORT_ASC]]; break; case 'relative': default: $searchQuery->orderBy(new Expression('FIELD(`id`, ' . implode(', ', $ids) . ')')); break; } } $activeDataProvider->query = $searchQuery; if ($sort) { $activeDataProvider->setSort($sort); } return $activeDataProvider; }
public function actionNews($id, $ignoreLink = false) { $news = News::find()->andWhere(['id' => filter_var($id, FILTER_SANITIZE_NUMBER_INT)])->with('author')->one(); if (!$news) { throw new NotFoundHttpException(); } if ($news->fullLink != \Yii::$app->request->url && !$ignoreLink) { return $this->redirect($news->fullLink, 301); } if (\Yii::$app->request->isAjax) { \Yii::$app->response->format = 'json'; switch (\Yii::$app->request->post('action')) { case 'voteComment': $commentID = \Yii::$app->request->post('commentID'); $comment = Comment::findOne($commentID); if (!$comment) { throw new NotFoundHttpException("Комментарий с идентификатором {$commentID} не найден!"); } $isGood = \Yii::$app->request->post('isGood') == 'true'; if (!empty($comment->myVote) && $comment->myVote->operation == ($isGood ? CommentVote::OPERATION_GOOD : CommentVote::OPERATION_BAD)) { return ['result' => $comment->rating]; } $comment->vote($isGood); $comment = Comment::findOne($commentID); return ['result' => $comment->rating]; break; } } if ($date = \Yii::$app->request->headers->get('If-Modified-Since', 0)) { if ($date = strtotime($date) && ($date >= $news->updated || $date >= $news->publishDate)) { header('HTTP/1.1 304 Not Modified'); die; } } \Yii::$app->response->headers->add('Last-Modified', gmdate('D, d M Y H:i:s', $news->updated ? $news->updated : $news->publishDate) . ' GMT'); if (!preg_match('/(googlebot|google.com\\/bot|yandex(\\w+|)bot|yandex\\.com\\/bots)/im', \Yii::$app->request->userAgent)) { (new Query())->createCommand(\Yii::$app->db)->setSql("UPDATE `news` SET `hits` = `hits` + 1 WHERE `id` = '{$news->id}'")->execute(); NewsViews::addView($news->id); } $commentForm = new CommentForm(); if (\Yii::$app->request->post('CommentForm')) { $commentForm->load(\Yii::$app->request->post()); $commentForm->news = $news; if ($commentForm->save()) { \Yii::$app->session->setFlash('saved', 'Комментарий успешно добавлен!' . ($news->moderatedComments == 1 ? ' Он будет опубликован после проверки модератором.' : '')); $commentForm = new CommentForm(); } } if (!empty($news->category)) { if (!empty($news->category->parentCategory)) { $this->getView()->params['breadcrumbs'][] = ['label' => $news->category->parentCategory->title, 'url' => yii\helpers\Url::toRoute(['/' . $news->category->parentCategory->fullLink], true)]; } $this->getView()->params['breadcrumbs'][] = ['label' => $news->category->title, 'url' => yii\helpers\Url::toRoute(['/' . $news->category->fullLink], true)]; } $today = strtotime(date('Y-m-d')); $interestNews = []; if ($news->category->showPopular) { $interestNews = NewsViews::find()->select('newsID')->where(['date' => $today])->andWhere(['not in', 'newsID', $news->id])->orderBy('views DESC')->limit(5)->asArray()->all(); if (empty($interestNews)) { $interestNews = NewsViews::find()->select('newsID')->where(['date' => $today - 86400])->andWhere(['not in', 'newsID', $news->id])->orderBy('views DESC')->limit(5)->asArray()->all(); } $interestNews = News::find()->andWhere(['in', 'id', ArrayHelper::getColumn($interestNews, 'newsID')])->andWhere(['not in', 'categoryID', '49'])->with('category')->limit(3)->all(); } return $this->render('article', ['article' => $news, 'interest' => $interestNews, 'commentForm' => $commentForm, 'categoryNews' => $news->category->showSimilar ? $news->category->getPossibleNews(3, [$news->id]) : []]); }
<?php $showedNewsIDs = []; foreach ($showedNews as $news) { $showedNewsIDs[] = $news->id; } $lastMonth = time() - 86400 * 30; $newsQuery = \frontend\models\News::find()->with('category')->where(['categoryID' => $category->id])->andWhere(['not in', 'id', $showedNewsIDs])->andWhere("publishDate >= '{$lastMonth}'")->limit('4')->orderBy('hits DESC'); if ($newsModels = $newsQuery->all()) { ?> <div class="items-more"> <h3>Это может быть интересно:</h3> <ol> <?php foreach ($newsModels as $news) { echo \yii\helpers\Html::tag('li', \yii\helpers\Html::a($news->title, \yii\helpers\Url::to($news->fullLink)), ['class' => 'longHeader']); } ?> </ol> </div> <?php }
public static function IdToCategory() { $news = News::find()->where(['category_id' => 3])->one(); //$category = $news->category; var_dump($news); }
public function actionNews() { $model = News::find()->orderBy('created_at DESC')->all(); return $this->render('news', ['model' => $model]); }