UNPKG

32.9 kBJavaScriptView Raw
1import { __decorate, __extends } from "tslib";
2import { Injectable } from '@angular/core';
3import { IonicNativePlugin, cordova } from '@ionic-native/core';
4var PayPal = /** @class */ (function (_super) {
5 __extends(PayPal, _super);
6 function PayPal() {
7 return _super !== null && _super.apply(this, arguments) || this;
8 }
9 PayPal.prototype.version = function () { return cordova(this, "version", {}, arguments); };
10 PayPal.prototype.init = function (clientIdsForEnvironments) { return cordova(this, "init", {}, arguments); };
11 PayPal.prototype.prepareToRender = function (environment, configuration) { return cordova(this, "prepareToRender", {}, arguments); };
12 PayPal.prototype.renderSinglePaymentUI = function (payment) { return cordova(this, "renderSinglePaymentUI", {}, arguments); };
13 PayPal.prototype.clientMetadataID = function () { return cordova(this, "clientMetadataID", {}, arguments); };
14 PayPal.prototype.renderFuturePaymentUI = function () { return cordova(this, "renderFuturePaymentUI", {}, arguments); };
15 PayPal.prototype.renderProfileSharingUI = function (scopes) { return cordova(this, "renderProfileSharingUI", {}, arguments); };
16 PayPal.pluginName = "PayPal";
17 PayPal.plugin = "com.paypal.cordova.mobilesdk";
18 PayPal.pluginRef = "PayPalMobile";
19 PayPal.repo = "https://github.com/paypal/PayPal-Cordova-Plugin";
20 PayPal.platforms = ["Android", "iOS"];
21 PayPal = __decorate([
22 Injectable()
23 ], PayPal);
24 return PayPal;
25}(IonicNativePlugin));
26export { PayPal };
27var PayPalPayment = /** @class */ (function () {
28 function PayPalPayment(amount, currency, shortDescription, intent, details) {
29 /**
30 * Optional Build Notation code ("BN code"), obtained from partnerprogram@paypal.com,
31 * for your tracking purposes.
32 */
33 this.bnCode = 'PhoneGap_SP';
34 this.amount = amount;
35 this.currency = currency;
36 this.shortDescription = shortDescription;
37 this.intent = intent;
38 this.details = details;
39 }
40 return PayPalPayment;
41}());
42export { PayPalPayment };
43var PayPalItem = /** @class */ (function () {
44 /**
45 * The PayPalItem class defines an optional itemization for a payment.
46 * @see https://developer.paypal.com/docs/api/#item-object for more details.
47 * @param {String} name: Name of the item. 127 characters max
48 * @param {Number} quantity: Number of units. 10 characters max.
49 * @param {String} price: Unit price for this item 10 characters max.
50 * May be negative for "coupon" etc
51 * @param {String} currency: ISO standard currency code.
52 * @param {String} sku: The stock keeping unit for this item. 50 characters max (optional)
53 */
54 function PayPalItem(name, quantity, price, currency, sku) {
55 this.name = name;
56 this.quantity = quantity;
57 this.price = price;
58 this.currency = currency;
59 this.sku = sku;
60 }
61 return PayPalItem;
62}());
63export { PayPalItem };
64var PayPalPaymentDetails = /** @class */ (function () {
65 /**
66 * The PayPalPaymentDetails class defines optional amount details.
67 * @param {String} subtotal: Sub-total (amount) of items being paid for. 10 characters max with support for 2 decimal places.
68 * @param {String} shipping: Amount charged for shipping. 10 characters max with support for 2 decimal places.
69 * @param {String} tax: Amount charged for tax. 10 characters max with support for 2 decimal places.
70 */
71 function PayPalPaymentDetails(subtotal, shipping, tax) {
72 this.subtotal = subtotal;
73 this.shipping = shipping;
74 this.tax = tax;
75 }
76 return PayPalPaymentDetails;
77}());
78export { PayPalPaymentDetails };
79var PayPalConfiguration = /** @class */ (function () {
80 /**
81 * You use a PayPalConfiguration object to configure many aspects of how the SDK behaves.
82 * see defaults for options available
83 */
84 function PayPalConfiguration(options) {
85 var defaults = {
86 defaultUserEmail: null,
87 defaultUserPhoneCountryCode: null,
88 defaultUserPhoneNumber: null,
89 merchantName: null,
90 merchantPrivacyPolicyURL: null,
91 merchantUserAgreementURL: null,
92 acceptCreditCards: true,
93 payPalShippingAddressOption: 0,
94 rememberUser: true,
95 languageOrLocale: null,
96 disableBlurWhenBackgrounding: false,
97 presentingInPopover: false,
98 forceDefaultsInSandbox: false,
99 sandboxUserPassword: null,
100 sandboxUserPin: null,
101 };
102 if (options && typeof options === 'object') {
103 for (var i in options) {
104 if (defaults.hasOwnProperty(i)) {
105 defaults[i] = options[i];
106 }
107 }
108 }
109 return defaults;
110 }
111 return PayPalConfiguration;
112}());
113export { PayPalConfiguration };
114var PayPalShippingAddress = /** @class */ (function () {
115 /**
116 * See the documentation of the individual properties for more detail.
117 * @param {String} recipientName: Name of the recipient at this address. 50 characters max.
118 * @param {String} line1: Line 1 of the address (e.g., Number, street, etc). 100 characters max.
119 * @param {String} line2: Line 2 of the address (e.g., Suite, apt #, etc). 100 characters max. Optional.
120 * @param {String} city: City name. 50 characters max.
121 * @param {String} state: 2-letter code for US states, and the equivalent for other countries. 100 characters max. Required in certain countries.
122 * @param {String} postalCode: ZIP code or equivalent is usually required for countries that have them. 20 characters max. Required in certain countries.
123 * @param {String} countryCode: 2-letter country code. 2 characters max.
124 */
125 function PayPalShippingAddress(recipientName, line1, line2, city, state, postalCode, countryCode) {
126 this.recipientName = recipientName;
127 this.line1 = line1;
128 this.line2 = line2;
129 this.city = city;
130 this.state = state;
131 this.postalCode = postalCode;
132 this.countryCode = countryCode;
133 }
134 return PayPalShippingAddress;
135}());
136export { PayPalShippingAddress };
137//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/@ionic-native/plugins/paypal/ngx/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { Cordova, IonicNativePlugin, Plugin } from '@ionic-native/core';\n\n/**\n * @name PayPal\n * @description\n * PayPal plugin for Cordova/Ionic Applications\n *\n * @usage\n * ```typescript\n * import { PayPal, PayPalPayment, PayPalConfiguration } from '@ionic-native/paypal/ngx';\n *\n * constructor(private payPal: PayPal) { }\n *\n * ...\n *\n *\n * this.payPal.init({\n *   PayPalEnvironmentProduction: 'YOUR_PRODUCTION_CLIENT_ID',\n *   PayPalEnvironmentSandbox: 'YOUR_SANDBOX_CLIENT_ID'\n * }).then(() => {\n *   // Environments: PayPalEnvironmentNoNetwork, PayPalEnvironmentSandbox, PayPalEnvironmentProduction\n *   this.payPal.prepareToRender('PayPalEnvironmentSandbox', new PayPalConfiguration({\n *     // Only needed if you get an \"Internal Service Error\" after PayPal login!\n *     //payPalShippingAddressOption: 2 // PayPalShippingAddressOptionPayPal\n *   })).then(() => {\n *     let payment = new PayPalPayment('3.33', 'USD', 'Description', 'sale');\n *     this.payPal.renderSinglePaymentUI(payment).then(() => {\n *       // Successfully paid\n *\n *       // Example sandbox response\n *       //\n *       // {\n *       //   \"client\": {\n *       //     \"environment\": \"sandbox\",\n *       //     \"product_name\": \"PayPal iOS SDK\",\n *       //     \"paypal_sdk_version\": \"2.16.0\",\n *       //     \"platform\": \"iOS\"\n *       //   },\n *       //   \"response_type\": \"payment\",\n *       //   \"response\": {\n *       //     \"id\": \"PAY-1AB23456CD789012EF34GHIJ\",\n *       //     \"state\": \"approved\",\n *       //     \"create_time\": \"2016-10-03T13:33:33Z\",\n *       //     \"intent\": \"sale\"\n *       //   }\n *       // }\n *     }, () => {\n *       // Error or render dialog closed without being successful\n *     });\n *   }, () => {\n *     // Error in configuration\n *   });\n * }, () => {\n *   // Error in initialization, maybe PayPal isn't supported or something else\n * });\n * ```\n * @interfaces\n * PayPalEnvironment\n * PayPalConfigurationOptions\n * @classes\n * PayPalPayment\n * PayPalItem\n * PayPalPaymentDetails\n * PayPalShippingAddress\n */\n@Plugin({\n  pluginName: 'PayPal',\n  plugin: 'com.paypal.cordova.mobilesdk',\n  pluginRef: 'PayPalMobile',\n  repo: 'https://github.com/paypal/PayPal-Cordova-Plugin',\n  platforms: ['Android', 'iOS'],\n})\n@Injectable()\nexport class PayPal extends IonicNativePlugin {\n  /**\n   * Retrieve the version of the PayPal iOS SDK library. Useful when contacting support.\n   * @returns {Promise<string>}\n   */\n  @Cordova()\n  version(): Promise<string> {\n    return;\n  }\n\n  /**\n   * You must preconnect to PayPal to prepare the device for processing payments.\n   * This improves the user experience, by making the presentation of the\n   * UI faster. The preconnect is valid for a limited time, so\n   * the recommended time to preconnect is on page load.\n   *\n   * @param {PayPalEnvironment} clientIdsForEnvironments: set of client ids for environments\n   * @returns {Promise<any>}\n   */\n  @Cordova()\n  init(clientIdsForEnvironments: PayPalEnvironment): Promise<any> {\n    return;\n  }\n\n  /**\n   * You must preconnect to PayPal to prepare the device for processing payments.\n   * This improves the user experience, by making the presentation of the UI faster.\n   * The preconnect is valid for a limited time, so the recommended time to preconnect is on page load.\n   *\n   * @param {String} environment: available options are \"PayPalEnvironmentNoNetwork\", \"PayPalEnvironmentProduction\" and \"PayPalEnvironmentSandbox\"\n   * @param {PayPalConfiguration} configuration: PayPalConfiguration object, for Future Payments merchantName, merchantPrivacyPolicyURL and merchantUserAgreementURL must be set be set\n   * @returns {Promise<any>}\n   */\n  @Cordova()\n  prepareToRender(environment: string, configuration: PayPalConfiguration): Promise<any> {\n    return;\n  }\n\n  /**\n   * Start PayPal UI to collect payment from the user.\n   * See https://developer.paypal.com/webapps/developer/docs/integration/mobile/ios-integration-guide/\n   * for more documentation of the params.\n   *\n   * @param {PayPalPayment} payment PayPalPayment object\n   * @returns {Promise<any>}\n   */\n  @Cordova()\n  renderSinglePaymentUI(payment: PayPalPayment): Promise<any> {\n    return;\n  }\n\n  /**\n   * Once a user has consented to future payments, when the user subsequently initiates a PayPal payment\n   * from their device to be completed by your server, PayPal uses a Correlation ID to verify that the\n   * payment is originating from a valid, user-consented device+application.\n   * This helps reduce fraud and decrease declines.\n   * This method MUST be called prior to initiating a pre-consented payment (a \"future payment\") from a mobile device.\n   * Pass the result to your server, to include in the payment request sent to PayPal.\n   * Do not otherwise cache or store this value.\n   * @returns {Promise<any>}\n   */\n  @Cordova()\n  clientMetadataID(): Promise<any> {\n    return;\n  }\n\n  /**\n   * Please Read Docs on Future Payments at https://github.com/paypal/PayPal-iOS-SDK#future-payments\n   * @returns {Promise<any>}\n   */\n  @Cordova()\n  renderFuturePaymentUI(): Promise<any> {\n    return;\n  }\n\n  /**\n   * Please Read Docs on Profile Sharing at https://github.com/paypal/PayPal-iOS-SDK#profile-sharing\n   *\n   * @param {string[]} scopes scopes Set of requested scope-values. Accepted scopes are: openid, profile, address, email, phone, futurepayments and paypalattributes\n   * See https://developer.paypal.com/docs/integration/direct/identity/attributes/ for more details\n   * @returns {Promise<any>}\n   */\n  @Cordova()\n  renderProfileSharingUI(scopes: string[]): Promise<any> {\n    return;\n  }\n}\n\nexport interface PayPalEnvironment {\n  PayPalEnvironmentProduction: string;\n  PayPalEnvironmentSandbox: string;\n}\n\n/**\n * @hidden\n */\nexport class PayPalPayment {\n  constructor(\n    amount: string,\n    currency: string,\n    shortDescription: string,\n    intent: string,\n    details?: PayPalPaymentDetails\n  ) {\n    this.amount = amount;\n    this.currency = currency;\n    this.shortDescription = shortDescription;\n    this.intent = intent;\n    this.details = details;\n  }\n\n  /**\n   * The amount of the payment.\n   */\n  amount: string;\n  /**\n   * The ISO 4217 currency for the payment.\n   */\n  currency: string;\n  /**\n   * A short description of the payment.\n   */\n  shortDescription: string;\n  /**\n   * \"Sale\" for an immediate payment.\n   */\n  intent: string;\n  /**\n   * Optional Build Notation code (\"BN code\"), obtained from partnerprogram@paypal.com,\n   * for your tracking purposes.\n   */\n  bnCode = 'PhoneGap_SP';\n  /**\n   * Optional invoice number, for your tracking purposes. (up to 256 characters)\n   */\n  invoiceNumber: string;\n  /**\n   * Optional text, for your tracking purposes. (up to 256 characters)\n   */\n  custom: string;\n  /**\n   * Optional text which will appear on the customer's credit card statement. (up to 22 characters)\n   */\n  softDescriptor: string;\n  /**\n   * Optional array of PayPalItem objects.\n   */\n  items: PayPalItem[];\n\n  /**\n   * Optional payee email, if your app is paying a third-party merchant.\n   * The payee's email. It must be a valid PayPal email address.\n   */\n  payeeEmail: string;\n  /**\n   * Optional customer shipping address, if your app wishes to provide this to the SDK.\n   */\n  shippingAddress: string;\n  /**\n   * Optional PayPalPaymentDetails object\n   */\n  details: PayPalPaymentDetails;\n}\n\n/**\n * @hidden\n */\nexport class PayPalItem {\n  /**\n   * The PayPalItem class defines an optional itemization for a payment.\n   * @see https://developer.paypal.com/docs/api/#item-object for more details.\n   * @param {String} name: Name of the item. 127 characters max\n   * @param {Number} quantity: Number of units. 10 characters max.\n   * @param {String} price: Unit price for this item 10 characters max.\n   * May be negative for \"coupon\" etc\n   * @param {String} currency: ISO standard currency code.\n   * @param {String} sku: The stock keeping unit for this item. 50 characters max (optional)\n   */\n  constructor(name: string, quantity: number, price: string, currency: string, sku?: string) {\n    this.name = name;\n    this.quantity = quantity;\n    this.price = price;\n    this.currency = currency;\n    this.sku = sku;\n  }\n  /**\n   * Name of the item. 127 characters max\n   */\n  name: string;\n  /**\n   * Number of units. 10 characters max.\n   */\n  quantity: number;\n  /**\n   * Unit price for this item 10 characters max.\n   */\n  price: string;\n  /**\n   * ISO standard currency code.\n   */\n  currency: string;\n  /**\n   * The stock keeping unit for this item. 50 characters max (optional)\n   */\n  sku?: string;\n}\n\n/**\n * @hidden\n */\nexport class PayPalPaymentDetails {\n  /**\n   * Sub-total (amount) of items being paid for. 10 characters max with support for 2 decimal places.\n   */\n  subtotal: string;\n  /**\n   * Amount charged for shipping. 10 characters max with support for 2 decimal places.\n   */\n  shipping: string;\n  /**\n   * Amount charged for tax. 10 characters max with support for 2 decimal places.\n   */\n  tax: string;\n\n  /**\n   * The PayPalPaymentDetails class defines optional amount details.\n   * @param {String} subtotal: Sub-total (amount) of items being paid for. 10 characters max with support for 2 decimal places.\n   * @param {String} shipping: Amount charged for shipping. 10 characters max with support for 2 decimal places.\n   * @param {String} tax: Amount charged for tax. 10 characters max with support for 2 decimal places.\n   */\n  constructor(subtotal: string, shipping: string, tax: string) {\n    this.subtotal = subtotal;\n    this.shipping = shipping;\n    this.tax = tax;\n  }\n}\n\n/**\n * @hidden\n */\nexport interface PayPalConfigurationOptions {\n  /**\n   * Will be overridden by email used in most recent PayPal login.\n   */\n  defaultUserEmail?: string;\n  /**\n   * Will be overridden by phone country code used in most recent PayPal login\n   */\n  defaultUserPhoneCountryCode?: string;\n  /**\n   * Will be overridden by phone number used in most recent PayPal login.\n   */\n  defaultUserPhoneNumber?: string;\n  /**\n   * Your company name, as it should be displayed to the user when requesting consent via a PayPalFuturePaymentViewController.\n   */\n  merchantName?: string;\n  /**\n   * URL of your company's privacy policy, which will be offered to the user when requesting consent via a PayPalFuturePaymentViewController.\n   */\n  merchantPrivacyPolicyURL?: string;\n  /**\n   * URL of your company's user agreement, which will be offered to the user when requesting consent via a PayPalFuturePaymentViewController.\n   */\n  merchantUserAgreementURL?: string;\n  /**\n   * If set to NO, the SDK will only support paying with PayPal, not with credit cards.\n   * This applies only to single payments (via PayPalPaymentViewController).\n   * Future payments (via PayPalFuturePaymentViewController) always use PayPal.\n   * Defaults to true\n   */\n  acceptCreditCards?: boolean;\n  /**\n   * For single payments, options for the shipping address.\n   * - 0 - PayPalShippingAddressOptionNone: no shipping address applies.\n   * - 1 - PayPalShippingAddressOptionProvided: shipping address will be provided by your app,\n   *   in the shippingAddress property of PayPalPayment.\n   * - 2 - PayPalShippingAddressOptionPayPal: user will choose from shipping addresses on file\n   *   for their PayPal account.\n   * - 3 - PayPalShippingAddressOptionBoth: user will choose from the shipping address provided by your app,\n   *   in the shippingAddress property of PayPalPayment, plus the shipping addresses on file for the user's PayPal account.\n   * Defaults to 0 (PayPalShippingAddressOptionNone).\n   */\n  payPalShippingAddressOption?: number;\n  /**\n   * If set to YES, then if the user pays via their PayPal account,\n   * the SDK will remember the user's PayPal username or phone number;\n   * if the user pays via their credit card, then the SDK will remember\n   * the PayPal Vault token representing the user's credit card.\n   *\n   * If set to NO, then any previously-remembered username, phone number, or\n   * credit card token will be erased, and subsequent payment information will\n   * not be remembered.\n   *\n   * Defaults to YES.\n   */\n  rememberUser?: boolean;\n  /**\n   * If not set, or if set to nil, defaults to the device's current language setting.\n   *\n   * Can be specified as a language code (\"en\", \"fr\", \"zh-Hans\", etc.) or as a locale (\"en_AU\", \"fr_FR\", \"zh-Hant_HK\", etc.).\n   * If the library does not contain localized strings for a specified locale, then will fall back to the language. E.g., \"es_CO\" -> \"es\".\n   * If the library does not contain localized strings for a specified language, then will fall back to American English.\n   *\n   * If you specify only a language code, and that code matches the device's currently preferred language,\n   * then the library will attempt to use the device's current region as well.\n   * E.g., specifying \"en\" on a device set to \"English\" and \"United Kingdom\" will result in \"en_GB\".\n   */\n  languageOrLocale?: string;\n  /**\n   * Normally, the SDK blurs the screen when the app is backgrounded,\n   * to obscure credit card or PayPal account details in the iOS-saved screenshot.\n   * If your app already does its own blurring upon backgrounding, you might choose to disable this.\n   * Defaults to NO.\n   */\n  disableBlurWhenBackgrounding?: boolean;\n  /**\n   * If you will present the SDK's view controller within a popover, then set this property to YES.\n   * Defaults to NO. (iOS only)\n   */\n  presentingInPopover?: boolean;\n  /**\n   * Sandbox credentials can be difficult to type on a mobile device. Setting this flag to YES will\n   * cause the sandboxUserPassword and sandboxUserPin to always be pre-populated into login fields.\n   */\n  forceDefaultsInSandbox?: boolean;\n  /**\n   * Password to use for sandbox if 'forceDefaultsInSandbox' is set.\n   */\n  sandboxUserPassword?: string;\n  /**\n   * PIN to use for sandbox if 'forceDefaultsInSandbox' is set.\n   */\n  sandboxUserPin?: string;\n\n  /**\n   * @hidden\n   */\n  [key: string]: any;\n}\n\n/**\n * @hidden\n */\nexport class PayPalConfiguration implements PayPalConfigurationOptions {\n  /**\n   * You use a PayPalConfiguration object to configure many aspects of how the SDK behaves.\n   * see defaults for options available\n   */\n  constructor(options?: PayPalConfigurationOptions) {\n    const defaults: PayPalConfigurationOptions = {\n      defaultUserEmail: null,\n      defaultUserPhoneCountryCode: null,\n      defaultUserPhoneNumber: null,\n      merchantName: null,\n      merchantPrivacyPolicyURL: null,\n      merchantUserAgreementURL: null,\n      acceptCreditCards: true,\n      payPalShippingAddressOption: 0,\n      rememberUser: true,\n      languageOrLocale: null,\n      disableBlurWhenBackgrounding: false,\n      presentingInPopover: false,\n      forceDefaultsInSandbox: false,\n      sandboxUserPassword: null,\n      sandboxUserPin: null,\n    };\n\n    if (options && typeof options === 'object') {\n      for (const i in options) {\n        if (defaults.hasOwnProperty(i)) {\n          defaults[i] = options[i];\n        }\n      }\n    }\n\n    return defaults;\n  }\n}\n\n/**\n * @hidden\n */\nexport class PayPalShippingAddress {\n  /**\n   * See the documentation of the individual properties for more detail.\n   * @param {String} recipientName: Name of the recipient at this address. 50 characters max.\n   * @param {String} line1: Line 1 of the address (e.g., Number, street, etc). 100 characters max.\n   * @param {String} line2: Line 2 of the address (e.g., Suite, apt #, etc). 100 characters max. Optional.\n   * @param {String} city: City name. 50 characters max.\n   * @param {String} state: 2-letter code for US states, and the equivalent for other countries. 100 characters max. Required in certain countries.\n   * @param {String} postalCode: ZIP code or equivalent is usually required for countries that have them. 20 characters max. Required in certain countries.\n   * @param {String} countryCode: 2-letter country code. 2 characters max.\n   */\n  constructor(\n    recipientName: string,\n    line1: string,\n    line2: string,\n    city: string,\n    state: string,\n    postalCode: string,\n    countryCode: string\n  ) {\n    this.recipientName = recipientName;\n    this.line1 = line1;\n    this.line2 = line2;\n    this.city = city;\n    this.state = state;\n    this.postalCode = postalCode;\n    this.countryCode = countryCode;\n  }\n  /**\n   * Name of the recipient at this address. 50 characters max.\n   */\n  recipientName: string;\n  /**\n   * Line 1 of the address (e.g., Number, street, etc). 100 characters max.\n   */\n  line1: string;\n  /**\n   * Line 2 of the address (e.g., Suite, apt #, etc). 100 characters max. Optional.\n   */\n  line2: string;\n  /**\n   * City name. 50 characters max.\n   */\n  city: string;\n  /**\n   * 2-letter code for US states, and the equivalent for other countries. 100 characters max. Required in certain countries.\n   */\n  state: string;\n  /**\n   * ZIP code or equivalent is usually required for countries that have them. 20 characters max. Required in certain countries.\n   */\n  postalCode: string;\n  /**\n   * 2-letter country code. 2 characters max.\n   */\n  countryCode: string;\n}\n"]}
\No newline at end of file