@lightspeed/online-payments-sdk 1.4.2 → 1.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -5,7 +5,9 @@ exports.isTokenValid = isTokenValid;
5
5
  var error_1 = require("./error");
6
6
  function decodePaymentSessionToContext(paymentSession) {
7
7
  try {
8
- var decoded = atob(paymentSession);
8
+ var binary = atob(paymentSession);
9
+ var bytes = Uint8Array.from(binary, function (c) { return c.charCodeAt(0); });
10
+ var decoded = new TextDecoder('utf-8', { fatal: true }).decode(bytes);
9
11
  var jsonToken = JSON.parse(decoded);
10
12
  if (jsonToken && isTokenValid(jsonToken)) {
11
13
  return jsonToken;
@@ -92,10 +92,11 @@ function initStripe(context, theme) {
92
92
  * @param defaultValues - Default values for the payment element
93
93
  * @param theme - Theme configuration
94
94
  * @param hideNameField - Whether to hide the billing details name field (used when address element is present to avoid duplicates with ACH)
95
+ * @param businessName - Overrides the merchant name Stripe renders in mandate text (passed to `business.name`)
95
96
  */
96
- function createPaymentElementOptions(defaultValues, theme, hideNameField) {
97
+ function createPaymentElementOptions(defaultValues, theme, hideNameField, businessName) {
97
98
  if (hideNameField === void 0) { hideNameField = false; }
98
- var options = __assign(__assign({ wallets: {
99
+ var options = __assign(__assign(__assign({ wallets: {
99
100
  applePay: 'never',
100
101
  googlePay: 'never',
101
102
  link: 'never',
@@ -107,7 +108,7 @@ function createPaymentElementOptions(defaultValues, theme, hideNameField) {
107
108
  },
108
109
  })), { terms: {
109
110
  usBankAccount: 'never', // Hide Stripe's default T&Cs (shown for ACH payments)
110
- } });
111
+ } }), (businessName && { business: { name: businessName } }));
111
112
  if (defaultValues) {
112
113
  options.defaultValues = {
113
114
  billingDetails: {
@@ -50,7 +50,7 @@ function mountMotoWidget(mountElement, session, eventBroadcaster, defaultValues,
50
50
  case 0: return [4 /*yield*/, (0, shared_1.initStripe)(session.context, theme)];
51
51
  case 1:
52
52
  _a = _c.sent(), stripe = _a.stripe, elements = _a.elements;
53
- paymentOptions = (0, shared_1.createPaymentElementOptions)(defaultValues, theme);
53
+ paymentOptions = (0, shared_1.createPaymentElementOptions)(defaultValues, theme, false, session.context.businessName);
54
54
  _b = (0, shared_1.createPaymentElement)(elements, paymentOptions, mountElement, eventBroadcaster), paymentElement = _b.element, paymentContainer = _b.container, customTermsContainer = _b.customTermsContainer;
55
55
  // Setup change handler for payment element only (MOTO forms don't have address element)
56
56
  (0, shared_1.setupChangeEventHandler)(paymentElement, eventBroadcaster);
@@ -51,7 +51,7 @@ function mountPaymentWidget(mountElement, session, eventBroadcaster, defaultValu
51
51
  _a = _d.sent(), stripe = _a.stripe, elements = _a.elements;
52
52
  addressOptions = (0, shared_1.createAddressElementOptions)(defaultValues);
53
53
  _b = (0, shared_1.createAddressElement)(elements, addressOptions, mountElement), addressElement = _b.element, addressContainer = _b.container;
54
- paymentOptions = (0, shared_1.createPaymentElementOptions)(defaultValues, theme, true);
54
+ paymentOptions = (0, shared_1.createPaymentElementOptions)(defaultValues, theme, true, session.context.businessName);
55
55
  _c = (0, shared_1.createPaymentElement)(elements, paymentOptions, mountElement, eventBroadcaster), paymentElement = _c.element, paymentContainer = _c.container, customTermsContainer = _c.customTermsContainer;
56
56
  // Setup change handler that emits Complete only when both elements are complete
57
57
  (0, shared_1.setupChangeEventHandler)(paymentElement, eventBroadcaster, addressElement);
@@ -3,4 +3,4 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.SDK_VERSION = void 0;
4
4
  // This file is auto-generated during the build process
5
5
  // DO NOT EDIT MANUALLY - Version is extracted from package.json
6
- exports.SDK_VERSION = '1.4.2';
6
+ exports.SDK_VERSION = '1.5.0';
@@ -1,7 +1,9 @@
1
1
  import { InvalidSessionPayloadError, InvalidSessionError } from './error';
2
2
  export function decodePaymentSessionToContext(paymentSession) {
3
3
  try {
4
- var decoded = atob(paymentSession);
4
+ var binary = atob(paymentSession);
5
+ var bytes = Uint8Array.from(binary, function (c) { return c.charCodeAt(0); });
6
+ var decoded = new TextDecoder('utf-8', { fatal: true }).decode(bytes);
5
7
  var jsonToken = JSON.parse(decoded);
6
8
  if (jsonToken && isTokenValid(jsonToken)) {
7
9
  return jsonToken;
@@ -11,4 +11,5 @@ export type StripeContext = {
11
11
  intent: 'save-card' | 'payment';
12
12
  locale?: StripeElementLocale;
13
13
  redirectUrl?: string;
14
+ businessName?: string;
14
15
  };
@@ -21,8 +21,9 @@ export declare function initStripe(context: StripeContext, theme?: PaymentWidget
21
21
  * @param defaultValues - Default values for the payment element
22
22
  * @param theme - Theme configuration
23
23
  * @param hideNameField - Whether to hide the billing details name field (used when address element is present to avoid duplicates with ACH)
24
+ * @param businessName - Overrides the merchant name Stripe renders in mandate text (passed to `business.name`)
24
25
  */
25
- export declare function createPaymentElementOptions(defaultValues?: DefaultValues, theme?: PaymentWidgetTheme, hideNameField?: boolean): StripePaymentElementOptions;
26
+ export declare function createPaymentElementOptions(defaultValues?: DefaultValues, theme?: PaymentWidgetTheme, hideNameField?: boolean, businessName?: string): StripePaymentElementOptions;
26
27
  /**
27
28
  * Create address element options
28
29
  */
@@ -80,10 +80,11 @@ export function initStripe(context, theme) {
80
80
  * @param defaultValues - Default values for the payment element
81
81
  * @param theme - Theme configuration
82
82
  * @param hideNameField - Whether to hide the billing details name field (used when address element is present to avoid duplicates with ACH)
83
+ * @param businessName - Overrides the merchant name Stripe renders in mandate text (passed to `business.name`)
83
84
  */
84
- export function createPaymentElementOptions(defaultValues, theme, hideNameField) {
85
+ export function createPaymentElementOptions(defaultValues, theme, hideNameField, businessName) {
85
86
  if (hideNameField === void 0) { hideNameField = false; }
86
- var options = __assign(__assign({ wallets: {
87
+ var options = __assign(__assign(__assign({ wallets: {
87
88
  applePay: 'never',
88
89
  googlePay: 'never',
89
90
  link: 'never',
@@ -95,7 +96,7 @@ export function createPaymentElementOptions(defaultValues, theme, hideNameField)
95
96
  },
96
97
  })), { terms: {
97
98
  usBankAccount: 'never', // Hide Stripe's default T&Cs (shown for ACH payments)
98
- } });
99
+ } }), (businessName && { business: { name: businessName } }));
99
100
  if (defaultValues) {
100
101
  options.defaultValues = {
101
102
  billingDetails: {
@@ -47,7 +47,7 @@ export function mountMotoWidget(mountElement, session, eventBroadcaster, default
47
47
  case 0: return [4 /*yield*/, initStripe(session.context, theme)];
48
48
  case 1:
49
49
  _a = _c.sent(), stripe = _a.stripe, elements = _a.elements;
50
- paymentOptions = createPaymentElementOptions(defaultValues, theme);
50
+ paymentOptions = createPaymentElementOptions(defaultValues, theme, false, session.context.businessName);
51
51
  _b = createPaymentElement(elements, paymentOptions, mountElement, eventBroadcaster), paymentElement = _b.element, paymentContainer = _b.container, customTermsContainer = _b.customTermsContainer;
52
52
  // Setup change handler for payment element only (MOTO forms don't have address element)
53
53
  setupChangeEventHandler(paymentElement, eventBroadcaster);
@@ -48,7 +48,7 @@ export function mountPaymentWidget(mountElement, session, eventBroadcaster, defa
48
48
  _a = _d.sent(), stripe = _a.stripe, elements = _a.elements;
49
49
  addressOptions = createAddressElementOptions(defaultValues);
50
50
  _b = createAddressElement(elements, addressOptions, mountElement), addressElement = _b.element, addressContainer = _b.container;
51
- paymentOptions = createPaymentElementOptions(defaultValues, theme, true);
51
+ paymentOptions = createPaymentElementOptions(defaultValues, theme, true, session.context.businessName);
52
52
  _c = createPaymentElement(elements, paymentOptions, mountElement, eventBroadcaster), paymentElement = _c.element, paymentContainer = _c.container, customTermsContainer = _c.customTermsContainer;
53
53
  // Setup change handler that emits Complete only when both elements are complete
54
54
  setupChangeEventHandler(paymentElement, eventBroadcaster, addressElement);
package/dist/version.d.ts CHANGED
@@ -1 +1 @@
1
- export declare const SDK_VERSION = "1.4.2";
1
+ export declare const SDK_VERSION = "1.5.0";
package/dist/version.js CHANGED
@@ -1,3 +1,3 @@
1
1
  // This file is auto-generated during the build process
2
2
  // DO NOT EDIT MANUALLY - Version is extracted from package.json
3
- export var SDK_VERSION = '1.4.2';
3
+ export var SDK_VERSION = '1.5.0';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@lightspeed/online-payments-sdk",
3
- "version": "1.4.2",
3
+ "version": "1.5.0",
4
4
  "description": "Process online-payments with Lightspeed Payments",
5
5
  "author": "Lightspeed Commerce Inc.",
6
6
  "license": "SEE LICENSE IN LICENSE.md",