@ionic-native/email-composer
Version:
Ionic Native - Native plugins for ionic apps
101 lines • 16.1 kB
JavaScript
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 (Object.prototype.hasOwnProperty.call(b, 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 { IonicNativePlugin, checkAvailability, cordova, getPromise } from '@ionic-native/core';
var EmailComposerOriginal = /** @class */ (function (_super) {
__extends(EmailComposerOriginal, _super);
function EmailComposerOriginal() {
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 () {
var _this = this;
return (function () {
if (checkAvailability(_this) === true) {
return getPromise(function (resolve) {
EmailComposerOriginal.getPlugin().hasAccount(function (result) {
if (result) {
resolve(true);
}
else {
resolve(false);
}
});
});
}
})();
};
EmailComposerOriginal.prototype.hasClient = function (app) {
var _this = this;
return (function () {
if (checkAvailability(_this) === true) {
return getPromise(function (resolve) {
if (app) {
EmailComposerOriginal.getPlugin().hasClient(app, function (result) {
if (result) {
resolve(true);
}
else {
resolve(false);
}
});
}
else {
EmailComposerOriginal.getPlugin().getClients(function (apps) {
resolve(apps && apps.length > 0);
});
}
});
}
})();
};
EmailComposerOriginal.prototype.getClients = function () {
var _this = this;
return (function () {
if (checkAvailability(_this) === true) {
return getPromise(function (resolve) {
EmailComposerOriginal.getPlugin().getClients(function (apps) {
if (Object.prototype.toString.call(apps) === '[object String]') {
apps = [apps];
}
resolve(apps);
});
});
}
})();
};
EmailComposerOriginal.prototype.isAvailable = function (app) {
var _this = this;
return (function () {
if (checkAvailability(_this) === true) {
return getPromise(function (resolve) {
Promise.all([_this.hasAccount, _this.hasClient(app)]).then(function (results) {
return resolve(results.length === 2 && results[0] && results[1]);
});
});
}
})();
};
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;
}(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,iDAAoD,UAAU,EAAE,MAAM,oBAAoB,CAAC;;IAmI/D,iCAAiB;;;;IASlD,qCAAa;IAYb,yCAAiB;IAUjB,kCAAU;;;mDAAiB;gBACzB,OAAO,UAAU,CAAU,UAAA,OAAO;oBAChC,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,UAAA,OAAO;oBAChC,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,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;wBACnC,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;yBACf;wBACD,OAAO,CAAC,IAAI,CAAC,CAAC;oBAChB,CAAC,CAAC,CAAC;gBACL,CAAC,CAAC,CAAC;aACJ;;;IASD,mCAAW,aAAC,GAAY;;;mDAAgB;gBACtC,OAAO,UAAU,CAAU,UAAA,OAAO;oBAChC,OAAO,CAAC,GAAG,CAAC,CAAC,KAAI,CAAC,UAAU,EAAE,KAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAA,OAAO;wBAC9D,OAAO,OAAO,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC,IAAI,OAAO,CAAC,CAAC,CAAC,IAAI,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;oBACnE,CAAC,CAAC,CAAC;gBACL,CAAC,CAAC,CAAC;aACJ;;;IAaD,4BAAI,aAAC,OAA6B,EAAE,KAAW;IAW/C,gCAAQ,aAAC,KAAa,EAAE,WAAmB;;;;;;wBAhQ7C;EAoImC,iBAAiB;SAAvC,aAAa","sourcesContent":["import { Injectable } from '@angular/core';\nimport { Cordova, CordovaCheck, IonicNativePlugin, Plugin, getPromise } 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 * @premier 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 && 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)]).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"]}