@rpg-engine/long-bow 0.4.5 → 0.4.7

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 (164) hide show
  1. package/LICENSE +20 -20
  2. package/README.md +181 -181
  3. package/dist/components/SkillProgressBar.d.ts +1 -0
  4. package/dist/long-bow.cjs.development.js +1161 -1132
  5. package/dist/long-bow.cjs.development.js.map +1 -1
  6. package/dist/long-bow.cjs.production.min.js +1 -1
  7. package/dist/long-bow.cjs.production.min.js.map +1 -1
  8. package/dist/long-bow.esm.js +1238 -1209
  9. package/dist/long-bow.esm.js.map +1 -1
  10. package/package.json +100 -100
  11. package/src/components/Abstractions/ModalPortal.tsx +22 -22
  12. package/src/components/Abstractions/SlotsContainer.tsx +62 -62
  13. package/src/components/Arrow/SelectArrow.tsx +69 -69
  14. package/src/components/Arrow/img/arrow01-left-clicked.png +0 -0
  15. package/src/components/Arrow/img/arrow01-left.png +0 -0
  16. package/src/components/Arrow/img/arrow01-right-clicked.png +0 -0
  17. package/src/components/Arrow/img/arrow01-right.png +0 -0
  18. package/src/components/Arrow/img/arrow02-left-clicked.png +0 -0
  19. package/src/components/Arrow/img/arrow02-left.png +0 -0
  20. package/src/components/Arrow/img/arrow02-right-clicked.png +0 -0
  21. package/src/components/Arrow/img/arrow02-right.png +0 -0
  22. package/src/components/Button.tsx +40 -40
  23. package/src/components/Character/CharacterSelection.tsx +98 -98
  24. package/src/components/CharacterStatus/CharacterStatus.tsx +120 -120
  25. package/src/components/Chat/Chat.tsx +196 -196
  26. package/src/components/Chatdeprecated/ChatDeprecated.tsx +198 -198
  27. package/src/components/CheckButton.tsx +65 -65
  28. package/src/components/CircularController/CircularController.tsx +282 -282
  29. package/src/components/CraftBook/CraftBook.tsx +286 -286
  30. package/src/components/CraftBook/CraftingRecipe.tsx +161 -161
  31. package/src/components/CraftBook/MockItems.ts +101 -101
  32. package/src/components/DraggableContainer.tsx +180 -180
  33. package/src/components/DropdownSelectorContainer.tsx +42 -42
  34. package/src/components/Equipment/EquipmentSet.tsx +199 -199
  35. package/src/components/HistoryDialog.tsx +104 -104
  36. package/src/components/Input.tsx +15 -15
  37. package/src/components/InputRadio.tsx +41 -41
  38. package/src/components/Item/Cards/ItemInfo.tsx +298 -298
  39. package/src/components/Item/Cards/ItemInfoDisplay.tsx +135 -135
  40. package/src/components/Item/Cards/ItemInfoWrapper.tsx +62 -62
  41. package/src/components/Item/Cards/ItemTooltip.tsx +83 -83
  42. package/src/components/Item/Cards/MobileItemTooltip.tsx +149 -149
  43. package/src/components/Item/Inventory/ErrorBoundary.tsx +42 -42
  44. package/src/components/Item/Inventory/ItemContainer.tsx +231 -231
  45. package/src/components/Item/Inventory/ItemContainerTypes.ts +6 -6
  46. package/src/components/Item/Inventory/ItemQuantitySelector.tsx +138 -138
  47. package/src/components/Item/Inventory/ItemSlot.tsx +580 -580
  48. package/src/components/Item/Inventory/itemContainerHelper.ts +175 -175
  49. package/src/components/ListMenu.tsx +63 -63
  50. package/src/components/Marketplace/Marketplace.tsx +132 -132
  51. package/src/components/Marketplace/MarketplaceRows.tsx +171 -171
  52. package/src/components/Marketplace/__mocks__/index.tsx +65 -65
  53. package/src/components/Multitab/Tab.tsx +66 -66
  54. package/src/components/Multitab/TabBody.tsx +13 -13
  55. package/src/components/Multitab/TabsContainer.tsx +97 -97
  56. package/src/components/NPCDialog/NPCDialog.tsx +121 -121
  57. package/src/components/NPCDialog/NPCDialogText.tsx +113 -113
  58. package/src/components/NPCDialog/NPCMultiDialog.tsx +159 -159
  59. package/src/components/NPCDialog/QuestionDialog/QuestionDialog.tsx +237 -237
  60. package/src/components/ProgressBar.tsx +95 -95
  61. package/src/components/PropertySelect/PropertySelect.tsx +106 -106
  62. package/src/components/QuestInfo/QuestInfo.tsx +233 -233
  63. package/src/components/QuestList.tsx +135 -135
  64. package/src/components/RPGUIContainer.tsx +47 -47
  65. package/src/components/RPGUIForceRenderStart.tsx +45 -45
  66. package/src/components/RPGUIRoot.tsx +14 -14
  67. package/src/components/RadioButton.tsx +53 -53
  68. package/src/components/RadioInput/RadioButton.tsx +96 -96
  69. package/src/components/RadioInput/RadioInput.tsx +102 -102
  70. package/src/components/RadioInput/instruments.ts +15 -15
  71. package/src/components/RangeSlider.tsx +78 -78
  72. package/src/components/RelativeListMenu.tsx +90 -90
  73. package/src/components/ScrollList.tsx +79 -79
  74. package/src/components/Shortcuts/Shortcuts.tsx +193 -193
  75. package/src/components/Shortcuts/ShortcutsSetter.tsx +139 -139
  76. package/src/components/Shortcuts/SingleShortcut.ts +82 -82
  77. package/src/components/Shortcuts/useShortcutCooldown.ts +23 -23
  78. package/src/components/SimpleProgressBar.tsx +62 -62
  79. package/src/components/SkillProgressBar.tsx +198 -133
  80. package/src/components/SkillsContainer.tsx +213 -211
  81. package/src/components/Spellbook/Spell.tsx +236 -236
  82. package/src/components/Spellbook/Spellbook.tsx +161 -161
  83. package/src/components/Spellbook/cards/MobileSpellTooltip.tsx +137 -137
  84. package/src/components/Spellbook/cards/SpellInfo.tsx +134 -134
  85. package/src/components/Spellbook/cards/SpellInfoDisplay.tsx +31 -31
  86. package/src/components/Spellbook/cards/SpellInfoWrapper.tsx +48 -48
  87. package/src/components/Spellbook/cards/SpellTooltip.tsx +70 -70
  88. package/src/components/Spellbook/constants.ts +7 -7
  89. package/src/components/Spellbook/mockSpells.ts +84 -84
  90. package/src/components/StaticBook/StaticBook.tsx +103 -103
  91. package/src/components/TextArea.tsx +11 -11
  92. package/src/components/TimeWidget/DayNightPeriod/DayNightPeriod.tsx +35 -35
  93. package/src/components/TimeWidget/TimeWidget.tsx +65 -65
  94. package/src/components/TradingMenu/TradingItemRow.tsx +199 -199
  95. package/src/components/TradingMenu/TradingMenu.tsx +219 -219
  96. package/src/components/TradingMenu/items.mock.ts +48 -48
  97. package/src/components/Truncate.tsx +25 -25
  98. package/src/components/itemSelector/ItemSelector.tsx +136 -136
  99. package/src/components/shared/Column.tsx +16 -16
  100. package/src/components/shared/Ellipsis.tsx +68 -68
  101. package/src/components/shared/SpriteFromAtlas.tsx +104 -104
  102. package/src/components/typography/DynamicText.tsx +49 -49
  103. package/src/constants/uiColors.ts +20 -20
  104. package/src/constants/uiDevices.ts +3 -3
  105. package/src/constants/uiFonts.ts +12 -12
  106. package/src/hooks/useEventListener.ts +21 -21
  107. package/src/hooks/useOutsideAlerter.ts +25 -25
  108. package/src/index.tsx +42 -42
  109. package/src/libs/CastingTypeHelper.ts +7 -7
  110. package/src/libs/StringHelpers.ts +3 -3
  111. package/src/libs/itemCounter.ts +21 -21
  112. package/src/mocks/atlas/entities/entities.json +20215 -20215
  113. package/src/mocks/atlas/icons/icons.json +735 -735
  114. package/src/mocks/atlas/items/items.json +12086 -12086
  115. package/src/mocks/equipmentSet.mocks.ts +391 -391
  116. package/src/mocks/itemContainer.mocks.ts +605 -605
  117. package/src/mocks/skills.mocks.ts +130 -128
  118. package/src/stories/Arrow.stories.tsx +26 -26
  119. package/src/stories/Button.stories.tsx +36 -36
  120. package/src/stories/CharacterSelection.stories.tsx +44 -44
  121. package/src/stories/CharacterStatus.stories.tsx +29 -29
  122. package/src/stories/Chat.stories.tsx +187 -187
  123. package/src/stories/ChatDeprecated.stories.tsx +170 -170
  124. package/src/stories/CheckButton.stories.tsx +48 -48
  125. package/src/stories/CircullarController.stories.tsx +37 -37
  126. package/src/stories/CraftBook.stories.tsx +42 -42
  127. package/src/stories/DayNightPeriod.stories.tsx +27 -27
  128. package/src/stories/DraggableContainer.stories.tsx +28 -28
  129. package/src/stories/Dropdown.stories.tsx +46 -46
  130. package/src/stories/DropdownSelectorContainer.stories.tsx +41 -41
  131. package/src/stories/EquipmentSet.stories.tsx +65 -65
  132. package/src/stories/HistoryDialog.stories.tsx +61 -61
  133. package/src/stories/ItemContainer.stories.tsx +201 -201
  134. package/src/stories/ItemInfoDisplay.stories.tsx +33 -33
  135. package/src/stories/ItemQuantitySelector.stories.tsx +26 -26
  136. package/src/stories/ItemSelector.stories.tsx +77 -77
  137. package/src/stories/ItemTradingComponent.stories.tsx +35 -35
  138. package/src/stories/ListMenu.stories.tsx +56 -56
  139. package/src/stories/Marketplace.stories.tsx +42 -42
  140. package/src/stories/MarketplaceRows.stories.tsx +28 -28
  141. package/src/stories/Multitab.stories.tsx +51 -51
  142. package/src/stories/NPCDialog.stories.tsx +130 -130
  143. package/src/stories/NPCMultiDialog.stories.tsx +71 -71
  144. package/src/stories/ProgressBar.stories.tsx +23 -23
  145. package/src/stories/PropertySelect.stories.tsx +40 -40
  146. package/src/stories/QuestInfo.stories.tsx +107 -107
  147. package/src/stories/QuestList.stories.tsx +82 -82
  148. package/src/stories/RPGUIContainers.stories.tsx +42 -42
  149. package/src/stories/RadioButton.stories.tsx +49 -49
  150. package/src/stories/RadioInput.stories.tsx +34 -34
  151. package/src/stories/RangeSlider.stories.tsx +64 -64
  152. package/src/stories/ScrollList.stories.tsx +85 -85
  153. package/src/stories/Shortcuts.stories.tsx +39 -39
  154. package/src/stories/SimpleProgressBar.stories.tsx +22 -22
  155. package/src/stories/SkillProgressBar.stories.tsx +34 -34
  156. package/src/stories/SkillsContainer.stories.tsx +35 -35
  157. package/src/stories/SpellInfoDisplay.stories.tsx +27 -27
  158. package/src/stories/Spellbook.stories.tsx +104 -104
  159. package/src/stories/StaticBook.stories.tsx +32 -32
  160. package/src/stories/Text.stories.tsx +42 -42
  161. package/src/stories/TimeWidget.stories.tsx +27 -27
  162. package/src/stories/TradingMenu.stories.tsx +47 -47
  163. package/src/types/eventTypes.ts +4 -4
  164. 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
