@rpg-engine/long-bow 0.3.97 → 0.3.99

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 (173) hide show
  1. package/LICENSE +20 -20
  2. package/README.md +181 -181
  3. package/dist/components/Spellbook/Spell.d.ts +4 -4
  4. package/dist/components/Spellbook/Spellbook.d.ts +2 -2
  5. package/dist/components/Spellbook/cards/MobileSpellTooltip.d.ts +15 -0
  6. package/dist/components/Spellbook/cards/SpellInfo.d.ts +7 -0
  7. package/dist/components/Spellbook/cards/SpellInfoDisplay.d.ts +7 -0
  8. package/dist/components/Spellbook/cards/SpellInfoWrapper.d.ts +9 -0
  9. package/dist/components/Spellbook/cards/SpellTooltip.d.ts +6 -0
  10. package/dist/components/Spellbook/mockSpells.d.ts +2 -2
  11. package/dist/libs/CastingTypeHelper.d.ts +1 -0
  12. package/dist/long-bow.cjs.development.js +1424 -1210
  13. package/dist/long-bow.cjs.development.js.map +1 -1
  14. package/dist/long-bow.cjs.production.min.js +1 -1
  15. package/dist/long-bow.cjs.production.min.js.map +1 -1
  16. package/dist/long-bow.esm.js +1447 -1233
  17. package/dist/long-bow.esm.js.map +1 -1
  18. package/dist/stories/SpellInfoDisplay.stories.d.ts +8 -0
  19. package/package.json +100 -100
  20. package/src/components/Abstractions/ModalPortal.tsx +22 -22
  21. package/src/components/Abstractions/SlotsContainer.tsx +62 -62
  22. package/src/components/Arrow/SelectArrow.tsx +69 -69
  23. package/src/components/Arrow/img/arrow01-left-clicked.png +0 -0
  24. package/src/components/Arrow/img/arrow01-left.png +0 -0
  25. package/src/components/Arrow/img/arrow01-right-clicked.png +0 -0
  26. package/src/components/Arrow/img/arrow01-right.png +0 -0
  27. package/src/components/Arrow/img/arrow02-left-clicked.png +0 -0
  28. package/src/components/Arrow/img/arrow02-left.png +0 -0
  29. package/src/components/Arrow/img/arrow02-right-clicked.png +0 -0
  30. package/src/components/Arrow/img/arrow02-right.png +0 -0
  31. package/src/components/Button.tsx +40 -40
  32. package/src/components/Character/CharacterSelection.tsx +98 -98
  33. package/src/components/CharacterStatus/CharacterStatus.tsx +120 -120
  34. package/src/components/Chat/Chat.tsx +196 -196
  35. package/src/components/Chatdeprecated/ChatDeprecated.tsx +198 -198
  36. package/src/components/CheckButton.tsx +65 -65
  37. package/src/components/CircularController/CircularController.tsx +282 -282
  38. package/src/components/CraftBook/CraftBook.tsx +286 -286
  39. package/src/components/CraftBook/CraftingRecipe.tsx +161 -161
  40. package/src/components/CraftBook/MockItems.ts +101 -101
  41. package/src/components/DraggableContainer.tsx +180 -180
  42. package/src/components/DropdownSelectorContainer.tsx +42 -42
  43. package/src/components/Equipment/EquipmentSet.tsx +199 -199
  44. package/src/components/HistoryDialog.tsx +104 -104
  45. package/src/components/Input.tsx +15 -15
  46. package/src/components/InputRadio.tsx +41 -41
  47. package/src/components/Item/Cards/ItemInfo.tsx +298 -298
  48. package/src/components/Item/Cards/ItemInfoDisplay.tsx +135 -135
  49. package/src/components/Item/Cards/ItemInfoWrapper.tsx +62 -62
  50. package/src/components/Item/Cards/ItemTooltip.tsx +83 -83
  51. package/src/components/Item/Cards/MobileItemTooltip.tsx +149 -149
  52. package/src/components/Item/Inventory/ErrorBoundary.tsx +42 -42
  53. package/src/components/Item/Inventory/ItemContainer.tsx +231 -231
  54. package/src/components/Item/Inventory/ItemContainerTypes.ts +6 -6
  55. package/src/components/Item/Inventory/ItemQuantitySelector.tsx +138 -138
  56. package/src/components/Item/Inventory/ItemSlot.tsx +580 -580
  57. package/src/components/Item/Inventory/itemContainerHelper.ts +175 -175
  58. package/src/components/ListMenu.tsx +63 -63
  59. package/src/components/Marketplace/Marketplace.tsx +132 -132
  60. package/src/components/Marketplace/MarketplaceRows.tsx +171 -171
  61. package/src/components/Marketplace/__mocks__/index.tsx +65 -65
  62. package/src/components/Multitab/Tab.tsx +66 -66
  63. package/src/components/Multitab/TabBody.tsx +13 -13
  64. package/src/components/Multitab/TabsContainer.tsx +97 -97
  65. package/src/components/NPCDialog/NPCDialog.tsx +121 -121
  66. package/src/components/NPCDialog/NPCDialogText.tsx +113 -113
  67. package/src/components/NPCDialog/NPCMultiDialog.tsx +159 -159
  68. package/src/components/NPCDialog/QuestionDialog/QuestionDialog.tsx +237 -237
  69. package/src/components/ProgressBar.tsx +95 -92
  70. package/src/components/PropertySelect/PropertySelect.tsx +106 -106
  71. package/src/components/QuestInfo/QuestInfo.tsx +233 -233
  72. package/src/components/QuestList.tsx +135 -135
  73. package/src/components/RPGUIContainer.tsx +47 -47
  74. package/src/components/RPGUIForceRenderStart.tsx +45 -45
  75. package/src/components/RPGUIRoot.tsx +14 -14
  76. package/src/components/RadioButton.tsx +53 -53
  77. package/src/components/RadioInput/RadioButton.tsx +96 -96
  78. package/src/components/RadioInput/RadioInput.tsx +102 -102
  79. package/src/components/RadioInput/instruments.ts +15 -15
  80. package/src/components/RangeSlider.tsx +78 -78
  81. package/src/components/RelativeListMenu.tsx +90 -90
  82. package/src/components/ScrollList.tsx +79 -79
  83. package/src/components/Shortcuts/Shortcuts.tsx +193 -192
  84. package/src/components/Shortcuts/ShortcutsSetter.tsx +139 -139
  85. package/src/components/Shortcuts/SingleShortcut.ts +82 -82
  86. package/src/components/Shortcuts/useShortcutCooldown.ts +23 -23
  87. package/src/components/SimpleProgressBar.tsx +62 -62
  88. package/src/components/SkillProgressBar.tsx +133 -133
  89. package/src/components/SkillsContainer.tsx +220 -206
  90. package/src/components/Spellbook/Spell.tsx +236 -226
  91. package/src/components/Spellbook/Spellbook.tsx +161 -158
  92. package/src/components/Spellbook/cards/MobileSpellTooltip.tsx +137 -0
  93. package/src/components/Spellbook/cards/SpellInfo.tsx +134 -0
  94. package/src/components/Spellbook/cards/SpellInfoDisplay.tsx +31 -0
  95. package/src/components/Spellbook/cards/SpellInfoWrapper.tsx +48 -0
  96. package/src/components/Spellbook/cards/SpellTooltip.tsx +70 -0
  97. package/src/components/Spellbook/constants.ts +8 -8
  98. package/src/components/Spellbook/mockSpells.ts +85 -60
  99. package/src/components/StaticBook/StaticBook.tsx +103 -103
  100. package/src/components/TextArea.tsx +11 -11
  101. package/src/components/TimeWidget/DayNightPeriod/DayNightPeriod.tsx +35 -35
  102. package/src/components/TimeWidget/TimeWidget.tsx +65 -65
  103. package/src/components/TradingMenu/TradingItemRow.tsx +199 -199
  104. package/src/components/TradingMenu/TradingMenu.tsx +219 -219
  105. package/src/components/TradingMenu/items.mock.ts +48 -48
  106. package/src/components/Truncate.tsx +25 -25
  107. package/src/components/itemSelector/ItemSelector.tsx +136 -136
  108. package/src/components/shared/Column.tsx +16 -16
  109. package/src/components/shared/Ellipsis.tsx +68 -68
  110. package/src/components/shared/SpriteFromAtlas.tsx +104 -104
  111. package/src/components/typography/DynamicText.tsx +49 -49
  112. package/src/constants/uiColors.ts +20 -20
  113. package/src/constants/uiDevices.ts +3 -3
  114. package/src/constants/uiFonts.ts +12 -12
  115. package/src/hooks/useEventListener.ts +21 -21
  116. package/src/hooks/useOutsideAlerter.ts +25 -25
  117. package/src/index.tsx +42 -42
  118. package/src/libs/CastingTypeHelper.ts +8 -0
  119. package/src/libs/StringHelpers.ts +3 -3
  120. package/src/libs/itemCounter.ts +21 -21
  121. package/src/mocks/atlas/entities/entities.json +20215 -20215
  122. package/src/mocks/atlas/icons/icons.json +735 -735
  123. package/src/mocks/atlas/items/items.json +12086 -12086
  124. package/src/mocks/equipmentSet.mocks.ts +391 -391
  125. package/src/mocks/itemContainer.mocks.ts +605 -605
  126. package/src/mocks/skills.mocks.ts +128 -128
  127. package/src/stories/Arrow.stories.tsx +26 -26
  128. package/src/stories/Button.stories.tsx +36 -36
  129. package/src/stories/CharacterSelection.stories.tsx +44 -44
  130. package/src/stories/CharacterStatus.stories.tsx +29 -29
  131. package/src/stories/Chat.stories.tsx +187 -187
  132. package/src/stories/ChatDeprecated.stories.tsx +170 -170
  133. package/src/stories/CheckButton.stories.tsx +48 -48
  134. package/src/stories/CircullarController.stories.tsx +37 -37
  135. package/src/stories/CraftBook.stories.tsx +42 -42
  136. package/src/stories/DayNightPeriod.stories.tsx +27 -27
  137. package/src/stories/DraggableContainer.stories.tsx +28 -28
  138. package/src/stories/Dropdown.stories.tsx +46 -46
  139. package/src/stories/DropdownSelectorContainer.stories.tsx +41 -41
  140. package/src/stories/EquipmentSet.stories.tsx +65 -65
  141. package/src/stories/HistoryDialog.stories.tsx +61 -61
  142. package/src/stories/ItemContainer.stories.tsx +201 -201
  143. package/src/stories/ItemInfoDisplay.stories.tsx +33 -33
  144. package/src/stories/ItemQuantitySelector.stories.tsx +26 -26
  145. package/src/stories/ItemSelector.stories.tsx +77 -77
  146. package/src/stories/ItemTradingComponent.stories.tsx +35 -35
  147. package/src/stories/ListMenu.stories.tsx +56 -56
  148. package/src/stories/Marketplace.stories.tsx +42 -42
  149. package/src/stories/MarketplaceRows.stories.tsx +28 -28
  150. package/src/stories/Multitab.stories.tsx +51 -51
  151. package/src/stories/NPCDialog.stories.tsx +130 -130
  152. package/src/stories/NPCMultiDialog.stories.tsx +71 -71
  153. package/src/stories/ProgressBar.stories.tsx +23 -23
  154. package/src/stories/PropertySelect.stories.tsx +40 -40
  155. package/src/stories/QuestInfo.stories.tsx +107 -107
  156. package/src/stories/QuestList.stories.tsx +82 -82
  157. package/src/stories/RPGUIContainers.stories.tsx +42 -42
  158. package/src/stories/RadioButton.stories.tsx +49 -49
  159. package/src/stories/RadioInput.stories.tsx +34 -34
  160. package/src/stories/RangeSlider.stories.tsx +64 -64
  161. package/src/stories/ScrollList.stories.tsx +85 -85
  162. package/src/stories/Shortcuts.stories.tsx +39 -39
  163. package/src/stories/SimpleProgressBar.stories.tsx +22 -22
  164. package/src/stories/SkillProgressBar.stories.tsx +34 -34
  165. package/src/stories/SkillsContainer.stories.tsx +35 -35
  166. package/src/stories/SpellInfoDisplay.stories.tsx +27 -0
  167. package/src/stories/Spellbook.stories.tsx +104 -104
  168. package/src/stories/StaticBook.stories.tsx +32 -32
  169. package/src/stories/Text.stories.tsx +42 -42
  170. package/src/stories/TimeWidget.stories.tsx +27 -27
  171. package/src/stories/TradingMenu.stories.tsx +47 -47
  172. package/src/types/eventTypes.ts +4 -4
  173. package/src/types/index.d.ts +2 -2
@@ -14593,703 +14593,374 @@ var EquipmentColumn = /*#__PURE__*/styled.div.withConfig({
14593
14593
  componentId: "sc-1wuddg2-1"
14594
14594
  })(["display:flex;justify-content:center;flex-wrap:wrap;flex-direction:column;touch-action:none;"]);
14595
14595
 
