With the new plugin created, you can begin implementing functionality across a variety of platforms.
To implement new functionality in your plugin, begin by defining the function’s signature in the exported TypeScript interface for your plugin in
src/definitions.ts
.
In the example below, the
openMap()
function is added which takes a
latitude
and
longitude
. It is good practice to define interfaces for method parameters that can be imported and used in apps.
export interface EchoPlugin {
echo(options: { value: string }): Promise<{ value: string }>;
+ openMap(options: OpenMapOptions): Promise<void>;
}
+export interface OpenMapOptions {
+ latitude: number;
+ longitude: number;
+}
Implement the web implementation in src/web.ts
:
import type {
EchoPlugin,
+ OpenMapOptions,
} from './definitions';
export class EchoPluginWeb extends WebPlugin implements EchoPlugin {
// other functions
+ async openMap(location: OpenMapOptions): Promise<void> {
+ // logic here
+ }
}
To compile the plugin, navigate into the plugin directory then run:
npm run build
Implement
Android functionality in
android/src/main/[nested folders]/PluginName.java
:
@PluginMethod()
public void openMap(PluginCall call) {
Double latitude = call.getDouble("latitude");
Double longitude = call.getDouble("longitude");
// more logic
call.resolve();
}
Implement iOS functionality in ios/Plugin/Plugin.swift
:
@objc func openMap(_ call: CAPPluginCall) {
let latitude = call.getString("latitude")
let longitude = call.getNumber("longitude")
// more logic
call.resolve()
}
Remember to register plugin methods in your
.m
file.
To test the plugin locally while developing it, link the plugin folder to your app using
npm install
with the path to your plugin.
npm install ../path/to/my-plugin
The project’s
package.json
file now shows the plugin package link in the dependencies list:
"my-plugin": "file:../path/to/my-plugin",
Finally, run npx cap sync
to make the native projects aware of your plugin. If it was detected correctly, it will print something like this:
[info] Found 1 Capacitor plugin for android:
- my-plugin (0.0.1)
To unlink the local plugin from your app, use npm uninstall
with the package name of your plugin.
npm uninstall my-plugin
The plugin template ships with a variety of scripts in
package.json
.
verify
: builds and tests web and native codelint
: lints web and native codefmt
: autoformats web and native codedocgen
: generates documentation from plugin interface (see
Documentation)build
: builds web code into ESM and bundle distributionsTo document plugin functionality, add JSDoc comment blocks to functions and properties.
It is usually not necessary to include type information with the
@param
and@returns
JSDoc tags in TypeScript files.
Using our
openMap()
function as an example, open
src/definitions.ts
and start documenting!
export interface EchoPlugin {
echo(options: { value: string }): Promise<{ value: string }>;
+ /**
+ * Opens the map at a given location.
+ *
+ * @since 1.1.0
+ */
openMap(options: OpenMapOptions): Promise<void>;
}
export interface OpenMapOptions {
+ /**
+ * The latitude at which to open the map.
+ */
latitude: number;
+ /**
+ * The longitude at which to open the map.
+ */
longitude: number;
}
The plugin template ships with @capacitor/docgen
, which writes generated documentation to
README.md
. Documentation is generated during
npm run build
. You can also run it manually:
npm run docgen
Whenever you are ready to publish your plugin, just use:
npm publish
This will build the JS portion of your plugin and publish the rest of your plugin files to npm.
Your package can now be installed using
npm install my-plugin
in any Capacitor app.