How to install Awesome Cordova Plugins in Angular, React, and TypeScript projects using Cordova or Capacitor.
Apache Cordova is an open source native runtime that allows developers to build native mobile apps with HTML, CSS, and JavaScript. Similar to Capacitor, Ionic's own native runtime, Cordova allows developers to access native device features, such as camera, keyboard, and geolocation, using a system of plugins. A plugin is a small amount of add-on code that provides JavaScript interface to native components. They allow your app to use native device capabilities beyond what is available to pure web apps.
These plugins are submitted and maintained by the community. While community members are generally quick to find and fix issues, certain plugins may not function properly.
Capacitor Support
In addition to Cordova, Awesome Cordova Plugins also works with Capacitor, Ionic's official native runtime. Basic usage below. For complete details, see the Capacitor documentation.
Usage
All plugins have two components — the native code (Cordova) and the TypeScript code (Awesome Cordova Plugins). Cordova plugins are also wrapped in a Promise or Observable in order to provide a common plugin interface and modernized development approach.
Using the Camera plugin as an example, first install it:
Next, begin using the plugin, following the various framework usage options below. For FAQ, see here.
Angular (Standalone)
Angular apps can use either Cordova or Capacitor to build native mobile apps. Register the plugin as a provider in your application bootstrap. For Angular, the import path should end with /ngx. Angular's change detection is automatically handled.
After the plugin has been registered, inject it in any component or service using Angular's inject() function:
React
React apps must use Capacitor to build native mobile apps. However, Awesome Cordova Plugins (and therefore, Cordova plugins) can still be used.
Import the plugin object then use its static methods:
ES2015+/TypeScript
ES2015+ and TypeScript apps can use either Cordova or Capacitor to build native mobile apps. To use any plugin, import the class from the appropriate package and use its static methods: