Я пытаюсь отобразить new label
в своем приложении в зависимости от времени публикации продуктов.
Логика
- Показать ярлык, новый со времени публикации продукта
created_at
до 20
days
после.
Код
Это то, что я делал до сих пор, но не уверен в этом.
$new = Product::where('created_at', '=<', Carbon::now()->subDays(30));
screenshot
этот ярлык должен быть показан только первые 20 дней.
Вопрос
- Как мне сделать
if statement
в моем клинке за $new
?(я имею в виду, я создал @if($new)...@endif
, он не работает) - Мой код правильный?
ОБНОВЛЕНИЕ
my page controller
$products = DB::table('products')
->join('page-views','products.id','=','page-views.visitable_id')
->select(DB::raw('count(visitable_id) as count'),'products.*')
->groupBy('id')
->orderBy('count','desc')
->having('count', '>=', 100)
->get();
PS: я должен добавить, я добавил код ниже Основываясь на ответе Quezler к моей модели, даже на моей обычной коллекции, такой как $products = Product::all();
дает ту же ошибку.
error
Undefined property: stdClass::$new
model
public function getNewAttribute(): boolean
{
return (clone $this->created_at)->addDays(20)->greaterThanOrEqualTo(Carbon::now());
}