14596
- var SlotsContainer = function SlotsContainer(_ref) {
14597
- var children = _ref.children,
14598
- title = _ref.title,
14599
- onClose = _ref.onClose,
14600
- _onPositionChange = _ref.onPositionChange,
14601
- _onPositionChangeEnd = _ref.onPositionChangeEnd,
14602
- _onPositionChangeStart = _ref.onPositionChangeStart,
14603
- onOutsideClick = _ref.onOutsideClick,
14604
- initialPosition = _ref.initialPosition,
14605
- scale = _ref.scale;
14606
- return React__default.createElement(DraggableContainer, {
14607
- title: title,
14608
- type: exports.RPGUIContainerTypes.Framed,
14609
- onCloseButton: function onCloseButton() {
14610
- if (onClose) {
14611
- onClose();
14612
- }
14613
- },
14614
- width: "400px",
14615
- cancelDrag: ".item-container-body, #shortcuts_list",
14616
- onPositionChange: function onPositionChange(_ref2) {
14617
- var x = _ref2.x,
14618
- y = _ref2.y;
14619
- if (_onPositionChange) {
14620
- _onPositionChange({
14621
- x: x,
14622
- y: y
14623
- });
14624
- }
14625
- },
14626
- onPositionChangeEnd: function onPositionChangeEnd(_ref3) {
14627
- var x = _ref3.x,
14628
- y = _ref3.y;
14629
- if (_onPositionChangeEnd) {
14630
- _onPositionChangeEnd({
14631
- x: x,
14632
- y: y
14633
- });
14596
+ var IS_MOBILE_OR_TABLET = /*#__PURE__*/shared.isMobileOrTablet();
14597
+
14598
+ var chunkString = function chunkString(str, length) {
14599
+ return str.match(new RegExp('.{1,' + length + '}', 'g'));
14600
+ };
14601
+
14602
+ var DynamicText = function DynamicText(_ref) {
14603
+ var text = _ref.text,
14604
+ onFinish = _ref.onFinish,
14605
+ onStart = _ref.onStart;
14606
+ var _useState = React.useState(''),
14607
+ textState = _useState[0],
14608
+ setTextState = _useState[1];
14609
+ React.useEffect(function () {
14610
+ var i = 0;
14611
+ var interval = setInterval(function () {
14612
+ // on every interval, show one more character
14613
+ if (i === 0) {
14614
+ if (onStart) {
14615
+ onStart();
14616
+ }
14634
14617
  }
14635
- },
14636
- onPositionChangeStart: function onPositionChangeStart(_ref4) {
14637
- var x = _ref4.x,
14638
- y = _ref4.y;
14639
- if (_onPositionChangeStart) {
14640
- _onPositionChangeStart({
14641
- x: x,
14642
- y: y
14643
- });
14618
+ if (i < text.length) {
14619
+ setTextState(text.substring(0, i + 1));
14620
+ i++;
14621
+ } else {
14622
+ clearInterval(interval);
14623
+ if (onFinish) {
14624
+ onFinish();
14625
+ }
14644
14626
  }
14645
- },
14646
- onOutsideClick: onOutsideClick,
14647
- initialPosition: initialPosition,
14648
- scale: scale
14649
- }, children);
14627
+ }, 50);
14628
+ return function () {
14629
+ clearInterval(interval);
14630
+ };
14631
+ }, [text]);
14632
+ return React__default.createElement(TextContainer, null, textState);
14650
14633
  };
14634
+ var TextContainer = /*#__PURE__*/styled.p.withConfig({
14635
+ displayName: "DynamicText__TextContainer",
14636
+ componentId: "sc-1ggl9nd-0"
14637
+ })(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]);
14651
14638
 
14652
- (function (RangeSliderType) {
14653
- RangeSliderType["Slider"] = "rpgui-slider";
14654
- RangeSliderType["GoldSlider"] = "rpgui-slider golden";
14655
- })(exports.RangeSliderType || (exports.RangeSliderType = {}));
14656
- var RangeSlider = function RangeSlider(_ref) {
14657
- var type = _ref.type,
14658
- valueMin = _ref.valueMin,
14659
- valueMax = _ref.valueMax,
14660
- width = _ref.width,
14661
- _onChange = _ref.onChange,
14662
- value = _ref.value;
14663
- var sliderId = uuid.v4();
14664
- var containerRef = React.useRef(null);
14639
+ var img$5 = '';
14640
+
14641
+ var img$6 = '';
14642
+
14643
+ var NPCDialogText = function NPCDialogText(_ref) {
14644
+ var text = _ref.text,
14645
+ onClose = _ref.onClose,
14646
+ onEndStep = _ref.onEndStep,
14647
+ onStartStep = _ref.onStartStep,
14648
+ type = _ref.type;
14649
+ var windowSize = React.useRef([window.innerWidth, window.innerHeight]);
14650
+ function maxCharacters(width) {
14651
+ // Set the font size to 16 pixels
14652
+ var fontSize = 11.2;
14653
+ // Calculate the number of characters that can fit in one line
14654
+ var charactersPerLine = Math.floor(width / 2 / fontSize);
14655
+ // Calculate the number of lines that can fit in the div
14656
+ var linesPerDiv = Math.floor(180 / fontSize);
14657
+ // Calculate the maximum number of characters that can fit in the div
14658
+ var maxCharacters = charactersPerLine * linesPerDiv;
14659
+ // Return the maximum number of characters
14660
+ return Math.round(maxCharacters / 5);
14661
+ }
14662
+ var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
14665
14663
  var _useState = React.useState(0),
14666
- left = _useState[0],
14667
- setLeft = _useState[1];
14664
+ chunkIndex = _useState[0],
14665
+ setChunkIndex = _useState[1];
14666
+ var onHandleSpacePress = function onHandleSpacePress(event) {
14667
+ if (event.code === 'Space') {
14668
+ goToNextStep();
14669
+ }
14670
+ };
14671
+ var goToNextStep = function goToNextStep() {
14672
+ var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
14673
+ if (hasNextChunk) {
14674
+ setChunkIndex(function (prev) {
14675
+ return prev + 1;
14676
+ });
14677
+ } else {
14678
+ // if there's no more text chunks, close the dialog
14679
+ onClose();
14680
+ }
14681
+ };
14668
14682
  React.useEffect(function () {
14669
- var _containerRef$current;
14670
- var calculatedWidth = ((_containerRef$current = containerRef.current) == null ? void 0 : _containerRef$current.clientWidth) || 0;
14671
- setLeft(Math.max((value - valueMin) / (valueMax - valueMin) * (calculatedWidth - 35) + 10));
14672
- }, [value, valueMin, valueMax]);
14673
- var typeClass = type === exports.RangeSliderType.GoldSlider ? 'golden' : '';
14674
- return React__default.createElement("div", {
14675
- style: {
14676
- width: width,
14677
- position: 'relative'
14683
+ document.addEventListener('keydown', onHandleSpacePress);
14684
+ return function () {
14685
+ return document.removeEventListener('keydown', onHandleSpacePress);
14686
+ };
14687
+ }, [chunkIndex]);
14688
+ var _useState2 = React.useState(false),
14689
+ showGoNextIndicator = _useState2[0],
14690
+ setShowGoNextIndicator = _useState2[1];
14691
+ return React__default.createElement(Container$e, null, React__default.createElement(DynamicText, {
14692
+ text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
14693
+ onFinish: function onFinish() {
14694
+ setShowGoNextIndicator(true);
14695
+ onEndStep && onEndStep();
14678
14696
  },
14679
- className: "rpgui-slider-container " + typeClass,
14680
- id: "rpgui-slider-" + sliderId,
14681
- ref: containerRef
14682
- }, React__default.createElement("div", {
14683
- style: {
14684
- pointerEvents: 'none'
14697
+ onStart: function onStart() {
14698
+ setShowGoNextIndicator(false);
14699
+ onStartStep && onStartStep();
14685
14700
  }
14686
- }, React__default.createElement("div", {
14687
- className: "rpgui-slider-track " + typeClass
14688
- }), React__default.createElement("div", {
14689
- className: "rpgui-slider-left-edge " + typeClass
14690
- }), React__default.createElement("div", {
14691
- className: "rpgui-slider-right-edge " + typeClass
14692
- }), React__default.createElement("div", {
14693
- className: "rpgui-slider-thumb " + typeClass,
14694
- style: {
14695
- left: left
14701
+ }), showGoNextIndicator && React__default.createElement(PressSpaceIndicator, {
14702
+ right: type === exports.NPCDialogType.TextOnly ? '1rem' : '10.5rem',
14703
+ src: IS_MOBILE_OR_TABLET ? img$5 : img$6,
14704
+ onPointerDown: function onPointerDown() {
14705
+ goToNextStep();
14696
14706
  }
14697
- })), React__default.createElement(Input$1, {
14698
- type: "range",
14699
- style: {
14700
- width: width
14701
- },
14702
- min: valueMin,
14703
- max: valueMax,
14704
- onChange: function onChange(e) {
14705
- return _onChange(Number(e.target.value));
14706
- },
14707
- value: value,
14708
- className: "rpgui-cursor-point"
14709
14707
  }));
14710
14708
  };
14711
- var Input$1 = /*#__PURE__*/styled.input.withConfig({
14712
- displayName: "RangeSlider__Input",
14713
- componentId: "sc-v8mte9-0"
14714
- })(["opacity:0;position:absolute;width:100%;height:100%;top:0;left:0;margin-top:-5px;"]);
14709
+ var Container$e = /*#__PURE__*/styled.div.withConfig({
14710
+ displayName: "NPCDialogText__Container",
14711
+ componentId: "sc-1cxkdh9-0"
14712
+ })([""]);
14713
+ var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
14714
+ displayName: "NPCDialogText__PressSpaceIndicator",
14715
+ componentId: "sc-1cxkdh9-1"
14716
+ })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
14717
+ var right = _ref2.right;
14718
+ return right;
14719
+ });
14715
14720
 
14716
- var ItemQuantitySelector = function ItemQuantitySelector(_ref) {
14717
- var quantity = _ref.quantity,
14718
- onConfirm = _ref.onConfirm,
14721
+ //@ts-ignore
14722
+ var useEventListener = function useEventListener(type, handler, el) {
14723
+ if (el === void 0) {
14724
+ el = window;
14725
+ }
14726
+ var savedHandler = React__default.useRef();
14727
+ React__default.useEffect(function () {
14728
+ savedHandler.current = handler;
14729
+ }, [handler]);
14730
+ React__default.useEffect(function () {
14731
+ //@ts-ignore
14732
+ var listener = function listener(e) {
14733
+ return savedHandler.current(e);
14734
+ };
14735
+ el.addEventListener(type, listener);
14736
+ return function () {
14737
+ el.removeEventListener(type, listener);
14738
+ };
14739
+ }, [type, el]);
14740
+ };
14741
+
14742
+ var QuestionDialog = function QuestionDialog(_ref) {
14743
+ var questions = _ref.questions,
14744
+ answers = _ref.answers,
14719
14745
  onClose = _ref.onClose;
14720
- var _useState = React.useState(quantity),
14721
- value = _useState[0],
14722
- setValue = _useState[1];
14723
- var inputRef = React.useRef(null);
14724
- React.useEffect(function () {
14725
- if (inputRef.current) {
14726
- inputRef.current.focus();
14727
- inputRef.current.select();
14728
- var closeSelector = function closeSelector(e) {
14729
- if (e.key === 'Escape') {
14730
- onClose();
14731
- }
14732
- };
14733
- document.addEventListener('keydown', closeSelector);
14734
- return function () {
14735
- document.removeEventListener('keydown', closeSelector);
14736
- };
14737
- }
14738
- return function () {};
14739
- }, []);
14740
- return React__default.createElement(StyledContainer, {
14741
- type: exports.RPGUIContainerTypes.Framed,
14742
- width: "25rem"
14743
- }, React__default.createElement(CloseButton$2, {
14744
- className: "container-close",
14745
- onPointerDown: onClose
14746
- }, "X"), React__default.createElement("h2", null, "Select quantity to move"), React__default.createElement(StyledForm, {
14747
- style: {
14748
- width: '100%'
14749
- },
14750
- onSubmit: function onSubmit(e) {
14751
- e.preventDefault();
14752
- var numberValue = Number(value);
14753
- if (Number.isNaN(numberValue)) {
14754
- return;
14755
- }
14756
- onConfirm(Math.max(1, Math.min(quantity, numberValue)));
14757
- },
14758
- noValidate: true
14759
- }, React__default.createElement(StyledInput, {
14760
- innerRef: inputRef,
14761
- placeholder: "Enter quantity",
14762
- type: "number",
14763
- min: 1,
14764
- max: quantity,
14765
- value: value,
14766
- onChange: function onChange(e) {
14767
- if (Number(e.target.value) >= quantity) {
14768
- setValue(quantity);
14769
- return;
14770
- }
14771
- setValue(e.target.value);
14772
- },
14773
- onBlur: function onBlur(e) {
14774
- var newValue = Math.max(1, Math.min(quantity, Number(e.target.value)));
14775
- setValue(newValue);
14746
+ var _useState = React.useState(questions[0]),
14747
+ currentQuestion = _useState[0],
14748
+ setCurrentQuestion = _useState[1];
14749
+ var _useState2 = React.useState(false),
14750
+ canShowAnswers = _useState2[0],
14751
+ setCanShowAnswers = _useState2[1];
14752
+ var onGetFirstAnswer = function onGetFirstAnswer() {
14753
+ if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {
14754
+ return null;
14776
14755
  }
14777
- }), React__default.createElement(RangeSlider, {
14778
- type: exports.RangeSliderType.Slider,
14779
- valueMin: 1,
14780
- valueMax: quantity,
14781
- width: "100%",
14782
- onChange: setValue,
14783
- value: value
14784
- }), React__default.createElement(Button, {
14785
- buttonType: exports.ButtonTypes.RPGUIButton,
14786
- type: "submit"
14787
- }, "Confirm")));
14788
- };
14789
- var StyledContainer = /*#__PURE__*/styled(RPGUIContainer).withConfig({
14790
- displayName: "ItemQuantitySelector__StyledContainer",
14791
- componentId: "sc-yfdtpn-0"
14792
- })(["display:flex;flex-direction:column;align-items:center;"]);
14793
- var StyledForm = /*#__PURE__*/styled.form.withConfig({
14794
- displayName: "ItemQuantitySelector__StyledForm",
14795
- componentId: "sc-yfdtpn-1"
14796
- })(["display:flex;flex-direction:column;align-items:center;width:100%;"]);
14797
- var StyledInput = /*#__PURE__*/styled(Input).withConfig({
14798
- displayName: "ItemQuantitySelector__StyledInput",
14799
- componentId: "sc-yfdtpn-2"
14800
- })(["text-align:center;&::-webkit-outer-spin-button,&::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}&[type='number']{-moz-appearance:textfield;}"]);
14801
- var CloseButton$2 = /*#__PURE__*/styled.div.withConfig({
14802
- displayName: "ItemQuantitySelector__CloseButton",
14803
- componentId: "sc-yfdtpn-3"
14804
- })(["position:absolute;top:3px;right:0px;color:white;z-index:22;font-size:0.8rem;"]);
14805
-
14806
- var ShortcutsSetter = function ShortcutsSetter(_ref) {
14807
- var setSettingShortcutIndex = _ref.setSettingShortcutIndex,
14808
- settingShortcutIndex = _ref.settingShortcutIndex,
14809
- shortcuts = _ref.shortcuts,
14810
- removeShortcut = _ref.removeShortcut,
14811
- atlasJSON = _ref.atlasJSON,
14812
- atlasIMG = _ref.atlasIMG;
14813
- var getContent = function getContent(index) {
14814
- var _shortcuts$index, _shortcuts$index3;
14815
- if (((_shortcuts$index = shortcuts[index]) == null ? void 0 : _shortcuts$index.type) === shared.ShortcutType.Item) {
14816
- var _shortcuts$index2;
14817
- var _payload = (_shortcuts$index2 = shortcuts[index]) == null ? void 0 : _shortcuts$index2.payload;
14818
- if (!_payload) return null;
14819
- return React__default.createElement(SpriteFromAtlas, {
14820
- atlasIMG: atlasIMG,
14821
- atlasJSON: atlasJSON,
14822
- spriteKey: shared.getItemTextureKeyPath({
14823
- key: _payload.texturePath,
14824
- texturePath: _payload.texturePath,
14825
- stackQty: _payload.stackQty || 1,
14826
- isStackable: _payload.isStackable
14827
- }, atlasJSON),
14828
- width: 32,
14829
- height: 32,
14830
- imgScale: 1.6,
14831
- imgStyle: {
14832
- left: '5px'
14833
- }
14756
+ var firstAnswerId = currentQuestion.answerIds[0];
14757
+ return answers.find(function (answer) {
14758
+ return answer.id === firstAnswerId;
14759
+ });
14760
+ };
14761
+ var _useState3 = React.useState(onGetFirstAnswer()),
14762
+ currentAnswer = _useState3[0],
14763
+ setCurrentAnswer = _useState3[1];
14764
+ React.useEffect(function () {
14765
+ setCurrentAnswer(onGetFirstAnswer());
14766
+ }, [currentQuestion]);
14767
+ var onGetAnswers = function onGetAnswers(answerIds) {
14768
+ return answerIds.map(function (answerId) {
14769
+ return answers.find(function (answer) {
14770
+ return answer.id === answerId;
14834
14771
  });
14772
+ });
14773
+ };
14774
+ var onKeyPress = function onKeyPress(e) {
14775
+ switch (e.key) {
14776
+ case 'ArrowDown':
14777
+ // select next answer, if any.
14778
+ // if no next answer, select first answer
14779
+ // const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(
14780
+ // (answer) => answer?.id === currentAnswer!.id + 1
14781
+ // );
14782
+ var nextAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
14783
+ return (answer == null ? void 0 : answer.id) === currentAnswer.id + 1;
14784
+ });
14785
+ var nextAnswerID = currentQuestion.answerIds[nextAnswerIndex];
14786
+ var nextAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
14787
+ return (answer == null ? void 0 : answer.id) === nextAnswerID;
14788
+ });
14789
+ setCurrentAnswer(nextAnswer || onGetFirstAnswer());
14790
+ break;
14791
+ case 'ArrowUp':
14792
+ // select previous answer, if any.
14793
+ // if no previous answer, select last answer
14794
+ var previousAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
14795
+ return (answer == null ? void 0 : answer.id) === currentAnswer.id - 1;
14796
+ });
14797
+ var previousAnswerID = currentQuestion.answerIds && currentQuestion.answerIds[previousAnswerIndex];
14798
+ var previousAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
14799
+ return (answer == null ? void 0 : answer.id) === previousAnswerID;
14800
+ });
14801
+ if (previousAnswer) {
14802
+ setCurrentAnswer(previousAnswer);
14803
+ } else {
14804
+ setCurrentAnswer(onGetAnswers(currentQuestion.answerIds).pop());
14805
+ }
14806
+ break;
14807
+ case 'Enter':
14808
+ setCanShowAnswers(false);
14809
+ if (!(currentAnswer != null && currentAnswer.nextQuestionId)) {
14810
+ onClose();
14811
+ return;
14812
+ } else {
14813
+ setCurrentQuestion(questions.find(function (question) {
14814
+ return question.id === currentAnswer.nextQuestionId;
14815
+ }));
14816
+ }
14817
+ break;
14835
14818
  }
14836
- var payload = (_shortcuts$index3 = shortcuts[index]) == null ? void 0 : _shortcuts$index3.payload;
14837
- return React__default.createElement("span", null, payload == null ? void 0 : payload.magicWords.split(' ').map(function (word) {
14838
- return word[0];
14839
- }));
14840
14819
  };
14841
- return React__default.createElement(Container$e, null, React__default.createElement("p", null, "Shortcuts:"), React__default.createElement(List, {
14842
- id: "shortcuts_list"
14843
- }, Array.from({
14844
- length: 6
14845
- }).map(function (_, i) {
14846
- return React__default.createElement(Shortcut, {
14847
- key: i,
14848
- onPointerDown: function onPointerDown() {
14849
- if (settingShortcutIndex !== -1) setSettingShortcutIndex(-1);
14850
- removeShortcut(i);
14851
- if (settingShortcutIndex === -1 && (!shortcuts[i] || shortcuts[i].type === shared.ShortcutType.None)) setSettingShortcutIndex(i);
14852
- },
14853
- disabled: settingShortcutIndex !== -1 && settingShortcutIndex !== i,
14854
- isBeingSet: settingShortcutIndex === i,
14855
- id: "shortcutSetter_" + i
14856
- }, getContent(i));
14857
- })));
14858
- };
14859
- var Container$e = /*#__PURE__*/styled.div.withConfig({
14860
- displayName: "ShortcutsSetter__Container",
14861
- componentId: "sc-xuouuf-0"
14862
- })(["p{margin:0;margin-left:0.5rem;}"]);
14863
- var Shortcut = /*#__PURE__*/styled.button.withConfig({
14864
- displayName: "ShortcutsSetter__Shortcut",
14865
- componentId: "sc-xuouuf-1"
14866
- })(["width:2.6rem;height:2.6rem;background-color:", ";border:2px solid ", ";border-radius:50%;text-transform:uppercase;font-size:0.7rem;font-weight:bold;display:flex;align-items:center;justify-content:center;span{margin-top:4px;}&:hover,&:focus{background-color:", ";}&:active{background-color:", ";}&:disabled{opacity:0.5;}"], uiColors.lightGray, function (_ref2) {
14867
- var isBeingSet = _ref2.isBeingSet;
14868
- return isBeingSet ? uiColors.yellow : uiColors.darkGray;
14869
- }, uiColors.darkGray, uiColors.gray);
14870
- var List = /*#__PURE__*/styled.div.withConfig({
14871
- displayName: "ShortcutsSetter__List",
14872
- componentId: "sc-xuouuf-2"
14873
- })(["width:100%;display:flex;align-items:center;gap:0.5rem;padding-bottom:0.5rem;padding-left:0.5rem;box-sizing:border-box;margin:0 !important;"]);
14874
-
14875
- var ItemContainer$1 = function ItemContainer(_ref) {
14876
- var itemContainer = _ref.itemContainer,
14877
- onClose = _ref.onClose,
14878
- _onMouseOver = _ref.onMouseOver,
14879
- _onSelected = _ref.onSelected,
14880
- onItemClick = _ref.onItemClick,
14881
- type = _ref.type,
14882
- atlasJSON = _ref.atlasJSON,
14883
- atlasIMG = _ref.atlasIMG,
14884
- _ref$disableContextMe = _ref.disableContextMenu,
14885
- disableContextMenu = _ref$disableContextMe === void 0 ? false : _ref$disableContextMe,
14886
- onItemDragEnd = _ref.onItemDragEnd,
14887
- onItemDragStart = _ref.onItemDragStart,
14888
- onItemPlaceDrop = _ref.onItemPlaceDrop,
14889
- _onOutsideDrop = _ref.onOutsideDrop,
14890
- checkIfItemCanBeMoved = _ref.checkIfItemCanBeMoved,
14891
- initialPosition = _ref.initialPosition,
14892
- checkIfItemShouldDragEnd = _ref.checkIfItemShouldDragEnd,
14893
- scale = _ref.scale,
14894
- shortcuts = _ref.shortcuts,
14895
- setItemShortcut = _ref.setItemShortcut,
14896
- removeShortcut = _ref.removeShortcut,
14897
- equipmentSet = _ref.equipmentSet,
14898
- isDepotSystem = _ref.isDepotSystem,
14899
- onPositionChangeEnd = _ref.onPositionChangeEnd,
14900
- onPositionChangeStart = _ref.onPositionChangeStart;
14901
- var _useState = React.useState({
14902
- isOpen: false,
14903
- maxQuantity: 1,
14904
- callback: function callback(_quantity) {}
14905
- }),
14906
- quantitySelect = _useState[0],
14907
- setQuantitySelect = _useState[1];
14908
- var _useState2 = React.useState(-1),
14909
- settingShortcutIndex = _useState2[0],
14910
- setSettingShortcutIndex = _useState2[1];
14911
- var handleSetShortcut = function handleSetShortcut(item, index) {
14912
- if (item.type === shared.ItemType.Consumable || item.type === shared.ItemType.Tool) {
14913
- setItemShortcut == null ? void 0 : setItemShortcut(item.key, index);
14820
+ useEventListener('keydown', onKeyPress);
14821
+ var onAnswerClick = function onAnswerClick(answer) {
14822
+ setCanShowAnswers(false);
14823
+ if (answer.nextQuestionId) {
14824
+ // if there is a next question, go to it
14825
+ setCurrentQuestion(questions.find(function (question) {
14826
+ return question.id === answer.nextQuestionId;
14827
+ }));
14828
+ } else {
14829
+ // else, finish dialog!
14830
+ onClose();
14914
14831
  }
14915
14832
  };
14916
- var onRenderSlots = function onRenderSlots() {
14917
- var slots = [];
14918
- for (var i = 0; i < itemContainer.slotQty; i++) {
14919
- var _itemContainer$slots;
14920
- slots.push(React__default.createElement(ItemSlot, {
14921
- isContextMenuDisabled: disableContextMenu,
14922
- key: i,
14923
- slotIndex: i,
14924
- item: ((_itemContainer$slots = itemContainer.slots) == null ? void 0 : _itemContainer$slots[i]) || null,
14925
- itemContainerType: type,
14926
- onMouseOver: function onMouseOver(event, slotIndex, item) {
14927
- if (_onMouseOver) _onMouseOver(event, slotIndex, item);
14928
- },
14929
- onPointerDown: function onPointerDown(itemType, containerType, item) {
14930
- if (settingShortcutIndex !== -1) {
14931
- setSettingShortcutIndex(-1);
14932
- handleSetShortcut(item, settingShortcutIndex);
14933
- } else if (onItemClick) onItemClick(item, itemType, containerType);
14934
- },
14935
- onSelected: function onSelected(optionId, item) {
14936
- if (_onSelected) _onSelected(optionId, item);
14937
- },
14938
- onDragStart: function onDragStart(item, slotIndex, itemContainerType) {
14939
- if (onItemDragStart) onItemDragStart(item, slotIndex, itemContainerType);
14940
- },
14941
- onDragEnd: function onDragEnd(quantity) {
14942
- if (onItemDragEnd) onItemDragEnd(quantity);
14943
- },
14944
- dragScale: scale,
14945
- checkIfItemCanBeMoved: checkIfItemCanBeMoved,
14946
- checkIfItemShouldDragEnd: checkIfItemShouldDragEnd,
14947
- openQuantitySelector: function openQuantitySelector(maxQuantity, callback) {
14948
- setQuantitySelect({
14949
- isOpen: true,
14950
- maxQuantity: maxQuantity,
14951
- callback: callback
14952
- });
14953
- },
14954
- onPlaceDrop: function onPlaceDrop(item, slotIndex, itemContainerType) {
14955
- if (onItemPlaceDrop) onItemPlaceDrop(item, slotIndex, itemContainerType);
14956
- },
14957
- onOutsideDrop: function onOutsideDrop(item, position) {
14958
- if (_onOutsideDrop) _onOutsideDrop(item, position);
14959
- },
14960
- atlasIMG: atlasIMG,
14961
- atlasJSON: atlasJSON,
14962
- isSelectingShortcut: settingShortcutIndex !== -1,
14963
- equipmentSet: equipmentSet,
14964
- setItemShortcut: type === shared.ItemContainerType.Inventory ? handleSetShortcut : undefined,
14965
- isDepotSystem: isDepotSystem
14966
- }));
14967
- }
14968
- return slots;
14969
- };
14970
- return React__default.createElement(React__default.Fragment, null, React__default.createElement(SlotsContainer, {
14971
- title: itemContainer.name || 'Container',
14972
- onClose: onClose,
14973
- initialPosition: initialPosition,
14974
- scale: scale,
14975
- onPositionChangeEnd: onPositionChangeEnd,
14976
- onPositionChangeStart: onPositionChangeStart
14977
- }, type === shared.ItemContainerType.Inventory && shortcuts && removeShortcut && React__default.createElement(ShortcutsSetter, {
14978
- setSettingShortcutIndex: setSettingShortcutIndex,
14979
- settingShortcutIndex: settingShortcutIndex,
14980
- shortcuts: shortcuts,
14981
- removeShortcut: removeShortcut,
14982
- atlasIMG: atlasIMG,
14983
- atlasJSON: atlasJSON
14984
- }), React__default.createElement(ItemsContainer, {
14985
- className: "item-container-body"
14986
- }, onRenderSlots())), quantitySelect.isOpen && React__default.createElement(ModalPortal, null, React__default.createElement(QuantitySelectorContainer, null, React__default.createElement(ItemQuantitySelector, {
14987
- quantity: quantitySelect.maxQuantity,
14988
- onConfirm: function onConfirm(quantity) {
14989
- quantitySelect.callback(quantity);
14990
- setQuantitySelect({
14991
- isOpen: false,
14992
- maxQuantity: 1,
14993
- callback: function callback() {}
14994
- });
14995
- },
14996
- onClose: function onClose() {
14997
- quantitySelect.callback(-1);
14998
- setQuantitySelect({
14999
- isOpen: false,
15000
- maxQuantity: 1,
15001
- callback: function callback() {}
15002
- });
15003
- }
15004
- }))));
15005
- };
15006
- var ItemsContainer = /*#__PURE__*/styled.div.withConfig({
15007
- displayName: "ItemContainer__ItemsContainer",
15008
- componentId: "sc-15y5p9l-0"
15009
- })(["display:flex;justify-content:center;flex-wrap:wrap;"]);
15010
- var QuantitySelectorContainer = /*#__PURE__*/styled.div.withConfig({
15011
- displayName: "ItemContainer__QuantitySelectorContainer",
15012
- componentId: "sc-15y5p9l-1"
15013
- })(["position:absolute;top:0;left:0;width:100vw;height:100vh;z-index:100;display:flex;justify-content:center;align-items:center;background-color:rgba(0,0,0,0.5);"]);
15014
-
15015
- var ItemSelector = function ItemSelector(_ref) {
15016
- var atlasIMG = _ref.atlasIMG,
15017
- atlasJSON = _ref.atlasJSON,
15018
- options = _ref.options,
15019
- onClose = _ref.onClose,
15020
- onSelect = _ref.onSelect;
15021
- var _useState = React.useState(),
15022
- selectedValue = _useState[0],
15023
- setSelectedValue = _useState[1];
15024
- var handleClick = function handleClick() {
15025
- var element = document.querySelector("input[name='test']:checked");
15026
- var elementValue = element.value;
15027
- setSelectedValue(elementValue);
15028
- };
15029
- React.useEffect(function () {
15030
- if (selectedValue) {
15031
- onSelect(selectedValue);
15032
- }
15033
- }, [selectedValue]);
15034
- return React__default.createElement(DraggableContainer, {
15035
- type: exports.RPGUIContainerTypes.Framed,
15036
- width: "500px",
15037
- cancelDrag: ".equipment-container-body .arrow-selector",
15038
- onCloseButton: function onCloseButton() {
15039
- if (onClose) {
15040
- onClose();
15041
- }
15042
- }
15043
- }, React__default.createElement("div", {
15044
- style: {
15045
- width: '100%'
15046
- }
15047
- }, React__default.createElement(Title$3, null, 'Harvesting instruments'), React__default.createElement(Subtitle$1, null, 'Use the tool, you need it'), React__default.createElement("hr", {
15048
- className: "golden"
15049
- })), React__default.createElement(RadioInputScroller$1, null, options == null ? void 0 : options.map(function (option, index) {
15050
- return React__default.createElement(RadioOptionsWrapper$1, {
15051
- key: index
15052
- }, React__default.createElement(SpriteAtlasWrapper$1, null, React__default.createElement(SpriteFromAtlas, {
15053
- atlasIMG: atlasIMG,
15054
- atlasJSON: atlasJSON,
15055
- spriteKey: option.imageKey,
15056
- imgScale: 3
15057
- })), React__default.createElement("div", null, React__default.createElement("input", {
15058
- className: "rpgui-radio",
15059
- type: "radio",
15060
- value: option.name,
15061
- name: "test"
15062
- }), React__default.createElement("label", {
15063
- onPointerDown: handleClick,
15064
- style: {
15065
- display: 'flex',
15066
- alignItems: 'center'
15067
- }
15068
- }, option.name, " ", React__default.createElement("br", null), option.description)));
15069
- })), React__default.createElement(ButtonWrapper$1, null, React__default.createElement(Button, {
15070
- buttonType: exports.ButtonTypes.RPGUIButton,
15071
- onPointerDown: onClose
15072
- }, "Cancel"), React__default.createElement(Button, {
15073
- buttonType: exports.ButtonTypes.RPGUIButton
15074
- }, "Select")));
15075
- };
15076
- var Title$3 = /*#__PURE__*/styled.h1.withConfig({
15077
- displayName: "ItemSelector__Title",
15078
- componentId: "sc-gptoxp-0"
15079
- })(["font-size:0.6rem;color:yellow !important;"]);
15080
- var Subtitle$1 = /*#__PURE__*/styled.h1.withConfig({
15081
- displayName: "ItemSelector__Subtitle",
15082
- componentId: "sc-gptoxp-1"
15083
- })(["font-size:0.4rem;color:yellow !important;"]);
15084
- var RadioInputScroller$1 = /*#__PURE__*/styled.div.withConfig({
15085
- displayName: "ItemSelector__RadioInputScroller",
15086
- componentId: "sc-gptoxp-2"
15087
- })(["padding-left:15px;padding-top:10px;width:100%;margin-top:1rem;align-items:center;margin-left:20px;align-items:flex-start;overflow-y:scroll;height:360px;"]);
15088
- var SpriteAtlasWrapper$1 = /*#__PURE__*/styled.div.withConfig({
15089
- displayName: "ItemSelector__SpriteAtlasWrapper",
15090
- componentId: "sc-gptoxp-3"
15091
- })(["margin-right:40px;"]);
15092
- var RadioOptionsWrapper$1 = /*#__PURE__*/styled.div.withConfig({
15093
- displayName: "ItemSelector__RadioOptionsWrapper",
15094
- componentId: "sc-gptoxp-4"
15095
- })(["display:flex;align-items:stretch;margin-bottom:40px;"]);
15096
- var ButtonWrapper$1 = /*#__PURE__*/styled.div.withConfig({
15097
- displayName: "ItemSelector__ButtonWrapper",
15098
- componentId: "sc-gptoxp-5"
15099
- })(["display:flex;justify-content:space-around;padding-top:20px;width:100%;"]);
15100
-
15101
- var ListMenu = function ListMenu(_ref) {
15102
- var options = _ref.options,
15103
- onSelected = _ref.onSelected,
15104
- x = _ref.x,
15105
- y = _ref.y;
15106
- return React__default.createElement(Container$f, {
15107
- x: x,
15108
- y: y
15109
- }, React__default.createElement("ul", {
15110
- className: "rpgui-list-imp",
15111
- style: {
15112
- overflow: 'hidden'
14833
+ var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
14834
+ var answerIds = currentQuestion.answerIds;
14835
+ if (!answerIds) {
14836
+ return null;
15113
14837
  }
15114
- }, options.map(function (params, index) {
15115
- return React__default.createElement(ListElement$1, {
15116
- key: (params == null ? void 0 : params.id) || index,
15117
- onPointerDown: function onPointerDown() {
15118
- onSelected(params == null ? void 0 : params.id);
15119
- }
15120
- }, (params == null ? void 0 : params.text) || 'No text');
15121
- })));
15122
- };
15123
- var Container$f = /*#__PURE__*/styled.div.withConfig({
15124
- displayName: "ListMenu__Container",
15125
- componentId: "sc-i9097t-0"
15126
- })(["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) {
15127
- return props.y || 0;
15128
- }, function (props) {
15129
- return props.x || 0;
15130
- }, uiFonts.size.xsmall);
15131
- var ListElement$1 = /*#__PURE__*/styled.li.withConfig({
15132
- displayName: "ListMenu__ListElement",
15133
- componentId: "sc-i9097t-1"
15134
- })(["margin-right:0.5rem;"]);
15135
-
15136
- var MarketplaceRows = function MarketplaceRows(_ref) {
15137
- var atlasJSON = _ref.atlasJSON,
15138
- atlasIMG = _ref.atlasIMG,
15139
- item = _ref.item,
15140
- itemPrice = _ref.itemPrice,
15141
- equipmentSet = _ref.equipmentSet,
15142
- scale = _ref.scale,
15143
- onHandleClick = _ref.onHandleClick;
15144
- return React__default.createElement(MarketPlaceWrapper, null, React__default.createElement(ItemIconContainer, null, React__default.createElement(SpriteContainer, null, React__default.createElement(ItemInfoWrapper, {
15145
- item: item,
15146
- atlasIMG: atlasIMG,
15147
- atlasJSON: atlasJSON,
15148
- equipmentSet: equipmentSet,
15149
- scale: scale
15150
- }, React__default.createElement(SpriteFromAtlas, {
15151
- atlasIMG: atlasIMG,
15152
- atlasJSON: atlasJSON,
15153
- spriteKey: shared.getItemTextureKeyPath({
15154
- key: item.key,
15155
- stackQty: item.stackQty || 1,
15156
- texturePath: item.texturePath,
15157
- isStackable: item.isStackable
15158
- }, atlasJSON),
15159
- imgScale: 2
15160
- }))), React__default.createElement(PriceValue, null, React__default.createElement("p", null, React__default.createElement(Ellipsis, {
15161
- maxLines: 1,
15162
- maxWidth: "150px",
15163
- fontSize: "10px"
15164
- }, item.name)))), React__default.createElement(QuantityContainer, null, React__default.createElement(QuantityDisplay, null, React__default.createElement(TextOverlay$1, null, React__default.createElement(Item$1, null, React__default.createElement(Ellipsis, {
15165
- maxLines: 1,
15166
- maxWidth: "150px",
15167
- fontSize: "10px"
15168
- }, item.rarity))))), React__default.createElement(ItemIconContainer, null, React__default.createElement(SpriteContainer, null, React__default.createElement(SpriteFromAtlas, {
15169
- atlasIMG: atlasIMG,
15170
- atlasJSON: atlasJSON,
15171
- spriteKey: 'others/gold-coin-qty-4.png',
15172
- imgScale: 2
15173
- })), React__default.createElement(PriceValue, null, React__default.createElement("p", null, React__default.createElement(Ellipsis, {
15174
- maxLines: 1,
15175
- maxWidth: "150px",
15176
- fontSize: "10px"
15177
- }, "$", itemPrice)))), React__default.createElement(ButtonContainer$1, null, React__default.createElement(Button, {
15178
- buttonType: exports.ButtonTypes.RPGUIButton,
15179
- onClick: function onClick() {
15180
- return onHandleClick(item.name);
14838
+ var answers = onGetAnswers(answerIds);
14839
+ if (!answers) {
14840
+ return null;
15181
14841
  }
15182
- }, "Buy")));
15183
- };
15184
- var MarketPlaceWrapper = /*#__PURE__*/styled.div.withConfig({
15185
- displayName: "MarketplaceRows__MarketPlaceWrapper",
15186
- componentId: "sc-wmpr1o-0"
15187
- })(["margin:auto;display:grid;grid-template-columns:35% 20% 20% 25%;&:hover{background-color:", ";}padding:0.5rem;p{font-size:0.8rem;}"], uiColors.darkGray);
15188
- var ItemIconContainer = /*#__PURE__*/styled.div.withConfig({
15189
- displayName: "MarketplaceRows__ItemIconContainer",
15190
- componentId: "sc-wmpr1o-1"
15191
- })(["display:flex;justify-content:flex-start;align-items:center;"]);
15192
- var SpriteContainer = /*#__PURE__*/styled.div.withConfig({
15193
- displayName: "MarketplaceRows__SpriteContainer",
15194
- componentId: "sc-wmpr1o-2"
15195
- })(["position:relative;top:-0.5rem;left:0.5rem;"]);
15196
- var Item$1 = /*#__PURE__*/styled.span.withConfig({
15197
- displayName: "MarketplaceRows__Item",
15198
- componentId: "sc-wmpr1o-3"
15199
- })(["color:white;text-align:center;z-index:1;width:100%;"]);
15200
- var TextOverlay$1 = /*#__PURE__*/styled.div.withConfig({
15201
- displayName: "MarketplaceRows__TextOverlay",
15202
- componentId: "sc-wmpr1o-4"
15203
- })(["width:100%;position:relative;"]);
15204
- var QuantityContainer = /*#__PURE__*/styled.div.withConfig({
15205
- displayName: "MarketplaceRows__QuantityContainer",
15206
- componentId: "sc-wmpr1o-5"
15207
- })(["position:relative;display:flex;min-width:100px;justify-content:center;align-items:center;"]);
15208
- var QuantityDisplay = /*#__PURE__*/styled.div.withConfig({
15209
- displayName: "MarketplaceRows__QuantityDisplay",
15210
- componentId: "sc-wmpr1o-6"
15211
- })(["font-size:", ";"], uiFonts.size.small);
15212
- var PriceValue = /*#__PURE__*/styled.div.withConfig({
15213
- displayName: "MarketplaceRows__PriceValue",
15214
- componentId: "sc-wmpr1o-7"
15215
- })(["margin-left:40px;"]);
15216
- var ButtonContainer$1 = /*#__PURE__*/styled.div.withConfig({
15217
- displayName: "MarketplaceRows__ButtonContainer",
15218
- componentId: "sc-wmpr1o-8"
15219
- })(["margin:auto;"]);
15220
-
15221
- var Marketplace = function Marketplace(_ref) {
15222
- var items = _ref.items,
15223
- atlasIMG = _ref.atlasIMG,
15224
- atlasJSON = _ref.atlasJSON,
15225
- onClose = _ref.onClose,
15226
- optionsType = _ref.optionsType,
15227
- optionsRarity = _ref.optionsRarity,
15228
- optionsPrice = _ref.optionsPrice,
15229
- onChangeType = _ref.onChangeType,
15230
- onChangeRarity = _ref.onChangeRarity,
15231
- onChangeOrder = _ref.onChangeOrder,
15232
- onChangeNameInput = _ref.onChangeNameInput,
15233
- scale = _ref.scale,
15234
- equipmentSet = _ref.equipmentSet,
15235
- onHandleClick = _ref.onHandleClick;
15236
- return React__default.createElement(DraggableContainer, {
15237
- type: exports.RPGUIContainerTypes.Framed,
15238
- onCloseButton: function onCloseButton() {
15239
- if (onClose) onClose();
15240
- },
15241
- width: "800px",
15242
- cancelDrag: "#MarketContainer",
15243
- scale: scale
15244
- }, React__default.createElement(React__default.Fragment, null, React__default.createElement(InputWrapper, null, React__default.createElement("p", null, " Search By Name"), React__default.createElement(Input, {
15245
- onChange: onChangeNameInput,
15246
- placeholder: 'Search...'
15247
- })), React__default.createElement(WrapperContainer, null, React__default.createElement(StyledDropdown, {
15248
- options: optionsType,
15249
- onChange: onChangeType,
15250
- width: '220px'
15251
- }), React__default.createElement(StyledDropdown, {
15252
- options: optionsRarity,
15253
- onChange: onChangeRarity,
15254
- width: '220px'
15255
- }), React__default.createElement(StyledDropdown, {
15256
- options: optionsPrice,
15257
- onChange: onChangeOrder,
15258
- width: '220px'
15259
- })), React__default.createElement(ItemComponentScrollWrapper, {
15260
- id: "MarketContainer"
15261
- }, items == null ? void 0 : items.map(function (item, index) {
15262
- return React__default.createElement(MarketplaceRows, {
15263
- key: item.key + "_" + index,
15264
- atlasIMG: atlasIMG,
15265
- atlasJSON: atlasJSON,
15266
- item: item,
15267
- itemPrice: 10,
15268
- equipmentSet: equipmentSet,
15269
- onHandleClick: onHandleClick
14842
+ return answers.map(function (answer) {
14843
+ var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
14844
+ var selectedColor = isSelected ? 'yellow' : 'white';
14845
+ if (answer) {
14846
+ return React__default.createElement(AnswerRow, {
14847
+ key: "answer_" + answer.id
14848
+ }, React__default.createElement(AnswerSelectedIcon, {
14849
+ color: selectedColor
14850
+ }, isSelected ? 'X' : null), React__default.createElement(Answer, {
14851
+ key: answer.id,
14852
+ onPointerDown: function onPointerDown() {
14853
+ return onAnswerClick(answer);
14854
+ },
14855
+ color: selectedColor
14856
+ }, answer.text));
14857
+ }
14858
+ return null;
15270
14859
  });
15271
- }))));
14860
+ };
14861
+ return React__default.createElement(Container$f, null, React__default.createElement(QuestionContainer, null, React__default.createElement(DynamicText, {
14862
+ text: currentQuestion.text,
14863
+ onStart: function onStart() {
14864
+ return setCanShowAnswers(false);
14865
+ },
14866
+ onFinish: function onFinish() {
14867
+ return setCanShowAnswers(true);
14868
+ }
14869
+ })), canShowAnswers && React__default.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
15272
14870
  };
15273
- var InputWrapper = /*#__PURE__*/styled.div.withConfig({
15274
- displayName: "Marketplace__InputWrapper",
15275
- componentId: "sc-h904b1-0"
15276
- })(["width:95%;display:flex;justify-content:flex-start;align-items:center;margin:auto;margin-bottom:10px;p{width:auto;margin-right:20px;}input{width:68%;height:10px;}"]);
15277
- var WrapperContainer = /*#__PURE__*/styled.div.withConfig({
15278
- displayName: "Marketplace__WrapperContainer",
15279
- componentId: "sc-h904b1-1"
15280
- })(["display:grid;grid-template-columns:30% 30% 30%;justify-content:space-between;width:90%;margin-left:10px;.rpgui-content .rpgui-dropdown-imp-header{padding:0px 10px 0 !important;}"]);
15281
- var ItemComponentScrollWrapper = /*#__PURE__*/styled.div.withConfig({
15282
- displayName: "Marketplace__ItemComponentScrollWrapper",
15283
- componentId: "sc-h904b1-2"
15284
- })(["overflow-y:scroll;height:390px;width:100%;margin-top:1rem;"]);
15285
- var StyledDropdown = /*#__PURE__*/styled(Dropdown).withConfig({
15286
- displayName: "Marketplace__StyledDropdown",
15287
- componentId: "sc-h904b1-3"
15288
- })(["margin:3px !important;width:170px !important;"]);
14871
+ var Container$f = /*#__PURE__*/styled.div.withConfig({
14872
+ displayName: "QuestionDialog__Container",
14873
+ componentId: "sc-bxc5u0-0"
14874
+ })(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
14875
+ var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
14876
+ displayName: "QuestionDialog__QuestionContainer",
14877
+ componentId: "sc-bxc5u0-1"
14878
+ })(["flex:100%;width:100%;"]);
14879
+ var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
14880
+ displayName: "QuestionDialog__AnswersContainer",
14881
+ componentId: "sc-bxc5u0-2"
14882
+ })(["flex:100%;"]);
14883
+ var Answer = /*#__PURE__*/styled.p.withConfig({
14884
+ displayName: "QuestionDialog__Answer",
14885
+ componentId: "sc-bxc5u0-3"
14886
+ })(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
14887
+ return props.color;
14888
+ });
14889
+ var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
14890
+ displayName: "QuestionDialog__AnswerSelectedIcon",
14891
+ componentId: "sc-bxc5u0-4"
14892
+ })(["flex:5% 0 0;color:", " !important;"], function (props) {
14893
+ return props.color;
14894
+ });
14895
+ var AnswerRow = /*#__PURE__*/styled.div.withConfig({
14896
+ displayName: "QuestionDialog__AnswerRow",
14897
+ componentId: "sc-bxc5u0-5"
14898
+ })(["display:flex;flex-wrap:wrap;justify-content:center;align-items:center;margin-bottom:0.5rem;height:22px;p{line-height:unset;margin-top:0;margin-bottom:0rem;}"]);
15289
14899
 
15290
- var img$5 = '';
14900
+ var img$7 = '';
15291
14901
 
15292
- var img$6 = '';
14902
+ (function (NPCDialogType) {
14903
+ NPCDialogType["TextOnly"] = "TextOnly";
14904
+ NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
14905
+ })(exports.NPCDialogType || (exports.NPCDialogType = {}));
14906
+ var NPCDialog = function NPCDialog(_ref) {
14907
+ var text = _ref.text,
14908
+ type = _ref.type,
14909
+ _onClose = _ref.onClose,
14910
+ imagePath = _ref.imagePath,
14911
+ _ref$isQuestionDialog = _ref.isQuestionDialog,
14912
+ isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
14913
+ questions = _ref.questions,
14914
+ answers = _ref.answers;
14915
+ return React__default.createElement(RPGUIContainer, {
14916
+ type: exports.RPGUIContainerTypes.FramedGold,
14917
+ width: isQuestionDialog ? '600px' : '80%',
14918
+ height: '180px'
14919
+ }, isQuestionDialog && questions && answers ? React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer$1, {
14920
+ flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
14921
+ }, React__default.createElement(QuestionDialog, {
14922
+ questions: questions,
14923
+ answers: answers,
14924
+ onClose: function onClose() {
14925
+ if (_onClose) {
14926
+ _onClose();
14927
+ }
14928
+ }
14929
+ })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
14930
+ src: imagePath || img$7
14931
+ }))) : React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$g, null, React__default.createElement(TextContainer$1, {
14932
+ flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
14933
+ }, React__default.createElement(NPCDialogText, {
14934
+ type: type,
14935
+ text: text || 'No text provided.',
14936
+ onClose: function onClose() {
14937
+ if (_onClose) {
14938
+ _onClose();
14939
+ }
14940
+ }
14941
+ })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
14942
+ src: imagePath || img$7
14943
+ })))));
14944
+ };
14945
+ var Container$g = /*#__PURE__*/styled.div.withConfig({
14946
+ displayName: "NPCDialog__Container",
14947
+ componentId: "sc-1b4aw74-0"
14948
+ })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
14949
+ var TextContainer$1 = /*#__PURE__*/styled.div.withConfig({
14950
+ displayName: "NPCDialog__TextContainer",
14951
+ componentId: "sc-1b4aw74-1"
14952
+ })(["flex:", " 0 0;width:355px;"], function (_ref2) {
14953
+ var flex = _ref2.flex;
14954
+ return flex;
14955
+ });
14956
+ var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
14957
+ displayName: "NPCDialog__ThumbnailContainer",
14958
+ componentId: "sc-1b4aw74-2"
14959
+ })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
14960
+ var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
14961
+ displayName: "NPCDialog__NPCThumbnail",
14962
+ componentId: "sc-1b4aw74-3"
14963
+ })(["image-rendering:pixelated;height:128px;width:128px;"]);
15293
14964
 