- }));
14833
+ var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
14834
+ var answerIds = currentQuestion.answerIds;
14835
+ if (!answerIds) {
14836
+ return null;
14967
14837
  }
14968
- return slots;
14838
+ var answers = onGetAnswers(answerIds);
14839
+ if (!answers) {
14840
+ return null;
14841
+ }
14842
+ return answers.map(function (answer) {
14843
+ var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
14844
+ var selectedColor = isSelected ? 'yellow' : 'white';
14845
+ if (answer) {
14846
+ return React__default.createElement(AnswerRow, {
14847
+ key: "answer_" + answer.id
14848
+ }, React__default.createElement(AnswerSelectedIcon, {
14849
+ color: selectedColor
14850
+ }, isSelected ? 'X' : null), React__default.createElement(Answer, {
14851
+ key: answer.id,
14852
+ onPointerDown: function onPointerDown() {
14853
+ return onAnswerClick(answer);
14854
+ },
14855
+ color: selectedColor
14856
+ }, answer.text));
14857
+ }
14858
+ return null;
14859
+ });
14969
14860
  };
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
- });
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);
14995
14865
  },
14996
- onClose: function onClose() {
14997
- quantitySelect.callback(-1);
14998
- setQuantitySelect({
14999
- isOpen: false,
15000
- maxQuantity: 1,
15001
- callback: function callback() {}
15002
- });
14866
+ onFinish: function onFinish() {
14867
+ return setCanShowAnswers(true);
15003
14868
  }
15004
- }))));
14869
+ })), canShowAnswers && React__default.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
15005
14870
  };
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);"]);
14871
+ var Container$f = /*#__PURE__*/styled.div.withConfig({
14872
+ displayName: "QuestionDialog__Container",
14873
+ componentId: "sc-bxc5u0-0"
14874
+ })(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
14875
+ var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
14876
+ displayName: "QuestionDialog__QuestionContainer",
14877
+ componentId: "sc-bxc5u0-1"
14878
+ })(["flex:100%;width:100%;"]);
14879
+ var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
14880
+ displayName: "QuestionDialog__AnswersContainer",
14881
+ componentId: "sc-bxc5u0-2"
14882
+ })(["flex:100%;"]);
14883
+ var Answer = /*#__PURE__*/styled.p.withConfig({
14884
+ displayName: "QuestionDialog__Answer",
14885
+ componentId: "sc-bxc5u0-3"
14886
+ })(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
14887
+ return props.color;
14888
+ });
14889
+ var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
14890
+ displayName: "QuestionDialog__AnswerSelectedIcon",
14891
+ componentId: "sc-bxc5u0-4"
14892
+ })(["flex:5% 0 0;color:", " !important;"], function (props) {
14893
+ return props.color;
14894
+ });
14895
+ var AnswerRow = /*#__PURE__*/styled.div.withConfig({
14896
+ displayName: "QuestionDialog__AnswerRow",
14897
+ componentId: "sc-bxc5u0-5"
14898
+ })(["display:flex;flex-wrap:wrap;justify-content:center;align-items:center;margin-bottom:0.5rem;height:22px;p{line-height:unset;margin-top:0;margin-bottom:0rem;}"]);
15014
14899
 
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();
14900
+ var img$7 = '';
14901
+
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();
15041
14927
  }
15042
14928
  }
