@rpg-engine/long-bow 0.3.97 → 0.3.98

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 (179) 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 +1438 -1229
  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 +1439 -1230
  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/.DS_Store +0 -0
  21. package/src/components/.DS_Store +0 -0
  22. package/src/components/Abstractions/ModalPortal.tsx +22 -22
  23. package/src/components/Abstractions/SlotsContainer.tsx +62 -62
  24. package/src/components/Arrow/SelectArrow.tsx +69 -69
  25. package/src/components/Arrow/img/arrow01-left-clicked.png +0 -0
  26. package/src/components/Arrow/img/arrow01-left.png +0 -0
  27. package/src/components/Arrow/img/arrow01-right-clicked.png +0 -0
  28. package/src/components/Arrow/img/arrow01-right.png +0 -0
  29. package/src/components/Arrow/img/arrow02-left-clicked.png +0 -0
  30. package/src/components/Arrow/img/arrow02-left.png +0 -0
  31. package/src/components/Arrow/img/arrow02-right-clicked.png +0 -0
  32. package/src/components/Arrow/img/arrow02-right.png +0 -0
  33. package/src/components/Button.tsx +40 -40
  34. package/src/components/Character/CharacterSelection.tsx +98 -98
  35. package/src/components/CharacterStatus/CharacterStatus.tsx +120 -120
  36. package/src/components/Chat/Chat.tsx +196 -196
  37. package/src/components/Chatdeprecated/ChatDeprecated.tsx +198 -198
  38. package/src/components/CheckButton.tsx +65 -65
  39. package/src/components/CircularController/CircularController.tsx +282 -282
  40. package/src/components/CraftBook/CraftBook.tsx +286 -286
  41. package/src/components/CraftBook/CraftingRecipe.tsx +161 -161
  42. package/src/components/CraftBook/MockItems.ts +101 -101
  43. package/src/components/DraggableContainer.tsx +180 -180
  44. package/src/components/DropdownSelectorContainer.tsx +42 -42
  45. package/src/components/Equipment/EquipmentSet.tsx +199 -199
  46. package/src/components/HistoryDialog.tsx +104 -104
  47. package/src/components/Input.tsx +15 -15
  48. package/src/components/InputRadio.tsx +41 -41
  49. package/src/components/Item/Cards/ItemInfo.tsx +298 -298
  50. package/src/components/Item/Cards/ItemInfoDisplay.tsx +135 -135
  51. package/src/components/Item/Cards/ItemInfoWrapper.tsx +62 -62
  52. package/src/components/Item/Cards/ItemTooltip.tsx +83 -83
  53. package/src/components/Item/Cards/MobileItemTooltip.tsx +149 -149
  54. package/src/components/Item/Inventory/ErrorBoundary.tsx +42 -42
  55. package/src/components/Item/Inventory/ItemContainer.tsx +231 -231
  56. package/src/components/Item/Inventory/ItemContainerTypes.ts +6 -6
  57. package/src/components/Item/Inventory/ItemQuantitySelector.tsx +138 -138
  58. package/src/components/Item/Inventory/ItemSlot.tsx +580 -580
  59. package/src/components/Item/Inventory/itemContainerHelper.ts +175 -175
  60. package/src/components/ListMenu.tsx +63 -63
  61. package/src/components/Marketplace/Marketplace.tsx +132 -132
  62. package/src/components/Marketplace/MarketplaceRows.tsx +171 -171
  63. package/src/components/Marketplace/__mocks__/index.tsx +65 -65
  64. package/src/components/Multitab/Tab.tsx +66 -66
  65. package/src/components/Multitab/TabBody.tsx +13 -13
  66. package/src/components/Multitab/TabsContainer.tsx +97 -97
  67. package/src/components/NPCDialog/.DS_Store +0 -0
  68. package/src/components/NPCDialog/NPCDialog.tsx +121 -121
  69. package/src/components/NPCDialog/NPCDialogText.tsx +113 -113
  70. package/src/components/NPCDialog/NPCMultiDialog.tsx +159 -159
  71. package/src/components/NPCDialog/QuestionDialog/QuestionDialog.tsx +237 -237
  72. package/src/components/NPCDialog/img/.DS_Store +0 -0
  73. package/src/components/ProgressBar.tsx +92 -92
  74. package/src/components/PropertySelect/PropertySelect.tsx +106 -106
  75. package/src/components/QuestInfo/QuestInfo.tsx +233 -233
  76. package/src/components/QuestList.tsx +135 -135
  77. package/src/components/RPGUIContainer.tsx +47 -47
  78. package/src/components/RPGUIForceRenderStart.tsx +45 -45
  79. package/src/components/RPGUIRoot.tsx +14 -14
  80. package/src/components/RadioButton.tsx +53 -53
  81. package/src/components/RadioInput/RadioButton.tsx +96 -96
  82. package/src/components/RadioInput/RadioInput.tsx +102 -102
  83. package/src/components/RadioInput/instruments.ts +15 -15
  84. package/src/components/RangeSlider.tsx +78 -78
  85. package/src/components/RelativeListMenu.tsx +90 -90
  86. package/src/components/ScrollList.tsx +79 -79
  87. package/src/components/Shortcuts/Shortcuts.tsx +192 -192
  88. package/src/components/Shortcuts/ShortcutsSetter.tsx +139 -139
  89. package/src/components/Shortcuts/SingleShortcut.ts +82 -82
  90. package/src/components/Shortcuts/useShortcutCooldown.ts +23 -23
  91. package/src/components/SimpleProgressBar.tsx +62 -62
  92. package/src/components/SkillProgressBar.tsx +133 -133
  93. package/src/components/SkillsContainer.tsx +206 -206
  94. package/src/components/Spellbook/Spell.tsx +236 -226
  95. package/src/components/Spellbook/Spellbook.tsx +159 -158
  96. package/src/components/Spellbook/cards/MobileSpellTooltip.tsx +137 -0
  97. package/src/components/Spellbook/cards/SpellInfo.tsx +132 -0
  98. package/src/components/Spellbook/cards/SpellInfoDisplay.tsx +31 -0
  99. package/src/components/Spellbook/cards/SpellInfoWrapper.tsx +48 -0
  100. package/src/components/Spellbook/cards/SpellTooltip.tsx +70 -0
  101. package/src/components/Spellbook/constants.ts +8 -8
  102. package/src/components/Spellbook/mockSpells.ts +85 -60
  103. package/src/components/StaticBook/StaticBook.tsx +103 -103
  104. package/src/components/TextArea.tsx +11 -11
  105. package/src/components/TimeWidget/DayNightPeriod/DayNightPeriod.tsx +35 -35
  106. package/src/components/TimeWidget/TimeWidget.tsx +65 -65
  107. package/src/components/TradingMenu/TradingItemRow.tsx +199 -199
  108. package/src/components/TradingMenu/TradingMenu.tsx +219 -219
  109. package/src/components/TradingMenu/items.mock.ts +48 -48
  110. package/src/components/Truncate.tsx +25 -25
  111. package/src/components/itemSelector/ItemSelector.tsx +136 -136
  112. package/src/components/shared/Column.tsx +16 -16
  113. package/src/components/shared/Ellipsis.tsx +68 -68
  114. package/src/components/shared/SpriteFromAtlas.tsx +104 -104
  115. package/src/components/typography/DynamicText.tsx +49 -49
  116. package/src/constants/uiColors.ts +20 -20
  117. package/src/constants/uiDevices.ts +3 -3
  118. package/src/constants/uiFonts.ts +12 -12
  119. package/src/hooks/useEventListener.ts +21 -21
  120. package/src/hooks/useOutsideAlerter.ts +25 -25
  121. package/src/index.tsx +42 -42
  122. package/src/libs/CastingTypeHelper.ts +8 -0
  123. package/src/libs/StringHelpers.ts +3 -3
  124. package/src/libs/itemCounter.ts +21 -21
  125. package/src/mocks/.DS_Store +0 -0
  126. package/src/mocks/atlas/.DS_Store +0 -0
  127. package/src/mocks/atlas/entities/entities.json +20215 -20215
  128. package/src/mocks/atlas/icons/icons.json +735 -735
  129. package/src/mocks/atlas/items/items.json +12086 -12086
  130. package/src/mocks/equipmentSet.mocks.ts +391 -391
  131. package/src/mocks/itemContainer.mocks.ts +605 -605
  132. package/src/mocks/skills.mocks.ts +128 -128
  133. package/src/stories/Arrow.stories.tsx +26 -26
  134. package/src/stories/Button.stories.tsx +36 -36
  135. package/src/stories/CharacterSelection.stories.tsx +44 -44
  136. package/src/stories/CharacterStatus.stories.tsx +29 -29
  137. package/src/stories/Chat.stories.tsx +187 -187
  138. package/src/stories/ChatDeprecated.stories.tsx +170 -170
  139. package/src/stories/CheckButton.stories.tsx +48 -48
  140. package/src/stories/CircullarController.stories.tsx +37 -37
  141. package/src/stories/CraftBook.stories.tsx +42 -42
  142. package/src/stories/DayNightPeriod.stories.tsx +27 -27
  143. package/src/stories/DraggableContainer.stories.tsx +28 -28
  144. package/src/stories/Dropdown.stories.tsx +46 -46
  145. package/src/stories/DropdownSelectorContainer.stories.tsx +41 -41
  146. package/src/stories/EquipmentSet.stories.tsx +65 -65
  147. package/src/stories/HistoryDialog.stories.tsx +61 -61
  148. package/src/stories/ItemContainer.stories.tsx +201 -201
  149. package/src/stories/ItemInfoDisplay.stories.tsx +33 -33
  150. package/src/stories/ItemQuantitySelector.stories.tsx +26 -26
  151. package/src/stories/ItemSelector.stories.tsx +77 -77
  152. package/src/stories/ItemTradingComponent.stories.tsx +35 -35
  153. package/src/stories/ListMenu.stories.tsx +56 -56
  154. package/src/stories/Marketplace.stories.tsx +42 -42
  155. package/src/stories/MarketplaceRows.stories.tsx +28 -28
  156. package/src/stories/Multitab.stories.tsx +51 -51
  157. package/src/stories/NPCDialog.stories.tsx +130 -130
  158. package/src/stories/NPCMultiDialog.stories.tsx +71 -71
  159. package/src/stories/ProgressBar.stories.tsx +23 -23
  160. package/src/stories/PropertySelect.stories.tsx +40 -40
  161. package/src/stories/QuestInfo.stories.tsx +107 -107
  162. package/src/stories/QuestList.stories.tsx +82 -82
  163. package/src/stories/RPGUIContainers.stories.tsx +42 -42
  164. package/src/stories/RadioButton.stories.tsx +49 -49
  165. package/src/stories/RadioInput.stories.tsx +34 -34
  166. package/src/stories/RangeSlider.stories.tsx +64 -64
  167. package/src/stories/ScrollList.stories.tsx +85 -85
  168. package/src/stories/Shortcuts.stories.tsx +39 -39
  169. package/src/stories/SimpleProgressBar.stories.tsx +22 -22
  170. package/src/stories/SkillProgressBar.stories.tsx +34 -34
  171. package/src/stories/SkillsContainer.stories.tsx +35 -35
  172. package/src/stories/SpellInfoDisplay.stories.tsx +27 -0
  173. package/src/stories/Spellbook.stories.tsx +104 -104
  174. package/src/stories/StaticBook.stories.tsx +32 -32
  175. package/src/stories/Text.stories.tsx +42 -42
  176. package/src/stories/TimeWidget.stories.tsx +27 -27
  177. package/src/stories/TradingMenu.stories.tsx +47 -47
  178. package/src/types/eventTypes.ts +4 -4
  179. 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
