DEV Community

Cover image for How to Build a Progressive Web App (PWA) with Angular.
Nitin Rachabathuni
Nitin Rachabathuni

Posted on • Originally published at dev.to

How to Build a Progressive Web App (PWA) with Angular.

Creating a Progressive Web App (PWA) using Angular is an excellent way to ensure that your web application delivers a native-like experience. PWAs are gaining popularity due to their ability to work offline, receive push notifications, and load quickly. In this LinkedIn article, we will discuss how to build a PWA with Angular, complete with coding examples to guide you through the process.

What is a Progressive Web App?
A Progressive Web App (PWA) is a type of application delivered through the web, built using common web technologies including HTML, CSS, and JavaScript. It is intended to work on any platform that uses a standards-compliant browser. PWAs are designed to be fast, engaging, and reliable, regardless of network conditions.

Setting Up Your Angular Environment
To get started, you need to have Angular CLI installed. If you haven't installed Angular CLI yet, you can do so by running:

npm install -g @angular/cli
Enter fullscreen mode Exit fullscreen mode
Next, create a new Angular project:
Enter fullscreen mode Exit fullscreen mode
ng new my-pwa --routing
cd my-pwa

Enter fullscreen mode Exit fullscreen mode

Making Your Angular App a PWA
Angular provides a simple command to add PWA capabilities to your project:

ng add @angular/pwa

Enter fullscreen mode Exit fullscreen mode

This command sets up your project with the necessary service worker and manifest file needed for a PWA.

Configuring the Manifest and Service Worker
The ng add @angular/pwa command creates a manifest.webmanifest file in your project. This file controls how your app appears to the user and defines its appearance at launch. Customize this file to change your app's name, icons, and more.

Angular also configures a basic service worker for you. To further customize it, modify the ngsw-config.json file. This file allows you to specify caching behaviors and define other settings for your service worker.

Implementing an Offline Experience
To improve offline capabilities, use the Angular service worker to cache important files. Here’s an example of how to cache your app's main page and assets:

{
  "index": "/index.html",
  "assetGroups": [{
    "name": "app",
    "installMode": "prefetch",
    "resources": {
      "files": [
        "/favicon.ico",
        "/index.html",
        "/*.css",
        "/*.js"
      ]
    }
  }]
}


Enter fullscreen mode Exit fullscreen mode

Adding Push Notifications
Push notifications can help re-engage users. Implementing push notifications in a PWA with Angular involves using the Web Push API. Here’s a basic setup:

Request Permission: Ask users for permission to send notifications.

Notification.requestPermission().then(permission => {
  if (permission === "granted") {
    console.log("Notification permission granted.");
    // TODO: Display a notification
  }
});
Enter fullscreen mode Exit fullscreen mode

Subscribe to Push Notifications: Use Angular's SwPush service to subscribe to notifications.

import { SwPush } from '@angular/service-worker';

constructor(private swPush: SwPush) {
  if (swPush.isEnabled) {
    swPush.requestSubscription({
      serverPublicKey: 'YOUR_PUBLIC_VAPID_KEY_HERE'
    })
    .then(subscription => {
      // TODO: Send subscription to the server
    })
    .catch(console.error);
  }
}
Enter fullscreen mode Exit fullscreen mode

Testing and Deployment
Before deploying your PWA, test it thoroughly. Use Lighthouse in Chrome DevTools for auditing your app’s performance, accessibility, and PWA metrics.

Deploy your app to a secure server with HTTPS, as service workers require a secure context to function.

Conclusion
Building a PWA with Angular leverages the strength of modern web technologies to deliver a user experience that rivals native applications. By following the steps outlined above, you can create a performant, engaging, and reliable PWA.

By integrating these technologies, you ensure that your web application is not only fast and efficient but also capable of working in various network conditions and on multiple devices, providing a seamless user experience.

Happy coding!


Thank you for reading my article! For more updates and useful information, feel free to connect with me on LinkedIn and follow me on Twitter. I look forward to engaging with more like-minded professionals and sharing valuable insights.

Top comments (0)