Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@ionic-native/email-composer

Package Overview
Dependencies
Maintainers
6
Versions
160
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@ionic-native/email-composer - npm Package Compare versions

Comparing version 5.18.1-beta.3 to 5.18.1-beta.5

index.metadata.json

4

index.d.ts

@@ -113,3 +113,3 @@ import { IonicNativePlugin } from '@ionic-native/core';

*/
export declare class EmailComposerOriginal extends IonicNativePlugin {
export declare class EmailComposer extends IonicNativePlugin {
/**

@@ -167,3 +167,1 @@ * Checks if the app has a permission to access email accounts information

}
export declare const EmailComposer: EmailComposerOriginal;

@@ -1,23 +0,12 @@

var __extends = (this && this.__extends) || (function () {
var extendStatics = function (d, b) {
extendStatics = Object.setPrototypeOf ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
return extendStatics(d, b);
};
return function (d, b) {
extendStatics(d, b);
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
})();
import * as tslib_1 from "tslib";
import { Injectable } from '@angular/core';
import { IonicNativePlugin, checkAvailability, cordova, getPromise } from '@ionic-native/core';
var EmailComposerOriginal = /** @class */ (function (_super) {
__extends(EmailComposerOriginal, _super);
function EmailComposerOriginal() {
var EmailComposer = /** @class */ (function (_super) {
tslib_1.__extends(EmailComposer, _super);
function EmailComposer() {
return _super !== null && _super.apply(this, arguments) || this;
}
EmailComposerOriginal.prototype.hasPermission = function () { return cordova(this, "hasPermission", { "successIndex": 0, "errorIndex": 2 }, arguments); };
EmailComposerOriginal.prototype.requestPermission = function () { return cordova(this, "requestPermission", { "successIndex": 0, "errorIndex": 2 }, arguments); };
EmailComposerOriginal.prototype.hasAccount = function () {
EmailComposer.prototype.hasPermission = function () { return cordova(this, "hasPermission", { "successIndex": 0, "errorIndex": 2 }, arguments); };
EmailComposer.prototype.requestPermission = function () { return cordova(this, "requestPermission", { "successIndex": 0, "errorIndex": 2 }, arguments); };
EmailComposer.prototype.hasAccount = function () {
var _this = this;

@@ -27,3 +16,3 @@ return (function () {

return getPromise(function (resolve) {
EmailComposerOriginal.getPlugin().hasAccount(function (result) {
EmailComposer.getPlugin().hasAccount(function (result) {
if (result) {

@@ -40,3 +29,3 @@ resolve(true);

};
EmailComposerOriginal.prototype.hasClient = function (app) {
EmailComposer.prototype.hasClient = function (app) {
var _this = this;

@@ -47,3 +36,3 @@ return (function () {

if (app) {
EmailComposerOriginal.getPlugin().hasClient(app, function (result) {
EmailComposer.getPlugin().hasClient(app, function (result) {
if (result) {

@@ -58,3 +47,3 @@ resolve(true);

else {
EmailComposerOriginal.getPlugin().getClients(function (apps) {
EmailComposer.getPlugin().getClients(function (apps) {
resolve(apps.length && apps.length > 0);

@@ -67,3 +56,3 @@ });

};
EmailComposerOriginal.prototype.getClients = function () {
EmailComposer.prototype.getClients = function () {
var _this = this;

@@ -73,3 +62,3 @@ return (function () {

return getPromise(function (resolve) {
EmailComposerOriginal.getPlugin().getClients(function (apps) {
EmailComposer.getPlugin().getClients(function (apps) {
if (Object.prototype.toString.call(apps) === '[object String]') {

@@ -84,3 +73,3 @@ apps = [apps];

};
EmailComposerOriginal.prototype.isAvailable = function (app) {
EmailComposer.prototype.isAvailable = function (app) {
var _this = this;

@@ -98,13 +87,15 @@ return (function () {

};
EmailComposerOriginal.prototype.open = function (options, scope) { return cordova(this, "open", { "successIndex": 1, "errorIndex": 3 }, arguments); };
EmailComposerOriginal.prototype.addAlias = function (alias, packageName) { return cordova(this, "addAlias", {}, arguments); };
EmailComposerOriginal.pluginName = "EmailComposer";
EmailComposerOriginal.plugin = "cordova-plugin-email-composer";
EmailComposerOriginal.pluginRef = "cordova.plugins.email";
EmailComposerOriginal.repo = "https://github.com/katzer/cordova-plugin-email-composer";
EmailComposerOriginal.platforms = ["Amazon Fire OS", "Android", "Browser", "iOS", "Windows", "macOS"];
return EmailComposerOriginal;
EmailComposer.prototype.open = function (options, scope) { return cordova(this, "open", { "successIndex": 1, "errorIndex": 3 }, arguments); };
EmailComposer.prototype.addAlias = function (alias, packageName) { return cordova(this, "addAlias", {}, arguments); };
EmailComposer.pluginName = "EmailComposer";
EmailComposer.plugin = "cordova-plugin-email-composer";
EmailComposer.pluginRef = "cordova.plugins.email";
EmailComposer.repo = "https://github.com/katzer/cordova-plugin-email-composer";
EmailComposer.platforms = ["Amazon Fire OS", "Android", "Browser", "iOS", "Windows", "macOS"];
EmailComposer = tslib_1.__decorate([
Injectable()
], EmailComposer);
return EmailComposer;
}(IonicNativePlugin));
var EmailComposer = new EmailComposerOriginal();
export { EmailComposer };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/@ionic-native/plugins/email-composer/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;AACA,OAAO,iDAKL,UAAU,EACX,MAAM,oBAAoB,CAAC;;IAkIO,iCAAiB;;;;IASlD,qCAAa;IAYb,yCAAiB;IAUjB,kCAAU;;;mDAAiB;gBACzB,OAAO,UAAU,CAAU,UAAC,OAAO;oBACjC,aAAa,CAAC,SAAS,EAAE,CAAC,UAAU,CAAC,UAAC,MAAe;wBACnD,IAAI,MAAM,EAAE;4BACV,OAAO,CAAC,IAAI,CAAC,CAAC;yBACf;6BAAM;4BACL,OAAO,CAAC,KAAK,CAAC,CAAC;yBAChB;oBACH,CAAC,CAAC,CAAC;gBACL,CAAC,CAAC,CAAC;aACJ;;;IAUD,iCAAS,aAAC,GAAY;;;mDAAgB;gBACpC,OAAO,UAAU,CAAU,UAAC,OAAO;oBACjC,IAAI,GAAG,EAAE;wBACP,aAAa,CAAC,SAAS,EAAE,CAAC,SAAS,CAAC,GAAG,EAAE,UAAC,MAAe;4BACvD,IAAI,MAAM,EAAE;gCACV,OAAO,CAAC,IAAI,CAAC,CAAC;6BACf;iCAAM;gCACL,OAAO,CAAC,KAAK,CAAC,CAAC;6BAChB;wBACH,CAAC,CAAC,CAAC;qBACJ;yBAAM;wBACL,aAAa,CAAC,SAAS,EAAE,CAAC,UAAU,CAAC,UAAC,IAAc;4BAClD,OAAO,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;wBAC1C,CAAC,CAAC,CAAC;qBACJ;gBACH,CAAC,CAAC,CAAC;aACJ;;;IASD,kCAAU;;;mDAAsB;gBAC9B,OAAO,UAAU,CAAW,UAAA,OAAO;oBACjC,aAAa,CAAC,SAAS,EAAE,CAAC,UAAU,CAAC,UAAC,IAAS;wBAC7C,IAAI,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,iBAAiB,EAAE;4BAC9D,IAAI,GAAG,CAAC,IAAI,CAAC,CAAC;yBACjB;wBACC,OAAO,CAAC,IAAI,CAAC,CAAC;oBAChB,CAAC,CAAC,CAAC;gBACL,CAAC,CAAC,CAAC;aACJ;;;IASD,mCAAW,aAAC,GAAY;;;mDAAgB;gBACtC,OAAO,UAAU,CAAU,UAAC,OAAO;oBACjC,OAAO,CAAC,GAAG,CAAC,CAAC,KAAI,CAAC,UAAU,EAAE,KAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC;yBAChD,IAAI,CAAC,UAAC,OAAO;wBACZ,OAAO,OAAO,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC,IAAI,OAAO,CAAC,CAAC,CAAC,IAAI,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;oBACnE,CAAC,CAAC,CAAC;gBACP,CAAC,CAAC,CAAC;aACJ;;;IAaD,4BAAI,aAAC,OAA6B,EAAE,KAAW;IAW/C,gCAAQ,aAAC,KAAa,EAAE,WAAmB;;;;;;wBAtQ7C;EAyImC,iBAAiB;SAAvC,aAAa","sourcesContent":["import { Injectable } from '@angular/core';\nimport {\n  Cordova,\n  CordovaCheck,\n  IonicNativePlugin,\n  Plugin,\n  getPromise\n} from '@ionic-native/core';\n\nexport interface EmailComposerOptions {\n  /**\n   * App to send the email with\n   */\n  app?: string;\n\n  /**\n   * Email address(es) for To field\n   */\n  to?: string | string[];\n\n  /**\n   * Email address(es) for CC field\n   */\n  cc?: string | string[];\n\n  /**\n   * Email address(es) for BCC field\n   */\n  bcc?: string | string[];\n\n  /**\n   * File paths or base64 data streams\n   */\n  attachments?: string[];\n\n  /**\n   * Subject of the email\n   */\n  subject?: string;\n\n  /**\n   * Email body (for HTML, set isHtml to true)\n   */\n  body?: string;\n\n  /**\n   * Indicates if the body is HTML or plain text\n   */\n  isHtml?: boolean;\n\n  /**\n   *  Content type of the email (Android only)\n   */\n  type?: string;\n}\n\n/**\n * @name Email Composer\n * @description\n *\n * Requires Cordova plugin: cordova-plugin-email-composer. For more info, please see the [Email Composer plugin docs](https://github.com/hypery2k/cordova-email-plugin).\n *\n *\n * @usage\n * ```typescript\n * import { EmailComposer } from '@ionic-native/email-composer/ngx';\n *\n * constructor(private emailComposer: EmailComposer) { }\n *\n * ...\n *\n *\n * this.emailComposer.getClients().then((apps: []) => {\n *    // Returns an array of configured email clients for the device\n * });\n *\n * this.emailComposer.hasClient().then(app, (isValid: boolean) => {\n *  if (isValid) {\n *    // Now we know we have a valid email client configured\n *    // Not specifying an app will return true if at least one email client is configured\n *  }\n * });\n *\n * this.emailComposer.hasAccount().then((isValid: boolean) => {\n *  if (isValid) {\n *    // Now we know we have a valid email account configured\n *  }\n * });\n *\n * this.emailComposer.isAvailable().then(app, (available: boolean) => {\n *  if(available) {\n *    // Now we know we can send an email, calls hasClient and hasAccount\n *    // Not specifying an app will return true if at least one email client is configured\n *  }\n * });\n *\n * let email = {\n *   to: 'max@mustermann.de',\n *   cc: 'erika@mustermann.de',\n *   bcc: ['john@doe.com', 'jane@doe.com'],\n *   attachments: [\n *     'file://img/logo.png',\n *     'res://icon.png',\n *     'base64:icon.png//iVBORw0KGgoAAAANSUhEUg...',\n *     'file://README.pdf'\n *   ],\n *   subject: 'Cordova Icons',\n *   body: 'How are you? Nice greetings from Leipzig',\n *   isHtml: true\n * }\n *\n * // Send a text message using default options\n * this.emailComposer.open(email);\n * ```\n *\n * You can also assign aliases to email apps\n * ```ts\n * // add alias\n * this.email.addAlias('gmail', 'com.google.android.gm');\n *\n * // then use alias when sending email\n * this.email.open({\n *   app: 'gmail',\n *   ...\n * });\n * ```\n * @interfaces\n * EmailComposerOptions\n */\n@Plugin({\n  pluginName: 'EmailComposer',\n  plugin: 'cordova-plugin-email-composer',\n  pluginRef: 'cordova.plugins.email',\n  repo: 'https://github.com/katzer/cordova-plugin-email-composer',\n  platforms: ['Amazon Fire OS', 'Android', 'Browser', 'iOS', 'Windows', 'macOS']\n})\n@Injectable()\nexport class EmailComposer extends IonicNativePlugin {\n  /**\n   * Checks if the app has a permission to access email accounts information\n   * @return {Promise<boolean>} returns a promise that resolves with a boolean that indicates if the permission was granted\n   */\n  @Cordova({\n    successIndex: 0,\n    errorIndex: 2\n  })\n  hasPermission(): Promise<boolean> {\n    return;\n  }\n\n  /**\n   * Request permission to access email accounts information\n   * @return {Promise<boolean>} returns a promise that resolves with a boolean that indicates if the permission was granted\n   */\n  @Cordova({\n    successIndex: 0,\n    errorIndex: 2\n  })\n  requestPermission(): Promise<boolean> {\n    return;\n  }\n\n  /**\n   * Verifies if an email account is configured on the device.\n   *\n   * @returns {Promise<any>} Resolves if available, rejects if not available\n   */\n  @CordovaCheck()\n  hasAccount(): Promise<any> {\n    return getPromise<boolean>((resolve) => {\n      EmailComposer.getPlugin().hasAccount((result: boolean) => {\n        if (result) {\n          resolve(true);\n        } else {\n          resolve(false);\n        }\n      });\n    });\n  }\n\n  /**\n   * Verifies if a specific email client is installed on the device.\n   *\n   * @param {string} [app] App id or uri scheme.\n   * @returns {Promise<any>} Resolves if available, rejects if not available\n   */\n\n  @CordovaCheck()\n  hasClient(app?: string): Promise<any> {\n    return getPromise<boolean>((resolve) => {\n      if (app) {\n        EmailComposer.getPlugin().hasClient(app, (result: boolean) => {\n          if (result) {\n            resolve(true);\n          } else {\n            resolve(false);\n          }\n        });\n      } else {\n        EmailComposer.getPlugin().getClients((apps: string[]) => {\n          resolve(apps.length && apps.length > 0);\n        });\n      }\n    });\n  }\n\n  /**\n   * Returns an array of email clients installed on the device.\n   *\n   * @returns {Promise<string[]>} Resolves if available, rejects if not available\n   */\n  @CordovaCheck()\n  @Cordova({ platforms: ['Android'] })\n  getClients(): Promise<string[]> {\n    return getPromise<string[]>(resolve => {\n      EmailComposer.getPlugin().getClients((apps: any) => {\n        if (Object.prototype.toString.call(apps) === '[object String]') {\n          apps = [apps];\n      }\n        resolve(apps);\n      });\n    });\n  }\n\n  /**\n   * Verifies if sending emails is supported on the device.\n   *\n   * @param {string} [app] App id or uri scheme.\n   * @returns {Promise<any>} Resolves if available, rejects if not available\n   */\n  @CordovaCheck()\n  isAvailable(app?: string): Promise<any> {\n    return getPromise<boolean>((resolve) => {\n      Promise.all([this.hasAccount, this.hasClient(app)])\n        .then((results) => {\n          return resolve(results.length === 2 && results[0] && results[1]);\n        });\n    });\n  }\n\n  /**\n   * Displays the email composer pre-filled with data.\n   *\n   * @param {EmailComposerOptions} options Email\n   * @param {any} [scope] Scope for the promise\n   * @returns {Promise<any>} Resolves promise when the EmailComposer has been opened\n   */\n  @Cordova({\n    successIndex: 1,\n    errorIndex: 3\n  })\n  open(options: EmailComposerOptions, scope?: any): Promise<any> {\n    return;\n  }\n\n  /**\n   * Adds a new mail app alias.\n   *\n   * @param {string} alias The alias name\n   * @param {string} packageName The package name\n   */\n  @Cordova()\n  addAlias(alias: string, packageName: string): void {}\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/@ionic-native/plugins/email-composer/ngx/index.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,iDAKL,UAAU,EACX,MAAM,oBAAoB,CAAC;;IAkIO,yCAAiB;;;;IASlD,qCAAa;IAYb,yCAAiB;IAUjB,kCAAU;;;mDAAiB;gBACzB,OAAO,UAAU,CAAU,UAAC,OAAO;oBACjC,aAAa,CAAC,SAAS,EAAE,CAAC,UAAU,CAAC,UAAC,MAAe;wBACnD,IAAI,MAAM,EAAE;4BACV,OAAO,CAAC,IAAI,CAAC,CAAC;yBACf;6BAAM;4BACL,OAAO,CAAC,KAAK,CAAC,CAAC;yBAChB;oBACH,CAAC,CAAC,CAAC;gBACL,CAAC,CAAC,CAAC;aACJ;;;IAUD,iCAAS,aAAC,GAAY;;;mDAAgB;gBACpC,OAAO,UAAU,CAAU,UAAC,OAAO;oBACjC,IAAI,GAAG,EAAE;wBACP,aAAa,CAAC,SAAS,EAAE,CAAC,SAAS,CAAC,GAAG,EAAE,UAAC,MAAe;4BACvD,IAAI,MAAM,EAAE;gCACV,OAAO,CAAC,IAAI,CAAC,CAAC;6BACf;iCAAM;gCACL,OAAO,CAAC,KAAK,CAAC,CAAC;6BAChB;wBACH,CAAC,CAAC,CAAC;qBACJ;yBAAM;wBACL,aAAa,CAAC,SAAS,EAAE,CAAC,UAAU,CAAC,UAAC,IAAc;4BAClD,OAAO,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;wBAC1C,CAAC,CAAC,CAAC;qBACJ;gBACH,CAAC,CAAC,CAAC;aACJ;;;IASD,kCAAU;;;mDAAsB;gBAC9B,OAAO,UAAU,CAAW,UAAA,OAAO;oBACjC,aAAa,CAAC,SAAS,EAAE,CAAC,UAAU,CAAC,UAAC,IAAS;wBAC7C,IAAI,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,iBAAiB,EAAE;4BAC9D,IAAI,GAAG,CAAC,IAAI,CAAC,CAAC;yBACjB;wBACC,OAAO,CAAC,IAAI,CAAC,CAAC;oBAChB,CAAC,CAAC,CAAC;gBACL,CAAC,CAAC,CAAC;aACJ;;;IASD,mCAAW,aAAC,GAAY;;;mDAAgB;gBACtC,OAAO,UAAU,CAAU,UAAC,OAAO;oBACjC,OAAO,CAAC,GAAG,CAAC,CAAC,KAAI,CAAC,UAAU,EAAE,KAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC;yBAChD,IAAI,CAAC,UAAC,OAAO;wBACZ,OAAO,OAAO,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC,IAAI,OAAO,CAAC,CAAC,CAAC,IAAI,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;oBACnE,CAAC,CAAC,CAAC;gBACP,CAAC,CAAC,CAAC;aACJ;;;IAaD,4BAAI,aAAC,OAA6B,EAAE,KAAW;IAW/C,gCAAQ,aAAC,KAAa,EAAE,WAAmB;;;;;;IA7HhC,aAAa;QADzB,UAAU,EAAE;OACA,aAAa;wBAzI1B;EAyImC,iBAAiB;SAAvC,aAAa","sourcesContent":["import { Injectable } from '@angular/core';\nimport {\n  Cordova,\n  CordovaCheck,\n  IonicNativePlugin,\n  Plugin,\n  getPromise\n} from '@ionic-native/core';\n\nexport interface EmailComposerOptions {\n  /**\n   * App to send the email with\n   */\n  app?: string;\n\n  /**\n   * Email address(es) for To field\n   */\n  to?: string | string[];\n\n  /**\n   * Email address(es) for CC field\n   */\n  cc?: string | string[];\n\n  /**\n   * Email address(es) for BCC field\n   */\n  bcc?: string | string[];\n\n  /**\n   * File paths or base64 data streams\n   */\n  attachments?: string[];\n\n  /**\n   * Subject of the email\n   */\n  subject?: string;\n\n  /**\n   * Email body (for HTML, set isHtml to true)\n   */\n  body?: string;\n\n  /**\n   * Indicates if the body is HTML or plain text\n   */\n  isHtml?: boolean;\n\n  /**\n   *  Content type of the email (Android only)\n   */\n  type?: string;\n}\n\n/**\n * @name Email Composer\n * @description\n *\n * Requires Cordova plugin: cordova-plugin-email-composer. For more info, please see the [Email Composer plugin docs](https://github.com/hypery2k/cordova-email-plugin).\n *\n *\n * @usage\n * ```typescript\n * import { EmailComposer } from '@ionic-native/email-composer/ngx';\n *\n * constructor(private emailComposer: EmailComposer) { }\n *\n * ...\n *\n *\n * this.emailComposer.getClients().then((apps: []) => {\n *    // Returns an array of configured email clients for the device\n * });\n *\n * this.emailComposer.hasClient().then(app, (isValid: boolean) => {\n *  if (isValid) {\n *    // Now we know we have a valid email client configured\n *    // Not specifying an app will return true if at least one email client is configured\n *  }\n * });\n *\n * this.emailComposer.hasAccount().then((isValid: boolean) => {\n *  if (isValid) {\n *    // Now we know we have a valid email account configured\n *  }\n * });\n *\n * this.emailComposer.isAvailable().then(app, (available: boolean) => {\n *  if(available) {\n *    // Now we know we can send an email, calls hasClient and hasAccount\n *    // Not specifying an app will return true if at least one email client is configured\n *  }\n * });\n *\n * let email = {\n *   to: 'max@mustermann.de',\n *   cc: 'erika@mustermann.de',\n *   bcc: ['john@doe.com', 'jane@doe.com'],\n *   attachments: [\n *     'file://img/logo.png',\n *     'res://icon.png',\n *     'base64:icon.png//iVBORw0KGgoAAAANSUhEUg...',\n *     'file://README.pdf'\n *   ],\n *   subject: 'Cordova Icons',\n *   body: 'How are you? Nice greetings from Leipzig',\n *   isHtml: true\n * }\n *\n * // Send a text message using default options\n * this.emailComposer.open(email);\n * ```\n *\n * You can also assign aliases to email apps\n * ```ts\n * // add alias\n * this.email.addAlias('gmail', 'com.google.android.gm');\n *\n * // then use alias when sending email\n * this.email.open({\n *   app: 'gmail',\n *   ...\n * });\n * ```\n * @interfaces\n * EmailComposerOptions\n */\n@Plugin({\n  pluginName: 'EmailComposer',\n  plugin: 'cordova-plugin-email-composer',\n  pluginRef: 'cordova.plugins.email',\n  repo: 'https://github.com/katzer/cordova-plugin-email-composer',\n  platforms: ['Amazon Fire OS', 'Android', 'Browser', 'iOS', 'Windows', 'macOS']\n})\n@Injectable()\nexport class EmailComposer extends IonicNativePlugin {\n  /**\n   * Checks if the app has a permission to access email accounts information\n   * @return {Promise<boolean>} returns a promise that resolves with a boolean that indicates if the permission was granted\n   */\n  @Cordova({\n    successIndex: 0,\n    errorIndex: 2\n  })\n  hasPermission(): Promise<boolean> {\n    return;\n  }\n\n  /**\n   * Request permission to access email accounts information\n   * @return {Promise<boolean>} returns a promise that resolves with a boolean that indicates if the permission was granted\n   */\n  @Cordova({\n    successIndex: 0,\n    errorIndex: 2\n  })\n  requestPermission(): Promise<boolean> {\n    return;\n  }\n\n  /**\n   * Verifies if an email account is configured on the device.\n   *\n   * @returns {Promise<any>} Resolves if available, rejects if not available\n   */\n  @CordovaCheck()\n  hasAccount(): Promise<any> {\n    return getPromise<boolean>((resolve) => {\n      EmailComposer.getPlugin().hasAccount((result: boolean) => {\n        if (result) {\n          resolve(true);\n        } else {\n          resolve(false);\n        }\n      });\n    });\n  }\n\n  /**\n   * Verifies if a specific email client is installed on the device.\n   *\n   * @param {string} [app] App id or uri scheme.\n   * @returns {Promise<any>} Resolves if available, rejects if not available\n   */\n\n  @CordovaCheck()\n  hasClient(app?: string): Promise<any> {\n    return getPromise<boolean>((resolve) => {\n      if (app) {\n        EmailComposer.getPlugin().hasClient(app, (result: boolean) => {\n          if (result) {\n            resolve(true);\n          } else {\n            resolve(false);\n          }\n        });\n      } else {\n        EmailComposer.getPlugin().getClients((apps: string[]) => {\n          resolve(apps.length && apps.length > 0);\n        });\n      }\n    });\n  }\n\n  /**\n   * Returns an array of email clients installed on the device.\n   *\n   * @returns {Promise<string[]>} Resolves if available, rejects if not available\n   */\n  @CordovaCheck()\n  @Cordova({ platforms: ['Android'] })\n  getClients(): Promise<string[]> {\n    return getPromise<string[]>(resolve => {\n      EmailComposer.getPlugin().getClients((apps: any) => {\n        if (Object.prototype.toString.call(apps) === '[object String]') {\n          apps = [apps];\n      }\n        resolve(apps);\n      });\n    });\n  }\n\n  /**\n   * Verifies if sending emails is supported on the device.\n   *\n   * @param {string} [app] App id or uri scheme.\n   * @returns {Promise<any>} Resolves if available, rejects if not available\n   */\n  @CordovaCheck()\n  isAvailable(app?: string): Promise<any> {\n    return getPromise<boolean>((resolve) => {\n      Promise.all([this.hasAccount, this.hasClient(app)])\n        .then((results) => {\n          return resolve(results.length === 2 && results[0] && results[1]);\n        });\n    });\n  }\n\n  /**\n   * Displays the email composer pre-filled with data.\n   *\n   * @param {EmailComposerOptions} options Email\n   * @param {any} [scope] Scope for the promise\n   * @returns {Promise<any>} Resolves promise when the EmailComposer has been opened\n   */\n  @Cordova({\n    successIndex: 1,\n    errorIndex: 3\n  })\n  open(options: EmailComposerOptions, scope?: any): Promise<any> {\n    return;\n  }\n\n  /**\n   * Adds a new mail app alias.\n   *\n   * @param {string} alias The alias name\n   * @param {string} packageName The package name\n   */\n  @Cordova()\n  addAlias(alias: string, packageName: string): void {}\n}\n"]}

@@ -1,1 +0,1 @@

{"description":"Ionic Native - Native plugins for ionic apps","module":"index.js","typings":"index.d.ts","author":"ionic","license":"MIT","repository":{"type":"git","url":"https://github.com/ionic-team/ionic-native.git"},"name":"@ionic-native/email-composer","dependencies":{"@types/cordova":"latest"},"peerDependencies":{"rxjs":"^5.5.0 || ^6.5.0","@ionic-native/core":"^5.1.0"},"version":"5.18.1-beta.3"}
{"description":"Ionic Native - Native plugins for ionic apps","module":"index.js","typings":"index.d.ts","author":"ionic","license":"MIT","repository":{"type":"git","url":"https://github.com/ionic-team/ionic-native.git"},"name":"@ionic-native/email-composer","dependencies":{"@types/cordova":"latest"},"peerDependencies":{"rxjs":"^5.5.0 || ^6.5.0","@ionic-native/core":"^5.1.0"},"version":"5.18.1-beta.5"}
SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc