@rpg-engine/long-bow 0.8.66 → 0.8.67

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.
Files changed (36) hide show
  1. package/dist/components/Character/SkinSelectionGrid.d.ts +11 -0
  2. package/dist/components/Store/CartView.d.ts +1 -0
  3. package/dist/components/Store/MetadataCollector.d.ts +9 -0
  4. package/dist/components/Store/StoreCharacterSkinRow.d.ts +11 -0
  5. package/dist/components/Store/StoreItemRow.d.ts +1 -1
  6. package/dist/components/Store/hooks/useStoreCart.d.ts +6 -2
  7. package/dist/components/Store/hooks/useStoreMetadata.d.ts +15 -0
  8. package/dist/components/Store/sections/StoreItemsSection.d.ts +1 -1
  9. package/dist/index.d.ts +5 -1
  10. package/dist/long-bow.cjs.development.js +1572 -193
  11. package/dist/long-bow.cjs.development.js.map +1 -1
  12. package/dist/long-bow.cjs.production.min.js +1 -1
  13. package/dist/long-bow.cjs.production.min.js.map +1 -1
  14. package/dist/long-bow.esm.js +1540 -165
  15. package/dist/long-bow.esm.js.map +1 -1
  16. package/dist/stories/Character/SkinSelectionGrid.stories.d.ts +1 -0
  17. package/dist/stories/Character/character/CharacterSkinSelectionModal.stories.d.ts +1 -5
  18. package/dist/stories/Features/store/MetadataCollector.stories.d.ts +1 -0
  19. package/package.json +2 -2
  20. package/src/components/Character/CharacterSkinSelectionModal.tsx +18 -71
  21. package/src/components/Character/SkinSelectionGrid.tsx +179 -0
  22. package/src/components/Store/CartView.tsx +66 -7
  23. package/src/components/Store/MetadataCollector.tsx +48 -0
  24. package/src/components/Store/Store.tsx +38 -5
  25. package/src/components/Store/StoreCharacterSkinRow.tsx +286 -0
  26. package/src/components/Store/StoreItemRow.tsx +1 -1
  27. package/src/components/Store/__test__/MetadataCollector.spec.tsx +228 -0
  28. package/src/components/Store/__test__/useStoreMetadata.spec.tsx +181 -0
  29. package/src/components/Store/hooks/useStoreCart.ts +89 -44
  30. package/src/components/Store/hooks/useStoreMetadata.ts +55 -0
  31. package/src/components/Store/sections/StoreItemsSection.tsx +30 -11
  32. package/src/index.tsx +6 -3
  33. package/src/stories/Character/SkinSelectionGrid.stories.tsx +106 -0
  34. package/src/stories/Character/character/CharacterSkinSelectionModal.stories.tsx +86 -25
  35. package/src/stories/Features/store/MetadataCollector.stories.tsx +94 -0
  36. package/src/stories/Features/store/Store.stories.tsx +100 -2
@@ -26119,6 +26119,104 @@ var Container$4 = /*#__PURE__*/styled__default.div.withConfig({
26119
26119
  componentId: "sc-b34498-0"
26120
26120
  })(["display:flex;flex-direction:column;align-items:center;image-rendering:pixelated;"]);
26121
26121
 