15294
14965
  (function (ImgSide) {
15295
14966
  ImgSide["right"] = "right";
@@ -15327,7 +14998,29 @@ var NPCMultiDialog = function NPCMultiDialog(_ref) {
15327
14998
  type: exports.RPGUIContainerTypes.FramedGold,
15328
14999
  width: '50%',
15329
15000
  height: '180px'
15330
- }, React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$g, null, ((_textAndTypeArray$sli = textAndTypeArray[slide]) == null ? void 0 : _textAndTypeArray$sli.imageSide) === 'right' && React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer, {
15001
+ }, React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$h, null, ((_textAndTypeArray$sli = textAndTypeArray[slide]) == null ? void 0 : _textAndTypeArray$sli.imageSide) === 'right' && React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer$2, {
15002
+ flex: '70%'
15003
+ }, React__default.createElement(NPCDialogText, {
15004
+ onStartStep: function onStartStep() {
15005
+ return setShowGoNextIndicator(false);
15006
+ },
15007
+ onEndStep: function onEndStep() {
15008
+ return setShowGoNextIndicator(true);
15009
+ },
15010
+ text: textAndTypeArray[slide].text || 'No text provided.',
15011
+ onClose: function onClose() {
15012
+ if (_onClose) {
15013
+ _onClose();
15014
+ }
15015
+ }
15016
+ })), React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
15017
+ src: textAndTypeArray[slide].imagePath || img$7
15018
+ })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator$1, {
15019
+ right: '10.5rem',
15020
+ src: img$6
15021
+ })), textAndTypeArray[slide].imageSide === 'left' && React__default.createElement(React__default.Fragment, null, React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
15022
+ src: textAndTypeArray[slide].imagePath || img$7
15023
+ })), React__default.createElement(TextContainer$2, {
15331
15024
  flex: '70%'
15332
15025
  }, React__default.createElement(NPCDialogText, {
15333
15026
  onStartStep: function onStartStep() {
@@ -15336,281 +15029,801 @@ var NPCMultiDialog = function NPCMultiDialog(_ref) {
15336
15029
  onEndStep: function onEndStep() {
15337
15030
  return setShowGoNextIndicator(true);
15338
15031
  },
15339
- text: textAndTypeArray[slide].text || 'No text provided.',
15340
- onClose: function onClose() {
15341
- if (_onClose) {
15342
- _onClose();
15032
+ text: textAndTypeArray[slide].text || 'No text provided.',
15033
+ onClose: function onClose() {
15034
+ if (_onClose) {
15035
+ _onClose();
15036
+ }
15037
+ }
15038
+ })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator$1, {
15039
+ right: '1rem',
15040
+ src: img$6
15041
+ }))), ")"));
15042
+ };
15043
+ var Container$h = /*#__PURE__*/styled.div.withConfig({
15044
+ displayName: "NPCMultiDialog__Container",
15045
+ componentId: "sc-rvu5wg-0"
15046
+ })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
15047
+ var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
15048
+ displayName: "NPCMultiDialog__TextContainer",
15049
+ componentId: "sc-rvu5wg-1"
15050
+ })(["flex:", " 0 0;width:355px;"], function (_ref2) {
15051
+ var flex = _ref2.flex;
15052
+ return flex;
15053
+ });
15054
+ var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
15055
+ displayName: "NPCMultiDialog__ThumbnailContainer",
15056
+ componentId: "sc-rvu5wg-2"
15057
+ })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
15058
+ var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
15059
+ displayName: "NPCMultiDialog__NPCThumbnail",
15060
+ componentId: "sc-rvu5wg-3"
15061
+ })(["image-rendering:pixelated;height:128px;width:128px;"]);
15062
+ var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
15063
+ displayName: "NPCMultiDialog__PressSpaceIndicator",
15064
+ componentId: "sc-rvu5wg-4"
15065
+ })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref3) {
15066
+ var right = _ref3.right;
15067
+ return right;
15068
+ });
15069
+
15070
+ var HistoryDialog = function HistoryDialog(_ref) {
15071
+ var backgroundImgPath = _ref.backgroundImgPath,
15072
+ fullCoverBackground = _ref.fullCoverBackground,
15073
+ questions = _ref.questions,
15074
+ answers = _ref.answers,
15075
+ text = _ref.text,
15076
+ imagePath = _ref.imagePath,
15077
+ textAndTypeArray = _ref.textAndTypeArray,
15078
+ onClose = _ref.onClose;
15079
+ var _useState = React.useState(0),
15080
+ img = _useState[0],
15081
+ setImage = _useState[1];
15082
+ var onHandleSpacePress = function onHandleSpacePress(event) {
15083
+ if (event.code === 'Space') {
15084
+ if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
15085
+ setImage(function (prev) {
15086
+ return prev + 1;
15087
+ });
15088
+ } else {
15089
+ // if there's no more text chunks, close the dialog
15090
+ onClose();
15091
+ }
15092
+ }
15093
+ };
15094
+ React.useEffect(function () {
15095
+ document.addEventListener('keydown', onHandleSpacePress);
15096
+ return function () {
15097
+ return document.removeEventListener('keydown', onHandleSpacePress);
15098
+ };
15099
+ }, [backgroundImgPath]);
15100
+ return React__default.createElement(BackgroundContainer, {
15101
+ imgPath: backgroundImgPath[img],
15102
+ fullImg: fullCoverBackground
15103
+ }, React__default.createElement(DialogContainer, null, textAndTypeArray ? React__default.createElement(NPCMultiDialog, {
15104
+ textAndTypeArray: textAndTypeArray,
15105
+ onClose: onClose
15106
+ }) : questions && answers ? React__default.createElement(QuestionDialog, {
15107
+ questions: questions,
15108
+ answers: answers,
15109
+ onClose: onClose
15110
+ }) : text && imagePath ? React__default.createElement(NPCDialog, {
15111
+ text: text,
15112
+ imagePath: imagePath,
15113
+ onClose: onClose,
15114
+ type: exports.NPCDialogType.TextAndThumbnail
15115
+ }) : React__default.createElement(NPCDialog, {
15116
+ text: text,
15117
+ onClose: onClose,
15118
+ type: exports.NPCDialogType.TextOnly
15119
+ })));
15120
+ };
15121
+ var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
15122
+ displayName: "HistoryDialog__BackgroundContainer",
15123
+ componentId: "sc-u6oe75-0"
15124
+ })(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
15125
+ return props.imgPath;
15126
+ }, function (props) {
15127
+ return props.imgPath ? 'cover' : 'auto';
15128
+ });
15129
+ var DialogContainer = /*#__PURE__*/styled.div.withConfig({
15130
+ displayName: "HistoryDialog__DialogContainer",
15131
+ componentId: "sc-u6oe75-1"
15132
+ })(["display:flex;justify-content:center;padding-top:200px;"]);
15133
+
15134
+ var SlotsContainer = function SlotsContainer(_ref) {
15135
+ var children = _ref.children,
15136
+ title = _ref.title,
15137
+ onClose = _ref.onClose,
15138
+ _onPositionChange = _ref.onPositionChange,
15139
+ _onPositionChangeEnd = _ref.onPositionChangeEnd,
15140
+ _onPositionChangeStart = _ref.onPositionChangeStart,
15141
+ onOutsideClick = _ref.onOutsideClick,
15142
+ initialPosition = _ref.initialPosition,
15143
+ scale = _ref.scale;
15144
+ return React__default.createElement(DraggableContainer, {
15145
+ title: title,
15146
+ type: exports.RPGUIContainerTypes.Framed,
15147
+ onCloseButton: function onCloseButton() {
15148
+ if (onClose) {
15149
+ onClose();
15150
+ }
15151
+ },
15152
+ width: "400px",
15153
+ cancelDrag: ".item-container-body, #shortcuts_list",
15154
+ onPositionChange: function onPositionChange(_ref2) {
15155
+ var x = _ref2.x,
15156
+ y = _ref2.y;
15157
+ if (_onPositionChange) {
15158
+ _onPositionChange({
15159
+ x: x,
15160
+ y: y
15161
+ });
15343
15162
  }
15344
- }
15345
- })), React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
15346
- src: textAndTypeArray[slide].imagePath || img$5
15347
- })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator, {
15348
- right: '10.5rem',
15349
- src: img$6
15350
- })), textAndTypeArray[slide].imageSide === 'left' && React__default.createElement(React__default.Fragment, null, React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
15351
- src: textAndTypeArray[slide].imagePath || img$5
15352
- })), React__default.createElement(TextContainer, {
15353
- flex: '70%'
15354
- }, React__default.createElement(NPCDialogText, {
15355
- onStartStep: function onStartStep() {
15356
- return setShowGoNextIndicator(false);
15357
15163
  },
15358
- onEndStep: function onEndStep() {
15359
- return setShowGoNextIndicator(true);
15164
+ onPositionChangeEnd: function onPositionChangeEnd(_ref3) {
15165
+ var x = _ref3.x,
15166
+ y = _ref3.y;
15167
+ if (_onPositionChangeEnd) {
15168
+ _onPositionChangeEnd({
15169
+ x: x,
15170
+ y: y
15171
+ });
15172
+ }
15360
15173
  },
15361
- text: textAndTypeArray[slide].text || 'No text provided.',
15362
- onClose: function onClose() {
15363
- if (_onClose) {
15364
- _onClose();
15174
+ onPositionChangeStart: function onPositionChangeStart(_ref4) {
15175
+ var x = _ref4.x,
15176
+ y = _ref4.y;
15177
+ if (_onPositionChangeStart) {
15178
+ _onPositionChangeStart({
15179
+ x: x,
15180
+ y: y
15181
+ });
15365
15182
  }
15366
- }
15367
- })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator, {
15368
- right: '1rem',
15369
- src: img$6
15370
- }))), ")"));
15183
+ },
15184
+ onOutsideClick: onOutsideClick,
15185
+ initialPosition: initialPosition,
15186
+ scale: scale
15187
+ }, children);
15371
15188
  };
