@@ 304-331 (lines=28) @@ | ||
301 | * @param bool $sameTerm |
|
302 | * @return array|null|Post |
|
303 | */ |
|
304 | public function getNextPost($sameType = true, $sameTerm = false) |
|
305 | { |
|
306 | /* @var $query \yii\db\ActiveQuery */ |
|
307 | $query = static::find() |
|
308 | ->from(['post' => $this->tableName()]) |
|
309 | ->andWhere(['>', 'post.id', $this->id]) |
|
310 | ->andWhere(['status' => 'publish']) |
|
311 | ->orderBy(['post.id' => SORT_ASC]); |
|
312 | ||
313 | if ($sameType) { |
|
314 | $query->andWhere(['type' => $this->type]); |
|
315 | } |
|
316 | ||
317 | if ($sameTerm) { |
|
318 | $query->innerJoinWith([ |
|
319 | 'terms' => function ($query) { |
|
320 | /* @var $query \yii\db\ActiveQuery */ |
|
321 | $query->from(['term' => Term::tableName()])->andWhere([ |
|
322 | 'IN', |
|
323 | 'term.id', |
|
324 | implode(',', ArrayHelper::getColumn($this->terms, 'id')), |
|
325 | ]); |
|
326 | }, |
|
327 | ]); |
|
328 | } |
|
329 | ||
330 | return $query->one(); |
|
331 | } |
|
332 | ||
333 | /** |
|
334 | * @param bool $sameType |
|
@@ 360-387 (lines=28) @@ | ||
357 | * @param bool $sameTerm |
|
358 | * @return array|null|Post |
|
359 | */ |
|
360 | public function getPrevPost($sameType = true, $sameTerm = false) |
|
361 | { |
|
362 | /* @var $query \yii\db\ActiveQuery */ |
|
363 | $query = static::find() |
|
364 | ->from(['post' => $this->tableName()]) |
|
365 | ->andWhere(['<', 'post.id', $this->id]) |
|
366 | ->andWhere(['status' => 'publish']) |
|
367 | ->orderBy(['post.id' => SORT_DESC]); |
|
368 | ||
369 | if ($sameType) { |
|
370 | $query->andWhere(['type' => $this->type]); |
|
371 | } |
|
372 | ||
373 | if ($sameTerm) { |
|
374 | $query->innerJoinWith([ |
|
375 | 'terms' => function ($query) { |
|
376 | /* @var $query \yii\db\ActiveQuery */ |
|
377 | $query->from(['term' => Term::tableName()])->andWhere([ |
|
378 | 'IN', |
|
379 | 'term.id', |
|
380 | implode(',', ArrayHelper::getColumn($this->terms, 'id')), |
|
381 | ]); |
|
382 | }, |
|
383 | ]); |
|
384 | } |
|
385 | ||
386 | return $query->one(); |
|
387 | } |
|
388 | ||
389 | /** |
|
390 | * @param bool $sameType |