- }
14833
+ var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
14834
+ var answerIds = currentQuestion.answerIds;
14835
+ if (!answerIds) {
14836
+ return null;
15042
14837
  }
15043
- }, React__default.createElement("div", {
15044
- style: {
15045
- width: '100%'
14838
+ var answers = onGetAnswers(answerIds);
14839
+ if (!answers) {
14840
+ return null;
15046
14841
  }
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'
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));
15067
14857
  }
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'
14858
+ return null;
14859
+ });
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);
15113
14868
  }
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
- })));
14869
+ })), canShowAnswers && React__default.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
15122
14870
  };
15123
14871
  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);
15181
- }
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
15270
- });
15271
- }))));
15272
- };
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;"]);
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";
@@ -15311,306 +14982,848 @@ var NPCMultiDialog = function NPCMultiDialog(_ref) {
15311
14982
  setSlide(function (prev) {
15312
14983
  return prev + 1;
15313
14984
  });
15314
- } else {
15315
- // if there's no more text chunks, close the dialog
15316
- _onClose();
14985
+ } else {
14986
+ // if there's no more text chunks, close the dialog
14987
+ _onClose();
14988
+ }
14989
+ }
14990
+ };
14991
+ React.useEffect(function () {
14992
+ document.addEventListener('keydown', onHandleSpacePress);
14993
+ return function () {
14994
+ return document.removeEventListener('keydown', onHandleSpacePress);
14995
+ };
14996
+ }, [slide]);
14997
+ return React__default.createElement(RPGUIContainer, {
14998
+ type: exports.RPGUIContainerTypes.FramedGold,
14999
+ width: '50%',
15000
+ height: '180px'
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, {
15024
+ flex: '70%'
15025
+ }, React__default.createElement(NPCDialogText, {
15026
+ onStartStep: function onStartStep() {
15027
+ return setShowGoNextIndicator(false);
15028
+ },
15029
+ onEndStep: function onEndStep() {
15030
+ return setShowGoNextIndicator(true);
15031
+ },
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
+ });
15162
+ }
15163
+ },
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
+ }
15173
+ },
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
+ });
15317
15182
  }