15372
- var Container$g = /*#__PURE__*/styled.div.withConfig({
15373
- displayName: "NPCMultiDialog__Container",
15374
- componentId: "sc-rvu5wg-0"
15375
- })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
15376
- var TextContainer = /*#__PURE__*/styled.div.withConfig({
15377
- displayName: "NPCMultiDialog__TextContainer",
15378
- componentId: "sc-rvu5wg-1"
15379
- })(["flex:", " 0 0;width:355px;"], function (_ref2) {
15380
- var flex = _ref2.flex;
15381
- return flex;
15382
- });
15383
- var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
15384
- displayName: "NPCMultiDialog__ThumbnailContainer",
15385
- componentId: "sc-rvu5wg-2"
15386
- })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
15387
- var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
15388
- displayName: "NPCMultiDialog__NPCThumbnail",
15389
- componentId: "sc-rvu5wg-3"
15390
- })(["image-rendering:pixelated;height:128px;width:128px;"]);
15391
- var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
15392
- displayName: "NPCMultiDialog__PressSpaceIndicator",
15393
- componentId: "sc-rvu5wg-4"
15394
- })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref3) {
15395
- var right = _ref3.right;
15396
- return right;
15397
- });
15398
15189
 
15399
- //@ts-ignore
15400
- var useEventListener = function useEventListener(type, handler, el) {
15401
- if (el === void 0) {
15402
- el = window;
15403
- }
15404
- var savedHandler = React__default.useRef();
15405
- React__default.useEffect(function () {
15406
- savedHandler.current = handler;
15407
- }, [handler]);
15408
- React__default.useEffect(function () {
15409
- //@ts-ignore
15410
- var listener = function listener(e) {
15411
- return savedHandler.current(e);
15412
- };
15413
- el.addEventListener(type, listener);
15414
- return function () {
15415
- el.removeEventListener(type, listener);
15416
- };
15417
- }, [type, el]);
15190
+ (function (RangeSliderType) {
15191
+ RangeSliderType["Slider"] = "rpgui-slider";
15192
+ RangeSliderType["GoldSlider"] = "rpgui-slider golden";
15193
+ })(exports.RangeSliderType || (exports.RangeSliderType = {}));
15194
+ var RangeSlider = function RangeSlider(_ref) {
15195
+ var type = _ref.type,
15196
+ valueMin = _ref.valueMin,
15197
+ valueMax = _ref.valueMax,
15198
+ width = _ref.width,
15199
+ _onChange = _ref.onChange,
15200
+ value = _ref.value;
15201
+ var sliderId = uuid.v4();
15202
+ var containerRef = React.useRef(null);
15203
+ var _useState = React.useState(0),
15204
+ left = _useState[0],
15205
+ setLeft = _useState[1];
15206
+ React.useEffect(function () {
15207
+ var _containerRef$current;
15208
+ var calculatedWidth = ((_containerRef$current = containerRef.current) == null ? void 0 : _containerRef$current.clientWidth) || 0;
15209
+ setLeft(Math.max((value - valueMin) / (valueMax - valueMin) * (calculatedWidth - 35) + 10));
15210
+ }, [value, valueMin, valueMax]);
15211
+ var typeClass = type === exports.RangeSliderType.GoldSlider ? 'golden' : '';
15212
+ return React__default.createElement("div", {
15213
+ style: {
15214
+ width: width,
15215
+ position: 'relative'
15216
+ },
15217
+ className: "rpgui-slider-container " + typeClass,
15218
+ id: "rpgui-slider-" + sliderId,
15219
+ ref: containerRef
15220
+ }, React__default.createElement("div", {
15221
+ style: {
15222
+ pointerEvents: 'none'
15223
+ }
15224
+ }, React__default.createElement("div", {
15225
+ className: "rpgui-slider-track " + typeClass
15226
+ }), React__default.createElement("div", {
15227
+ className: "rpgui-slider-left-edge " + typeClass
15228
+ }), React__default.createElement("div", {
15229
+ className: "rpgui-slider-right-edge " + typeClass
15230
+ }), React__default.createElement("div", {
15231
+ className: "rpgui-slider-thumb " + typeClass,
15232
+ style: {
15233
+ left: left
15234
+ }
15235
+ })), React__default.createElement(Input$1, {
15236
+ type: "range",
15237
+ style: {
15238
+ width: width
15239
+ },
15240
+ min: valueMin,
15241
+ max: valueMax,
15242
+ onChange: function onChange(e) {
15243
+ return _onChange(Number(e.target.value));
15244
+ },
15245
+ value: value,
15246
+ className: "rpgui-cursor-point"
15247
+ }));
15418
15248
  };
15249
+ var Input$1 = /*#__PURE__*/styled.input.withConfig({
15250
+ displayName: "RangeSlider__Input",
15251
+ componentId: "sc-v8mte9-0"
15252
+ })(["opacity:0;position:absolute;width:100%;height:100%;top:0;left:0;margin-top:-5px;"]);
15419
15253
 
15420
- var DynamicText = function DynamicText(_ref) {
15421
- var text = _ref.text,
15422
- onFinish = _ref.onFinish,
15423
- onStart = _ref.onStart;
15424
- var _useState = React.useState(''),
15425
- textState = _useState[0],
15426
- setTextState = _useState[1];
15254
+ var ItemQuantitySelector = function ItemQuantitySelector(_ref) {
15255
+ var quantity = _ref.quantity,
15256
+ onConfirm = _ref.onConfirm,
15257
+ onClose = _ref.onClose;
15258
+ var _useState = React.useState(quantity),
15259
+ value = _useState[0],
15260
+ setValue = _useState[1];
15261
+ var inputRef = React.useRef(null);
15427
15262
  React.useEffect(function () {
15428
- var i = 0;
15429
- var interval = setInterval(function () {
15430
- // on every interval, show one more character
15431
- if (i === 0) {
15432
- if (onStart) {
15433
- onStart();
15263
+ if (inputRef.current) {
15264
+ inputRef.current.focus();
15265
+ inputRef.current.select();
15266
+ var closeSelector = function closeSelector(e) {
15267
+ if (e.key === 'Escape') {
15268
+ onClose();
15434
15269
  }
15270
+ };
15271
+ document.addEventListener('keydown', closeSelector);
15272
+ return function () {
15273
+ document.removeEventListener('keydown', closeSelector);
15274
+ };
15275
+ }
15276
+ return function () {};
15277
+ }, []);
15278
+ return React__default.createElement(StyledContainer, {
15279
+ type: exports.RPGUIContainerTypes.Framed,
15280
+ width: "25rem"
15281
+ }, React__default.createElement(CloseButton$2, {
15282
+ className: "container-close",
15283
+ onPointerDown: onClose
15284
+ }, "X"), React__default.createElement("h2", null, "Select quantity to move"), React__default.createElement(StyledForm, {
15285
+ style: {
15286
+ width: '100%'
15287
+ },
15288
+ onSubmit: function onSubmit(e) {
15289
+ e.preventDefault();
15290
+ var numberValue = Number(value);
15291
+ if (Number.isNaN(numberValue)) {
15292
+ return;
15435
15293
  }
15436
- if (i < text.length) {
15437
- setTextState(text.substring(0, i + 1));
15438
- i++;
15439
- } else {
15440
- clearInterval(interval);
15441
- if (onFinish) {
15442
- onFinish();
15294
+ onConfirm(Math.max(1, Math.min(quantity, numberValue)));
15295
+ },
15296
+ noValidate: true
15297
+ }, React__default.createElement(StyledInput, {
15298
+ innerRef: inputRef,
15299
+ placeholder: "Enter quantity",
15300
+ type: "number",
15301
+ min: 1,
15302
+ max: quantity,
15303
+ value: value,
15304
+ onChange: function onChange(e) {
15305
+ if (Number(e.target.value) >= quantity) {
15306
+ setValue(quantity);
15307
+ return;
15308
+ }
15309
+ setValue(e.target.value);
15310
+ },
15311
+ onBlur: function onBlur(e) {
15312
+ var newValue = Math.max(1, Math.min(quantity, Number(e.target.value)));
15313
+ setValue(newValue);
15314
+ }
15315
+ }), React__default.createElement(RangeSlider, {
15316
+ type: exports.RangeSliderType.Slider,
15317
+ valueMin: 1,
15318
+ valueMax: quantity,
15319
+ width: "100%",
15320
+ onChange: setValue,
15321
+ value: value
15322
+ }), React__default.createElement(Button, {
15323
+ buttonType: exports.ButtonTypes.RPGUIButton,
15324
+ type: "submit"
15325
+ }, "Confirm")));
15326
+ };
15327
+ var StyledContainer = /*#__PURE__*/styled(RPGUIContainer).withConfig({
15328
+ displayName: "ItemQuantitySelector__StyledContainer",
15329
+ componentId: "sc-yfdtpn-0"
15330
+ })(["display:flex;flex-direction:column;align-items:center;"]);
15331
+ var StyledForm = /*#__PURE__*/styled.form.withConfig({
15332
+ displayName: "ItemQuantitySelector__StyledForm",
15333
+ componentId: "sc-yfdtpn-1"
15334
+ })(["display:flex;flex-direction:column;align-items:center;width:100%;"]);
15335
+ var StyledInput = /*#__PURE__*/styled(Input).withConfig({
15336
+ displayName: "ItemQuantitySelector__StyledInput",
15337
+ componentId: "sc-yfdtpn-2"
15338
+ })(["text-align:center;&::-webkit-outer-spin-button,&::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}&[type='number']{-moz-appearance:textfield;}"]);
15339
+ var CloseButton$2 = /*#__PURE__*/styled.div.withConfig({
15340
+ displayName: "ItemQuantitySelector__CloseButton",
15341
+ componentId: "sc-yfdtpn-3"
15342
+ })(["position:absolute;top:3px;right:0px;color:white;z-index:22;font-size:0.8rem;"]);
15343
+
15344
+ var ShortcutsSetter = function ShortcutsSetter(_ref) {
15345
+ var setSettingShortcutIndex = _ref.setSettingShortcutIndex,
15346
+ settingShortcutIndex = _ref.settingShortcutIndex,
15347
+ shortcuts = _ref.shortcuts,
15348
+ removeShortcut = _ref.removeShortcut,
15349
+ atlasJSON = _ref.atlasJSON,
15350
+ atlasIMG = _ref.atlasIMG;
15351
+ var getContent = function getContent(index) {
15352
+ var _shortcuts$index, _shortcuts$index3;
15353
+ if (((_shortcuts$index = shortcuts[index]) == null ? void 0 : _shortcuts$index.type) === shared.ShortcutType.Item) {
15354
+ var _shortcuts$index2;
15355
+ var _payload = (_shortcuts$index2 = shortcuts[index]) == null ? void 0 : _shortcuts$index2.payload;
15356
+ if (!_payload) return null;
15357
+ return React__default.createElement(SpriteFromAtlas, {
15358
+ atlasIMG: atlasIMG,
15359
+ atlasJSON: atlasJSON,
15360
+ spriteKey: shared.getItemTextureKeyPath({
15361
+ key: _payload.texturePath,
15362
+ texturePath: _payload.texturePath,
15363
+ stackQty: _payload.stackQty || 1,
15364
+ isStackable: _payload.isStackable
15365
+ }, atlasJSON),
15366
+ width: 32,
15367
+ height: 32,
15368
+ imgScale: 1.6,
15369
+ imgStyle: {
15370
+ left: '5px'
15443
15371
  }
15444
- }
15445
- }, 50);
15446
- return function () {
15447
- clearInterval(interval);
15448
- };
15449
- }, [text]);
15450
- return React__default.createElement(TextContainer$1, null, textState);
15372
+ });
15373
+ }
15374
+ var payload = (_shortcuts$index3 = shortcuts[index]) == null ? void 0 : _shortcuts$index3.payload;
15375
+ return React__default.createElement("span", null, payload == null ? void 0 : payload.magicWords.split(' ').map(function (word) {
15376
+ return word[0];
15377
+ }));
15378
+ };
15379
+ return React__default.createElement(Container$i, null, React__default.createElement("p", null, "Shortcuts:"), React__default.createElement(List, {
15380
+ id: "shortcuts_list"
15381
+ }, Array.from({
15382
+ length: 6
15383
+ }).map(function (_, i) {
15384
+ return React__default.createElement(Shortcut, {
15385
+ key: i,
15386
+ onPointerDown: function onPointerDown() {
15387
+ if (settingShortcutIndex !== -1) setSettingShortcutIndex(-1);
15388
+ removeShortcut(i);
15389
+ if (settingShortcutIndex === -1 && (!shortcuts[i] || shortcuts[i].type === shared.ShortcutType.None)) setSettingShortcutIndex(i);
15390
+ },
15391
+ disabled: settingShortcutIndex !== -1 && settingShortcutIndex !== i,
15392
+ isBeingSet: settingShortcutIndex === i,
15393
+ id: "shortcutSetter_" + i
15394
+ }, getContent(i));
15395
+ })));
15451
15396
  };
15452
- var TextContainer$1 = /*#__PURE__*/styled.p.withConfig({
15453
- displayName: "DynamicText__TextContainer",
15454
- componentId: "sc-1ggl9nd-0"
15455
- })(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]);
15397
+ var Container$i = /*#__PURE__*/styled.div.withConfig({
15398
+ displayName: "ShortcutsSetter__Container",
15399
+ componentId: "sc-xuouuf-0"
15400
+ })(["p{margin:0;margin-left:0.5rem;}"]);
15401
+ var Shortcut = /*#__PURE__*/styled.button.withConfig({
15402
+ displayName: "ShortcutsSetter__Shortcut",
15403
+ componentId: "sc-xuouuf-1"
15404
+ })(["width:2.6rem;height:2.6rem;background-color:", ";border:2px solid ", ";border-radius:50%;text-transform:uppercase;font-size:0.7rem;font-weight:bold;display:flex;align-items:center;justify-content:center;span{margin-top:4px;}&:hover,&:focus{background-color:", ";}&:active{background-color:", ";}&:disabled{opacity:0.5;}"], uiColors.lightGray, function (_ref2) {
15405
+ var isBeingSet = _ref2.isBeingSet;
15406
+ return isBeingSet ? uiColors.yellow : uiColors.darkGray;
15407
+ }, uiColors.darkGray, uiColors.gray);
15408
+ var List = /*#__PURE__*/styled.div.withConfig({
15409
+ displayName: "ShortcutsSetter__List",
15410
+ componentId: "sc-xuouuf-2"
15411
+ })(["width:100%;display:flex;align-items:center;gap:0.5rem;padding-bottom:0.5rem;padding-left:0.5rem;box-sizing:border-box;margin:0 !important;"]);
15456
15412
 
15457
- var QuestionDialog = function QuestionDialog(_ref) {
15458
- var questions = _ref.questions,
15459
- answers = _ref.answers,
15460
- onClose = _ref.onClose;
15461
- var _useState = React.useState(questions[0]),
15462
- currentQuestion = _useState[0],
15463
- setCurrentQuestion = _useState[1];
15464
- var _useState2 = React.useState(false),
15465
- canShowAnswers = _useState2[0],
15466
- setCanShowAnswers = _useState2[1];
15467
- var onGetFirstAnswer = function onGetFirstAnswer() {
15468
- if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {
15469
- return null;
15413
+ var ItemContainer$1 = function ItemContainer(_ref) {
15414
+ var itemContainer = _ref.itemContainer,
15415
+ onClose = _ref.onClose,
15416
+ _onMouseOver = _ref.onMouseOver,
15417
+ _onSelected = _ref.onSelected,
15418
+ onItemClick = _ref.onItemClick,
15419
+ type = _ref.type,
15420
+ atlasJSON = _ref.atlasJSON,
15421
+ atlasIMG = _ref.atlasIMG,
15422
+ _ref$disableContextMe = _ref.disableContextMenu,
15423
+ disableContextMenu = _ref$disableContextMe === void 0 ? false : _ref$disableContextMe,
15424
+ onItemDragEnd = _ref.onItemDragEnd,
15425
+ onItemDragStart = _ref.onItemDragStart,
15426
+ onItemPlaceDrop = _ref.onItemPlaceDrop,
15427
+ _onOutsideDrop = _ref.onOutsideDrop,
15428
+ checkIfItemCanBeMoved = _ref.checkIfItemCanBeMoved,
15429
+ initialPosition = _ref.initialPosition,
15430
+ checkIfItemShouldDragEnd = _ref.checkIfItemShouldDragEnd,
15431
+ scale = _ref.scale,
15432
+ shortcuts = _ref.shortcuts,
15433
+ setItemShortcut = _ref.setItemShortcut,
15434
+ removeShortcut = _ref.removeShortcut,
15435
+ equipmentSet = _ref.equipmentSet,
15436
+ isDepotSystem = _ref.isDepotSystem,
15437
+ onPositionChangeEnd = _ref.onPositionChangeEnd,
15438
+ onPositionChangeStart = _ref.onPositionChangeStart;
15439
+ var _useState = React.useState({
15440
+ isOpen: false,
15441
+ maxQuantity: 1,
15442
+ callback: function callback(_quantity) {}
15443
+ }),
15444
+ quantitySelect = _useState[0],
15445
+ setQuantitySelect = _useState[1];
15446
+ var _useState2 = React.useState(-1),
15447
+ settingShortcutIndex = _useState2[0],
15448
+ setSettingShortcutIndex = _useState2[1];
15449
+ var handleSetShortcut = function handleSetShortcut(item, index) {
15450
+ if (item.type === shared.ItemType.Consumable || item.type === shared.ItemType.Tool) {
15451
+ setItemShortcut == null ? void 0 : setItemShortcut(item.key, index);
15470
15452
  }
15471
- var firstAnswerId = currentQuestion.answerIds[0];
15472
- return answers.find(function (answer) {
15473
- return answer.id === firstAnswerId;
15474
- });
15475
15453
  };
15476
- var _useState3 = React.useState(onGetFirstAnswer()),
15477
- currentAnswer = _useState3[0],
15478
- setCurrentAnswer = _useState3[1];
15479
- React.useEffect(function () {
15480
- setCurrentAnswer(onGetFirstAnswer());
15481
- }, [currentQuestion]);
15482
- var onGetAnswers = function onGetAnswers(answerIds) {
15483
- return answerIds.map(function (answerId) {
15484
- return answers.find(function (answer) {
15485
- return answer.id === answerId;
15486
- });
15487
- });
15454
+ var onRenderSlots = function onRenderSlots() {
15455
+ var slots = [];
15456
+ for (var i = 0; i < itemContainer.slotQty; i++) {
15457
+ var _itemContainer$slots;
15458
+ slots.push(React__default.createElement(ItemSlot, {
15459
+ isContextMenuDisabled: disableContextMenu,
15460
+ key: i,
15461
+ slotIndex: i,
15462
+ item: ((_itemContainer$slots = itemContainer.slots) == null ? void 0 : _itemContainer$slots[i]) || null,
15463
+ itemContainerType: type,
15464
+ onMouseOver: function onMouseOver(event, slotIndex, item) {
15465
+ if (_onMouseOver) _onMouseOver(event, slotIndex, item);
15466
+ },
15467
+ onPointerDown: function onPointerDown(itemType, containerType, item) {
15468
+ if (settingShortcutIndex !== -1) {
15469
+ setSettingShortcutIndex(-1);
15470
+ handleSetShortcut(item, settingShortcutIndex);
15471
+ } else if (onItemClick) onItemClick(item, itemType, containerType);
15472
+ },
15473
+ onSelected: function onSelected(optionId, item) {
15474
+ if (_onSelected) _onSelected(optionId, item);
15475
+ },
15476
+ onDragStart: function onDragStart(item, slotIndex, itemContainerType) {
15477
+ if (onItemDragStart) onItemDragStart(item, slotIndex, itemContainerType);
15478
+ },
15479
+ onDragEnd: function onDragEnd(quantity) {
15480
+ if (onItemDragEnd) onItemDragEnd(quantity);
15481
+ },
15482
+ dragScale: scale,
15483
+ checkIfItemCanBeMoved: checkIfItemCanBeMoved,
15484
+ checkIfItemShouldDragEnd: checkIfItemShouldDragEnd,
15485
+ openQuantitySelector: function openQuantitySelector(maxQuantity, callback) {
15486
+ setQuantitySelect({
15487
+ isOpen: true,
15488
+ maxQuantity: maxQuantity,
15489
+ callback: callback
15490
+ });
15491
+ },
15492
+ onPlaceDrop: function onPlaceDrop(item, slotIndex, itemContainerType) {
15493
+ if (onItemPlaceDrop) onItemPlaceDrop(item, slotIndex, itemContainerType);
15494
+ },
15495
+ onOutsideDrop: function onOutsideDrop(item, position) {
15496
+ if (_onOutsideDrop) _onOutsideDrop(item, position);
15497
+ },
15498
+ atlasIMG: atlasIMG,
15499
+ atlasJSON: atlasJSON,
15500
+ isSelectingShortcut: settingShortcutIndex !== -1,
15501
+ equipmentSet: equipmentSet,
15502
+ setItemShortcut: type === shared.ItemContainerType.Inventory ? handleSetShortcut : undefined,
15503
+ isDepotSystem: isDepotSystem
15504
+ }));
15505
+ }
15506
+ return slots;
15488
15507
  };
15489
- var onKeyPress = function onKeyPress(e) {
15490
- switch (e.key) {
15491
- case 'ArrowDown':
15492
- // select next answer, if any.
15493
- // if no next answer, select first answer
15494
- // const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(
15495
- // (answer) => answer?.id === currentAnswer!.id + 1
15496
- // );
15497
- var nextAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
15498
- return (answer == null ? void 0 : answer.id) === currentAnswer.id + 1;
15499
- });
15500
- var nextAnswerID = currentQuestion.answerIds[nextAnswerIndex];
15501
- var nextAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
15502
- return (answer == null ? void 0 : answer.id) === nextAnswerID;
15503
- });
15504
- setCurrentAnswer(nextAnswer || onGetFirstAnswer());
15505
- break;
15506
- case 'ArrowUp':
15507
- // select previous answer, if any.
15508
- // if no previous answer, select last answer
15509
- var previousAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
15510
- return (answer == null ? void 0 : answer.id) === currentAnswer.id - 1;
15511
- });
15512
- var previousAnswerID = currentQuestion.answerIds && currentQuestion.answerIds[previousAnswerIndex];
15513
- var previousAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
15514
- return (answer == null ? void 0 : answer.id) === previousAnswerID;
15515
- });
15516
- if (previousAnswer) {
15517
- setCurrentAnswer(previousAnswer);
15518
- } else {
15519
- setCurrentAnswer(onGetAnswers(currentQuestion.answerIds).pop());
15520
- }
15521
- break;
15522
- case 'Enter':
15523
- setCanShowAnswers(false);
15524
- if (!(currentAnswer != null && currentAnswer.nextQuestionId)) {
15525
- onClose();
15526
- return;
15527
- } else {
15528
- setCurrentQuestion(questions.find(function (question) {
15529
- return question.id === currentAnswer.nextQuestionId;
15530
- }));
15531
- }
15532
- break;
15508
+ return React__default.createElement(React__default.Fragment, null, React__default.createElement(SlotsContainer, {
15509
+ title: itemContainer.name || 'Container',
15510
+ onClose: onClose,
15511
+ initialPosition: initialPosition,
15512
+ scale: scale,
15513
+ onPositionChangeEnd: onPositionChangeEnd,
15514
+ onPositionChangeStart: onPositionChangeStart
15515
+ }, type === shared.ItemContainerType.Inventory && shortcuts && removeShortcut && React__default.createElement(ShortcutsSetter, {
15516
+ setSettingShortcutIndex: setSettingShortcutIndex,
15517
+ settingShortcutIndex: settingShortcutIndex,
15518
+ shortcuts: shortcuts,
15519
+ removeShortcut: removeShortcut,
15520
+ atlasIMG: atlasIMG,
15521
+ atlasJSON: atlasJSON
15522
+ }), React__default.createElement(ItemsContainer, {
15523
+ className: "item-container-body"
15524
+ }, onRenderSlots())), quantitySelect.isOpen && React__default.createElement(ModalPortal, null, React__default.createElement(QuantitySelectorContainer, null, React__default.createElement(ItemQuantitySelector, {
15525
+ quantity: quantitySelect.maxQuantity,
15526
+ onConfirm: function onConfirm(quantity) {
15527
+ quantitySelect.callback(quantity);
15528
+ setQuantitySelect({
15529
+ isOpen: false,
15530
+ maxQuantity: 1,
15531
+ callback: function callback() {}
15532
+ });
15533
+ },
15534
+ onClose: function onClose() {
15535
+ quantitySelect.callback(-1);
15536
+ setQuantitySelect({
15537
+ isOpen: false,
15538
+ maxQuantity: 1,
15539
+ callback: function callback() {}
15540
+ });
15533
15541
  }
15542
+ }))));
15543
+ };
15544
+ var ItemsContainer = /*#__PURE__*/styled.div.withConfig({
15545
+ displayName: "ItemContainer__ItemsContainer",
15546
+ componentId: "sc-15y5p9l-0"
15547
+ })(["display:flex;justify-content:center;flex-wrap:wrap;"]);
15548
+ var QuantitySelectorContainer = /*#__PURE__*/styled.div.withConfig({
15549
+ displayName: "ItemContainer__QuantitySelectorContainer",
15550
+ componentId: "sc-15y5p9l-1"
15551
+ })(["position:absolute;top:0;left:0;width:100vw;height:100vh;z-index:100;display:flex;justify-content:center;align-items:center;background-color:rgba(0,0,0,0.5);"]);
15552
+
15553
+ var ItemSelector = function ItemSelector(_ref) {
15554
+ var atlasIMG = _ref.atlasIMG,
15555
+ atlasJSON = _ref.atlasJSON,
15556
+ options = _ref.options,
15557
+ onClose = _ref.onClose,
15558
+ onSelect = _ref.onSelect;
15559
+ var _useState = React.useState(),
15560
+ selectedValue = _useState[0],
15561
+ setSelectedValue = _useState[1];
15562
+ var handleClick = function handleClick() {
15563
+ var element = document.querySelector("input[name='test']:checked");
15564
+ var elementValue = element.value;
15565
+ setSelectedValue(elementValue);
15534
15566
  };
15535
- useEventListener('keydown', onKeyPress);
15536
- var onAnswerClick = function onAnswerClick(answer) {
15537
- setCanShowAnswers(false);
15538
- if (answer.nextQuestionId) {
15539
- // if there is a next question, go to it
15540
- setCurrentQuestion(questions.find(function (question) {
15541
- return question.id === answer.nextQuestionId;
15542
- }));
15543
- } else {
15544
- // else, finish dialog!
15545
- onClose();
15567
+ React.useEffect(function () {
15568
+ if (selectedValue) {
15569
+ onSelect(selectedValue);
15546
15570
  }
15547
- };
15548
- var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
15549
- var answerIds = currentQuestion.answerIds;
15550
- if (!answerIds) {
15551
- return null;
15571
+ }, [selectedValue]);
15572
+ return React__default.createElement(DraggableContainer, {
15573
+ type: exports.RPGUIContainerTypes.Framed,
15574
+ width: "500px",
15575
+ cancelDrag: ".equipment-container-body .arrow-selector",
15576
+ onCloseButton: function onCloseButton() {
15577
+ if (onClose) {
15578
+ onClose();
15579
+ }
15552
15580
  }
15553
- var answers = onGetAnswers(answerIds);
15554
- if (!answers) {
15555
- return null;
15581
+ }, React__default.createElement("div", {
15582
+ style: {
15583
+ width: '100%'
15556
15584
  }
15557
- return answers.map(function (answer) {
15558
- var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
15559
- var selectedColor = isSelected ? 'yellow' : 'white';
15560
- if (answer) {
15561
- return React__default.createElement(AnswerRow, {
15562
- key: "answer_" + answer.id
15563
- }, React__default.createElement(AnswerSelectedIcon, {
15564
- color: selectedColor
15565
- }, isSelected ? 'X' : null), React__default.createElement(Answer, {
15566
- key: answer.id,
15567
- onPointerDown: function onPointerDown() {
15568
- return onAnswerClick(answer);
15569
- },
15570
- color: selectedColor
15571
- }, answer.text));
15585
+ }, React__default.createElement(Title$3, null, 'Harvesting instruments'), React__default.createElement(Subtitle$1, null, 'Use the tool, you need it'), React__default.createElement("hr", {
15586
+ className: "golden"
15587
+ })), React__default.createElement(RadioInputScroller$1, null, options == null ? void 0 : options.map(function (option, index) {
15588
+ return React__default.createElement(RadioOptionsWrapper$1, {
15589
+ key: index
15590
+ }, React__default.createElement(SpriteAtlasWrapper$1, null, React__default.createElement(SpriteFromAtlas, {
15591
+ atlasIMG: atlasIMG,
15592
+ atlasJSON: atlasJSON,
15593
+ spriteKey: option.imageKey,
15594
+ imgScale: 3
15595
+ })), React__default.createElement("div", null, React__default.createElement("input", {
15596
+ className: "rpgui-radio",
15597
+ type: "radio",
15598
+ value: option.name,
15599
+ name: "test"
15600
+ }), React__default.createElement("label", {
15601
+ onPointerDown: handleClick,
15602
+ style: {
15603
+ display: 'flex',
15604
+ alignItems: 'center'
15572
15605
  }
15573
- return null;
15574
- });
15575
- };
15576
- return React__default.createElement(Container$h, null, React__default.createElement(QuestionContainer, null, React__default.createElement(DynamicText, {
15577
- text: currentQuestion.text,
15578
- onStart: function onStart() {
15579
- return setCanShowAnswers(false);
15606
+ }, option.name, " ", React__default.createElement("br", null), option.description)));
15607
+ })), React__default.createElement(ButtonWrapper$1, null, React__default.createElement(Button, {
15608
+ buttonType: exports.ButtonTypes.RPGUIButton,
15609
+ onPointerDown: onClose
15610
+ }, "Cancel"), React__default.createElement(Button, {
15611
+ buttonType: exports.ButtonTypes.RPGUIButton
15612
+ }, "Select")));
15613
+ };
15614
+ var Title$3 = /*#__PURE__*/styled.h1.withConfig({
15615
+ displayName: "ItemSelector__Title",
15616
+ componentId: "sc-gptoxp-0"
15617
+ })(["font-size:0.6rem;color:yellow !important;"]);
15618
+ var Subtitle$1 = /*#__PURE__*/styled.h1.withConfig({
15619
+ displayName: "ItemSelector__Subtitle",
15620
+ componentId: "sc-gptoxp-1"
15621
+ })(["font-size:0.4rem;color:yellow !important;"]);
15622
+ var RadioInputScroller$1 = /*#__PURE__*/styled.div.withConfig({
15623
+ displayName: "ItemSelector__RadioInputScroller",
15624
+ componentId: "sc-gptoxp-2"
15625
+ })(["padding-left:15px;padding-top:10px;width:100%;margin-top:1rem;align-items:center;margin-left:20px;align-items:flex-start;overflow-y:scroll;height:360px;"]);
15626
+ var SpriteAtlasWrapper$1 = /*#__PURE__*/styled.div.withConfig({
15627
+ displayName: "ItemSelector__SpriteAtlasWrapper",
15628
+ componentId: "sc-gptoxp-3"
15629
+ })(["margin-right:40px;"]);
15630
+ var RadioOptionsWrapper$1 = /*#__PURE__*/styled.div.withConfig({
15631
+ displayName: "ItemSelector__RadioOptionsWrapper",
15632
+ componentId: "sc-gptoxp-4"
15633
+ })(["display:flex;align-items:stretch;margin-bottom:40px;"]);
15634
+ var ButtonWrapper$1 = /*#__PURE__*/styled.div.withConfig({
15635
+ displayName: "ItemSelector__ButtonWrapper",
15636
+ componentId: "sc-gptoxp-5"
15637
+ })(["display:flex;justify-content:space-around;padding-top:20px;width:100%;"]);
15638
+
15639
+ var ListMenu = function ListMenu(_ref) {
15640
+ var options = _ref.options,
15641
+ onSelected = _ref.onSelected,
15642
+ x = _ref.x,
15643
+ y = _ref.y;
15644
+ return React__default.createElement(Container$j, {
15645
+ x: x,
15646
+ y: y
15647
+ }, React__default.createElement("ul", {
15648
+ className: "rpgui-list-imp",
15649
+ style: {
15650
+ overflow: 'hidden'
15651
+ }
15652
+ }, options.map(function (params, index) {
15653
+ return React__default.createElement(ListElement$1, {
15654
+ key: (params == null ? void 0 : params.id) || index,
15655
+ onPointerDown: function onPointerDown() {
15656
+ onSelected(params == null ? void 0 : params.id);
15657
+ }
15658
+ }, (params == null ? void 0 : params.text) || 'No text');
15659
+ })));
15660
+ };
15661
+ var Container$j = /*#__PURE__*/styled.div.withConfig({
15662
+ displayName: "ListMenu__Container",
15663
+ componentId: "sc-i9097t-0"
15664
+ })(["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) {
15665
+ return props.y || 0;
15666
+ }, function (props) {
15667
+ return props.x || 0;
15668
+ }, uiFonts.size.xsmall);
15669
+ var ListElement$1 = /*#__PURE__*/styled.li.withConfig({
15670
+ displayName: "ListMenu__ListElement",
15671
+ componentId: "sc-i9097t-1"
15672
+ })(["margin-right:0.5rem;"]);
15673
+
15674
+ var MarketplaceRows = function MarketplaceRows(_ref) {
15675
+ var atlasJSON = _ref.atlasJSON,
15676
+ atlasIMG = _ref.atlasIMG,
15677
+ item = _ref.item,
15678
+ itemPrice = _ref.itemPrice,
15679
+ equipmentSet = _ref.equipmentSet,
15680
+ scale = _ref.scale,
15681
+ onHandleClick = _ref.onHandleClick;
15682
+ return React__default.createElement(MarketPlaceWrapper, null, React__default.createElement(ItemIconContainer, null, React__default.createElement(SpriteContainer, null, React__default.createElement(ItemInfoWrapper, {
15683
+ item: item,
15684
+ atlasIMG: atlasIMG,
15685
+ atlasJSON: atlasJSON,
15686
+ equipmentSet: equipmentSet,
15687
+ scale: scale
15688
+ }, React__default.createElement(SpriteFromAtlas, {
15689
+ atlasIMG: atlasIMG,
15690
+ atlasJSON: atlasJSON,
15691
+ spriteKey: shared.getItemTextureKeyPath({
15692
+ key: item.key,
15693
+ stackQty: item.stackQty || 1,
15694
+ texturePath: item.texturePath,
15695
+ isStackable: item.isStackable
15696
+ }, atlasJSON),
15697
+ imgScale: 2
15698
+ }))), React__default.createElement(PriceValue, null, React__default.createElement("p", null, React__default.createElement(Ellipsis, {
15699
+ maxLines: 1,
15700
+ maxWidth: "150px",
15701
+ fontSize: "10px"
15702
+ }, item.name)))), React__default.createElement(QuantityContainer, null, React__default.createElement(QuantityDisplay, null, React__default.createElement(TextOverlay$1, null, React__default.createElement(Item$1, null, React__default.createElement(Ellipsis, {
15703
+ maxLines: 1,
15704
+ maxWidth: "150px",
15705
+ fontSize: "10px"
15706
+ }, item.rarity))))), React__default.createElement(ItemIconContainer, null, React__default.createElement(SpriteContainer, null, React__default.createElement(SpriteFromAtlas, {
15707
+ atlasIMG: atlasIMG,
15708
+ atlasJSON: atlasJSON,
15709
+ spriteKey: 'others/gold-coin-qty-4.png',
15710
+ imgScale: 2
15711
+ })), React__default.createElement(PriceValue, null, React__default.createElement("p", null, React__default.createElement(Ellipsis, {
15712
+ maxLines: 1,
15713
+ maxWidth: "150px",
15714
+ fontSize: "10px"
15715
+ }, "$", itemPrice)))), React__default.createElement(ButtonContainer$1, null, React__default.createElement(Button, {
15716
+ buttonType: exports.ButtonTypes.RPGUIButton,
15717
+ onClick: function onClick() {
15718
+ return onHandleClick(item.name);
15719
+ }
15720
+ }, "Buy")));
15721
+ };
15722
+ var MarketPlaceWrapper = /*#__PURE__*/styled.div.withConfig({
15723
+ displayName: "MarketplaceRows__MarketPlaceWrapper",
15724
+ componentId: "sc-wmpr1o-0"
15725
+ })(["margin:auto;display:grid;grid-template-columns:35% 20% 20% 25%;&:hover{background-color:", ";}padding:0.5rem;p{font-size:0.8rem;}"], uiColors.darkGray);
15726
+ var ItemIconContainer = /*#__PURE__*/styled.div.withConfig({
15727
+ displayName: "MarketplaceRows__ItemIconContainer",
15728
+ componentId: "sc-wmpr1o-1"
15729
+ })(["display:flex;justify-content:flex-start;align-items:center;"]);
15730
+ var SpriteContainer = /*#__PURE__*/styled.div.withConfig({
15731
+ displayName: "MarketplaceRows__SpriteContainer",
15732
+ componentId: "sc-wmpr1o-2"
15733
+ })(["position:relative;top:-0.5rem;left:0.5rem;"]);
15734
+ var Item$1 = /*#__PURE__*/styled.span.withConfig({
15735
+ displayName: "MarketplaceRows__Item",
15736
+ componentId: "sc-wmpr1o-3"
15737
+ })(["color:white;text-align:center;z-index:1;width:100%;"]);
15738
+ var TextOverlay$1 = /*#__PURE__*/styled.div.withConfig({
15739
+ displayName: "MarketplaceRows__TextOverlay",
15740
+ componentId: "sc-wmpr1o-4"
15741
+ })(["width:100%;position:relative;"]);
15742
+ var QuantityContainer = /*#__PURE__*/styled.div.withConfig({
15743
+ displayName: "MarketplaceRows__QuantityContainer",
15744
+ componentId: "sc-wmpr1o-5"
15745
+ })(["position:relative;display:flex;min-width:100px;justify-content:center;align-items:center;"]);
15746
+ var QuantityDisplay = /*#__PURE__*/styled.div.withConfig({
15747
+ displayName: "MarketplaceRows__QuantityDisplay",
15748
+ componentId: "sc-wmpr1o-6"
15749
+ })(["font-size:", ";"], uiFonts.size.small);
15750
+ var PriceValue = /*#__PURE__*/styled.div.withConfig({
15751
+ displayName: "MarketplaceRows__PriceValue",
15752
+ componentId: "sc-wmpr1o-7"
15753
+ })(["margin-left:40px;"]);
15754
+ var ButtonContainer$1 = /*#__PURE__*/styled.div.withConfig({
15755
+ displayName: "MarketplaceRows__ButtonContainer",
15756
+ componentId: "sc-wmpr1o-8"
15757
+ })(["margin:auto;"]);
15758
+
15759
+ var Marketplace = function Marketplace(_ref) {
15760
+ var items = _ref.items,
15761
+ atlasIMG = _ref.atlasIMG,
15762
+ atlasJSON = _ref.atlasJSON,
15763
+ onClose = _ref.onClose,
15764
+ optionsType = _ref.optionsType,
15765
+ optionsRarity = _ref.optionsRarity,
15766
+ optionsPrice = _ref.optionsPrice,
15767
+ onChangeType = _ref.onChangeType,
15768
+ onChangeRarity = _ref.onChangeRarity,
15769
+ onChangeOrder = _ref.onChangeOrder,
15770
+ onChangeNameInput = _ref.onChangeNameInput,
15771
+ scale = _ref.scale,
15772
+ equipmentSet = _ref.equipmentSet,
15773
+ onHandleClick = _ref.onHandleClick;
15774
+ return React__default.createElement(DraggableContainer, {
15775
+ type: exports.RPGUIContainerTypes.Framed,
15776
+ onCloseButton: function onCloseButton() {
15777
+ if (onClose) onClose();
15580
15778
  },
15581
- onFinish: function onFinish() {
15582
- return setCanShowAnswers(true);
15583
- }
15584
- })), canShowAnswers && React__default.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
15779
+ width: "800px",
15780
+ cancelDrag: "#MarketContainer",
15781
+ scale: scale
15782
+ }, React__default.createElement(React__default.Fragment, null, React__default.createElement(InputWrapper, null, React__default.createElement("p", null, " Search By Name"), React__default.createElement(Input, {
15783
+ onChange: onChangeNameInput,
15784
+ placeholder: 'Search...'
15785
+ })), React__default.createElement(WrapperContainer, null, React__default.createElement(StyledDropdown, {
15786
+ options: optionsType,
15787
+ onChange: onChangeType,
15788
+ width: '220px'
15789
+ }), React__default.createElement(StyledDropdown, {
15790
+ options: optionsRarity,
15791
+ onChange: onChangeRarity,
15792
+ width: '220px'
15793
+ }), React__default.createElement(StyledDropdown, {
15794
+ options: optionsPrice,
15795
+ onChange: onChangeOrder,
15796
+ width: '220px'
15797
+ })), React__default.createElement(ItemComponentScrollWrapper, {
15798
+ id: "MarketContainer"
15799
+ }, items == null ? void 0 : items.map(function (item, index) {
15800
+ return React__default.createElement(MarketplaceRows, {
15801
+ key: item.key + "_" + index,
15802
+ atlasIMG: atlasIMG,
15803
+ atlasJSON: atlasJSON,
15804
+ item: item,
15805
+ itemPrice: 10,
15806
+ equipmentSet: equipmentSet,
15807
+ onHandleClick: onHandleClick
15808
+ });
15809
+ }))));
15585
15810
  };
15586
- var Container$h = /*#__PURE__*/styled.div.withConfig({
15587
- displayName: "QuestionDialog__Container",
15588
- componentId: "sc-bxc5u0-0"
15589
- })(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
15590
- var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
15591
- displayName: "QuestionDialog__QuestionContainer",
15592
- componentId: "sc-bxc5u0-1"
15593
- })(["flex:100%;width:100%;"]);
15594
- var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
15595
- displayName: "QuestionDialog__AnswersContainer",
15596
- componentId: "sc-bxc5u0-2"
15597
- })(["flex:100%;"]);
15598
- var Answer = /*#__PURE__*/styled.p.withConfig({
15599
- displayName: "QuestionDialog__Answer",
15600
- componentId: "sc-bxc5u0-3"
15601
- })(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
15602
- return props.color;
15603
- });
15604
- var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
15605
- displayName: "QuestionDialog__AnswerSelectedIcon",
15606
- componentId: "sc-bxc5u0-4"
15607
- })(["flex:5% 0 0;color:", " !important;"], function (props) {
15608
- return props.color;
15609
- });
15610
- var AnswerRow = /*#__PURE__*/styled.div.withConfig({
15611
- displayName: "QuestionDialog__AnswerRow",
15612
- componentId: "sc-bxc5u0-5"
15613
- })(["display:flex;flex-wrap:wrap;justify-content:center;align-items:center;margin-bottom:0.5rem;height:22px;p{line-height:unset;margin-top:0;margin-bottom:0rem;}"]);
15811
+ var InputWrapper = /*#__PURE__*/styled.div.withConfig({
15812
+ displayName: "Marketplace__InputWrapper",
15813
+ componentId: "sc-h904b1-0"
15814
+ })(["width:95%;display:flex;justify-content:flex-start;align-items:center;margin:auto;margin-bottom:10px;p{width:auto;margin-right:20px;}input{width:68%;height:10px;}"]);
15815
+ var WrapperContainer = /*#__PURE__*/styled.div.withConfig({
15816
+ displayName: "Marketplace__WrapperContainer",
15817
+ componentId: "sc-h904b1-1"
15818
+ })(["display:grid;grid-template-columns:30% 30% 30%;justify-content:space-between;width:90%;margin-left:10px;.rpgui-content .rpgui-dropdown-imp-header{padding:0px 10px 0 !important;}"]);
15819
+ var ItemComponentScrollWrapper = /*#__PURE__*/styled.div.withConfig({
15820
+ displayName: "Marketplace__ItemComponentScrollWrapper",
15821
+ componentId: "sc-h904b1-2"
15822
+ })(["overflow-y:scroll;height:390px;width:100%;margin-top:1rem;"]);
15823
+ var StyledDropdown = /*#__PURE__*/styled(Dropdown).withConfig({
15824
+ displayName: "Marketplace__StyledDropdown",
15825
+ componentId: "sc-h904b1-3"
15826
+ })(["margin:3px !important;width:170px !important;"]);
15614
15827
 
