@rpg-engine/long-bow 0.3.85 → 0.3.86

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 +790 -790
  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 +719 -719
  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 +564 -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, isMobileOrTablet, getSPForLevel, PeriodOfDay } from '@rpg-engine/shared';
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';
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';
@@ -34584,546 +34584,6 @@ var EquipmentColumn = /*#__PURE__*/styled.div.withConfig({
34584
34584
  componentId: "sc-1wuddg2-1"
34585
34585
  })(["display:flex;justify-content:center;flex-wrap:wrap;flex-direction:column;touch-action:none;"]);
34586
34586
 
34587
- var IS_MOBILE_OR_TABLET = /*#__PURE__*/isMobileOrTablet();
34588
-
34589
- var chunkString = function chunkString(str, length) {
34590
- return str.match(new RegExp('.{1,' + length + '}', 'g'));
34591
- };
34592
-
34593
- var DynamicText = function DynamicText(_ref) {
34594
- var text = _ref.text,
34595
- onFinish = _ref.onFinish,
34596
- onStart = _ref.onStart;
34597
- var _useState = useState(''),
34598
- textState = _useState[0],
34599
- setTextState = _useState[1];
34600
- useEffect(function () {
34601
- var i = 0;
34602
- var interval = setInterval(function () {
34603
- // on every interval, show one more character
34604
- if (i === 0) {
34605
- if (onStart) {
34606
- onStart();
34607
- }
34608
- }
34609
- if (i < text.length) {
34610
- setTextState(text.substring(0, i + 1));
34611
- i++;
34612
- } else {
34613
- clearInterval(interval);
34614
- if (onFinish) {
34615
- onFinish();
34616
- }
34617
- }
34618
- }, 50);
34619
- return function () {
34620
- clearInterval(interval);
34621
- };
34622
- }, [text]);
34623
- return React.createElement(TextContainer, null, textState);
34624
- };
34625
- var TextContainer = /*#__PURE__*/styled.p.withConfig({
34626
- displayName: "DynamicText__TextContainer",
34627
- componentId: "sc-1ggl9nd-0"
34628
- })(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]);
34629
-
34630
- var img$6 = '';
34631
-
34632
- var img$7 = '';
34633
-
34634
- var NPCDialogText = function NPCDialogText(_ref) {
34635
- var text = _ref.text,
34636
- onClose = _ref.onClose,
34637
- onEndStep = _ref.onEndStep,
34638
- onStartStep = _ref.onStartStep,
34639
- type = _ref.type;
34640
- var windowSize = useRef([window.innerWidth, window.innerHeight]);
34641
- function maxCharacters(width) {
34642
- // Set the font size to 16 pixels
34643
- var fontSize = 11.2;
34644
- // Calculate the number of characters that can fit in one line
34645
- var charactersPerLine = Math.floor(width / 2 / fontSize);
34646
- // Calculate the number of lines that can fit in the div
34647
- var linesPerDiv = Math.floor(180 / fontSize);
34648
- // Calculate the maximum number of characters that can fit in the div
34649
- var maxCharacters = charactersPerLine * linesPerDiv;
34650
- // Return the maximum number of characters
34651
- return Math.round(maxCharacters / 5);
34652
- }
34653
- var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
34654
- var _useState = useState(0),
34655
- chunkIndex = _useState[0],
34656
- setChunkIndex = _useState[1];
34657
- var onHandleSpacePress = function onHandleSpacePress(event) {
34658
- if (event.code === 'Space') {
34659
- goToNextStep();
34660
- }
34661
- };
34662
- var goToNextStep = function goToNextStep() {
34663
- var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
34664
- if (hasNextChunk) {
34665
- setChunkIndex(function (prev) {
34666
- return prev + 1;
34667
- });
34668
- } else {
34669
- // if there's no more text chunks, close the dialog
34670
- onClose();
34671
- }
34672
- };
34673
- useEffect(function () {
34674
- document.addEventListener('keydown', onHandleSpacePress);
34675
- return function () {
34676
- return document.removeEventListener('keydown', onHandleSpacePress);
34677
- };
34678
- }, [chunkIndex]);
34679
- var _useState2 = useState(false),
34680
- showGoNextIndicator = _useState2[0],
34681
- setShowGoNextIndicator = _useState2[1];
34682
- return React.createElement(Container$e, null, React.createElement(DynamicText, {
34683
- text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
34684
- onFinish: function onFinish() {
34685
- setShowGoNextIndicator(true);
34686
- onEndStep && onEndStep();
34687
- },
34688
- onStart: function onStart() {
34689
- setShowGoNextIndicator(false);
34690
- onStartStep && onStartStep();
34691
- }
34692
- }), showGoNextIndicator && React.createElement(PressSpaceIndicator, {
34693
- right: type === NPCDialogType.TextOnly ? '1rem' : '10.5rem',
34694
- src: IS_MOBILE_OR_TABLET ? img$6 : img$7,
34695
- onPointerDown: function onPointerDown() {
34696
- goToNextStep();
34697
- }
34698
- }));
34699
- };
34700
- var Container$e = /*#__PURE__*/styled.div.withConfig({
34701
- displayName: "NPCDialogText__Container",
34702
- componentId: "sc-1cxkdh9-0"
34703
- })([""]);
34704
- var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
34705
- displayName: "NPCDialogText__PressSpaceIndicator",
34706
- componentId: "sc-1cxkdh9-1"
34707
- })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
34708
- var right = _ref2.right;
34709
- return right;
34710
- });
34711
-
34712
- //@ts-ignore
34713
- var useEventListener = function useEventListener(type, handler, el) {
34714
- if (el === void 0) {
34715
- el = window;
34716
- }
34717
- var savedHandler = React.useRef();
34718
- React.useEffect(function () {
34719
- savedHandler.current = handler;
34720
- }, [handler]);
34721
- React.useEffect(function () {
34722
- //@ts-ignore
34723
- var listener = function listener(e) {
34724
- return savedHandler.current(e);
34725
- };
34726
- el.addEventListener(type, listener);
34727
- return function () {
34728
- el.removeEventListener(type, listener);
34729
- };
34730
- }, [type, el]);
34731
- };
34732
-
34733
- var QuestionDialog = function QuestionDialog(_ref) {
34734
- var questions = _ref.questions,
34735
- answers = _ref.answers,
34736
- onClose = _ref.onClose;
34737
- var _useState = useState(questions[0]),
34738
- currentQuestion = _useState[0],
34739
- setCurrentQuestion = _useState[1];
34740
- var _useState2 = useState(false),
34741
- canShowAnswers = _useState2[0],
34742
- setCanShowAnswers = _useState2[1];
34743
- var onGetFirstAnswer = function onGetFirstAnswer() {
34744
- if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {
34745
- return null;
34746
- }
34747
- var firstAnswerId = currentQuestion.answerIds[0];
34748
- return answers.find(function (answer) {
34749
- return answer.id === firstAnswerId;
34750
- });
34751
- };
34752
- var _useState3 = useState(onGetFirstAnswer()),
34753
- currentAnswer = _useState3[0],
34754
- setCurrentAnswer = _useState3[1];
34755
- useEffect(function () {
34756
- setCurrentAnswer(onGetFirstAnswer());
34757
- }, [currentQuestion]);
34758
- var onGetAnswers = function onGetAnswers(answerIds) {
34759
- return answerIds.map(function (answerId) {
34760
- return answers.find(function (answer) {
34761
- return answer.id === answerId;
34762
- });
34763
- });
34764
- };
34765
- var onKeyPress = function onKeyPress(e) {
34766
- switch (e.key) {
34767
- case 'ArrowDown':
34768
- // select next answer, if any.
34769
- // if no next answer, select first answer
34770
- // const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(
34771
- // (answer) => answer?.id === currentAnswer!.id + 1
34772
- // );
34773
- var nextAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34774
- return (answer == null ? void 0 : answer.id) === currentAnswer.id + 1;
34775
- });
34776
- var nextAnswerID = currentQuestion.answerIds[nextAnswerIndex];
34777
- var nextAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34778
- return (answer == null ? void 0 : answer.id) === nextAnswerID;
34779
- });
34780
- setCurrentAnswer(nextAnswer || onGetFirstAnswer());
34781
- break;
34782
- case 'ArrowUp':
34783
- // select previous answer, if any.
34784
- // if no previous answer, select last answer
34785
- var previousAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34786
- return (answer == null ? void 0 : answer.id) === currentAnswer.id - 1;
34787
- });
34788
- var previousAnswerID = currentQuestion.answerIds && currentQuestion.answerIds[previousAnswerIndex];
34789
- var previousAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34790
- return (answer == null ? void 0 : answer.id) === previousAnswerID;
34791
- });
34792
- if (previousAnswer) {
34793
- setCurrentAnswer(previousAnswer);
34794
- } else {
34795
- setCurrentAnswer(onGetAnswers(currentQuestion.answerIds).pop());
34796
- }
34797
- break;
34798
- case 'Enter':
34799
- setCanShowAnswers(false);
34800
- if (!(currentAnswer != null && currentAnswer.nextQuestionId)) {
34801
- onClose();
34802
- return;
34803
- } else {
34804
- setCurrentQuestion(questions.find(function (question) {
34805
- return question.id === currentAnswer.nextQuestionId;
34806
- }));
34807
- }
34808
- break;
34809
- }
34810
- };
34811
- useEventListener('keydown', onKeyPress);
34812
- var onAnswerClick = function onAnswerClick(answer) {
34813
- setCanShowAnswers(false);
34814
- if (answer.nextQuestionId) {
34815
- // if there is a next question, go to it
34816
- setCurrentQuestion(questions.find(function (question) {
34817
- return question.id === answer.nextQuestionId;
34818
- }));
34819
- } else {
34820
- // else, finish dialog!
34821
- onClose();
34822
- }
34823
- };
34824
- var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
34825
- var answerIds = currentQuestion.answerIds;
34826
- if (!answerIds) {
34827
- return null;
34828
- }
34829
- var answers = onGetAnswers(answerIds);
34830
- if (!answers) {
34831
- return null;
34832
- }
34833
- return answers.map(function (answer) {
34834
- var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
34835
- var selectedColor = isSelected ? 'yellow' : 'white';
34836
- if (answer) {
34837
- return React.createElement(AnswerRow, {
34838
- key: "answer_" + answer.id
34839
- }, React.createElement(AnswerSelectedIcon, {
34840
- color: selectedColor
34841
- }, isSelected ? 'X' : null), React.createElement(Answer, {
34842
- key: answer.id,
34843
- onPointerDown: function onPointerDown() {
34844
- return onAnswerClick(answer);
34845
- },
34846
- color: selectedColor
34847
- }, answer.text));
34848
- }
34849
- return null;
34850
- });
34851
- };
34852
- return React.createElement(Container$f, null, React.createElement(QuestionContainer, null, React.createElement(DynamicText, {
34853
- text: currentQuestion.text,
34854
- onStart: function onStart() {
34855
- return setCanShowAnswers(false);
34856
- },
34857
- onFinish: function onFinish() {
34858
- return setCanShowAnswers(true);
34859
- }
34860
- })), canShowAnswers && React.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
34861
- };
34862
- var Container$f = /*#__PURE__*/styled.div.withConfig({
34863
- displayName: "QuestionDialog__Container",
34864
- componentId: "sc-bxc5u0-0"
34865
- })(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
34866
- var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
34867
- displayName: "QuestionDialog__QuestionContainer",
34868
- componentId: "sc-bxc5u0-1"
34869
- })(["flex:100%;width:100%;"]);
34870
- var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
34871
- displayName: "QuestionDialog__AnswersContainer",
34872
- componentId: "sc-bxc5u0-2"
34873
- })(["flex:100%;"]);
34874
- var Answer = /*#__PURE__*/styled.p.withConfig({
34875
- displayName: "QuestionDialog__Answer",
34876
- componentId: "sc-bxc5u0-3"
34877
- })(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
34878
- return props.color;
34879
- });
34880
- var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
34881
- displayName: "QuestionDialog__AnswerSelectedIcon",
34882
- componentId: "sc-bxc5u0-4"
34883
- })(["flex:5% 0 0;color:", " !important;"], function (props) {
34884
- return props.color;
34885
- });
34886
- var AnswerRow = /*#__PURE__*/styled.div.withConfig({
34887
- displayName: "QuestionDialog__AnswerRow",
34888
- componentId: "sc-bxc5u0-5"
34889
- })(["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;}"]);
34890
-
34891
- var img$8 = '';
34892
-
34893
- var NPCDialogType;
34894
- (function (NPCDialogType) {
34895
- NPCDialogType["TextOnly"] = "TextOnly";
34896
- NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
34897
- })(NPCDialogType || (NPCDialogType = {}));
34898
- var NPCDialog = function NPCDialog(_ref) {
34899
- var text = _ref.text,
34900
- type = _ref.type,
34901
- _onClose = _ref.onClose,
34902
- imagePath = _ref.imagePath,
34903
- _ref$isQuestionDialog = _ref.isQuestionDialog,
34904
- isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
34905
- questions = _ref.questions,
34906
- answers = _ref.answers;
34907
- return React.createElement(RPGUIContainer, {
34908
- type: RPGUIContainerTypes.FramedGold,
34909
- width: isQuestionDialog ? '600px' : '80%',
34910
- height: '180px'
34911
- }, isQuestionDialog && questions && answers ? React.createElement(React.Fragment, null, React.createElement(TextContainer$1, {
34912
- flex: type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'
34913
- }, React.createElement(QuestionDialog, {
34914
- questions: questions,
34915
- answers: answers,
34916
- onClose: function onClose() {
34917
- if (_onClose) {
34918
- _onClose();
34919
- }
34920
- }
34921
- })), type === NPCDialogType.TextAndThumbnail && React.createElement(ThumbnailContainer, null, React.createElement(NPCThumbnail, {
34922
- src: imagePath || img$8
34923
- }))) : React.createElement(React.Fragment, null, React.createElement(Container$g, null, React.createElement(TextContainer$1, {
34924
- flex: type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'
34925
- }, React.createElement(NPCDialogText, {
34926
- type: type,
34927
- text: text || 'No text provided.',
34928
- onClose: function onClose() {
34929
- if (_onClose) {
34930
- _onClose();
34931
- }
34932
- }
34933
- })), type === NPCDialogType.TextAndThumbnail && React.createElement(ThumbnailContainer, null, React.createElement(NPCThumbnail, {
34934
- src: imagePath || img$8
34935
- })))));
34936
- };
34937
- var Container$g = /*#__PURE__*/styled.div.withConfig({
34938
- displayName: "NPCDialog__Container",
34939
- componentId: "sc-1b4aw74-0"
34940
- })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
34941
- var TextContainer$1 = /*#__PURE__*/styled.div.withConfig({
34942
- displayName: "NPCDialog__TextContainer",
34943
- componentId: "sc-1b4aw74-1"
34944
- })(["flex:", " 0 0;width:355px;"], function (_ref2) {
34945
- var flex = _ref2.flex;
34946
- return flex;
34947
- });
34948
- var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
34949
- displayName: "NPCDialog__ThumbnailContainer",
34950
- componentId: "sc-1b4aw74-2"
34951
- })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
34952
- var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
34953
- displayName: "NPCDialog__NPCThumbnail",
34954
- componentId: "sc-1b4aw74-3"
34955
- })(["image-rendering:pixelated;height:128px;width:128px;"]);
34956
-
34957
- var ImgSide;
34958
- (function (ImgSide) {
34959
- ImgSide["right"] = "right";
34960
- ImgSide["left"] = "left";
34961
- })(ImgSide || (ImgSide = {}));
34962
- var NPCMultiDialog = function NPCMultiDialog(_ref) {
34963
- var _textAndTypeArray$sli;
34964
- var _onClose = _ref.onClose,
34965
- textAndTypeArray = _ref.textAndTypeArray;
34966
- var _useState = useState(false),
34967
- showGoNextIndicator = _useState[0],
34968
- setShowGoNextIndicator = _useState[1];
34969
- var _useState2 = useState(0),
34970
- slide = _useState2[0],
34971
- setSlide = _useState2[1];
34972
- var onHandleSpacePress = function onHandleSpacePress(event) {
34973
- if (event.code === 'Space') {
34974
- if (slide < (textAndTypeArray == null ? void 0 : textAndTypeArray.length) - 1) {
34975
- setSlide(function (prev) {
34976
- return prev + 1;
34977
- });
34978
- } else {
34979
- // if there's no more text chunks, close the dialog
34980
- _onClose();
34981
- }
34982
- }
34983
- };
34984
- useEffect(function () {
34985
- document.addEventListener('keydown', onHandleSpacePress);
34986
- return function () {
34987
- return document.removeEventListener('keydown', onHandleSpacePress);
34988
- };
34989
- }, [slide]);
34990
- return React.createElement(RPGUIContainer, {
34991
- type: RPGUIContainerTypes.FramedGold,
34992
- width: '50%',
34993
- height: '180px'
34994
- }, 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, {
34995
- flex: '70%'
34996
- }, React.createElement(NPCDialogText, {
34997
- onStartStep: function onStartStep() {
34998
- return setShowGoNextIndicator(false);
34999
- },
35000
- onEndStep: function onEndStep() {
35001
- return setShowGoNextIndicator(true);
35002
- },
35003
- text: textAndTypeArray[slide].text || 'No text provided.',
35004
- onClose: function onClose() {
35005
- if (_onClose) {
35006
- _onClose();
35007
- }
35008
- }
35009
- })), React.createElement(ThumbnailContainer$1, null, React.createElement(NPCThumbnail$1, {
35010
- src: textAndTypeArray[slide].imagePath || img$8
35011
- })), showGoNextIndicator && React.createElement(PressSpaceIndicator$1, {
35012
- right: '10.5rem',
35013
- src: img$7
35014
- })), textAndTypeArray[slide].imageSide === 'left' && React.createElement(React.Fragment, null, React.createElement(ThumbnailContainer$1, null, React.createElement(NPCThumbnail$1, {
35015
- src: textAndTypeArray[slide].imagePath || img$8
35016
- })), React.createElement(TextContainer$2, {
35017
- flex: '70%'
35018
- }, React.createElement(NPCDialogText, {
35019
- onStartStep: function onStartStep() {
35020
- return setShowGoNextIndicator(false);
35021
- },
35022
- onEndStep: function onEndStep() {
35023
- return setShowGoNextIndicator(true);
35024
- },
35025
- text: textAndTypeArray[slide].text || 'No text provided.',
35026
- onClose: function onClose() {
35027
- if (_onClose) {
35028
- _onClose();
35029
- }
35030
- }
35031
- })), showGoNextIndicator && React.createElement(PressSpaceIndicator$1, {
35032
- right: '1rem',
35033
- src: img$7
35034
- }))), ")"));
35035
- };
35036
- var Container$h = /*#__PURE__*/styled.div.withConfig({
35037
- displayName: "NPCMultiDialog__Container",
35038
- componentId: "sc-rvu5wg-0"
35039
- })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
35040
- var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
35041
- displayName: "NPCMultiDialog__TextContainer",
35042
- componentId: "sc-rvu5wg-1"
35043
- })(["flex:", " 0 0;width:355px;"], function (_ref2) {
35044
- var flex = _ref2.flex;
35045
- return flex;
35046
- });
35047
- var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
35048
- displayName: "NPCMultiDialog__ThumbnailContainer",
35049
- componentId: "sc-rvu5wg-2"
35050
- })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
35051
- var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
35052
- displayName: "NPCMultiDialog__NPCThumbnail",
35053
- componentId: "sc-rvu5wg-3"
35054
- })(["image-rendering:pixelated;height:128px;width:128px;"]);
35055
- var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
35056
- displayName: "NPCMultiDialog__PressSpaceIndicator",
35057
- componentId: "sc-rvu5wg-4"
35058
- })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref3) {
35059
- var right = _ref3.right;
35060
- return right;
35061
- });
35062
-
35063
- var HistoryDialog = function HistoryDialog(_ref) {
35064
- var backgroundImgPath = _ref.backgroundImgPath,
35065
- fullCoverBackground = _ref.fullCoverBackground,
35066
- questions = _ref.questions,
35067
- answers = _ref.answers,
35068
- text = _ref.text,
35069
- imagePath = _ref.imagePath,
35070
- textAndTypeArray = _ref.textAndTypeArray,
35071
- onClose = _ref.onClose;
35072
- var _useState = useState(0),
35073
- img = _useState[0],
35074
- setImage = _useState[1];
35075
- var onHandleSpacePress = function onHandleSpacePress(event) {
35076
- if (event.code === 'Space') {
35077
- if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
35078
- setImage(function (prev) {
35079
- return prev + 1;
35080
- });
35081
- } else {
35082
- // if there's no more text chunks, close the dialog
35083
- onClose();
35084
- }
35085
- }
35086
- };
35087
- useEffect(function () {
35088
- document.addEventListener('keydown', onHandleSpacePress);
35089
- return function () {
35090
- return document.removeEventListener('keydown', onHandleSpacePress);
35091
- };
35092
- }, [backgroundImgPath]);
35093
- return React.createElement(BackgroundContainer, {
35094
- imgPath: backgroundImgPath[img],
35095
- fullImg: fullCoverBackground
35096
- }, React.createElement(DialogContainer, null, textAndTypeArray ? React.createElement(NPCMultiDialog, {
35097
- textAndTypeArray: textAndTypeArray,
35098
- onClose: onClose
35099
- }) : questions && answers ? React.createElement(QuestionDialog, {
35100
- questions: questions,
35101
- answers: answers,
35102
- onClose: onClose
35103
- }) : text && imagePath ? React.createElement(NPCDialog, {
35104
- text: text,
35105
- imagePath: imagePath,
35106
- onClose: onClose,
35107
- type: NPCDialogType.TextAndThumbnail
35108
- }) : React.createElement(NPCDialog, {
35109
- text: text,
35110
- onClose: onClose,
35111
- type: NPCDialogType.TextOnly
35112
- })));
35113
- };
35114
- var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
35115
- displayName: "HistoryDialog__BackgroundContainer",
35116
- componentId: "sc-u6oe75-0"
35117
- })(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
35118
- return props.imgPath;
35119
- }, function (props) {
35120
- return props.imgPath ? 'cover' : 'auto';
35121
- });
35122
- var DialogContainer = /*#__PURE__*/styled.div.withConfig({
35123
- displayName: "HistoryDialog__DialogContainer",
35124
- componentId: "sc-u6oe75-1"
35125
- })(["display:flex;justify-content:center;padding-top:200px;"]);
35126
-
35127
34587
  var SlotsContainer = function SlotsContainer(_ref) {
35128
34588
  var children = _ref.children,
35129
34589
  title = _ref.title,
@@ -35369,7 +34829,7 @@ var ShortcutsSetter = function ShortcutsSetter(_ref) {
35369
34829
  return word[0];
35370
34830
  }));