15318
- }
15319
- };
15320
- React.useEffect(function () {
15321
- document.addEventListener('keydown', onHandleSpacePress);
15322
- return function () {
15323
- return document.removeEventListener('keydown', onHandleSpacePress);
15324
- };
15325
- }, [slide]);
15326
- return React__default.createElement(RPGUIContainer, {
15327
- type: exports.RPGUIContainerTypes.FramedGold,
15328
- width: '50%',
15329
- 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, {
15331
- flex: '70%'
15332
- }, React__default.createElement(NPCDialogText, {
15333
- onStartStep: function onStartStep() {
15334
- return setShowGoNextIndicator(false);
15335
15183
  },
15336
- onEndStep: function onEndStep() {
15337
- return setShowGoNextIndicator(true);
15184
+ onOutsideClick: onOutsideClick,
15185
+ initialPosition: initialPosition,
15186
+ scale: scale
15187
+ }, children);
15188
+ };
15189
+
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'
15338
15216
  },
15339
- text: textAndTypeArray[slide].text || 'No text provided.',
15340
- onClose: function onClose() {
15341
- if (_onClose) {
15342
- _onClose();
15343
- }
15217
+ className: "rpgui-slider-container " + typeClass,
15218
+ id: "rpgui-slider-" + sliderId,
15219
+ ref: containerRef
15220
+ }, React__default.createElement("div", {
15221
+ style: {
15222
+ pointerEvents: 'none'
15344
15223
  }
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);
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
15357
15239
  },
15358
- onEndStep: function onEndStep() {
15359
- return setShowGoNextIndicator(true);
15240
+ min: valueMin,
15241
+ max: valueMax,
15242
+ onChange: function onChange(e) {
15243
+ return _onChange(Number(e.target.value));
15360
15244
  },
15361
- text: textAndTypeArray[slide].text || 'No text provided.',
15362
- onClose: function onClose() {
15363
- if (_onClose) {
15364
- _onClose();
15365
- }
15366
- }
15367
- })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator, {
15368
- right: '1rem',
15369
- src: img$6
15370
- }))), ")"));
15371
- };
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
-
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]);
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,
@@ -15629,7 +15842,7 @@ var ProgressBar = function ProgressBar(_ref) {
15629
15842
  }
15630
15843
  return value * 100 / max;
15631
15844
  };