26122
+ var SkinSelectionGrid = function SkinSelectionGrid(_ref) {
26123
+ var availableCharacters = _ref.availableCharacters,
26124
+ _ref$initialSelectedS = _ref.initialSelectedSkin,
26125
+ initialSelectedSkin = _ref$initialSelectedS === void 0 ? '' : _ref$initialSelectedS,
26126
+ onChange = _ref.onChange,
26127
+ atlasJSON = _ref.atlasJSON,
26128
+ atlasIMG = _ref.atlasIMG;
26129
+ var _useState = React.useState(0),
26130
+ currentIndex = _useState[0],
26131
+ setCurrentIndex = _useState[1];
26132
+ // Find the initial index based on initialSelectedSkin
26133
+ React.useEffect(function () {
26134
+ if (initialSelectedSkin && availableCharacters.length > 0) {
26135
+ var initialIndex = availableCharacters.findIndex(function (character) {
26136
+ return character.textureKey === initialSelectedSkin;
26137
+ });
26138
+ if (initialIndex !== -1) {
26139
+ setCurrentIndex(initialIndex);
26140
+ }
26141
+ }
26142
+ }, [initialSelectedSkin, availableCharacters]);
26143
+ // Update the selected skin when currentIndex changes
26144
+ React.useEffect(function () {
26145
+ if (availableCharacters.length > 0) {
26146
+ var selectedCharacter = availableCharacters[currentIndex];
26147
+ onChange(selectedCharacter.textureKey);
26148
+ }
26149
+ }, [currentIndex, availableCharacters, onChange]);
26150
+ var handlePrevious = function handlePrevious() {
26151
+ setCurrentIndex(function (prevIndex) {
26152
+ return prevIndex === 0 ? availableCharacters.length - 1 : prevIndex - 1;
26153
+ });
26154
+ };
26155
+ var handleNext = function handleNext() {
26156
+ setCurrentIndex(function (prevIndex) {
26157
+ return prevIndex === availableCharacters.length - 1 ? 0 : prevIndex + 1;
26158
+ });
26159
+ };
26160
+ var getSpriteKey = function getSpriteKey(textureKey) {
26161
+ return textureKey + '/down/standing/0.png';
26162
+ };
26163
+ if (availableCharacters.length === 0) {
26164
+ return React__default.createElement(Container$5, null, "No skins available");
26165
+ }
26166
+ var currentCharacter = availableCharacters[currentIndex];
26167
+ return React__default.createElement(Container$5, null, React__default.createElement(Header, null, "Select Your Character Skin"), React__default.createElement(CarouselContainer, null, React__default.createElement(NavButtonWrapper, null, React__default.createElement(SelectArrow, {
26168
+ direction: "left",
26169
+ onPointerDown: handlePrevious
26170
+ })), React__default.createElement(SkinPreview, null, currentCharacter && React__default.createElement(React__default.Fragment, null, React__default.createElement(ErrorBoundary, null, React__default.createElement(SpriteFromAtlas, {
26171
+ spriteKey: getSpriteKey(currentCharacter.textureKey),
26172
+ atlasIMG: atlasIMG,
26173
+ atlasJSON: atlasJSON,
26174
+ imgScale: 4,
26175
+ height: 80,
26176
+ width: 64,
26177
+ containerStyle: {
26178
+ display: 'flex',
26179
+ alignItems: 'center',
26180
+ justifyContent: 'center'
26181
+ },
26182
+ imgStyle: {
26183
+ position: 'relative',
26184
+ left: 0
26185
+ }
26186
+ })), React__default.createElement(SkinName, null, currentCharacter.name))), React__default.createElement(NavButtonWrapper, null, React__default.createElement(SelectArrow, {
26187
+ direction: "right",
26188
+ onPointerDown: handleNext
26189
+ }))), React__default.createElement(CounterIndicator, null, currentIndex + 1, " / ", availableCharacters.length));
26190
+ };
26191
+ var Container$5 = /*#__PURE__*/styled__default.div.withConfig({
26192
+ displayName: "SkinSelectionGrid__Container",
26193
+ componentId: "sc-1b8uucy-0"
26194
+ })(["display:flex;flex-direction:column;align-items:center;width:100%;margin-top:1rem;image-rendering:pixelated;"]);
26195
+ var Header = /*#__PURE__*/styled__default.h3.withConfig({
26196
+ displayName: "SkinSelectionGrid__Header",
26197
+ componentId: "sc-1b8uucy-1"
26198
+ })(["margin:0 0 1rem 0;color:white;text-align:center;font-size:1.1rem;"]);
26199
+ var CarouselContainer = /*#__PURE__*/styled__default.div.withConfig({
26200
+ displayName: "SkinSelectionGrid__CarouselContainer",
26201
+ componentId: "sc-1b8uucy-2"
26202
+ })(["display:flex;align-items:center;justify-content:space-between;width:100%;margin-bottom:0.5rem;position:relative;"]);
26203
+ var SkinPreview = /*#__PURE__*/styled__default.div.withConfig({
26204
+ displayName: "SkinSelectionGrid__SkinPreview",
26205
+ componentId: "sc-1b8uucy-3"
26206
+ })(["display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem;background-color:rgba(245,158,11,0.1);border:2px solid #f59e0b;border-radius:8px;width:140px;height:150px;margin:0 1.5rem;"]);
26207
+ var SkinName = /*#__PURE__*/styled__default.span.withConfig({
26208
+ displayName: "SkinSelectionGrid__SkinName",
26209
+ componentId: "sc-1b8uucy-4"
26210
+ })(["color:white;font-size:1rem;margin-top:0.8rem;text-align:center;font-weight:bold;"]);
26211
+ var NavButtonWrapper = /*#__PURE__*/styled__default.div.withConfig({
26212
+ displayName: "SkinSelectionGrid__NavButtonWrapper",
26213
+ componentId: "sc-1b8uucy-5"
26214
+ })(["width:40px;height:42px;position:relative;"]);
26215
+ var CounterIndicator = /*#__PURE__*/styled__default.div.withConfig({
26216
+ displayName: "SkinSelectionGrid__CounterIndicator",
26217
+ componentId: "sc-1b8uucy-6"
26218
+ })(["color:white;font-size:0.8rem;margin-top:0.5rem;"]);
26219
+
26122
26220
  var CharacterSkinSelectionModal = function CharacterSkinSelectionModal(_ref) {
26123
26221
  var isOpen = _ref.isOpen,
26124
26222
  onClose = _ref.onClose,
@@ -26128,48 +26226,21 @@ var CharacterSkinSelectionModal = function CharacterSkinSelectionModal(_ref) {
26128
26226
  atlasIMG = _ref.atlasIMG,
26129
26227
  _ref$initialSelectedS = _ref.initialSelectedSkin,
26130
26228
  initialSelectedSkin = _ref$initialSelectedS === void 0 ? '' : _ref$initialSelectedS;
26131
- // Convert availableCharacters to the format used by PropertySelect
26132
- var propertySelectValues = availableCharacters.map(function (item) {
26133
- return {
26134
- id: item.textureKey,
26135
- name: item.name
26136
- };
26137
- });
26138
- // State to store the selected skin and the sprite key
26139
- var _useState = React.useState(),
26140
- selectedValue = _useState[0],
26141
- setSelectedValue = _useState[1];
26142
- var _useState2 = React.useState(''),
26143
- selectedSpriteKey = _useState2[0],
26144
- setSelectedSpriteKey = _useState2[1];
26145
- // Update sprite when the selected value changes
26146
- var updateSelectedSpriteKey = function updateSelectedSpriteKey() {
26147
- var textureKey = selectedValue ? selectedValue.id : '';
26148
- var spriteKey = textureKey ? textureKey + '/down/standing/0.png' : '';
26149
- if (spriteKey === selectedSpriteKey) {
26150
- return;
26151
- }
26152
- setSelectedSpriteKey(spriteKey);
26153
- };
26154
- // Update sprite when selectedValue changes
26155
- React.useEffect(function () {
26156
- updateSelectedSpriteKey();
26157
- }, [selectedValue]);
26158
- // Initialize selectedValue
26229
+ var _useState = React.useState(initialSelectedSkin),
26230
+ selectedSkin = _useState[0],
26231
+ setSelectedSkin = _useState[1];
26232
+ // Initialize selected skin
26159
26233
  React.useEffect(function () {
26160
26234
  if (initialSelectedSkin) {
26161
- var initialProperty = propertySelectValues.find(function (prop) {
26162
- return prop.id === initialSelectedSkin;
26163
- });
26164
- setSelectedValue(initialProperty || propertySelectValues[0]);
26165
- } else if (propertySelectValues.length > 0) {
26166
- setSelectedValue(propertySelectValues[0]);
26235
+ setSelectedSkin(initialSelectedSkin);
26236
+ } else if (availableCharacters.length > 0) {
26237
+ setSelectedSkin(availableCharacters[0].textureKey);
26167
26238
  }
26168
26239
  }, [initialSelectedSkin, availableCharacters]);
26169
26240
  // Functions to handle confirmation and cancellation
26170
26241
  var handleConfirm = function handleConfirm() {
26171
- if (selectedValue) {
26172
- onConfirm(selectedValue.id);
26242
+ if (selectedSkin) {
26243
+ onConfirm(selectedSkin);
26173
26244
  onClose();
26174
26245
  }
26175
26246
  };
@@ -26177,44 +26248,30 @@ var CharacterSkinSelectionModal = function CharacterSkinSelectionModal(_ref) {
26177
26248
  onClose();
26178
26249
  };
26179
26250
  if (!isOpen) return null;
26180
- return React__default.createElement(Container$5, null, selectedSpriteKey && atlasIMG && atlasJSON && React__default.createElement(ErrorBoundary, null, React__default.createElement(SpriteFromAtlas, {
26181
- spriteKey: selectedSpriteKey,
26182
- atlasIMG: atlasIMG,
26251
+ return React__default.createElement(Container$6, null, React__default.createElement(SkinSelectionGrid, {
26252
+ availableCharacters: availableCharacters,
26253
+ initialSelectedSkin: selectedSkin,
26254
+ onChange: setSelectedSkin,
26183
26255
  atlasJSON: atlasJSON,
26184
- imgScale: 4,
26185
- height: 80,
26186
- width: 64,
26187
- containerStyle: {
26188
- display: 'flex',
26189
- alignItems: 'center',
26190
- paddingBottom: '15px'
26191
- },
26192
- imgStyle: {
26193
- left: '22px'
26194
- }
26195
- })), React__default.createElement(PropertySelect, {
26196
- availableProperties: propertySelectValues,
26197
- onChange: function onChange(value) {
26198
- setSelectedValue(value);
26199
- }
26256
+ atlasIMG: atlasIMG
26200
26257
  }), React__default.createElement(ButtonsContainer, null, React__default.createElement(Button, {
26201
26258
  buttonType: exports.ButtonTypes.RPGUIButton,
26202
26259
  onClick: handleCancel
26203
26260
  }, "Cancel"), React__default.createElement(Button, {
26204
26261
  buttonType: exports.ButtonTypes.RPGUIButton,
26205
26262
  onClick: handleConfirm,
26206
- disabled: !selectedValue
26263
+ disabled: !selectedSkin
26207
26264
  }, "Confirm")));
26208
26265
  };
26209
26266
  // Styled components
26210
- var Container$5 = /*#__PURE__*/styled__default.div.withConfig({
26267
+ var Container$6 = /*#__PURE__*/styled__default.div.withConfig({
26211
26268
  displayName: "CharacterSkinSelectionModal__Container",
26212
26269
  componentId: "sc-qsroao-0"
26213
- })(["display:flex;flex-direction:column;align-items:center;image-rendering:pixelated;"]);
26270
+ })(["display:flex;flex-direction:column;align-items:center;width:400px;max-width:100%;image-rendering:pixelated;"]);
26214
26271
  var ButtonsContainer = /*#__PURE__*/styled__default.div.withConfig({
26215
26272
  displayName: "CharacterSkinSelectionModal__ButtonsContainer",
26216
26273
  componentId: "sc-qsroao-1"
26217
- })(["display:flex;justify-content:center;gap:0.8rem;width:100%;margin:3rem 0 0.75rem;button{min-width:95px;font-size:0.9rem;}"]);
26274
+ })(["display:flex;justify-content:center;gap:0.8rem;width:100%;margin:2rem 0 0.75rem;button{min-width:95px;font-size:0.9rem;}"]);
26218
26275
 
26219
26276
  var Chat = function Chat(_ref) {
26220
26277
  var chatMessages = _ref.chatMessages,
@@ -26360,13 +26417,13 @@ var RPGUIContainer = function RPGUIContainer(_ref) {
26360
26417
  width = _ref$width === void 0 ? '50%' : _ref$width,
26361
26418
  height = _ref.height,
26362
26419
  className = _ref.className;
26363
- return React__default.createElement(Container$6, {
26420
+ return React__default.createElement(Container$7, {
26364
26421
  width: width,
26365
26422
  height: height || 'auto',
26366
26423
  className: "rpgui-container " + type + " " + className
26367
26424
  }, children);
26368
26425
  };
26369
- var Container$6 = /*#__PURE__*/styled__default.div.withConfig({
26426
+ var Container$7 = /*#__PURE__*/styled__default.div.withConfig({
26370
26427
  displayName: "RPGUIContainer__Container",
26371
26428
  componentId: "sc-a7heha-0"
26372
26429
  })(["height:", ";width:", ";display:flex;flex-wrap:wrap;image-rendering:pixelated;"], function (props) {
@@ -26438,7 +26495,7 @@ var ChatDeprecated = function ChatDeprecated(_ref) {
26438
26495
  }, onRenderMessageLines(emitter, createdAt, message));
26439
26496
  }) : React__default.createElement(MessageText, null, "No messages available.");
26440
26497
  };
26441
- return React__default.createElement(Container$7, null, React__default.createElement(CustomContainer, {
26498
+ return React__default.createElement(Container$8, null, React__default.createElement(CustomContainer, {
26442
26499
  type: exports.RPGUIContainerTypes.FramedGrey,
26443
26500
  width: width,
26444
26501
  height: height,
@@ -26476,7 +26533,7 @@ var ChatDeprecated = function ChatDeprecated(_ref) {
26476
26533
  id: "chat-send-button"
26477
26534
  }, "Send"))))));
26478
26535
  };
26479
- var Container$7 = /*#__PURE__*/styled__default.div.withConfig({
26536
+ var Container$8 = /*#__PURE__*/styled__default.div.withConfig({
26480
26537
  displayName: "ChatDeprecated__Container",
26481
26538
  componentId: "sc-fuuod3-0"
26482
26539
  })(["position:relative;"]);
@@ -27443,7 +27500,7 @@ var DraggableContainer = function DraggableContainer(_ref) {
27443
27500
  },
27444
27501
  defaultPosition: initialPosition,
27445
27502
  scale: scale
27446
- }, React__default.createElement(Container$8, {
27503
+ }, React__default.createElement(Container$9, {
27447
27504
  ref: draggableRef,
27448
27505
  width: width,
27449
27506
  height: height || 'auto',
@@ -27462,7 +27519,7 @@ var DraggableContainer = function DraggableContainer(_ref) {
27462
27519
  onPointerDown: onCloseButton
27463
27520
  }, "X"), children));
27464
27521
  };
27465
- var Container$8 = /*#__PURE__*/styled__default.div.withConfig({
27522
+ var Container$9 = /*#__PURE__*/styled__default.div.withConfig({
27466
27523
  displayName: "DraggableContainer__Container",
27467
27524
  componentId: "sc-184mpyl-0"
27468
27525
  })(["height:", ";width:", ";min-width:", ";min-height:", ";display:flex;flex-wrap:wrap;image-rendering:pixelated;overflow-y:hidden;", " ", " &.rpgui-container{padding-top:1.5rem;}"], function (props) {
@@ -27539,7 +27596,7 @@ var Dropdown = function Dropdown(_ref) {
27539
27596
  onChange(selectedValue);
27540
27597
  }
27541
27598
  }, [selectedValue]);
27542
- return React__default.createElement(Container$9, {
27599
+ return React__default.createElement(Container$a, {
27543
27600
  onMouseLeave: function onMouseLeave() {
27544
27601
  return setOpened(false);
27545
27602
  },
@@ -27567,7 +27624,7 @@ var Dropdown = function Dropdown(_ref) {
27567
27624
  }, option.option);
27568
27625
  })));
27569
27626
  };
27570
- var Container$9 = /*#__PURE__*/styled__default.div.withConfig({
27627
+ var Container$a = /*#__PURE__*/styled__default.div.withConfig({
27571
27628
  displayName: "Dropdown__Container",
27572
27629
  componentId: "sc-8arn65-0"
27573
27630
  })(["position:relative;width:", ";"], function (props) {
@@ -27591,11 +27648,11 @@ var DropdownOptions$1 = /*#__PURE__*/styled__default.ul.withConfig({
27591
27648
  var modalRoot = /*#__PURE__*/document.getElementById('modal-root');
27592
27649
  var ModalPortal = function ModalPortal(_ref) {
27593
27650
  var children = _ref.children;
27594
- return ReactDOM__default.createPortal(React__default.createElement(Container$a, {
27651
+ return ReactDOM__default.createPortal(React__default.createElement(Container$b, {
27595
27652
  className: "rpgui-content"
27596
27653
  }, children), modalRoot);
27597
27654
  };
27598
- var Container$a = /*#__PURE__*/styled__default.div.withConfig({
27655
+ var Container$b = /*#__PURE__*/styled__default.div.withConfig({
27599
27656
  displayName: "ModalPortal__Container",
27600
27657
  componentId: "sc-dgmp04-0"
27601
27658
  })(["position:static !important;"]);
@@ -28315,7 +28372,7 @@ var ItemSlot = /*#__PURE__*/mobxReactLite.observer(function (_ref) {
28315
28372
  });
28316
28373
  }
28317
28374
  };
28318
- return React__default.createElement(Container$b, {
28375
+ return React__default.createElement(Container$c, {
28319
28376
  isDraggingItem: !!draggingState.item,
28320
28377
  item: item,
28321
28378
  className: "rpgui-icon empty-slot",
@@ -28379,7 +28436,7 @@ var ItemSlot = /*#__PURE__*/mobxReactLite.observer(function (_ref) {
28379
28436
  containerType: containerType
28380
28437
  }))));
28381
28438
  });
28382
- var Container$b = /*#__PURE__*/styled__default.div.withConfig({
28439
+ var Container$c = /*#__PURE__*/styled__default.div.withConfig({
28383
28440
  displayName: "ItemSlot__Container",
28384
28441
  componentId: "sc-l2j5ef-0"
28385
28442
  })(["margin:0.1rem;.react-draggable-dragging{opacity:", ";}position:relative;.sprite-from-atlas-img--item{position:relative;top:1.5rem;left:1.5rem;border-color:", ";box-shadow:", " inset,", ";}.quality-star{position:absolute;top:0.5rem;left:0.5rem;font-size:1.2rem;z-index:2;text-shadow:0 0 3px black;pointer-events:none;color:", ";}&::before{content:'';position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;border-radius:12px;pointer-events:none;animation:", ";@keyframes bg-color-change{0%{background-color:rgba(255 255 255 / 0.5);}50%{background-color:transparent;}100%{background-color:rgba(255 255 255 / 0.5);}}}"], function (_ref2) {
@@ -28498,9 +28555,9 @@ var ItemInfo = function ItemInfo(_ref) {
28498
28555
  });
28499
28556
  };
28500
28557
  var skillName = (_item$minRequirements = item.minRequirements) == null ? void 0 : (_item$minRequirements2 = _item$minRequirements.skill) == null ? void 0 : _item$minRequirements2.name;
28501
- return React__default.createElement(Container$c, {
28558
+ return React__default.createElement(Container$d, {
28502
28559
  item: item
28503
- }, React__default.createElement(Header, null, React__default.createElement("div", null, React__default.createElement(Title$1, null, item.name), item.rarity !== 'Common' && React__default.createElement(Rarity, {
28560
+ }, React__default.createElement(Header$1, null, React__default.createElement("div", null, React__default.createElement(Title$1, null, item.name), item.rarity !== 'Common' && React__default.createElement(Rarity, {
28504
28561
  item: item
28505
28562
  }, item.rarity), React__default.createElement(Type, null, item.subType)), React__default.createElement(AllowedSlots, null, renderAvaibleSlots())), item.minRequirements && React__default.createElement(LevelRequirement, null, React__default.createElement("div", {
28506
28563
  className: "title"
@@ -28512,7 +28569,7 @@ var ItemInfo = function ItemInfo(_ref) {
28512
28569
  "$isSpecial": true
28513
28570
  }, "Two handed"), React__default.createElement(Description, null, item.description), item.maxStackSize && item.maxStackSize !== 1 && React__default.createElement(StackInfo, null, "x", Math.round(((_item$stackQty = item.stackQty) != null ? _item$stackQty : 1) * 100) / 100, "(", item.maxStackSize, ")"), renderMissingStatistic().length > 0 && React__default.createElement(MissingStatistics, null, React__default.createElement(Statistic, null, "Equipped Diff"), itemToCompare && renderMissingStatistic()));
28514
28571
  };
28515
- var Container$c = /*#__PURE__*/styled__default.div.withConfig({
28572
+ var Container$d = /*#__PURE__*/styled__default.div.withConfig({
28516
28573
  displayName: "ItemInfo__Container",
28517
28574
  componentId: "sc-1xm4q8k-0"
28518
28575
  })(["color:white;background-color:#222;border-radius:5px;padding:0.5rem;font-size:", ";border:3px solid ", ";box-shadow:", ";height:max-content;width:18rem;position:relative;@media (max-width:640px){width:80vw;}"], uiFonts.size.small, function (_ref2) {
@@ -28553,7 +28610,7 @@ var Description = /*#__PURE__*/styled__default.div.withConfig({
28553
28610
  displayName: "ItemInfo__Description",
28554
28611
  componentId: "sc-1xm4q8k-6"
28555
28612
  })(["margin-top:1.5rem;font-size:", ";color:", ";font-style:italic;"], uiFonts.size.small, uiColors.lightGray);
28556
- var Header = /*#__PURE__*/styled__default.div.withConfig({
28613
+ var Header$1 = /*#__PURE__*/styled__default.div.withConfig({
28557
28614
  displayName: "ItemInfo__Header",
28558
28615
  componentId: "sc-1xm4q8k-7"
28559
28616
  })(["display:flex;align-items:center;justify-content:space-between;margin-bottom:0.5rem;"]);
@@ -28661,7 +28718,7 @@ var ItemTooltip = function ItemTooltip(_ref) {
28661
28718
  }
28662
28719
  return;
28663
28720
  }, []);
28664
- return React__default.createElement(ModalPortal, null, React__default.createElement(Container$d, {
28721
+ return React__default.createElement(ModalPortal, null, React__default.createElement(Container$e, {
28665
28722
  ref: ref
28666
28723
  }, React__default.createElement(ItemInfoDisplay, {
28667
28724
  item: item,
@@ -28670,7 +28727,7 @@ var ItemTooltip = function ItemTooltip(_ref) {
28670
28727
  equipmentSet: equipmentSet
28671
28728
  })));
28672
28729
  };
28673
- var Container$d = /*#__PURE__*/styled__default.div.withConfig({
28730
+ var Container$e = /*#__PURE__*/styled__default.div.withConfig({
28674
28731
  displayName: "ItemTooltip__Container",
28675
28732
  componentId: "sc-11d9r7x-0"
28676
28733
  })(["position:absolute;z-index:100;pointer-events:none;left:0;top:0;opacity:0;transition:opacity 0.08s;"]);
@@ -28690,7 +28747,7 @@ var MobileItemTooltip = function MobileItemTooltip(_ref) {
28690
28747
  var _ref$current;
28691
28748
  (_ref$current = ref.current) == null ? void 0 : _ref$current.classList.add('fadeOut');
28692
28749
  };
28693
- return React__default.createElement(ModalPortal, null, React__default.createElement(Container$e, {
28750
+ return React__default.createElement(ModalPortal, null, React__default.createElement(Container$f, {
28694
28751
  ref: ref,
28695
28752
  onTouchEnd: function onTouchEnd() {
28696
28753
  handleFadeOut();
@@ -28718,7 +28775,7 @@ var MobileItemTooltip = function MobileItemTooltip(_ref) {
28718
28775
  }, option.text);
28719
28776
  }))));
28720
28777
  };
28721
- var Container$e = /*#__PURE__*/styled__default.div.withConfig({
28778
+ var Container$f = /*#__PURE__*/styled__default.div.withConfig({
28722
28779
  displayName: "MobileItemTooltip__Container",
28723
28780
  componentId: "sc-ku4p1j-0"
28724
28781
  })(["position:absolute;z-index:100;left:0;top:0;width:100vw;height:100vh;background-color:rgba(0 0 0 / 0.5);display:flex;justify-content:center;align-items:center;gap:0.5rem;transition:opacity 0.08s;animation:fadeIn 0.1s forwards;@keyframes fadeIn{0%{opacity:0;}100%{opacity:0.92;}}@keyframes fadeOut{0%{opacity:0.92;}100%{opacity:0;}}&.fadeOut{animation:fadeOut 0.1s forwards;}@media (max-width:640px){flex-direction:column;}"]);
@@ -29470,7 +29527,7 @@ var ReadOnlyCheckItem = function ReadOnlyCheckItem(_ref) {
29470
29527
  var labelLeft = _ref.labelLeft,
29471
29528
  labelRight = _ref.labelRight,
29472
29529
  checked = _ref.checked;
29473
- return React__default.createElement(Container$f, null, labelLeft && React__default.createElement(Label, null, labelLeft), React__default.createElement("div", {
29530
+ return React__default.createElement(Container$g, null, labelLeft && React__default.createElement(Label, null, labelLeft), React__default.createElement("div", {
29474
29531
  className: "rpgui-checkbox-container"
29475
29532
  }, React__default.createElement(CheckBox, {
29476
29533
  className: "rpgui-checkbox",
@@ -29481,7 +29538,7 @@ var ReadOnlyCheckItem = function ReadOnlyCheckItem(_ref) {
29481
29538
  isRight: true
29482
29539
  }, labelRight));
29483
29540
  };
29484
- var Container$f = /*#__PURE__*/styled__default.div.withConfig({
29541
+ var Container$g = /*#__PURE__*/styled__default.div.withConfig({
29485
29542
  displayName: "ReadOnlyCheckItem__Container",
29486
29543
  componentId: "sc-1peplf9-0"
29487
29544
  })(["display:flex;align-items:center;width:100%;height:20px;"]);
@@ -29804,7 +29861,7 @@ var DailyTasks = function DailyTasks(_ref) {
29804
29861
  scale: scale,
29805
29862
  width: size.width,
29806
29863
  height: size.height
29807
- }, React__default.createElement(TaskTitle$1, null, "Daily Tasks"), React__default.createElement(Container$g, null, React__default.createElement(TasksList, {
29864
+ }, React__default.createElement(TaskTitle$1, null, "Daily Tasks"), React__default.createElement(Container$h, null, React__default.createElement(TasksList, {
29808
29865
  className: "tasks-container"
29809
29866
  }, React__default.createElement(GlobalDailyProgress, {
29810
29867
  tasks: localTasks,
@@ -29828,7 +29885,7 @@ var TasksContainer = /*#__PURE__*/styled__default(DraggableContainer).withConfig
29828
29885
  displayName: "DailyTasks__TasksContainer",
29829
29886
  componentId: "sc-ittn77-0"
29830
29887
  })(["min-width:450px;max-width:550px;margin:0 auto;.rpgui-container-title{width:100%;display:flex;justify-content:center;align-items:center;text-align:center;}.rpgui-container{padding:0 !important;overflow:hidden !important;background-color:rgba(30,30,30,0.9) !important;}"]);
29831
- var Container$g = /*#__PURE__*/styled__default.div.withConfig({
29888
+ var Container$h = /*#__PURE__*/styled__default.div.withConfig({
29832
29889
  displayName: "DailyTasks__Container",
29833
29890
  componentId: "sc-ittn77-1"
29834
29891
  })(["width:100%;max-width:100%;margin:0 auto;padding:0.125rem;overflow-y:auto;box-sizing:border-box;@media (min-width:320px){padding:0.25rem;}@media (min-width:360px){padding:0.5rem;}@media (min-width:480px){padding:0.75rem;}"]);
@@ -30200,7 +30257,7 @@ var DraggedItem = function DraggedItem(_ref) {
30200
30257
  var centeredX = x - OFFSET$1;
30201
30258
  var centeredY = y - OFFSET$1;
30202
30259
  var stackInfo = onRenderStackInfo((_item$_id = item == null ? void 0 : item._id) != null ? _item$_id : '', (_item$stackQty = item == null ? void 0 : item.stackQty) != null ? _item$stackQty : 0);
30203
- return React__default.createElement(Container$h, null, React__default.createElement(SpriteContainer, {
30260
+ return React__default.createElement(Container$i, null, React__default.createElement(SpriteContainer, {
30204
30261
  x: centeredX,
30205
30262
  y: centeredY
30206
30263
  }, React__default.createElement(SpriteFromAtlas, {
@@ -30218,7 +30275,7 @@ var DraggedItem = function DraggedItem(_ref) {
30218
30275
  }), stackInfo));
30219
30276
  };
30220
30277
  var pulse = "\n @keyframes pulse {\n 0%, 100% {\n transform: scale(1) rotate(-3deg);\n }\n 50% {\n transform: scale(0.95) rotate(-3deg);\n }\n }\n";
30221
- var Container$h = /*#__PURE__*/styled__default.div.withConfig({
30278
+ var Container$i = /*#__PURE__*/styled__default.div.withConfig({
30222
30279
  displayName: "DraggedItem__Container",
30223
30280
  componentId: "sc-mlzzcp-0"
30224
30281
  })(["position:relative;"]);
@@ -30256,7 +30313,7 @@ var RelativeListMenu = function RelativeListMenu(_ref) {
30256
30313
  document.removeEventListener('clickOutside', function (_e) {});
30257
30314
  };
30258
30315
  }, []);
30259
- return React__default.createElement(ModalPortal, null, React__default.createElement(Container$i, Object.assign({
30316
+ return React__default.createElement(ModalPortal, null, React__default.createElement(Container$j, Object.assign({
30260
30317
  fontSize: fontSize,
30261
30318
  ref: ref
30262
30319
  }, pos), React__default.createElement("ul", {
@@ -30273,7 +30330,7 @@ var RelativeListMenu = function RelativeListMenu(_ref) {
30273
30330
  }, (params == null ? void 0 : params.text) || 'No text');
30274
30331
  }))));
30275
30332
  };
30276
- var Container$i = /*#__PURE__*/styled__default.div.withConfig({
30333
+ var Container$j = /*#__PURE__*/styled__default.div.withConfig({
30277
30334
  displayName: "RelativeListMenu__Container",
30278
30335
  componentId: "sc-7hohf-0"
30279
30336
  })(["position:absolute;top:", "px;left:", "px;display:flex;flex-direction:column;width:max-content;justify-content:start;align-items:flex-start;li{font-size:", "em;}"], function (props) {
@@ -30547,7 +30604,7 @@ var SearchFriend = function SearchFriend(_ref) {
30547
30604
  title: "Requests (" + friendRequests.length + ")",
30548
30605
  content: requestsTabContent
30549
30606
  }];
30550
- return React__default.createElement(Container$j, null, React__default.createElement(InternalTabs, {
30607
+ return React__default.createElement(Container$k, null, React__default.createElement(InternalTabs, {
30551
30608
  tabs: tabs,
30552
30609
  activeTextColor: "#000",
30553
30610
  inactiveColor: "#777",
@@ -30589,7 +30646,7 @@ var FriendRequestSection = function FriendRequestSection(_ref3) {
30589
30646
  }, "Reject")));
30590
30647
  })));
30591
30648
  };
30592
- var Container$j = /*#__PURE__*/styled__default.div.withConfig({
30649
+ var Container$k = /*#__PURE__*/styled__default.div.withConfig({
30593
30650
  displayName: "SearchFriend__Container",
30594
30651
  componentId: "sc-1lt1ols-0"
30595
30652
  })(["display:flex;flex-direction:column;gap:1rem;"]);
@@ -30792,7 +30849,7 @@ var NPCDialogText = function NPCDialogText(_ref) {
30792
30849
  var _useState2 = React.useState(false),
30793
30850
  showGoNextIndicator = _useState2[0],
30794
30851
  setShowGoNextIndicator = _useState2[1];
30795
- return React__default.createElement(Container$k, null, React__default.createElement(DynamicText, {
30852
+ return React__default.createElement(Container$l, null, React__default.createElement(DynamicText, {
30796
30853
  text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
30797
30854
  onFinish: function onFinish() {
30798
30855
  setShowGoNextIndicator(true);
@@ -30810,7 +30867,7 @@ var NPCDialogText = function NPCDialogText(_ref) {
30810
30867
  }
30811
30868
  }));
30812
30869
  };
30813
- var Container$k = /*#__PURE__*/styled__default.div.withConfig({
30870
+ var Container$l = /*#__PURE__*/styled__default.div.withConfig({
30814
30871
  displayName: "NPCDialogText__Container",
30815
30872
  componentId: "sc-1cxkdh9-0"
30816
30873
  })([""]);
@@ -30962,7 +31019,7 @@ var QuestionDialog = function QuestionDialog(_ref) {
30962
31019
  return null;
30963
31020
  });
30964
31021
  };
30965
- return React__default.createElement(Container$l, null, React__default.createElement(QuestionContainer, null, React__default.createElement(DynamicText, {
31022
+ return React__default.createElement(Container$m, null, React__default.createElement(QuestionContainer, null, React__default.createElement(DynamicText, {
30966
31023
  text: currentQuestion.text,
30967
31024
  onStart: function onStart() {
30968
31025
  return setCanShowAnswers(false);
@@ -30972,7 +31029,7 @@ var QuestionDialog = function QuestionDialog(_ref) {
30972
31029
  }
30973
31030
  })), canShowAnswers && React__default.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
30974
31031
  };
30975
- var Container$l = /*#__PURE__*/styled__default.div.withConfig({
31032
+ var Container$m = /*#__PURE__*/styled__default.div.withConfig({
30976
31033
  displayName: "QuestionDialog__Container",
30977
31034
  componentId: "sc-bxc5u0-0"
30978
31035
  })(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
@@ -31032,7 +31089,7 @@ var NPCDialog = function NPCDialog(_ref) {
31032
31089
  }
31033
31090
  })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
31034
31091
  src: imagePath || img$7
31035
- }))) : React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$m, null, React__default.createElement(CloseIcon, {
31092
+ }))) : React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$n, null, React__default.createElement(CloseIcon, {
31036
31093
  onPointerDown: _onClose
31037
31094
  }, "X"), React__default.createElement(TextContainer$1, {
31038
31095
  flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
@@ -31048,7 +31105,7 @@ var NPCDialog = function NPCDialog(_ref) {
31048
31105
  src: imagePath || img$7
31049
31106
  })))));
31050
31107
  };
31051
- var Container$m = /*#__PURE__*/styled__default.div.withConfig({
31108
+ var Container$n = /*#__PURE__*/styled__default.div.withConfig({
31052
31109
  displayName: "NPCDialog__Container",
31053
31110
  componentId: "sc-1b4aw74-0"
31054
31111
  })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
@@ -31108,7 +31165,7 @@ var NPCMultiDialog = function NPCMultiDialog(_ref) {
31108
31165
  type: exports.RPGUIContainerTypes.FramedGold,
31109
31166
  width: '50%',
31110
31167
  height: '180px'
31111
- }, React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$n, null, ((_textAndTypeArray$sli = textAndTypeArray[slide]) == null ? void 0 : _textAndTypeArray$sli.imageSide) === 'right' && React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer$2, {
31168
+ }, React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$o, null, ((_textAndTypeArray$sli = textAndTypeArray[slide]) == null ? void 0 : _textAndTypeArray$sli.imageSide) === 'right' && React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer$2, {
31112
31169
  flex: '70%'
31113
31170
  }, React__default.createElement(NPCDialogText, {
31114
31171
  onStartStep: function onStartStep() {
@@ -31150,7 +31207,7 @@ var NPCMultiDialog = function NPCMultiDialog(_ref) {
31150
31207
  src: img$6
31151
31208
  }))), ")"));
31152
31209
  };
31153
- var Container$n = /*#__PURE__*/styled__default.div.withConfig({
31210
+ var Container$o = /*#__PURE__*/styled__default.div.withConfig({
31154
31211
  displayName: "NPCMultiDialog__Container",
31155
31212
  componentId: "sc-rvu5wg-0"
31156
31213
  })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
@@ -31582,7 +31639,7 @@ var Pagination = function Pagination(_ref) {
31582
31639
  totalPages = _ref.totalPages,
31583
31640
  onPageChange = _ref.onPageChange,
31584
31641
  className = _ref.className;
31585
- return React__default.createElement(Container$o, {
31642
+ return React__default.createElement(Container$p, {
31586
31643
  className: className
31587
31644
  }, React__default.createElement(PaginationButton$1, {
31588
31645
  onClick: function onClick() {
@@ -31600,7 +31657,7 @@ var Pagination = function Pagination(_ref) {
31600
31657
  size: 12
31601
31658
  })));
31602
31659
  };
31603
- var Container$o = /*#__PURE__*/styled__default.div.withConfig({
31660
+ var Container$p = /*#__PURE__*/styled__default.div.withConfig({
31604
31661
  displayName: "Pagination__Container",
31605
31662
  componentId: "sc-3k4m4u-0"
31606
31663
  })(["display:flex;align-items:center;justify-content:center;gap:16px;padding:8px;"]);
@@ -31626,7 +31683,7 @@ var SearchBar = function SearchBar(_ref) {
31626
31683
  className = _ref.className,
31627
31684
  rightElement = _ref.rightElement;
31628
31685
  var hasRightElement = Boolean(rightElement);
31629
- return React__default.createElement(Container$p, {
31686
+ return React__default.createElement(Container$q, {
31630
31687
  className: className
31631
31688
  }, React__default.createElement(Input$1, {
31632
31689
  type: "text",
@@ -31639,7 +31696,7 @@ var SearchBar = function SearchBar(_ref) {
31639
31696
  "$hasRightElement": hasRightElement
31640
31697
  }), React__default.createElement(IconContainer, null, React__default.createElement(SearchIcon, null), rightElement));
31641
31698
  };
31642
- var Container$p = /*#__PURE__*/styled__default.div.withConfig({
31699
+ var Container$q = /*#__PURE__*/styled__default.div.withConfig({
31643
31700
  displayName: "SearchBar__Container",
31644
31701
  componentId: "sc-13n8z02-0"
31645
31702
  })(["position:relative;width:100%;"]);
@@ -31747,7 +31804,7 @@ var PaginatedContent = function PaginatedContent(_ref) {
31747
31804
  setCurrentPage = _usePagination.setCurrentPage,
31748
31805
  paginatedItems = _usePagination.paginatedItems,
31749
31806
  totalPages = _usePagination.totalPages;
31750
- return React__default.createElement(Container$q, {
31807
+ return React__default.createElement(Container$r, {
31751
31808
  className: className
31752
31809
  }, (searchOptions || filterOptions) && React__default.createElement(SearchHeader, {
31753
31810
  searchOptions: searchOptions,
@@ -31769,7 +31826,7 @@ var PaginatedContent = function PaginatedContent(_ref) {
31769
31826
  onPageChange: setCurrentPage
31770
31827
  }))));
31771
31828
  };
31772
- var Container$q = /*#__PURE__*/styled__default.div.withConfig({
31829
+ var Container$r = /*#__PURE__*/styled__default.div.withConfig({
31773
31830
  displayName: "PaginatedContent__Container",
31774
31831
  componentId: "sc-lzp9hn-0"
31775
31832
  })(["display:flex;flex-direction:column;gap:0.5rem;min-height:400px;width:100%;"]);
@@ -31891,11 +31948,11 @@ var BaseInformationDetails = function BaseInformationDetails(_ref) {
31891
31948
  atlasIMG = _ref.atlasIMG,
31892
31949
  onBack = _ref.onBack,
31893
31950
  children = _ref.children;
31894
- return React__default.createElement(Container$r, null, React__default.createElement(Overlay, {
31951
+ return React__default.createElement(Container$s, null, React__default.createElement(Overlay, {
31895
31952
  onClick: onBack
31896
31953
  }), React__default.createElement(Modal, null, React__default.createElement(CloseButton$5, {
31897
31954
  onClick: onBack
31898
- }, React__default.createElement(fa.FaTimes, null)), React__default.createElement(Header$1, null, React__default.createElement(SpriteContainer$2, null, React__default.createElement(SpriteFromAtlas, {
31955
+ }, React__default.createElement(fa.FaTimes, null)), React__default.createElement(Header$2, null, React__default.createElement(SpriteContainer$2, null, React__default.createElement(SpriteFromAtlas, {
31899
31956
  atlasJSON: atlasJSON,
31900
31957
  atlasIMG: atlasIMG,
31901
31958
  spriteKey: spriteKey,
@@ -31904,7 +31961,7 @@ var BaseInformationDetails = function BaseInformationDetails(_ref) {
31904
31961
  imgScale: 1
31905
31962
  })), React__default.createElement(Title$3, null, name)), React__default.createElement(Content$1, null, children)));
31906
31963
  };
31907
- var Container$r = /*#__PURE__*/styled__default.div.withConfig({
31964
+ var Container$s = /*#__PURE__*/styled__default.div.withConfig({
31908
31965
  displayName: "BaseInformationDetails__Container",
31909
31966
  componentId: "sc-1vguuz8-0"
31910
31967
  })(["position:fixed;inset:0;display:flex;justify-content:center;align-items:center;z-index:9999;"]);
@@ -31920,7 +31977,7 @@ var CloseButton$5 = /*#__PURE__*/styled__default.button.withConfig({
31920
31977
  displayName: "BaseInformationDetails__CloseButton",
31921
31978
  componentId: "sc-1vguuz8-3"
31922
31979
  })(["position:absolute;top:20px;right:20px;background:none;border:none;color:", ";font-size:1.2rem;cursor:pointer;padding:0;z-index:1;transition:transform 0.2s ease;&:hover{transform:scale(1.1);}"], uiColors.yellow);
31923
- var Header$1 = /*#__PURE__*/styled__default.div.withConfig({
31980
+ var Header$2 = /*#__PURE__*/styled__default.div.withConfig({
31924
31981
  displayName: "BaseInformationDetails__Header",
31925
31982
  componentId: "sc-1vguuz8-4"
31926
31983
  })(["display:flex;align-items:center;gap:16px;margin-bottom:24px;"]);
@@ -31946,19 +32003,19 @@ var Collapsible = function Collapsible(_ref) {
31946
32003
  var _useState = React.useState(defaultOpen),
31947
32004
  isOpen = _useState[0],
31948
32005
  setIsOpen = _useState[1];
31949
- return React__default.createElement(Container$s, {
32006
+ return React__default.createElement(Container$t, {
31950
32007
  className: className
31951
- }, React__default.createElement(Header$2, {
32008
+ }, React__default.createElement(Header$3, {
31952
32009
  onClick: function onClick() {
31953
32010
  return setIsOpen(!isOpen);
31954
32011
  }
31955
32012
  }, React__default.createElement(Title$4, null, title), React__default.createElement(Icon$1, null, isOpen ? React__default.createElement(fa.FaChevronUp, null) : React__default.createElement(fa.FaChevronDown, null))), isOpen && React__default.createElement(Content$2, null, children));
31956
32013
  };
31957
- var Container$s = /*#__PURE__*/styled__default.div.withConfig({
32014
+ var Container$t = /*#__PURE__*/styled__default.div.withConfig({
31958
32015
  displayName: "Collapsible__Container",
31959
32016
  componentId: "sc-s4h8ey-0"
31960
32017
  })(["background:rgba(0,0,0,0.3);border-radius:4px;overflow:hidden;border:1px solid ", ";"], uiColors.darkGray);
31961
- var Header$2 = /*#__PURE__*/styled__default.div.withConfig({
32018
+ var Header$3 = /*#__PURE__*/styled__default.div.withConfig({
31962
32019
  displayName: "Collapsible__Header",
31963
32020
  componentId: "sc-s4h8ey-1"
31964
32021
  })(["padding:10px 12px;background:rgba(0,0,0,0.2);display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:background-color 0.2s ease;&:hover{background:rgba(0,0,0,0.4);}"]);
@@ -32284,7 +32341,7 @@ var AdvancedFilters = function AdvancedFilters(_ref) {
32284
32341
  onClose();
32285
32342
  }
32286
32343
  };
32287
- return React__default.createElement(Container$t, null, React__default.createElement(FilterButton, {
32344
+ return React__default.createElement(Container$u, null, React__default.createElement(FilterButton, {
32288
32345
  onClick: onToggle,
32289
32346
  "$hasActiveFilters": hasActiveFilters,
32290
32347
  ref: buttonRef
@@ -32315,7 +32372,7 @@ var AdvancedFilters = function AdvancedFilters(_ref) {
32315
32372
  onClick: onClearAll
32316
32373
  }, "Clear All Filters"))));
32317
32374
  };
32318
- var Container$t = /*#__PURE__*/styled__default.div.withConfig({
32375
+ var Container$u = /*#__PURE__*/styled__default.div.withConfig({
32319
32376
  displayName: "AdvancedFilters__Container",
32320
32377
  componentId: "sc-1xj6ldr-0"
32321
32378
  })(["position:relative;margin-left:0.5rem;"]);
@@ -33409,7 +33466,7 @@ var InformationCenter = function InformationCenter(_ref) {
33409
33466
  minWidth: "300px",
33410
33467
  cancelDrag: ".PaginatedContent-content",
33411
33468
  onCloseButton: onClose
33412
- }, React__default.createElement(Container$u, null, React__default.createElement(InternalTabs, {
33469
+ }, React__default.createElement(Container$v, null, React__default.createElement(InternalTabs, {
33413
33470
  tabs: tabs,
33414
33471
  activeTextColor: "#000000",
33415
33472
  activeTab: activeTab,
@@ -33420,7 +33477,7 @@ var InformationCenter = function InformationCenter(_ref) {
33420
33477
  hoverColor: "#fef3c7"
33421
33478
  })));
33422
33479
  };
33423
- var Container$u = /*#__PURE__*/styled__default.div.withConfig({
33480
+ var Container$v = /*#__PURE__*/styled__default.div.withConfig({
33424
33481
  displayName: "InformationCenter__Container",
33425
33482
  componentId: "sc-1ttl62e-0"
33426
33483
  })(["width:100%;max-width:100%;margin:0 auto;padding:0.125rem;overflow:hidden;box-sizing:border-box;@media (min-width:320px){padding:0.25rem;}@media (min-width:360px){padding:0.5rem;}@media (min-width:480px){padding:0.75rem;}"]);
@@ -33591,7 +33648,7 @@ var ShortcutsSetter = function ShortcutsSetter(_ref) {
33591
33648
  }
33592
33649
  return null;
33593
33650
  };
33594
- return React__default.createElement(Container$v, null, React__default.createElement("p", null, "Shortcuts:"), React__default.createElement(List, {
33651
+ return React__default.createElement(Container$w, null, React__default.createElement("p", null, "Shortcuts:"), React__default.createElement(List, {
33595
33652
  id: "shortcuts_list"
33596
33653
  }, Array.from({
33597
33654
  length: 12
@@ -33609,7 +33666,7 @@ var ShortcutsSetter = function ShortcutsSetter(_ref) {
33609
33666
  }, getContent(i));
33610
33667
  })));
33611
33668
  };
33612
- var Container$v = /*#__PURE__*/styled__default.div.withConfig({
33669
+ var Container$w = /*#__PURE__*/styled__default.div.withConfig({
33613
33670
  displayName: "ShortcutsSetter__Container",
33614
33671
  componentId: "sc-xuouuf-0"
33615
33672
  })(["p{margin:0;margin-left:0.5rem;font-size:10px;}width:100%;"]);
@@ -34152,7 +34209,7 @@ var ColorSelector = function ColorSelector(_ref) {
34152
34209
  cancelDrag: ".react-colorful",
34153
34210
  width: "25rem",
34154
34211
  onCloseButton: onClose
34155
- }, React__default.createElement(Container$w, null, React__default.createElement(Header$3, null, "Select Color"), React__default.createElement(ColorPickerWrapper, null, React__default.createElement(reactColorful.HexColorPicker, {
34212
+ }, React__default.createElement(Container$x, null, React__default.createElement(Header$4, null, "Select Color"), React__default.createElement(ColorPickerWrapper, null, React__default.createElement(reactColorful.HexColorPicker, {
34156
34213
  color: currentColor,
34157
34214
  onChange: function onChange(color) {
34158
34215
  setCurrentColor(color);
@@ -34168,11 +34225,11 @@ var ColorSelector = function ColorSelector(_ref) {
34168
34225
  onClose: handleClose
34169
34226
  }));
34170
34227
  };
34171
- var Container$w = /*#__PURE__*/styled__default.div.withConfig({
34228
+ var Container$x = /*#__PURE__*/styled__default.div.withConfig({
34172
34229
  displayName: "ItemPropertyColorSelector__Container",
34173
34230
  componentId: "sc-me1r4z-0"
34174
34231
  })(["text-align:center;background:inherit;display:flex;flex-direction:column;gap:1.5rem;align-items:center;width:100%;max-width:24rem;margin:0 auto;"]);
34175
- var Header$3 = /*#__PURE__*/styled__default.h2.withConfig({
34232
+ var Header$4 = /*#__PURE__*/styled__default.h2.withConfig({
34176
34233
  displayName: "ItemPropertyColorSelector__Header",
34177
34234
  componentId: "sc-me1r4z-1"
34178
34235
  })(["color:white;font-size:1rem;margin:0;width:100%;text-align:center;"]);
@@ -34243,7 +34300,7 @@ var GemSelector = function GemSelector(_ref) {
34243
34300
  scale: scale,
34244
34301
  cancelDrag: ".gem-selector-container",
34245
34302
  onCloseButton: onClose
34246
- }, React__default.createElement(ContentWrapper$1, null, React__default.createElement(Header$4, null, React__default.createElement(Title$5, null, "GEM SELECTION"), React__default.createElement(Subtitle, null, "Select gems to detach")), React__default.createElement(GemGrid, null, (_item$attachedGems = item.attachedGems) == null ? void 0 : _item$attachedGems.map(function (gem, index) {
34303
+ }, React__default.createElement(ContentWrapper$1, null, React__default.createElement(Header$5, null, React__default.createElement(Title$5, null, "GEM SELECTION"), React__default.createElement(Subtitle, null, "Select gems to detach")), React__default.createElement(GemGrid, null, (_item$attachedGems = item.attachedGems) == null ? void 0 : _item$attachedGems.map(function (gem, index) {
34247
34304
  return React__default.createElement(GemItem, {
34248
34305
  key: gem.key + "-" + index
34249
34306
  }, React__default.createElement(CheckItemWrapper$1, null, React__default.createElement(CheckItem, {
@@ -34282,7 +34339,7 @@ var Subtitle = /*#__PURE__*/styled__default.h2.withConfig({
34282
34339
  displayName: "GemSelector__Subtitle",
34283
34340
  componentId: "sc-gbt8g4-1"
34284
34341
  })(["font-size:0.6rem;color:", ";margin:0;"], uiColors.white);
34285
- var Header$4 = /*#__PURE__*/styled__default.div.withConfig({
34342
+ var Header$5 = /*#__PURE__*/styled__default.div.withConfig({
34286
34343
  displayName: "GemSelector__Header",
34287
34344
  componentId: "sc-gbt8g4-2"
34288
34345
  })(["text-align:center;padding:5px;border-bottom:2px solid #444;"]);
@@ -34524,7 +34581,7 @@ var ListMenu = function ListMenu(_ref) {
34524
34581
  onSelected = _ref.onSelected,
34525
34582
  x = _ref.x,
34526
34583
  y = _ref.y;
34527
- return React__default.createElement(Container$x, {
34584
+ return React__default.createElement(Container$y, {
34528
34585
  x: x,
34529
34586
  y: y
34530
34587
  }, React__default.createElement("ul", {
@@ -34541,7 +34598,7 @@ var ListMenu = function ListMenu(_ref) {
34541
34598
  }, (params == null ? void 0 : params.text) || 'No text');
34542
34599
  })));
34543
34600
  };
34544
- var Container$x = /*#__PURE__*/styled__default.div.withConfig({
34601
+ var Container$y = /*#__PURE__*/styled__default.div.withConfig({
34545
34602
  displayName: "ListMenu__Container",
34546
34603
  componentId: "sc-i9097t-0"
34547
34604
  })(["display:flex;flex-direction:column;width:100%;justify-content:start;align-items:flex-start;position:absolute;top:", "px;left:", "px;li{font-size:", ";}"], function (props) {
@@ -34560,7 +34617,7 @@ var Pager = function Pager(_ref) {
34560
34617
  itemsPerPage = _ref.itemsPerPage,
34561
34618
  onPageChange = _ref.onPageChange;
34562
34619
  var totalPages = Math.ceil(totalItems / itemsPerPage);
34563
- return React__default.createElement(Container$y, null, React__default.createElement("p", null, "Total items: ", totalItems), React__default.createElement(PagerContainer, null, React__default.createElement("button", {
34620
+ return React__default.createElement(Container$z, null, React__default.createElement("p", null, "Total items: ", totalItems), React__default.createElement(PagerContainer, null, React__default.createElement("button", {
34564
34621
  disabled: currentPage === 1,
34565
34622
  onPointerDown: function onPointerDown() {
34566
34623
  return onPageChange(Math.max(currentPage - 1, 1));
@@ -34574,7 +34631,7 @@ var Pager = function Pager(_ref) {
34574
34631
  }
34575
34632
  }, '>')));
34576
34633
  };
34577
- var Container$y = /*#__PURE__*/styled__default.div.withConfig({
34634
+ var Container$z = /*#__PURE__*/styled__default.div.withConfig({
34578
34635
  displayName: "Pager__Container",
34579
34636
  componentId: "sc-1ekmf50-0"
34580
34637
  })(["display:flex;flex-direction:column;align-items:center;p{margin:0;font-size:", ";}"], uiFonts.size.xsmall);
@@ -35095,13 +35152,13 @@ var TabBody = function TabBody(_ref) {
35095
35152
  children = _ref.children,
35096
35153
  styles = _ref.styles,
35097
35154
  centerContent = _ref.centerContent;
35098
- return React__default.createElement(Container$z, {
35155
+ return React__default.createElement(Container$A, {
35099
35156
  styles: styles,
35100
35157
  "data-tab-id": id,
35101
35158
  centerContent: centerContent
35102
35159
  }, children);
35103
35160
  };
35104
- var Container$z = /*#__PURE__*/styled__default.div.withConfig({
35161
+ var Container$A = /*#__PURE__*/styled__default.div.withConfig({
35105
35162
  displayName: "TabBody__Container",
35106
35163
  componentId: "sc-196oof2-0"
35107
35164
  })(["width:", ";height:", ";overflow-y:auto;display:", ";justify-content:", ";align-items:", ";"], function (props) {
@@ -35753,7 +35810,7 @@ var ProgressBar$1 = function ProgressBar(_ref) {
35753
35810
  }
35754
35811
  return value * 100 / max;
35755
35812
  };
35756
- return React__default.createElement(Container$A, {
35813
+ return React__default.createElement(Container$B, {
35757
35814
  className: "rpgui-progress",
35758
35815
  "data-value": calculatePercentageValue(max, value) / 100,
35759
35816
  "data-rpguitype": "progress",
@@ -35783,7 +35840,7 @@ var TextOverlay$1 = /*#__PURE__*/styled__default.div.withConfig({
35783
35840
  displayName: "ProgressBar__TextOverlay",
35784
35841
  componentId: "sc-qa6fzh-1"
35785
35842
  })(["width:100%;position:relative;"]);
35786
- var Container$A = /*#__PURE__*/styled__default.div.withConfig({
35843
+ var Container$B = /*#__PURE__*/styled__default.div.withConfig({
35787
35844
  displayName: "ProgressBar__Container",
35788
35845
  componentId: "sc-qa6fzh-2"
35789
35846
  })(["display:flex;flex-direction:column;min-width:", "px;width:", "%;justify-content:start;align-items:flex-start;", " @media (max-width:950px){transform:scale(", ");}"], function (props) {
@@ -36024,9 +36081,9 @@ var InputRadio = function InputRadio(_ref) {
36024
36081
 
36025
36082
  var RPGUIScrollbar = function RPGUIScrollbar(_ref) {
36026
36083
  var children = _ref.children;
36027
- return React__default.createElement(Container$B, null, children);
36084
+ return React__default.createElement(Container$C, null, children);
36028
36085
  };
36029
- var Container$B = /*#__PURE__*/styled__default.div.withConfig({
36086
+ var Container$C = /*#__PURE__*/styled__default.div.withConfig({
36030
36087
  displayName: "RPGUIScrollbar__Container",
36031
36088
  componentId: "sc-p3msmb-0"
36032
36089
  })([".rpgui-content ::-webkit-scrollbar,.rpgui-content::-webkit-scrollbar{width:25px !important;}.rpgui-content ::-webkit-scrollbar-track,.rpgui-content::-webkit-scrollbar-track{background-size:25px 60px !important;}"]);
@@ -36182,7 +36239,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
36182
36239
  margin = _ref$margin === void 0 ? 20 : _ref$margin;
36183
36240
  // Ensure the width is at least 1% if value is greater than 0
36184
36241
  var width = value > 0 ? Math.max(1, Math.min(100, value)) : 0;
36185
- return React__default.createElement(Container$C, {
36242
+ return React__default.createElement(Container$D, {
36186
36243
  className: "simple-progress-bar"
36187
36244
  }, React__default.createElement(ProgressBarContainer, {
36188
36245
  margin: margin
@@ -36191,7 +36248,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
36191
36248
  bgColor: bgColor
36192
36249
  }))));
36193
36250
  };
36194
- var Container$C = /*#__PURE__*/styled__default.div.withConfig({
36251
+ var Container$D = /*#__PURE__*/styled__default.div.withConfig({
36195
36252
  displayName: "SimpleProgressBar__Container",
36196
36253
  componentId: "sc-mbeil3-0"
36197
36254
  })(["display:flex;justify-content:center;align-items:center;width:100%;"]);
@@ -36524,7 +36581,7 @@ var SocialModal = function SocialModal(_ref) {
36524
36581
  title: "Social Channels",
36525
36582
  width: "500px",
36526
36583
  onCloseButton: onClose
36527
- }, React__default.createElement(Container$D, null, React__default.createElement(HeaderImage, {
36584
+ }, React__default.createElement(Container$E, null, React__default.createElement(HeaderImage, {
36528
36585
  src: img$9,
36529
36586
  alt: ""
36530
36587
  }), React__default.createElement(ButtonsContainer$3, null, React__default.createElement(MainButtons, null, React__default.createElement(SocialButton$1, {
@@ -36542,7 +36599,7 @@ var SocialModal = function SocialModal(_ref) {
36542
36599
  onClick: handleWhatsAppClick
36543
36600
  }, React__default.createElement(fa.FaWhatsapp, null), " Join WhatsApp")))));
36544
36601
  };
36545
- var Container$D = /*#__PURE__*/styled__default.div.withConfig({
36602
+ var Container$E = /*#__PURE__*/styled__default.div.withConfig({
36546
36603
  displayName: "SocialModal__Container",
36547
36604
  componentId: "sc-tbjhp9-0"
36548
36605
  })(["width:100%;display:flex;flex-direction:column;gap:16px;background-color:#5c4132;position:relative;border-radius:8px;overflow:hidden;&:before,&:after{content:'';position:absolute;left:0;right:0;height:3px;}&:before{bottom:0;background:linear-gradient( to right,#5c4132 0%,#2b1810 2%,#2b1810 98%,#5c4132 100% );}"]);
@@ -36588,7 +36645,7 @@ var SpellInfo$1 = function SpellInfo(_ref) {
36588
36645
  castingType = spell.castingType,
36589
36646
  cooldown = spell.cooldown,
36590
36647
  maxDistanceGrid = spell.maxDistanceGrid;
36591
- return React__default.createElement(Container$E, null, React__default.createElement(Header$5, null, React__default.createElement("div", null, React__default.createElement(Title$b, null, name), React__default.createElement(Type$1, null, magicWords))), React__default.createElement(Statistic$1, null, React__default.createElement("div", {
36648
+ return React__default.createElement(Container$F, null, React__default.createElement(Header$6, null, React__default.createElement("div", null, React__default.createElement(Title$b, null, name), React__default.createElement(Type$1, null, magicWords))), React__default.createElement(Statistic$1, null, React__default.createElement("div", {
36592
36649
  className: "label"
36593
36650
  }, "Casting Type:"), React__default.createElement("div", {
36594
36651
  className: "value"
@@ -36614,7 +36671,7 @@ var SpellInfo$1 = function SpellInfo(_ref) {
36614
36671
  className: "value"
36615
36672
  }, requiredItem))), React__default.createElement(Description$4, null, description));
36616
36673
  };
36617
- var Container$E = /*#__PURE__*/styled__default.div.withConfig({
36674
+ var Container$F = /*#__PURE__*/styled__default.div.withConfig({
36618
36675
  displayName: "SpellInfo__Container",
36619
36676
  componentId: "sc-4hbw3q-0"
36620
36677
  })(["color:white;background-color:#222;border-radius:5px;padding:0.5rem;font-size:", ";border:3px solid ", ";height:max-content;width:30rem;@media (max-width:580px){width:80vw;}"], uiFonts.size.small, uiColors.lightGray);
@@ -36630,7 +36687,7 @@ var Description$4 = /*#__PURE__*/styled__default.div.withConfig({
36630
36687
  displayName: "SpellInfo__Description",
36631
36688
  componentId: "sc-4hbw3q-3"
36632
36689
  })(["margin-top:1.5rem;font-size:", ";color:", ";font-style:italic;"], uiFonts.size.small, uiColors.lightGray);
36633
- var Header$5 = /*#__PURE__*/styled__default.div.withConfig({
36690
+ var Header$6 = /*#__PURE__*/styled__default.div.withConfig({
36634
36691
  displayName: "SpellInfo__Header",
36635
36692
  componentId: "sc-4hbw3q-4"
36636
36693
  })(["display:flex;align-items:center;justify-content:space-between;margin-bottom:0.5rem;"]);
@@ -36668,7 +36725,7 @@ var MobileSpellTooltip = function MobileSpellTooltip(_ref) {
36668
36725
  var _ref$current;
36669
36726
  (_ref$current = ref.current) == null ? void 0 : _ref$current.classList.add('fadeOut');
36670
36727
  };
36671
- return React__default.createElement(ModalPortal, null, React__default.createElement(Container$F, {
36728
+ return React__default.createElement(ModalPortal, null, React__default.createElement(Container$G, {
36672
36729
  ref: ref,
36673
36730
  onTouchEnd: function onTouchEnd() {
36674
36731
  handleFadeOut();
@@ -36693,7 +36750,7 @@ var MobileSpellTooltip = function MobileSpellTooltip(_ref) {
36693
36750
  }, option.text);
36694
36751
  }))));
36695
36752
  };
36696
- var Container$F = /*#__PURE__*/styled__default.div.withConfig({
36753
+ var Container$G = /*#__PURE__*/styled__default.div.withConfig({
36697
36754
  displayName: "MobileSpellTooltip__Container",
36698
36755
  componentId: "sc-6p7uvr-0"
36699
36756
  })(["position:absolute;z-index:100;left:0;top:0;width:100vw;height:100vh;background-color:rgba(0 0 0 / 0.5);display:flex;justify-content:center;align-items:center;gap:0.5rem;transition:opacity 0.08s;animation:fadeIn 0.1s forwards;@keyframes fadeIn{0%{opacity:0;}100%{opacity:0.92;}}@keyframes fadeOut{0%{opacity:0.92;}100%{opacity:0;}}&.fadeOut{animation:fadeOut 0.1s forwards;}@media (max-width:580px){flex-direction:column;}"]);
@@ -36734,13 +36791,13 @@ var MagicTooltip = function MagicTooltip(_ref) {
36734
36791
  }
36735
36792
  return;
36736
36793
  }, []);
36737
- return React__default.createElement(ModalPortal, null, React__default.createElement(Container$G, {
36794
+ return React__default.createElement(ModalPortal, null, React__default.createElement(Container$H, {
36738
36795
  ref: ref
36739
36796
  }, React__default.createElement(SpellInfoDisplay, {
36740
36797
  spell: spell
36741
36798
  })));
36742
36799
  };
36743
- var Container$G = /*#__PURE__*/styled__default.div.withConfig({
36800
+ var Container$H = /*#__PURE__*/styled__default.div.withConfig({
36744
36801
  displayName: "SpellTooltip__Container",
36745
36802
  componentId: "sc-1go0gwg-0"
36746
36803
  })(["position:absolute;z-index:100;pointer-events:none;left:0;top:0;opacity:0;transition:opacity 0.08s;"]);
@@ -36813,7 +36870,7 @@ var Spell = function Spell(_ref) {
36813
36870
  var IMAGE_SCALE = 2;
36814
36871
  return React__default.createElement(SpellInfoWrapper, {
36815
36872
  spell: spell
36816
- }, React__default.createElement(Container$H, {
36873
+ }, React__default.createElement(Container$I, {
36817
36874
  onPointerUp: onPointerUp == null ? void 0 : onPointerUp.bind(null, spellKey),
36818
36875
  isSettingShortcut: isSettingShortcut && !disabled,
36819
36876
  className: "spell"
@@ -36832,7 +36889,7 @@ var Spell = function Spell(_ref) {
36832
36889
  className: "mana"
36833
36890
  }, manaCost))));
36834
36891
  };
36835
- var Container$H = /*#__PURE__*/styled__default.button.withConfig({
36892
+ var Container$I = /*#__PURE__*/styled__default.button.withConfig({
36836
36893
  displayName: "Spell__Container",
36837
36894
  componentId: "sc-j96fa2-0"
36838
36895
  })(["display:block;background:none;border:2px solid transparent;border-radius:1rem;width:100%;display:flex;gap:1rem;align-items:center;padding:0 1rem;text-align:left;position:relative;animation:", ";@keyframes border-color-change{0%{border-color:", ";}50%{border-color:transparent;}100%{border-color:", ";}}&:hover,&:focus{background-color:", ";}&:active{background:none;}"], function (_ref2) {
@@ -36911,7 +36968,7 @@ var Spellbook = function Spellbook(_ref) {
36911
36968
  height: "inherit",
36912
36969
  cancelDrag: "#spellbook-search, #shortcuts_list, .spell",
36913
36970
  scale: scale
36914
- }, React__default.createElement(Container$I, null, React__default.createElement(Title$d, null, "Learned Spells"), React__default.createElement(ShortcutsSetter, {
36971
+ }, React__default.createElement(Container$J, null, React__default.createElement(Title$d, null, "Learned Spells"), React__default.createElement(ShortcutsSetter, {
36915
36972
  setSettingShortcutIndex: setSettingShortcutIndex,
36916
36973
  settingShortcutIndex: settingShortcutIndex,
36917
36974
  shortcuts: shortcuts,
@@ -36947,7 +37004,7 @@ var Title$d = /*#__PURE__*/styled__default.h1.withConfig({
36947
37004
  displayName: "Spellbook__Title",
36948
37005
  componentId: "sc-r02nfq-0"
36949
37006
  })(["font-size:", " !important;margin-bottom:0 !important;"], uiFonts.size.large);
36950
- var Container$I = /*#__PURE__*/styled__default.div.withConfig({
37007
+ var Container$J = /*#__PURE__*/styled__default.div.withConfig({
36951
37008
  displayName: "Spellbook__Container",
36952
37009
  componentId: "sc-r02nfq-1"
36953
37010
  })(["width:100%;height:100%;color:white;display:flex;flex-direction:column;"]);
@@ -37099,42 +37156,1360 @@ var ProgressIndicator = /*#__PURE__*/styled__default.div.withConfig({
37099
37156
  return isActive ? '0 0 0 1px black, 1px 1px 0 1px black, 2px 2px 0 1px black, -1px -1px 0 1px black' : '0 0 0 1px black, 1px 1px 0 1px gray, 2px 2px 0 1px gray, -1px -1px 0 1px gray';
37100
37157
  });
37101
37158
 
37102
- var TextArea = function TextArea(_ref) {
37103
- var props = _extends({}, (_objectDestructuringEmpty(_ref), _ref));
37104
- return React__default.createElement("textarea", Object.assign({}, props));
37159
+ var CTAButton = function CTAButton(_ref) {
37160
+ var icon = _ref.icon,
37161
+ label = _ref.label,
37162
+ onClick = _ref.onClick,
37163
+ className = _ref.className,
37164
+ _ref$fullWidth = _ref.fullWidth,
37165
+ fullWidth = _ref$fullWidth === void 0 ? false : _ref$fullWidth,
37166
+ _ref$textColor = _ref.textColor,
37167
+ textColor = _ref$textColor === void 0 ? '#ffffff' : _ref$textColor,
37168
+ _ref$iconColor = _ref.iconColor,
37169
+ iconColor = _ref$iconColor === void 0 ? '#f59e0b' : _ref$iconColor,
37170
+ _ref$disabled = _ref.disabled,
37171
+ disabled = _ref$disabled === void 0 ? false : _ref$disabled;
37172
+ return React__default.createElement(ButtonContainer$5, {
37173
+ className: className,
37174
+ onPointerDown: disabled ? undefined : onClick,
37175
+ "$fullWidth": fullWidth,
37176
+ "$disabled": disabled,
37177
+ "$color": textColor
37178
+ }, React__default.createElement(ButtonContent, null, React__default.createElement(IconWrapper, {
37179
+ "$color": iconColor,
37180
+ "$disabled": disabled
37181
+ }, icon), label && React__default.createElement(ButtonLabel, {
37182
+ "$color": textColor,
37183
+ "$disabled": disabled
37184
+ }, label)));
37105
37185
  };
37186
+ var ButtonContainer$5 = /*#__PURE__*/styled__default.div.withConfig({
37187
+ displayName: "CTAButton__ButtonContainer",
37188
+ componentId: "sc-1azvwn5-0"
37189
+ })(["display:inline-flex;align-items:center;padding:0.75rem 1.25rem;background:rgba(0,0,0,0.3);border:2px solid #f59e0b;box-shadow:0 0 10px rgba(245,158,11,0.3);border-radius:4px;cursor:", ";transition:all 0.2s;position:relative;opacity:", ";color:", ";", " &:hover{background:", ";box-shadow:", ";transform:", ";}&:active{transform:", ";box-shadow:", ";}&:before{content:'';position:absolute;inset:-1px;border-radius:5px;padding:1px;background:linear-gradient(45deg,#f59e0b,#fbbf24,#f59e0b);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask-composite:exclude;-webkit-mask-composite:destination-out;}"], function (props) {
37190
+ return props.$disabled ? 'not-allowed' : 'pointer';
37191
+ }, function (props) {
37192
+ return props.$disabled ? 0.5 : 1;
37193
+ }, function (props) {
37194
+ return props.$disabled ? '#6b7280' : props.$color;
37195
+ }, function (props) {
37196
+ return props.$fullWidth && styled.css(["display:flex;justify-content:center;"]);
37197
+ }, function (props) {
37198
+ return props.$disabled ? 'rgba(0, 0, 0, 0.3)' : 'rgba(0, 0, 0, 0.4)';
37199
+ }, function (props) {
37200
+ return props.$disabled ? '0 0 10px rgba(245, 158, 11, 0.3)' : '0 0 15px rgba(245, 158, 11, 0.4)';
37201
+ }, function (props) {
37202
+ return props.$disabled ? 'none' : 'translateY(-1px)';
37203
+ }, function (props) {
37204
+ return props.$disabled ? 'none' : 'translateY(1px)';
37205
+ }, function (props) {
37206
+ return props.$disabled ? '0 0 10px rgba(245, 158, 11, 0.3)' : '0 0 5px rgba(245, 158, 11, 0.2)';
37207
+ });
37208
+ var ButtonContent = /*#__PURE__*/styled__default.div.withConfig({
37209
+ displayName: "CTAButton__ButtonContent",
37210
+ componentId: "sc-1azvwn5-1"
37211
+ })(["display:flex;align-items:center;gap:0.75rem;"]);
37212
+ var IconWrapper = /*#__PURE__*/styled__default.div.withConfig({
37213
+ displayName: "CTAButton__IconWrapper",
37214
+ componentId: "sc-1azvwn5-2"
37215
+ })(["svg{font-size:1.25rem;color:", ";filter:drop-shadow(0 0 2px rgba(245,158,11,0.5));opacity:", ";}"], function (props) {
37216
+ return props.$color;
37217
+ }, function (props) {
37218
+ return props.$disabled ? 0.5 : 1;
37219
+ });
37220
+ var ButtonLabel = /*#__PURE__*/styled__default.span.withConfig({
37221
+ displayName: "CTAButton__ButtonLabel",
37222
+ componentId: "sc-1azvwn5-3"
37223
+ })(["color:", ";font-family:'Press Start 2P',cursive;font-size:0.875rem;text-shadow:0 0 4px rgba(245,158,11,0.5);opacity:", ";"], function (props) {
37224
+ return props.$color;
37225
+ }, function (props) {
37226
+ return props.$disabled ? 0.5 : 1;
37227
+ });
37106
37228
 
37107
- var img$a = '';
37108
-
37109
- var img$b = '';
37110
-
37111
- var img$c = '';
37112
-
37113
- var DayNightPeriod = function DayNightPeriod(_ref) {
37114
- var _periodOfDaySrcFiles;
37115
- var periodOfDay = _ref.periodOfDay;
37116
- var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[shared.PeriodOfDay.Morning] = img$b, _periodOfDaySrcFiles[shared.PeriodOfDay.Afternoon] = img$a, _periodOfDaySrcFiles[shared.PeriodOfDay.Night] = img$c, _periodOfDaySrcFiles);
37117
- return React__default.createElement(GifContainer, null, React__default.createElement("img", {
37118
- src: periodOfDaySrcFiles[periodOfDay]
37119
- }));
37229
+ var MetadataDisplay = function MetadataDisplay(_ref) {
37230
+ var _metadata$selectedSki;
37231
+ var type = _ref.type,
37232
+ metadata = _ref.metadata;
37233
+ switch (type) {
37234
+ case shared.MetadataType.CharacterSkin:
37235
+ return React__default.createElement(MetadataInfo, null, React__default.createElement(MetadataLabel, null, React__default.createElement(fa.FaInfoCircle, null), React__default.createElement("span", null, "Skin:")), React__default.createElement(MetadataValue, null, ((_metadata$selectedSki = metadata.selectedSkin) == null ? void 0 : _metadata$selectedSki.name) || 'Custom skin'));
37236
+ default:
37237
+ return null;
37238
+ }
37120
37239
  };
37121
- var GifContainer = /*#__PURE__*/styled__default.div.withConfig({
37122
- displayName: "DayNightPeriod__GifContainer",
37123
- componentId: "sc-10t97fw-0"
37124
- })(["width:100%;img{width:67%;}"]);
37125
-
37126
- var img$d = '';
37240
+ var CartView = function CartView(_ref2) {
37241
+ var cartItems = _ref2.cartItems,
37242
+ onRemoveFromCart = _ref2.onRemoveFromCart,
37243
+ onClose = _ref2.onClose,
37244
+ onPurchase = _ref2.onPurchase,
37245
+ atlasJSON = _ref2.atlasJSON,
37246
+ atlasIMG = _ref2.atlasIMG;
37247
+ var _useState = React.useState(false),
37248
+ isLoading = _useState[0],
37249
+ setIsLoading = _useState[1];
37250
+ var _useState2 = React.useState(null),
37251
+ error = _useState2[0],
37252
+ setError = _useState2[1];
37253
+ var total = cartItems.reduce(function (sum, cartItem) {
37254
+ return sum + cartItem.item.price * cartItem.quantity;
37255
+ }, 0);
37256
+ var formatPrice = function formatPrice(price) {
37257
+ return price.toFixed(2);
37258
+ };
37259
+ var handlePurchase = /*#__PURE__*/function () {
37260
+ var _ref3 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
37261
+ var success;
37262
+ return _regeneratorRuntime().wrap(function _callee$(_context) {
37263
+ while (1) switch (_context.prev = _context.next) {
37264
+ case 0:
37265
+ _context.prev = 0;
37266
+ setIsLoading(true);
37267
+ setError(null);
37268
+ _context.next = 5;
37269
+ return onPurchase();
37270
+ case 5:
37271
+ success = _context.sent;
37272
+ if (!success) {
37273
+ setError('Purchase failed. Please try again.');
37274
+ }
37275
+ _context.next = 13;
37276
+ break;
37277
+ case 9:
37278
+ _context.prev = 9;
37279
+ _context.t0 = _context["catch"](0);
37280
+ setError('An error occurred during purchase. Please try again.');
37281
+ console.error('Purchase error:', _context.t0);
37282
+ case 13:
37283
+ _context.prev = 13;
37284
+ setIsLoading(false);
37285
+ return _context.finish(13);
37286
+ case 16:
37287
+ case "end":
37288
+ return _context.stop();
37289
+ }
37290
+ }, _callee, null, [[0, 9, 13, 16]]);
37291
+ }));
37292
+ return function handlePurchase() {
37293
+ return _ref3.apply(this, arguments);
37294
+ };
37295
+ }();
37296
+ return React__default.createElement(Container$K, null, React__default.createElement(Header$7, null, React__default.createElement(Title$e, null, "Shopping Cart"), React__default.createElement(CloseButton$9, {
37297
+ onPointerDown: onClose
37298
+ }, React__default.createElement(fa.FaTimes, null))), React__default.createElement(CartItems, null, cartItems.length === 0 ? React__default.createElement(EmptyCart, null, "Your cart is empty") : cartItems.map(function (cartItem) {
37299
+ return React__default.createElement(CartItemRow, {
37300
+ key: cartItem.item.key
37301
+ }, React__default.createElement(ItemIconContainer$1, null, React__default.createElement(SpriteFromAtlas, {
37302
+ atlasJSON: atlasJSON,
37303
+ atlasIMG: atlasIMG,
37304
+ spriteKey: cartItem.item.texturePath,
37305
+ width: 32,
37306
+ height: 32,
37307
+ imgScale: 2,
37308
+ centered: true
37309
+ })), React__default.createElement(ItemDetails, null, React__default.createElement(ItemName, null, cartItem.item.name), React__default.createElement(ItemInfo$1, null, React__default.createElement("span", null, "$", formatPrice(cartItem.item.price)), React__default.createElement("span", null, "\xD7"), React__default.createElement("span", null, cartItem.quantity), React__default.createElement("span", null, "="), React__default.createElement("span", null, "$", formatPrice(cartItem.item.price * cartItem.quantity))), cartItem.metadata && cartItem.item.metadataType && React__default.createElement(MetadataDisplay, {
37310
+ type: cartItem.item.metadataType,
37311
+ metadata: cartItem.metadata
37312
+ })), React__default.createElement(CTAButton, {
37313
+ icon: React__default.createElement(fa.FaTrash, null),
37314
+ onClick: function onClick(e) {
37315
+ e.stopPropagation();
37316
+ onRemoveFromCart(cartItem.item.key);
37317
+ }
37318
+ }));
37319
+ })), React__default.createElement(Footer$1, null, React__default.createElement(TotalInfo, null, React__default.createElement(TotalRow, null, React__default.createElement("span", null, "Total:"), React__default.createElement("span", null, "$", formatPrice(total))), error && React__default.createElement(ErrorMessage$1, null, error)), React__default.createElement(CTAButton, {
37320
+ icon: React__default.createElement(fa.FaShoppingBag, null),
37321
+ label: isLoading ? 'Processing...' : 'Complete Purchase',
37322
+ onClick: handlePurchase,
37323
+ fullWidth: true,
37324
+ disabled: cartItems.length === 0 || isLoading
37325
+ })));
37326
+ };
37327
+ var Container$K = /*#__PURE__*/styled__default.div.withConfig({
37328
+ displayName: "CartView__Container",
37329
+ componentId: "sc-ydtyl1-0"
37330
+ })(["display:flex;flex-direction:column;width:100%;height:100%;gap:1.5rem;padding:1.5rem;"]);
37331
+ var Header$7 = /*#__PURE__*/styled__default.div.withConfig({
37332
+ displayName: "CartView__Header",
37333
+ componentId: "sc-ydtyl1-1"
37334
+ })(["display:flex;justify-content:space-between;align-items:center;"]);
37335
+ var Title$e = /*#__PURE__*/styled__default.h2.withConfig({
37336
+ displayName: "CartView__Title",
37337
+ componentId: "sc-ydtyl1-2"
37338
+ })(["font-family:'Press Start 2P',cursive;font-size:1rem;color:#ffffff;margin:0;"]);
37339
+ var CloseButton$9 = /*#__PURE__*/styled__default.div.withConfig({
37340
+ displayName: "CartView__CloseButton",
37341
+ componentId: "sc-ydtyl1-3"
37342
+ })(["padding:0.5rem;min-width:unset;width:42px;height:42px;display:flex;font-size:1.5rem;align-items:center;color:white;justify-content:center;"]);
37343
+ var CartItems = /*#__PURE__*/styled__default.div.withConfig({
37344
+ displayName: "CartView__CartItems",
37345
+ componentId: "sc-ydtyl1-4"
37346
+ })(["display:flex;flex-direction:column;gap:1rem;overflow-y:auto;flex:1;min-height:200px;padding-right:0.5rem;&::-webkit-scrollbar{width:8px;background-color:rgba(0,0,0,0.2);border-radius:4px;}&::-webkit-scrollbar-thumb{background-color:rgba(255,255,255,0.2);border-radius:4px;&:hover{background-color:rgba(255,255,255,0.3);}}scrollbar-width:thin;scrollbar-color:rgba(255,255,255,0.2) rgba(0,0,0,0.2);"]);
37347
+ var EmptyCart = /*#__PURE__*/styled__default.div.withConfig({
37348
+ displayName: "CartView__EmptyCart",
37349
+ componentId: "sc-ydtyl1-5"
37350
+ })(["display:flex;align-items:center;justify-content:center;height:100%;color:#ffffff;font-family:'Press Start 2P',cursive;font-size:0.875rem;opacity:0.7;"]);
37351
+ var CartItemRow = /*#__PURE__*/styled__default.div.withConfig({
37352
+ displayName: "CartView__CartItemRow",
37353
+ componentId: "sc-ydtyl1-6"
37354
+ })(["display:flex;align-items:center;gap:1rem;padding:1rem;background:rgba(0,0,0,0.2);border-radius:4px;"]);
37355
+ var ItemIconContainer$1 = /*#__PURE__*/styled__default.div.withConfig({
37356
+ displayName: "CartView__ItemIconContainer",
37357
+ componentId: "sc-ydtyl1-7"
37358
+ })(["width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;padding:4px;"]);
37359
+ var ItemDetails = /*#__PURE__*/styled__default.div.withConfig({
37360
+ displayName: "CartView__ItemDetails",
37361
+ componentId: "sc-ydtyl1-8"
37362
+ })(["flex:1;display:flex;flex-direction:column;gap:0.5rem;"]);
37363
+ var ItemName = /*#__PURE__*/styled__default.div.withConfig({
37364
+ displayName: "CartView__ItemName",
37365
+ componentId: "sc-ydtyl1-9"
37366
+ })(["font-family:'Press Start 2P',cursive;font-size:0.875rem;color:#ffffff;"]);
37367
+ var ItemInfo$1 = /*#__PURE__*/styled__default.div.withConfig({
37368
+ displayName: "CartView__ItemInfo",
37369
+ componentId: "sc-ydtyl1-10"
37370
+ })(["display:flex;align-items:center;gap:0.5rem;font-family:'Press Start 2P',cursive;font-size:0.75rem;color:#fef08a;"]);
37371
+ var Footer$1 = /*#__PURE__*/styled__default.div.withConfig({
37372
+ displayName: "CartView__Footer",
37373
+ componentId: "sc-ydtyl1-11"
37374
+ })(["display:flex;flex-direction:column;gap:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,0.1);flex-shrink:0;"]);
37375
+ var TotalInfo = /*#__PURE__*/styled__default.div.withConfig({
37376
+ displayName: "CartView__TotalInfo",
37377
+ componentId: "sc-ydtyl1-12"
37378
+ })(["display:flex;flex-direction:column;gap:0.5rem;"]);
37379
+ var TotalRow = /*#__PURE__*/styled__default.div.withConfig({
37380
+ displayName: "CartView__TotalRow",
37381
+ componentId: "sc-ydtyl1-13"
37382
+ })(["display:flex;align-items:center;justify-content:space-between;gap:1rem;font-family:'Press Start 2P',cursive;font-size:1rem;color:#ffffff;span:last-child{color:#fef08a;}"]);
37383
+ var ErrorMessage$1 = /*#__PURE__*/styled__default.div.withConfig({
37384
+ displayName: "CartView__ErrorMessage",
37385
+ componentId: "sc-ydtyl1-14"
37386
+ })(["color:#ef4444;font-size:0.875rem;font-family:'Press Start 2P',cursive;text-align:center;"]);
37387
+ var MetadataInfo = /*#__PURE__*/styled__default.div.withConfig({
37388
+ displayName: "CartView__MetadataInfo",
37389
+ componentId: "sc-ydtyl1-15"
37390
+ })(["display:flex;align-items:center;margin-top:0.5rem;gap:0.5rem;font-size:0.75rem;color:#a3e635;background:rgba(163,230,53,0.1);padding:0.25rem 0.5rem;border-radius:4px;"]);
37391
+ var MetadataLabel = /*#__PURE__*/styled__default.div.withConfig({
37392
+ displayName: "CartView__MetadataLabel",
37393
+ componentId: "sc-ydtyl1-16"
37394
+ })(["display:flex;align-items:center;gap:0.25rem;font-weight:bold;color:#d9f99d;"]);
37395
+ var MetadataValue = /*#__PURE__*/styled__default.div.withConfig({
37396
+ displayName: "CartView__MetadataValue",
37397
+ componentId: "sc-ydtyl1-17"
37398
+ })(["overflow:hidden;text-overflow:ellipsis;white-space:nowrap;"]);
37127
37399
 
37128
- var TimeWidget = function TimeWidget(_ref) {
37129
- var onClose = _ref.onClose,
37130
- TimeClock = _ref.TimeClock,
37131
- periodOfDay = _ref.periodOfDay,
37132
- scale = _ref.scale;
37133
- return React__default.createElement(Draggable, {
37134
- scale: scale,
37135
- cancel: ".time-widget-close,.time-widget-container,.time-widget-container *"
37136
- }, React__default.createElement(WidgetContainer, null, React__default.createElement(CloseButton$9, {
37137
- onPointerDown: onClose,
37400
+ var useStoreMetadata = function useStoreMetadata() {
37401
+ var _useState = React.useState(false),
37402
+ isCollectingMetadata = _useState[0],
37403
+ setIsCollectingMetadata = _useState[1];
37404
+ var collectMetadata = /*#__PURE__*/function () {
37405
+ var _ref = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(item) {
37406
+ return _regeneratorRuntime().wrap(function _callee$(_context) {
37407
+ while (1) switch (_context.prev = _context.next) {
37408
+ case 0:
37409
+ if (!(!item.metadataType || item.metadataType === shared.MetadataType.None)) {
37410
+ _context.next = 2;
37411
+ break;
37412
+ }
37413
+ return _context.abrupt("return", null);
37414
+ case 2:
37415
+ setIsCollectingMetadata(true);
37416
+ _context.prev = 3;
37417
+ _context.next = 6;
37418
+ return new Promise(function (_resolve) {
37419
+ // We'll store the resolver functions in a global context
37420
+ // that will be accessible to the MetadataCollector component
37421
+ window.__metadataResolvers = {
37422
+ resolve: function resolve(metadata) {
37423
+ _resolve(metadata);
37424
+ },
37425
+ item: item
37426
+ };
37427
+ });
37428
+ case 6:
37429
+ return _context.abrupt("return", _context.sent);
37430
+ case 7:
37431
+ _context.prev = 7;
37432
+ setIsCollectingMetadata(false);
37433
+ // Clean up the resolvers
37434
+ if (window.__metadataResolvers) {
37435
+ delete window.__metadataResolvers;
37436
+ }
37437
+ return _context.finish(7);
37438
+ case 11:
37439
+ case "end":
37440
+ return _context.stop();
37441
+ }
37442
+ }, _callee, null, [[3,, 7, 11]]);
37443
+ }));
37444
+ return function collectMetadata(_x) {
37445
+ return _ref.apply(this, arguments);
37446
+ };
37447
+ }();
37448
+ return {
37449
+ collectMetadata: collectMetadata,
37450
+ isCollectingMetadata: isCollectingMetadata
37451
+ };
37452
+ };
37453
+
37454
+ var useStoreCart = function useStoreCart() {
37455
+ var _useState = React.useState([]),
37456
+ cartItems = _useState[0],
37457
+ setCartItems = _useState[1];
37458
+ var _useState2 = React.useState(false),
37459
+ isCartOpen = _useState2[0],
37460
+ setIsCartOpen = _useState2[1];
37461
+ var isMounted = React.useRef(true);
37462
+ React.useEffect(function () {
37463
+ return function () {
37464
+ isMounted.current = false;
37465
+ };
37466
+ }, []);
37467
+ var _useStoreMetadata = useStoreMetadata(),
37468
+ collectMetadata = _useStoreMetadata.collectMetadata,
37469
+ isCollectingMetadata = _useStoreMetadata.isCollectingMetadata;
37470
+ var handleAddToCart = /*#__PURE__*/function () {
37471
+ var _ref = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(item, quantity, preselectedMetadata) {
37472
+ var metadata;
37473
+ return _regeneratorRuntime().wrap(function _callee$(_context) {
37474
+ while (1) switch (_context.prev = _context.next) {
37475
+ case 0:
37476
+ if (!preselectedMetadata) {
37477
+ _context.next = 3;
37478
+ break;
37479
+ }
37480
+ setCartItems(function (prevItems) {
37481
+ return [].concat(prevItems, [{
37482
+ item: item,
37483
+ quantity: quantity,
37484
+ metadata: preselectedMetadata
37485
+ }]);
37486
+ });
37487
+ return _context.abrupt("return");
37488
+ case 3:
37489
+ if (!(item.metadataType && item.metadataType !== shared.MetadataType.None)) {
37490
+ _context.next = 12;
37491
+ break;
37492
+ }
37493
+ _context.next = 6;
37494
+ return collectMetadata(item);
37495
+ case 6:
37496
+ metadata = _context.sent;
37497
+ if (metadata) {
37498
+ _context.next = 9;
37499
+ break;
37500
+ }
37501
+ return _context.abrupt("return");
37502
+ case 9:
37503
+ // User cancelled
37504
+ // Add item with metadata
37505
+ setCartItems(function (prevItems) {
37506
+ // Create new cart item with metadata
37507
+ return [].concat(prevItems, [{
37508
+ item: item,
37509
+ quantity: quantity,
37510
+ metadata: metadata
37511
+ }]);
37512
+ });
37513
+ _context.next = 13;
37514
+ break;
37515
+ case 12:
37516
+ // Existing add to cart logic for items without metadata
37517
+ setCartItems(function (prevItems) {
37518
+ var existingItem = prevItems.find(function (cartItem) {
37519
+ return cartItem.item.key === item.key;
37520
+ });
37521
+ if (existingItem) {
37522
+ return prevItems.map(function (cartItem) {
37523
+ return cartItem.item.key === item.key ? _extends({}, cartItem, {
37524
+ quantity: Math.min(cartItem.quantity + quantity, 99)
37525
+ }) : cartItem;
37526
+ });
37527
+ }
37528
+ return [].concat(prevItems, [{
37529
+ item: item,
37530
+ quantity: quantity
37531
+ }]);
37532
+ });
37533
+ case 13:
37534
+ case "end":
37535
+ return _context.stop();
37536
+ }
37537
+ }, _callee);
37538
+ }));
37539
+ return function handleAddToCart(_x, _x2, _x3) {
37540
+ return _ref.apply(this, arguments);
37541
+ };
37542
+ }();
37543
+ var handleRemoveFromCart = function handleRemoveFromCart(itemKey) {
37544
+ setCartItems(function (prevItems) {
37545
+ return prevItems.filter(function (cartItem) {
37546
+ return cartItem.item.key !== itemKey;
37547
+ });
37548
+ });
37549
+ };
37550
+ var handlePurchase = function handlePurchase(onPurchase) {
37551
+ var purchaseUnits = cartItems.map(function (cartItem) {
37552
+ return {
37553
+ purchaseKey: cartItem.item.key,
37554
+ qty: cartItem.quantity,
37555
+ type: getPurchaseType(cartItem.item),
37556
+ name: cartItem.item.name,
37557
+ metadata: cartItem.metadata || cartItem.item.metadataConfig
37558
+ };
37559
+ });
37560
+ var purchase = {
37561
+ _id: uuidv4(),
37562
+ userId: '1',
37563
+ status: 'pending',
37564
+ createdAt: new Date().toISOString(),
37565
+ updatedAt: new Date().toISOString(),
37566
+ purchases: purchaseUnits
37567
+ };
37568
+ onPurchase(purchase);
37569
+ if (isMounted.current) {
37570
+ setCartItems([]);
37571
+ setIsCartOpen(false);
37572
+ }
37573
+ };
37574
+ var openCart = function openCart() {
37575
+ return setIsCartOpen(true);
37576
+ };
37577
+ var closeCart = function closeCart() {
37578
+ return setIsCartOpen(false);
37579
+ };
37580
+ var getTotalItems = function getTotalItems() {
37581
+ return cartItems.reduce(function (sum, item) {
37582
+ return sum + item.quantity;
37583
+ }, 0);
37584
+ };
37585
+ var getTotalPrice = function getTotalPrice() {
37586
+ return Number(cartItems.reduce(function (sum, item) {
37587
+ return sum + item.item.price * item.quantity;
37588
+ }, 0).toFixed(2));
37589
+ };
37590
+ return {
37591
+ cartItems: cartItems,
37592
+ isCartOpen: isCartOpen,
37593
+ handleAddToCart: handleAddToCart,
37594
+ handleRemoveFromCart: handleRemoveFromCart,
37595
+ handlePurchase: handlePurchase,
37596
+ openCart: openCart,
37597
+ closeCart: closeCart,
37598
+ getTotalItems: getTotalItems,
37599
+ getTotalPrice: getTotalPrice,
37600
+ isCollectingMetadata: isCollectingMetadata
37601
+ };
37602
+ };
37603
+ // Helper functions
37604
+ function getPurchaseType(item) {
37605
+ // Check if the item comes from a pack based on naming convention or other property
37606
+ if (item.key.startsWith('pack_')) {
37607
+ return shared.PurchaseType.Pack;
37608
+ } else {
37609
+ return shared.PurchaseType.Item;
37610
+ }
37611
+ }
37612
+ function uuidv4() {
37613
+ return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {
37614
+ var r = Math.random() * 16 | 0,
37615
+ v = c === 'x' ? r : r & 0x3 | 0x8;
37616
+ return v.toString(16);
37617
+ });
37618
+ }
37619
+
37620
+ var MetadataCollector = function MetadataCollector(_ref) {
37621
+ var metadataType = _ref.metadataType,
37622
+ config = _ref.config,
37623
+ onCollect = _ref.onCollect,
37624
+ onCancel = _ref.onCancel;
37625
+ // Make sure we clean up if unmounted without collecting
37626
+ React.useEffect(function () {
37627
+ return function () {
37628
+ // If we're unmounting without explicitly collecting or canceling,
37629
+ // make sure to call onCancel to prevent any hanging promises
37630
+ if (window.__metadataResolvers) {
37631
+ onCancel();
37632
+ }
37633
+ };
37634
+ }, [onCancel]);
37635
+ // Use string comparison instead of direct property access
37636
+ if (metadataType === 'CharacterSkin') {
37637
+ return React__default.createElement(CharacterSkinSelectionModal, {
37638
+ isOpen: true,
37639
+ onClose: onCancel,
37640
+ onConfirm: function onConfirm(selectedSkin) {
37641
+ return onCollect({
37642
+ selectedSkin: selectedSkin
37643
+ });
37644
+ },
37645
+ availableCharacters: config.availableCharacters || [],
37646
+ atlasJSON: config.atlasJSON,
37647
+ atlasIMG: config.atlasIMG,
37648
+ initialSelectedSkin: config.initialSelectedSkin
37649
+ });
37650
+ } else {
37651
+ console.warn("No collector implemented for metadata type: " + metadataType);
37652
+ // Auto-cancel for unhandled types to prevent hanging promises
37653
+ setTimeout(onCancel, 0);
37654
+ return null;
37655
+ }
37656
+ };
37657
+
37658
+ var ScrollableContent = function ScrollableContent(_ref) {
37659
+ var items = _ref.items,
37660
+ renderItem = _ref.renderItem,
37661
+ _ref$emptyMessage = _ref.emptyMessage,
37662
+ emptyMessage = _ref$emptyMessage === void 0 ? 'No items found' : _ref$emptyMessage,
37663
+ className = _ref.className,
37664
+ filterOptions = _ref.filterOptions,
37665
+ searchOptions = _ref.searchOptions,
37666
+ _ref$layout = _ref.layout,
37667
+ layout = _ref$layout === void 0 ? 'list' : _ref$layout,
37668
+ _ref$gridColumns = _ref.gridColumns,
37669
+ gridColumns = _ref$gridColumns === void 0 ? 4 : _ref$gridColumns,
37670
+ _ref$maxHeight = _ref.maxHeight,
37671
+ maxHeight = _ref$maxHeight === void 0 ? '500px' : _ref$maxHeight;
37672
+ if (items.length === 0) {
37673
+ return React__default.createElement(EmptyMessage$1, null, emptyMessage);
37674
+ }
37675
+ return React__default.createElement(Container$L, {
37676
+ className: className
37677
+ }, (searchOptions || filterOptions) && React__default.createElement(HeaderContainer$3, null, React__default.createElement(HeaderContent$1, null, searchOptions && React__default.createElement(SearchContainer$3, null, React__default.createElement(StyledSearchBar$2, {
37678
+ value: searchOptions.value,
37679
+ onChange: searchOptions.onChange,
37680
+ placeholder: searchOptions.placeholder || 'Search...'
37681
+ })), filterOptions && React__default.createElement(FilterContainer$1, null, React__default.createElement(StyledDropdown$3, {
37682
+ options: filterOptions.options,
37683
+ onChange: filterOptions.onOptionChange,
37684
+ width: "200px"
37685
+ })))), React__default.createElement(Content$4, {
37686
+ className: "ScrollableContent-content " + layout,
37687
+ "$gridColumns": gridColumns,
37688
+ "$maxHeight": maxHeight
37689
+ }, items.map(function (item, index) {
37690
+ return React__default.createElement("div", {
37691
+ key: index,
37692
+ className: "ScrollableContent-item"
37693
+ }, renderItem(item));
37694
+ })));
37695
+ };
37696
+ var Container$L = /*#__PURE__*/styled__default.div.withConfig({
37697
+ displayName: "ScrollableContent__Container",
37698
+ componentId: "sc-xhh2um-0"
37699
+ })(["display:flex;flex-direction:column;gap:1rem;width:100%;"]);
37700
+ var HeaderContainer$3 = /*#__PURE__*/styled__default.div.withConfig({
37701
+ displayName: "ScrollableContent__HeaderContainer",
37702
+ componentId: "sc-xhh2um-1"
37703
+ })(["flex-shrink:0;"]);
37704
+ var HeaderContent$1 = /*#__PURE__*/styled__default.div.withConfig({
37705
+ displayName: "ScrollableContent__HeaderContent",
37706
+ componentId: "sc-xhh2um-2"
37707
+ })(["display:flex;justify-content:space-between;align-items:center;gap:1rem;background:rgba(0,0,0,0.2);padding:1rem;border-radius:4px;"]);
37708
+ var SearchContainer$3 = /*#__PURE__*/styled__default.div.withConfig({
37709
+ displayName: "ScrollableContent__SearchContainer",
37710
+ componentId: "sc-xhh2um-3"
37711
+ })(["flex:1;"]);
37712
+ var FilterContainer$1 = /*#__PURE__*/styled__default.div.withConfig({
37713
+ displayName: "ScrollableContent__FilterContainer",
37714
+ componentId: "sc-xhh2um-4"
37715
+ })(["display:flex;justify-content:flex-end;"]);
37716
+ var StyledSearchBar$2 = /*#__PURE__*/styled__default(SearchBar).withConfig({
37717
+ displayName: "ScrollableContent__StyledSearchBar",
37718
+ componentId: "sc-xhh2um-5"
37719
+ })(["width:100%;"]);
37720
+ var StyledDropdown$3 = /*#__PURE__*/styled__default(Dropdown).withConfig({
37721
+ displayName: "ScrollableContent__StyledDropdown",
37722
+ componentId: "sc-xhh2um-6"
37723
+ })(["min-width:150px;"]);
37724
+ var Content$4 = /*#__PURE__*/styled__default.div.withConfig({
37725
+ displayName: "ScrollableContent__Content",
37726
+ componentId: "sc-xhh2um-7"
37727
+ })(["display:flex;flex-direction:column;gap:0.5rem;flex:1;padding:1rem;max-height:", ";overflow-y:auto;overflow-x:hidden;&.grid{display:grid;grid-template-columns:repeat( ", ",minmax(0,1fr) );gap:1rem;align-items:start;.ScrollableContent-item{display:flex;align-items:flex-start;}}&.list{display:flex;flex-direction:column;gap:0.5rem;}"], function (props) {
37728
+ return props.$maxHeight;
37729
+ }, function (props) {
37730
+ return props.$gridColumns;
37731
+ });
37732
+ var EmptyMessage$1 = /*#__PURE__*/styled__default.div.withConfig({
37733
+ displayName: "ScrollableContent__EmptyMessage",
37734
+ componentId: "sc-xhh2um-8"
37735
+ })(["text-align:center;color:#9ca3af;padding:2rem;flex:1;display:flex;align-items:center;justify-content:center;"]);
37736
+
37737
+ var StoreCharacterSkinRow = function StoreCharacterSkinRow(_ref) {
37738
+ var _item$metadataConfig, _item$metadataConfig2, _item$metadataConfig3, _item$requiredAccount;
37739
+ var item = _ref.item,
37740
+ atlasJSON = _ref.atlasJSON,
37741
+ atlasIMG = _ref.atlasIMG,
37742
+ onAddToCart = _ref.onAddToCart,
37743
+ userAccountType = _ref.userAccountType;
37744
+ var _useState = React.useState(1),
37745
+ quantity = _useState[0],
37746
+ setQuantity = _useState[1];
37747
+ var _useState2 = React.useState(0),
37748
+ currentIndex = _useState2[0],
37749
+ setCurrentIndex = _useState2[1];
37750
+ // Get available characters from metadata
37751
+ var availableCharacters = item.metadataType === shared.MetadataType.CharacterSkin && ((_item$metadataConfig = item.metadataConfig) == null ? void 0 : _item$metadataConfig.availableCharacters) || [];
37752
+ // Get the active character entity atlas info
37753
+ var entityAtlasJSON = (_item$metadataConfig2 = item.metadataConfig) == null ? void 0 : _item$metadataConfig2.atlasJSON;
37754
+ var entityAtlasIMG = (_item$metadataConfig3 = item.metadataConfig) == null ? void 0 : _item$metadataConfig3.atlasIMG;
37755
+ // Effect to reset currentIndex when switching items
37756
+ React.useEffect(function () {
37757
+ setCurrentIndex(0);
37758
+ }, [item._id]);
37759
+ var handleQuantityChange = function handleQuantityChange(e) {
37760
+ var value = parseInt(e.target.value) || 1;
37761
+ setQuantity(Math.min(Math.max(1, value), 99));
37762
+ };
37763
+ var handleBlur = function handleBlur() {
37764
+ if (quantity < 1) setQuantity(1);
37765
+ if (quantity > 99) setQuantity(99);
37766
+ };
37767
+ var incrementQuantity = function incrementQuantity() {
37768
+ setQuantity(function (prev) {
37769
+ return Math.min(prev + 1, 99);
37770
+ });
37771
+ };
37772
+ var decrementQuantity = function decrementQuantity() {
37773
+ setQuantity(function (prev) {
37774
+ return Math.max(1, prev - 1);
37775
+ });
37776
+ };
37777
+ var handlePreviousSkin = function handlePreviousSkin() {
37778
+ setCurrentIndex(function (prevIndex) {
37779
+ return prevIndex === 0 ? availableCharacters.length - 1 : prevIndex - 1;
37780
+ });
37781
+ };
37782
+ var handleNextSkin = function handleNextSkin() {
37783
+ setCurrentIndex(function (prevIndex) {
37784
+ return prevIndex === availableCharacters.length - 1 ? 0 : prevIndex + 1;
37785
+ });
37786
+ };
37787
+ var hasRequiredAccount = !((_item$requiredAccount = item.requiredAccountType) != null && _item$requiredAccount.length) || item.requiredAccountType.includes(userAccountType);
37788
+ var handleAddToCart = function handleAddToCart() {
37789
+ if (!hasRequiredAccount) return;
37790
+ // If we have character skins, add the selected skin to the purchase
37791
+ if (availableCharacters.length > 0) {
37792
+ var selectedCharacter = availableCharacters[currentIndex];
37793
+ onAddToCart(item, quantity, {
37794
+ selectedSkin: selectedCharacter.textureKey
37795
+ });
37796
+ } else {
37797
+ onAddToCart(item, quantity);
37798
+ }
37799
+ setQuantity(1); // Reset quantity after adding to cart
37800
+ };
37801
+ var getSpriteKey = function getSpriteKey(textureKey) {
37802
+ return textureKey + '/down/standing/0.png';
37803
+ };
37804
+ var currentCharacter = availableCharacters[currentIndex];
37805
+ return React__default.createElement(ItemWrapper, null, React__default.createElement(ItemIconContainer$2, null, availableCharacters.length > 0 && currentCharacter && entityAtlasJSON && entityAtlasIMG ? React__default.createElement(CharacterSkinPreviewContainer, null, React__default.createElement(NavArrow, {
37806
+ direction: "left",
37807
+ onPointerDown: handlePreviousSkin,
37808
+ size: 24
37809
+ }), React__default.createElement(SpriteContainer$5, null, React__default.createElement(ErrorBoundary, null, React__default.createElement(SpriteFromAtlas, {
37810
+ atlasJSON: entityAtlasJSON,
37811
+ atlasIMG: entityAtlasIMG,
37812
+ spriteKey: getSpriteKey(currentCharacter.textureKey),
37813
+ width: 32,
37814
+ height: 32,
37815
+ imgScale: 2,
37816
+ centered: true
37817
+ }))), React__default.createElement(NavArrow, {
37818
+ direction: "right",
37819
+ onPointerDown: handleNextSkin,
37820
+ size: 24
37821
+ })) : React__default.createElement(SpriteFromAtlas, {
37822
+ atlasJSON: atlasJSON,
37823
+ atlasIMG: atlasIMG,
37824
+ spriteKey: item.texturePath,
37825
+ width: 32,
37826
+ height: 32,
37827
+ imgScale: 2,
37828
+ centered: true
37829
+ })), React__default.createElement(ItemDetails$1, null, React__default.createElement(ItemName$1, null, item.name), availableCharacters.length > 0 && currentCharacter && React__default.createElement(SelectedSkin, null, "Selected: ", currentCharacter.name), React__default.createElement(ItemPrice, null, "$", item.price)), React__default.createElement(Controls, null, React__default.createElement(ArrowsContainer, null, React__default.createElement(SelectArrow, {
37830
+ direction: "left",
37831
+ onPointerDown: decrementQuantity,
37832
+ size: 24
37833
+ }), React__default.createElement(QuantityInput, {
37834
+ type: "number",
37835
+ value: quantity,
37836
+ onChange: handleQuantityChange,
37837
+ onBlur: handleBlur,
37838
+ min: 1,
37839
+ max: 99,
37840
+ className: "rpgui-input"
37841
+ }), React__default.createElement(SelectArrow, {
37842
+ direction: "right",
37843
+ onPointerDown: incrementQuantity,
37844
+ size: 24
37845
+ })), React__default.createElement(CTAButton, {
37846
+ icon: React__default.createElement(fa.FaCartPlus, null),
37847
+ label: "Add",
37848
+ onClick: handleAddToCart,
37849
+ disabled: !hasRequiredAccount
37850
+ })));
37851
+ };
37852
+ var ItemWrapper = /*#__PURE__*/styled__default.div.withConfig({
37853
+ displayName: "StoreCharacterSkinRow__ItemWrapper",
37854
+ componentId: "sc-81xqsx-0"
37855
+ })(["display:flex;align-items:center;gap:1rem;padding:1rem;border-bottom:1px solid rgba(255,255,255,0.1);&:last-child{border-bottom:none;}"]);
37856
+ var ItemIconContainer$2 = /*#__PURE__*/styled__default.div.withConfig({
37857
+ displayName: "StoreCharacterSkinRow__ItemIconContainer",
37858
+ componentId: "sc-81xqsx-1"
37859
+ })(["min-width:140px;display:flex;align-items:center;justify-content:center;border-radius:4px;padding:4px;"]);
37860
+ var CharacterSkinPreviewContainer = /*#__PURE__*/styled__default.div.withConfig({
37861
+ displayName: "StoreCharacterSkinRow__CharacterSkinPreviewContainer",
37862
+ componentId: "sc-81xqsx-2"
37863
+ })(["position:relative;display:flex;align-items:center;width:140px;height:42px;justify-content:space-between;"]);
37864
+ var SpriteContainer$5 = /*#__PURE__*/styled__default.div.withConfig({
37865
+ displayName: "StoreCharacterSkinRow__SpriteContainer",
37866
+ componentId: "sc-81xqsx-3"
37867
+ })(["display:flex;align-items:center;justify-content:center;position:absolute;left:50%;transform:translateX(-50%);"]);
37868
+ var NavArrow = /*#__PURE__*/styled__default(SelectArrow).withConfig({
37869
+ displayName: "StoreCharacterSkinRow__NavArrow",
37870
+ componentId: "sc-81xqsx-4"
37871
+ })(["z-index:2;"]);
37872
+ var ItemDetails$1 = /*#__PURE__*/styled__default.div.withConfig({
37873
+ displayName: "StoreCharacterSkinRow__ItemDetails",
37874
+ componentId: "sc-81xqsx-5"
37875
+ })(["flex:1;display:flex;flex-direction:column;gap:0.5rem;"]);
37876
+ var ItemName$1 = /*#__PURE__*/styled__default.div.withConfig({
37877
+ displayName: "StoreCharacterSkinRow__ItemName",
37878
+ componentId: "sc-81xqsx-6"
37879
+ })(["font-family:'Press Start 2P',cursive;font-size:0.875rem;color:#ffffff;"]);
37880
+ var SelectedSkin = /*#__PURE__*/styled__default.div.withConfig({
37881
+ displayName: "StoreCharacterSkinRow__SelectedSkin",
37882
+ componentId: "sc-81xqsx-7"
37883
+ })(["font-family:'Press Start 2P',cursive;font-size:0.65rem;color:#fef08a;"]);
37884
+ var ItemPrice = /*#__PURE__*/styled__default.div.withConfig({
37885
+ displayName: "StoreCharacterSkinRow__ItemPrice",
37886
+ componentId: "sc-81xqsx-8"
37887
+ })(["font-family:'Press Start 2P',cursive;font-size:0.75rem;color:#fef08a;"]);
37888
+ var Controls = /*#__PURE__*/styled__default.div.withConfig({
37889
+ displayName: "StoreCharacterSkinRow__Controls",
37890
+ componentId: "sc-81xqsx-9"
37891
+ })(["display:flex;align-items:center;gap:1rem;min-width:fit-content;"]);
37892
+ var ArrowsContainer = /*#__PURE__*/styled__default.div.withConfig({
37893
+ displayName: "StoreCharacterSkinRow__ArrowsContainer",
37894
+ componentId: "sc-81xqsx-10"
37895
+ })(["position:relative;display:flex;align-items:center;width:120px;height:42px;justify-content:space-between;"]);
37896
+ var QuantityInput = /*#__PURE__*/styled__default.input.withConfig({
37897
+ displayName: "StoreCharacterSkinRow__QuantityInput",
37898
+ componentId: "sc-81xqsx-11"
37899
+ })(["width:40px;text-align:center;margin:0 auto;font-size:0.875rem;background:rgba(0,0,0,0.2);color:#ffffff;border:none;padding:0.25rem;&::-webkit-inner-spin-button,&::-webkit-outer-spin-button{-webkit-appearance:none;margin:0;}"]);
37900
+
37901
+ var StoreItemRow = function StoreItemRow(_ref) {
37902
+ var _item$requiredAccount;
37903
+ var item = _ref.item,
37904
+ atlasJSON = _ref.atlasJSON,
37905
+ atlasIMG = _ref.atlasIMG,
37906
+ onAddToCart = _ref.onAddToCart,
37907
+ userAccountType = _ref.userAccountType;
37908
+ var _useState = React.useState(1),
37909
+ quantity = _useState[0],
37910
+ setQuantity = _useState[1];
37911
+ var handleQuantityChange = function handleQuantityChange(e) {
37912
+ var value = parseInt(e.target.value) || 1;
37913
+ setQuantity(Math.min(Math.max(1, value), 99));
37914
+ };
37915
+ var handleBlur = function handleBlur() {
37916
+ if (quantity < 1) setQuantity(1);
37917
+ if (quantity > 99) setQuantity(99);
37918
+ };
37919
+ var incrementQuantity = function incrementQuantity() {
37920
+ setQuantity(function (prev) {
37921
+ return Math.min(prev + 1, 99);
37922
+ });
37923
+ };
37924
+ var decrementQuantity = function decrementQuantity() {
37925
+ setQuantity(function (prev) {
37926
+ return Math.max(1, prev - 1);
37927
+ });
37928
+ };
37929
+ var hasRequiredAccount = !((_item$requiredAccount = item.requiredAccountType) != null && _item$requiredAccount.length) || item.requiredAccountType.includes(userAccountType);
37930
+ var handleAddToCart = function handleAddToCart() {
37931
+ if (!hasRequiredAccount) return;
37932
+ onAddToCart(item, quantity);
37933
+ setQuantity(1); // Reset quantity after adding to cart
37934
+ };
37935
+ return React__default.createElement(ItemWrapper$1, null, React__default.createElement(ItemIconContainer$3, null, React__default.createElement(SpriteFromAtlas, {
37936
+ atlasJSON: atlasJSON,
37937
+ atlasIMG: atlasIMG,
37938
+ spriteKey: item.texturePath,
37939
+ width: 32,
37940
+ height: 32,
37941
+ imgScale: 2,
37942
+ centered: true
37943
+ })), 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(Controls$1, null, React__default.createElement(ArrowsContainer$1, null, React__default.createElement(SelectArrow, {
37944
+ direction: "left",
37945
+ onPointerDown: decrementQuantity,
37946
+ size: 24
37947
+ }), React__default.createElement(QuantityInput$1, {
37948
+ type: "number",
37949
+ value: quantity,
37950
+ onChange: handleQuantityChange,
37951
+ onBlur: handleBlur,
37952
+ min: 1,
37953
+ max: 99,
37954
+ className: "rpgui-input"
37955
+ }), React__default.createElement(SelectArrow, {
37956
+ direction: "right",
37957
+ onPointerDown: incrementQuantity,
37958
+ size: 24
37959
+ })), React__default.createElement(CTAButton, {
37960
+ icon: React__default.createElement(fa.FaCartPlus, null),
37961
+ label: "Add",
37962
+ onClick: handleAddToCart,
37963
+ disabled: !hasRequiredAccount
37964
+ })));
37965
+ };
37966
+ var ItemWrapper$1 = /*#__PURE__*/styled__default.div.withConfig({
37967
+ displayName: "StoreItemRow__ItemWrapper",
37968
+ componentId: "sc-ptotuo-0"
37969
+ })(["display:flex;align-items:center;gap:1rem;padding:1rem;border-bottom:1px solid rgba(255,255,255,0.1);&:last-child{border-bottom:none;}"]);
37970
+ var ItemIconContainer$3 = /*#__PURE__*/styled__default.div.withConfig({
37971
+ displayName: "StoreItemRow__ItemIconContainer",
37972
+ componentId: "sc-ptotuo-1"
37973
+ })(["width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;padding:4px;"]);
37974
+ var ItemDetails$2 = /*#__PURE__*/styled__default.div.withConfig({
37975
+ displayName: "StoreItemRow__ItemDetails",
37976
+ componentId: "sc-ptotuo-2"
37977
+ })(["flex:1;display:flex;flex-direction:column;gap:0.5rem;"]);
37978
+ var ItemName$2 = /*#__PURE__*/styled__default.div.withConfig({
37979
+ displayName: "StoreItemRow__ItemName",
37980
+ componentId: "sc-ptotuo-3"
37981
+ })(["font-family:'Press Start 2P',cursive;font-size:0.875rem;color:#ffffff;"]);
37982
+ var ItemPrice$1 = /*#__PURE__*/styled__default.div.withConfig({
37983
+ displayName: "StoreItemRow__ItemPrice",
37984
+ componentId: "sc-ptotuo-4"
37985
+ })(["font-family:'Press Start 2P',cursive;font-size:0.75rem;color:#fef08a;"]);
37986
+ var Controls$1 = /*#__PURE__*/styled__default.div.withConfig({
37987
+ displayName: "StoreItemRow__Controls",
37988
+ componentId: "sc-ptotuo-5"
37989
+ })(["display:flex;align-items:center;gap:1rem;min-width:fit-content;"]);
37990
+ var ArrowsContainer$1 = /*#__PURE__*/styled__default.div.withConfig({
37991
+ displayName: "StoreItemRow__ArrowsContainer",
37992
+ componentId: "sc-ptotuo-6"
37993
+ })(["position:relative;display:flex;align-items:center;width:120px;height:42px;justify-content:space-between;"]);
37994
+ var QuantityInput$1 = /*#__PURE__*/styled__default.input.withConfig({
37995
+ displayName: "StoreItemRow__QuantityInput",
37996
+ componentId: "sc-ptotuo-7"
37997
+ })(["width:40px;text-align:center;margin:0 auto;font-size:0.875rem;background:rgba(0,0,0,0.2);color:#ffffff;border:none;padding:0.25rem;&::-webkit-inner-spin-button,&::-webkit-outer-spin-button{-webkit-appearance:none;margin:0;}"]);
37998
+
37999
+ var StoreItemsSection = function StoreItemsSection(_ref) {
38000
+ var items = _ref.items,
38001
+ onAddToCart = _ref.onAddToCart,
38002
+ atlasJSON = _ref.atlasJSON,
38003
+ atlasIMG = _ref.atlasIMG,
38004
+ userAccountType = _ref.userAccountType;
38005
+ var _useState = React.useState(''),
38006
+ searchQuery = _useState[0],
38007
+ setSearchQuery = _useState[1];
38008
+ var filteredItems = items.filter(function (item) {
38009
+ return item.name.toLowerCase().includes(searchQuery.toLowerCase());
38010
+ });
38011
+ var renderStoreItem = function renderStoreItem(item) {
38012
+ // Use the specialized character skin row for items with character skin metadata
38013
+ if (item.metadataType === shared.MetadataType.CharacterSkin) {
38014
+ return React__default.createElement(StoreCharacterSkinRow, {
38015
+ key: item._id,
38016
+ item: item,
38017
+ atlasJSON: atlasJSON,
38018
+ atlasIMG: atlasIMG,
38019
+ onAddToCart: onAddToCart,
38020
+ userAccountType: userAccountType || shared.UserAccountTypes.Free
38021
+ });
38022
+ }
38023
+ // Use the standard item row for all other items
38024
+ return React__default.createElement(StoreItemRow, {
38025
+ key: item._id,
38026
+ item: item,
38027
+ atlasJSON: atlasJSON,
38028
+ atlasIMG: atlasIMG,
38029
+ onAddToCart: onAddToCart,
38030
+ userAccountType: userAccountType || shared.UserAccountTypes.Free
38031
+ });
38032
+ };
38033
+ return React__default.createElement(ScrollableContent, {
38034
+ items: filteredItems,
38035
+ renderItem: renderStoreItem,
38036
+ emptyMessage: "No items available.",
38037
+ searchOptions: {
38038
+ value: searchQuery,
38039
+ onChange: setSearchQuery,
38040
+ placeholder: 'Search items...'
38041
+ },
38042
+ layout: "list",
38043
+ maxHeight: "400px"
38044
+ });
38045
+ };
38046
+
38047
+ var ShoppingCardHorizontal = function ShoppingCardHorizontal(_ref) {
38048
+ var title = _ref.title,
38049
+ description = _ref.description,
38050
+ imageUrl = _ref.imageUrl,
38051
+ onClick = _ref.onClick,
38052
+ footer = _ref.footer,
38053
+ className = _ref.className;
38054
+ var getImageSrc = function getImageSrc() {
38055
+ if (!imageUrl) return '/placeholder-thumbnail.png';
38056
+ if (typeof imageUrl === 'string') return imageUrl;
38057
+ return imageUrl["default"] || imageUrl.src;
38058
+ };
38059
+ return React__default.createElement(CardContainer, {
38060
+ onClick: onClick,
38061
+ className: className
38062
+ }, React__default.createElement(LeftSection, null, imageUrl && React__default.createElement(CardThumbnail, null, React__default.createElement("img", {
38063
+ src: getImageSrc(),
38064
+ alt: title
38065
+ }))), React__default.createElement(RightSection, null, React__default.createElement(CardTitle, null, React__default.createElement(Ellipsis, {
38066
+ maxLines: 1,
38067
+ maxWidth: "100%"
38068
+ }, title)), React__default.createElement(CardDescription, null, React__default.createElement(Ellipsis, {
38069
+ maxLines: 3,
38070
+ maxWidth: "100%"
38071
+ }, description)), footer && React__default.createElement(CardFooter, {
38072
+ onClick: function onClick(e) {
38073
+ return e.stopPropagation();
38074
+ }
38075
+ }, footer)));
38076
+ };
38077
+ var CardContainer = /*#__PURE__*/styled__default.div.withConfig({
38078
+ displayName: "CartCardHorizontal__CardContainer",
38079
+ componentId: "sc-ngkh06-0"
38080
+ })(["display:flex;background:rgba(0,0,0,0.3);border-radius:4px;border:1px solid ", ";cursor:", ";transition:transform 0.2s ease;&:hover{transform:", ";}max-width:380px;"], uiColors.darkGray, function (props) {
38081
+ return props.onClick ? 'pointer' : 'default';
38082
+ }, function (props) {
38083
+ return props.onClick ? 'translateY(-2px)' : 'none';
38084
+ });
38085
+ var LeftSection = /*#__PURE__*/styled__default.div.withConfig({
38086
+ displayName: "CartCardHorizontal__LeftSection",
38087
+ componentId: "sc-ngkh06-1"
38088
+ })(["width:120px;flex-shrink:0;"]);
38089
+ var RightSection = /*#__PURE__*/styled__default.div.withConfig({
38090
+ displayName: "CartCardHorizontal__RightSection",
38091
+ componentId: "sc-ngkh06-2"
38092
+ })(["flex:1;display:flex;flex-direction:column;padding:12px;min-width:0;max-width:100%;"]);
38093
+ var CardThumbnail = /*#__PURE__*/styled__default.div.withConfig({
38094
+ displayName: "CartCardHorizontal__CardThumbnail",
38095
+ componentId: "sc-ngkh06-3"
38096
+ })(["width:100%;height:100%;background:rgba(0,0,0,0.2);overflow:hidden;img{width:100%;height:100%;object-fit:cover;}"]);
38097
+ var CardTitle = /*#__PURE__*/styled__default.h3.withConfig({
38098
+ displayName: "CartCardHorizontal__CardTitle",
38099
+ componentId: "sc-ngkh06-4"
38100
+ })(["margin:0;font-size:0.6rem;color:", ";font-family:'Press Start 2P',cursive;margin-bottom:8px;"], uiColors.yellow);
38101
+ var CardDescription = /*#__PURE__*/styled__default.p.withConfig({
38102
+ displayName: "CartCardHorizontal__CardDescription",
38103
+ componentId: "sc-ngkh06-5"
38104
+ })(["margin:0;font-size:0.55rem;color:", ";font-family:'Press Start 2P',cursive;line-height:1.4;margin-bottom:8px;"], uiColors.lightGray);
38105
+ var CardFooter = /*#__PURE__*/styled__default.div.withConfig({
38106
+ displayName: "CartCardHorizontal__CardFooter",
38107
+ componentId: "sc-ngkh06-6"
38108
+ })(["margin-top:auto;padding-top:8px;border-top:1px solid rgba(255,255,255,0.1);"]);
38109
+
38110
+ var StorePacksSection = function StorePacksSection(_ref) {
38111
+ var packs = _ref.packs,
38112
+ onAddToCart = _ref.onAddToCart,
38113
+ onSelectPack = _ref.onSelectPack;
38114
+ var _useState = React.useState(''),
38115
+ searchQuery = _useState[0],
38116
+ setSearchQuery = _useState[1];
38117
+ var renderPackFooter = React.useCallback(function (pack) {
38118
+ return React__default.createElement(FooterContainer, null, React__default.createElement(Price, null, "$", pack.priceUSD), React__default.createElement(CTAButton, {
38119
+ icon: React__default.createElement(fa.FaCartPlus, null),
38120
+ label: "Add",
38121
+ onClick: function onClick(e) {
38122
+ e.stopPropagation();
38123
+ onAddToCart(pack);
38124
+ }
38125
+ }));
38126
+ }, [onAddToCart]);
38127
+ var renderPack = React.useCallback(function (pack) {
38128
+ return React__default.createElement(ShoppingCardHorizontal, {
38129
+ key: pack.key,
38130
+ title: pack.title,
38131
+ description: pack.description,
38132
+ imageUrl: pack.image,
38133
+ footer: renderPackFooter(pack),
38134
+ onClick: function onClick() {
38135
+ return onSelectPack == null ? void 0 : onSelectPack(pack);
38136
+ }
38137
+ });
38138
+ }, [onSelectPack, renderPackFooter]);
38139
+ var filteredPacks = React.useMemo(function () {
38140
+ return packs.filter(function (pack) {
38141
+ return pack.title.toLowerCase().includes(searchQuery.toLowerCase());
38142
+ });
38143
+ }, [packs, searchQuery]);
38144
+ return React__default.createElement(ScrollableContent, {
38145
+ items: filteredPacks,
38146
+ renderItem: renderPack,
38147
+ emptyMessage: "No packs available.",
38148
+ searchOptions: {
38149
+ value: searchQuery,
38150
+ onChange: setSearchQuery,
38151
+ placeholder: 'Search packs...'
38152
+ },
38153
+ layout: "grid",
38154
+ gridColumns: 2,
38155
+ maxHeight: "420px"
38156
+ });
38157
+ };
38158
+ var FooterContainer = /*#__PURE__*/styled__default.div.withConfig({
38159
+ displayName: "StorePacksSection__FooterContainer",
38160
+ componentId: "sc-ulazq3-0"
38161
+ })(["display:flex;align-items:center;justify-content:space-between;gap:8px;"]);
38162
+ var Price = /*#__PURE__*/styled__default.span.withConfig({
38163
+ displayName: "StorePacksSection__Price",
38164
+ componentId: "sc-ulazq3-1"
38165
+ })(["font-family:'Press Start 2P',cursive;font-size:0.6rem;color:#fef08a;"]);
38166
+
38167
+ var StoreItemDetails = function StoreItemDetails(_ref) {
38168
+ var item = _ref.item,
38169
+ onBack = _ref.onBack,
38170
+ onAddToCart = _ref.onAddToCart,
38171
+ imageUrl = _ref.imageUrl;
38172
+ var getImageSrc = function getImageSrc() {
38173
+ if (!imageUrl) return '/placeholder-thumbnail.png';
38174
+ if (typeof imageUrl === 'string') return imageUrl;
38175
+ return imageUrl["default"] || imageUrl.src;
38176
+ };
38177
+ return React__default.createElement(Container$M, null, React__default.createElement(Header$8, null, React__default.createElement(BackButton, {
38178
+ onClick: onBack
38179
+ }, 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", {
38180
+ src: getImageSrc(),
38181
+ alt: item.name
38182
+ })), 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, {
38183
+ icon: React__default.createElement(fa.FaCartPlus, null),
38184
+ label: "Add to Cart",
38185
+ onClick: function onClick() {
38186
+ return onAddToCart(item);
38187
+ },
38188
+ fullWidth: true
38189
+ }))));
38190
+ };
38191
+ var Container$M = /*#__PURE__*/styled__default.div.withConfig({
38192
+ displayName: "StoreItemDetails__Container",
38193
+ componentId: "sc-k3ho5z-0"
38194
+ })(["display:flex;flex-direction:column;gap:1.5rem;padding:1.5rem;height:100%;"]);
38195
+ var Header$8 = /*#__PURE__*/styled__default.div.withConfig({
38196
+ displayName: "StoreItemDetails__Header",
38197
+ componentId: "sc-k3ho5z-1"
38198
+ })(["display:flex;align-items:center;gap:1rem;"]);
38199
+ var BackButton = /*#__PURE__*/styled__default.button.withConfig({
38200
+ displayName: "StoreItemDetails__BackButton",
38201
+ componentId: "sc-k3ho5z-2"
38202
+ })(["display:flex;align-items:center;gap:0.5rem;background:none;border:none;color:#ffffff;font-family:'Press Start 2P',cursive;font-size:0.875rem;cursor:pointer;padding:0.5rem;transition:opacity 0.2s;&:hover{opacity:0.8;}"]);
38203
+ var Content$5 = /*#__PURE__*/styled__default.div.withConfig({
38204
+ displayName: "StoreItemDetails__Content",
38205
+ componentId: "sc-k3ho5z-3"
38206
+ })(["flex:1;display:flex;flex-direction:column;gap:2rem;overflow-y:auto;"]);
38207
+ var DetailsGrid = /*#__PURE__*/styled__default.div.withConfig({
38208
+ displayName: "StoreItemDetails__DetailsGrid",
38209
+ componentId: "sc-k3ho5z-4"
38210
+ })(["display:grid;grid-template-columns:280px 1fr;gap:2rem;align-items:start;@media (max-width:768px){grid-template-columns:1fr;}"]);
38211
+ var ItemIcon = /*#__PURE__*/styled__default.div.withConfig({
38212
+ displayName: "StoreItemDetails__ItemIcon",
38213
+ componentId: "sc-k3ho5z-5"
38214
+ })(["width:100%;aspect-ratio:1;background:rgba(0,0,0,0.2);overflow:hidden;border-radius:4px;img{width:100%;height:100%;object-fit:cover;}"]);
38215
+ var ItemInfo$2 = /*#__PURE__*/styled__default.div.withConfig({
38216
+ displayName: "StoreItemDetails__ItemInfo",
38217
+ componentId: "sc-k3ho5z-6"
38218
+ })(["display:flex;flex-direction:column;gap:1rem;"]);
38219
+ var ItemName$3 = /*#__PURE__*/styled__default.h2.withConfig({
38220
+ displayName: "StoreItemDetails__ItemName",
38221
+ componentId: "sc-k3ho5z-7"
38222
+ })(["margin:0;font-family:'Press Start 2P',cursive;font-size:1.25rem;color:#fef08a;"]);
38223
+ var ItemPrice$2 = /*#__PURE__*/styled__default.div.withConfig({
38224
+ displayName: "StoreItemDetails__ItemPrice",
38225
+ componentId: "sc-k3ho5z-8"
38226
+ })(["font-family:'Press Start 2P',cursive;font-size:1rem;color:#fef08a;"]);
38227
+ var Description$6 = /*#__PURE__*/styled__default.p.withConfig({
38228
+ displayName: "StoreItemDetails__Description",
38229
+ componentId: "sc-k3ho5z-9"
38230
+ })(["margin:0;font-family:'Press Start 2P',cursive;font-size:0.875rem;line-height:1.6;color:#ffffff;"]);
38231
+ var Actions = /*#__PURE__*/styled__default.div.withConfig({
38232
+ displayName: "StoreItemDetails__Actions",
38233
+ componentId: "sc-k3ho5z-10"
38234
+ })(["margin-top:auto;padding-top:1rem;border-top:1px solid rgba(255,255,255,0.1);"]);
38235
+
38236
+ var Store = function Store(_ref) {
38237
+ var items = _ref.items,
38238
+ _ref$packs = _ref.packs,
38239
+ packs = _ref$packs === void 0 ? [] : _ref$packs,
38240
+ atlasJSON = _ref.atlasJSON,
38241
+ atlasIMG = _ref.atlasIMG,
38242
+ _onPurchase = _ref.onPurchase,
38243
+ userAccountType = _ref.userAccountType,
38244
+ _ref$loading = _ref.loading,
38245
+ loading = _ref$loading === void 0 ? false : _ref$loading,
38246
+ error = _ref.error,
38247
+ onClose = _ref.onClose;
38248
+ var _useState = React.useState(null),
38249
+ selectedPack = _useState[0],
38250
+ setSelectedPack = _useState[1];
38251
+ var _useState2 = React.useState('premium'),
38252
+ activeTab = _useState2[0],
38253
+ setActiveTab = _useState2[1];
38254
+ var _useStoreCart = useStoreCart(),
38255
+ cartItems = _useStoreCart.cartItems,
38256
+ handleAddToCart = _useStoreCart.handleAddToCart,
38257
+ handleRemoveFromCart = _useStoreCart.handleRemoveFromCart,
38258
+ handleCartPurchase = _useStoreCart.handlePurchase,
38259
+ openCart = _useStoreCart.openCart,
38260
+ closeCart = _useStoreCart.closeCart,
38261
+ getTotalItems = _useStoreCart.getTotalItems,
38262
+ getTotalPrice = _useStoreCart.getTotalPrice,
38263
+ isCartOpen = _useStoreCart.isCartOpen;
38264
+ var _useState3 = React.useState(false),
38265
+ isCollectingMetadata = _useState3[0],
38266
+ setIsCollectingMetadata = _useState3[1];
38267
+ var _useState4 = React.useState(null),
38268
+ currentMetadataItem = _useState4[0],
38269
+ setCurrentMetadataItem = _useState4[1];
38270
+ var handleAddPackToCart = function handleAddPackToCart(pack) {
38271
+ var packItem = {
38272
+ _id: pack.key,
38273
+ key: pack.key,
38274
+ name: pack.title,
38275
+ price: pack.priceUSD,
38276
+ texturePath: pack.image["default"] || pack.image.src,
38277
+ textureKey: pack.image["default"] || pack.image.src,
38278
+ type: shared.ItemType.Consumable,
38279
+ subType: shared.ItemSubType.Other,
38280
+ description: pack.description || '',
38281
+ fullDescription: pack.description || '',
38282
+ textureAtlas: 'items',
38283
+ weight: 0,
38284
+ rarity: shared.ItemRarities.Common,
38285
+ allowedEquipSlotType: [],
38286
+ isEquipable: false,
38287
+ isStackable: false,
38288
+ isTwoHanded: false,
38289
+ hasUseWith: false,
38290
+ maxStackSize: 1,
38291
+ isUsable: false,
38292
+ isStorable: true,
38293
+ isSolid: false,
38294
+ isItemContainer: false
38295
+ };
38296
+ handleAddToCart(packItem, 1);
38297
+ };
38298
+ var filterItems = function filterItems(itemsToFilter, type) {
38299
+ return itemsToFilter.filter(function (item) {
38300
+ if (type === 'premium') {
38301
+ var _item$requiredAccount, _item$requiredAccount2;
38302
+ return (_item$requiredAccount = (_item$requiredAccount2 = item.requiredAccountType) == null ? void 0 : _item$requiredAccount2.length) != null ? _item$requiredAccount : 0 > 0;
38303
+ }
38304
+ return true;
38305
+ });
38306
+ };
38307
+ var filteredItems = React.useMemo(function () {
38308
+ return {
38309
+ items: filterItems(items, 'items'),
38310
+ premium: filterItems(items, 'premium')
38311
+ };
38312
+ }, [items]);
38313
+ var handleMetadataCollected = function handleMetadataCollected(metadata) {
38314
+ if (currentMetadataItem && window.__metadataResolvers) {
38315
+ // Resolve the promise in the useStoreMetadata hook
38316
+ window.__metadataResolvers.resolve(metadata);
38317
+ // Reset the metadata collection state
38318
+ setCurrentMetadataItem(null);
38319
+ // Removed unused setPendingMetadataQuantity call
38320
+ }
38321
+ };
38322
+ var handleMetadataCancel = function handleMetadataCancel() {
38323
+ if (window.__metadataResolvers) {
38324
+ // Resolve with null to indicate cancellation
38325
+ window.__metadataResolvers.resolve(null);
38326
+ }
38327
+ // Reset the metadata collection state
38328
+ setCurrentMetadataItem(null);
38329
+ // Removed unused setPendingMetadataQuantity call
38330
+ setIsCollectingMetadata(false);
38331
+ };
38332
+ if (loading) {
38333
+ return React__default.createElement(LoadingMessage$1, null, "Loading...");
38334
+ }
38335
+ if (error) {
38336
+ return React__default.createElement(ErrorMessage$2, null, error);
38337
+ }
38338
+ var tabs = [{
38339
+ id: 'premium',
38340
+ title: 'Premium',
38341
+ content: React__default.createElement(StorePacksSection, {
38342
+ packs: packs.filter(function (pack) {
38343
+ return pack.priceUSD >= 9.99;
38344
+ }),
38345
+ onAddToCart: handleAddPackToCart,
38346
+ onSelectPack: setSelectedPack
38347
+ })
38348
+ }, {
38349
+ id: 'packs',
38350
+ title: 'Packs',
38351
+ content: React__default.createElement(StorePacksSection, {
38352
+ packs: packs.filter(function (pack) {
38353
+ return pack.priceUSD < 9.99;
38354
+ }),
38355
+ onAddToCart: handleAddPackToCart,
38356
+ onSelectPack: setSelectedPack
38357
+ })
38358
+ }, {
38359
+ id: 'items',
38360
+ title: 'Items',
38361
+ content: React__default.createElement(StoreItemsSection, {
38362
+ items: filteredItems.items,
38363
+ onAddToCart: handleAddToCart,
38364
+ atlasJSON: atlasJSON,
38365
+ atlasIMG: atlasIMG,
38366
+ userAccountType: userAccountType
38367
+ })
38368
+ }];
38369
+ return React__default.createElement(DraggableContainer, {
38370
+ title: "Store",
38371
+ onCloseButton: onClose,
38372
+ width: "850px",
38373
+ minWidth: "600px",
38374
+ height: "auto",
38375
+ type: exports.RPGUIContainerTypes.Framed,
38376
+ cancelDrag: "[class*='Store__Container'], [class*='CartView'], [class*='StoreItemDetails'], .close-button"
38377
+ }, isCollectingMetadata && currentMetadataItem && currentMetadataItem.metadataType ? React__default.createElement(MetadataCollector, {
38378
+ metadataType: currentMetadataItem.metadataType,
38379
+ config: currentMetadataItem.metadataConfig || {},
38380
+ onCollect: handleMetadataCollected,
38381
+ onCancel: handleMetadataCancel
38382
+ }) : isCartOpen ? React__default.createElement(CartView, {
38383
+ cartItems: cartItems,
38384
+ onRemoveFromCart: handleRemoveFromCart,
38385
+ onClose: closeCart,
38386
+ onPurchase: function () {
38387
+ var _onPurchase2 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
38388
+ return _regeneratorRuntime().wrap(function _callee$(_context) {
38389
+ while (1) switch (_context.prev = _context.next) {
38390
+ case 0:
38391
+ _context.next = 2;
38392
+ return handleCartPurchase(_onPurchase);
38393
+ case 2:
38394
+ return _context.abrupt("return", true);
38395
+ case 3:
38396
+ case "end":
38397
+ return _context.stop();
38398
+ }
38399
+ }, _callee);
38400
+ }));
38401
+ function onPurchase() {
38402
+ return _onPurchase2.apply(this, arguments);
38403
+ }
38404
+ return onPurchase;
38405
+ }(),
38406
+ atlasJSON: atlasJSON,
38407
+ atlasIMG: atlasIMG
38408
+ }) : selectedPack ? React__default.createElement(StoreItemDetails, {
38409
+ item: _extends({}, selectedPack, {
38410
+ name: selectedPack.title,
38411
+ texturePath: selectedPack.image["default"] || selectedPack.image.src
38412
+ }),
38413
+ imageUrl: selectedPack.image,
38414
+ onBack: function onBack() {
38415
+ return setSelectedPack(null);
38416
+ },
38417
+ onAddToCart: function onAddToCart() {
38418
+ return handleAddPackToCart(selectedPack);
38419
+ }
38420
+ }) : React__default.createElement(Container$N, null, React__default.createElement(TopBar$1, null, React__default.createElement(CartButton, null, React__default.createElement(CTAButton, {
38421
+ icon: React__default.createElement(fa.FaShoppingCart, null),
38422
+ label: getTotalItems() + " items ($" + getTotalPrice().toFixed(2) + ")",
38423
+ onClick: openCart
38424
+ }))), React__default.createElement(MainContent$1, null, React__default.createElement(InternalTabs, {
38425
+ tabs: tabs,
38426
+ activeTextColor: "#000000",
38427
+ activeColor: "#fef08a",
38428
+ inactiveColor: "#6b7280",
38429
+ borderColor: "#f59e0b",
38430
+ hoverColor: "#fef3c7",
38431
+ activeTab: activeTab,
38432
+ onTabChange: setActiveTab
38433
+ })), cartItems.length > 0 && React__default.createElement(Footer$2, null, React__default.createElement(CartSummary, null, React__default.createElement(CartInfo, null, React__default.createElement("span", null, "Items in cart:"), React__default.createElement("span", null, getTotalItems())), React__default.createElement(CartInfo, null, React__default.createElement("span", null, "Total:"), React__default.createElement("span", null, "$", getTotalPrice().toFixed(2)))), React__default.createElement(CTAButton, {
38434
+ icon: React__default.createElement(fa.FaShoppingCart, null),
38435
+ label: "Proceed to Checkout ($" + getTotalPrice().toFixed(2) + ")",
38436
+ onClick: openCart,
38437
+ fullWidth: true
38438
+ }))));
38439
+ };
38440
+ var Container$N = /*#__PURE__*/styled__default.div.withConfig({
38441
+ displayName: "Store__Container",
38442
+ componentId: "sc-64dj00-0"
38443
+ })(["display:flex;flex-direction:column;width:100%;height:100%;gap:1rem;position:relative;"]);
38444
+ var TopBar$1 = /*#__PURE__*/styled__default.div.withConfig({
38445
+ displayName: "Store__TopBar",
38446
+ componentId: "sc-64dj00-1"
38447
+ })(["display:flex;align-items:center;justify-content:flex-end;gap:1rem;padding:0 1rem;flex-shrink:0;margin-top:0.5rem;"]);
38448
+ var CartButton = /*#__PURE__*/styled__default.div.withConfig({
38449
+ displayName: "Store__CartButton",
38450
+ componentId: "sc-64dj00-2"
38451
+ })(["min-width:fit-content;"]);
38452
+ var MainContent$1 = /*#__PURE__*/styled__default.div.withConfig({
38453
+ displayName: "Store__MainContent",
38454
+ componentId: "sc-64dj00-3"
38455
+ })(["flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden;.rpgui-tabs-content{flex:1;overflow-y:auto;padding-right:0.5rem;}"]);
38456
+ var Footer$2 = /*#__PURE__*/styled__default.div.withConfig({
38457
+ displayName: "Store__Footer",
38458
+ componentId: "sc-64dj00-4"
38459
+ })(["display:flex;flex-direction:column;gap:1rem;padding:1rem;border-top:2px solid #f59e0b;background:rgba(0,0,0,0.2);flex-shrink:0;"]);
38460
+ var CartSummary = /*#__PURE__*/styled__default.div.withConfig({
38461
+ displayName: "Store__CartSummary",
38462
+ componentId: "sc-64dj00-5"
38463
+ })(["display:flex;flex-direction:column;gap:0.5rem;"]);
38464
+ var CartInfo = /*#__PURE__*/styled__default.div.withConfig({
38465
+ displayName: "Store__CartInfo",
38466
+ componentId: "sc-64dj00-6"
38467
+ })(["display:flex;align-items:center;gap:0.75rem;font-family:'Press Start 2P',cursive;font-size:0.75rem;color:#ffffff;span:last-child{color:#fef08a;}"]);
38468
+ var LoadingMessage$1 = /*#__PURE__*/styled__default.div.withConfig({
38469
+ displayName: "Store__LoadingMessage",
38470
+ componentId: "sc-64dj00-7"
38471
+ })(["text-align:center;color:", ";padding:2rem;"], uiColors.white);
38472
+ var ErrorMessage$2 = /*#__PURE__*/styled__default.div.withConfig({
38473
+ displayName: "Store__ErrorMessage",
38474
+ componentId: "sc-64dj00-8"
38475
+ })(["text-align:center;color:", ";padding:2rem;"], uiColors.red);
38476
+
38477
+ var TextArea = function TextArea(_ref) {
38478
+ var props = _extends({}, (_objectDestructuringEmpty(_ref), _ref));
38479
+ return React__default.createElement("textarea", Object.assign({}, props));
38480
+ };
38481
+
38482
+ var img$a = '';
38483
+
38484
+ var img$b = '';
38485
+
38486
+ var img$c = '';
38487
+
38488
+ var DayNightPeriod = function DayNightPeriod(_ref) {
38489
+ var _periodOfDaySrcFiles;
38490
+ var periodOfDay = _ref.periodOfDay;
38491
+ var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[shared.PeriodOfDay.Morning] = img$b, _periodOfDaySrcFiles[shared.PeriodOfDay.Afternoon] = img$a, _periodOfDaySrcFiles[shared.PeriodOfDay.Night] = img$c, _periodOfDaySrcFiles);
38492
+ return React__default.createElement(GifContainer, null, React__default.createElement("img", {
38493
+ src: periodOfDaySrcFiles[periodOfDay]
38494
+ }));
38495
+ };
38496
+ var GifContainer = /*#__PURE__*/styled__default.div.withConfig({
38497
+ displayName: "DayNightPeriod__GifContainer",
38498
+ componentId: "sc-10t97fw-0"
38499
+ })(["width:100%;img{width:67%;}"]);
38500
+
38501
+ var img$d = '';
38502
+
38503
+ var TimeWidget = function TimeWidget(_ref) {
38504
+ var onClose = _ref.onClose,
38505
+ TimeClock = _ref.TimeClock,
38506
+ periodOfDay = _ref.periodOfDay,
38507
+ scale = _ref.scale;
38508
+ return React__default.createElement(Draggable, {
38509
+ scale: scale,
38510
+ cancel: ".time-widget-close,.time-widget-container,.time-widget-container *"
38511
+ }, React__default.createElement(WidgetContainer, null, React__default.createElement(CloseButton$a, {
38512
+ onPointerDown: onClose,
37138
38513
  className: "time-widget-close"
37139
38514
  }, "X"), React__default.createElement(DayNightContainer, {
37140
38515
  className: "time-widget-container"
@@ -37150,7 +38525,7 @@ var Time = /*#__PURE__*/styled__default.div.withConfig({
37150
38525
  displayName: "TimeWidget__Time",
37151
38526
  componentId: "sc-1ja236h-1"
37152
38527
  })(["top:0.75rem;right:0.5rem;position:absolute;font-size:", ";color:white;"], uiFonts.size.small);
37153
- var CloseButton$9 = /*#__PURE__*/styled__default.p.withConfig({
38528
+ var CloseButton$a = /*#__PURE__*/styled__default.p.withConfig({
37154
38529
  displayName: "TimeWidget__CloseButton",
37155
38530
  componentId: "sc-1ja236h-2"
37156
38531
  })(["position:absolute;top:-0.5rem;margin:0;right:-0.2rem;font-size:", " !important;z-index:1;"], uiFonts.size.small);
@@ -37259,7 +38634,7 @@ var TradingItemRow = function TradingItemRow(_ref) {
37259
38634
  }
37260
38635
  return null;
37261
38636
  };
37262
- return React__default.createElement(ItemWrapper, null, React__default.createElement(ItemIconContainer$1, null, React__default.createElement(SpriteContainer$5, null, React__default.createElement(ItemInfoWrapper, {
38637
+ return React__default.createElement(ItemWrapper$2, null, React__default.createElement(ItemIconContainer$4, null, React__default.createElement(SpriteContainer$6, null, React__default.createElement(ItemInfoWrapper, {
37263
38638
  atlasIMG: atlasIMG,
37264
38639
  atlasJSON: atlasJSON,
37265
38640
  equipmentSet: equipmentSet,
@@ -37293,7 +38668,7 @@ var TradingItemRow = function TradingItemRow(_ref) {
37293
38668
  onPointerDown: function onPointerDown() {
37294
38669
  return onLeftClick();
37295
38670
  }
37296
- }), React__default.createElement(QuantityInput, {
38671
+ }), React__default.createElement(QuantityInput$2, {
37297
38672
  type: "text",
37298
38673
  value: inputQty,
37299
38674
  onChange: handleQuantityChange,
@@ -37319,7 +38694,7 @@ var StyledArrow = /*#__PURE__*/styled__default(SelectArrow).withConfig({
37319
38694
  displayName: "TradingItemRow__StyledArrow",
37320
38695
  componentId: "sc-mja0b5-0"
37321
38696
  })(["margin:0 1.5rem;"]);
37322
- var ItemWrapper = /*#__PURE__*/styled__default.div.withConfig({
38697
+ var ItemWrapper$2 = /*#__PURE__*/styled__default.div.withConfig({
37323
38698
  displayName: "TradingItemRow__ItemWrapper",
37324
38699
  componentId: "sc-mja0b5-1"
37325
38700
  })(["width:100%;display:flex;justify-content:space-between;margin-bottom:0.5rem;padding:0.25rem;&:hover{background-color:", ";}"], uiColors.darkGray);
@@ -37327,11 +38702,11 @@ var ItemNameContainer = /*#__PURE__*/styled__default.div.withConfig({
37327
38702
  displayName: "TradingItemRow__ItemNameContainer",
37328
38703
  componentId: "sc-mja0b5-2"
37329
38704
  })(["flex:60%;display:flex;align-items:center;"]);
37330
- var ItemIconContainer$1 = /*#__PURE__*/styled__default.div.withConfig({
38705
+ var ItemIconContainer$4 = /*#__PURE__*/styled__default.div.withConfig({
37331
38706
  displayName: "TradingItemRow__ItemIconContainer",
37332
38707
  componentId: "sc-mja0b5-3"
37333
38708
  })(["display:flex;justify-content:flex-start;align-items:center;flex:0 0 40px;"]);
37334
- var SpriteContainer$5 = /*#__PURE__*/styled__default.div.withConfig({
38709
+ var SpriteContainer$6 = /*#__PURE__*/styled__default.div.withConfig({
37335
38710
  displayName: "TradingItemRow__SpriteContainer",
37336
38711
  componentId: "sc-mja0b5-4"
37337
38712
  })(["position:relative;top:-0.5rem;left:0;"]);
@@ -37343,7 +38718,7 @@ var QuantityContainer$1 = /*#__PURE__*/styled__default.div.withConfig({
37343
38718
  displayName: "TradingItemRow__QuantityContainer",
37344
38719
  componentId: "sc-mja0b5-6"
37345
38720
  })(["display:flex;min-width:90px;width:40%;justify-content:flex-end;align-items:center;flex:30%;gap:2px;position:relative;"]);
37346
- var QuantityInput = /*#__PURE__*/styled__default.input.withConfig({
38721
+ var QuantityInput$2 = /*#__PURE__*/styled__default.input.withConfig({
37347
38722
  displayName: "TradingItemRow__QuantityInput",
37348
38723
  componentId: "sc-mja0b5-7"
37349
38724
  })(["width:30px;text-align:center;background-color:", ";color:white;border:none;padding:1px;font-size:", ";position:relative;right:4px;"], uiColors.darkGray, uiFonts.size.small);
@@ -37429,7 +38804,7 @@ var TradingMenu = function TradingMenu(_ref) {
37429
38804
  width: "500px",
37430
38805
  cancelDrag: "#TraderContainer",
37431
38806
  scale: scale
37432
- }, React__default.createElement(Container$J, null, React__default.createElement(Title$e, null, type.charAt(0).toUpperCase() + type.slice(1), " Menu"), React__default.createElement("hr", {
38807
+ }, React__default.createElement(Container$O, null, React__default.createElement(Title$f, null, type.charAt(0).toUpperCase() + type.slice(1), " Menu"), React__default.createElement("hr", {
37433
38808
  className: "golden"
37434
38809
  }), React__default.createElement(ScrollWrapper, {
37435
38810
  id: "TraderContainer"
@@ -37457,11 +38832,11 @@ var TradingMenu = function TradingMenu(_ref) {
37457
38832
  onPointerDown: onClose
37458
38833
  }, "Cancel"))));
37459
38834
  };
37460
- var Container$J = /*#__PURE__*/styled__default.div.withConfig({
38835
+ var Container$O = /*#__PURE__*/styled__default.div.withConfig({
37461
38836
  displayName: "TradingMenu__Container",
37462
38837
  componentId: "sc-1wjsz1l-0"
37463
38838
  })(["width:100%;"]);
37464
- var Title$e = /*#__PURE__*/styled__default.h1.withConfig({
38839
+ var Title$f = /*#__PURE__*/styled__default.h1.withConfig({
37465
38840
  displayName: "TradingMenu__Title",
37466
38841
  componentId: "sc-1wjsz1l-1"
37467
38842
  })(["font-size:0.7rem !important;color:yellow !important;text-align:center;"]);
@@ -37491,11 +38866,11 @@ var Truncate = function Truncate(_ref) {
37491
38866
  var _ref$maxLines = _ref.maxLines,
37492
38867
  maxLines = _ref$maxLines === void 0 ? 1 : _ref$maxLines,
37493
38868
  children = _ref.children;
37494
- return React__default.createElement(Container$K, {
38869
+ return React__default.createElement(Container$P, {
37495
38870
  maxLines: maxLines
37496
38871
  }, children);
37497
38872
  };
37498
- var Container$K = /*#__PURE__*/styled__default.div.withConfig({
38873
+ var Container$P = /*#__PURE__*/styled__default.div.withConfig({
37499
38874
  displayName: "Truncate__Container",
37500
38875
  componentId: "sc-6x00qb-0"
37501
38876
  })(["display:-webkit-box;max-width:100%;max-height:100%;-webkit-line-clamp:", ";-webkit-box-orient:vertical;overflow:hidden;"], function (props) {
@@ -37603,7 +38978,7 @@ var TutorialStepper = /*#__PURE__*/React__default.memo(function (_ref) {
37603
38978
  };
37604
38979
  });
37605
38980
  }, [lessons, imageStyle]);
37606
- return React__default.createElement(Container$L, null, React__default.createElement(Stepper, {
38981
+ return React__default.createElement(Container$Q, null, React__default.createElement(Stepper, {
37607
38982
  steps: generateLessons,
37608
38983
  finalCTAButton: {
37609
38984
  label: 'Close',
@@ -37620,7 +38995,7 @@ var LessonBody = /*#__PURE__*/styled__default.div.withConfig({
37620
38995
  displayName: "TutorialStepper__LessonBody",
37621
38996
  componentId: "sc-7tgzv2-1"
37622
38997
  })([""]);
37623
- var Container$L = /*#__PURE__*/styled__default.div.withConfig({
38998
+ var Container$Q = /*#__PURE__*/styled__default.div.withConfig({
37624
38999
  displayName: "TutorialStepper__Container",
37625
39000
  componentId: "sc-7tgzv2-2"
37626
39001
  })(["width:80%;max-width:600px;@media (max-width:600px){width:95%;}"]);
@@ -37644,6 +39019,7 @@ var LessonContainer = /*#__PURE__*/styled__default.div.withConfig({
37644
39019
  exports.ActionButtons = ActionButtons;
37645
39020
  exports.AsyncDropdown = AsyncDropdown;
37646
39021
  exports.Button = Button;
39022
+ exports.CartView = CartView;
37647
39023
  exports.CharacterSelection = CharacterSelection;
37648
39024
  exports.CharacterSkinSelectionModal = CharacterSkinSelectionModal;
37649
39025
  exports.Chat = Chat;
@@ -37679,6 +39055,7 @@ exports.Leaderboard = Leaderboard;
37679
39055
  exports.ListMenu = ListMenu;
37680
39056
  exports.Marketplace = Marketplace;
37681
39057
  exports.MarketplaceRows = MarketplaceRows;
39058
+ exports.MetadataCollector = MetadataCollector;
37682
39059
  exports.NPCDialog = NPCDialog;
37683
39060
  exports.NPCMultiDialog = NPCMultiDialog;
37684
39061
  exports.PartyCreate = PartyCreate;
@@ -37706,6 +39083,7 @@ exports.SocialModal = SocialModal;
37706
39083
  exports.Spellbook = Spellbook;
37707
39084
  exports.SpriteFromAtlas = SpriteFromAtlas;
37708
39085
  exports.Stepper = Stepper;
39086
+ exports.Store = Store;
37709
39087
  exports.TabBody = TabBody;
37710
39088
  exports.Table = Table;
37711
39089
  exports.TableCell = TableCell;
@@ -37730,4 +39108,5 @@ exports.mockedPartyRows = mockedPartyRows;
37730
39108
  exports.mockedPlayersRows = mockedPlayersRows;
37731
39109
  exports.mockedPlayersRows2 = mockedPlayersRows2;
37732
39110
  exports.useEventListener = useEventListener;
39111
+ exports.useStoreCart = useStoreCart;
37733
39112
  //# sourceMappingURL=long-bow.cjs.development.js.map