35371
34831
  };
35372
- return React.createElement(Container$i, null, React.createElement("p", null, "Shortcuts:"), React.createElement(List, {
34832
+ return React.createElement(Container$e, null, React.createElement("p", null, "Shortcuts:"), React.createElement(List, {
35373
34833
  id: "shortcuts_list"
35374
34834
  }, Array.from({
35375
34835
  length: 6
@@ -35385,7 +34845,7 @@ var ShortcutsSetter = function ShortcutsSetter(_ref) {
35385
34845
  }, getContent(i));
35386
34846
  })));
35387
34847
  };
35388
- var Container$i = /*#__PURE__*/styled.div.withConfig({
34848
+ var Container$e = /*#__PURE__*/styled.div.withConfig({
35389
34849
  displayName: "ShortcutsSetter__Container",
35390
34850
  componentId: "sc-xuouuf-0"
35391
34851
  })(["p{margin:0;margin-left:0.5rem;}"]);
@@ -35490,173 +34950,499 @@ var ItemContainer$1 = function ItemContainer(_ref) {
35490
34950
  isDepotSystem: isDepotSystem
35491
34951
  }));
35492
34952
  }
35493
- return slots;
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;
35302
+ }
35303
+ var firstAnswerId = currentQuestion.answerIds[0];
35304
+ return answers.find(function (answer) {
35305
+ return answer.id === firstAnswerId;
35306
+ });
35494
35307
  };
