Capacitor Full App - Ionic Angular
  • What is Capacitor Full App - Ionic Angular?
  • Understand the Frameworks
  • Template Highlights
  • Setup
    • Initial Setup
  • Running the app
  • Building App on device
  • Deploying app as PWA
    • Deploy PWA on Firebase
  • How to use this template
    • Two way to use this Template
  • Removing a Page / Component
  • Removing a plugin
  • Extra
    • Troubleshooting
    • FAQ
  • Changelog
  • Features
    • Startup Features
      • Layouts
      • Firebase
      • Addons
        • Globalization - Translation
        • Content Loaders
        • Custom Fonts
        • Infinite Scroll
        • Pull to Refresh
        • List Re-ordering
        • Date Time Pickers
        • Settings
      • Login & Signups
      • Sidemenu Layouts
      • Wordpress
        • How to integrate
      • Video Playlist
      • Grid and List Layouts
      • Chat Lists & Chat Pages
    • Pro Features
      • Pro Addons
        • AdMob
          • Integration
          • Setting up Google Admob
        • Music Player
        • Push Notifications
        • Local Notifications
        • Device
        • Clipboard
        • Social Login
        • In-App Browser
        • Sweet Alerts
        • Social Sharing
        • Google Places
        • Google Autocomplete
        • Image Cropper
      • Phaser Game Framework
      • WooCommerce
      • Payment Gateways
    • Others
      • Adding Icon and Splash
Powered by GitBook
On this page
  • Required Dependencies
  • Building the App & Adding Platforms
  • Using the Capacitor Push Notification API
  • Creating a Project for your App on Firebase
  • Android
  • Integrating Firebase with the Android app
  • Download and Use thegoogle-services.jsonfile
  • iOS
  • Prerequisites
  • Integrating Firebase with our native iOS app
  • Add theGoogleService-Info.plistfile to your iOS app
  • Add the Firebase SDK via CocoaPods
  • Update the Project
  • Add Initialization Code
  • Upload the APNS Certificate or Key to Firebase
  • Sending a Test Notification

Was this helpful?

  1. Features
  2. Pro Features
  3. Pro Addons

Push Notifications

The feature integration is taken from Ionic Framework's official documentation

PreviousMusic PlayerNextLocal Notifications

Last updated 5 years ago

Was this helpful?

The feature integration is taken from Ionic Framework's

One of the most common features provided by application developers to their users is push notifications. In this tutorial, we'll walk through all the steps needed to get working on iOS and Android.

For the purposes of registering and monitoring for push notifications from Firebase, we'll make use of the in an Ionic + Angular application.

Required Dependencies

Building and deploying iOS and Android applications using Capacitor requires a bit of setup. Please before continuing.

To test push notifications on iOS, Apple requires that you have and a physical iOS device.

Building the App & Adding Platforms

Before adding any native platforms to this project, the app must be built at least once. A web build creates the web assets directory that Capacitor needs (www folder in Ionic projects).

ionic build

Next, let's add the iOS and Android platforms to our app.

npx cap add ios
npx cap add android

Upon running these commands, both android and ios folders at the root of the project are created. These are entirely separate native project artifacts that should be considered part of your Ionic app (i.e., check them into source control).

Using the Capacitor Push Notification API

Before we get to Firebase, we'll need to ensure that our application can register for push notifications by making use of the Capacitor Push Notification API. We'll also add an alert (you could use console.log statements instead) to show us the payload for a notification when it arrives and the app is open on our device.

In your app, head to the home.page.ts file and add an import statement and a const to make use of the Capacitor Push API:

import {
  Plugins,
  PushNotification,
  PushNotificationToken,
  PushNotificationActionPerformed } from '@capacitor/core';

const { PushNotifications } = Plugins;

Then, add the ngOnInit() method with some API methods to register and monitor for push notifications. We will also add an alert() a few of the events to monitor what is happening:

export class HomePage implements OnInit {

ngOnInit() {
    console.log('Initializing HomePage');

    // Register with Apple / Google to receive push via APNS/FCM
    PushNotifications.register();

    // On success, we should be able to receive notifications
    PushNotifications.addListener('registration', 
      (token: PushNotificationToken) => {
        alert('Push registration success, token: ' + token.value);
      }
    );

    // Some issue with our setup and push will not work
    PushNotifications.addListener('registrationError', 
      (error: any) => {
        alert('Error on registration: ' + JSON.stringify(error));
      }
    );

    // Show us the notification payload if the app is open on our device
    PushNotifications.addListener('pushNotificationReceived', 
      (notification: PushNotification) => {
        alert('Push received: ' + JSON.stringify(notification));
      }
    );

    // Method called when tapping on a notification
    PushNotifications.addListener('pushNotificationActionPerformed', 
      (notification: PushNotificationActionPerformed) => {
        alert('Push action performed: ' + JSON.stringify(notification));
      }
    );
}

Here is the full implementation of home.page.ts:

import { Component, OnInit } from '@angular/core';

import {
  Plugins,
  PushNotification,
  PushNotificationToken,
  PushNotificationActionPerformed } from '@capacitor/core';

const { PushNotifications } = Plugins;

@Component({
  selector: 'app-home',
  templateUrl: 'home.page.html',
  styleUrls: ['home.page.scss'],
})

export class HomePage implements OnInit {

  ngOnInit() {
    console.log('Initializing HomePage');

    PushNotifications.register();

    PushNotifications.addListener('registration', 
      (token: PushNotificationToken) => {
        alert('Push registration success, token: ' + token.value);
      }
    );

    PushNotifications.addListener('registrationError', 
      (error: any) => {
        alert('Error on registration: ' + JSON.stringify(error));
      }
    );

    PushNotifications.addListener('pushNotificationReceived', 
      (notification: PushNotification) => {
        alert('Push received: ' + JSON.stringify(notification));
      }
    );

    PushNotifications.addListener('pushNotificationActionPerformed', 
      (notification: PushNotificationActionPerformed) => {
        alert('Push action performed: ' + JSON.stringify(notification));
      }
    );
}

Creating a Project for your App on Firebase

Before we can connect Firebase Cloud Messaging to your application and send push notifications, you'll need to start a project in Firebase.

Name the project, accept the Firebase ToS and click Create project to continue. A Project ID should be automatically generated for you.

Android

Integrating Firebase with the Android app

Go to the Project Overview page for your Firebase project and, under the Grow section, click the Cloud Messaging option. At the top, click on the Android icon.

The next screen will ask you for some information about your application.

  • Your Android package name should match the appId from your capacitor.config.json file

  • We used com.mydomain.myappname for this Capacitor app ID, so that is what we'll use for this entry.

  • Nickname and Debug Signing Certificate are optional

Then click the Register app button.

Download and Use thegoogle-services.jsonfile

The next prompt will ask you to download a google-services.json file. This file contains the information your Capacitor app needs to connect to Firebase from Android.

Download the google-services.json file to your local machine. Then move the file into your Capacitor Android project directory, specifically under android/app/.

We don't need to add any dependencies to our project because Capacitor projects automatically include a version of firebase-messaging in it's build.gradle file.

iOS

Prerequisites

Integrating Firebase with our native iOS app

This part is very similar to the Android section above, with a few key differences.

First, go to the Project Overview page for your Firebase project. If you've been following this guide, you'll already have an Android application listed at the top of the page.

To add iOS to your Firebase project, click the Add App button and select the iOS platform.

The next screen will ask you for some information about your application.

  • Your iOS bundle ID should match the appId from your capacitor.config.json file

  • We used com.mydomain.myappname for this Capacitor app ID, so that is what we'll use for this entry.

  • App Nickname and App Store ID are optional

Then click the Register app button.

Add theGoogleService-Info.plistfile to your iOS app

Note: This is not the same file used for your Android app.

Download the GoogleService-Info.plist provided to your local machine.

You'll then want to open Xcode...

npx cap open ios

... and move the .plist file into your Xcode project as instructed by Firebase, ensuring to add it to all targets.

Add the Firebase SDK via CocoaPods

The Push Notification API on iOS makes use of CocoaPods - an iOS dependency management system - and we need to tell CocoaPods to make use of Firebase.

To do this, we need to modify the Podfile, which can be found in Xcode under Pods:

We need to add Firebase to the CocoaPods provided for our App target. To do that, add pod Firebase/Messaging to your target 'App' section, like so:

target 'App' do
capacitor_pods
# Add your Pods here
pod 'Firebase/Messaging' # Add this line
end

Your Podfile should look something like this:

platform :ios, '11.0'
use_frameworks!

# workaround to avoid Xcode 10 caching of Pods that requires
# Product -> Clean Build Folder after new Cordova plugins installed
# Requires CocoaPods 1.6 or newer
install! 'cocoapods', :disable_input_output_paths => true

def capacitor_pods
  # Automatic Capacitor Pod dependencies, do not delete
  pod 'Capacitor', :path => '../../node_modules/@capacitor/ios'
  pod 'CapacitorCordova', :path => '../../node_modules/@capacitor/ios'

  # Do not delete
end

target 'App' do
  capacitor_pods
  # Add your Pods here
  pod 'Firebase/Messaging'
end

Update the Project

Now we'll need to ensure that our iOS project is updated with the proper Firebase CocoaPod installed.

Note: This part can take a while as CocoaPods needs to download all the appropriate files/dependencies.

npx cap update ios

Add Initialization Code

To connect to Firebase when your iOS app starts up, you need to add the following to your AppDelegate.swift file.

First, add an import at the top of the file:

import Firebase

... and then add the configuration method for Firebase to initialization code to your AppDelegate.swift file, in the application(didFinishLaunchingWithOptions) method.

FirebaseApp.configure()

Your completed AppDelegate.swift file should look something like this:

import UIKit
import Capacitor
import Firebase

@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {

  var window: UIWindow?


  func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
    // Override point for customization after application launch.
    FirebaseApp.configure()
    return true
  }

Upload the APNS Certificate or Key to Firebase

If you followed the instructions from the beginning, you'll have created an Apple APNS Certificate or an APNS Auth Key in the Apple Developer portal. You need to upload one of these to Firebase before Firebase can talk to APNS and send push notifications to your application.

To upload your certificate or auth key, from the Project Overview page:

  1. Click on your iOS application and then the Settings gear icon.

  2. On the Settings page, click on the Cloud Messaging tab.

  3. Under the iOS app configuration header, upload your Auth Key or Certificate(s) using the provided Upload button.

Sending a Test Notification

Now for the fun part - let's verify that push notifications from Firebase are working on Android and iOS!

We need to fire up our application on Android or iOS so that our home.page.ts page can register and receive notifications.

To open your Android project in Android Studio:

npx cap open android

To open your iOS project in Xcode:

npx cap open ios

Once the project is open, side-load the application on your device using the Run feature of either Android Studio or Xcode. The app should start up on the home page.

Note: On iOS, you will see a popup asking you to allow notifications for your app - make sure you choose to Allow notifications!

If your app successfully registers and you followed the code above, you should see an alert with a success message!

Now we'll test to see if the notifications are received by our device. To send a notification, in Firebase, go to the Cloud Messaging section under the Grow header in the project pane.

Next, select the New Notification button.

When creating the notification, you only need to specify the following information:

  1. The text of the notification

  2. The title (Android only, optional for iOS)

  3. The Target (either a user segment or topic; I recommend just targeting the iOS or Android app itself, see below)

  1. The Scheduling (leave this to "Now")

At that point, you can Review the notification you've put together and select Publish to send the notification out.

If you've setup your application correctly, you'll see an alert pop up on your home screen with the push notification you composed in Firebase. You can then tap on the notification and you should get an alert for the pushActionPerformed event, per our code above.

Go to the and click the Add project button.

This section more-or-less mirrors the . See below for specific Capacitor-related notes.

Google Services JSON Location for Android

iOS push notifications are significantly more complicated to set up than Android. You must have a and take care of the following items prior to being able to test push notifications with your iOS application:

for your iOS application in the Apple Developer Portal

for either Development or Production in the Apple Developer Portal

in your application in Xcode

Have a physical iOS device as per the guidelines in the documentation

Google Service Info Plist Location for iOS
Podfile Location iOS
Change Push Target Firebase
Push Test Android
official documentation
Firebase Cloud Messaging
Push Notification API for Capacitor
follow the instructions to install the necessary Capacitor dependencies here
a paid Apple Developer account
Firebase Console
setting up Firebase using the Firebase console documentation
paid Apple Developer account
Setup the proper Development or Production certificates & provisioning profiles
Create an APNS certificate or key
Ensure Push Notification capabilities have been enabled
Dependencies