15043
- }, React__default.createElement("div", {
15044
- style: {
15045
- width: '100%'
15046
- }
15047
- }, React__default.createElement(Title$3, null, 'Harvesting instruments'), React__default.createElement(Subtitle$1, null, 'Use the tool, you need it'), React__default.createElement("hr", {
15048
- className: "golden"
15049
- })), React__default.createElement(RadioInputScroller$1, null, options == null ? void 0 : options.map(function (option, index) {
15050
- return React__default.createElement(RadioOptionsWrapper$1, {
15051
- key: index
15052
- }, React__default.createElement(SpriteAtlasWrapper$1, null, React__default.createElement(SpriteFromAtlas, {
15053
- atlasIMG: atlasIMG,
15054
- atlasJSON: atlasJSON,
15055
- spriteKey: option.imageKey,
15056
- imgScale: 3
15057
- })), React__default.createElement("div", null, React__default.createElement("input", {
15058
- className: "rpgui-radio",
15059
- type: "radio",
15060
- value: option.name,
15061
- name: "test"
15062
- }), React__default.createElement("label", {
15063
- onPointerDown: handleClick,
15064
- style: {
15065
- display: 'flex',
15066
- alignItems: 'center'
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();
15067
14939
  }
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")));
14940
+ }
14941
+ })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
14942
+ src: imagePath || img$7
14943
+ })))));
15075
14944
  };
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'
15113
- }
15114
- }, options.map(function (params, index) {
15115
- return React__default.createElement(ListElement$1, {
15116
- key: (params == null ? void 0 : params.id) || index,
15117
- onPointerDown: function onPointerDown() {
15118
- onSelected(params == null ? void 0 : params.id);
15119
- }
15120
- }, (params == null ? void 0 : params.text) || 'No text');
15121
- })));
15122
- };
15123
- var Container$f = /*#__PURE__*/styled.div.withConfig({
15124
- displayName: "ListMenu__Container",
15125
- componentId: "sc-i9097t-0"
15126
- })(["display:flex;flex-direction:column;width:100%;justify-content:start;align-items:flex-start;position:absolute;top:", "px;left:", "px;li{font-size:", ";}"], function (props) {
15127
- return props.y || 0;
15128
- }, function (props) {
15129
- return props.x || 0;
15130
- }, uiFonts.size.xsmall);
15131
- var ListElement$1 = /*#__PURE__*/styled.li.withConfig({
15132
- displayName: "ListMenu__ListElement",
15133
- componentId: "sc-i9097t-1"
15134
- })(["margin-right:0.5rem;"]);
15135
-
15136
- var MarketplaceRows = function MarketplaceRows(_ref) {
15137
- var atlasJSON = _ref.atlasJSON,
15138
- atlasIMG = _ref.atlasIMG,
15139
- item = _ref.item,
15140
- itemPrice = _ref.itemPrice,
15141
- equipmentSet = _ref.equipmentSet,
15142
- scale = _ref.scale,
15143
- onHandleClick = _ref.onHandleClick;
15144
- return React__default.createElement(MarketPlaceWrapper, null, React__default.createElement(ItemIconContainer, null, React__default.createElement(SpriteContainer, null, React__default.createElement(ItemInfoWrapper, {
15145
- item: item,
15146
- atlasIMG: atlasIMG,
15147
- atlasJSON: atlasJSON,
15148
- equipmentSet: equipmentSet,
15149
- scale: scale
15150
- }, React__default.createElement(SpriteFromAtlas, {
15151
- atlasIMG: atlasIMG,
15152
- atlasJSON: atlasJSON,
15153
- spriteKey: shared.getItemTextureKeyPath({
15154
- key: item.key,
15155
- stackQty: item.stackQty || 1,
15156
- texturePath: item.texturePath,
15157
- isStackable: item.isStackable
15158
- }, atlasJSON),
15159
- imgScale: 2
15160
- }))), React__default.createElement(PriceValue, null, React__default.createElement("p", null, React__default.createElement(Ellipsis, {
15161
- maxLines: 1,
15162
- maxWidth: "150px",
15163
- fontSize: "10px"
15164
- }, item.name)))), React__default.createElement(QuantityContainer, null, React__default.createElement(QuantityDisplay, null, React__default.createElement(TextOverlay$1, null, React__default.createElement(Item$1, null, React__default.createElement(Ellipsis, {
15165
- maxLines: 1,
15166
- maxWidth: "150px",
15167
- fontSize: "10px"
15168
- }, item.rarity))))), React__default.createElement(ItemIconContainer, null, React__default.createElement(SpriteContainer, null, React__default.createElement(SpriteFromAtlas, {
15169
- atlasIMG: atlasIMG,
15170
- atlasJSON: atlasJSON,
15171
- spriteKey: 'others/gold-coin-qty-4.png',
15172
- imgScale: 2
15173
- })), React__default.createElement(PriceValue, null, React__default.createElement("p", null, React__default.createElement(Ellipsis, {
15174
- maxLines: 1,
15175
- maxWidth: "150px",
15176
- fontSize: "10px"
15177
- }, "$", itemPrice)))), React__default.createElement(ButtonContainer$1, null, React__default.createElement(Button, {
15178
- buttonType: exports.ButtonTypes.RPGUIButton,
15179
- onClick: function onClick() {
15180
- return onHandleClick(item.name);
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;"]);
15289
-
15290
- var img$5 = '';
15291
-
15292
- var img$6 = '';
14945
+ var Container$g = /*#__PURE__*/styled.div.withConfig({
14946
+ displayName: "NPCDialog__Container",
14947
+ componentId: "sc-1b4aw74-0"
14948
+ })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
14949
+ var TextContainer$1 = /*#__PURE__*/styled.div.withConfig({
14950
+ displayName: "NPCDialog__TextContainer",
14951
+ componentId: "sc-1b4aw74-1"
14952
+ })(["flex:", " 0 0;width:355px;"], function (_ref2) {
14953
+ var flex = _ref2.flex;
14954
+ return flex;
14955
+ });
14956
+ var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
14957
+ displayName: "NPCDialog__ThumbnailContainer",
14958
+ componentId: "sc-1b4aw74-2"
14959
+ })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
14960
+ var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
14961
+ displayName: "NPCDialog__NPCThumbnail",
14962
+ componentId: "sc-1b4aw74-3"
14963
+ })(["image-rendering:pixelated;height:128px;width:128px;"]);
15293
14964
 
15294
14965
  (function (ImgSide) {
15295
14966
  ImgSide["right"] = "right";
@@ -15327,7 +14998,7 @@ var NPCMultiDialog = function NPCMultiDialog(_ref) {
15327
14998
  type: exports.RPGUIContainerTypes.FramedGold,
15328
14999
  width: '50%',
15329
15000
  height: '180px'
15330
- }, React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$g, null, ((_textAndTypeArray$sli = textAndTypeArray[slide]) == null ? void 0 : _textAndTypeArray$sli.imageSide) === 'right' && React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer, {
15001
+ }, React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$h, null, ((_textAndTypeArray$sli = textAndTypeArray[slide]) == null ? void 0 : _textAndTypeArray$sli.imageSide) === 'right' && React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer$2, {
15331
15002
  flex: '70%'
15332
15003
  }, React__default.createElement(NPCDialogText, {
15333
15004
  onStartStep: function onStartStep() {
@@ -15342,14 +15013,14 @@ var NPCMultiDialog = function NPCMultiDialog(_ref) {
15342
15013
  _onClose();
15343
15014
  }
15344
15015
  }
15345
- })), React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
15346
- src: textAndTypeArray[slide].imagePath || img$5
15347
- })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator, {
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, {
15348
15019
  right: '10.5rem',
15349
15020
  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, {
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, {
15353
15024
  flex: '70%'
15354
15025
  }, React__default.createElement(NPCDialogText, {
15355
15026
  onStartStep: function onStartStep() {
@@ -15364,31 +15035,31 @@ var NPCMultiDialog = function NPCMultiDialog(_ref) {
15364
15035
  _onClose();
15365
15036
  }
15366
15037
  }
15367
- })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator, {
15038
+ })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator$1, {
15368
15039
  right: '1rem',
15369
15040
  src: img$6
15370
15041
  }))), ")"));