15615
15828
  var ProgressBar = function ProgressBar(_ref) {
15616
15829
  var max = _ref.max,
@@ -15623,13 +15836,15 @@ var ProgressBar = function ProgressBar(_ref) {
15623
15836
  _ref$minWidth = _ref.minWidth,
15624
15837
  minWidth = _ref$minWidth === void 0 ? 100 : _ref$minWidth,
15625
15838
  style = _ref.style;
15839
+ value = Math.round(value);
15840
+ max = Math.round(max);
15626
15841
  var calculatePercentageValue = function calculatePercentageValue(max, value) {
15627
15842
  if (value > max) {
15628
15843
  value = max;
15629
15844
  }
15630
15845
  return value * 100 / max;
15631
15846
  };
15632
- return React__default.createElement(Container$i, {
15847
+ return React__default.createElement(Container$k, {
15633
15848
  className: "rpgui-progress",
15634
15849
  "data-value": calculatePercentageValue(max, value) / 100,
15635
15850
  "data-rpguitype": "progress",
@@ -15658,7 +15873,7 @@ var TextOverlay$2 = /*#__PURE__*/styled.div.withConfig({
15658
15873
  displayName: "ProgressBar__TextOverlay",
15659
15874
  componentId: "sc-qa6fzh-1"
15660
15875
  })(["width:100%;position:relative;"]);
15661
- var Container$i = /*#__PURE__*/styled.div.withConfig({
15876
+ var Container$k = /*#__PURE__*/styled.div.withConfig({
15662
15877
  displayName: "ProgressBar__Container",
15663
15878
  componentId: "sc-qa6fzh-2"
15664
15879
  })(["display:flex;flex-direction:column;min-width:", "px;width:", "%;justify-content:start;align-items:flex-start;", ""], function (props) {
@@ -15669,7 +15884,7 @@ var Container$i = /*#__PURE__*/styled.div.withConfig({
15669
15884
  return props.style;
15670
15885
  });
15671
15886
 
15672
- var img$7 = '';
15887
+ var img$8 = '';
15673
15888
 
15674
15889
  var QuestInfo = function QuestInfo(_ref) {
15675
15890
  var quests = _ref.quests,
@@ -15713,7 +15928,7 @@ var QuestInfo = function QuestInfo(_ref) {
15713
15928
  }), React__default.createElement(QuestContainer, null, React__default.createElement(TitleContainer$1, {
15714
15929
  className: "drag-handler"
15715
15930
  }, React__default.createElement(Title$4, null, React__default.createElement(Thumbnail, {
15716
- src: quests[currentIndex].thumbnail || img$7
15931
+ src: quests[currentIndex].thumbnail || img$8
15717
15932
  }), quests[currentIndex].title), React__default.createElement(QuestSplitDiv, null, React__default.createElement("hr", {
15718
15933
  className: "golden"
15719
15934
  }))), React__default.createElement(Content, null, React__default.createElement("p", null, quests[currentIndex].description)), React__default.createElement(QuestColumn, {
@@ -15732,7 +15947,7 @@ var QuestInfo = function QuestInfo(_ref) {
15732
15947
  })))) : React__default.createElement(QuestsContainer, null, React__default.createElement(QuestContainer, null, React__default.createElement(TitleContainer$1, {
15733
15948
  className: "drag-handler"
15734
15949
  }, React__default.createElement(Title$4, null, React__default.createElement(Thumbnail, {
15735
- src: quests[0].thumbnail || img$7
15950
+ src: quests[0].thumbnail || img$8
15736
15951
  }), quests[0].title), React__default.createElement(QuestSplitDiv, null, React__default.createElement("hr", {
15737
15952
  className: "golden"
15738
15953
  }))), React__default.createElement(Content, null, React__default.createElement("p", null, quests[0].description)), React__default.createElement(QuestColumn, {
@@ -15918,7 +16133,7 @@ var Shortcuts = function Shortcuts(_ref) {
15918
16133
  return classBase + " " + (isOnCooldown ? 'onCooldown' : '');
15919
16134
  };
15920
16135
  var isOnShortcutCooldown = shortcutCooldown > 0;
15921
- if (((_shortcuts$i = shortcuts[i]) == null ? void 0 : _shortcuts$i.type) === shared.ShortcutType.Item) {
16136
+ if (shortcuts && ((_shortcuts$i = shortcuts[i]) == null ? void 0 : _shortcuts$i.type) === shared.ShortcutType.Item) {
15922
16137
  var _shortcuts$i2;
15923
16138
  var _payload = (_shortcuts$i2 = shortcuts[i]) == null ? void 0 : _shortcuts$i2.payload;
15924
16139
  var itemsFromEquipment = [];
@@ -15958,7 +16173,7 @@ var Shortcuts = function Shortcuts(_ref) {
15958
16173
  className: buildClassName('keyboard', isOnShortcutCooldown)
15959
16174
  }, i + 1));
15960
16175
  }
15961
- var payload = (_shortcuts$i3 = shortcuts[i]) == null ? void 0 : _shortcuts$i3.payload;
16176
+ var payload = shortcuts && ((_shortcuts$i3 = shortcuts[i]) == null ? void 0 : _shortcuts$i3.payload); //check if shortcuts exists before using the ? operator.
15962
16177
  var spellCooldown = !payload ? 0 : (_spellCooldowns$paylo = spellCooldowns == null ? void 0 : spellCooldowns[payload.magicWords.replaceAll(' ', '_')]) != null ? _spellCooldowns$paylo : shortcutCooldown;
15963
16178
  var cooldown = spellCooldown > shortcutCooldown ? spellCooldown : shortcutCooldown;
15964
16179
  var isOnCooldown = cooldown > 0 && !!payload;
@@ -15997,7 +16212,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
15997
16212
  bgColor = _ref$bgColor === void 0 ? 'red' : _ref$bgColor,
15998
16213
  _ref$margin = _ref.margin,
15999
16214
  margin = _ref$margin === void 0 ? 20 : _ref$margin;
16000
- return React__default.createElement(Container$j, {
16215
+ return React__default.createElement(Container$l, {
16001
16216
  className: "simple-progress-bar"
16002
16217
  }, React__default.createElement(ProgressBarContainer, {
16003
16218
  margin: margin
@@ -16006,7 +16221,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
16006
16221
  bgColor: bgColor
16007
16222
  }))));
16008
16223
  };
16009
- var Container$j = /*#__PURE__*/styled.div.withConfig({
16224
+ var Container$l = /*#__PURE__*/styled.div.withConfig({
16010
16225
  displayName: "SimpleProgressBar__Container",
16011
16226
  componentId: "sc-mbeil3-0"
16012
16227
  })(["display:flex;justify-content:center;align-items:center;width:100%;"]);
@@ -16165,6 +16380,9 @@ var SkillsContainer = function SkillsContainer(_ref) {
16165
16380
  var _Object$entries$_i = _Object$entries[_i],
16166
16381
  key = _Object$entries$_i[0],
16167
16382
  value = _Object$entries$_i[1];
16383
+ if (key === 'stamina') {
16384
+ continue;
16385
+ }
16168
16386
  //@ts-ignore
16169
16387
  var skillDetails = skill[key];
16170
16388
  output.push(React__default.createElement(SkillProgressBar, {
@@ -16185,60 +16403,268 @@ var SkillsContainer = function SkillsContainer(_ref) {
16185
16403
  title: "Skills",
16186
16404
  cancelDrag: "#skillsDiv",
16187
16405
  scale: scale
16188
- }, onCloseButton && React__default.createElement(CloseButton$3, {
16189
- onPointerDown: onCloseButton
16190
- }, "X"), React__default.createElement(SkillsContainerDiv, {
16191
- id: "skillsDiv"
16192
- }, React__default.createElement(SkillSplitDiv, null, React__default.createElement("p", null, "General"), React__default.createElement("hr", {
16193
- className: "golden"
16194
- }), React__default.createElement(SkillProgressBar, {
16195
- skillName: 'Level',
16196
- bgColor: uiColors.navyBlue,
16197
- level: Math.round(skill.level) || 0,
16198
- skillPoints: Math.round(skill.experience) || 0,
16199
- skillPointsToNextLevel: Math.round(skill.xpToNextLevel) || 0,
16200
- texturePath: 'swords/broad-sword.png',
16201
- atlasIMG: atlasIMG,
16202
- atlasJSON: atlasJSON
16203
- }), React__default.createElement("p", null, "Combat Skills"), React__default.createElement("hr", {
16204
- className: "golden"
16205
- })), onRenderSkillCategory('combat'), React__default.createElement(SkillSplitDiv, null, React__default.createElement("p", null, "Crafting Skills"), React__default.createElement("hr", {
16206
- className: "golden"
16207
- })), onRenderSkillCategory('crafting'), React__default.createElement(SkillSplitDiv, null, React__default.createElement("p", null, "Basic Attributes"), React__default.createElement("hr", {
16208
- className: "golden"
16209
- })), onRenderSkillCategory('attributes')));
16406
+ }, onCloseButton && React__default.createElement(CloseButton$3, {
16407
+ onPointerDown: onCloseButton
16408
+ }, "X"), React__default.createElement(SkillsContainerDiv, {
16409
+ id: "skillsDiv"
16410
+ }, React__default.createElement(SkillSplitDiv, null, React__default.createElement("p", null, "General"), React__default.createElement("hr", {
16411
+ className: "golden"
16412
+ }), React__default.createElement(SkillProgressBar, {
16413
+ skillName: 'Level',
16414
+ bgColor: uiColors.navyBlue,
16415
+ level: Math.round(skill.level) || 0,
16416
+ skillPoints: Math.round(skill.experience) || 0,
16417
+ skillPointsToNextLevel: Math.round(skill.xpToNextLevel) || 0,
16418
+ texturePath: 'swords/broad-sword.png',
16419
+ atlasIMG: atlasIMG,
16420
+ atlasJSON: atlasJSON
16421
+ }), React__default.createElement("p", null, "Combat Skills"), React__default.createElement("hr", {
16422
+ className: "golden"
16423
+ })), onRenderSkillCategory('combat'), React__default.createElement(SkillSplitDiv, null, React__default.createElement("p", null, "Crafting Skills"), React__default.createElement("hr", {
16424
+ className: "golden"
16425
+ })), onRenderSkillCategory('crafting'), React__default.createElement(SkillSplitDiv, null, React__default.createElement("p", null, "Basic Attributes"), React__default.createElement("hr", {
16426
+ className: "golden"
16427
+ })), onRenderSkillCategory('attributes')));
16428
+ };
16429
+ var SkillsDraggableContainer = /*#__PURE__*/styled(DraggableContainer).withConfig({
16430
+ displayName: "SkillsContainer__SkillsDraggableContainer",
16431
+ componentId: "sc-1g0c67q-0"
16432
+ })(["border:1px solid black;@media screen and (min-width:800px){body{width:800px;}}@media screen and (max-width:800px){body{width:400px;}}height:90%;.DraggableContainer__TitleContainer-sc-184mpyl-2{width:auto;height:auto;}"]);
16433
+ var SkillsContainerDiv = /*#__PURE__*/styled.div.withConfig({
16434
+ displayName: "SkillsContainer__SkillsContainerDiv",
16435
+ componentId: "sc-1g0c67q-1"
16436
+ })(["width:100%;-webkit-overflow-y:scroll;overflow-y:scroll;height:90%;padding-right:10px;"]);
16437
+ var SkillSplitDiv = /*#__PURE__*/styled.div.withConfig({
16438
+ displayName: "SkillsContainer__SkillSplitDiv",
16439
+ componentId: "sc-1g0c67q-2"
16440
+ })(["width:100%;font-size:11px;hr{margin:0;margin-bottom:1rem;padding:0px;}p{margin-bottom:0px;}"]);
16441
+ var CloseButton$3 = /*#__PURE__*/styled.div.withConfig({
16442
+ displayName: "SkillsContainer__CloseButton",
16443
+ componentId: "sc-1g0c67q-3"
16444
+ })(["position:absolute;top:2px;right:2px;color:white;z-index:22;font-size:1.1rem;"]);
16445
+
16446
+ var formatSpellCastingType = function formatSpellCastingType(castingType) {
16447
+ var formattedCastingType = castingType.split("-").map(function (word) {
16448
+ return word.charAt(0).toUpperCase() + word.slice(1);
16449
+ }).join(" ");
16450
+ return formattedCastingType;
16451
+ };
16452
+
16453
+ var SpellInfo = function SpellInfo(_ref) {
16454
+ var spell = _ref.spell;
16455
+ var magicWords = spell.magicWords,
16456
+ name = spell.name,
16457
+ manaCost = spell.manaCost,
16458
+ requiredItem = spell.requiredItem,
16459
+ description = spell.description,
16460
+ castingType = spell.castingType,
16461
+ cooldown = spell.cooldown,
16462
+ maxDistanceGrid = spell.maxDistanceGrid;
16463
+ return React__default.createElement(Container$m, null, React__default.createElement(Header$1, null, React__default.createElement("div", null, React__default.createElement(Title$6, null, name), React__default.createElement(Type$1, null, magicWords))), React__default.createElement(Statistic$1, null, React__default.createElement("div", {
16464
+ className: "label"
16465
+ }, "Casting Type:"), React__default.createElement("div", {
16466
+ className: "value"
16467
+ }, formatSpellCastingType(castingType))), React__default.createElement(Statistic$1, null, React__default.createElement("div", {
16468
+ className: "label"
16469
+ }, "Magic words:"), React__default.createElement("div", {
16470
+ className: "value"
16471
+ }, magicWords)), React__default.createElement(Statistic$1, null, React__default.createElement("div", {
16472
+ className: "label"
16473
+ }, "Mana cost:"), React__default.createElement("div", {
16474
+ className: "value"
16475
+ }, manaCost)), React__default.createElement(Statistic$1, null, React__default.createElement("div", {
16476
+ className: "label"
16477
+ }, "Cooldown:"), React__default.createElement("div", {
16478
+ className: "value"
16479
+ }, cooldown)), maxDistanceGrid && React__default.createElement(Statistic$1, null, React__default.createElement("div", {
16480
+ className: "label"
16481
+ }, "Max Distance Grid:"), React__default.createElement("div", {
16482
+ className: "value"
16483
+ }, maxDistanceGrid)), React__default.createElement(Statistic$1, null, requiredItem && React__default.createElement(React__default.Fragment, null, React__default.createElement("div", {
16484
+ className: "label"
16485
+ }, "Required Item:"), React__default.createElement("div", {
16486
+ className: "value"
16487
+ }, requiredItem))), React__default.createElement(Description$1, null, description));
16488
+ };
16489
+ var Container$m = /*#__PURE__*/styled.div.withConfig({
16490
+ displayName: "SpellInfo__Container",
16491
+ componentId: "sc-4hbw3q-0"
16492
+ })(["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);
16493
+ var Title$6 = /*#__PURE__*/styled.div.withConfig({
16494
+ displayName: "SpellInfo__Title",
16495
+ componentId: "sc-4hbw3q-1"
16496
+ })(["font-size:", ";font-weight:bold;margin-bottom:0.5rem;display:flex;align-items:center;margin:0;"], uiFonts.size.medium);
16497
+ var Type$1 = /*#__PURE__*/styled.div.withConfig({
16498
+ displayName: "SpellInfo__Type",
16499
+ componentId: "sc-4hbw3q-2"
16500
+ })(["font-size:", ";margin-top:0.2rem;color:", ";"], uiFonts.size.small, uiColors.lightGray);
16501
+ var Description$1 = /*#__PURE__*/styled.div.withConfig({
16502
+ displayName: "SpellInfo__Description",
16503
+ componentId: "sc-4hbw3q-3"
16504
+ })(["margin-top:1.5rem;font-size:", ";color:", ";font-style:italic;"], uiFonts.size.small, uiColors.lightGray);
16505
+ var Header$1 = /*#__PURE__*/styled.div.withConfig({
16506
+ displayName: "SpellInfo__Header",
16507
+ componentId: "sc-4hbw3q-4"
16508
+ })(["display:flex;align-items:center;justify-content:space-between;margin-bottom:0.5rem;"]);
16509
+ var Statistic$1 = /*#__PURE__*/styled.div.withConfig({
16510
+ displayName: "SpellInfo__Statistic",
16511
+ componentId: "sc-4hbw3q-5"
16512
+ })(["margin-bottom:0.4rem;width:max-content;.label{display:inline-block;margin-right:0.5rem;color:inherit;}.value{display:inline-block;color:inherit;}&.better,.better{color:", ";}&.worse,.worse{color:", ";}"], uiColors.lightGreen, uiColors.cardinal);
16513
+
16514
+ var SpellInfoDisplay = function SpellInfoDisplay(_ref) {
16515
+ var spell = _ref.spell,
16516
+ isMobile = _ref.isMobile;
16517
+ return React__default.createElement(Flex$1, {
16518
+ "$isMobile": isMobile
16519
+ }, React__default.createElement(SpellInfo, {
16520
+ spell: spell
16521
+ }));
16522
+ };
16523
+ var Flex$1 = /*#__PURE__*/styled.div.withConfig({
16524
+ displayName: "SpellInfoDisplay__Flex",
16525
+ componentId: "sc-1htnsmm-0"
16526
+ })(["display:flex;gap:0.5rem;flex-direction:", ";@media (max-width:580px){flex-direction:column-reverse;align-items:center;}"], function (_ref2) {
16527
+ var $isMobile = _ref2.$isMobile;
16528
+ return $isMobile ? 'row-reverse' : 'row';
16529
+ });
16530
+
16531
+ var MobileSpellTooltip = function MobileSpellTooltip(_ref) {
16532
+ var spell = _ref.spell,
16533
+ closeTooltip = _ref.closeTooltip,
16534
+ _ref$scale = _ref.scale,
16535
+ scale = _ref$scale === void 0 ? 1 : _ref$scale,
16536
+ options = _ref.options,
16537
+ onSelected = _ref.onSelected;
16538
+ var ref = React.useRef(null);
16539
+ var handleFadeOut = function handleFadeOut() {
16540
+ var _ref$current;
16541
+ (_ref$current = ref.current) == null ? void 0 : _ref$current.classList.add('fadeOut');
16542
+ };
16543
+ return React__default.createElement(ModalPortal, null, React__default.createElement(Container$n, {
16544
+ ref: ref,
16545
+ onTouchEnd: function onTouchEnd() {
16546
+ handleFadeOut();
16547
+ setTimeout(function () {
16548
+ closeTooltip();
16549
+ }, 100);
16550
+ },
16551
+ scale: scale
16552
+ }, React__default.createElement(SpellInfoDisplay, {
16553
+ spell: spell,
16554
+ isMobile: true
16555
+ }), React__default.createElement(OptionsContainer$1, null, options == null ? void 0 : options.map(function (option) {
16556
+ return React__default.createElement(Option$1, {
16557
+ key: option.id,
16558
+ onTouchEnd: function onTouchEnd() {
16559
+ handleFadeOut();
16560
+ setTimeout(function () {
16561
+ onSelected == null ? void 0 : onSelected(option.id);
16562
+ closeTooltip();
16563
+ }, 100);
16564
+ }
16565
+ }, option.text);
16566
+ }))));
16567
+ };
16568
+ var Container$n = /*#__PURE__*/styled.div.withConfig({
16569
+ displayName: "MobileSpellTooltip__Container",
16570
+ componentId: "sc-6p7uvr-0"
16571
+ })(["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;}"]);
16572
+ var OptionsContainer$1 = /*#__PURE__*/styled.div.withConfig({
16573
+ displayName: "MobileSpellTooltip__OptionsContainer",
16574
+ componentId: "sc-6p7uvr-1"
16575
+ })(["display:flex;flex-direction:column;gap:0.5rem;flex-wrap:wrap;@media (max-width:580px){flex-direction:row;justify-content:center;}"]);
16576
+ var Option$1 = /*#__PURE__*/styled.button.withConfig({
16577
+ displayName: "MobileSpellTooltip__Option",
16578
+ componentId: "sc-6p7uvr-2"
16579
+ })(["padding:1rem;background-color:#333;color:white;border:none;border-radius:3px;width:8rem;transition:background-color 0.1s;&:hover{background-color:#555;}@media (max-width:580px){padding:1rem 0.5rem;}"]);
16580
+
16581
+ var offset$1 = 20;
16582
+ var MagicTooltip = function MagicTooltip(_ref) {
16583
+ var spell = _ref.spell;
16584
+ var ref = React.useRef(null);
16585
+ React.useEffect(function () {
16586
+ var current = ref.current;
16587
+ if (current) {
16588
+ var handleMouseMove = function handleMouseMove(event) {
16589
+ var clientX = event.clientX,
16590
+ clientY = event.clientY;
16591
+ // Adjust the position of the tooltip based on the mouse position
16592
+ var rect = current.getBoundingClientRect();
16593
+ var tooltipWidth = rect.width;
16594
+ var tooltipHeight = rect.height;
16595
+ var isOffScreenRight = clientX + tooltipWidth + offset$1 > window.innerWidth;
16596
+ var isOffScreenBottom = clientY + tooltipHeight + offset$1 > window.innerHeight;
16597
+ var x = isOffScreenRight ? clientX - tooltipWidth - offset$1 : clientX + offset$1;
16598
+ var y = isOffScreenBottom ? clientY - tooltipHeight - offset$1 : clientY + offset$1;
16599
+ current.style.transform = "translate(" + x + "px, " + y + "px)";
16600
+ current.style.opacity = '1';
16601
+ };
16602
+ window.addEventListener('mousemove', handleMouseMove);
16603
+ return function () {
16604
+ window.removeEventListener('mousemove', handleMouseMove);
16605
+ };
16606
+ }
16607
+ return;
16608
+ }, []);
16609
+ return React__default.createElement(ModalPortal, null, React__default.createElement(Container$o, {
16610
+ ref: ref
16611
+ }, React__default.createElement(SpellInfoDisplay, {
16612
+ spell: spell
16613
+ })));
16614
+ };
16615
+ var Container$o = /*#__PURE__*/styled.div.withConfig({
16616
+ displayName: "SpellTooltip__Container",
16617
+ componentId: "sc-1go0gwg-0"
16618
+ })(["position:absolute;z-index:100;pointer-events:none;left:0;top:0;opacity:0;transition:opacity 0.08s;"]);
16619
+
16620
+ var SpellInfoWrapper = function SpellInfoWrapper(_ref) {
16621
+ var children = _ref.children,
16622
+ spell = _ref.spell,
16623
+ scale = _ref.scale;
16624
+ var _useState = React.useState(false),
16625
+ isTooltipVisible = _useState[0],
16626
+ setIsTooltipVisible = _useState[1];
16627
+ var _useState2 = React.useState(false),
16628
+ isTooltipMobileVisible = _useState2[0],
16629
+ setIsTooltipMobileVisible = _useState2[1];
16630
+ return React__default.createElement("div", {
16631
+ onMouseEnter: function onMouseEnter() {
16632
+ if (!isTooltipMobileVisible) setIsTooltipVisible(true);
16633
+ },
16634
+ onMouseLeave: setIsTooltipVisible.bind(null, false),
16635
+ onTouchEnd: function onTouchEnd() {
16636
+ setIsTooltipMobileVisible(true);
16637
+ setIsTooltipVisible(false);
16638
+ }
16639
+ }, children, isTooltipVisible && !isTooltipMobileVisible && React__default.createElement(MagicTooltip, {
16640
+ spell: spell
16641
+ }), isTooltipMobileVisible && React__default.createElement(MobileSpellTooltip, {
16642
+ closeTooltip: function closeTooltip() {
16643
+ setIsTooltipMobileVisible(false);
16644
+ console.log('close');
16645
+ },
16646
+ spell: spell,
16647
+ scale: scale
16648
+ }));
16210
16649
  };
16211
- var SkillsDraggableContainer = /*#__PURE__*/styled(DraggableContainer).withConfig({
16212
- displayName: "SkillsContainer__SkillsDraggableContainer",
16213
- componentId: "sc-1g0c67q-0"
16214
- })(["border:1px solid black;width:400px;height:90%;.DraggableContainer__TitleContainer-sc-184mpyl-2{width:auto;height:auto;}"]);
16215
- var SkillsContainerDiv = /*#__PURE__*/styled.div.withConfig({
16216
- displayName: "SkillsContainer__SkillsContainerDiv",
16217
- componentId: "sc-1g0c67q-1"
16218
- })(["width:100%;-webkit-overflow-y:scroll;overflow-y:scroll;height:90%;padding-right:10px;"]);
16219
- var SkillSplitDiv = /*#__PURE__*/styled.div.withConfig({
16220
- displayName: "SkillsContainer__SkillSplitDiv",
16221
- componentId: "sc-1g0c67q-2"
16222
- })(["width:100%;font-size:11px;hr{margin:0;margin-bottom:1rem;padding:0px;}p{margin-bottom:0px;}"]);
16223
- var CloseButton$3 = /*#__PURE__*/styled.div.withConfig({
16224
- displayName: "SkillsContainer__CloseButton",
16225
- componentId: "sc-1g0c67q-3"
16226
- })(["position:absolute;top:2px;right:2px;color:white;z-index:22;font-size:1.1rem;"]);
16227
16650
 
16228
16651
  var Spell = function Spell(_ref) {
16229
16652
  var spellKey = _ref.spellKey,
16230
- name = _ref.name,
16231
- description = _ref.description,
16232
- magicWords = _ref.magicWords,
16233
- manaCost = _ref.manaCost,
16234
16653
  charMana = _ref.charMana,
16235
16654
  charMagicLevel = _ref.charMagicLevel,
16236
16655
  onPointerUp = _ref.onPointerUp,
16237
16656
  isSettingShortcut = _ref.isSettingShortcut,
16238
- minMagicLevelRequired = _ref.minMagicLevelRequired,
16657
+ spell = _ref.spell,
16239
16658
  activeCooldown = _ref.activeCooldown;
16659
+ var manaCost = spell.manaCost,
16660
+ minMagicLevelRequired = spell.minMagicLevelRequired,
16661
+ magicWords = spell.magicWords,
16662
+ name = spell.name,
16663
+ description = spell.description;
16240
16664
  var disabled = isSettingShortcut ? charMagicLevel < minMagicLevelRequired : manaCost > charMana || charMagicLevel < minMagicLevelRequired;
16241
- return React__default.createElement(Container$k, {
16665
+ return React__default.createElement(SpellInfoWrapper, {
16666
+ spell: spell
16667
+ }, React__default.createElement(Container$p, {
16242
16668
  disabled: disabled || (activeCooldown != null ? activeCooldown : 0) > 0,
16243
16669
  onPointerUp: onPointerUp == null ? void 0 : onPointerUp.bind(null, spellKey),
16244
16670
  isSettingShortcut: isSettingShortcut && !disabled,
@@ -16247,16 +16673,16 @@ var Spell = function Spell(_ref) {
16247
16673
  className: "cooldown"
16248
16674
  }, activeCooldown.toFixed(activeCooldown > 10 ? 0 : 1)) : null, magicWords.split(' ').map(function (word) {
16249
16675
  return word[0];
16250
- })), React__default.createElement(Info, null, React__default.createElement(Title$6, null, React__default.createElement("span", null, name), React__default.createElement("span", {
16676
+ })), React__default.createElement(Info, null, React__default.createElement(Title$7, null, React__default.createElement("span", null, name), React__default.createElement("span", {
16251
16677
  className: "spell"
16252
- }, "(", magicWords, ")")), React__default.createElement(Description$1, null, description)), React__default.createElement(Divider, null), React__default.createElement(Cost, null, React__default.createElement("span", null, "Mana cost:"), React__default.createElement("span", {
16678
+ }, "(", magicWords, ")")), React__default.createElement(Description$2, null, description)), React__default.createElement(Divider, null), React__default.createElement(Cost, null, React__default.createElement("span", null, "Mana cost:"), React__default.createElement("span", {
16253
16679
  className: "mana"
16254
- }, manaCost)));
16680
+ }, manaCost))));
16255
16681
  };
16256
- var Container$k = /*#__PURE__*/styled.button.withConfig({
16682
+ var Container$p = /*#__PURE__*/styled.button.withConfig({
16257
16683
  displayName: "Spell__Container",
16258
16684
  componentId: "sc-j96fa2-0"
16259
- })(["display:block;background:none;border:2px solid transparent;border-radius:1rem;width:100%;display:flex;height:5rem;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) {
16685
+ })(["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) {
16260
16686
  var isSettingShortcut = _ref2.isSettingShortcut;
16261
16687
  return isSettingShortcut ? 'border-color-change 1s infinite' : 'none';
16262
16688
  }, uiColors.yellow, uiColors.yellow, uiColors.darkGray);
@@ -16267,12 +16693,12 @@ var SpellImage = /*#__PURE__*/styled.div.withConfig({
16267
16693
  var Info = /*#__PURE__*/styled.span.withConfig({
16268
16694
  displayName: "Spell__Info",
16269
16695
  componentId: "sc-j96fa2-2"
16270
- })(["width:0;flex:1;"]);
16271
- var Title$6 = /*#__PURE__*/styled.p.withConfig({
16696
+ })(["width:0;flex:1;@media (orientation:portrait){display:none;}"]);
16697
+ var Title$7 = /*#__PURE__*/styled.p.withConfig({
16272
16698
  displayName: "Spell__Title",
16273
16699
  componentId: "sc-j96fa2-3"
16274
16700
  })(["display:flex;flex-wrap:wrap;align-items:center;margin-bottom:5px;margin:0;span{font-size:", " !important;font-weight:bold !important;color:", " !important;margin-right:0.5rem;}.spell{font-size:", " !important;font-weight:normal !important;color:", " !important;}"], uiFonts.size.medium, uiColors.yellow, uiFonts.size.small, uiColors.lightGray);
16275
- var Description$1 = /*#__PURE__*/styled.div.withConfig({
16701
+ var Description$2 = /*#__PURE__*/styled.div.withConfig({
16276
16702
  displayName: "Spell__Description",
16277
16703
  componentId: "sc-j96fa2-4"
16278
16704
  })(["font-size:", " !important;line-height:1.1 !important;"], uiFonts.size.small);
@@ -16341,7 +16767,7 @@ var Spellbook = function Spellbook(_ref) {
16341
16767
  height: "inherit",
16342
16768
  cancelDrag: "#spellbook-search, #shortcuts_list, .spell",
16343
16769
  scale: scale
16344
- }, React__default.createElement(Container$l, null, React__default.createElement(Title$7, null, "Learned Spells"), React__default.createElement(ShortcutsSetter, {
16770
+ }, React__default.createElement(Container$q, null, React__default.createElement(Title$8, null, "Learned Spells"), React__default.createElement(ShortcutsSetter, {
16345
16771
  setSettingShortcutIndex: setSettingShortcutIndex,
16346
16772
  settingShortcutIndex: settingShortcutIndex,
16347
16773
  shortcuts: shortcuts,
@@ -16366,15 +16792,16 @@ var Spellbook = function Spellbook(_ref) {
16366
16792
  onPointerUp: settingShortcutIndex !== -1 ? setShortcut : onSpellClick,
16367
16793
  spellKey: spell.key,
16368
16794
  isSettingShortcut: settingShortcutIndex !== -1,
16795
+ spell: spell,
16369
16796
  activeCooldown: spellCooldowns == null ? void 0 : spellCooldowns[spell.magicWords.replaceAll(' ', '_')]
16370
16797
  }, spell)));
16371
16798
  }))));
16372
16799
  };
16373
- var Title$7 = /*#__PURE__*/styled.h1.withConfig({
16800
+ var Title$8 = /*#__PURE__*/styled.h1.withConfig({
16374
16801
  displayName: "Spellbook__Title",
16375
16802
  componentId: "sc-r02nfq-0"
16376
16803
  })(["font-size:", " !important;margin-bottom:0 !important;"], uiFonts.size.large);
16377
- var Container$l = /*#__PURE__*/styled.div.withConfig({
16804
+ var Container$q = /*#__PURE__*/styled.div.withConfig({
16378
16805
  displayName: "Spellbook__Container",
16379
16806
  componentId: "sc-r02nfq-1"
16380
16807
  })(["width:100%;height:100%;color:white;display:flex;flex-direction:column;"]);
@@ -16388,16 +16815,16 @@ var TextArea = function TextArea(_ref) {
16388
16815
  return React__default.createElement("textarea", Object.assign({}, props));
16389
16816
  };
16390
16817
 
16391
- var img$8 = '';
16818
+ var img$9 = '';
16392
16819
 
16393
- var img$9 = '';
16820
+ var img$a = '';
16394
16821
 
16395
- var img$a = '';
16822
+ var img$b = '';
16396
16823
 
16397
16824
  var DayNightPeriod = function DayNightPeriod(_ref) {
16398
16825
  var _periodOfDaySrcFiles;
16399
16826
  var periodOfDay = _ref.periodOfDay;
16400
- var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[shared.PeriodOfDay.Morning] = img$9, _periodOfDaySrcFiles[shared.PeriodOfDay.Afternoon] = img$8, _periodOfDaySrcFiles[shared.PeriodOfDay.Night] = img$a, _periodOfDaySrcFiles);
16827
+ var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[shared.PeriodOfDay.Morning] = img$a, _periodOfDaySrcFiles[shared.PeriodOfDay.Afternoon] = img$9, _periodOfDaySrcFiles[shared.PeriodOfDay.Night] = img$b, _periodOfDaySrcFiles);
16401
16828
  return React__default.createElement(GifContainer, null, React__default.createElement("img", {
16402
16829
  src: periodOfDaySrcFiles[periodOfDay]
16403
16830
  }));
@@ -16407,7 +16834,7 @@ var GifContainer = /*#__PURE__*/styled.div.withConfig({
16407
16834
  componentId: "sc-10t97fw-0"
16408
16835
  })(["width:100%;img{width:67%;}"]);
16409
16836
 
16410
- var img$b = '';
16837
+ var img$c = '';
16411
16838
 
16412
16839
  var TimeWidget = function TimeWidget(_ref) {
16413
16840
  var onClose = _ref.onClose,
@@ -16425,7 +16852,7 @@ var TimeWidget = function TimeWidget(_ref) {
16425
16852
  var WidgetContainer = /*#__PURE__*/styled.div.withConfig({
16426
16853
  displayName: "TimeWidget__WidgetContainer",
16427
16854
  componentId: "sc-1ja236h-0"
16428
- })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$b);
16855
+ })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$c);
16429
16856
  var Time = /*#__PURE__*/styled.div.withConfig({
16430
16857
  displayName: "TimeWidget__Time",
16431
16858
  componentId: "sc-1ja236h-1"
@@ -16611,7 +17038,7 @@ var TradingMenu = function TradingMenu(_ref) {
16611
17038
  style: {
16612
17039
  width: '100%'
16613
17040
  }
16614
- }, React__default.createElement(Title$8, null, Capitalize(type), " Menu"), React__default.createElement("hr", {
17041
+ }, React__default.createElement(Title$9, null, Capitalize(type), " Menu"), React__default.createElement("hr", {
16615
17042
  className: "golden"
16616
17043
  })), React__default.createElement(TradingComponentScrollWrapper, {
16617
17044
  id: "TraderContainer"
@@ -16641,7 +17068,7 @@ var TradingMenu = function TradingMenu(_ref) {
16641
17068
  }
16642
17069
  }, "Cancel"))));
16643
17070
  };
16644
- var Title$8 = /*#__PURE__*/styled.h1.withConfig({
17071
+ var Title$9 = /*#__PURE__*/styled.h1.withConfig({
16645
17072
  displayName: "TradingMenu__Title",
16646
17073
  componentId: "sc-1wjsz1l-0"
16647
17074
  })(["z-index:22;font-size:0.6rem;color:yellow !important;"]);
@@ -16675,230 +17102,17 @@ var Truncate = function Truncate(_ref) {
16675
17102
  var _ref$maxLines = _ref.maxLines,
16676
17103
  maxLines = _ref$maxLines === void 0 ? 1 : _ref$maxLines,
16677
17104
  children = _ref.children;
16678
- return React__default.createElement(Container$m, {
17105
+ return React__default.createElement(Container$r, {
16679
17106
  maxLines: maxLines
16680
17107
  }, children);
16681
17108
  };
16682
- var Container$m = /*#__PURE__*/styled.div.withConfig({
17109
+ var Container$r = /*#__PURE__*/styled.div.withConfig({
16683
17110
  displayName: "Truncate__Container",
16684
17111
  componentId: "sc-6x00qb-0"
16685
17112
  })(["display:-webkit-box;max-width:100%;max-height:100%;-webkit-line-clamp:", ";-webkit-box-orient:vertical;overflow:hidden;"], function (props) {
16686
17113
  return props.maxLines;
16687
17114
  });
16688
17115
 
16689
- var IS_MOBILE_OR_TABLET = /*#__PURE__*/shared.isMobileOrTablet();
16690
-
16691
- var chunkString = function chunkString(str, length) {
16692
- return str.match(new RegExp('.{1,' + length + '}', 'g'));
16693
- };
16694
-
16695
- var img$c = '';
16696
-
16697
- var NPCDialogText = function NPCDialogText(_ref) {
16698
- var text = _ref.text,
16699
- onClose = _ref.onClose,
16700
- onEndStep = _ref.onEndStep,
16701
- onStartStep = _ref.onStartStep,
16702
- type = _ref.type;
16703
- var windowSize = React.useRef([window.innerWidth, window.innerHeight]);
16704
- function maxCharacters(width) {
16705
- // Set the font size to 16 pixels
16706
- var fontSize = 11.2;
16707
- // Calculate the number of characters that can fit in one line
16708
- var charactersPerLine = Math.floor(width / 2 / fontSize);
16709
- // Calculate the number of lines that can fit in the div
16710
- var linesPerDiv = Math.floor(180 / fontSize);
16711
- // Calculate the maximum number of characters that can fit in the div
16712
- var maxCharacters = charactersPerLine * linesPerDiv;
16713
- // Return the maximum number of characters
16714
- return Math.round(maxCharacters / 5);
16715
- }
16716
- var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
16717
- var _useState = React.useState(0),
16718
- chunkIndex = _useState[0],
16719
- setChunkIndex = _useState[1];
16720
- var onHandleSpacePress = function onHandleSpacePress(event) {
16721
- if (event.code === 'Space') {
16722
- goToNextStep();
16723
- }
16724
- };
16725
- var goToNextStep = function goToNextStep() {
16726
- var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
16727
- if (hasNextChunk) {
16728
- setChunkIndex(function (prev) {
16729
- return prev + 1;
16730
- });
16731
- } else {
16732
- // if there's no more text chunks, close the dialog
16733
- onClose();
16734
- }
16735
- };
16736
- React.useEffect(function () {
16737
- document.addEventListener('keydown', onHandleSpacePress);
16738
- return function () {
16739
- return document.removeEventListener('keydown', onHandleSpacePress);
16740
- };
16741
- }, [chunkIndex]);
16742
- var _useState2 = React.useState(false),
16743
- showGoNextIndicator = _useState2[0],
16744
- setShowGoNextIndicator = _useState2[1];
16745
- return React__default.createElement(Container$n, null, React__default.createElement(DynamicText, {
16746
- text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
16747
- onFinish: function onFinish() {
16748
- setShowGoNextIndicator(true);
16749
- onEndStep && onEndStep();
16750
- },
16751
- onStart: function onStart() {
16752
- setShowGoNextIndicator(false);
16753
- onStartStep && onStartStep();
16754
- }
16755
- }), showGoNextIndicator && React__default.createElement(PressSpaceIndicator$1, {
16756
- right: type === exports.NPCDialogType.TextOnly ? '1rem' : '10.5rem',
16757
- src: IS_MOBILE_OR_TABLET ? img$c : img$6,
16758
- onPointerDown: function onPointerDown() {
16759
- goToNextStep();
16760
- }
16761
- }));
16762
- };
16763
- var Container$n = /*#__PURE__*/styled.div.withConfig({
16764
- displayName: "NPCDialogText__Container",
16765
- componentId: "sc-1cxkdh9-0"
16766
- })([""]);
16767
- var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
16768
- displayName: "NPCDialogText__PressSpaceIndicator",
16769
- componentId: "sc-1cxkdh9-1"
16770
- })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
16771
- var right = _ref2.right;
16772
- return right;
16773
- });
16774
-
16775
- (function (NPCDialogType) {
16776
- NPCDialogType["TextOnly"] = "TextOnly";
16777
- NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
16778
- })(exports.NPCDialogType || (exports.NPCDialogType = {}));
16779
- var NPCDialog = function NPCDialog(_ref) {
16780
- var text = _ref.text,
16781
- type = _ref.type,
16782
- _onClose = _ref.onClose,
16783
- imagePath = _ref.imagePath,
16784
- _ref$isQuestionDialog = _ref.isQuestionDialog,
16785
- isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
16786
- questions = _ref.questions,
16787
- answers = _ref.answers;
16788
- return React__default.createElement(RPGUIContainer, {
16789
- type: exports.RPGUIContainerTypes.FramedGold,
16790
- width: isQuestionDialog ? '600px' : '80%',
16791
- height: '180px'
16792
- }, isQuestionDialog && questions && answers ? React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer$2, {
16793
- flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
16794
- }, React__default.createElement(QuestionDialog, {
16795
- questions: questions,
16796
- answers: answers,
16797
- onClose: function onClose() {
16798
- if (_onClose) {
16799
- _onClose();
16800
- }
16801
- }
16802
- })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
16803
- src: imagePath || img$5
16804
- }))) : React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$o, null, React__default.createElement(TextContainer$2, {
16805
- flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
16806
- }, React__default.createElement(NPCDialogText, {
16807
- type: type,
16808
- text: text || 'No text provided.',
16809
- onClose: function onClose() {
16810
- if (_onClose) {
16811
- _onClose();
16812
- }
16813
- }
16814
- })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
16815
- src: imagePath || img$5
16816
- })))));
16817
- };
16818
- var Container$o = /*#__PURE__*/styled.div.withConfig({
16819
- displayName: "NPCDialog__Container",
16820
- componentId: "sc-1b4aw74-0"
16821
- })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
16822
- var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
16823
- displayName: "NPCDialog__TextContainer",
16824
- componentId: "sc-1b4aw74-1"
16825
- })(["flex:", " 0 0;width:355px;"], function (_ref2) {
16826
- var flex = _ref2.flex;
16827
- return flex;
16828
- });
16829
- var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
16830
- displayName: "NPCDialog__ThumbnailContainer",
16831
- componentId: "sc-1b4aw74-2"
16832
- })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
16833
- var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
16834
- displayName: "NPCDialog__NPCThumbnail",
16835
- componentId: "sc-1b4aw74-3"
16836
- })(["image-rendering:pixelated;height:128px;width:128px;"]);
16837
-
16838
- var HistoryDialog = function HistoryDialog(_ref) {
16839
- var backgroundImgPath = _ref.backgroundImgPath,
16840
- fullCoverBackground = _ref.fullCoverBackground,
16841
- questions = _ref.questions,
16842
- answers = _ref.answers,
16843
- text = _ref.text,
16844
- imagePath = _ref.imagePath,
16845
- textAndTypeArray = _ref.textAndTypeArray,
16846
- onClose = _ref.onClose;
16847
- var _useState = React.useState(0),
16848
- img = _useState[0],
16849
- setImage = _useState[1];
16850
- var onHandleSpacePress = function onHandleSpacePress(event) {
16851
- if (event.code === 'Space') {
16852
- if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
16853
- setImage(function (prev) {
16854
- return prev + 1;
16855
- });
16856
- } else {
16857
- // if there's no more text chunks, close the dialog
16858
- onClose();
16859
- }
16860
- }
16861
- };
16862
- React.useEffect(function () {
16863
- document.addEventListener('keydown', onHandleSpacePress);
16864
- return function () {
16865
- return document.removeEventListener('keydown', onHandleSpacePress);
16866
- };
16867
- }, [backgroundImgPath]);
16868
- return React__default.createElement(BackgroundContainer, {
16869
- imgPath: backgroundImgPath[img],
16870
- fullImg: fullCoverBackground
16871
- }, React__default.createElement(DialogContainer, null, textAndTypeArray ? React__default.createElement(NPCMultiDialog, {
16872
- textAndTypeArray: textAndTypeArray,
16873
- onClose: onClose
16874
- }) : questions && answers ? React__default.createElement(QuestionDialog, {
16875
- questions: questions,
16876
- answers: answers,
16877
- onClose: onClose
16878
- }) : text && imagePath ? React__default.createElement(NPCDialog, {
16879
- text: text,
16880
- imagePath: imagePath,
16881
- onClose: onClose,
16882
- type: exports.NPCDialogType.TextAndThumbnail
16883
- }) : React__default.createElement(NPCDialog, {
16884
- text: text,
16885
- onClose: onClose,
16886
- type: exports.NPCDialogType.TextOnly
16887
- })));
16888
- };
16889
- var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
16890
- displayName: "HistoryDialog__BackgroundContainer",
16891
- componentId: "sc-u6oe75-0"
16892
- })(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
16893
- return props.imgPath;
16894
- }, function (props) {
16895
- return props.imgPath ? 'cover' : 'auto';
16896
- });
16897
- var DialogContainer = /*#__PURE__*/styled.div.withConfig({
16898
- displayName: "HistoryDialog__DialogContainer",
16899
- componentId: "sc-u6oe75-1"
16900
- })(["display:flex;justify-content:center;padding-top:200px;"]);
16901
-
16902
17116
  exports.Button = Button;
16903
17117
  exports.CharacterSelection = CharacterSelection;
16904
17118
  exports.Chat = Chat;