tf-checkout-react 1.3.24 → 1.3.26

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.
@@ -10,8 +10,9 @@ export interface IAddonContainterProps {
10
10
  onConfirmSelectionSuccess?: (res: any) => void;
11
11
  onConfirmSelectionError?: (error: any) => void;
12
12
  onCountdownFinish?: () => void;
13
+ samePageBilling?: boolean;
13
14
  }
14
15
  export interface ObjectLiteral {
15
16
  [key: string]: any;
16
17
  }
17
- export declare const AddonsContainter: ({ classNamePrefix, enableBillingInfoAutoCreate, enableTimer, onGetAddonsPageInfoSuccess, onGetAddonsPageInfoError, onPostCheckoutSuccess, onPostCheckoutError, onConfirmSelectionSuccess, onConfirmSelectionError, onCountdownFinish, }: IAddonContainterProps) => JSX.Element;
18
+ export declare const AddonsContainter: ({ classNamePrefix, enableBillingInfoAutoCreate, enableTimer, onGetAddonsPageInfoSuccess, onGetAddonsPageInfoError, onPostCheckoutSuccess, onPostCheckoutError, onConfirmSelectionSuccess, onConfirmSelectionError, onCountdownFinish, samePageBilling, }: IAddonContainterProps) => JSX.Element;
@@ -1,5 +1,5 @@
1
- import { ReactNode } from 'react';
2
1
  import './style.css';
2
+ import { ReactNode } from 'react';
3
3
  interface ITicketsSectionProps {
4
4
  ticketsList: any;
5
5
  selectedTickets: any;
@@ -67,6 +67,7 @@ var TablePagination = _interopDefault(require('@mui/material/TablePagination'));
67
67
  var TableRow = _interopDefault(require('@mui/material/TableRow'));
68
68
  var _has = _interopDefault(require('lodash/has'));
69
69
  var Radio = _interopDefault(require('@mui/material/Radio'));
70
+ var lodash = require('lodash');
70
71
  var _isNull = _interopDefault(require('lodash/isNull'));
71
72
  var _reverse = _interopDefault(require('lodash/reverse'));
72
73
 
@@ -5442,7 +5443,12 @@ var TicketsSection = function TicketsSection(_ref) {
5442
5443
  ticketsHeaderComponent = _ref.ticketsHeaderComponent,
5443
5444
  hideTicketsHeader = _ref.hideTicketsHeader;
5444
5445
  var sortedTicketsList = sortBySoldOut ? _sortBy(_sortBy(ticketsList, 'sortOrder'), 'soldOut') : _sortBy(ticketsList, 'sortOrder');
5446
+ var showGroup = !!sortedTicketsList.find(function (ticket) {
5447
+ return ticket.groupName;
5448
+ });
5445
5449
  return React__default.createElement(React__default.Fragment, null, !hideTicketsHeader && ticketsHeaderComponent, sortedTicketsList.map(function (ticket, i, arr) {
5450
+ var _arr;
5451
+
5446
5452
  var isSoldOut = ticket.sold_out || !ticket.displayTicket || ticket.soldOut;
5447
5453
 
5448
5454
  var ticketSelect = function ticketSelect(event) {
@@ -5457,9 +5463,13 @@ var TicketsSection = function TicketsSection(_ref) {
5457
5463
  }
5458
5464
 
5459
5465
  var ticketIsFree = +ticket.price === 0;
5460
- var ticketPrice = isSoldOut ? 'SOLD OUT' : ticketIsFree ? 'FREE' : "$ " + (+ticket.price).toFixed(2);
5461
- return React__default.createElement("div", {
5462
- key: ticket.id || ticket.name,
5466
+ var ticketPrice = isSoldOut ? 'SOLD OUT' : ticketIsFree ? 'FREE' : "\xA3 " + (+ticket.price).toFixed(2);
5467
+ var isNewGroupTicket = (ticket == null ? void 0 : ticket.groupName) !== ((_arr = arr[i - 1]) == null ? void 0 : _arr.groupName);
5468
+ return React__default.createElement(React__default.Fragment, {
5469
+ key: ticket.id || ticket.name
5470
+ }, showGroup && isNewGroupTicket ? React__default.createElement("div", {
5471
+ className: 'event-detail__tier group-title'
5472
+ }, ticket.groupName || '') : null, React__default.createElement("div", {
5463
5473
  className: "event-detail__tier " + (isSoldOut ? 'disabled' : '')
5464
5474
  }, React__default.createElement("div", {
5465
5475
  className: "event-detail__tier-name"
@@ -5469,7 +5479,7 @@ var TicketsSection = function TicketsSection(_ref) {
5469
5479
  className: "event-detail__tier-price"
5470
5480
  }, ticketIsDiscounted && React__default.createElement("p", {
5471
5481
  className: "old-price"
5472
- }, "$ ", (+ticket.oldPrice).toFixed(2)), React__default.createElement("p", {
5482
+ }, "\xA3 ", (+ticket.oldPrice).toFixed(2)), React__default.createElement("p", {
5473
5483
  className: isSoldOut ? 'sold-out' : ''
5474
5484
  }, ticketPrice), !isSoldOut && !ticketIsFree && React__default.createElement("p", {
5475
5485
  className: "fees"
@@ -5483,7 +5493,7 @@ var TicketsSection = function TicketsSection(_ref) {
5483
5493
  prevTicketTier: arr[i - 1],
5484
5494
  selectedTickets: selectedTickets,
5485
5495
  handleTicketSelect: ticketSelect
5486
- }))));
5496
+ })))));
5487
5497
  }));
5488
5498
  };
5489
5499
 