35495
- return React.createElement(React.Fragment, null, React.createElement(SlotsContainer, {
35496
- title: itemContainer.name || 'Container',
35497
- onClose: onClose,
35498
- initialPosition: initialPosition,
35499
- scale: scale,
35500
- onPositionChangeEnd: onPositionChangeEnd,
35501
- onPositionChangeStart: onPositionChangeStart
35502
- }, type === ItemContainerType.Inventory && shortcuts && removeShortcut && React.createElement(ShortcutsSetter, {
35503
- setSettingShortcutIndex: setSettingShortcutIndex,
35504
- settingShortcutIndex: settingShortcutIndex,
35505
- shortcuts: shortcuts,
35506
- removeShortcut: removeShortcut,
35507
- atlasIMG: atlasIMG,
35508
- atlasJSON: atlasJSON
35509
- }), React.createElement(ItemsContainer, {
35510
- className: "item-container-body"
35511
- }, onRenderSlots())), quantitySelect.isOpen && React.createElement(ModalPortal, null, React.createElement(QuantitySelectorContainer, null, React.createElement(ItemQuantitySelector, {
35512
- quantity: quantitySelect.maxQuantity,
35513
- onConfirm: function onConfirm(quantity) {
35514
- quantitySelect.callback(quantity);
35515
- setQuantitySelect({
35516
- isOpen: false,
35517
- maxQuantity: 1,
35518
- callback: function callback() {}
35519
- });
35520
- },
35521
- onClose: function onClose() {
35522
- quantitySelect.callback(-1);
35523
- setQuantitySelect({
35524
- isOpen: false,
35525
- maxQuantity: 1,
35526
- callback: function callback() {}
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;
35527
35318
  });
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;
35528
35365
  }
35529
- }))));
35530
- };
35531
- var ItemsContainer = /*#__PURE__*/styled.div.withConfig({
35532
- displayName: "ItemContainer__ItemsContainer",
35533
- componentId: "sc-15y5p9l-0"
35534
- })(["display:flex;justify-content:center;flex-wrap:wrap;"]);
35535
- var QuantitySelectorContainer = /*#__PURE__*/styled.div.withConfig({
35536
- displayName: "ItemContainer__QuantitySelectorContainer",
35537
- componentId: "sc-15y5p9l-1"
35538
- })(["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);"]);
35539
-
35540
- var ItemSelector = function ItemSelector(_ref) {
35541
- var atlasIMG = _ref.atlasIMG,
35542
- atlasJSON = _ref.atlasJSON,
35543
- options = _ref.options,
35544
- onClose = _ref.onClose,
35545
- onSelect = _ref.onSelect;
35546
- var _useState = useState(),
35547
- selectedValue = _useState[0],
35548
- setSelectedValue = _useState[1];
35549
- var handleClick = function handleClick() {
35550
- var element = document.querySelector("input[name='test']:checked");
35551
- var elementValue = element.value;
35552
- setSelectedValue(elementValue);
35553
35366
  };
35554
- useEffect(function () {
35555
- if (selectedValue) {
35556
- onSelect(selectedValue);
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();
35557
35378
  }
35558
- }, [selectedValue]);
35559
- return React.createElement(DraggableContainer, {
35560
- type: RPGUIContainerTypes.Framed,
35561
- width: "500px",
35562
- cancelDrag: ".equipment-container-body .arrow-selector",
35563
- onCloseButton: function onCloseButton() {
35564
- if (onClose) {
35565
- onClose();
35566
- }
35379
+ };
35380
+ var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
35381
+ var answerIds = currentQuestion.answerIds;
35382
+ if (!answerIds) {
35383
+ return null;
35567
35384
  }
35568
- }, React.createElement("div", {
35569
- style: {
35570
- width: '100%'
35385
+ var answers = onGetAnswers(answerIds);
35386
+ if (!answers) {
35387
+ return null;
35571
35388
  }
35572
- }, React.createElement(Title$3, null, 'Harvesting instruments'), React.createElement(Subtitle$1, null, 'Use the tool, you need it'), React.createElement("hr", {
35573
- className: "golden"
35574
- })), React.createElement(RadioInputScroller$1, null, options == null ? void 0 : options.map(function (option, index) {
35575
- return React.createElement(RadioOptionsWrapper$1, {
35576
- key: index
35577
- }, React.createElement(SpriteAtlasWrapper$1, null, React.createElement(SpriteFromAtlas, {
35578
- atlasIMG: atlasIMG,
35579
- atlasJSON: atlasJSON,
35580
- spriteKey: option.imageKey,
35581
- imgScale: 3
35582
- })), React.createElement("div", null, React.createElement("input", {
35583
- className: "rpgui-radio",
35584
- type: "radio",
35585
- value: option.name,
35586
- name: "test"
35587
- }), React.createElement("label", {
35588
- onPointerDown: handleClick,
35589
- style: {
35590
- display: 'flex',
35591
- alignItems: 'center'
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));
35592
35404
  }
35593
- }, option.name, " ", React.createElement("br", null), option.description)));
35594
- })), React.createElement(ButtonWrapper$1, null, React.createElement(Button, {
35595
- buttonType: ButtonTypes.RPGUIButton,
35596
- onPointerDown: onClose
35597
- }, "Cancel"), React.createElement(Button, {
35598
- buttonType: ButtonTypes.RPGUIButton
35599
- }, "Select")));
35600
- };
35601
- var Title$3 = /*#__PURE__*/styled.h1.withConfig({
35602
- displayName: "ItemSelector__Title",
35603
- componentId: "sc-gptoxp-0"
35604
- })(["font-size:0.6rem;color:yellow !important;"]);
35605
- var Subtitle$1 = /*#__PURE__*/styled.h1.withConfig({
35606
- displayName: "ItemSelector__Subtitle",
35607
- componentId: "sc-gptoxp-1"
35608
- })(["font-size:0.4rem;color:yellow !important;"]);
35609
- var RadioInputScroller$1 = /*#__PURE__*/styled.div.withConfig({
35610
- displayName: "ItemSelector__RadioInputScroller",
35611
- componentId: "sc-gptoxp-2"
35612
- })(["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;"]);
35613
- var SpriteAtlasWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35614
- displayName: "ItemSelector__SpriteAtlasWrapper",
35615
- componentId: "sc-gptoxp-3"
35616
- })(["margin-right:40px;"]);
35617
- var RadioOptionsWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35618
- displayName: "ItemSelector__RadioOptionsWrapper",
35619
- componentId: "sc-gptoxp-4"
35620
- })(["display:flex;align-items:stretch;margin-bottom:40px;"]);
35621
- var ButtonWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35622
- displayName: "ItemSelector__ButtonWrapper",
35623
- componentId: "sc-gptoxp-5"
35624
- })(["display:flex;justify-content:space-around;padding-top:20px;width:100%;"]);
35625
-
35626
- var ListMenu = function ListMenu(_ref) {
35627
- var options = _ref.options,
35628
- onSelected = _ref.onSelected,
35629
- x = _ref.x,
35630
- y = _ref.y;
35631
- return React.createElement(Container$j, {
35632
- x: x,
35633
- y: y
35634
- }, React.createElement("ul", {
35635
- className: "rpgui-list-imp",
35636
- style: {
35637
- overflow: 'hidden'
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);
35638
35415
  }
35639
- }, options.map(function (params, index) {
35640
- return React.createElement(ListElement$1, {
35641
- key: (params == null ? void 0 : params.id) || index,
35642
- onPointerDown: function onPointerDown() {
35643
- onSelected(params == null ? void 0 : params.id);
35644
- }
35645
- }, (params == null ? void 0 : params.text) || 'No text');
35646
- })));
35416
+ })), canShowAnswers && React.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
35647
35417
  };