15632
- return React__default.createElement(Container$i, {
15845
+ return React__default.createElement(Container$k, {
15633
15846
  className: "rpgui-progress",
15634
15847
  "data-value": calculatePercentageValue(max, value) / 100,
15635
15848
  "data-rpguitype": "progress",
@@ -15658,7 +15871,7 @@ var TextOverlay$2 = /*#__PURE__*/styled.div.withConfig({
15658
15871
  displayName: "ProgressBar__TextOverlay",
15659
15872
  componentId: "sc-qa6fzh-1"
15660
15873
  })(["width:100%;position:relative;"]);
15661
- var Container$i = /*#__PURE__*/styled.div.withConfig({
15874
+ var Container$k = /*#__PURE__*/styled.div.withConfig({
15662
15875
  displayName: "ProgressBar__Container",
15663
15876
  componentId: "sc-qa6fzh-2"
15664
15877
  })(["display:flex;flex-direction:column;min-width:", "px;width:", "%;justify-content:start;align-items:flex-start;", ""], function (props) {
@@ -15669,7 +15882,7 @@ var Container$i = /*#__PURE__*/styled.div.withConfig({
15669
15882
  return props.style;
15670
15883
  });
15671
15884
 
15672
- var img$7 = '';
15885
+ var img$8 = '';
15673
15886
 
15674
15887
  var QuestInfo = function QuestInfo(_ref) {
15675
15888
  var quests = _ref.quests,
@@ -15713,7 +15926,7 @@ var QuestInfo = function QuestInfo(_ref) {
15713
15926
  }), React__default.createElement(QuestContainer, null, React__default.createElement(TitleContainer$1, {
15714
15927
  className: "drag-handler"
15715
15928
  }, React__default.createElement(Title$4, null, React__default.createElement(Thumbnail, {
15716
- src: quests[currentIndex].thumbnail || img$7
15929
+ src: quests[currentIndex].thumbnail || img$8
15717
15930
  }), quests[currentIndex].title), React__default.createElement(QuestSplitDiv, null, React__default.createElement("hr", {
15718
15931
  className: "golden"
15719
15932
  }))), React__default.createElement(Content, null, React__default.createElement("p", null, quests[currentIndex].description)), React__default.createElement(QuestColumn, {
@@ -15732,7 +15945,7 @@ var QuestInfo = function QuestInfo(_ref) {
15732
15945
  })))) : React__default.createElement(QuestsContainer, null, React__default.createElement(QuestContainer, null, React__default.createElement(TitleContainer$1, {
15733
15946
  className: "drag-handler"
15734
15947
  }, React__default.createElement(Title$4, null, React__default.createElement(Thumbnail, {
15735
- src: quests[0].thumbnail || img$7
15948
+ src: quests[0].thumbnail || img$8
15736
15949
  }), quests[0].title), React__default.createElement(QuestSplitDiv, null, React__default.createElement("hr", {
15737
15950
  className: "golden"
15738
15951
  }))), React__default.createElement(Content, null, React__default.createElement("p", null, quests[0].description)), React__default.createElement(QuestColumn, {
@@ -15997,7 +16210,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
15997
16210
  bgColor = _ref$bgColor === void 0 ? 'red' : _ref$bgColor,
15998
16211
  _ref$margin = _ref.margin,
15999
16212
  margin = _ref$margin === void 0 ? 20 : _ref$margin;
16000
- return React__default.createElement(Container$j, {
16213
+ return React__default.createElement(Container$l, {
16001
16214
  className: "simple-progress-bar"
16002
16215
  }, React__default.createElement(ProgressBarContainer, {
16003
16216
  margin: margin
@@ -16006,7 +16219,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
16006
16219
  bgColor: bgColor
16007
16220
  }))));
16008
16221
  };
16009
- var Container$j = /*#__PURE__*/styled.div.withConfig({
16222
+ var Container$l = /*#__PURE__*/styled.div.withConfig({
16010
16223
  displayName: "SimpleProgressBar__Container",
16011
16224
  componentId: "sc-mbeil3-0"
16012
16225
  })(["display:flex;justify-content:center;align-items:center;width:100%;"]);
@@ -16185,60 +16398,268 @@ var SkillsContainer = function SkillsContainer(_ref) {
16185
16398
  title: "Skills",
16186
16399
  cancelDrag: "#skillsDiv",
16187
16400
  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')));
16401
+ }, onCloseButton && React__default.createElement(CloseButton$3, {
16402
+ onPointerDown: onCloseButton
16403
+ }, "X"), React__default.createElement(SkillsContainerDiv, {
16404
+ id: "skillsDiv"
16405
+ }, React__default.createElement(SkillSplitDiv, null, React__default.createElement("p", null, "General"), React__default.createElement("hr", {
16406
+ className: "golden"
16407
+ }), React__default.createElement(SkillProgressBar, {
16408
+ skillName: 'Level',
16409
+ bgColor: uiColors.navyBlue,
16410
+ level: Math.round(skill.level) || 0,
16411
+ skillPoints: Math.round(skill.experience) || 0,
16412
+ skillPointsToNextLevel: Math.round(skill.xpToNextLevel) || 0,
16413
+ texturePath: 'swords/broad-sword.png',
16414
+ atlasIMG: atlasIMG,
16415
+ atlasJSON: atlasJSON
16416
+ }), React__default.createElement("p", null, "Combat Skills"), React__default.createElement("hr", {
16417
+ className: "golden"
16418
+ })), onRenderSkillCategory('combat'), React__default.createElement(SkillSplitDiv, null, React__default.createElement("p", null, "Crafting Skills"), React__default.createElement("hr", {
16419
+ className: "golden"
16420
+ })), onRenderSkillCategory('crafting'), React__default.createElement(SkillSplitDiv, null, React__default.createElement("p", null, "Basic Attributes"), React__default.createElement("hr", {
16421
+ className: "golden"
16422
+ })), onRenderSkillCategory('attributes')));
16423
+ };
16424
+ var SkillsDraggableContainer = /*#__PURE__*/styled(DraggableContainer).withConfig({
16425
+ displayName: "SkillsContainer__SkillsDraggableContainer",
16426
+ componentId: "sc-1g0c67q-0"
16427
+ })(["border:1px solid black;width:400px;height:90%;.DraggableContainer__TitleContainer-sc-184mpyl-2{width:auto;height:auto;}"]);
16428
+ var SkillsContainerDiv = /*#__PURE__*/styled.div.withConfig({
16429
+ displayName: "SkillsContainer__SkillsContainerDiv",
16430
+ componentId: "sc-1g0c67q-1"
16431
+ })(["width:100%;-webkit-overflow-y:scroll;overflow-y:scroll;height:90%;padding-right:10px;"]);
16432
+ var SkillSplitDiv = /*#__PURE__*/styled.div.withConfig({
16433
+ displayName: "SkillsContainer__SkillSplitDiv",
16434
+ componentId: "sc-1g0c67q-2"
16435
+ })(["width:100%;font-size:11px;hr{margin:0;margin-bottom:1rem;padding:0px;}p{margin-bottom:0px;}"]);
16436
+ var CloseButton$3 = /*#__PURE__*/styled.div.withConfig({
16437
+ displayName: "SkillsContainer__CloseButton",
16438
+ componentId: "sc-1g0c67q-3"
16439
+ })(["position:absolute;top:2px;right:2px;color:white;z-index:22;font-size:1.1rem;"]);
16440
+
16441
+ var formatSpellCastingType = function formatSpellCastingType(castingType) {
16442
+ var formattedCastingType = castingType.split("-").map(function (word) {
16443
+ return word.charAt(0).toUpperCase() + word.slice(1);
16444
+ }).join(" ");
16445
+ return formattedCastingType;
16446
+ };
16447
+
16448
+ var SpellInfo = function SpellInfo(_ref) {
16449
+ var spell = _ref.spell;
16450
+ var magicWords = spell.magicWords,
16451
+ name = spell.name,
16452
+ manaCost = spell.manaCost,
16453
+ requiredItem = spell.requiredItem,
16454
+ description = spell.description,
16455
+ castingType = spell.castingType,
16456
+ cooldown = spell.cooldown,
16457
+ maxDistanceGrid = spell.maxDistanceGrid;
16458
+ 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", {
16459
+ className: "label"
16460
+ }, "Casting Type:"), React__default.createElement("div", {
16461
+ className: "value"
16462
+ }, formatSpellCastingType(castingType))), React__default.createElement(Statistic$1, null, React__default.createElement("div", {
16463
+ className: "label"
16464
+ }, "Magic words:"), React__default.createElement("div", {
16465
+ className: "value"
16466
+ }, magicWords)), React__default.createElement(Statistic$1, null, React__default.createElement("div", {
16467
+ className: "label"
16468
+ }, "Mana cost:"), React__default.createElement("div", {
16469
+ className: "value"
16470
+ }, manaCost)), React__default.createElement(Statistic$1, null, React__default.createElement("div", {
16471
+ className: "label"
16472
+ }, "Cooldown:"), React__default.createElement("div", {
16473
+ className: "value"
16474
+ }, cooldown)), React__default.createElement(Statistic$1, null, React__default.createElement("div", {
16475
+ className: "label"
16476
+ }, "Max Distance Grid:"), React__default.createElement("div", {
16477
+ className: "value"
16478
+ }, maxDistanceGrid)), React__default.createElement(Statistic$1, null, requiredItem && React__default.createElement(React__default.Fragment, null, React__default.createElement("div", {
16479
+ className: "label"
16480
+ }, "Required Item:"), React__default.createElement("div", {
16481
+ className: "value"
16482
+ }, requiredItem))), React__default.createElement(Description$1, null, description));
16483
+ };
16484
+ var Container$m = /*#__PURE__*/styled.div.withConfig({
16485
+ displayName: "SpellInfo__Container",
16486
+ componentId: "sc-4hbw3q-0"
16487
+ })(["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);
16488
+ var Title$6 = /*#__PURE__*/styled.div.withConfig({
16489
+ displayName: "SpellInfo__Title",
16490
+ componentId: "sc-4hbw3q-1"
16491
+ })(["font-size:", ";font-weight:bold;margin-bottom:0.5rem;display:flex;align-items:center;margin:0;"], uiFonts.size.medium);
16492
+ var Type$1 = /*#__PURE__*/styled.div.withConfig({
16493
+ displayName: "SpellInfo__Type",
16494
+ componentId: "sc-4hbw3q-2"
16495
+ })(["font-size:", ";margin-top:0.2rem;color:", ";"], uiFonts.size.small, uiColors.lightGray);
16496
+ var Description$1 = /*#__PURE__*/styled.div.withConfig({
16497
+ displayName: "SpellInfo__Description",
16498
+ componentId: "sc-4hbw3q-3"
16499
+ })(["margin-top:1.5rem;font-size:", ";color:", ";font-style:italic;"], uiFonts.size.small, uiColors.lightGray);
16500
+ var Header$1 = /*#__PURE__*/styled.div.withConfig({
16501
+ displayName: "SpellInfo__Header",
16502
+ componentId: "sc-4hbw3q-4"
16503
+ })(["display:flex;align-items:center;justify-content:space-between;margin-bottom:0.5rem;"]);
16504
+ var Statistic$1 = /*#__PURE__*/styled.div.withConfig({
16505
+ displayName: "SpellInfo__Statistic",
16506
+ componentId: "sc-4hbw3q-5"
16507
+ })(["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);
16508
+
16509
+ var SpellInfoDisplay = function SpellInfoDisplay(_ref) {
16510
+ var spell = _ref.spell,
16511
+ isMobile = _ref.isMobile;
16512
+ return React__default.createElement(Flex$1, {
16513
+ "$isMobile": isMobile
16514
+ }, React__default.createElement(SpellInfo, {
16515
+ spell: spell
16516
+ }));
16517
+ };
16518
+ var Flex$1 = /*#__PURE__*/styled.div.withConfig({
16519
+ displayName: "SpellInfoDisplay__Flex",
16520
+ componentId: "sc-1htnsmm-0"
16521
+ })(["display:flex;gap:0.5rem;flex-direction:", ";@media (max-width:580px){flex-direction:column-reverse;align-items:center;}"], function (_ref2) {
16522
+ var $isMobile = _ref2.$isMobile;
16523
+ return $isMobile ? 'row-reverse' : 'row';
16524
+ });
16525
+
16526
+ var MobileSpellTooltip = function MobileSpellTooltip(_ref) {
16527
+ var spell = _ref.spell,
16528
+ closeTooltip = _ref.closeTooltip,
16529
+ _ref$scale = _ref.scale,
16530
+ scale = _ref$scale === void 0 ? 1 : _ref$scale,
16531
+ options = _ref.options,
16532
+ onSelected = _ref.onSelected;
16533
+ var ref = React.useRef(null);
16534
+ var handleFadeOut = function handleFadeOut() {
16535
+ var _ref$current;
16536
+ (_ref$current = ref.current) == null ? void 0 : _ref$current.classList.add('fadeOut');
16537
+ };
16538
+ return React__default.createElement(ModalPortal, null, React__default.createElement(Container$n, {
16539
+ ref: ref,
16540
+ onTouchEnd: function onTouchEnd() {
16541
+ handleFadeOut();
16542
+ setTimeout(function () {
16543
+ closeTooltip();
16544
+ }, 100);
16545
+ },
16546
+ scale: scale
16547
+ }, React__default.createElement(SpellInfoDisplay, {
16548
+ spell: spell,
16549
+ isMobile: true
16550
+ }), React__default.createElement(OptionsContainer$1, null, options == null ? void 0 : options.map(function (option) {
16551
+ return React__default.createElement(Option$1, {
16552
+ key: option.id,
16553
+ onTouchEnd: function onTouchEnd() {
16554
+ handleFadeOut();
16555
+ setTimeout(function () {
16556
+ onSelected == null ? void 0 : onSelected(option.id);
16557
+ closeTooltip();
16558
+ }, 100);
16559
+ }
16560
+ }, option.text);
16561
+ }))));
16562
+ };
16563
+ var Container$n = /*#__PURE__*/styled.div.withConfig({
16564
+ displayName: "MobileSpellTooltip__Container",
16565
+ componentId: "sc-6p7uvr-0"
16566
+ })(["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;}"]);
16567
+ var OptionsContainer$1 = /*#__PURE__*/styled.div.withConfig({
16568
+ displayName: "MobileSpellTooltip__OptionsContainer",
16569
+ componentId: "sc-6p7uvr-1"
16570
+ })(["display:flex;flex-direction:column;gap:0.5rem;flex-wrap:wrap;@media (max-width:580px){flex-direction:row;justify-content:center;}"]);
16571
+ var Option$1 = /*#__PURE__*/styled.button.withConfig({
16572
+ displayName: "MobileSpellTooltip__Option",
16573
+ componentId: "sc-6p7uvr-2"
16574
+ })(["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;}"]);
16575
+
16576
+ var offset$1 = 20;
16577
+ var MagicTooltip = function MagicTooltip(_ref) {
16578
+ var spell = _ref.spell;
16579
+ var ref = React.useRef(null);
16580
+ React.useEffect(function () {
16581
+ var current = ref.current;
16582
+ if (current) {
16583
+ var handleMouseMove = function handleMouseMove(event) {
16584
+ var clientX = event.clientX,
16585
+ clientY = event.clientY;
16586
+ // Adjust the position of the tooltip based on the mouse position
16587
+ var rect = current.getBoundingClientRect();
16588
+ var tooltipWidth = rect.width;
16589
+ var tooltipHeight = rect.height;
16590
+ var isOffScreenRight = clientX + tooltipWidth + offset$1 > window.innerWidth;
16591
+ var isOffScreenBottom = clientY + tooltipHeight + offset$1 > window.innerHeight;
16592
+ var x = isOffScreenRight ? clientX - tooltipWidth - offset$1 : clientX + offset$1;
16593
+ var y = isOffScreenBottom ? clientY - tooltipHeight - offset$1 : clientY + offset$1;
16594
+ current.style.transform = "translate(" + x + "px, " + y + "px)";
16595
+ current.style.opacity = '1';
16596
+ };
16597
+ window.addEventListener('mousemove', handleMouseMove);
16598
+ return function () {
16599
+ window.removeEventListener('mousemove', handleMouseMove);
16600
+ };
16601
+ }
16602
+ return;
16603
+ }, []);
16604
+ return React__default.createElement(ModalPortal, null, React__default.createElement(Container$o, {
16605
+ ref: ref
16606
+ }, React__default.createElement(SpellInfoDisplay, {
16607
+ spell: spell
16608
+ })));
16609
+ };
16610
+ var Container$o = /*#__PURE__*/styled.div.withConfig({
16611
+ displayName: "SpellTooltip__Container",
16612
+ componentId: "sc-1go0gwg-0"
16613
+ })(["position:absolute;z-index:100;pointer-events:none;left:0;top:0;opacity:0;transition:opacity 0.08s;"]);
16614
+
16615
+ var SpellInfoWrapper = function SpellInfoWrapper(_ref) {
16616
+ var children = _ref.children,
16617
+ spell = _ref.spell,
16618
+ scale = _ref.scale;
16619
+ var _useState = React.useState(false),
16620
+ isTooltipVisible = _useState[0],
16621
+ setIsTooltipVisible = _useState[1];
16622
+ var _useState2 = React.useState(false),
16623
+ isTooltipMobileVisible = _useState2[0],
16624
+ setIsTooltipMobileVisible = _useState2[1];
16625
+ return React__default.createElement("div", {
16626
+ onMouseEnter: function onMouseEnter() {
16627
+ if (!isTooltipMobileVisible) setIsTooltipVisible(true);
16628
+ },
16629
+ onMouseLeave: setIsTooltipVisible.bind(null, false),
16630
+ onTouchEnd: function onTouchEnd() {
16631
+ setIsTooltipMobileVisible(true);
16632
+ setIsTooltipVisible(false);
16633
+ }
16634
+ }, children, isTooltipVisible && !isTooltipMobileVisible && React__default.createElement(MagicTooltip, {
16635
+ spell: spell
16636
+ }), isTooltipMobileVisible && React__default.createElement(MobileSpellTooltip, {
16637
+ closeTooltip: function closeTooltip() {
16638
+ setIsTooltipMobileVisible(false);
16639
+ console.log('close');
16640
+ },
16641
+ spell: spell,
16642
+ scale: scale
16643
+ }));
16210
16644
  };
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
16645
 
16228
16646
  var Spell = function Spell(_ref) {
16229
16647
  var spellKey = _ref.spellKey,
16230
- name = _ref.name,
16231
- description = _ref.description,
16232
- magicWords = _ref.magicWords,
16233
- manaCost = _ref.manaCost,
16234
16648
  charMana = _ref.charMana,
16235
16649
  charMagicLevel = _ref.charMagicLevel,
16236
16650
  onPointerUp = _ref.onPointerUp,
16237
16651
  isSettingShortcut = _ref.isSettingShortcut,
16238
- minMagicLevelRequired = _ref.minMagicLevelRequired,
16652
+ spell = _ref.spell,
16239
16653
  activeCooldown = _ref.activeCooldown;
16654
+ var manaCost = spell.manaCost,
16655
+ minMagicLevelRequired = spell.minMagicLevelRequired,
16656
+ magicWords = spell.magicWords,
16657
+ name = spell.name,
16658
+ description = spell.description;
16240
16659
  var disabled = isSettingShortcut ? charMagicLevel < minMagicLevelRequired : manaCost > charMana || charMagicLevel < minMagicLevelRequired;
16241
- return React__default.createElement(Container$k, {
16660
+ return React__default.createElement(SpellInfoWrapper, {
16661
+ spell: spell
16662
+ }, React__default.createElement(Container$p, {
16242
16663
  disabled: disabled || (activeCooldown != null ? activeCooldown : 0) > 0,
16243
16664
  onPointerUp: onPointerUp == null ? void 0 : onPointerUp.bind(null, spellKey),
16244
16665
  isSettingShortcut: isSettingShortcut && !disabled,
@@ -16247,13 +16668,13 @@ var Spell = function Spell(_ref) {
16247
16668
  className: "cooldown"
16248
16669
  }, activeCooldown.toFixed(activeCooldown > 10 ? 0 : 1)) : null, magicWords.split(' ').map(function (word) {
16249
16670
  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", {
16671
+ })), React__default.createElement(Info, null, React__default.createElement(Title$7, null, React__default.createElement("span", null, name), React__default.createElement("span", {
16251
16672
  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", {
16673
+ }, "(", 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
16674
  className: "mana"
16254
- }, manaCost)));
16675
+ }, manaCost))));
16255
16676
  };
16256
- var Container$k = /*#__PURE__*/styled.button.withConfig({
16677
+ var Container$p = /*#__PURE__*/styled.button.withConfig({
16257
16678
  displayName: "Spell__Container",
16258
16679
  componentId: "sc-j96fa2-0"
16259
16680
  })(["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) {
@@ -16267,12 +16688,12 @@ var SpellImage = /*#__PURE__*/styled.div.withConfig({
16267
16688
  var Info = /*#__PURE__*/styled.span.withConfig({
16268
16689
  displayName: "Spell__Info",
16269
16690
  componentId: "sc-j96fa2-2"
16270
- })(["width:0;flex:1;"]);
16271
- var Title$6 = /*#__PURE__*/styled.p.withConfig({
16691
+ })(["width:0;flex:1;@media (orientation:portrait){display:none;}"]);
16692
+ var Title$7 = /*#__PURE__*/styled.p.withConfig({
16272
16693
  displayName: "Spell__Title",
16273
16694
  componentId: "sc-j96fa2-3"
16274
16695
  })(["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({
16696
+ var Description$2 = /*#__PURE__*/styled.div.withConfig({
16276
16697
  displayName: "Spell__Description",
16277
16698
  componentId: "sc-j96fa2-4"
16278
16699
  })(["font-size:", " !important;line-height:1.1 !important;"], uiFonts.size.small);
@@ -16341,7 +16762,7 @@ var Spellbook = function Spellbook(_ref) {
16341
16762
  height: "inherit",
16342
16763
  cancelDrag: "#spellbook-search, #shortcuts_list, .spell",
16343
16764
  scale: scale
16344
- }, React__default.createElement(Container$l, null, React__default.createElement(Title$7, null, "Learned Spells"), React__default.createElement(ShortcutsSetter, {
16765
+ }, React__default.createElement(Container$q, null, React__default.createElement(Title$8, null, "Learned Spells"), React__default.createElement(ShortcutsSetter, {
16345
16766
  setSettingShortcutIndex: setSettingShortcutIndex,
16346
16767
  settingShortcutIndex: settingShortcutIndex,
16347
16768
  shortcuts: shortcuts,
@@ -16366,15 +16787,16 @@ var Spellbook = function Spellbook(_ref) {
16366
16787
  onPointerUp: settingShortcutIndex !== -1 ? setShortcut : onSpellClick,
16367
16788
  spellKey: spell.key,
16368
16789
  isSettingShortcut: settingShortcutIndex !== -1,
16790
+ spell: spell,
16369
16791
  activeCooldown: spellCooldowns == null ? void 0 : spellCooldowns[spell.magicWords.replaceAll(' ', '_')]
16370
16792
  }, spell)));
16371
16793
  }))));
16372
16794
  };
16373
- var Title$7 = /*#__PURE__*/styled.h1.withConfig({
16795
+ var Title$8 = /*#__PURE__*/styled.h1.withConfig({
16374
16796
  displayName: "Spellbook__Title",
16375
16797
  componentId: "sc-r02nfq-0"
16376
16798
  })(["font-size:", " !important;margin-bottom:0 !important;"], uiFonts.size.large);
16377
- var Container$l = /*#__PURE__*/styled.div.withConfig({
16799
+ var Container$q = /*#__PURE__*/styled.div.withConfig({
16378
16800
  displayName: "Spellbook__Container",
16379
16801
  componentId: "sc-r02nfq-1"
16380
16802
  })(["width:100%;height:100%;color:white;display:flex;flex-direction:column;"]);
@@ -16388,16 +16810,16 @@ var TextArea = function TextArea(_ref) {
16388
16810
  return React__default.createElement("textarea", Object.assign({}, props));
16389
16811
  };
16390
16812
 
16391
- var img$8 = '';
16813
+ var img$9 = '';
16392
16814
 
16393
- var img$9 = '';
16815
+ var img$a = '';
16394
16816
 
16395
- var img$a = '';
16817
+ var img$b = '';
16396
16818
 
16397
16819
  var DayNightPeriod = function DayNightPeriod(_ref) {
16398
16820
  var _periodOfDaySrcFiles;
16399
16821
  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);
16822
+ var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[shared.PeriodOfDay.Morning] = img$a, _periodOfDaySrcFiles[shared.PeriodOfDay.Afternoon] = img$9, _periodOfDaySrcFiles[shared.PeriodOfDay.Night] = img$b, _periodOfDaySrcFiles);
16401
16823
  return React__default.createElement(GifContainer, null, React__default.createElement("img", {
16402
16824
  src: periodOfDaySrcFiles[periodOfDay]
16403
16825
  }));
@@ -16407,7 +16829,7 @@ var GifContainer = /*#__PURE__*/styled.div.withConfig({
16407
16829
  componentId: "sc-10t97fw-0"
16408
16830
  })(["width:100%;img{width:67%;}"]);
16409
16831
 
16410
- var img$b = '';
16832
+ var img$c = '';
16411
16833
 
16412
16834
  var TimeWidget = function TimeWidget(_ref) {
16413
16835
  var onClose = _ref.onClose,
@@ -16425,7 +16847,7 @@ var TimeWidget = function TimeWidget(_ref) {
16425
16847
  var WidgetContainer = /*#__PURE__*/styled.div.withConfig({
16426
16848
  displayName: "TimeWidget__WidgetContainer",
16427
16849
  componentId: "sc-1ja236h-0"
16428
- })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$b);
16850
+ })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$c);
16429
16851
  var Time = /*#__PURE__*/styled.div.withConfig({
16430
16852
  displayName: "TimeWidget__Time",
16431
16853
  componentId: "sc-1ja236h-1"
@@ -16611,7 +17033,7 @@ var TradingMenu = function TradingMenu(_ref) {
16611
17033
  style: {
16612
17034
  width: '100%'
16613
17035
  }
16614
- }, React__default.createElement(Title$8, null, Capitalize(type), " Menu"), React__default.createElement("hr", {
17036
+ }, React__default.createElement(Title$9, null, Capitalize(type), " Menu"), React__default.createElement("hr", {
16615
17037
  className: "golden"
16616
17038
  })), React__default.createElement(TradingComponentScrollWrapper, {
16617
17039
  id: "TraderContainer"
@@ -16641,7 +17063,7 @@ var TradingMenu = function TradingMenu(_ref) {
16641
17063
  }
16642
17064
  }, "Cancel"))));
16643
17065
  };
16644
- var Title$8 = /*#__PURE__*/styled.h1.withConfig({
17066
+ var Title$9 = /*#__PURE__*/styled.h1.withConfig({
16645
17067
  displayName: "TradingMenu__Title",
16646
17068
  componentId: "sc-1wjsz1l-0"
16647
17069
  })(["z-index:22;font-size:0.6rem;color:yellow !important;"]);
@@ -16675,230 +17097,17 @@ var Truncate = function Truncate(_ref) {
16675
17097
  var _ref$maxLines = _ref.maxLines,
16676
17098
  maxLines = _ref$maxLines === void 0 ? 1 : _ref$maxLines,
16677
17099
  children = _ref.children;
16678
- return React__default.createElement(Container$m, {
17100
+ return React__default.createElement(Container$r, {
16679
17101
  maxLines: maxLines
16680
17102
  }, children);
16681
17103
  };
16682
- var Container$m = /*#__PURE__*/styled.div.withConfig({
17104
+ var Container$r = /*#__PURE__*/styled.div.withConfig({
16683
17105
  displayName: "Truncate__Container",
16684
17106
  componentId: "sc-6x00qb-0"
16685
17107
  })(["display:-webkit-box;max-width:100%;max-height:100%;-webkit-line-clamp:", ";-webkit-box-orient:vertical;overflow:hidden;"], function (props) {
16686
17108
  return props.maxLines;
16687
17109
  });
16688
17110
 
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
17111
  exports.Button = Button;
16903
17112
  exports.CharacterSelection = CharacterSelection;
16904
17113
  exports.Chat = Chat;