@@ -7647,8 +7657,11 @@ var AddonsContainter = function AddonsContainter(_ref) {
7647
7657
  _ref$onConfirmSelecti2 = _ref.onConfirmSelectionError,
7648
7658
  onConfirmSelectionError = _ref$onConfirmSelecti2 === void 0 ? _identity : _ref$onConfirmSelecti2,
7649
7659
  _ref$onCountdownFinis = _ref.onCountdownFinish,
7650
- _onCountdownFinish = _ref$onCountdownFinis === void 0 ? _identity : _ref$onCountdownFinis;
7660
+ _onCountdownFinish = _ref$onCountdownFinis === void 0 ? _identity : _ref$onCountdownFinis,
7661
+ _ref$samePageBilling = _ref.samePageBilling,
7662
+ samePageBilling = _ref$samePageBilling === void 0 ? false : _ref$samePageBilling;
7651
7663
 
7664
+ var valuesRef = React.useRef(null);
7652
7665
  var eventId = getQueryVariable('event_id');
7653
7666
 
7654
7667
  var _useState = React.useState([]),
@@ -7825,7 +7838,7 @@ var AddonsContainter = function AddonsContainter(_ref) {
7825
7838
  collectOptionalWalletAddress = (_pageConfigsData$coll = pageConfigsData.collect_optional_wallet_address) != null ? _pageConfigsData$coll : false;
7826
7839
  collectMandatoryWalletAddress = (_pageConfigsData$coll2 = pageConfigsData.collect_mandatory_wallet_address) != null ? _pageConfigsData$coll2 : false;
7827
7840
 
7828
- if (!(skipBillingPage && enableBillingInfoAutoCreate)) {
7841
+ if (!(skipBillingPage && enableBillingInfoAutoCreate && !samePageBilling)) {
7829
7842
  _context2.next = 36;
7830
7843
  break;
7831
7844
  }
@@ -7929,6 +7942,7 @@ var AddonsContainter = function AddonsContainter(_ref) {
7929
7942
  }));
7930
7943
  }
7931
7944
 
7945
+ var flagHasAddOn = getQueryVariable('hasAddOn') === 'true';
7932
7946
  return React__default.createElement(React__default.Fragment, null, !!cartExpirationTime && enableTimer && React__default.createElement(TimerWidget$1, {
7933
7947
  expires_at: cartExpirationTime,
7934
7948
  onCountdownFinish: function onCountdownFinish() {
@@ -7936,7 +7950,7 @@ var AddonsContainter = function AddonsContainter(_ref) {
7936
7950
 
7937
7951
  _onCountdownFinish();
7938
7952
  }
7939
- }), React__default.createElement("div", {
7953
+ }), samePageBilling && !flagHasAddOn ? null : React__default.createElement("div", {
7940
7954
  className: classNamePrefix + "_container"
7941
7955
  }, React__default.createElement("div", {
7942
7956
  className: classNamePrefix + "_block"
@@ -7944,7 +7958,7 @@ var AddonsContainter = function AddonsContainter(_ref) {
7944
7958
  className: classNamePrefix + "_line_block"
7945
7959
  }, React__default.createElement("p", {
7946
7960
  className: classNamePrefix + "_info_title"
7947
- }, "Get Your Tickets"), React__default.createElement("button", {
7961
+ }, "Get Your Tickets"), samePageBilling ? null : React__default.createElement("button", {
7948
7962
  type: "button",
7949
7963
  className: classNamePrefix + "_skip",
7950
7964
  onClick: function onClick() {
@@ -7962,6 +7976,11 @@ var AddonsContainter = function AddonsContainter(_ref) {
7962
7976
  }
7963
7977
  }, function (_ref4) {
7964
7978
  var values = _ref4.values;
7979
+
7980
+ if (!lodash.isEqual(values, valuesRef.current)) {
7981
+ valuesRef.current = values;
7982
+ }
7983
+
7965
7984
  var isConfirmDisabled = !isAtLeastOneAddonSelected(values);
7966
7985
  return React__default.createElement(formik.Form, {
7967
7986
  autoComplete: "off",
@@ -8001,7 +8020,13 @@ var AddonsContainter = function AddonsContainter(_ref) {
8001
8020
  selectOptions: addonsOptions[variant.id],
8002
8021
  classNamePrefix: classNamePrefix,
8003
8022
  handleAddonChange: function handleAddonChange(id, value) {
8004
- return onFieldChange(id, value, addon);
8023
+ onFieldChange(id, value, addon);
8024
+
8025
+ if (samePageBilling) {
8026
+ setTimeout(function () {
8027
+ handleConfirm(valuesRef.current);
8028
+ }, 100);
8029
+ }
8005
8030
  }
8006
8031
  })
8007
8032
  );
@@ -8012,10 +8037,16 @@ var AddonsContainter = function AddonsContainter(_ref) {
8012
8037
  selectOptions: addonsOptions[addon.id],
8013
8038
  classNamePrefix: classNamePrefix,
8014
8039
  handleAddonChange: function handleAddonChange(id, value) {
8015
- return onFieldChange(id, value, addon);
8040
+ onFieldChange(id, value, addon);
8041
+
8042
+ if (samePageBilling) {
8043
+ setTimeout(function () {
8044
+ handleConfirm(valuesRef.current);
8045
+ }, 100);
8046
+ }
8016
8047
  }
8017
8048
  })));
8018
- }), React__default.createElement("button", {
8049
+ }), samePageBilling ? null : React__default.createElement("button", {
8019
8050
  type: "submit",
8020
8051
  className: (isConfirmDisabled ? classNamePrefix + "_is_disabled" : '') + " " + classNamePrefix + "_submit_button",
8021
8052
  disabled: isConfirmDisabled