35648
- var Container$j = /*#__PURE__*/styled.div.withConfig({
35649
- displayName: "ListMenu__Container",
35650
- componentId: "sc-i9097t-0"
35651
- })(["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) {
35652
- return props.y || 0;
35653
- }, function (props) {
35654
- return props.x || 0;
35655
- }, uiFonts.size.xsmall);
35656
- var ListElement$1 = /*#__PURE__*/styled.li.withConfig({
35657
- displayName: "ListMenu__ListElement",
35658
- componentId: "sc-i9097t-1"
35659
- })(["margin-right:0.5rem;"]);
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;}"]);
35660
35446
 
35661
35447
  var ProgressBar = function ProgressBar(_ref) {
35662
35448
  var max = _ref.max,
@@ -35675,7 +35461,7 @@ var ProgressBar = function ProgressBar(_ref) {
35675
35461
  }
35676
35462
  return value * 100 / max;
35677
35463
  };
35678
- return React.createElement(Container$k, {
35464
+ return React.createElement(Container$i, {
35679
35465
  className: "rpgui-progress",
35680
35466
  "data-value": calculatePercentageValue(max, value) / 100,
35681
35467
  "data-rpguitype": "progress",
@@ -35704,7 +35490,7 @@ var TextOverlay$1 = /*#__PURE__*/styled.div.withConfig({
35704
35490
  displayName: "ProgressBar__TextOverlay",
35705
35491
  componentId: "sc-qa6fzh-1"
35706
35492
  })(["width:100%;position:relative;"]);
35707
- var Container$k = /*#__PURE__*/styled.div.withConfig({
35493
+ var Container$i = /*#__PURE__*/styled.div.withConfig({
35708
35494
  displayName: "ProgressBar__Container",
35709
35495
  componentId: "sc-qa6fzh-2"
35710
35496
  })(["display:flex;flex-direction:column;min-width:", "px;width:", "%;justify-content:start;align-items:flex-start;", ""], function (props) {
@@ -35715,7 +35501,7 @@ var Container$k = /*#__PURE__*/styled.div.withConfig({
35715
35501
  return props.style;
35716
35502
  });
35717
35503
 
35718
- var img$9 = '';
35504
+ var img$8 = '';
35719
35505
 
35720
35506
  var QuestInfo = function QuestInfo(_ref) {
35721
35507
  var quests = _ref.quests,
@@ -35759,7 +35545,7 @@ var QuestInfo = function QuestInfo(_ref) {
35759
35545
  }), React.createElement(QuestContainer, null, React.createElement(TitleContainer$1, {
35760
35546
  className: "drag-handler"
35761
35547
  }, React.createElement(Title$4, null, React.createElement(Thumbnail, {
35762
- src: quests[currentIndex].thumbnail || img$9
35548
+ src: quests[currentIndex].thumbnail || img$8
35763
35549
  }), quests[currentIndex].title), React.createElement(QuestSplitDiv, null, React.createElement("hr", {
35764
35550
  className: "golden"
35765
35551
  }))), React.createElement(Content, null, React.createElement("p", null, quests[currentIndex].description)), React.createElement(QuestColumn, {
@@ -35778,7 +35564,7 @@ var QuestInfo = function QuestInfo(_ref) {
35778
35564
  })))) : React.createElement(QuestsContainer, null, React.createElement(QuestContainer, null, React.createElement(TitleContainer$1, {
35779
35565
  className: "drag-handler"
35780
35566
  }, React.createElement(Title$4, null, React.createElement(Thumbnail, {
35781
- src: quests[0].thumbnail || img$9
35567
+ src: quests[0].thumbnail || img$8
35782
35568
  }), quests[0].title), React.createElement(QuestSplitDiv, null, React.createElement("hr", {
35783
35569
  className: "golden"
35784
35570
  }))), React.createElement(Content, null, React.createElement("p", null, quests[0].description)), React.createElement(QuestColumn, {
@@ -36029,7 +35815,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
36029
35815
  bgColor = _ref$bgColor === void 0 ? 'red' : _ref$bgColor,
36030
35816
  _ref$margin = _ref.margin,
36031
35817
  margin = _ref$margin === void 0 ? 20 : _ref$margin;
36032
- return React.createElement(Container$l, {
35818
+ return React.createElement(Container$j, {
36033
35819
  className: "simple-progress-bar"
36034
35820
  }, React.createElement(ProgressBarContainer, {
36035
35821
  margin: margin
@@ -36038,7 +35824,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
36038
35824
  bgColor: bgColor
36039
35825
  }))));
36040
35826
  };
36041
- var Container$l = /*#__PURE__*/styled.div.withConfig({
35827
+ var Container$j = /*#__PURE__*/styled.div.withConfig({
36042
35828
  displayName: "SimpleProgressBar__Container",
36043
35829
  componentId: "sc-mbeil3-0"
36044
35830
  })(["display:flex;justify-content:center;align-items:center;width:100%;"]);
@@ -36269,7 +36055,7 @@ var Spell = function Spell(_ref) {
36269
36055
  isSettingShortcut = _ref.isSettingShortcut,
36270
36056
  minMagicLevelRequired = _ref.minMagicLevelRequired;
36271
36057
  var disabled = isSettingShortcut ? charMagicLevel < minMagicLevelRequired : manaCost > charMana || charMagicLevel < minMagicLevelRequired;
36272
- return React.createElement(Container$m, {
36058
+ return React.createElement(Container$k, {
36273
36059
  disabled: disabled,
36274
36060
  onPointerDown: onPointerDown == null ? void 0 : onPointerDown.bind(null, spellKey),
36275
36061
  isSettingShortcut: isSettingShortcut && !disabled,
@@ -36282,7 +36068,7 @@ var Spell = function Spell(_ref) {
36282
36068
  className: "mana"
36283
36069
  }, manaCost)));
36284
36070
  };
36285
- var Container$m = /*#__PURE__*/styled.button.withConfig({
36071
+ var Container$k = /*#__PURE__*/styled.button.withConfig({
36286
36072
  displayName: "Spell__Container",
36287
36073
  componentId: "sc-j96fa2-0"
36288
36074
  })(["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) {
@@ -36369,7 +36155,7 @@ var Spellbook = function Spellbook(_ref) {
36369
36155
  height: "inherit",
36370
36156
  cancelDrag: "#spellbook-search, #shortcuts_list, .spell",
36371
36157
  scale: scale
36372
- }, React.createElement(Container$n, null, React.createElement(Title$7, null, "Learned Spells"), React.createElement(ShortcutsSetter, {
36158
+ }, React.createElement(Container$l, null, React.createElement(Title$7, null, "Learned Spells"), React.createElement(ShortcutsSetter, {
36373
36159
  setSettingShortcutIndex: setSettingShortcutIndex,
36374
36160
  settingShortcutIndex: settingShortcutIndex,
36375
36161
  shortcuts: shortcuts,
@@ -36401,7 +36187,7 @@ var Title$7 = /*#__PURE__*/styled.h1.withConfig({
36401
36187
  displayName: "Spellbook__Title",
36402
36188
  componentId: "sc-r02nfq-0"
36403
36189
  })(["font-size:", " !important;margin-bottom:0 !important;"], uiFonts.size.large);
36404
- var Container$n = /*#__PURE__*/styled.div.withConfig({
36190
+ var Container$l = /*#__PURE__*/styled.div.withConfig({
36405
36191
  displayName: "Spellbook__Container",
36406
36192
  componentId: "sc-r02nfq-1"
36407
36193
  })(["width:100%;height:100%;color:white;display:flex;flex-direction:column;"]);
@@ -36415,16 +36201,16 @@ var TextArea = function TextArea(_ref) {
36415
36201
  return React.createElement("textarea", Object.assign({}, props));
36416
36202
  };
36417
36203
 
36418
- var img$a = '';
36204
+ var img$9 = '';
36419
36205
 
36420
- var img$b = '';
36206
+ var img$a = '';
36421
36207
 
36422
- var img$c = '';
36208
+ var img$b = '';
36423
36209
 
36424
36210
  var DayNightPeriod = function DayNightPeriod(_ref) {
36425
36211
  var _periodOfDaySrcFiles;
36426
36212
  var periodOfDay = _ref.periodOfDay;
36427
- var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[PeriodOfDay.Morning] = img$b, _periodOfDaySrcFiles[PeriodOfDay.Afternoon] = img$a, _periodOfDaySrcFiles[PeriodOfDay.Night] = img$c, _periodOfDaySrcFiles);
36213
+ var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[PeriodOfDay.Morning] = img$a, _periodOfDaySrcFiles[PeriodOfDay.Afternoon] = img$9, _periodOfDaySrcFiles[PeriodOfDay.Night] = img$b, _periodOfDaySrcFiles);
36428
36214
  return React.createElement(GifContainer, null, React.createElement("img", {
36429
36215
  src: periodOfDaySrcFiles[periodOfDay]
36430
36216
  }));
@@ -36434,7 +36220,7 @@ var GifContainer = /*#__PURE__*/styled.div.withConfig({
36434
36220
  componentId: "sc-10t97fw-0"
36435
36221
  })(["width:100%;img{width:67%;}"]);
36436
36222
 
36437
- var img$d = '';
36223
+ var img$c = '';
36438
36224
 
36439
36225
  var TimeWidget = function TimeWidget(_ref) {
36440
36226
  var onClose = _ref.onClose,
@@ -36452,7 +36238,7 @@ var TimeWidget = function TimeWidget(_ref) {
36452
36238
  var WidgetContainer = /*#__PURE__*/styled.div.withConfig({
36453
36239
  displayName: "TimeWidget__WidgetContainer",
36454
36240
  componentId: "sc-1ja236h-0"
36455
- })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$d);
36241
+ })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$c);
36456
36242
  var Time = /*#__PURE__*/styled.div.withConfig({
36457
36243
  displayName: "TimeWidget__Time",
36458
36244
  componentId: "sc-1ja236h-1"
@@ -36701,16 +36487,230 @@ var Truncate = function Truncate(_ref) {
36701
36487
  var _ref$maxLines = _ref.maxLines,
36702
36488
  maxLines = _ref$maxLines === void 0 ? 1 : _ref$maxLines,
36703
36489
  children = _ref.children;
36704
- return React.createElement(Container$o, {
36490
+ return React.createElement(Container$m, {
36705
36491
  maxLines: maxLines
36706
36492
  }, children);
36707
36493
  };
36708
- var Container$o = /*#__PURE__*/styled.div.withConfig({
36494
+ var Container$m = /*#__PURE__*/styled.div.withConfig({
36709
36495
  displayName: "Truncate__Container",
36710
36496
  componentId: "sc-6x00qb-0"
36711
36497
  })(["display:-webkit-box;max-width:100%;max-height:100%;-webkit-line-clamp:", ";-webkit-box-orient:vertical;overflow:hidden;"], function (props) {
36712
36498
  return props.maxLines;
36713
36499
  });
36714
36500
 
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
36715
  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
36716
  //# sourceMappingURL=long-bow.esm.js.map