kseven / laravel-pwa
A simple and easy-to-use PWA (Progressive Web App) package for Laravel applications.
Requires
- php: >=8.0.0
- illuminate/database: ^8.12|^9.0|^10.0|^11.0
- illuminate/support: ^8.12|^9.0|^10.0|^11.0
- laravel-notification-channels/webpush: ^9.0
README
Laravel PWA is a package designed to seamlessly integrate Progressive Web Application (PWA) functionality into your Laravel projects. With this package, you can easily configure, update the manifest, and register service workers, enabling any Laravel app to function as a PWA.
Features 🚀
- Automatically generate PWA manifest and service worker
- Configurable installation button
- Supports Laravel 8, 9, 10, and 11
- Easy setup and usage
- Compatible with mobile and desktop devices
Important ⚠️
Note: PWAs require a secure HTTPS connection to work correctly. Ensure your application is hosted with HTTPS; otherwise, service workers and other PWA features will not function as expected.
Installation 📦
To get started, install the package using Composer:
composer require kseven/laravel-pwa
Once installed, publish the PWA configuration files using:
php artisan ks:publish-laravel-pwa
This will create the required configuration file config/pwa.php
and set up PWA functionality for your application.
Configuration ⚙️
Main Configuration File: config/pwa.php
This is your main configuration file where you can customize the PWA settings.
return [ 'debug' => env('APP_DEBUG', false), 'vapid_public' => env('VAPID_PUBLIC_KEY', null), 'install-button' => true, // Show or hide install button globally 'manifest' => [ 'name' => 'KSeven PWA', 'short_name' => 'KSPWA', 'description' => 'A Progressive Web Application setup for Laravel projects.', "version" => "0.0.0", 'background_color' => '#000', 'theme_color' => '#F12', "start_url" => "/?source=pwa", "scope" => "/", "display" => "standalone", "display_override" => ["standalone", "fullscreen"], "orientation" => "portrait-primary", "lang" => "pt-BR", "dir" => "ltr", "icons" => [ [ "src" => "/assets/images/96x96.png", "sizes" => "96x96", "type" => "image/png" ], [ "src" => "/assets/images/192x192.png", "sizes" => "192x192", "type" => "image/png" ], [ "src" => "/assets/images/512x512.png", "sizes" => "512x512", "type" => "image/png" ] ], "screenshots" => [ [ "src" => "/assets/images/screanshot1.jpg", "sizes" => "576x1280", "type" => "image/jpeg" ], [ "src" => "/assets/images/screanshot2.jpg", "sizes" => "576x1280", "type" => "image/jpeg" ], [ "src" => "/assets/images/screenshot-wide.jpg", "sizes" => "1365x605", "type" => "image/jpeg", "form_factor" => "wide" ] ], "categories" => ["general"], "shortcuts" => [ [ "name" => "KSeven", "short_name" => "KSeven", "description" => "Seu desenvolvedor...", "url" => "/", "icons" => [ [ "src" => "/assets/images/96x96.png", "sizes" => "96x96", "type" => "image/png" ] ] ] ], "related_applications" => [ [ "platform" => "webapp", "url" => "https://kseven.com.br/" ], [ "platform" => "play", "id" => "com.kseven.app" ] ], "prefer_related_applications" => false, "iarc_rating_id" => "e10+" ], ];
Customizing Manifest File
After changing config/pwa.php
in your manifest
array, run this command
You can update your PWA manifest file by running:
php artisan ks:pwa-update-manifest
This command updates the manifest.json
file located in the public directory of your Laravel project.
Usage 🛠️
To integrate PWA functionality into your layouts, use the provided Blade directives.
1. Add Meta Tags
Place the @PwaHead
directive inside the <head>
tag of your main layout file:
<!DOCTYPE html> <html lang="en"> <head> @PwaHead <!-- Add this directive to include the PWA meta tags --> <title>Your App Title</title> </head> <body>
2. Register Service Worker
Just before the closing </body>
tag in your main layout file, add:
@RegisterServiceWorkerScript <!-- This registers the service worker --> </body> </html>
These directives will automatically generate the necessary tags and JavaScript for the PWA.
Screenshots 📸
Installing PWA App
Offline Page
Contribution 🧑💻
We appreciate your interest in contributing to this Laravel PWA project! Whether you're reporting issues, fixing bugs, or adding new features, your help is greatly appreciated.
Forking and Cloning the Repository
-
Go to the repository page on GitHub.
-
Click the Fork button at the top-right corner of the repository page.
-
Clone your forked repository:
git clone https://github.com/your-username/laravel-pwa.git
Reporting Issues
If you encounter any issues, please check if the issue already exists in the Issues section. If not, create a new issue with the following details:
- Steps to reproduce the issue
- Expected and actual behavior
- Laravel version
- Any relevant logs or screenshots
Submit a Pull Request
When you're ready to contribute, open a pull request describing the changes you’ve made and how they improve the project. Please ensure:
- All commits are squashed into one clean commit.
- The code follows PSR-12 standards.
- You’ve tested the changes locally.
Coding Standards
- Follow the PSR-12 PHP coding standards.
- Keep your commit history clean and meaningful.
- Add comments where needed but avoid over-commenting.
Example Workflow 🌟
Here’s a simple example of how to use this package:
- Install the package via Composer.
- Publish the configuration files.
- Add the
@PwaHead
directive in your layout file’s<head>
. - Add the
@RegisterServiceWorkerScript
directive before the closing</body>
tag. - Customize the
config/pwa.php
to fit your project’s needs. - Run
php artisan ks:pwa-update-manifest
to update the manifest file. - That's it! Your Laravel app is now PWA-enabled. 🚀