@rpg-engine/long-bow 0.3.86 → 0.3.87

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 (148) hide show
  1. package/LICENSE +20 -20
  2. package/README.md +181 -181
  3. package/dist/long-bow.cjs.development.js +952 -950
  4. package/dist/long-bow.cjs.development.js.map +1 -1
  5. package/dist/long-bow.cjs.production.min.js +1 -1
  6. package/dist/long-bow.cjs.production.min.js.map +1 -1
  7. package/dist/long-bow.esm.js +731 -729
  8. package/dist/long-bow.esm.js.map +1 -1
  9. package/package.json +100 -100
  10. package/src/components/Abstractions/ModalPortal.tsx +22 -22
  11. package/src/components/Abstractions/SlotsContainer.tsx +62 -62
  12. package/src/components/Arrow/SelectArrow.tsx +69 -69
  13. package/src/components/Arrow/img/arrow01-left-clicked.png +0 -0
  14. package/src/components/Arrow/img/arrow01-left.png +0 -0
  15. package/src/components/Arrow/img/arrow01-right-clicked.png +0 -0
  16. package/src/components/Arrow/img/arrow01-right.png +0 -0
  17. package/src/components/Arrow/img/arrow02-left-clicked.png +0 -0
  18. package/src/components/Arrow/img/arrow02-left.png +0 -0
  19. package/src/components/Arrow/img/arrow02-right-clicked.png +0 -0
  20. package/src/components/Arrow/img/arrow02-right.png +0 -0
  21. package/src/components/Button.tsx +40 -40
  22. package/src/components/Character/CharacterSelection.tsx +96 -96
  23. package/src/components/CharacterStatus/CharacterStatus.tsx +120 -120
  24. package/src/components/Chat/Chat.tsx +196 -196
  25. package/src/components/Chatdeprecated/ChatDeprecated.tsx +198 -198
  26. package/src/components/CheckButton.tsx +65 -65
  27. package/src/components/CircularController/CircularController.tsx +248 -248
  28. package/src/components/CraftBook/CraftBook.tsx +241 -241
  29. package/src/components/CraftBook/MockItems.ts +77 -77
  30. package/src/components/DraggableContainer.tsx +176 -176
  31. package/src/components/Dropdown.tsx +90 -90
  32. package/src/components/DropdownSelectorContainer.tsx +42 -42
  33. package/src/components/Equipment/EquipmentSet.tsx +199 -199
  34. package/src/components/HistoryDialog.tsx +104 -104
  35. package/src/components/Input.tsx +15 -15
  36. package/src/components/Item/Cards/ItemInfo.tsx +252 -252
  37. package/src/components/Item/Cards/ItemInfoDisplay.tsx +128 -128
  38. package/src/components/Item/Cards/ItemInfoWrapper.tsx +62 -62
  39. package/src/components/Item/Cards/ItemTooltip.tsx +83 -83
  40. package/src/components/Item/Cards/MobileItemTooltip.tsx +149 -149
  41. package/src/components/Item/Inventory/ErrorBoundary.tsx +42 -42
  42. package/src/components/Item/Inventory/ItemContainer.tsx +227 -227
  43. package/src/components/Item/Inventory/ItemContainerTypes.ts +6 -6
  44. package/src/components/Item/Inventory/ItemQuantitySelector.tsx +138 -138
  45. package/src/components/Item/Inventory/ItemSlot.tsx +566 -564
  46. package/src/components/Item/Inventory/itemContainerHelper.ts +175 -175
  47. package/src/components/ListMenu.tsx +63 -63
  48. package/src/components/Multitab/Tab.tsx +66 -66
  49. package/src/components/Multitab/TabBody.tsx +13 -13
  50. package/src/components/Multitab/TabsContainer.tsx +97 -97
  51. package/src/components/NPCDialog/NPCDialog.tsx +121 -121
  52. package/src/components/NPCDialog/NPCDialogText.tsx +113 -113
  53. package/src/components/NPCDialog/NPCMultiDialog.tsx +159 -159
  54. package/src/components/NPCDialog/QuestionDialog/QuestionDialog.tsx +237 -237
  55. package/src/components/ProgressBar.tsx +92 -92
  56. package/src/components/PropertySelect/PropertySelect.tsx +106 -106
  57. package/src/components/QuestInfo/QuestInfo.tsx +233 -233
  58. package/src/components/QuestList.tsx +135 -135
  59. package/src/components/RPGUIContainer.tsx +47 -47
  60. package/src/components/RPGUIForceRenderStart.tsx +45 -45
  61. package/src/components/RPGUIRoot.tsx +14 -14
  62. package/src/components/RadioButton.tsx +53 -53
  63. package/src/components/RadioInput/RadioButton.tsx +96 -96
  64. package/src/components/RadioInput/RadioInput.tsx +102 -102
  65. package/src/components/RadioInput/instruments.ts +15 -15
  66. package/src/components/RangeSlider.tsx +78 -78
  67. package/src/components/RelativeListMenu.tsx +90 -90
  68. package/src/components/ScrollList.tsx +79 -79
  69. package/src/components/Shortcuts/Shortcuts.tsx +151 -151
  70. package/src/components/Shortcuts/ShortcutsSetter.tsx +132 -132
  71. package/src/components/Shortcuts/SingleShortcut.ts +62 -62
  72. package/src/components/SimpleProgressBar.tsx +62 -62
  73. package/src/components/SkillProgressBar.tsx +133 -133
  74. package/src/components/SkillsContainer.tsx +206 -206
  75. package/src/components/Spellbook/Spell.tsx +201 -201
  76. package/src/components/Spellbook/Spellbook.tsx +153 -153
  77. package/src/components/Spellbook/constants.ts +8 -8
  78. package/src/components/Spellbook/mockSpells.ts +60 -60
  79. package/src/components/StaticBook/StaticBook.tsx +103 -103
  80. package/src/components/TextArea.tsx +11 -11
  81. package/src/components/TimeWidget/DayNightPeriod/DayNightPeriod.tsx +35 -35
  82. package/src/components/TimeWidget/TimeWidget.tsx +65 -65
  83. package/src/components/TradingMenu/TradingItemRow.tsx +198 -198
  84. package/src/components/TradingMenu/TradingMenu.tsx +216 -216
  85. package/src/components/TradingMenu/items.mock.ts +48 -48
  86. package/src/components/Truncate.tsx +25 -25
  87. package/src/components/itemSelector/ItemSelector.tsx +136 -136
  88. package/src/components/shared/Column.tsx +16 -16
  89. package/src/components/shared/Ellipsis.tsx +65 -65
  90. package/src/components/shared/SpriteFromAtlas.tsx +104 -104
  91. package/src/components/typography/DynamicText.tsx +49 -49
  92. package/src/constants/uiColors.ts +20 -20
  93. package/src/constants/uiDevices.ts +3 -3
  94. package/src/constants/uiFonts.ts +12 -12
  95. package/src/hooks/useEventListener.ts +21 -21
  96. package/src/hooks/useOutsideAlerter.ts +25 -25
  97. package/src/index.tsx +40 -40
  98. package/src/libs/StringHelpers.ts +3 -3
  99. package/src/mocks/atlas/entities/entities.json +20215 -20215
  100. package/src/mocks/atlas/icons/icons.json +735 -735
  101. package/src/mocks/atlas/items/items.json +12086 -12086
  102. package/src/mocks/equipmentSet.mocks.ts +391 -391
  103. package/src/mocks/itemContainer.mocks.ts +563 -563
  104. package/src/mocks/skills.mocks.ts +128 -128
  105. package/src/stories/Arrow.stories.tsx +26 -26
  106. package/src/stories/Button.stories.tsx +36 -36
  107. package/src/stories/CharacterSelection.stories.tsx +45 -45
  108. package/src/stories/CharacterStatus.stories.tsx +29 -29
  109. package/src/stories/Chat.stories.tsx +187 -187
  110. package/src/stories/ChatDeprecated.stories.tsx +170 -170
  111. package/src/stories/CheckButton.stories.tsx +48 -48
  112. package/src/stories/CircullarController.stories.tsx +37 -37
  113. package/src/stories/CraftBook.stories.tsx +42 -42
  114. package/src/stories/DayNightPeriod.stories.tsx +27 -27
  115. package/src/stories/DraggableContainer.stories.tsx +28 -28
  116. package/src/stories/Dropdown.stories.tsx +46 -46
  117. package/src/stories/DropdownSelectorContainer.stories.tsx +41 -41
  118. package/src/stories/EquipmentSet.stories.tsx +65 -65
  119. package/src/stories/HistoryDialog.stories.tsx +61 -61
  120. package/src/stories/ItemContainer.stories.tsx +201 -201
  121. package/src/stories/ItemInfoDisplay.stories.tsx +33 -33
  122. package/src/stories/ItemQuantitySelector.stories.tsx +26 -26
  123. package/src/stories/ItemSelector.stories.tsx +77 -77
  124. package/src/stories/ItemTradingComponent.stories.tsx +35 -35
  125. package/src/stories/ListMenu.stories.tsx +56 -56
  126. package/src/stories/Multitab.stories.tsx +51 -51
  127. package/src/stories/NPCDialog.stories.tsx +130 -130
  128. package/src/stories/NPCMultiDialog.stories.tsx +71 -71
  129. package/src/stories/ProgressBar.stories.tsx +23 -23
  130. package/src/stories/PropertySelect.stories.tsx +40 -40
  131. package/src/stories/QuestInfo.stories.tsx +107 -107
  132. package/src/stories/QuestList.stories.tsx +82 -82
  133. package/src/stories/RPGUIContainers.stories.tsx +42 -42
  134. package/src/stories/RadioButton.stories.tsx +49 -49
  135. package/src/stories/RadioInput.stories.tsx +34 -34
  136. package/src/stories/RangeSlider.stories.tsx +64 -64
  137. package/src/stories/ScrollList.stories.tsx +85 -85
  138. package/src/stories/Shortcuts.stories.tsx +39 -39
  139. package/src/stories/SimpleProgressBar.stories.tsx +22 -22
  140. package/src/stories/SkillProgressBar.stories.tsx +34 -34
  141. package/src/stories/SkillsContainer.stories.tsx +35 -35
  142. package/src/stories/Spellbook.stories.tsx +104 -104
  143. package/src/stories/StaticBook.stories.tsx +32 -32
  144. package/src/stories/Text.stories.tsx +42 -42
  145. package/src/stories/TimeWidget.stories.tsx +27 -27
  146. package/src/stories/TradingMenu.stories.tsx +47 -47
  147. package/src/types/eventTypes.ts +4 -4
  148. package/src/types/index.d.ts +2 -2
@@ -1,6 +1,6 @@
1
1
  import React, { Component, useState, useEffect, useRef, useMemo, Fragment } from 'react';
2
2
  import styled from 'styled-components';
3
- import { GRID_WIDTH, GRID_HEIGHT, ShortcutType, getItemTextureKeyPath, ItemContainerType, ItemType, DepotSocketEvents, ItemSocketEvents, ItemSocketEventsDisplayLabels, ActionsForInventory, ActionsForEquipmentSet, ActionsForLoot, ActionsForMapContainer, ItemRarities, ItemSubType, ItemSlotType, getSPForLevel, PeriodOfDay, isMobileOrTablet } from '@rpg-engine/shared';
3
+ import { GRID_WIDTH, GRID_HEIGHT, ShortcutType, getItemTextureKeyPath, ItemContainerType, ItemType, DepotSocketEvents, ItemSocketEvents, ItemSocketEventsDisplayLabels, ActionsForInventory, ActionsForEquipmentSet, ActionsForLoot, ActionsForMapContainer, ItemRarities, ItemSubType, ItemSlotType, isMobileOrTablet, getSPForLevel, PeriodOfDay } from '@rpg-engine/shared';
4
4
  import dayjs from 'dayjs';
5
5
  import { ErrorBoundary as ErrorBoundary$1 } from 'react-error-boundary';
6
6
  import { RxPaperPlane } from 'react-icons/rx';
@@ -33734,7 +33734,8 @@ var ItemSlot = /*#__PURE__*/observer(function (_ref) {
33734
33734
  spriteKey: getItemTextureKeyPath({
33735
33735
  key: itemToRender.texturePath,
33736
33736
  texturePath: itemToRender.texturePath,
33737
- stackQty: itemToRender.stackQty || 1
33737
+ stackQty: itemToRender.stackQty || 1,
33738
+ isStackable: itemToRender.isStackable
33738
33739
  }, atlasJSON),
33739
33740
  imgScale: 3,
33740
33741
  imgClassname: "sprite-from-atlas-img--item"
@@ -33760,7 +33761,8 @@ var ItemSlot = /*#__PURE__*/observer(function (_ref) {
33760
33761
  spriteKey: getItemTextureKeyPath({
33761
33762
  key: itemToRender.texturePath,
33762
33763
  texturePath: itemToRender.texturePath,
33763
- stackQty: itemToRender.stackQty || 1
33764
+ stackQty: itemToRender.stackQty || 1,
33765
+ isStackable: itemToRender.isStackable
33764
33766
  }, atlasJSON),
33765
33767
  imgScale: 3,
33766
33768
  imgClassname: "sprite-from-atlas-img--item"
@@ -34584,6 +34586,546 @@ var EquipmentColumn = /*#__PURE__*/styled.div.withConfig({
34584
34586
  componentId: "sc-1wuddg2-1"
34585
34587
  })(["display:flex;justify-content:center;flex-wrap:wrap;flex-direction:column;touch-action:none;"]);
34586
34588
 
34589
+ var IS_MOBILE_OR_TABLET = /*#__PURE__*/isMobileOrTablet();
34590
+
34591
+ var chunkString = function chunkString(str, length) {
34592
+ return str.match(new RegExp('.{1,' + length + '}', 'g'));
34593
+ };
34594
+
34595
+ var DynamicText = function DynamicText(_ref) {
34596
+ var text = _ref.text,
34597
+ onFinish = _ref.onFinish,
34598
+ onStart = _ref.onStart;
34599
+ var _useState = useState(''),
34600
+ textState = _useState[0],
34601
+ setTextState = _useState[1];
34602
+ useEffect(function () {
34603
+ var i = 0;
34604
+ var interval = setInterval(function () {
34605
+ // on every interval, show one more character
34606
+ if (i === 0) {
34607
+ if (onStart) {
34608
+ onStart();
34609
+ }
34610
+ }
34611
+ if (i < text.length) {
34612
+ setTextState(text.substring(0, i + 1));
34613
+ i++;
34614
+ } else {
34615
+ clearInterval(interval);
34616
+ if (onFinish) {
34617
+ onFinish();
34618
+ }
34619
+ }
34620
+ }, 50);
34621
+ return function () {
34622
+ clearInterval(interval);
34623
+ };
34624
+ }, [text]);
34625
+ return React.createElement(TextContainer, null, textState);
34626
+ };
34627
+ var TextContainer = /*#__PURE__*/styled.p.withConfig({
34628
+ displayName: "DynamicText__TextContainer",
34629
+ componentId: "sc-1ggl9nd-0"
34630
+ })(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]);
34631
+
34632
+ var img$6 = '';
34633
+
34634
+ var img$7 = '';
34635
+
34636
+ var NPCDialogText = function NPCDialogText(_ref) {
34637
+ var text = _ref.text,
34638
+ onClose = _ref.onClose,
34639
+ onEndStep = _ref.onEndStep,
34640
+ onStartStep = _ref.onStartStep,
34641
+ type = _ref.type;
34642
+ var windowSize = useRef([window.innerWidth, window.innerHeight]);
34643
+ function maxCharacters(width) {
34644
+ // Set the font size to 16 pixels
34645
+ var fontSize = 11.2;
34646
+ // Calculate the number of characters that can fit in one line
34647
+ var charactersPerLine = Math.floor(width / 2 / fontSize);
34648
+ // Calculate the number of lines that can fit in the div
34649
+ var linesPerDiv = Math.floor(180 / fontSize);
34650
+ // Calculate the maximum number of characters that can fit in the div
34651
+ var maxCharacters = charactersPerLine * linesPerDiv;
34652
+ // Return the maximum number of characters
34653
+ return Math.round(maxCharacters / 5);
34654
+ }
34655
+ var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
34656
+ var _useState = useState(0),
34657
+ chunkIndex = _useState[0],
34658
+ setChunkIndex = _useState[1];
34659
+ var onHandleSpacePress = function onHandleSpacePress(event) {
34660
+ if (event.code === 'Space') {
34661
+ goToNextStep();
34662
+ }
34663
+ };
34664
+ var goToNextStep = function goToNextStep() {
34665
+ var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
34666
+ if (hasNextChunk) {
34667
+ setChunkIndex(function (prev) {
34668
+ return prev + 1;
34669
+ });
34670
+ } else {
34671
+ // if there's no more text chunks, close the dialog
34672
+ onClose();
34673
+ }
34674
+ };
34675
+ useEffect(function () {
34676
+ document.addEventListener('keydown', onHandleSpacePress);
34677
+ return function () {
34678
+ return document.removeEventListener('keydown', onHandleSpacePress);
34679
+ };
34680
+ }, [chunkIndex]);
34681
+ var _useState2 = useState(false),
34682
+ showGoNextIndicator = _useState2[0],
34683
+ setShowGoNextIndicator = _useState2[1];
34684
+ return React.createElement(Container$e, null, React.createElement(DynamicText, {
34685
+ text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
34686
+ onFinish: function onFinish() {
34687
+ setShowGoNextIndicator(true);
34688
+ onEndStep && onEndStep();
34689
+ },
34690
+ onStart: function onStart() {
34691
+ setShowGoNextIndicator(false);
34692
+ onStartStep && onStartStep();
34693
+ }
34694
+ }), showGoNextIndicator && React.createElement(PressSpaceIndicator, {
34695
+ right: type === NPCDialogType.TextOnly ? '1rem' : '10.5rem',
34696
+ src: IS_MOBILE_OR_TABLET ? img$6 : img$7,
34697
+ onPointerDown: function onPointerDown() {
34698
+ goToNextStep();
34699
+ }
34700
+ }));
34701
+ };
34702
+ var Container$e = /*#__PURE__*/styled.div.withConfig({
34703
+ displayName: "NPCDialogText__Container",
34704
+ componentId: "sc-1cxkdh9-0"
34705
+ })([""]);
34706
+ var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
34707
+ displayName: "NPCDialogText__PressSpaceIndicator",
34708
+ componentId: "sc-1cxkdh9-1"
34709
+ })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
34710
+ var right = _ref2.right;
34711
+ return right;
34712
+ });
34713
+
34714
+ //@ts-ignore
34715
+ var useEventListener = function useEventListener(type, handler, el) {
34716
+ if (el === void 0) {
34717
+ el = window;
34718
+ }
34719
+ var savedHandler = React.useRef();
34720
+ React.useEffect(function () {
34721
+ savedHandler.current = handler;
34722
+ }, [handler]);
34723
+ React.useEffect(function () {
34724
+ //@ts-ignore
34725
+ var listener = function listener(e) {
34726
+ return savedHandler.current(e);
34727
+ };
34728
+ el.addEventListener(type, listener);
34729
+ return function () {
34730
+ el.removeEventListener(type, listener);
34731
+ };
34732
+ }, [type, el]);
34733
+ };
34734
+
34735
+ var QuestionDialog = function QuestionDialog(_ref) {
34736
+ var questions = _ref.questions,
34737
+ answers = _ref.answers,
34738
+ onClose = _ref.onClose;
34739
+ var _useState = useState(questions[0]),
34740
+ currentQuestion = _useState[0],
34741
+ setCurrentQuestion = _useState[1];
34742
+ var _useState2 = useState(false),
34743
+ canShowAnswers = _useState2[0],
34744
+ setCanShowAnswers = _useState2[1];
34745
+ var onGetFirstAnswer = function onGetFirstAnswer() {
34746
+ if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {
34747
+ return null;
34748
+ }
34749
+ var firstAnswerId = currentQuestion.answerIds[0];
34750
+ return answers.find(function (answer) {
34751
+ return answer.id === firstAnswerId;
34752
+ });
34753
+ };
34754
+ var _useState3 = useState(onGetFirstAnswer()),
34755
+ currentAnswer = _useState3[0],
34756
+ setCurrentAnswer = _useState3[1];
34757
+ useEffect(function () {
34758
+ setCurrentAnswer(onGetFirstAnswer());
34759
+ }, [currentQuestion]);
34760
+ var onGetAnswers = function onGetAnswers(answerIds) {
34761
+ return answerIds.map(function (answerId) {
34762
+ return answers.find(function (answer) {
34763
+ return answer.id === answerId;
34764
+ });
34765
+ });
34766
+ };
34767
+ var onKeyPress = function onKeyPress(e) {
34768
+ switch (e.key) {
34769
+ case 'ArrowDown':
34770
+ // select next answer, if any.
34771
+ // if no next answer, select first answer
34772
+ // const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(
34773
+ // (answer) => answer?.id === currentAnswer!.id + 1
34774
+ // );
34775
+ var nextAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34776
+ return (answer == null ? void 0 : answer.id) === currentAnswer.id + 1;
34777
+ });
34778
+ var nextAnswerID = currentQuestion.answerIds[nextAnswerIndex];
34779
+ var nextAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34780
+ return (answer == null ? void 0 : answer.id) === nextAnswerID;
34781
+ });
34782
+ setCurrentAnswer(nextAnswer || onGetFirstAnswer());
34783
+ break;
34784
+ case 'ArrowUp':
34785
+ // select previous answer, if any.
34786
+ // if no previous answer, select last answer
34787
+ var previousAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34788
+ return (answer == null ? void 0 : answer.id) === currentAnswer.id - 1;
34789
+ });
34790
+ var previousAnswerID = currentQuestion.answerIds && currentQuestion.answerIds[previousAnswerIndex];
34791
+ var previousAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34792
+ return (answer == null ? void 0 : answer.id) === previousAnswerID;
34793
+ });
34794
+ if (previousAnswer) {
34795
+ setCurrentAnswer(previousAnswer);
34796
+ } else {
34797
+ setCurrentAnswer(onGetAnswers(currentQuestion.answerIds).pop());
34798
+ }
34799
+ break;
34800
+ case 'Enter':
34801
+ setCanShowAnswers(false);
34802
+ if (!(currentAnswer != null && currentAnswer.nextQuestionId)) {
34803
+ onClose();
34804
+ return;
34805
+ } else {
34806
+ setCurrentQuestion(questions.find(function (question) {
34807
+ return question.id === currentAnswer.nextQuestionId;
34808
+ }));
34809
+ }
34810
+ break;
34811
+ }
34812
+ };
34813
+ useEventListener('keydown', onKeyPress);
34814
+ var onAnswerClick = function onAnswerClick(answer) {
34815
+ setCanShowAnswers(false);
34816
+ if (answer.nextQuestionId) {
34817
+ // if there is a next question, go to it
34818
+ setCurrentQuestion(questions.find(function (question) {
34819
+ return question.id === answer.nextQuestionId;
34820
+ }));
34821
+ } else {
34822
+ // else, finish dialog!
34823
+ onClose();
34824
+ }
34825
+ };
34826
+ var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
34827
+ var answerIds = currentQuestion.answerIds;
34828
+ if (!answerIds) {
34829
+ return null;
34830
+ }
34831
+ var answers = onGetAnswers(answerIds);
34832
+ if (!answers) {
34833
+ return null;
34834
+ }
34835
+ return answers.map(function (answer) {
34836
+ var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
34837
+ var selectedColor = isSelected ? 'yellow' : 'white';
34838
+ if (answer) {
34839
+ return React.createElement(AnswerRow, {
34840
+ key: "answer_" + answer.id
34841
+ }, React.createElement(AnswerSelectedIcon, {
34842
+ color: selectedColor
34843
+ }, isSelected ? 'X' : null), React.createElement(Answer, {
34844
+ key: answer.id,
34845
+ onPointerDown: function onPointerDown() {
34846
+ return onAnswerClick(answer);
34847
+ },
34848
+ color: selectedColor
34849
+ }, answer.text));
34850
+ }
34851
+ return null;
34852
+ });
34853
+ };
34854
+ return React.createElement(Container$f, null, React.createElement(QuestionContainer, null, React.createElement(DynamicText, {
34855
+ text: currentQuestion.text,
34856
+ onStart: function onStart() {
34857
+ return setCanShowAnswers(false);
34858
+ },
34859
+ onFinish: function onFinish() {
34860
+ return setCanShowAnswers(true);
34861
+ }
34862
+ })), canShowAnswers && React.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
34863
+ };
34864
+ var Container$f = /*#__PURE__*/styled.div.withConfig({
34865
+ displayName: "QuestionDialog__Container",
34866
+ componentId: "sc-bxc5u0-0"
34867
+ })(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
34868
+ var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
34869
+ displayName: "QuestionDialog__QuestionContainer",
34870
+ componentId: "sc-bxc5u0-1"
34871
+ })(["flex:100%;width:100%;"]);
34872
+ var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
34873
+ displayName: "QuestionDialog__AnswersContainer",
34874
+ componentId: "sc-bxc5u0-2"
34875
+ })(["flex:100%;"]);
34876
+ var Answer = /*#__PURE__*/styled.p.withConfig({
34877
+ displayName: "QuestionDialog__Answer",
34878
+ componentId: "sc-bxc5u0-3"
34879
+ })(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
34880
+ return props.color;
34881
+ });
34882
+ var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
34883
+ displayName: "QuestionDialog__AnswerSelectedIcon",
34884
+ componentId: "sc-bxc5u0-4"
34885
+ })(["flex:5% 0 0;color:", " !important;"], function (props) {
34886
+ return props.color;
34887
+ });
34888
+ var AnswerRow = /*#__PURE__*/styled.div.withConfig({
34889
+ displayName: "QuestionDialog__AnswerRow",
34890
+ componentId: "sc-bxc5u0-5"
34891
+ })(["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;}"]);
34892
+
34893
+ var img$8 = '';
34894
+
34895
+ var NPCDialogType;
34896
+ (function (NPCDialogType) {
34897
+ NPCDialogType["TextOnly"] = "TextOnly";
34898
+ NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
34899
+ })(NPCDialogType || (NPCDialogType = {}));
34900
+ var NPCDialog = function NPCDialog(_ref) {
34901
+ var text = _ref.text,
34902
+ type = _ref.type,
34903
+ _onClose = _ref.onClose,
34904
+ imagePath = _ref.imagePath,
34905
+ _ref$isQuestionDialog = _ref.isQuestionDialog,
34906
+ isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
34907
+ questions = _ref.questions,
34908
+ answers = _ref.answers;
34909
+ return React.createElement(RPGUIContainer, {
34910
+ type: RPGUIContainerTypes.FramedGold,
34911
+ width: isQuestionDialog ? '600px' : '80%',
34912
+ height: '180px'
34913
+ }, isQuestionDialog && questions && answers ? React.createElement(React.Fragment, null, React.createElement(TextContainer$1, {
34914
+ flex: type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'
34915
+ }, React.createElement(QuestionDialog, {
34916
+ questions: questions,
34917
+ answers: answers,
34918
+ onClose: function onClose() {
34919
+ if (_onClose) {
34920
+ _onClose();
34921
+ }
34922
+ }
34923
+ })), type === NPCDialogType.TextAndThumbnail && React.createElement(ThumbnailContainer, null, React.createElement(NPCThumbnail, {
34924
+ src: imagePath || img$8
34925
+ }))) : React.createElement(React.Fragment, null, React.createElement(Container$g, null, React.createElement(TextContainer$1, {
34926
+ flex: type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'
34927
+ }, React.createElement(NPCDialogText, {
34928
+ type: type,
34929
+ text: text || 'No text provided.',
34930
+ onClose: function onClose() {
34931
+ if (_onClose) {
34932
+ _onClose();
34933
+ }
34934
+ }
34935
+ })), type === NPCDialogType.TextAndThumbnail && React.createElement(ThumbnailContainer, null, React.createElement(NPCThumbnail, {
34936
+ src: imagePath || img$8
34937
+ })))));
34938
+ };
34939
+ var Container$g = /*#__PURE__*/styled.div.withConfig({
34940
+ displayName: "NPCDialog__Container",
34941
+ componentId: "sc-1b4aw74-0"
34942
+ })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
34943
+ var TextContainer$1 = /*#__PURE__*/styled.div.withConfig({
34944
+ displayName: "NPCDialog__TextContainer",
34945
+ componentId: "sc-1b4aw74-1"
34946
+ })(["flex:", " 0 0;width:355px;"], function (_ref2) {
34947
+ var flex = _ref2.flex;
34948
+ return flex;
34949
+ });
34950
+ var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
34951
+ displayName: "NPCDialog__ThumbnailContainer",
34952
+ componentId: "sc-1b4aw74-2"
34953
+ })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
34954
+ var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
34955
+ displayName: "NPCDialog__NPCThumbnail",
34956
+ componentId: "sc-1b4aw74-3"
34957
+ })(["image-rendering:pixelated;height:128px;width:128px;"]);
34958
+
34959
+ var ImgSide;
34960
+ (function (ImgSide) {
34961
+ ImgSide["right"] = "right";
34962
+ ImgSide["left"] = "left";
34963
+ })(ImgSide || (ImgSide = {}));
34964
+ var NPCMultiDialog = function NPCMultiDialog(_ref) {
34965
+ var _textAndTypeArray$sli;
34966
+ var _onClose = _ref.onClose,
34967
+ textAndTypeArray = _ref.textAndTypeArray;
34968
+ var _useState = useState(false),
34969
+ showGoNextIndicator = _useState[0],
34970
+ setShowGoNextIndicator = _useState[1];
34971
+ var _useState2 = useState(0),
34972
+ slide = _useState2[0],
34973
+ setSlide = _useState2[1];
34974
+ var onHandleSpacePress = function onHandleSpacePress(event) {
34975
+ if (event.code === 'Space') {
34976
+ if (slide < (textAndTypeArray == null ? void 0 : textAndTypeArray.length) - 1) {
34977
+ setSlide(function (prev) {
34978
+ return prev + 1;
34979
+ });
34980
+ } else {
34981
+ // if there's no more text chunks, close the dialog
34982
+ _onClose();
34983
+ }
34984
+ }
34985
+ };
34986
+ useEffect(function () {
34987
+ document.addEventListener('keydown', onHandleSpacePress);
34988
+ return function () {
34989
+ return document.removeEventListener('keydown', onHandleSpacePress);
34990
+ };
34991
+ }, [slide]);
34992
+ return React.createElement(RPGUIContainer, {
34993
+ type: RPGUIContainerTypes.FramedGold,
34994
+ width: '50%',
34995
+ height: '180px'
34996
+ }, React.createElement(React.Fragment, null, React.createElement(Container$h, null, ((_textAndTypeArray$sli = textAndTypeArray[slide]) == null ? void 0 : _textAndTypeArray$sli.imageSide) === 'right' && React.createElement(React.Fragment, null, React.createElement(TextContainer$2, {
34997
+ flex: '70%'
34998
+ }, React.createElement(NPCDialogText, {
34999
+ onStartStep: function onStartStep() {
35000
+ return setShowGoNextIndicator(false);
35001
+ },
35002
+ onEndStep: function onEndStep() {
35003
+ return setShowGoNextIndicator(true);
35004
+ },
35005
+ text: textAndTypeArray[slide].text || 'No text provided.',
35006
+ onClose: function onClose() {
35007
+ if (_onClose) {
35008
+ _onClose();
35009
+ }
35010
+ }
35011
+ })), React.createElement(ThumbnailContainer$1, null, React.createElement(NPCThumbnail$1, {
35012
+ src: textAndTypeArray[slide].imagePath || img$8
35013
+ })), showGoNextIndicator && React.createElement(PressSpaceIndicator$1, {
35014
+ right: '10.5rem',
35015
+ src: img$7
35016
+ })), textAndTypeArray[slide].imageSide === 'left' && React.createElement(React.Fragment, null, React.createElement(ThumbnailContainer$1, null, React.createElement(NPCThumbnail$1, {
35017
+ src: textAndTypeArray[slide].imagePath || img$8
35018
+ })), React.createElement(TextContainer$2, {
35019
+ flex: '70%'
35020
+ }, React.createElement(NPCDialogText, {
35021
+ onStartStep: function onStartStep() {
35022
+ return setShowGoNextIndicator(false);
35023
+ },
35024
+ onEndStep: function onEndStep() {
35025
+ return setShowGoNextIndicator(true);
35026
+ },
35027
+ text: textAndTypeArray[slide].text || 'No text provided.',
35028
+ onClose: function onClose() {
35029
+ if (_onClose) {
35030
+ _onClose();
35031
+ }
35032
+ }
35033
+ })), showGoNextIndicator && React.createElement(PressSpaceIndicator$1, {
35034
+ right: '1rem',
35035
+ src: img$7
35036
+ }))), ")"));
35037
+ };
35038
+ var Container$h = /*#__PURE__*/styled.div.withConfig({
35039
+ displayName: "NPCMultiDialog__Container",
35040
+ componentId: "sc-rvu5wg-0"
35041
+ })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
35042
+ var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
35043
+ displayName: "NPCMultiDialog__TextContainer",
35044
+ componentId: "sc-rvu5wg-1"
35045
+ })(["flex:", " 0 0;width:355px;"], function (_ref2) {
35046
+ var flex = _ref2.flex;
35047
+ return flex;
35048
+ });
35049
+ var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
35050
+ displayName: "NPCMultiDialog__ThumbnailContainer",
35051
+ componentId: "sc-rvu5wg-2"
35052
+ })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
35053
+ var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
35054
+ displayName: "NPCMultiDialog__NPCThumbnail",
35055
+ componentId: "sc-rvu5wg-3"
35056
+ })(["image-rendering:pixelated;height:128px;width:128px;"]);
35057
+ var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
35058
+ displayName: "NPCMultiDialog__PressSpaceIndicator",
35059
+ componentId: "sc-rvu5wg-4"
35060
+ })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref3) {
35061
+ var right = _ref3.right;
35062
+ return right;
35063
+ });
35064
+
35065
+ var HistoryDialog = function HistoryDialog(_ref) {
35066
+ var backgroundImgPath = _ref.backgroundImgPath,
35067
+ fullCoverBackground = _ref.fullCoverBackground,
35068
+ questions = _ref.questions,
35069
+ answers = _ref.answers,
35070
+ text = _ref.text,
35071
+ imagePath = _ref.imagePath,
35072
+ textAndTypeArray = _ref.textAndTypeArray,
35073
+ onClose = _ref.onClose;
35074
+ var _useState = useState(0),
35075
+ img = _useState[0],
35076
+ setImage = _useState[1];
35077
+ var onHandleSpacePress = function onHandleSpacePress(event) {
35078
+ if (event.code === 'Space') {
35079
+ if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
35080
+ setImage(function (prev) {
35081
+ return prev + 1;
35082
+ });
35083
+ } else {
35084
+ // if there's no more text chunks, close the dialog
35085
+ onClose();
35086
+ }
35087
+ }
35088
+ };
35089
+ useEffect(function () {
35090
+ document.addEventListener('keydown', onHandleSpacePress);
35091
+ return function () {
35092
+ return document.removeEventListener('keydown', onHandleSpacePress);
35093
+ };
35094
+ }, [backgroundImgPath]);
35095
+ return React.createElement(BackgroundContainer, {
35096
+ imgPath: backgroundImgPath[img],
35097
+ fullImg: fullCoverBackground
35098
+ }, React.createElement(DialogContainer, null, textAndTypeArray ? React.createElement(NPCMultiDialog, {
35099
+ textAndTypeArray: textAndTypeArray,
35100
+ onClose: onClose
35101
+ }) : questions && answers ? React.createElement(QuestionDialog, {
35102
+ questions: questions,
35103
+ answers: answers,
35104
+ onClose: onClose
35105
+ }) : text && imagePath ? React.createElement(NPCDialog, {
35106
+ text: text,
35107
+ imagePath: imagePath,
35108
+ onClose: onClose,
35109
+ type: NPCDialogType.TextAndThumbnail
35110
+ }) : React.createElement(NPCDialog, {
35111
+ text: text,
35112
+ onClose: onClose,
35113
+ type: NPCDialogType.TextOnly
35114
+ })));
35115
+ };
35116
+ var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
35117
+ displayName: "HistoryDialog__BackgroundContainer",
35118
+ componentId: "sc-u6oe75-0"
35119
+ })(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
35120
+ return props.imgPath;
35121
+ }, function (props) {
35122
+ return props.imgPath ? 'cover' : 'auto';
35123
+ });
35124
+ var DialogContainer = /*#__PURE__*/styled.div.withConfig({
35125
+ displayName: "HistoryDialog__DialogContainer",
35126
+ componentId: "sc-u6oe75-1"
35127
+ })(["display:flex;justify-content:center;padding-top:200px;"]);
35128
+
34587
35129
  var SlotsContainer = function SlotsContainer(_ref) {
34588
35130
  var children = _ref.children,
34589
35131
  title = _ref.title,
@@ -34829,7 +35371,7 @@ var ShortcutsSetter = function ShortcutsSetter(_ref) {
34829
35371
  return word[0];
34830
35372
  }));
34831
35373
  };
34832
- return React.createElement(Container$e, null, React.createElement("p", null, "Shortcuts:"), React.createElement(List, {
35374
+ return React.createElement(Container$i, null, React.createElement("p", null, "Shortcuts:"), React.createElement(List, {
34833
35375
  id: "shortcuts_list"
34834
35376
  }, Array.from({
34835
35377
  length: 6
@@ -34845,7 +35387,7 @@ var ShortcutsSetter = function ShortcutsSetter(_ref) {
34845
35387
  }, getContent(i));
34846
35388
  })));
34847
35389
  };
34848
- var Container$e = /*#__PURE__*/styled.div.withConfig({
35390
+ var Container$i = /*#__PURE__*/styled.div.withConfig({
34849
35391
  displayName: "ShortcutsSetter__Container",
34850
35392
  componentId: "sc-xuouuf-0"
34851
35393
  })(["p{margin:0;margin-left:0.5rem;}"]);
@@ -34941,508 +35483,182 @@ var ItemContainer$1 = function ItemContainer(_ref) {
34941
35483
  if (onItemPlaceDrop) onItemPlaceDrop(item, slotIndex, itemContainerType);
34942
35484
  },
34943
35485
  onOutsideDrop: function onOutsideDrop(item, position) {
34944
- if (_onOutsideDrop) _onOutsideDrop(item, position);
34945
- },
34946
- atlasIMG: atlasIMG,
34947
- atlasJSON: atlasJSON,
34948
- isSelectingShortcut: settingShortcutIndex !== -1,
34949
- equipmentSet: equipmentSet,
34950
- isDepotSystem: isDepotSystem
34951
- }));
34952
- }
34953
- return slots;
34954
- };
34955
- return React.createElement(React.Fragment, null, React.createElement(SlotsContainer, {
34956
- title: itemContainer.name || 'Container',
34957
- onClose: onClose,
34958
- initialPosition: initialPosition,
34959
- scale: scale,
34960
- onPositionChangeEnd: onPositionChangeEnd,
34961
- onPositionChangeStart: onPositionChangeStart
34962
- }, type === ItemContainerType.Inventory && shortcuts && removeShortcut && React.createElement(ShortcutsSetter, {
34963
- setSettingShortcutIndex: setSettingShortcutIndex,
34964
- settingShortcutIndex: settingShortcutIndex,
34965
- shortcuts: shortcuts,
34966
- removeShortcut: removeShortcut,
34967
- atlasIMG: atlasIMG,
34968
- atlasJSON: atlasJSON
34969
- }), React.createElement(ItemsContainer, {
34970
- className: "item-container-body"
34971
- }, onRenderSlots())), quantitySelect.isOpen && React.createElement(ModalPortal, null, React.createElement(QuantitySelectorContainer, null, React.createElement(ItemQuantitySelector, {
34972
- quantity: quantitySelect.maxQuantity,
34973
- onConfirm: function onConfirm(quantity) {
34974
- quantitySelect.callback(quantity);
34975
- setQuantitySelect({
34976
- isOpen: false,
34977
- maxQuantity: 1,
34978
- callback: function callback() {}
34979
- });
34980
- },
34981
- onClose: function onClose() {
34982
- quantitySelect.callback(-1);
34983
- setQuantitySelect({
34984
- isOpen: false,
34985
- maxQuantity: 1,
34986
- callback: function callback() {}
34987
- });
34988
- }
34989
- }))));
34990
- };
34991
- var ItemsContainer = /*#__PURE__*/styled.div.withConfig({
34992
- displayName: "ItemContainer__ItemsContainer",
34993
- componentId: "sc-15y5p9l-0"
34994
- })(["display:flex;justify-content:center;flex-wrap:wrap;"]);
34995
- var QuantitySelectorContainer = /*#__PURE__*/styled.div.withConfig({
34996
- displayName: "ItemContainer__QuantitySelectorContainer",
34997
- componentId: "sc-15y5p9l-1"
34998
- })(["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);"]);
34999
-
35000
- var ItemSelector = function ItemSelector(_ref) {
35001
- var atlasIMG = _ref.atlasIMG,
35002
- atlasJSON = _ref.atlasJSON,
35003
- options = _ref.options,
35004
- onClose = _ref.onClose,
35005
- onSelect = _ref.onSelect;
35006
- var _useState = useState(),
35007
- selectedValue = _useState[0],
35008
- setSelectedValue = _useState[1];
35009
- var handleClick = function handleClick() {
35010
- var element = document.querySelector("input[name='test']:checked");
35011
- var elementValue = element.value;
35012
- setSelectedValue(elementValue);
35013
- };
35014
- useEffect(function () {
35015
- if (selectedValue) {
35016
- onSelect(selectedValue);
35017
- }
35018
- }, [selectedValue]);
35019
- return React.createElement(DraggableContainer, {
35020
- type: RPGUIContainerTypes.Framed,
35021
- width: "500px",
35022
- cancelDrag: ".equipment-container-body .arrow-selector",
35023
- onCloseButton: function onCloseButton() {
35024
- if (onClose) {
35025
- onClose();
35026
- }
35027
- }
35028
- }, React.createElement("div", {
35029
- style: {
35030
- width: '100%'
35031
- }
35032
- }, React.createElement(Title$3, null, 'Harvesting instruments'), React.createElement(Subtitle$1, null, 'Use the tool, you need it'), React.createElement("hr", {
35033
- className: "golden"
35034
- })), React.createElement(RadioInputScroller$1, null, options == null ? void 0 : options.map(function (option, index) {
35035
- return React.createElement(RadioOptionsWrapper$1, {
35036
- key: index
35037
- }, React.createElement(SpriteAtlasWrapper$1, null, React.createElement(SpriteFromAtlas, {
35038
- atlasIMG: atlasIMG,
35039
- atlasJSON: atlasJSON,
35040
- spriteKey: option.imageKey,
35041
- imgScale: 3
35042
- })), React.createElement("div", null, React.createElement("input", {
35043
- className: "rpgui-radio",
35044
- type: "radio",
35045
- value: option.name,
35046
- name: "test"
35047
- }), React.createElement("label", {
35048
- onPointerDown: handleClick,
35049
- style: {
35050
- display: 'flex',
35051
- alignItems: 'center'
35052
- }
35053
- }, option.name, " ", React.createElement("br", null), option.description)));
35054
- })), React.createElement(ButtonWrapper$1, null, React.createElement(Button, {
35055
- buttonType: ButtonTypes.RPGUIButton,
35056
- onPointerDown: onClose
35057
- }, "Cancel"), React.createElement(Button, {
35058
- buttonType: ButtonTypes.RPGUIButton
35059
- }, "Select")));
35060
- };
35061
- var Title$3 = /*#__PURE__*/styled.h1.withConfig({
35062
- displayName: "ItemSelector__Title",
35063
- componentId: "sc-gptoxp-0"
35064
- })(["font-size:0.6rem;color:yellow !important;"]);
35065
- var Subtitle$1 = /*#__PURE__*/styled.h1.withConfig({
35066
- displayName: "ItemSelector__Subtitle",
35067
- componentId: "sc-gptoxp-1"
35068
- })(["font-size:0.4rem;color:yellow !important;"]);
35069
- var RadioInputScroller$1 = /*#__PURE__*/styled.div.withConfig({
35070
- displayName: "ItemSelector__RadioInputScroller",
35071
- componentId: "sc-gptoxp-2"
35072
- })(["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;"]);
35073
- var SpriteAtlasWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35074
- displayName: "ItemSelector__SpriteAtlasWrapper",
35075
- componentId: "sc-gptoxp-3"
35076
- })(["margin-right:40px;"]);
35077
- var RadioOptionsWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35078
- displayName: "ItemSelector__RadioOptionsWrapper",
35079
- componentId: "sc-gptoxp-4"
35080
- })(["display:flex;align-items:stretch;margin-bottom:40px;"]);
35081
- var ButtonWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35082
- displayName: "ItemSelector__ButtonWrapper",
35083
- componentId: "sc-gptoxp-5"
35084
- })(["display:flex;justify-content:space-around;padding-top:20px;width:100%;"]);
35085
-
35086
- var ListMenu = function ListMenu(_ref) {
35087
- var options = _ref.options,
35088
- onSelected = _ref.onSelected,
35089
- x = _ref.x,
35090
- y = _ref.y;
35091
- return React.createElement(Container$f, {
35092
- x: x,
35093
- y: y
35094
- }, React.createElement("ul", {
35095
- className: "rpgui-list-imp",
35096
- style: {
35097
- overflow: 'hidden'
35098
- }
35099
- }, options.map(function (params, index) {
35100
- return React.createElement(ListElement$1, {
35101
- key: (params == null ? void 0 : params.id) || index,
35102
- onPointerDown: function onPointerDown() {
35103
- onSelected(params == null ? void 0 : params.id);
35104
- }
35105
- }, (params == null ? void 0 : params.text) || 'No text');
35106
- })));
35107
- };
35108
- var Container$f = /*#__PURE__*/styled.div.withConfig({
35109
- displayName: "ListMenu__Container",
35110
- componentId: "sc-i9097t-0"
35111
- })(["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) {
35112
- return props.y || 0;
35113
- }, function (props) {
35114
- return props.x || 0;
35115
- }, uiFonts.size.xsmall);
35116
- var ListElement$1 = /*#__PURE__*/styled.li.withConfig({
35117
- displayName: "ListMenu__ListElement",
35118
- componentId: "sc-i9097t-1"
35119
- })(["margin-right:0.5rem;"]);
35120
-
35121
- var img$6 = '';
35122
-
35123
- var img$7 = '';
35124
-
35125
- var ImgSide;
35126
- (function (ImgSide) {
35127
- ImgSide["right"] = "right";
35128
- ImgSide["left"] = "left";
35129
- })(ImgSide || (ImgSide = {}));
35130
- var NPCMultiDialog = function NPCMultiDialog(_ref) {
35131
- var _textAndTypeArray$sli;
35132
- var _onClose = _ref.onClose,
35133
- textAndTypeArray = _ref.textAndTypeArray;
35134
- var _useState = useState(false),
35135
- showGoNextIndicator = _useState[0],
35136
- setShowGoNextIndicator = _useState[1];
35137
- var _useState2 = useState(0),
35138
- slide = _useState2[0],
35139
- setSlide = _useState2[1];
35140
- var onHandleSpacePress = function onHandleSpacePress(event) {
35141
- if (event.code === 'Space') {
35142
- if (slide < (textAndTypeArray == null ? void 0 : textAndTypeArray.length) - 1) {
35143
- setSlide(function (prev) {
35144
- return prev + 1;
35145
- });
35146
- } else {
35147
- // if there's no more text chunks, close the dialog
35148
- _onClose();
35149
- }
35150
- }
35151
- };
35152
- useEffect(function () {
35153
- document.addEventListener('keydown', onHandleSpacePress);
35154
- return function () {
35155
- return document.removeEventListener('keydown', onHandleSpacePress);
35156
- };
35157
- }, [slide]);
35158
- return React.createElement(RPGUIContainer, {
35159
- type: RPGUIContainerTypes.FramedGold,
35160
- width: '50%',
35161
- height: '180px'
35162
- }, React.createElement(React.Fragment, null, React.createElement(Container$g, null, ((_textAndTypeArray$sli = textAndTypeArray[slide]) == null ? void 0 : _textAndTypeArray$sli.imageSide) === 'right' && React.createElement(React.Fragment, null, React.createElement(TextContainer, {
35163
- flex: '70%'
35164
- }, React.createElement(NPCDialogText, {
35165
- onStartStep: function onStartStep() {
35166
- return setShowGoNextIndicator(false);
35167
- },
35168
- onEndStep: function onEndStep() {
35169
- return setShowGoNextIndicator(true);
35170
- },
35171
- text: textAndTypeArray[slide].text || 'No text provided.',
35172
- onClose: function onClose() {
35173
- if (_onClose) {
35174
- _onClose();
35175
- }
35176
- }
35177
- })), React.createElement(ThumbnailContainer, null, React.createElement(NPCThumbnail, {
35178
- src: textAndTypeArray[slide].imagePath || img$6
35179
- })), showGoNextIndicator && React.createElement(PressSpaceIndicator, {
35180
- right: '10.5rem',
35181
- src: img$7
35182
- })), textAndTypeArray[slide].imageSide === 'left' && React.createElement(React.Fragment, null, React.createElement(ThumbnailContainer, null, React.createElement(NPCThumbnail, {
35183
- src: textAndTypeArray[slide].imagePath || img$6
35184
- })), React.createElement(TextContainer, {
35185
- flex: '70%'
35186
- }, React.createElement(NPCDialogText, {
35187
- onStartStep: function onStartStep() {
35188
- return setShowGoNextIndicator(false);
35189
- },
35190
- onEndStep: function onEndStep() {
35191
- return setShowGoNextIndicator(true);
35192
- },
35193
- text: textAndTypeArray[slide].text || 'No text provided.',
35194
- onClose: function onClose() {
35195
- if (_onClose) {
35196
- _onClose();
35197
- }
35198
- }
35199
- })), showGoNextIndicator && React.createElement(PressSpaceIndicator, {
35200
- right: '1rem',
35201
- src: img$7
35202
- }))), ")"));
35203
- };
35204
- var Container$g = /*#__PURE__*/styled.div.withConfig({
35205
- displayName: "NPCMultiDialog__Container",
35206
- componentId: "sc-rvu5wg-0"
35207
- })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
35208
- var TextContainer = /*#__PURE__*/styled.div.withConfig({
35209
- displayName: "NPCMultiDialog__TextContainer",
35210
- componentId: "sc-rvu5wg-1"
35211
- })(["flex:", " 0 0;width:355px;"], function (_ref2) {
35212
- var flex = _ref2.flex;
35213
- return flex;
35214
- });
35215
- var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
35216
- displayName: "NPCMultiDialog__ThumbnailContainer",
35217
- componentId: "sc-rvu5wg-2"
35218
- })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
35219
- var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
35220
- displayName: "NPCMultiDialog__NPCThumbnail",
35221
- componentId: "sc-rvu5wg-3"
35222
- })(["image-rendering:pixelated;height:128px;width:128px;"]);
35223
- var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
35224
- displayName: "NPCMultiDialog__PressSpaceIndicator",
35225
- componentId: "sc-rvu5wg-4"
35226
- })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref3) {
35227
- var right = _ref3.right;
35228
- return right;
35229
- });
35230
-
35231
- //@ts-ignore
35232
- var useEventListener = function useEventListener(type, handler, el) {
35233
- if (el === void 0) {
35234
- el = window;
35235
- }
35236
- var savedHandler = React.useRef();
35237
- React.useEffect(function () {
35238
- savedHandler.current = handler;
35239
- }, [handler]);
35240
- React.useEffect(function () {
35241
- //@ts-ignore
35242
- var listener = function listener(e) {
35243
- return savedHandler.current(e);
35244
- };
35245
- el.addEventListener(type, listener);
35246
- return function () {
35247
- el.removeEventListener(type, listener);
35248
- };
35249
- }, [type, el]);
35250
- };
35251
-
35252
- var DynamicText = function DynamicText(_ref) {
35253
- var text = _ref.text,
35254
- onFinish = _ref.onFinish,
35255
- onStart = _ref.onStart;
35256
- var _useState = useState(''),
35257
- textState = _useState[0],
35258
- setTextState = _useState[1];
35259
- useEffect(function () {
35260
- var i = 0;
35261
- var interval = setInterval(function () {
35262
- // on every interval, show one more character
35263
- if (i === 0) {
35264
- if (onStart) {
35265
- onStart();
35266
- }
35267
- }
35268
- if (i < text.length) {
35269
- setTextState(text.substring(0, i + 1));
35270
- i++;
35271
- } else {
35272
- clearInterval(interval);
35273
- if (onFinish) {
35274
- onFinish();
35275
- }
35276
- }
35277
- }, 50);
35278
- return function () {
35279
- clearInterval(interval);
35280
- };
35281
- }, [text]);
35282
- return React.createElement(TextContainer$1, null, textState);
35283
- };
35284
- var TextContainer$1 = /*#__PURE__*/styled.p.withConfig({
35285
- displayName: "DynamicText__TextContainer",
35286
- componentId: "sc-1ggl9nd-0"
35287
- })(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]);
35288
-
35289
- var QuestionDialog = function QuestionDialog(_ref) {
35290
- var questions = _ref.questions,
35291
- answers = _ref.answers,
35292
- onClose = _ref.onClose;
35293
- var _useState = useState(questions[0]),
35294
- currentQuestion = _useState[0],
35295
- setCurrentQuestion = _useState[1];
35296
- var _useState2 = useState(false),
35297
- canShowAnswers = _useState2[0],
35298
- setCanShowAnswers = _useState2[1];
35299
- var onGetFirstAnswer = function onGetFirstAnswer() {
35300
- if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {
35301
- return null;
35486
+ if (_onOutsideDrop) _onOutsideDrop(item, position);
35487
+ },
35488
+ atlasIMG: atlasIMG,
35489
+ atlasJSON: atlasJSON,
35490
+ isSelectingShortcut: settingShortcutIndex !== -1,
35491
+ equipmentSet: equipmentSet,
35492
+ isDepotSystem: isDepotSystem
35493
+ }));
35302
35494
  }
35303
- var firstAnswerId = currentQuestion.answerIds[0];
35304
- return answers.find(function (answer) {
35305
- return answer.id === firstAnswerId;
35306
- });
35495
+ return slots;
35307
35496
  };
35308
- var _useState3 = useState(onGetFirstAnswer()),
35309
- currentAnswer = _useState3[0],
35310
- setCurrentAnswer = _useState3[1];
35311
- useEffect(function () {
35312
- setCurrentAnswer(onGetFirstAnswer());
35313
- }, [currentQuestion]);
35314
- var onGetAnswers = function onGetAnswers(answerIds) {
35315
- return answerIds.map(function (answerId) {
35316
- return answers.find(function (answer) {
35317
- return answer.id === answerId;
35497
+ return React.createElement(React.Fragment, null, React.createElement(SlotsContainer, {
35498
+ title: itemContainer.name || 'Container',
35499
+ onClose: onClose,
35500
+ initialPosition: initialPosition,
35501
+ scale: scale,
35502
+ onPositionChangeEnd: onPositionChangeEnd,
35503
+ onPositionChangeStart: onPositionChangeStart
35504
+ }, type === ItemContainerType.Inventory && shortcuts && removeShortcut && React.createElement(ShortcutsSetter, {
35505
+ setSettingShortcutIndex: setSettingShortcutIndex,
35506
+ settingShortcutIndex: settingShortcutIndex,
35507
+ shortcuts: shortcuts,
35508
+ removeShortcut: removeShortcut,
35509
+ atlasIMG: atlasIMG,
35510
+ atlasJSON: atlasJSON
35511
+ }), React.createElement(ItemsContainer, {
35512
+ className: "item-container-body"
35513
+ }, onRenderSlots())), quantitySelect.isOpen && React.createElement(ModalPortal, null, React.createElement(QuantitySelectorContainer, null, React.createElement(ItemQuantitySelector, {
35514
+ quantity: quantitySelect.maxQuantity,
35515
+ onConfirm: function onConfirm(quantity) {
35516
+ quantitySelect.callback(quantity);
35517
+ setQuantitySelect({
35518
+ isOpen: false,
35519
+ maxQuantity: 1,
35520
+ callback: function callback() {}
35521
+ });
35522
+ },
35523
+ onClose: function onClose() {
35524
+ quantitySelect.callback(-1);
35525
+ setQuantitySelect({
35526
+ isOpen: false,
35527
+ maxQuantity: 1,
35528
+ callback: function callback() {}
35318
35529
  });
35319
- });
35320
- };
35321
- var onKeyPress = function onKeyPress(e) {
35322
- switch (e.key) {
35323
- case 'ArrowDown':
35324
- // select next answer, if any.
35325
- // if no next answer, select first answer
35326
- // const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(
35327
- // (answer) => answer?.id === currentAnswer!.id + 1
35328
- // );
35329
- var nextAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
35330
- return (answer == null ? void 0 : answer.id) === currentAnswer.id + 1;
35331
- });
35332
- var nextAnswerID = currentQuestion.answerIds[nextAnswerIndex];
35333
- var nextAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
35334
- return (answer == null ? void 0 : answer.id) === nextAnswerID;
35335
- });
35336
- setCurrentAnswer(nextAnswer || onGetFirstAnswer());
35337
- break;
35338
- case 'ArrowUp':
35339
- // select previous answer, if any.
35340
- // if no previous answer, select last answer
35341
- var previousAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
35342
- return (answer == null ? void 0 : answer.id) === currentAnswer.id - 1;
35343
- });
35344
- var previousAnswerID = currentQuestion.answerIds && currentQuestion.answerIds[previousAnswerIndex];
35345
- var previousAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
35346
- return (answer == null ? void 0 : answer.id) === previousAnswerID;
35347
- });
35348
- if (previousAnswer) {
35349
- setCurrentAnswer(previousAnswer);
35350
- } else {
35351
- setCurrentAnswer(onGetAnswers(currentQuestion.answerIds).pop());
35352
- }
35353
- break;
35354
- case 'Enter':
35355
- setCanShowAnswers(false);
35356
- if (!(currentAnswer != null && currentAnswer.nextQuestionId)) {
35357
- onClose();
35358
- return;
35359
- } else {
35360
- setCurrentQuestion(questions.find(function (question) {
35361
- return question.id === currentAnswer.nextQuestionId;
35362
- }));
35363
- }
35364
- break;
35365
35530
  }
35531
+ }))));
35532
+ };
35533
+ var ItemsContainer = /*#__PURE__*/styled.div.withConfig({
35534
+ displayName: "ItemContainer__ItemsContainer",
35535
+ componentId: "sc-15y5p9l-0"
35536
+ })(["display:flex;justify-content:center;flex-wrap:wrap;"]);
35537
+ var QuantitySelectorContainer = /*#__PURE__*/styled.div.withConfig({
35538
+ displayName: "ItemContainer__QuantitySelectorContainer",
35539
+ componentId: "sc-15y5p9l-1"
35540
+ })(["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);"]);
35541
+
35542
+ var ItemSelector = function ItemSelector(_ref) {
35543
+ var atlasIMG = _ref.atlasIMG,
35544
+ atlasJSON = _ref.atlasJSON,
35545
+ options = _ref.options,
35546
+ onClose = _ref.onClose,
35547
+ onSelect = _ref.onSelect;
35548
+ var _useState = useState(),
35549
+ selectedValue = _useState[0],
35550
+ setSelectedValue = _useState[1];
35551
+ var handleClick = function handleClick() {
35552
+ var element = document.querySelector("input[name='test']:checked");
35553
+ var elementValue = element.value;
35554
+ setSelectedValue(elementValue);
35366
35555
  };
35367
- useEventListener('keydown', onKeyPress);
35368
- var onAnswerClick = function onAnswerClick(answer) {
35369
- setCanShowAnswers(false);
35370
- if (answer.nextQuestionId) {
35371
- // if there is a next question, go to it
35372
- setCurrentQuestion(questions.find(function (question) {
35373
- return question.id === answer.nextQuestionId;
35374
- }));
35375
- } else {
35376
- // else, finish dialog!
35377
- onClose();
35556
+ useEffect(function () {
35557
+ if (selectedValue) {
35558
+ onSelect(selectedValue);
35378
35559
  }
35379
- };
35380
- var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
35381
- var answerIds = currentQuestion.answerIds;
35382
- if (!answerIds) {
35383
- return null;
35560
+ }, [selectedValue]);
35561
+ return React.createElement(DraggableContainer, {
35562
+ type: RPGUIContainerTypes.Framed,
35563
+ width: "500px",
35564
+ cancelDrag: ".equipment-container-body .arrow-selector",
35565
+ onCloseButton: function onCloseButton() {
35566
+ if (onClose) {
35567
+ onClose();
35568
+ }
35384
35569
  }
35385
- var answers = onGetAnswers(answerIds);
35386
- if (!answers) {
35387
- return null;
35570
+ }, React.createElement("div", {
35571
+ style: {
35572
+ width: '100%'
35388
35573
  }
35389
- return answers.map(function (answer) {
35390
- var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
35391
- var selectedColor = isSelected ? 'yellow' : 'white';
35392
- if (answer) {
35393
- return React.createElement(AnswerRow, {
35394
- key: "answer_" + answer.id
35395
- }, React.createElement(AnswerSelectedIcon, {
35396
- color: selectedColor
35397
- }, isSelected ? 'X' : null), React.createElement(Answer, {
35398
- key: answer.id,
35399
- onPointerDown: function onPointerDown() {
35400
- return onAnswerClick(answer);
35401
- },
35402
- color: selectedColor
35403
- }, answer.text));
35574
+ }, React.createElement(Title$3, null, 'Harvesting instruments'), React.createElement(Subtitle$1, null, 'Use the tool, you need it'), React.createElement("hr", {
35575
+ className: "golden"
35576
+ })), React.createElement(RadioInputScroller$1, null, options == null ? void 0 : options.map(function (option, index) {
35577
+ return React.createElement(RadioOptionsWrapper$1, {
35578
+ key: index
35579
+ }, React.createElement(SpriteAtlasWrapper$1, null, React.createElement(SpriteFromAtlas, {
35580
+ atlasIMG: atlasIMG,
35581
+ atlasJSON: atlasJSON,
35582
+ spriteKey: option.imageKey,
35583
+ imgScale: 3
35584
+ })), React.createElement("div", null, React.createElement("input", {
35585
+ className: "rpgui-radio",
35586
+ type: "radio",
35587
+ value: option.name,
35588
+ name: "test"
35589
+ }), React.createElement("label", {
35590
+ onPointerDown: handleClick,
35591
+ style: {
35592
+ display: 'flex',
35593
+ alignItems: 'center'
35404
35594
  }
35405
- return null;
35406
- });
35407
- };
35408
- return React.createElement(Container$h, null, React.createElement(QuestionContainer, null, React.createElement(DynamicText, {
35409
- text: currentQuestion.text,
35410
- onStart: function onStart() {
35411
- return setCanShowAnswers(false);
35412
- },
35413
- onFinish: function onFinish() {
35414
- return setCanShowAnswers(true);
35595
+ }, option.name, " ", React.createElement("br", null), option.description)));
35596
+ })), React.createElement(ButtonWrapper$1, null, React.createElement(Button, {
35597
+ buttonType: ButtonTypes.RPGUIButton,
35598
+ onPointerDown: onClose
35599
+ }, "Cancel"), React.createElement(Button, {
35600
+ buttonType: ButtonTypes.RPGUIButton
35601
+ }, "Select")));
35602
+ };
35603
+ var Title$3 = /*#__PURE__*/styled.h1.withConfig({
35604
+ displayName: "ItemSelector__Title",
35605
+ componentId: "sc-gptoxp-0"
35606
+ })(["font-size:0.6rem;color:yellow !important;"]);
35607
+ var Subtitle$1 = /*#__PURE__*/styled.h1.withConfig({
35608
+ displayName: "ItemSelector__Subtitle",
35609
+ componentId: "sc-gptoxp-1"
35610
+ })(["font-size:0.4rem;color:yellow !important;"]);
35611
+ var RadioInputScroller$1 = /*#__PURE__*/styled.div.withConfig({
35612
+ displayName: "ItemSelector__RadioInputScroller",
35613
+ componentId: "sc-gptoxp-2"
35614
+ })(["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;"]);
35615
+ var SpriteAtlasWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35616
+ displayName: "ItemSelector__SpriteAtlasWrapper",
35617
+ componentId: "sc-gptoxp-3"
35618
+ })(["margin-right:40px;"]);
35619
+ var RadioOptionsWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35620
+ displayName: "ItemSelector__RadioOptionsWrapper",
35621
+ componentId: "sc-gptoxp-4"
35622
+ })(["display:flex;align-items:stretch;margin-bottom:40px;"]);
35623
+ var ButtonWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35624
+ displayName: "ItemSelector__ButtonWrapper",
35625
+ componentId: "sc-gptoxp-5"
35626
+ })(["display:flex;justify-content:space-around;padding-top:20px;width:100%;"]);
35627
+
35628
+ var ListMenu = function ListMenu(_ref) {
35629
+ var options = _ref.options,
35630
+ onSelected = _ref.onSelected,
35631
+ x = _ref.x,
35632
+ y = _ref.y;
35633
+ return React.createElement(Container$j, {
35634
+ x: x,
35635
+ y: y
35636
+ }, React.createElement("ul", {
35637
+ className: "rpgui-list-imp",
35638
+ style: {
35639
+ overflow: 'hidden'
35415
35640
  }
35416
- })), canShowAnswers && React.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
35641
+ }, options.map(function (params, index) {
35642
+ return React.createElement(ListElement$1, {
35643
+ key: (params == null ? void 0 : params.id) || index,
35644
+ onPointerDown: function onPointerDown() {
35645
+ onSelected(params == null ? void 0 : params.id);
35646
+ }
35647
+ }, (params == null ? void 0 : params.text) || 'No text');
35648
+ })));
35417
35649
  };
35418
- var Container$h = /*#__PURE__*/styled.div.withConfig({
35419
- displayName: "QuestionDialog__Container",
35420
- componentId: "sc-bxc5u0-0"
35421
- })(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
35422
- var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
35423
- displayName: "QuestionDialog__QuestionContainer",
35424
- componentId: "sc-bxc5u0-1"
35425
- })(["flex:100%;width:100%;"]);
35426
- var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
35427
- displayName: "QuestionDialog__AnswersContainer",
35428
- componentId: "sc-bxc5u0-2"
35429
- })(["flex:100%;"]);
35430
- var Answer = /*#__PURE__*/styled.p.withConfig({
35431
- displayName: "QuestionDialog__Answer",
35432
- componentId: "sc-bxc5u0-3"
35433
- })(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
35434
- return props.color;
35435
- });
35436
- var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
35437
- displayName: "QuestionDialog__AnswerSelectedIcon",
35438
- componentId: "sc-bxc5u0-4"
35439
- })(["flex:5% 0 0;color:", " !important;"], function (props) {
35440
- return props.color;
35441
- });
35442
- var AnswerRow = /*#__PURE__*/styled.div.withConfig({
35443
- displayName: "QuestionDialog__AnswerRow",
35444
- componentId: "sc-bxc5u0-5"
35445
- })(["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;}"]);
35650
+ var Container$j = /*#__PURE__*/styled.div.withConfig({
35651
+ displayName: "ListMenu__Container",
35652
+ componentId: "sc-i9097t-0"
35653
+ })(["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) {
35654
+ return props.y || 0;
35655
+ }, function (props) {
35656
+ return props.x || 0;
35657
+ }, uiFonts.size.xsmall);
35658
+ var ListElement$1 = /*#__PURE__*/styled.li.withConfig({
35659
+ displayName: "ListMenu__ListElement",
35660
+ componentId: "sc-i9097t-1"
35661
+ })(["margin-right:0.5rem;"]);
35446
35662
 
35447
35663
  var ProgressBar = function ProgressBar(_ref) {
35448
35664
  var max = _ref.max,
@@ -35461,7 +35677,7 @@ var ProgressBar = function ProgressBar(_ref) {
35461
35677
  }
35462
35678
  return value * 100 / max;
35463
35679
  };
35464
- return React.createElement(Container$i, {
35680
+ return React.createElement(Container$k, {
35465
35681
  className: "rpgui-progress",
35466
35682
  "data-value": calculatePercentageValue(max, value) / 100,
35467
35683
  "data-rpguitype": "progress",
@@ -35490,7 +35706,7 @@ var TextOverlay$1 = /*#__PURE__*/styled.div.withConfig({
35490
35706
  displayName: "ProgressBar__TextOverlay",
35491
35707
  componentId: "sc-qa6fzh-1"
35492
35708
  })(["width:100%;position:relative;"]);
35493
- var Container$i = /*#__PURE__*/styled.div.withConfig({
35709
+ var Container$k = /*#__PURE__*/styled.div.withConfig({
35494
35710
  displayName: "ProgressBar__Container",
35495
35711
  componentId: "sc-qa6fzh-2"
35496
35712
  })(["display:flex;flex-direction:column;min-width:", "px;width:", "%;justify-content:start;align-items:flex-start;", ""], function (props) {
@@ -35501,7 +35717,7 @@ var Container$i = /*#__PURE__*/styled.div.withConfig({
35501
35717
  return props.style;
35502
35718
  });
35503
35719
 
35504
- var img$8 = '';
35720
+ var img$9 = '';
35505
35721
 
35506
35722
  var QuestInfo = function QuestInfo(_ref) {
35507
35723
  var quests = _ref.quests,
@@ -35545,7 +35761,7 @@ var QuestInfo = function QuestInfo(_ref) {
35545
35761
  }), React.createElement(QuestContainer, null, React.createElement(TitleContainer$1, {
35546
35762
  className: "drag-handler"
35547
35763
  }, React.createElement(Title$4, null, React.createElement(Thumbnail, {
35548
- src: quests[currentIndex].thumbnail || img$8
35764
+ src: quests[currentIndex].thumbnail || img$9
35549
35765
  }), quests[currentIndex].title), React.createElement(QuestSplitDiv, null, React.createElement("hr", {
35550
35766
  className: "golden"
35551
35767
  }))), React.createElement(Content, null, React.createElement("p", null, quests[currentIndex].description)), React.createElement(QuestColumn, {
@@ -35564,7 +35780,7 @@ var QuestInfo = function QuestInfo(_ref) {
35564
35780
  })))) : React.createElement(QuestsContainer, null, React.createElement(QuestContainer, null, React.createElement(TitleContainer$1, {
35565
35781
  className: "drag-handler"
35566
35782
  }, React.createElement(Title$4, null, React.createElement(Thumbnail, {
35567
- src: quests[0].thumbnail || img$8
35783
+ src: quests[0].thumbnail || img$9
35568
35784
  }), quests[0].title), React.createElement(QuestSplitDiv, null, React.createElement("hr", {
35569
35785
  className: "golden"
35570
35786
  }))), React.createElement(Content, null, React.createElement("p", null, quests[0].description)), React.createElement(QuestColumn, {
@@ -35815,7 +36031,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
35815
36031
  bgColor = _ref$bgColor === void 0 ? 'red' : _ref$bgColor,
35816
36032
  _ref$margin = _ref.margin,
35817
36033
  margin = _ref$margin === void 0 ? 20 : _ref$margin;
35818
- return React.createElement(Container$j, {
36034
+ return React.createElement(Container$l, {
35819
36035
  className: "simple-progress-bar"
35820
36036
  }, React.createElement(ProgressBarContainer, {
35821
36037
  margin: margin
@@ -35824,7 +36040,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
35824
36040
  bgColor: bgColor
35825
36041
  }))));
35826
36042
  };
35827
- var Container$j = /*#__PURE__*/styled.div.withConfig({
36043
+ var Container$l = /*#__PURE__*/styled.div.withConfig({
35828
36044
  displayName: "SimpleProgressBar__Container",
35829
36045
  componentId: "sc-mbeil3-0"
35830
36046
  })(["display:flex;justify-content:center;align-items:center;width:100%;"]);
@@ -36055,7 +36271,7 @@ var Spell = function Spell(_ref) {
36055
36271
  isSettingShortcut = _ref.isSettingShortcut,
36056
36272
  minMagicLevelRequired = _ref.minMagicLevelRequired;
36057
36273
  var disabled = isSettingShortcut ? charMagicLevel < minMagicLevelRequired : manaCost > charMana || charMagicLevel < minMagicLevelRequired;
36058
- return React.createElement(Container$k, {
36274
+ return React.createElement(Container$m, {
36059
36275
  disabled: disabled,
36060
36276
  onPointerDown: onPointerDown == null ? void 0 : onPointerDown.bind(null, spellKey),
36061
36277
  isSettingShortcut: isSettingShortcut && !disabled,
@@ -36068,7 +36284,7 @@ var Spell = function Spell(_ref) {
36068
36284
  className: "mana"
36069
36285
  }, manaCost)));
36070
36286
  };
36071
- var Container$k = /*#__PURE__*/styled.button.withConfig({
36287
+ var Container$m = /*#__PURE__*/styled.button.withConfig({
36072
36288
  displayName: "Spell__Container",
36073
36289
  componentId: "sc-j96fa2-0"
36074
36290
  })(["display:block;background:none;border:2px solid transparent;border-radius:1rem;width:100%;display:flex;height:5rem;gap:1rem;align-items:center;padding:0 1rem;text-align:left;position:relative;animation:", ";@keyframes border-color-change{0%{border-color:", ";}50%{border-color:transparent;}100%{border-color:", ";}}&:hover,&:focus{background-color:", ";}&:active{background:none;}"], function (_ref2) {
@@ -36155,7 +36371,7 @@ var Spellbook = function Spellbook(_ref) {
36155
36371
  height: "inherit",
36156
36372
  cancelDrag: "#spellbook-search, #shortcuts_list, .spell",
36157
36373
  scale: scale
36158
- }, React.createElement(Container$l, null, React.createElement(Title$7, null, "Learned Spells"), React.createElement(ShortcutsSetter, {
36374
+ }, React.createElement(Container$n, null, React.createElement(Title$7, null, "Learned Spells"), React.createElement(ShortcutsSetter, {
36159
36375
  setSettingShortcutIndex: setSettingShortcutIndex,
36160
36376
  settingShortcutIndex: settingShortcutIndex,
36161
36377
  shortcuts: shortcuts,
@@ -36187,7 +36403,7 @@ var Title$7 = /*#__PURE__*/styled.h1.withConfig({
36187
36403
  displayName: "Spellbook__Title",
36188
36404
  componentId: "sc-r02nfq-0"
36189
36405
  })(["font-size:", " !important;margin-bottom:0 !important;"], uiFonts.size.large);
36190
- var Container$l = /*#__PURE__*/styled.div.withConfig({
36406
+ var Container$n = /*#__PURE__*/styled.div.withConfig({
36191
36407
  displayName: "Spellbook__Container",
36192
36408
  componentId: "sc-r02nfq-1"
36193
36409
  })(["width:100%;height:100%;color:white;display:flex;flex-direction:column;"]);
@@ -36201,16 +36417,16 @@ var TextArea = function TextArea(_ref) {
36201
36417
  return React.createElement("textarea", Object.assign({}, props));
36202
36418
  };
36203
36419
 
36204
- var img$9 = '';
36420
+ var img$a = '';
36205
36421
 
36206
- var img$a = '';
36422
+ var img$b = '';
36207
36423
 
36208
- var img$b = '';
36424
+ var img$c = '';
36209
36425
 
36210
36426
  var DayNightPeriod = function DayNightPeriod(_ref) {
36211
36427
  var _periodOfDaySrcFiles;
36212
36428
  var periodOfDay = _ref.periodOfDay;
36213
- var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[PeriodOfDay.Morning] = img$a, _periodOfDaySrcFiles[PeriodOfDay.Afternoon] = img$9, _periodOfDaySrcFiles[PeriodOfDay.Night] = img$b, _periodOfDaySrcFiles);
36429
+ var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[PeriodOfDay.Morning] = img$b, _periodOfDaySrcFiles[PeriodOfDay.Afternoon] = img$a, _periodOfDaySrcFiles[PeriodOfDay.Night] = img$c, _periodOfDaySrcFiles);
36214
36430
  return React.createElement(GifContainer, null, React.createElement("img", {
36215
36431
  src: periodOfDaySrcFiles[periodOfDay]
36216
36432
  }));
@@ -36220,7 +36436,7 @@ var GifContainer = /*#__PURE__*/styled.div.withConfig({
36220
36436
  componentId: "sc-10t97fw-0"
36221
36437
  })(["width:100%;img{width:67%;}"]);
36222
36438
 
36223
- var img$c = '';
36439
+ var img$d = '';
36224
36440
 
36225
36441
  var TimeWidget = function TimeWidget(_ref) {
36226
36442
  var onClose = _ref.onClose,
@@ -36238,7 +36454,7 @@ var TimeWidget = function TimeWidget(_ref) {
36238
36454
  var WidgetContainer = /*#__PURE__*/styled.div.withConfig({
36239
36455
  displayName: "TimeWidget__WidgetContainer",
36240
36456
  componentId: "sc-1ja236h-0"
36241
- })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$c);
36457
+ })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$d);
36242
36458
  var Time = /*#__PURE__*/styled.div.withConfig({
36243
36459
  displayName: "TimeWidget__Time",
36244
36460
  componentId: "sc-1ja236h-1"
@@ -36487,230 +36703,16 @@ var Truncate = function Truncate(_ref) {
36487
36703
  var _ref$maxLines = _ref.maxLines,
36488
36704
  maxLines = _ref$maxLines === void 0 ? 1 : _ref$maxLines,
36489
36705
  children = _ref.children;
36490
- return React.createElement(Container$m, {
36706
+ return React.createElement(Container$o, {
36491
36707
  maxLines: maxLines
36492
36708
  }, children);
36493
36709
  };
36494
- var Container$m = /*#__PURE__*/styled.div.withConfig({
36710
+ var Container$o = /*#__PURE__*/styled.div.withConfig({
36495
36711
  displayName: "Truncate__Container",
36496
36712
  componentId: "sc-6x00qb-0"
36497
36713
  })(["display:-webkit-box;max-width:100%;max-height:100%;-webkit-line-clamp:", ";-webkit-box-orient:vertical;overflow:hidden;"], function (props) {
36498
36714
  return props.maxLines;
36499
36715
  });
36500
36716
 
36501
- var IS_MOBILE_OR_TABLET = /*#__PURE__*/isMobileOrTablet();
36502
-
36503
- var chunkString = function chunkString(str, length) {
36504
- return str.match(new RegExp('.{1,' + length + '}', 'g'));
36505
- };
36506
-
36507
- var img$d = '';
36508
-
36509
- var NPCDialogText = function NPCDialogText(_ref) {
36510
- var text = _ref.text,
36511
- onClose = _ref.onClose,
36512
- onEndStep = _ref.onEndStep,
36513
- onStartStep = _ref.onStartStep,
36514
- type = _ref.type;
36515
- var windowSize = useRef([window.innerWidth, window.innerHeight]);
36516
- function maxCharacters(width) {
36517
- // Set the font size to 16 pixels
36518
- var fontSize = 11.2;
36519
- // Calculate the number of characters that can fit in one line
36520
- var charactersPerLine = Math.floor(width / 2 / fontSize);
36521
- // Calculate the number of lines that can fit in the div
36522
- var linesPerDiv = Math.floor(180 / fontSize);
36523
- // Calculate the maximum number of characters that can fit in the div
36524
- var maxCharacters = charactersPerLine * linesPerDiv;
36525
- // Return the maximum number of characters
36526
- return Math.round(maxCharacters / 5);
36527
- }
36528
- var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
36529
- var _useState = useState(0),
36530
- chunkIndex = _useState[0],
36531
- setChunkIndex = _useState[1];
36532
- var onHandleSpacePress = function onHandleSpacePress(event) {
36533
- if (event.code === 'Space') {
36534
- goToNextStep();
36535
- }
36536
- };
36537
- var goToNextStep = function goToNextStep() {
36538
- var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
36539
- if (hasNextChunk) {
36540
- setChunkIndex(function (prev) {
36541
- return prev + 1;
36542
- });
36543
- } else {
36544
- // if there's no more text chunks, close the dialog
36545
- onClose();
36546
- }
36547
- };
36548
- useEffect(function () {
36549
- document.addEventListener('keydown', onHandleSpacePress);
36550
- return function () {
36551
- return document.removeEventListener('keydown', onHandleSpacePress);
36552
- };
36553
- }, [chunkIndex]);
36554
- var _useState2 = useState(false),
36555
- showGoNextIndicator = _useState2[0],
36556
- setShowGoNextIndicator = _useState2[1];
36557
- return React.createElement(Container$n, null, React.createElement(DynamicText, {
36558
- text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
36559
- onFinish: function onFinish() {
36560
- setShowGoNextIndicator(true);
36561
- onEndStep && onEndStep();
36562
- },
36563
- onStart: function onStart() {
36564
- setShowGoNextIndicator(false);
36565
- onStartStep && onStartStep();
36566
- }
36567
- }), showGoNextIndicator && React.createElement(PressSpaceIndicator$1, {
36568
- right: type === NPCDialogType.TextOnly ? '1rem' : '10.5rem',
36569
- src: IS_MOBILE_OR_TABLET ? img$d : img$7,
36570
- onPointerDown: function onPointerDown() {
36571
- goToNextStep();
36572
- }
36573
- }));
36574
- };
36575
- var Container$n = /*#__PURE__*/styled.div.withConfig({
36576
- displayName: "NPCDialogText__Container",
36577
- componentId: "sc-1cxkdh9-0"
36578
- })([""]);
36579
- var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
36580
- displayName: "NPCDialogText__PressSpaceIndicator",
36581
- componentId: "sc-1cxkdh9-1"
36582
- })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
36583
- var right = _ref2.right;
36584
- return right;
36585
- });
36586
-
36587
- var NPCDialogType;
36588
- (function (NPCDialogType) {
36589
- NPCDialogType["TextOnly"] = "TextOnly";
36590
- NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
36591
- })(NPCDialogType || (NPCDialogType = {}));
36592
- var NPCDialog = function NPCDialog(_ref) {
36593
- var text = _ref.text,
36594
- type = _ref.type,
36595
- _onClose = _ref.onClose,
36596
- imagePath = _ref.imagePath,
36597
- _ref$isQuestionDialog = _ref.isQuestionDialog,
36598
- isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
36599
- questions = _ref.questions,
36600
- answers = _ref.answers;
36601
- return React.createElement(RPGUIContainer, {
36602
- type: RPGUIContainerTypes.FramedGold,
36603
- width: isQuestionDialog ? '600px' : '80%',
36604
- height: '180px'
36605
- }, isQuestionDialog && questions && answers ? React.createElement(React.Fragment, null, React.createElement(TextContainer$2, {
36606
- flex: type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'
36607
- }, React.createElement(QuestionDialog, {
36608
- questions: questions,
36609
- answers: answers,
36610
- onClose: function onClose() {
36611
- if (_onClose) {
36612
- _onClose();
36613
- }
36614
- }
36615
- })), type === NPCDialogType.TextAndThumbnail && React.createElement(ThumbnailContainer$1, null, React.createElement(NPCThumbnail$1, {
36616
- src: imagePath || img$6
36617
- }))) : React.createElement(React.Fragment, null, React.createElement(Container$o, null, React.createElement(TextContainer$2, {
36618
- flex: type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'
36619
- }, React.createElement(NPCDialogText, {
36620
- type: type,
36621
- text: text || 'No text provided.',
36622
- onClose: function onClose() {
36623
- if (_onClose) {
36624
- _onClose();
36625
- }
36626
- }
36627
- })), type === NPCDialogType.TextAndThumbnail && React.createElement(ThumbnailContainer$1, null, React.createElement(NPCThumbnail$1, {
36628
- src: imagePath || img$6
36629
- })))));
36630
- };
36631
- var Container$o = /*#__PURE__*/styled.div.withConfig({
36632
- displayName: "NPCDialog__Container",
36633
- componentId: "sc-1b4aw74-0"
36634
- })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
36635
- var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
36636
- displayName: "NPCDialog__TextContainer",
36637
- componentId: "sc-1b4aw74-1"
36638
- })(["flex:", " 0 0;width:355px;"], function (_ref2) {
36639
- var flex = _ref2.flex;
36640
- return flex;
36641
- });
36642
- var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
36643
- displayName: "NPCDialog__ThumbnailContainer",
36644
- componentId: "sc-1b4aw74-2"
36645
- })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
36646
- var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
36647
- displayName: "NPCDialog__NPCThumbnail",
36648
- componentId: "sc-1b4aw74-3"
36649
- })(["image-rendering:pixelated;height:128px;width:128px;"]);
36650
-
36651
- var HistoryDialog = function HistoryDialog(_ref) {
36652
- var backgroundImgPath = _ref.backgroundImgPath,
36653
- fullCoverBackground = _ref.fullCoverBackground,
36654
- questions = _ref.questions,
36655
- answers = _ref.answers,
36656
- text = _ref.text,
36657
- imagePath = _ref.imagePath,
36658
- textAndTypeArray = _ref.textAndTypeArray,
36659
- onClose = _ref.onClose;
36660
- var _useState = useState(0),
36661
- img = _useState[0],
36662
- setImage = _useState[1];
36663
- var onHandleSpacePress = function onHandleSpacePress(event) {
36664
- if (event.code === 'Space') {
36665
- if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
36666
- setImage(function (prev) {
36667
- return prev + 1;
36668
- });
36669
- } else {
36670
- // if there's no more text chunks, close the dialog
36671
- onClose();
36672
- }
36673
- }
36674
- };
36675
- useEffect(function () {
36676
- document.addEventListener('keydown', onHandleSpacePress);
36677
- return function () {
36678
- return document.removeEventListener('keydown', onHandleSpacePress);
36679
- };
36680
- }, [backgroundImgPath]);
36681
- return React.createElement(BackgroundContainer, {
36682
- imgPath: backgroundImgPath[img],
36683
- fullImg: fullCoverBackground
36684
- }, React.createElement(DialogContainer, null, textAndTypeArray ? React.createElement(NPCMultiDialog, {
36685
- textAndTypeArray: textAndTypeArray,
36686
- onClose: onClose
36687
- }) : questions && answers ? React.createElement(QuestionDialog, {
36688
- questions: questions,
36689
- answers: answers,
36690
- onClose: onClose
36691
- }) : text && imagePath ? React.createElement(NPCDialog, {
36692
- text: text,
36693
- imagePath: imagePath,
36694
- onClose: onClose,
36695
- type: NPCDialogType.TextAndThumbnail
36696
- }) : React.createElement(NPCDialog, {
36697
- text: text,
36698
- onClose: onClose,
36699
- type: NPCDialogType.TextOnly
36700
- })));
36701
- };
36702
- var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
36703
- displayName: "HistoryDialog__BackgroundContainer",
36704
- componentId: "sc-u6oe75-0"
36705
- })(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
36706
- return props.imgPath;
36707
- }, function (props) {
36708
- return props.imgPath ? 'cover' : 'auto';
36709
- });
36710
- var DialogContainer = /*#__PURE__*/styled.div.withConfig({
36711
- displayName: "HistoryDialog__DialogContainer",
36712
- componentId: "sc-u6oe75-1"
36713
- })(["display:flex;justify-content:center;padding-top:200px;"]);
36714
-
36715
36717
  export { Button, ButtonTypes, CharacterSelection, Chat, ChatDeprecated, CheckButton, CircularController, CraftBook, DraggableContainer, Dropdown, DropdownSelectorContainer, DynamicText, EquipmentSet, EquipmentSlotSpriteByType, ErrorBoundary, HistoryDialog, ImgSide, Input, InputRadio, ItemContainer$1 as ItemContainer, ItemSelector, ItemSlot, ListMenu, NPCDialog, NPCDialogType, NPCMultiDialog, ProgressBar, PropertySelect, QuestInfo, QuestList, QuestionDialog, RPGUIContainer, RPGUIContainerTypes, RPGUIRoot, RangeSlider, RangeSliderType, Shortcuts, SkillProgressBar, SkillsContainer, Spellbook, SpriteFromAtlas, TextArea, TimeWidget, TradingMenu, Truncate, _RPGUI, rarityColor, useEventListener };
36716
36718
  //# sourceMappingURL=long-bow.esm.js.map