ramiro1982 / livewire-infinite-feed
Livewire infinite scroll feed component
Requires
- livewire/flux: ^1.1
- livewire/livewire: ^3.0
README
A reusable Livewire component that provides infinite scroll functionality for any Eloquent model.
Ideal for feeds, post-listings, news pages, and more.
đ Installation
You can install the package via Composer:
composer require ramiro1982/livewire-infinite-feed:^0.4.2
đ§âđģ Basic Usage
<livewire:infinite-feed model="App\\Models\\Post" item-view="components.post" per-page="10" />
đ ī¸ Required Parameters
model
(string): Fully qualified class name of the Eloquent model.item-view
(string): Blade partial used to render each item in the feed.
When rendering, the component will include your partial like this:
@include($this->itemView, ['post' => $item])
âšī¸ The variable name (e.g., post
) is derived from the model name in lowercase.
âī¸ Optional Parameters
per-page
(int): Number of items per scroll (default: 10)placeholder
(string): View shown as placeholder during lazy loading â requires using thelazy
attributewith
(array): Relationships to eager load
â ī¸ Use the :
prefix in Blade to pass the with parameter as a PHP array:
<livewire:infinite-feed model="App\\Models\\Post" item-view="components.post" :with="['author', 'tags']" />
đŗī¸ Placeholder View
To show a placeholder while the component loads, provide a custom view and use lazy
:
<livewire:infinite-feed model="App\\Models\\Post" item-view="components.post" placeholder="components.feed-placeholder" lazy />
đ§Š Overriding the Default View and Placeholder
To customize the default views, publish them with:
php artisan vendor:publish --tag=views
This will copy the files to:
resources/views/vendor/infinite-feed/feed.blade.php
resources/views/vendor/infinite-feed/placeholder.blade.php
The default view uses Tailwind CSS and Flux UI components.
âī¸ Requirements
This component requires Alpine.js to handle scroll detection.
Via CDN:
<script src="https://unpkg.com/alpinejs" defer></script>
Or via NPM (Vite):
npm install alpinejs
// app.js import Alpine from 'alpinejs' window.Alpine = Alpine Alpine.start()
đ Refreshing the Feed
If your application allows creating new items via another component, you can automatically refresh the feed by dispatching the item-added
event.
đ Created by
Made with đģ and â by Ramiro Rimoldi
đ¤ Contributing
Pull requests and suggestions are welcome! If you find a bug or want to add a feature, feel free to open an issue or PR.
đ License
MIT Š RAMIRO1982