Yoram Kornatzky
2 min readNov 27, 2020

--

Building a web site for an auction, we wanted an infinite scroll of lots as many lots where expected.

The web application is a Laravel project with Livewire for the views.

The Livewire Component

The list of lots is a Livewire component:

<?php

namespace App\Http\Livewire\Catalogue\Lot;

use Livewire\Component;
use Illuminate\Database\Eloquent\Builder;

use App\Lot;
use App\Auction;

class LotList extends Component
{
public $count;
}

$count tracks the number of lots to show on the screen.

We render the view with:

public function render()
{
return view('livewire.catalogue.lot.lot-list', [
'subdomain' => $this->subdomain,
]);
}

Using the computed property,

public function getLotsProperty()
{
$query = Lot::query();

$lots = $query
->orderBy('updated_at', 'asc')
->take($this->count)
->get();
return $lots;
}

So we take $count items.

The Blade View

We use Tailwind to construct the view,

<div class="flex flex-start flex-wrap items-stretch 
min-w-full mt-2 mb-2">
@foreach($lots as $lot)
<div wire:click="showLot({{ $lot->id }})">

--

--

Yoram Kornatzky
Yoram Kornatzky

Written by Yoram Kornatzky

Entrepreneur, Auctibles: https://auctibles.com, 25 years of development experience, Ph.D. Computer Science

Responses (1)