ladumor / laravel-pwa
this package used for the make pwa website.
Fund package maintenance!
Requires
- php: >=5.6
- illuminate/support: >=5.4
This package is auto-updated.
Last update: 2026-02-22 04:55:45 UTC
README
Laravel PWA
You can follow this video tutorial as well for installation.
Watch Other Lavavel tutorial here
Installation
Install the package by the following command, (try without --dev if you want to install it on production environment)
composer require --dev ladumor/laravel-pwa
Add Provider
Add the provider to your config/app.php into provider section if using lower version of laravel,
Ladumor\LaravelPwa\PWAServiceProvider::class,
Add Facade
Add the Facade to your config/app.php into aliases section,
'LaravelPwa' => \Ladumor\LaravelPwa\LaravelPwa::class,
Publish the Assets
Run the following command to publish config file,
php artisan laravel-pwa:publish
Configure PWA
Add following code in root blade file in header section.
<!-- PWA -->
@pwaHead
You can also pass custom logo and theme color as arguments:
@pwaHead('custom-logo.png', '#ff0000')
Add following code in root blade file in before close the body.
@laravelPwa
@pwaUpdateNotifier
@pwaInstallButton
Background Sync
This package supports Background Sync, allowing users to queue actions while offline and automatically synchronize them when the connection is restored.
Automatic Form Sync
When a user submits a POST form while offline:
- The submission is intercepted.
- The data is saved locally in IndexedDB.
- A background sync event is registered.
- As soon as the browser detects the connection is restored, the Service Worker automatically retries the queued submissions.
Manual Request Queuing
Developers can also manually queue requests using the global window.laravelPwaSync helper:
const request = new Request('/api/data', { method: 'POST', body: JSON.stringify({ key: 'value' }), headers: { 'Content-Type': 'application/json' } }); if (window.laravelPwaSync) { await window.laravelPwaSync.queue(request); }
Browser Support
Background Sync relies on the Service Worker and SyncManager API. If the browser does not support these features, the application will continue to work as a standard web application without background synchronization.
Smart Install Prompt Manager
This package provides helpers to manage the PWA installation experience effectively.
Detecting Installability
You can check if the app is ready to be installed using window.laravelPwaInstall.canInstall().
if (window.laravelPwaInstall.canInstall()) { console.log('App is ready for installation'); }
Deferring and Triggering Prompts
The package automatically intercepts the beforeinstallprompt event and defers it. You can trigger the prompt manually at a better time (e.g., after a user interaction).
async function myCustomInstallFlow() { const outcome = await window.laravelPwaInstall.showPrompt(); if (outcome === 'accepted') { console.log('User accepted the install prompt'); } }
Tracking Install Events
You can listen for custom events to track the installation process:
window.addEventListener('pwa-installable', (e) => { console.log('PWA is ready to be installed'); }); window.addEventListener('pwa-installed', () => { console.log('PWA was successfully installed'); });
Checking Standalone Mode
Check if the app is currently running in standalone mode (installed):
if (window.laravelPwaInstall.isStandalone()) { console.log('App is running in standalone mode'); }
Splash Screen & Icon Generator
This package includes a tool to automatically generate all required PWA icons and splash screen assets from a single source image.
How to use:
- Place your high-resolution source image (recommended 512x512 or larger) in the
publicdirectory of your Laravel application. - Name the file
pwa-source.png. - Run the publish command:
php artisan laravel-pwa:publish
- The package will automatically generate icons of various sizes (72x72 to 512x512) and update your
manifest.json.
If pwa-source.png is not found, the package will use a default logo to generate the assets.
Smart Versioning & Cache Busting
This package includes a smart versioning system to ensure that your users always have the latest version of your PWA and its assets.
How it works:
- Service Worker Versioning: Every time you run
php artisan laravel-pwa:publish, a new unique version ID is generated and embedded in yoursw.js. This triggers an update in the user's browser. - Manifest & Icon Cache Busting: The
manifest.jsonand all listed icons include version query parameters, ensuring that browsers and devices refresh them when you re-publish. - Blade Directive versioning: The
@laravelPwadirective automatically appends a version timestamp to thesw.js,pwa-install.js, andbackground-sync.jsscript registrations. This forces the browser to check for a new Service Worker file immediately. - Automatic Update Notification: When a new version is detected, the
@pwaUpdateNotifierdirective (if included) will automatically handle theskipWaitingand reload the page to activate the new Service Worker, ensuring a seamless update experience for users.
To update your PWA version and bust all caches, simply run:
php artisan laravel-pwa:publish
Built-in Manifest Generator
Instead of manually editing the manifest.json file, you can use the interactive manifest generator to configure your PWA settings:
php artisan pwa:manifest
This command will prompt you for:
- App Name
- Short Name
- Description
- Start URL
- Theme & Background Colors
- Display Mode (fullscreen, standalone, etc.)
- Orientation
After running this command, remember to run php artisan laravel-pwa:publish to apply the changes to your public directory.
Debug & Dev Tools
This package includes a set of developer-friendly tools to help you debug your PWA implementation.
Artisan Command
Run the following command to see debugging tips:
php artisan pwa:debug
On-Screen Debug Helper
Add the @pwaDebug directive to your blade file (ideally only in development). It will only load if APP_DEBUG=true in your .env.
@pwaDebug
This directive injects a global window.laravelPwaDebug object into your browser console with the following utilities:
| Method | Description |
|---|---|
laravelPwaDebug.viewCaches() |
List all PWA caches and their current contents. |
laravelPwaDebug.clearCaches() |
Clear all PWA-related caches. |
laravelPwaDebug.forceUpdate() |
Force a Service Worker update check. |
laravelPwaDebug.unregister() |
Unregister all Service Workers for the domain. |
laravelPwaDebug.help() |
Show available debug commands. |
Service Worker Logging
The Service Worker now includes basic lifecycle logging (Installing, Activated) to help you track its state in the browser console.
License
The MIT License (MIT). Please see License File for more information
Note
PWA only works with https. so, you need to run either with php artisan serve or create a virtual host with https.
you can watch the video for how to create a virtual host with HTTPS