@rpg-engine/long-bow 0.8.131 → 0.8.134

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.
@@ -0,0 +1,8 @@
1
+ import React from 'react';
2
+ export interface IPaymentMethodModalProps {
3
+ dcBalance: number;
4
+ onPayWithDC: () => void;
5
+ onPayWithCard: () => void;
6
+ onClose: () => void;
7
+ }
8
+ export declare const PaymentMethodModal: React.FC<IPaymentMethodModalProps>;
@@ -10,6 +10,7 @@ export interface IStoreProps {
10
10
  onShowHistory?: () => void;
11
11
  onShowWallet?: () => void;
12
12
  walletLabel?: string;
13
+ packsTabLabel?: string;
13
14
  userAccountType: UserAccountTypes;
14
15
  loading?: boolean;
15
16
  error?: string;
package/dist/index.d.ts CHANGED
@@ -61,6 +61,7 @@ export * from './components/Store/CartView';
61
61
  export * from './components/Store/hooks/useStoreCart';
62
62
  export * from './components/Store/MetadataCollector';
63
63
  export * from './components/Store/Store';
64
+ export * from './components/Store/PaymentMethodModal';
64
65
  export * from './components/Table/Table';
65
66
  export * from './components/TextArea';
66
67
  export * from './components/TimeWidget/TimeWidget';
@@ -58647,7 +58647,7 @@ var StoreItemRow = function StoreItemRow(_ref) {
58647
58647
  height: 32,
58648
58648
  imgScale: 2,
58649
58649
  centered: true
58650
- })), React__default.createElement(ItemDetails$2, null, React__default.createElement(ItemName$2, null, item.name), React__default.createElement(ItemPrice$1, null, "$", item.price), React__default.createElement(ItemDescription, null, item.description)), React__default.createElement(Controls$1, null, showTextInput ? React__default.createElement(TextInput, {
58650
+ })), React__default.createElement(ItemDetails$2, null, React__default.createElement(ItemName$2, null, item.name), React__default.createElement(ItemPrice$1, null, "$", item.price, item.dcPrice ? " \xB7 " + item.dcPrice.toLocaleString() + " DC" : ''), React__default.createElement(ItemDescription, null, item.description)), React__default.createElement(Controls$1, null, showTextInput ? React__default.createElement(TextInput, {
58651
58651
  type: "text",
58652
58652
  value: textInputValue,
58653
58653
  placeholder: textInputPlaceholder,
@@ -58953,7 +58953,7 @@ var StoreItemDetails = function StoreItemDetails(_ref) {
58953
58953
  }, React__default.createElement(fa.FaArrowLeft, null), React__default.createElement("span", null, "Back"))), React__default.createElement(Content$5, null, React__default.createElement(DetailsGrid, null, React__default.createElement(ItemIcon, null, React__default.createElement("img", {
58954
58954
  src: getImageSrc(),
58955
58955
  alt: item.name
58956
- })), React__default.createElement(ItemInfo$2, null, React__default.createElement(ItemName$3, null, item.name), React__default.createElement(ItemPrice$2, null, "$", 'priceUSD' in item ? item.priceUSD : item.price), React__default.createElement(Description$6, null, item.description))), React__default.createElement(Actions, null, React__default.createElement(CTAButton, {
58956
+ })), React__default.createElement(ItemInfo$2, null, React__default.createElement(ItemName$3, null, item.name), React__default.createElement(ItemPrice$2, null, "$", 'priceUSD' in item ? item.priceUSD : item.price, item.dcPrice ? " \xB7 " + item.dcPrice.toLocaleString() + " DC" : ''), React__default.createElement(Description$6, null, item.description))), React__default.createElement(Actions, null, React__default.createElement(CTAButton, {
58957
58957
  icon: React__default.createElement(fa.FaCartPlus, null),
58958
58958
  label: "Add to Cart",
58959
58959
  onClick: function onClick() {
@@ -59029,7 +59029,9 @@ var Store = function Store(_ref) {
59029
59029
  _ref$textInputItemKey = _ref.textInputItemKeys,
59030
59030
  textInputItemKeys = _ref$textInputItemKey === void 0 ? [] : _ref$textInputItemKey,
59031
59031
  customPacksContent = _ref.customPacksContent,
59032
- customWalletContent = _ref.customWalletContent;
59032
+ customWalletContent = _ref.customWalletContent,
59033
+ _ref$packsTabLabel = _ref.packsTabLabel,
59034
+ packsTabLabel = _ref$packsTabLabel === void 0 ? 'Packs' : _ref$packsTabLabel;
59033
59035
  var _useState = React.useState(null),
59034
59036
  selectedPack = _useState[0],
59035
59037
  setSelectedPack = _useState[1];
@@ -59153,7 +59155,7 @@ var Store = function Store(_ref) {
59153
59155
  },
59154
59156
  packs: {
59155
59157
  id: 'packs',
59156
- title: 'Packs',
59158
+ title: packsTabLabel,
59157
59159
  content: customPacksContent != null ? customPacksContent : React__default.createElement(StorePacksSection, {
59158
59160
  packs: packs.filter(function (pack) {
59159
59161
  return pack.priceUSD < 9.99;
@@ -59305,6 +59307,117 @@ var ErrorMessage$2 = /*#__PURE__*/styled__default.div.withConfig({
59305
59307
  componentId: "sc-64dj00-9"
59306
59308
  })(["text-align:center;color:", ";padding:2rem;"], uiColors.red);
59307
59309
 
59310
+ var PaymentMethodModal = function PaymentMethodModal(_ref) {
59311
+ var dcBalance = _ref.dcBalance,
59312
+ onPayWithDC = _ref.onPayWithDC,
59313
+ onPayWithCard = _ref.onPayWithCard,
59314
+ onClose = _ref.onClose;
59315
+ var _useState = React.useState('card'),
59316
+ selected = _useState[0],
59317
+ setSelected = _useState[1];
59318
+ var stopPropagation = React.useCallback(function (e) {
59319
+ e.stopPropagation();
59320
+ }, []);
59321
+ var handleConfirm = React.useCallback(function () {
59322
+ if (selected === 'dc') {
59323
+ onPayWithDC();
59324
+ } else {
59325
+ onPayWithCard();
59326
+ }
59327
+ }, [selected, onPayWithDC, onPayWithCard]);
59328
+ return React__default.createElement(ModalPortal, null, React__default.createElement(Overlay$4, {
59329
+ onPointerDown: onClose
59330
+ }), React__default.createElement(ModalContainer$1, null, React__default.createElement(ModalContent$1, {
59331
+ onClick: stopPropagation,
59332
+ onTouchStart: stopPropagation,
59333
+ onPointerDown: stopPropagation
59334
+ }, React__default.createElement(Header$a, null, React__default.createElement(Title$f, null, "How would you like to pay?"), React__default.createElement(CloseButton$a, {
59335
+ onPointerDown: onClose,
59336
+ "aria-label": "Close"
59337
+ }, React__default.createElement(fa.FaTimes, null))), React__default.createElement(Options, null, React__default.createElement(RadioOption, {
59338
+ "$selected": selected === 'card',
59339
+ onPointerDown: function onPointerDown() {
59340
+ return setSelected('card');
59341
+ }
59342
+ }, React__default.createElement(RadioCircle, {
59343
+ "$selected": selected === 'card'
59344
+ }), React__default.createElement(OptionText, null, React__default.createElement(OptionLabel, null, "Credit Card"), React__default.createElement(OptionSub, null, "Stripe secure checkout"))), React__default.createElement(RadioOption, {
59345
+ "$selected": selected === 'dc',
59346
+ onPointerDown: function onPointerDown() {
59347
+ return setSelected('dc');
59348
+ }
59349
+ }, React__default.createElement(RadioCircle, {
59350
+ "$selected": selected === 'dc'
59351
+ }), React__default.createElement(OptionText, null, React__default.createElement(OptionLabel, null, "Definya Coin"), React__default.createElement(OptionSub, null, dcBalance.toLocaleString(), " DC available")))), React__default.createElement(ConfirmRow, null, React__default.createElement(Button, {
59352
+ buttonType: exports.ButtonTypes.RPGUIButton,
59353
+ onPointerDown: handleConfirm
59354
+ }, "Confirm")))));
59355
+ };
59356
+ var Overlay$4 = /*#__PURE__*/styled__default.div.withConfig({
59357
+ displayName: "PaymentMethodModal__Overlay",
59358
+ componentId: "sc-1dxy6lr-0"
59359
+ })(["position:fixed;inset:0;background:rgba(0,0,0,0.65);z-index:1000;"]);
59360
+ var ModalContainer$1 = /*#__PURE__*/styled__default.div.withConfig({
59361
+ displayName: "PaymentMethodModal__ModalContainer",
59362
+ componentId: "sc-1dxy6lr-1"
59363
+ })(["position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:1001;pointer-events:none;"]);
59364
+ var ModalContent$1 = /*#__PURE__*/styled__default.div.withConfig({
59365
+ displayName: "PaymentMethodModal__ModalContent",
59366
+ componentId: "sc-1dxy6lr-2"
59367
+ })(["background:#1a1a2e;border:2px solid #f59e0b;border-radius:8px;padding:20px 24px 24px;min-width:300px;max-width:90%;display:flex;flex-direction:column;gap:16px;pointer-events:auto;animation:scaleIn 0.15s ease-out;@keyframes scaleIn{from{transform:scale(0.85);opacity:0;}to{transform:scale(1);opacity:1;}}"]);
59368
+ var Header$a = /*#__PURE__*/styled__default.div.withConfig({
59369
+ displayName: "PaymentMethodModal__Header",
59370
+ componentId: "sc-1dxy6lr-3"
59371
+ })(["display:flex;align-items:center;justify-content:space-between;"]);
59372
+ var Title$f = /*#__PURE__*/styled__default.h3.withConfig({
59373
+ displayName: "PaymentMethodModal__Title",
59374
+ componentId: "sc-1dxy6lr-4"
59375
+ })(["margin:0;font-family:'Press Start 2P',cursive;font-size:0.7rem;color:#fef08a;"]);
59376
+ var CloseButton$a = /*#__PURE__*/styled__default.button.withConfig({
59377
+ displayName: "PaymentMethodModal__CloseButton",
59378
+ componentId: "sc-1dxy6lr-5"
59379
+ })(["background:none;border:none;color:rgba(255,255,255,0.6);cursor:pointer;font-size:1rem;padding:4px;display:flex;align-items:center;&:hover{color:#ffffff;}"]);
59380
+ var Options = /*#__PURE__*/styled__default.div.withConfig({
59381
+ displayName: "PaymentMethodModal__Options",
59382
+ componentId: "sc-1dxy6lr-6"
59383
+ })(["display:flex;flex-direction:column;gap:8px;"]);
59384
+ var RadioOption = /*#__PURE__*/styled__default.div.withConfig({
59385
+ displayName: "PaymentMethodModal__RadioOption",
59386
+ componentId: "sc-1dxy6lr-7"
59387
+ })(["display:flex;align-items:center;gap:12px;padding:10px 12px;border:1px solid ", ";border-radius:6px;background:", ";cursor:pointer;transition:border-color 0.15s,background 0.15s;&:hover{border-color:#f59e0b;}"], function (_ref2) {
59388
+ var $selected = _ref2.$selected;
59389
+ return $selected ? '#f59e0b' : 'rgba(255,255,255,0.15)';
59390
+ }, function (_ref3) {
59391
+ var $selected = _ref3.$selected;
59392
+ return $selected ? 'rgba(245,158,11,0.1)' : 'transparent';
59393
+ });
59394
+ var RadioCircle = /*#__PURE__*/styled__default.div.withConfig({
59395
+ displayName: "PaymentMethodModal__RadioCircle",
59396
+ componentId: "sc-1dxy6lr-8"
59397
+ })(["width:16px;height:16px;border-radius:50%;border:2px solid ", ";display:flex;align-items:center;justify-content:center;flex-shrink:0;&::after{content:'';width:8px;height:8px;border-radius:50%;background:#f59e0b;opacity:", ";transition:opacity 0.15s;}"], function (_ref4) {
59398
+ var $selected = _ref4.$selected;
59399
+ return $selected ? '#f59e0b' : 'rgba(255,255,255,0.4)';
59400
+ }, function (_ref5) {
59401
+ var $selected = _ref5.$selected;
59402
+ return $selected ? 1 : 0;
59403
+ });
59404
+ var OptionText = /*#__PURE__*/styled__default.div.withConfig({
59405
+ displayName: "PaymentMethodModal__OptionText",
59406
+ componentId: "sc-1dxy6lr-9"
59407
+ })(["display:flex;flex-direction:column;gap:3px;"]);
59408
+ var OptionLabel = /*#__PURE__*/styled__default.span.withConfig({
59409
+ displayName: "PaymentMethodModal__OptionLabel",
59410
+ componentId: "sc-1dxy6lr-10"
59411
+ })(["font-family:'Press Start 2P',cursive;font-size:0.65rem;color:#ffffff;"]);
59412
+ var OptionSub = /*#__PURE__*/styled__default.span.withConfig({
59413
+ displayName: "PaymentMethodModal__OptionSub",
59414
+ componentId: "sc-1dxy6lr-11"
59415
+ })(["font-family:'Press Start 2P',cursive;font-size:0.5rem;color:rgba(255,255,255,0.55);"]);
59416
+ var ConfirmRow = /*#__PURE__*/styled__default.div.withConfig({
59417
+ displayName: "PaymentMethodModal__ConfirmRow",
59418
+ componentId: "sc-1dxy6lr-12"
59419
+ })(["display:flex;justify-content:center;margin-top:4px;"]);
59420
+
59308
59421
  var TextArea = function TextArea(_ref) {
59309
59422
  var props = _extends({}, (_objectDestructuringEmpty(_ref), _ref));
59310
59423
  return React__default.createElement("textarea", Object.assign({}, props));
@@ -59339,7 +59452,7 @@ var TimeWidget = function TimeWidget(_ref) {
59339
59452
  return React__default.createElement(Draggable, {
59340
59453
  scale: scale,
59341
59454
  cancel: ".time-widget-close,.time-widget-container,.time-widget-container *"
59342
- }, React__default.createElement(WidgetContainer, null, React__default.createElement(CloseButton$a, {
59455
+ }, React__default.createElement(WidgetContainer, null, React__default.createElement(CloseButton$b, {
59343
59456
  onPointerDown: onClose,
59344
59457
  className: "time-widget-close"
59345
59458
  }, "X"), React__default.createElement(DayNightContainer, {
@@ -59356,7 +59469,7 @@ var Time = /*#__PURE__*/styled__default.div.withConfig({
59356
59469
  displayName: "TimeWidget__Time",
59357
59470
  componentId: "sc-1ja236h-1"
59358
59471
  })(["top:0.75rem;right:0.5rem;position:absolute;font-size:", ";color:white;"], uiFonts.size.small);
59359
- var CloseButton$a = /*#__PURE__*/styled__default.p.withConfig({
59472
+ var CloseButton$b = /*#__PURE__*/styled__default.p.withConfig({
59360
59473
  displayName: "TimeWidget__CloseButton",
59361
59474
  componentId: "sc-1ja236h-2"
59362
59475
  })(["position:absolute;top:-0.5rem;margin:0;right:-0.2rem;font-size:", " !important;z-index:1;"], uiFonts.size.small);
@@ -59635,7 +59748,7 @@ var TradingMenu = function TradingMenu(_ref) {
59635
59748
  width: "500px",
59636
59749
  cancelDrag: "#TraderContainer",
59637
59750
  scale: scale
59638
- }, React__default.createElement(Container$O, null, React__default.createElement(Title$f, null, type.charAt(0).toUpperCase() + type.slice(1), " Menu"), React__default.createElement("hr", {
59751
+ }, React__default.createElement(Container$O, null, React__default.createElement(Title$g, null, type.charAt(0).toUpperCase() + type.slice(1), " Menu"), React__default.createElement("hr", {
59639
59752
  className: "golden"
59640
59753
  }), React__default.createElement(ScrollWrapper, {
59641
59754
  id: "TraderContainer"
@@ -59667,7 +59780,7 @@ var Container$O = /*#__PURE__*/styled__default.div.withConfig({
59667
59780
  displayName: "TradingMenu__Container",
59668
59781
  componentId: "sc-1wjsz1l-0"
59669
59782
  })(["width:100%;"]);
59670
- var Title$f = /*#__PURE__*/styled__default.h1.withConfig({
59783
+ var Title$g = /*#__PURE__*/styled__default.h1.withConfig({
59671
59784
  displayName: "TradingMenu__Title",
59672
59785
  componentId: "sc-1wjsz1l-1"
59673
59786
  })(["font-size:0.7rem !important;color:yellow !important;text-align:center;"]);
@@ -59896,6 +60009,7 @@ exports.PartyInvite = PartyInvite;
59896
60009
  exports.PartyManager = PartyManager;
59897
60010
  exports.PartyManagerRow = PartyManagerRow;
59898
60011
  exports.PartyRow = PartyRow;
60012
+ exports.PaymentMethodModal = PaymentMethodModal;
59899
60013
  exports.PlayersRow = PlayersRow;
59900
60014
  exports.ProgressBar = ProgressBar$1;
59901
60015
  exports.PropertySelect = PropertySelect;