1 | import { __decorate, __extends } from "tslib";
|
2 | import { Injectable } from '@angular/core';
|
3 | import { IonicNativePlugin, cordova } from '@ionic-native/core';
|
4 | var 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));
|
26 | export { PayPal };
|
27 | var 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 | }());
|
42 | export { PayPalPayment };
|
43 | var 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 | }());
|
63 | export { PayPalItem };
|
64 | var 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 | }());
|
78 | export { PayPalPaymentDetails };
|
79 | var 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 | }());
|
113 | export { PayPalConfiguration };
|
114 | var 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 | }());
|
136 | export { 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 |