15371
15042
  };
15372
- var Container$g = /*#__PURE__*/styled.div.withConfig({
15043
+ var Container$h = /*#__PURE__*/styled.div.withConfig({
15373
15044
  displayName: "NPCMultiDialog__Container",
15374
15045
  componentId: "sc-rvu5wg-0"
15375
15046
  })(["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({
15047
+ var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
15377
15048
  displayName: "NPCMultiDialog__TextContainer",
15378
15049
  componentId: "sc-rvu5wg-1"
15379
15050
  })(["flex:", " 0 0;width:355px;"], function (_ref2) {
15380
15051
  var flex = _ref2.flex;
15381
15052
  return flex;
15382
15053
  });
15383
- var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
15054
+ var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
15384
15055
  displayName: "NPCMultiDialog__ThumbnailContainer",
15385
15056
  componentId: "sc-rvu5wg-2"
15386
15057
  })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
15387
- var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
15058
+ var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
15388
15059
  displayName: "NPCMultiDialog__NPCThumbnail",
15389
15060
  componentId: "sc-rvu5wg-3"
15390
15061
  })(["image-rendering:pixelated;height:128px;width:128px;"]);
15391
- var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
15062
+ var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
15392
15063
  displayName: "NPCMultiDialog__PressSpaceIndicator",
15393
15064
  componentId: "sc-rvu5wg-4"
15394
15065
  })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref3) {
@@ -15396,221 +15067,763 @@ var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
15396
15067
  return right;
15397
15068
  });
15398
15069
 
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]);
15418
- };
15419
-
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];
15427
- 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();
15434
- }
15435
- }
15436
- if (i < text.length) {
15437
- setTextState(text.substring(0, i + 1));
15438
- i++;
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
+ });
15439
15088
  } else {
15440
- clearInterval(interval);
15441
- if (onFinish) {
15442
- onFinish();
15443
- }
15089
+ // if there's no more text chunks, close the dialog
15090
+ onClose();
15444
15091
  }
15445
- }, 50);
15092
+ }
15093
+ };
15094
+ React.useEffect(function () {
15095
+ document.addEventListener('keydown', onHandleSpacePress);
15446
15096
  return function () {
15447
- clearInterval(interval);
15097
+ return document.removeEventListener('keydown', onHandleSpacePress);
15448
15098
  };
15449
- }, [text]);
15450
- return React__default.createElement(TextContainer$1, null, textState);
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
+ })));
15451
15120
  };
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;"]);
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;"]);
15456
15133
 
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;
15470
- }
15471
- var firstAnswerId = currentQuestion.answerIds[0];
15472
- return answers.find(function (answer) {
15473
- return answer.id === firstAnswerId;
15474
- });
15475
- };
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
- });
15488
- };
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;
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
15503
15161
  });
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;
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
15511
15171
  });
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;
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
15515
15181
  });
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;
15533
- }
15534
- };
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();
15546
- }
15547
- };
15548
- var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
15549
- var answerIds = currentQuestion.answerIds;
15550
- if (!answerIds) {
15551
- return null;
15552
- }
15553
- var answers = onGetAnswers(answerIds);
15554
- if (!answers) {
15555
- return null;
15556
- }
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));
15572
15182
  }
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);
15580
15183
  },
15581
- onFinish: function onFinish() {
15582
- return setCanShowAnswers(true);
15583
- }
15584
- })), canShowAnswers && React__default.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
15184
+ onOutsideClick: onOutsideClick,
15185
+ initialPosition: initialPosition,
15186
+ scale: scale
15187
+ }, children);
15585
15188
  };
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;}"]);
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'
15216
+ },
15217
+ className: "rpgui-slider-container " + typeClass,
15218
+ id: "rpgui-slider-" + sliderId,
15219
+ ref: containerRef
15220
+ }, React__default.createElement("div", {
15221
+ style: {
15222
+ pointerEvents: 'none'
15223
+ }
15224
+ }, React__default.createElement("div", {
15225
+ className: "rpgui-slider-track " + typeClass
15226
+ }), React__default.createElement("div", {
15227
+ className: "rpgui-slider-left-edge " + typeClass
15228
+ }), React__default.createElement("div", {
15229
+ className: "rpgui-slider-right-edge " + typeClass
15230
+ }), React__default.createElement("div", {
15231
+ className: "rpgui-slider-thumb " + typeClass,
15232
+ style: {
15233
+ left: left
15234
+ }
15235
+ })), React__default.createElement(Input$1, {
15236
+ type: "range",
15237
+ style: {
15238
+ width: width
15239
+ },
15240
+ min: valueMin,
15241
+ max: valueMax,
15242
+ onChange: function onChange(e) {
15243
+ return _onChange(Number(e.target.value));
15244
+ },
15245
+ value: value,
15246
+ className: "rpgui-cursor-point"
15247
+ }));
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;"]);
15253
+
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);
15262
+ React.useEffect(function () {
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();
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;
15293
+ }
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'
15371
+ }
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
+ })));
15396
+ };
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;"]);
15412
+
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);
15452
+ }
15453
+ };
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;
15507
+ };
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
+ });
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);
15566
+ };
15567
+ React.useEffect(function () {
15568
+ if (selectedValue) {
15569
+ onSelect(selectedValue);
15570
+ }
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
+ }
15580
+ }
15581
+ }, React__default.createElement("div", {
15582
+ style: {
15583
+ width: '100%'
15584
+ }
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'
15605
+ }
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();
15778
+ },
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
+ }))));
15810
+ };
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,
@@ -15631,7 +15844,7 @@ var ProgressBar = function ProgressBar(_ref) {
15631
15844
  }
15632
15845
  return value * 100 / max;
15633
15846
  };
15634
- return React__default.createElement(Container$i, {
15847
+ return React__default.createElement(Container$k, {
15635
15848
  className: "rpgui-progress",
15636
15849
  "data-value": calculatePercentageValue(max, value) / 100,
15637
15850
  "data-rpguitype": "progress",
@@ -15660,7 +15873,7 @@ var TextOverlay$2 = /*#__PURE__*/styled.div.withConfig({
15660
15873
  displayName: "ProgressBar__TextOverlay",
15661
15874
  componentId: "sc-qa6fzh-1"
15662
15875
  })(["width:100%;position:relative;"]);
15663
- var Container$i = /*#__PURE__*/styled.div.withConfig({
15876
+ var Container$k = /*#__PURE__*/styled.div.withConfig({
15664
15877
  displayName: "ProgressBar__Container",
15665
15878
  componentId: "sc-qa6fzh-2"
15666
15879
  })(["display:flex;flex-direction:column;min-width:", "px;width:", "%;justify-content:start;align-items:flex-start;", ""], function (props) {
@@ -15671,7 +15884,7 @@ var Container$i = /*#__PURE__*/styled.div.withConfig({
15671
15884
  return props.style;
15672
15885
  });
15673
15886
 
15674
- var img$7 = '';
15887
+ var img$8 = '';
15675
15888
 
15676
15889
  var QuestInfo = function QuestInfo(_ref) {
15677
15890
  var quests = _ref.quests,
@@ -15715,7 +15928,7 @@ var QuestInfo = function QuestInfo(_ref) {
15715
15928
  }), React__default.createElement(QuestContainer, null, React__default.createElement(TitleContainer$1, {
15716
15929
  className: "drag-handler"
15717
15930
  }, React__default.createElement(Title$4, null, React__default.createElement(Thumbnail, {
15718
- src: quests[currentIndex].thumbnail || img$7
15931
+ src: quests[currentIndex].thumbnail || img$8
15719
15932
  }), quests[currentIndex].title), React__default.createElement(QuestSplitDiv, null, React__default.createElement("hr", {
15720
15933
  className: "golden"
15721
15934
  }))), React__default.createElement(Content, null, React__default.createElement("p", null, quests[currentIndex].description)), React__default.createElement(QuestColumn, {
@@ -15734,7 +15947,7 @@ var QuestInfo = function QuestInfo(_ref) {
15734
15947
  })))) : React__default.createElement(QuestsContainer, null, React__default.createElement(QuestContainer, null, React__default.createElement(TitleContainer$1, {
15735
15948
  className: "drag-handler"
15736
15949
  }, React__default.createElement(Title$4, null, React__default.createElement(Thumbnail, {
15737
- src: quests[0].thumbnail || img$7
15950
+ src: quests[0].thumbnail || img$8
15738
15951
  }), quests[0].title), React__default.createElement(QuestSplitDiv, null, React__default.createElement("hr", {
15739
15952
  className: "golden"
15740
15953
  }))), React__default.createElement(Content, null, React__default.createElement("p", null, quests[0].description)), React__default.createElement(QuestColumn, {
@@ -15999,7 +16212,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
15999
16212
  bgColor = _ref$bgColor === void 0 ? 'red' : _ref$bgColor,
16000
16213
  _ref$margin = _ref.margin,
16001
16214
  margin = _ref$margin === void 0 ? 20 : _ref$margin;
16002
- return React__default.createElement(Container$j, {
16215
+ return React__default.createElement(Container$l, {
16003
16216
  className: "simple-progress-bar"
16004
16217
  }, React__default.createElement(ProgressBarContainer, {
16005
16218
  margin: margin
@@ -16008,7 +16221,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
16008
16221
  bgColor: bgColor
16009
16222
  }))));
16010
16223
  };
16011
- var Container$j = /*#__PURE__*/styled.div.withConfig({
16224
+ var Container$l = /*#__PURE__*/styled.div.withConfig({
16012
16225
  displayName: "SimpleProgressBar__Container",
16013
16226
  componentId: "sc-mbeil3-0"
16014
16227
  })(["display:flex;justify-content:center;align-items:center;width:100%;"]);
@@ -16041,13 +16254,20 @@ var SkillProgressBar = function SkillProgressBar(_ref) {
16041
16254
  _ref$showSkillPoints = _ref.showSkillPoints,
16042
16255
  showSkillPoints = _ref$showSkillPoints === void 0 ? true : _ref$showSkillPoints,
16043
16256
  atlasIMG = _ref.atlasIMG,
16044
- atlasJSON = _ref.atlasJSON;
16257
+ atlasJSON = _ref.atlasJSON,
16258
+ buffAndDebuff = _ref.buffAndDebuff;
16045
16259
  if (!skillPointsToNextLevel) {
16046
16260
  skillPointsToNextLevel = shared.getSPForLevel(level + 1);
16047
16261
  }
16048
16262
  var nextLevelSPWillbe = skillPoints + skillPointsToNextLevel;
16049
16263
  var ratio = skillPoints / nextLevelSPWillbe * 100;
16050
- return React__default.createElement(React__default.Fragment, null, React__default.createElement(ProgressTitle, null, React__default.createElement(TitleName, null, skillName), React__default.createElement(ValueDisplay, null, "lv ", level)), React__default.createElement(ProgressBody, null, React__default.createElement(ProgressIconContainer, null, atlasIMG && atlasJSON ? React__default.createElement(SpriteContainer$1, null, React__default.createElement(ErrorBoundary, null, React__default.createElement(SpriteFromAtlas, {
16264
+ var skillsBuffsCalc = function skillsBuffsCalc() {
16265
+ if (buffAndDebuff) {
16266
+ return 1 + buffAndDebuff / 100;
16267
+ }
16268
+ return;
16269
+ };
16270
+ return React__default.createElement(React__default.Fragment, null, React__default.createElement(ProgressTitle, null, buffAndDebuff !== undefined && React__default.createElement(React__default.Fragment, null, buffAndDebuff > 0 ? React__default.createElement(BuffAndDebuffContainer, null, React__default.createElement(TitleNameContainer, null, React__default.createElement(TitleNameBuff, null, skillName), React__default.createElement(TitleNameBuff, null, "lv ", level, " (", skillsBuffsCalc(), ")")), React__default.createElement(TitleNameBuffContainer, null, React__default.createElement(TitleNameBuff, null, "(+", buffAndDebuff, "%)"))) : buffAndDebuff < 0 ? React__default.createElement(React__default.Fragment, null, React__default.createElement(TitleNameContainer, null, React__default.createElement(TitleNameDebuff, null, skillName), React__default.createElement(TitleNameDebuff, null, "lv ", level, " (", skillsBuffsCalc(), ")")), React__default.createElement("div", null, React__default.createElement(TitleNameDebuff, null, "(", buffAndDebuff, "%)"))) : React__default.createElement(TitleName, null, skillName)), !buffAndDebuff && React__default.createElement(TitleNameContainer, null, React__default.createElement(TitleName, null, skillName), React__default.createElement(ValueDisplay, null, "lv ", level))), React__default.createElement(ProgressBody, null, React__default.createElement(ProgressIconContainer, null, atlasIMG && atlasJSON ? React__default.createElement(SpriteContainer$1, null, React__default.createElement(ErrorBoundary, null, React__default.createElement(SpriteFromAtlas, {
16051
16271
  atlasIMG: atlasIMG,
16052
16272
  atlasJSON: atlasJSON,
16053
16273
  spriteKey: texturePath,
@@ -16079,22 +16299,42 @@ var TitleName = /*#__PURE__*/styled.span.withConfig({
16079
16299
  displayName: "SkillProgressBar__TitleName",
16080
16300
  componentId: "sc-5vuroc-4"
16081
16301
  })(["margin-left:5px;"]);
16302
+ var TitleNameBuff = /*#__PURE__*/styled.span.withConfig({
16303
+ displayName: "SkillProgressBar__TitleNameBuff",
16304
+ componentId: "sc-5vuroc-5"
16305
+ })(["margin-left:5px;color:", " !important;"], uiColors.lightGreen);
16306
+ var TitleNameDebuff = /*#__PURE__*/styled.span.withConfig({
16307
+ displayName: "SkillProgressBar__TitleNameDebuff",
16308
+ componentId: "sc-5vuroc-6"
16309
+ })(["margin-left:5px;color:", " !important;"], uiColors.red);
16082
16310
  var ValueDisplay = /*#__PURE__*/styled.span.withConfig({
16083
16311
  displayName: "SkillProgressBar__ValueDisplay",
16084
- componentId: "sc-5vuroc-5"
16312
+ componentId: "sc-5vuroc-7"
16085
16313
  })([""]);
16086
16314
  var ProgressIconContainer = /*#__PURE__*/styled.div.withConfig({
16087
16315
  displayName: "SkillProgressBar__ProgressIconContainer",
16088
- componentId: "sc-5vuroc-6"
16316
+ componentId: "sc-5vuroc-8"
16089
16317
  })(["display:flex;justify-content:center;align-items:center;"]);
16090
16318
  var ProgressBody = /*#__PURE__*/styled.div.withConfig({
16091
16319
  displayName: "SkillProgressBar__ProgressBody",
16092
- componentId: "sc-5vuroc-7"
16320
+ componentId: "sc-5vuroc-9"
16093
16321
  })(["display:flex;flex-direction:row;width:100%;"]);
16094
16322
  var ProgressTitle = /*#__PURE__*/styled.div.withConfig({
16095
16323
  displayName: "SkillProgressBar__ProgressTitle",
16096
- componentId: "sc-5vuroc-8"
16097
- })(["width:100%;display:flex;flex-direction:row;justify-content:space-between;span{font-size:0.6rem;}"]);
16324
+ componentId: "sc-5vuroc-10"
16325
+ })(["width:100%;display:flex;flex-direction:column;justify-content:space-between;span{font-size:0.6rem;}"]);
16326
+ var BuffAndDebuffContainer = /*#__PURE__*/styled.div.withConfig({
16327
+ displayName: "SkillProgressBar__BuffAndDebuffContainer",
16328
+ componentId: "sc-5vuroc-11"
16329
+ })([""]);
16330
+ var TitleNameBuffContainer = /*#__PURE__*/styled.div.withConfig({
16331
+ displayName: "SkillProgressBar__TitleNameBuffContainer",
16332
+ componentId: "sc-5vuroc-12"
16333
+ })([""]);
16334
+ var TitleNameContainer = /*#__PURE__*/styled.div.withConfig({
16335
+ displayName: "SkillProgressBar__TitleNameContainer",
16336
+ componentId: "sc-5vuroc-13"
16337
+ })(["display:flex;justify-content:space-between;"]);
16098
16338
 
16099
16339
  var skillProps = {
16100
16340
  attributes: {
@@ -16181,7 +16421,8 @@ var SkillsContainer = function SkillsContainer(_ref) {
16181
16421
  skillPointsToNextLevel: Math.round(skillDetails.skillPointsToNextLevel) || 0,
16182
16422
  texturePath: value,
16183
16423
  atlasIMG: atlasIMG,
16184
- atlasJSON: atlasJSON
16424
+ atlasJSON: atlasJSON,
16425
+ buffAndDebuff: skillDetails.buffAndDebuff
16185
16426
  }));
16186
16427
  }
16187
16428
  return output;
@@ -16189,7 +16430,8 @@ var SkillsContainer = function SkillsContainer(_ref) {
16189
16430
  return React__default.createElement(SkillsDraggableContainer, {
16190
16431
  title: "Skills",
16191
16432
  cancelDrag: "#skillsDiv",
16192
- scale: scale
16433
+ scale: scale,
16434
+ width: "100%"
16193
16435
  }, onCloseButton && React__default.createElement(CloseButton$3, {
16194
16436
  onPointerDown: onCloseButton
16195
16437
  }, "X"), React__default.createElement(SkillsContainerDiv, {
@@ -16216,7 +16458,7 @@ var SkillsContainer = function SkillsContainer(_ref) {
16216
16458
  var SkillsDraggableContainer = /*#__PURE__*/styled(DraggableContainer).withConfig({
16217
16459
  displayName: "SkillsContainer__SkillsDraggableContainer",
16218
16460
  componentId: "sc-1g0c67q-0"
16219
- })(["border:1px solid black;max-width:380px;height:90%;.DraggableContainer__TitleContainer-sc-184mpyl-2{width:auto;height:auto;}"]);
16461
+ })(["border:1px solid black;max-width:450px;height:90%;.DraggableContainer__TitleContainer-sc-184mpyl-2{width:auto;height:auto;}"]);
16220
16462
  var SkillsContainerDiv = /*#__PURE__*/styled.div.withConfig({
16221
16463
  displayName: "SkillsContainer__SkillsContainerDiv",
16222
16464
  componentId: "sc-1g0c67q-1"
@@ -16247,7 +16489,7 @@ var SpellInfo = function SpellInfo(_ref) {
16247
16489
  castingType = spell.castingType,
16248
16490
  cooldown = spell.cooldown,
16249
16491
  maxDistanceGrid = spell.maxDistanceGrid;
16250
- return React__default.createElement(Container$k, 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", {
16492
+ 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", {
16251
16493
  className: "label"
16252
16494
  }, "Casting Type:"), React__default.createElement("div", {
16253
16495
  className: "value"
@@ -16273,7 +16515,7 @@ var SpellInfo = function SpellInfo(_ref) {
16273
16515
  className: "value"
16274
16516
  }, requiredItem))), React__default.createElement(Description$1, null, description));
16275
16517
  };
16276
- var Container$k = /*#__PURE__*/styled.div.withConfig({
16518
+ var Container$m = /*#__PURE__*/styled.div.withConfig({
16277
16519
  displayName: "SpellInfo__Container",
16278
16520
  componentId: "sc-4hbw3q-0"
16279
16521
  })(["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);
@@ -16327,7 +16569,7 @@ var MobileSpellTooltip = function MobileSpellTooltip(_ref) {
16327
16569
  var _ref$current;
16328
16570
  (_ref$current = ref.current) == null ? void 0 : _ref$current.classList.add('fadeOut');
16329
16571
  };
16330
- return React__default.createElement(ModalPortal, null, React__default.createElement(Container$l, {
16572
+ return React__default.createElement(ModalPortal, null, React__default.createElement(Container$n, {
16331
16573
  ref: ref,
16332
16574
  onTouchEnd: function onTouchEnd() {
16333
16575
  handleFadeOut();
@@ -16352,7 +16594,7 @@ var MobileSpellTooltip = function MobileSpellTooltip(_ref) {
16352
16594
  }, option.text);
16353
16595
  }))));
16354
16596
  };
16355
- var Container$l = /*#__PURE__*/styled.div.withConfig({
16597
+ var Container$n = /*#__PURE__*/styled.div.withConfig({
16356
16598
  displayName: "MobileSpellTooltip__Container",
16357
16599
  componentId: "sc-6p7uvr-0"
16358
16600
  })(["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;}"]);
@@ -16393,13 +16635,13 @@ var MagicTooltip = function MagicTooltip(_ref) {
16393
16635
  }
16394
16636
  return;
16395
16637
  }, []);
16396
- return React__default.createElement(ModalPortal, null, React__default.createElement(Container$m, {
16638
+ return React__default.createElement(ModalPortal, null, React__default.createElement(Container$o, {
16397
16639
  ref: ref
16398
16640
  }, React__default.createElement(SpellInfoDisplay, {
16399
16641
  spell: spell
16400
16642
  })));
16401
16643
  };
16402
- var Container$m = /*#__PURE__*/styled.div.withConfig({
16644
+ var Container$o = /*#__PURE__*/styled.div.withConfig({
16403
16645
  displayName: "SpellTooltip__Container",
16404
16646
  componentId: "sc-1go0gwg-0"
16405
16647
  })(["position:absolute;z-index:100;pointer-events:none;left:0;top:0;opacity:0;transition:opacity 0.08s;"]);
@@ -16451,7 +16693,7 @@ var Spell = function Spell(_ref) {
16451
16693
  var disabled = isSettingShortcut ? charMagicLevel < minMagicLevelRequired : manaCost > charMana || charMagicLevel < minMagicLevelRequired;
16452
16694
  return React__default.createElement(SpellInfoWrapper, {
16453
16695
  spell: spell
16454
- }, React__default.createElement(Container$n, {
16696
+ }, React__default.createElement(Container$p, {
16455
16697
  disabled: disabled || (activeCooldown != null ? activeCooldown : 0) > 0,
16456
16698
  onPointerUp: onPointerUp == null ? void 0 : onPointerUp.bind(null, spellKey),
16457
16699
  isSettingShortcut: isSettingShortcut && !disabled,
@@ -16466,7 +16708,7 @@ var Spell = function Spell(_ref) {
16466
16708
  className: "mana"
16467
16709
  }, manaCost))));
16468
16710
  };
16469
- var Container$n = /*#__PURE__*/styled.button.withConfig({
16711
+ var Container$p = /*#__PURE__*/styled.button.withConfig({
16470
16712
  displayName: "Spell__Container",
16471
16713
  componentId: "sc-j96fa2-0"
16472
16714
  })(["display:block;background:none;border:2px solid transparent;border-radius:1rem;width:100%;display:flex;gap:1rem;align-items:center;padding:0 1rem;text-align:left;position:relative;animation:", ";@keyframes border-color-change{0%{border-color:", ";}50%{border-color:transparent;}100%{border-color:", ";}}&:hover,&:focus{background-color:", ";}&:active{background:none;}"], function (_ref2) {
@@ -16554,7 +16796,7 @@ var Spellbook = function Spellbook(_ref) {
16554
16796
  height: "inherit",
16555
16797
  cancelDrag: "#spellbook-search, #shortcuts_list, .spell",
16556
16798
  scale: scale
16557
- }, React__default.createElement(Container$o, null, React__default.createElement(Title$8, null, "Learned Spells"), React__default.createElement(ShortcutsSetter, {
16799
+ }, React__default.createElement(Container$q, null, React__default.createElement(Title$8, null, "Learned Spells"), React__default.createElement(ShortcutsSetter, {
16558
16800
  setSettingShortcutIndex: setSettingShortcutIndex,
16559
16801
  settingShortcutIndex: settingShortcutIndex,
16560
16802
  shortcuts: shortcuts,
@@ -16588,7 +16830,7 @@ var Title$8 = /*#__PURE__*/styled.h1.withConfig({
16588
16830
  displayName: "Spellbook__Title",
16589
16831
  componentId: "sc-r02nfq-0"
16590
16832
  })(["font-size:", " !important;margin-bottom:0 !important;"], uiFonts.size.large);
16591
- var Container$o = /*#__PURE__*/styled.div.withConfig({
16833
+ var Container$q = /*#__PURE__*/styled.div.withConfig({
16592
16834
  displayName: "Spellbook__Container",
16593
16835
  componentId: "sc-r02nfq-1"
16594
16836
  })(["width:100%;height:100%;color:white;display:flex;flex-direction:column;"]);
@@ -16602,16 +16844,16 @@ var TextArea = function TextArea(_ref) {
16602
16844
  return React__default.createElement("textarea", Object.assign({}, props));
16603
16845
  };
16604
16846
 
16605
- var img$8 = '';
16847
+ var img$9 = '';
16606
16848
 
16607
- var img$9 = '';
16849
+ var img$a = '';
16608
16850
 
16609
- var img$a = '';
16851
+ var img$b = '';
16610
16852
 
16611
16853
  var DayNightPeriod = function DayNightPeriod(_ref) {
16612
16854
  var _periodOfDaySrcFiles;
16613
16855
  var periodOfDay = _ref.periodOfDay;
16614
- var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[shared.PeriodOfDay.Morning] = img$9, _periodOfDaySrcFiles[shared.PeriodOfDay.Afternoon] = img$8, _periodOfDaySrcFiles[shared.PeriodOfDay.Night] = img$a, _periodOfDaySrcFiles);
16856
+ var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[shared.PeriodOfDay.Morning] = img$a, _periodOfDaySrcFiles[shared.PeriodOfDay.Afternoon] = img$9, _periodOfDaySrcFiles[shared.PeriodOfDay.Night] = img$b, _periodOfDaySrcFiles);
16615
16857
  return React__default.createElement(GifContainer, null, React__default.createElement("img", {
16616
16858
  src: periodOfDaySrcFiles[periodOfDay]
16617
16859
  }));
@@ -16621,7 +16863,7 @@ var GifContainer = /*#__PURE__*/styled.div.withConfig({
16621
16863
  componentId: "sc-10t97fw-0"
16622
16864
  })(["width:100%;img{width:67%;}"]);
16623
16865
 
16624
- var img$b = '';
16866
+ var img$c = '';
16625
16867
 
16626
16868
  var TimeWidget = function TimeWidget(_ref) {
16627
16869
  var onClose = _ref.onClose,
@@ -16639,7 +16881,7 @@ var TimeWidget = function TimeWidget(_ref) {
16639
16881
  var WidgetContainer = /*#__PURE__*/styled.div.withConfig({
16640
16882
  displayName: "TimeWidget__WidgetContainer",
16641
16883
  componentId: "sc-1ja236h-0"
16642
- })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$b);
16884
+ })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$c);
16643
16885
  var Time = /*#__PURE__*/styled.div.withConfig({
16644
16886
  displayName: "TimeWidget__Time",
16645
16887
  componentId: "sc-1ja236h-1"
@@ -16889,230 +17131,17 @@ var Truncate = function Truncate(_ref) {
16889
17131
  var _ref$maxLines = _ref.maxLines,
16890
17132
  maxLines = _ref$maxLines === void 0 ? 1 : _ref$maxLines,
16891
17133
  children = _ref.children;
16892
- return React__default.createElement(Container$p, {
17134
+ return React__default.createElement(Container$r, {
16893
17135
  maxLines: maxLines
16894
17136
  }, children);
16895
17137
  };
16896
- var Container$p = /*#__PURE__*/styled.div.withConfig({
17138
+ var Container$r = /*#__PURE__*/styled.div.withConfig({
16897
17139
  displayName: "Truncate__Container",
16898
17140
  componentId: "sc-6x00qb-0"
16899
17141
  })(["display:-webkit-box;max-width:100%;max-height:100%;-webkit-line-clamp:", ";-webkit-box-orient:vertical;overflow:hidden;"], function (props) {
16900
17142
  return props.maxLines;
16901
17143
  });
16902
17144
 
16903
- var IS_MOBILE_OR_TABLET = /*#__PURE__*/shared.isMobileOrTablet();
16904
-
16905
- var chunkString = function chunkString(str, length) {
16906
- return str.match(new RegExp('.{1,' + length + '}', 'g'));
16907
- };
16908
-
16909
- var img$c = '';
16910
-
16911
- var NPCDialogText = function NPCDialogText(_ref) {
16912
- var text = _ref.text,
16913
- onClose = _ref.onClose,
16914
- onEndStep = _ref.onEndStep,
16915
- onStartStep = _ref.onStartStep,
16916
- type = _ref.type;
16917
- var windowSize = React.useRef([window.innerWidth, window.innerHeight]);
16918
- function maxCharacters(width) {
16919
- // Set the font size to 16 pixels
16920
- var fontSize = 11.2;
16921
- // Calculate the number of characters that can fit in one line
16922
- var charactersPerLine = Math.floor(width / 2 / fontSize);
16923
- // Calculate the number of lines that can fit in the div
16924
- var linesPerDiv = Math.floor(180 / fontSize);
16925
- // Calculate the maximum number of characters that can fit in the div
16926
- var maxCharacters = charactersPerLine * linesPerDiv;
16927
- // Return the maximum number of characters
16928
- return Math.round(maxCharacters / 5);
16929
- }
16930
- var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
16931
- var _useState = React.useState(0),
16932
- chunkIndex = _useState[0],
16933
- setChunkIndex = _useState[1];
16934
- var onHandleSpacePress = function onHandleSpacePress(event) {
16935
- if (event.code === 'Space') {
16936
- goToNextStep();
16937
- }
16938
- };
16939
- var goToNextStep = function goToNextStep() {
16940
- var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
16941
- if (hasNextChunk) {
16942
- setChunkIndex(function (prev) {
16943
- return prev + 1;
16944
- });
16945
- } else {
16946
- // if there's no more text chunks, close the dialog
16947
- onClose();
16948
- }
16949
- };
16950
- React.useEffect(function () {
16951
- document.addEventListener('keydown', onHandleSpacePress);
16952
- return function () {
16953
- return document.removeEventListener('keydown', onHandleSpacePress);
16954
- };
16955
- }, [chunkIndex]);
16956
- var _useState2 = React.useState(false),
16957
- showGoNextIndicator = _useState2[0],
16958
- setShowGoNextIndicator = _useState2[1];
16959
- return React__default.createElement(Container$q, null, React__default.createElement(DynamicText, {
16960
- text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
16961
- onFinish: function onFinish() {
16962
- setShowGoNextIndicator(true);
16963
- onEndStep && onEndStep();
16964
- },
16965
- onStart: function onStart() {
16966
- setShowGoNextIndicator(false);
16967
- onStartStep && onStartStep();
16968
- }
16969
- }), showGoNextIndicator && React__default.createElement(PressSpaceIndicator$1, {
16970
- right: type === exports.NPCDialogType.TextOnly ? '1rem' : '10.5rem',
16971
- src: IS_MOBILE_OR_TABLET ? img$c : img$6,
16972
- onPointerDown: function onPointerDown() {
16973
- goToNextStep();
16974
- }
16975
- }));
16976
- };
16977
- var Container$q = /*#__PURE__*/styled.div.withConfig({
16978
- displayName: "NPCDialogText__Container",
16979
- componentId: "sc-1cxkdh9-0"
16980
- })([""]);
16981
- var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
16982
- displayName: "NPCDialogText__PressSpaceIndicator",
16983
- componentId: "sc-1cxkdh9-1"
16984
- })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
16985
- var right = _ref2.right;
16986
- return right;
16987
- });
16988
-
16989
- (function (NPCDialogType) {
16990
- NPCDialogType["TextOnly"] = "TextOnly";
16991
- NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
16992
- })(exports.NPCDialogType || (exports.NPCDialogType = {}));
16993
- var NPCDialog = function NPCDialog(_ref) {
16994
- var text = _ref.text,
16995
- type = _ref.type,
16996
- _onClose = _ref.onClose,
16997
- imagePath = _ref.imagePath,
16998
- _ref$isQuestionDialog = _ref.isQuestionDialog,
16999
- isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
17000
- questions = _ref.questions,
17001
- answers = _ref.answers;
17002
- return React__default.createElement(RPGUIContainer, {
17003
- type: exports.RPGUIContainerTypes.FramedGold,
17004
- width: isQuestionDialog ? '600px' : '80%',
17005
- height: '180px'
17006
- }, isQuestionDialog && questions && answers ? React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer$2, {
17007
- flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
17008
- }, React__default.createElement(QuestionDialog, {
17009
- questions: questions,
17010
- answers: answers,
17011
- onClose: function onClose() {
17012
- if (_onClose) {
17013
- _onClose();
17014
- }
17015
- }
17016
- })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
17017
- src: imagePath || img$5
17018
- }))) : React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$r, null, React__default.createElement(TextContainer$2, {
17019
- flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
17020
- }, React__default.createElement(NPCDialogText, {
17021
- type: type,
17022
- text: text || 'No text provided.',
17023
- onClose: function onClose() {
17024
- if (_onClose) {
17025
- _onClose();
17026
- }
17027
- }
17028
- })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
17029
- src: imagePath || img$5
17030
- })))));
17031
- };
17032
- var Container$r = /*#__PURE__*/styled.div.withConfig({
17033
- displayName: "NPCDialog__Container",
17034
- componentId: "sc-1b4aw74-0"
17035
- })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
17036
- var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
17037
- displayName: "NPCDialog__TextContainer",
17038
- componentId: "sc-1b4aw74-1"
17039
- })(["flex:", " 0 0;width:355px;"], function (_ref2) {
17040
- var flex = _ref2.flex;
17041
- return flex;
17042
- });
17043
- var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
17044
- displayName: "NPCDialog__ThumbnailContainer",
17045
- componentId: "sc-1b4aw74-2"
17046
- })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
17047
- var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
17048
- displayName: "NPCDialog__NPCThumbnail",
17049
- componentId: "sc-1b4aw74-3"
17050
- })(["image-rendering:pixelated;height:128px;width:128px;"]);
17051
-
17052
- var HistoryDialog = function HistoryDialog(_ref) {
17053
- var backgroundImgPath = _ref.backgroundImgPath,
17054
- fullCoverBackground = _ref.fullCoverBackground,
17055
- questions = _ref.questions,
17056
- answers = _ref.answers,
17057
- text = _ref.text,
17058
- imagePath = _ref.imagePath,
17059
- textAndTypeArray = _ref.textAndTypeArray,
17060
- onClose = _ref.onClose;
17061
- var _useState = React.useState(0),
17062
- img = _useState[0],
17063
- setImage = _useState[1];
17064
- var onHandleSpacePress = function onHandleSpacePress(event) {
17065
- if (event.code === 'Space') {
17066
- if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
17067
- setImage(function (prev) {
17068
- return prev + 1;
17069
- });
17070
- } else {
17071
- // if there's no more text chunks, close the dialog
17072
- onClose();
17073
- }
17074
- }
17075
- };
17076
- React.useEffect(function () {
17077
- document.addEventListener('keydown', onHandleSpacePress);
17078
- return function () {
17079
- return document.removeEventListener('keydown', onHandleSpacePress);
17080
- };
17081
- }, [backgroundImgPath]);
17082
- return React__default.createElement(BackgroundContainer, {
17083
- imgPath: backgroundImgPath[img],
17084
- fullImg: fullCoverBackground
17085
- }, React__default.createElement(DialogContainer, null, textAndTypeArray ? React__default.createElement(NPCMultiDialog, {
17086
- textAndTypeArray: textAndTypeArray,
17087
- onClose: onClose
17088
- }) : questions && answers ? React__default.createElement(QuestionDialog, {
17089
- questions: questions,
17090
- answers: answers,
17091
- onClose: onClose
17092
- }) : text && imagePath ? React__default.createElement(NPCDialog, {
17093
- text: text,
17094
- imagePath: imagePath,
17095
- onClose: onClose,
17096
- type: exports.NPCDialogType.TextAndThumbnail
17097
- }) : React__default.createElement(NPCDialog, {
17098
- text: text,
17099
- onClose: onClose,
17100
- type: exports.NPCDialogType.TextOnly
17101
- })));
17102
- };
17103
- var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
17104
- displayName: "HistoryDialog__BackgroundContainer",
17105
- componentId: "sc-u6oe75-0"
17106
- })(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
17107
- return props.imgPath;
17108
- }, function (props) {
17109
- return props.imgPath ? 'cover' : 'auto';
17110
- });
17111
- var DialogContainer = /*#__PURE__*/styled.div.withConfig({
17112
- displayName: "HistoryDialog__DialogContainer",
17113
- componentId: "sc-u6oe75-1"
17114
- })(["display:flex;justify-content:center;padding-top:200px;"]);
17115
-
17116
17145
  exports.Button = Button;
17117
17146
  exports.CharacterSelection = CharacterSelection;
17118
17147
  exports.Chat = Chat;