-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
36 lines (36 loc) · 17.5 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
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, cordova } from '@ionic-native/core';
import { Observable } from 'rxjs';
var ApplePayOriginal = /** @class */ (function (_super) {
__extends(ApplePayOriginal, _super);
function ApplePayOriginal() {
return _super !== null && _super.apply(this, arguments) || this;
}
ApplePayOriginal.prototype.canMakePayments = function () { return cordova(this, "canMakePayments", { "otherPromise": true }, arguments); };
ApplePayOriginal.prototype.startListeningForShippingContactSelection = function () { return cordova(this, "startListeningForShippingContactSelection", { "observable": true, "clearFunction": "stopListeningForShippingContactSelection" }, arguments); };
ApplePayOriginal.prototype.stopListeningForShippingContactSelection = function () { return cordova(this, "stopListeningForShippingContactSelection", { "otherPromise": true }, arguments); };
ApplePayOriginal.prototype.updateItemsAndShippingMethods = function (list) { return cordova(this, "updateItemsAndShippingMethods", { "otherPromise": true }, arguments); };
ApplePayOriginal.prototype.makePaymentRequest = function (order) { return cordova(this, "makePaymentRequest", { "otherPromise": true }, arguments); };
ApplePayOriginal.prototype.completeLastTransaction = function (complete) { return cordova(this, "completeLastTransaction", { "otherPromise": true }, arguments); };
ApplePayOriginal.pluginName = "ApplePay";
ApplePayOriginal.plugin = "cordova-plugin-applepay";
ApplePayOriginal.pluginRef = "ApplePay";
ApplePayOriginal.repo = "https://github.com/samkelleher/cordova-plugin-applepay";
ApplePayOriginal.platforms = ["iOS"];
return ApplePayOriginal;
}(IonicNativePlugin));
var ApplePay = new ApplePayOriginal();
export { ApplePay };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/@ionic-native/plugins/apple-pay/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;AACA,OAAO,8BAAsC,MAAM,oBAAoB,CAAC;AACxE,OAAO,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;;IAsJJ,4BAAiB;;;;IAmB7C,kCAAe;IAgBf,4DAAyC;IAYzC,2DAAwC;IA0CxC,gDAA6B,aAAC,IAAmC;IA6EjE,qCAAkB,aAAC,KAAa;IAgBhC,0CAAuB,aAAC,QAA4B;;;;;;mBA9UtD;EAwJ8B,iBAAiB;SAAlC,QAAQ","sourcesContent":["import { Injectable } from '@angular/core';\nimport { Cordova, IonicNativePlugin, Plugin } from '@ionic-native/core';\nimport { Observable } from 'rxjs';\n\nexport type IMakePayments =\n  | 'This device can make payments and has a supported card'\n  | 'This device cannot make payments.'\n  | 'This device can make payments but has no supported cards';\nexport type IShippingType = 'shipping' | 'delivery' | 'store' | 'service';\nexport type IBillingRequirement = 'none' | 'all' | 'postcode' | 'name' | 'email' | 'phone';\nexport type ITransactionStatus =\n  | 'success'\n  | 'failure'\n  | 'invalid-billing-address'\n  | 'invalid-shipping-address'\n  | 'invalid-shipping-contact'\n  | 'require-pin'\n  | 'incorrect-pin'\n  | 'locked-pin';\nexport type ICompleteTransaction = 'Payment status applied.';\nexport type IUpdateItemsAndShippingStatus = 'Updated List Info' | 'Did you make a payment request?';\nexport type IMerchantCapabilities = '3ds' | 'credit' | 'debit' | 'emv';\nexport type ISupportedNetworks = 'visa' | 'amex' | 'discover' | 'masterCard';\n\nexport interface IPaymentResponse {\n  billingNameFirst?: string;\n  billingNameMiddle?: string;\n  billingNameLast?: string;\n  billingEmailAddress?: string;\n  billingSupplementarySubLocality?: string;\n  billingAddressStreet?: string;\n  billingAddressCity?: string;\n  billingAddressState?: string;\n  billingPostalCode?: string;\n  billingCountry?: string;\n  billingISOCountryCode?: string;\n\n  shippingNameFirst?: string;\n  shippingNameMiddle?: string;\n  shippingNameLast?: string;\n  shippingEmailAddress?: string;\n  shippingPhoneNumber?: string;\n  shippingSupplementarySubLocality?: string;\n  shippingAddressStreet?: string;\n  shippingAddressCity?: string;\n  shippingAddressState?: string;\n  shippingPostalCode?: string;\n  shippingCountry?: string;\n  shippingISOCountryCode?: string;\n\n  paymentData: string;\n  transactionIdentifier: string;\n  paymentMethodDisplayName?: string;\n  paymentMethodNetwork?: string;\n  paymentMethodTypeCard?: string;\n}\n\nexport interface IOrderItem {\n  label: string;\n  amount: number;\n}\nexport interface IShippingMethod {\n  identifier: string;\n  label: string;\n  detail: string;\n  amount: number;\n}\n\nexport interface IOrderItemsAndShippingMethods {\n  items: IOrderItem[];\n  shippingMethods?: IShippingMethod[];\n}\n\nexport interface IOrder extends IOrderItemsAndShippingMethods {\n  merchantIdentifier: string;\n  currencyCode: string;\n  countryCode: string;\n  billingAddressRequirement?: IBillingRequirement | IBillingRequirement[];\n  shippingAddressRequirement?: IBillingRequirement | IBillingRequirement[];\n  shippingType?: IShippingType;\n  merchantCapabilities?: IMerchantCapabilities | IMerchantCapabilities[];\n  supportedNetworks?: ISupportedNetworks | ISupportedNetworks[];\n}\n\nexport interface ISelectedShippingContact {\n  shippingAddressCity: string;\n  shippingAddressState: string;\n  shippingPostalCode: string;\n  shippingISOCountryCode: string;\n}\n\n/**\n * @name Apple Pay\n * @description\n * A dependency free Cordova plugin to provide Apple Pay functionality.\n *\n * @usage\n * ```typescript\n * import { ApplePay } from '@ionic-native/apple-pay/ngx';\n *\n *\n * constructor(private applePay: ApplePay) { }\n *\n * ...\n * async applePay() {\n *   // This block is optional -- only if you need to update order items/shipping\n *   // methods in response to shipping method selections\n *   this.applePay.startListeningForShippingContactSelection()\n *     .subscribe(async selection => {\n *       try {\n *         await this.applePay.updateItemsAndShippingMethods({\n *           items: getFromSelection(selection),\n *           shippingMethods: getFromSelection(selection),\n *         });\n *       }\n *       catch {\n *         // handle update items error\n *       }\n *     });\n *\n *   try {\n *     const applePayTransaction = await this.applePay.makePaymentRequest({\n *       items,\n *       shippingMethods,\n *       merchantIdentifier,\n *       currencyCode,\n *       countryCode,\n *       billingAddressRequirement: ['name', 'email', 'phone'],\n *       shippingAddressRequirement: 'none',\n *       shippingType: 'shipping'\n *     });\n *\n *     const transactionStatus = await completeTransactionWithMerchant(applePayTransaction);\n *     await this.applePay.completeLastTransaction(transactionStatus);\n *   } catch {\n *     // handle payment request error\n *     // Can also handle stop complete transaction but these should normally not occur\n *   }\n *\n *   // only if you started listening before\n *   await this.applePay.stopListeningForShippingContactSelection();\n * }\n * ```\n */\n@Plugin({\n  pluginName: 'ApplePay',\n  plugin: 'cordova-plugin-applepay',\n  pluginRef: 'ApplePay',\n  repo: 'https://github.com/samkelleher/cordova-plugin-applepay',\n  platforms: ['iOS'],\n})\n@Injectable()\nexport class ApplePay extends IonicNativePlugin {\n  /**\n   * Detects if the current device supports Apple Pay and has any capable cards registered.\n   * @return {Promise<IMakePayments>} Returns a promise\n   *\n   * @usage\n   * try {\n   *   const message = await this.applePay.canMakePayments();\n   *   // Apple Pay is enabled and a supported card is setup. Expect:\n   *   // 'This device can make payments and has a supported card'\n   * } catch (message) {\n   *   // There is an issue, examine the message to see the details, will be:\n   *   // 'This device cannot make payments.''\n   *   // 'This device can make payments but has no supported cards'\n   * }\n   */\n  @Cordova({\n    otherPromise: true,\n  })\n  canMakePayments(): Promise<IMakePayments> {\n    return;\n  }\n\n  /**\n   * Starts listening for shipping contact selection changes\n   * Any time the user selects shipping contact, this callback will fire.\n   * You *must* call `updateItemsAndShippingMethods` in response or else the\n   * user will not be able to process payment.\n   * @return {Observable<ISelectedShippingContact>} emits with shipping contact information on\n   *   shipping contact selection changes\n   */\n  @Cordova({\n    observable: true,\n    clearFunction: 'stopListeningForShippingContactSelection',\n  })\n  startListeningForShippingContactSelection(): Observable<ISelectedShippingContact> {\n    return;\n  }\n\n  /**\n   * Stops listening for shipping contact selection changes\n   * @return {Promise} whether stop listening was successful. This should\n   *   really only fail if this is called without starting listening\n   */\n  @Cordova({\n    otherPromise: true,\n  })\n  stopListeningForShippingContactSelection(): Promise<boolean> {\n    return;\n  }\n\n  /**\n   * Update the list of pay sheet items and shipping methods in response to\n   * a shipping contact selection event. This *must* be called in response to\n   * any shipping contact selection event or else the user will not be able\n   * to complete a transaction on the pay sheet. Do not call without\n   * subscribing to shipping contact selection events first\n   *\n   * @param {IOrderItemsAndShippingMethods} list `items` and `shippingMethods` properties.\n   * @returns {Promise<IUpdateItemsAndShippingStatus>}\n   *\n   * @usage\n   * this.applePay.startListeningForShippingContactSelection().pluck('shippingAddressState').subscribe(shippingAddressState => {\n   *   let shippingMethods;\n   *   if ('AK' === shippingAddressState) {\n   *     shippingMethods = [{\n   *         identifier: 'Alaska',\n   *         label: 'Alaska',\n   *         detail: 'For shipping to Alaska',\n   *         amount: 9.99\n   *     },];\n   *   } else {\n   *     shippingMethods = [{\n   *         identifier: 'Continental',\n   *         label: 'Continental',\n   *         detail: 'For shipping Continentally',\n   *         amount: 5.99\n   *     }];\n   *   }\n   *   this.paySheetItems.shippingCost = {\n   *      label: 'Shipping Cost',\n   *      amount: shippingMethod[0].amount\n   *   }\n   *   this.applePay.updateItemsAndShippingMethods(this.paySheetItems, shippingMethods);\n   * });\n   */\n  @Cordova({\n    otherPromise: true,\n  })\n  updateItemsAndShippingMethods(list: IOrderItemsAndShippingMethods): Promise<IUpdateItemsAndShippingStatus> {\n    return;\n  }\n\n  /**\n   * Request a payment with Apple Pay\n   *\n   * @param {IOrder} order\n   * @return {Promise<IPaymentResponse>} Returns a promise that resolves when something happens\n   *\n   * @usage\n   * try {\n   *   const paymentResponse = this.applePay.makePaymentRequest({\n   *     items: [\n   *       {\n   *         label: '3 x Basket Items',\n   *         amount: 49.99\n   *       },\n   *       {\n   *         label: 'Next Day Delivery',\n   *         amount: 3.99\n   *       },\n   *       {\n   *         label: 'My Fashion Company',\n   *         amount: 53.98\n   *       }\n   *     ],\n   *     shippingMethods: [\n   *       {\n   *         identifier: 'NextDay',\n   *         label: 'NextDay',\n   *         detail: 'Arrives tomorrow by 5pm.',\n   *         amount: 3.99\n   *       },\n   *       {\n   *         identifier: 'Standard',\n   *         label: 'Standard',\n   *         detail: 'Arrive by Friday.',\n   *         amount: 4.99\n   *       },\n   *       {\n   *         identifier: 'SaturdayDelivery',\n   *         label: 'Saturday',\n   *         detail: 'Arrive by 5pm this Saturday.',\n   *         amount: 6.99\n   *       }\n   *     ],\n   *     merchantIdentifier: 'merchant.apple.test',\n   *     currencyCode: 'GBP',\n   *     countryCode: 'GB',\n   *     billingAddressRequirement: 'none',\n   *     shippingAddressRequirement: 'none',\n   *     shippingType: 'shipping',\n   *   });\n   *\n   *   // The user has authorized the payment.\n   *\n   *   // Handle the token, asynchronously, i.e. pass to your merchant bank to\n   *   // action the payment, then once finished, depending on the outcome:\n   *\n   *   // Here is an example implementation:\n   *\n   *   const captureStatus = await MyPaymentProvider.authorizeApplePayToken(paymentResponse.paymentData);\n   *   await this.applePay.completeLastTransaction('success');\n   * }\n   * catch (err) {\n   *   if (isPaymentAuthError(err)) {\n   *     this.completeLastTransaction('failure');\n   *   }\n   *   else {\n   *     // Failed to open pay sheet or user canceled payment\n   *   }\n   * }\n   */\n  @Cordova({\n    otherPromise: true,\n  })\n  makePaymentRequest(order: IOrder): Promise<IPaymentResponse> {\n    return;\n  }\n\n  /**\n   * Once the makePaymentRequest has been resolved successfully, the device will be waiting for a completion event.\n   * This means, that the application must proceed with the token authorization and return a success, failure,\n   * or other validation error. Once this has been passed back, the Apple Pay sheet will be dismissed via an animation.\n   *\n   * @param {ITransactionStatus} complete\n   * @return {Promise<ICompleteTransaction>} Returns a promise that resolves after confirmation of payment authorization completion\n   *\n   */\n  @Cordova({\n    otherPromise: true,\n  })\n  completeLastTransaction(complete: ITransactionStatus): Promise<ICompleteTransaction> {\n    return;\n  }\n}\n"]}