@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
@@ -34589,667 +34589,129 @@ var EquipmentColumn = /*#__PURE__*/styled.div.withConfig({
34589
34589
  componentId: "sc-1wuddg2-1"
34590
34590
  })(["display:flex;justify-content:center;flex-wrap:wrap;flex-direction:column;touch-action:none;"]);
34591
34591
 
34592
- var IS_MOBILE_OR_TABLET = /*#__PURE__*/shared.isMobileOrTablet();
34593
-
34594
- var chunkString = function chunkString(str, length) {
34595
- return str.match(new RegExp('.{1,' + length + '}', 'g'));
34596
- };
34597
-
34598
- var DynamicText = function DynamicText(_ref) {
34599
- var text = _ref.text,
34600
- onFinish = _ref.onFinish,
34601
- onStart = _ref.onStart;
34602
- var _useState = React.useState(''),
34603
- textState = _useState[0],
34604
- setTextState = _useState[1];
34605
- React.useEffect(function () {
34606
- var i = 0;
34607
- var interval = setInterval(function () {
34608
- // on every interval, show one more character
34609
- if (i === 0) {
34610
- if (onStart) {
34611
- onStart();
34612
- }
34592
+ var SlotsContainer = function SlotsContainer(_ref) {
34593
+ var children = _ref.children,
34594
+ title = _ref.title,
34595
+ onClose = _ref.onClose,
34596
+ _onPositionChange = _ref.onPositionChange,
34597
+ _onPositionChangeEnd = _ref.onPositionChangeEnd,
34598
+ _onPositionChangeStart = _ref.onPositionChangeStart,
34599
+ onOutsideClick = _ref.onOutsideClick,
34600
+ initialPosition = _ref.initialPosition,
34601
+ scale = _ref.scale;
34602
+ return React__default.createElement(DraggableContainer, {
34603
+ title: title,
34604
+ type: exports.RPGUIContainerTypes.Framed,
34605
+ onCloseButton: function onCloseButton() {
34606
+ if (onClose) {
34607
+ onClose();
34613
34608
  }
34614
- if (i < text.length) {
34615
- setTextState(text.substring(0, i + 1));
34616
- i++;
34617
- } else {
34618
- clearInterval(interval);
34619
- if (onFinish) {
34620
- onFinish();
34621
- }
34609
+ },
34610
+ width: "400px",
34611
+ cancelDrag: ".item-container-body, #shortcuts_list",
34612
+ onPositionChange: function onPositionChange(_ref2) {
34613
+ var x = _ref2.x,
34614
+ y = _ref2.y;
34615
+ if (_onPositionChange) {
34616
+ _onPositionChange({
34617
+ x: x,
34618
+ y: y
34619
+ });
34622
34620
  }
34623
- }, 50);
34624
- return function () {
34625
- clearInterval(interval);
34626
- };
34627
- }, [text]);
34628
- return React__default.createElement(TextContainer, null, textState);
34621
+ },
34622
+ onPositionChangeEnd: function onPositionChangeEnd(_ref3) {
34623
+ var x = _ref3.x,
34624
+ y = _ref3.y;
34625
+ if (_onPositionChangeEnd) {
34626
+ _onPositionChangeEnd({
34627
+ x: x,
34628
+ y: y
34629
+ });
34630
+ }
34631
+ },
34632
+ onPositionChangeStart: function onPositionChangeStart(_ref4) {
34633
+ var x = _ref4.x,
34634
+ y = _ref4.y;
34635
+ if (_onPositionChangeStart) {
34636
+ _onPositionChangeStart({
34637
+ x: x,
34638
+ y: y
34639
+ });
34640
+ }
34641
+ },
34642
+ onOutsideClick: onOutsideClick,
34643
+ initialPosition: initialPosition,
34644
+ scale: scale
34645
+ }, children);
34629
34646
  };
34630
- var TextContainer = /*#__PURE__*/styled.p.withConfig({
34631
- displayName: "DynamicText__TextContainer",
34632
- componentId: "sc-1ggl9nd-0"
34633
- })(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]);
34634
-
34635
- var img$6 = '';
34636
-
34637
- var img$7 = '';
34638
34647
 
34639
- var NPCDialogText = function NPCDialogText(_ref) {
34640
- var text = _ref.text,
34641
- onClose = _ref.onClose,
34642
- onEndStep = _ref.onEndStep,
34643
- onStartStep = _ref.onStartStep,
34644
- type = _ref.type;
34645
- var windowSize = React.useRef([window.innerWidth, window.innerHeight]);
34646
- function maxCharacters(width) {
34647
- // Set the font size to 16 pixels
34648
- var fontSize = 11.2;
34649
- // Calculate the number of characters that can fit in one line
34650
- var charactersPerLine = Math.floor(width / 2 / fontSize);
34651
- // Calculate the number of lines that can fit in the div
34652
- var linesPerDiv = Math.floor(180 / fontSize);
34653
- // Calculate the maximum number of characters that can fit in the div
34654
- var maxCharacters = charactersPerLine * linesPerDiv;
34655
- // Return the maximum number of characters
34656
- return Math.round(maxCharacters / 5);
34657
- }
34658
- var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
34648
+ (function (RangeSliderType) {
34649
+ RangeSliderType["Slider"] = "rpgui-slider";
34650
+ RangeSliderType["GoldSlider"] = "rpgui-slider golden";
34651
+ })(exports.RangeSliderType || (exports.RangeSliderType = {}));
34652
+ var RangeSlider = function RangeSlider(_ref) {
34653
+ var type = _ref.type,
34654
+ valueMin = _ref.valueMin,
34655
+ valueMax = _ref.valueMax,
34656
+ width = _ref.width,
34657
+ _onChange = _ref.onChange,
34658
+ value = _ref.value;
34659
+ var sliderId = uuid.v4();
34660
+ var containerRef = React.useRef(null);
34659
34661
  var _useState = React.useState(0),
34660
- chunkIndex = _useState[0],
34661
- setChunkIndex = _useState[1];
34662
- var onHandleSpacePress = function onHandleSpacePress(event) {
34663
- if (event.code === 'Space') {
34664
- goToNextStep();
34665
- }
34666
- };
34667
- var goToNextStep = function goToNextStep() {
34668
- var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
34669
- if (hasNextChunk) {
34670
- setChunkIndex(function (prev) {
34671
- return prev + 1;
34672
- });
34673
- } else {
34674
- // if there's no more text chunks, close the dialog
34675
- onClose();
34676
- }
34677
- };
34662
+ left = _useState[0],
34663
+ setLeft = _useState[1];
34678
34664
  React.useEffect(function () {
34679
- document.addEventListener('keydown', onHandleSpacePress);
34680
- return function () {
34681
- return document.removeEventListener('keydown', onHandleSpacePress);
34682
- };
34683
- }, [chunkIndex]);
34684
- var _useState2 = React.useState(false),
34685
- showGoNextIndicator = _useState2[0],
34686
- setShowGoNextIndicator = _useState2[1];
34687
- return React__default.createElement(Container$e, null, React__default.createElement(DynamicText, {
34688
- text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
34689
- onFinish: function onFinish() {
34690
- setShowGoNextIndicator(true);
34691
- onEndStep && onEndStep();
34665
+ var _containerRef$current;
34666
+ var calculatedWidth = ((_containerRef$current = containerRef.current) == null ? void 0 : _containerRef$current.clientWidth) || 0;
34667
+ setLeft(Math.max((value - valueMin) / (valueMax - valueMin) * (calculatedWidth - 35) + 10));
34668
+ }, [value, valueMin, valueMax]);
34669
+ var typeClass = type === exports.RangeSliderType.GoldSlider ? 'golden' : '';
34670
+ return React__default.createElement("div", {
34671
+ style: {
34672
+ width: width,
34673
+ position: 'relative'
34692
34674
  },
34693
- onStart: function onStart() {
34694
- setShowGoNextIndicator(false);
34695
- onStartStep && onStartStep();
34675
+ className: "rpgui-slider-container " + typeClass,
34676
+ id: "rpgui-slider-" + sliderId,
34677
+ ref: containerRef
34678
+ }, React__default.createElement("div", {
34679
+ style: {
34680
+ pointerEvents: 'none'
34696
34681
  }
34697
- }), showGoNextIndicator && React__default.createElement(PressSpaceIndicator, {
34698
- right: type === exports.NPCDialogType.TextOnly ? '1rem' : '10.5rem',
34699
- src: IS_MOBILE_OR_TABLET ? img$6 : img$7,
34700
- onPointerDown: function onPointerDown() {
34701
- goToNextStep();
34682
+ }, React__default.createElement("div", {
34683
+ className: "rpgui-slider-track " + typeClass
34684
+ }), React__default.createElement("div", {
34685
+ className: "rpgui-slider-left-edge " + typeClass
34686
+ }), React__default.createElement("div", {
34687
+ className: "rpgui-slider-right-edge " + typeClass
34688
+ }), React__default.createElement("div", {
34689
+ className: "rpgui-slider-thumb " + typeClass,
34690
+ style: {
34691
+ left: left
34702
34692
  }
34693
+ })), React__default.createElement(Input$1, {
34694
+ type: "range",
34695
+ style: {
34696
+ width: width
34697
+ },
34698
+ min: valueMin,
34699
+ max: valueMax,
34700
+ onChange: function onChange(e) {
34701
+ return _onChange(Number(e.target.value));
34702
+ },
34703
+ value: value,
34704
+ className: "rpgui-cursor-point"
34703
34705
  }));
34704
34706
  };
34705
- var Container$e = /*#__PURE__*/styled.div.withConfig({
34706
- displayName: "NPCDialogText__Container",
34707
- componentId: "sc-1cxkdh9-0"
34708
- })([""]);
34709
- var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
34710
- displayName: "NPCDialogText__PressSpaceIndicator",
34711
- componentId: "sc-1cxkdh9-1"
34712
- })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
34713
- var right = _ref2.right;
34714
- return right;
34715
- });
34716
-
34717
- //@ts-ignore
34718
- var useEventListener = function useEventListener(type, handler, el) {
34719
- if (el === void 0) {
34720
- el = window;
34721
- }
34722
- var savedHandler = React__default.useRef();
34723
- React__default.useEffect(function () {
34724
- savedHandler.current = handler;
34725
- }, [handler]);
34726
- React__default.useEffect(function () {
34727
- //@ts-ignore
34728
- var listener = function listener(e) {
34729
- return savedHandler.current(e);
34730
- };
34731
- el.addEventListener(type, listener);
34732
- return function () {
34733
- el.removeEventListener(type, listener);
34734
- };
34735
- }, [type, el]);
34736
- };
34707
+ var Input$1 = /*#__PURE__*/styled.input.withConfig({
34708
+ displayName: "RangeSlider__Input",
34709
+ componentId: "sc-v8mte9-0"
34710
+ })(["opacity:0;position:absolute;width:100%;height:100%;top:0;left:0;margin-top:-5px;"]);
34737
34711
 
34738
- var QuestionDialog = function QuestionDialog(_ref) {
34739
- var questions = _ref.questions,
34740
- answers = _ref.answers,
34741
- onClose = _ref.onClose;
34742
- var _useState = React.useState(questions[0]),
34743
- currentQuestion = _useState[0],
34744
- setCurrentQuestion = _useState[1];
34745
- var _useState2 = React.useState(false),
34746
- canShowAnswers = _useState2[0],
34747
- setCanShowAnswers = _useState2[1];
34748
- var onGetFirstAnswer = function onGetFirstAnswer() {
34749
- if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {
34750
- return null;
34751
- }
34752
- var firstAnswerId = currentQuestion.answerIds[0];
34753
- return answers.find(function (answer) {
34754
- return answer.id === firstAnswerId;
34755
- });
34756
- };
34757
- var _useState3 = React.useState(onGetFirstAnswer()),
34758
- currentAnswer = _useState3[0],
34759
- setCurrentAnswer = _useState3[1];
34760
- React.useEffect(function () {
34761
- setCurrentAnswer(onGetFirstAnswer());
34762
- }, [currentQuestion]);
34763
- var onGetAnswers = function onGetAnswers(answerIds) {
34764
- return answerIds.map(function (answerId) {
34765
- return answers.find(function (answer) {
34766
- return answer.id === answerId;
34767
- });
34768
- });
34769
- };
34770
- var onKeyPress = function onKeyPress(e) {
34771
- switch (e.key) {
34772
- case 'ArrowDown':
34773
- // select next answer, if any.
34774
- // if no next answer, select first answer
34775
- // const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(
34776
- // (answer) => answer?.id === currentAnswer!.id + 1
34777
- // );
34778
- var nextAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34779
- return (answer == null ? void 0 : answer.id) === currentAnswer.id + 1;
34780
- });
34781
- var nextAnswerID = currentQuestion.answerIds[nextAnswerIndex];
34782
- var nextAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34783
- return (answer == null ? void 0 : answer.id) === nextAnswerID;
34784
- });
34785
- setCurrentAnswer(nextAnswer || onGetFirstAnswer());
34786
- break;
34787
- case 'ArrowUp':
34788
- // select previous answer, if any.
34789
- // if no previous answer, select last answer
34790
- var previousAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34791
- return (answer == null ? void 0 : answer.id) === currentAnswer.id - 1;
34792
- });
34793
- var previousAnswerID = currentQuestion.answerIds && currentQuestion.answerIds[previousAnswerIndex];
34794
- var previousAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34795
- return (answer == null ? void 0 : answer.id) === previousAnswerID;
34796
- });
34797
- if (previousAnswer) {
34798
- setCurrentAnswer(previousAnswer);
34799
- } else {
34800
- setCurrentAnswer(onGetAnswers(currentQuestion.answerIds).pop());
34801
- }
34802
- break;
34803
- case 'Enter':
34804
- setCanShowAnswers(false);
34805
- if (!(currentAnswer != null && currentAnswer.nextQuestionId)) {
34806
- onClose();
34807
- return;
34808
- } else {
34809
- setCurrentQuestion(questions.find(function (question) {
34810
- return question.id === currentAnswer.nextQuestionId;
34811
- }));
34812
- }
34813
- break;
34814
- }
34815
- };
34816
- useEventListener('keydown', onKeyPress);
34817
- var onAnswerClick = function onAnswerClick(answer) {
34818
- setCanShowAnswers(false);
34819
- if (answer.nextQuestionId) {
34820
- // if there is a next question, go to it
34821
- setCurrentQuestion(questions.find(function (question) {
34822
- return question.id === answer.nextQuestionId;
34823
- }));
34824
- } else {
34825
- // else, finish dialog!
34826
- onClose();
34827
- }
34828
- };
34829
- var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
34830
- var answerIds = currentQuestion.answerIds;
34831
- if (!answerIds) {
34832
- return null;
34833
- }
34834
- var answers = onGetAnswers(answerIds);
34835
- if (!answers) {
34836
- return null;
34837
- }
34838
- return answers.map(function (answer) {
34839
- var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
34840
- var selectedColor = isSelected ? 'yellow' : 'white';
34841
- if (answer) {
34842
- return React__default.createElement(AnswerRow, {
34843
- key: "answer_" + answer.id
34844
- }, React__default.createElement(AnswerSelectedIcon, {
34845
- color: selectedColor
34846
- }, isSelected ? 'X' : null), React__default.createElement(Answer, {
34847
- key: answer.id,
34848
- onPointerDown: function onPointerDown() {
34849
- return onAnswerClick(answer);
34850
- },
34851
- color: selectedColor
34852
- }, answer.text));
34853
- }
34854
- return null;
34855
- });
34856
- };
34857
- return React__default.createElement(Container$f, null, React__default.createElement(QuestionContainer, null, React__default.createElement(DynamicText, {
34858
- text: currentQuestion.text,
34859
- onStart: function onStart() {
34860
- return setCanShowAnswers(false);
34861
- },
34862
- onFinish: function onFinish() {
34863
- return setCanShowAnswers(true);
34864
- }
34865
- })), canShowAnswers && React__default.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
34866
- };
34867
- var Container$f = /*#__PURE__*/styled.div.withConfig({
34868
- displayName: "QuestionDialog__Container",
34869
- componentId: "sc-bxc5u0-0"
34870
- })(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
34871
- var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
34872
- displayName: "QuestionDialog__QuestionContainer",
34873
- componentId: "sc-bxc5u0-1"
34874
- })(["flex:100%;width:100%;"]);
34875
- var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
34876
- displayName: "QuestionDialog__AnswersContainer",
34877
- componentId: "sc-bxc5u0-2"
34878
- })(["flex:100%;"]);
34879
- var Answer = /*#__PURE__*/styled.p.withConfig({
34880
- displayName: "QuestionDialog__Answer",
34881
- componentId: "sc-bxc5u0-3"
34882
- })(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
34883
- return props.color;
34884
- });
34885
- var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
34886
- displayName: "QuestionDialog__AnswerSelectedIcon",
34887
- componentId: "sc-bxc5u0-4"
34888
- })(["flex:5% 0 0;color:", " !important;"], function (props) {
34889
- return props.color;
34890
- });
34891
- var AnswerRow = /*#__PURE__*/styled.div.withConfig({
34892
- displayName: "QuestionDialog__AnswerRow",
34893
- componentId: "sc-bxc5u0-5"
34894
- })(["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;}"]);
34895
-
34896
- var img$8 = '';
34897
-
34898
- (function (NPCDialogType) {
34899
- NPCDialogType["TextOnly"] = "TextOnly";
34900
- NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
34901
- })(exports.NPCDialogType || (exports.NPCDialogType = {}));
34902
- var NPCDialog = function NPCDialog(_ref) {
34903
- var text = _ref.text,
34904
- type = _ref.type,
34905
- _onClose = _ref.onClose,
34906
- imagePath = _ref.imagePath,
34907
- _ref$isQuestionDialog = _ref.isQuestionDialog,
34908
- isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
34909
- questions = _ref.questions,
34910
- answers = _ref.answers;
34911
- return React__default.createElement(RPGUIContainer, {
34912
- type: exports.RPGUIContainerTypes.FramedGold,
34913
- width: isQuestionDialog ? '600px' : '80%',
34914
- height: '180px'
34915
- }, isQuestionDialog && questions && answers ? React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer$1, {
34916
- flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
34917
- }, React__default.createElement(QuestionDialog, {
34918
- questions: questions,
34919
- answers: answers,
34920
- onClose: function onClose() {
34921
- if (_onClose) {
34922
- _onClose();
34923
- }
34924
- }
34925
- })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
34926
- src: imagePath || img$8
34927
- }))) : React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$g, null, React__default.createElement(TextContainer$1, {
34928
- flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
34929
- }, React__default.createElement(NPCDialogText, {
34930
- type: type,
34931
- text: text || 'No text provided.',
34932
- onClose: function onClose() {
34933
- if (_onClose) {
34934
- _onClose();
34935
- }
34936
- }
34937
- })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
34938
- src: imagePath || img$8
34939
- })))));
34940
- };
34941
- var Container$g = /*#__PURE__*/styled.div.withConfig({
34942
- displayName: "NPCDialog__Container",
34943
- componentId: "sc-1b4aw74-0"
34944
- })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
34945
- var TextContainer$1 = /*#__PURE__*/styled.div.withConfig({
34946
- displayName: "NPCDialog__TextContainer",
34947
- componentId: "sc-1b4aw74-1"
34948
- })(["flex:", " 0 0;width:355px;"], function (_ref2) {
34949
- var flex = _ref2.flex;
34950
- return flex;
34951
- });
34952
- var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
34953
- displayName: "NPCDialog__ThumbnailContainer",
34954
- componentId: "sc-1b4aw74-2"
34955
- })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
34956
- var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
34957
- displayName: "NPCDialog__NPCThumbnail",
34958
- componentId: "sc-1b4aw74-3"
34959
- })(["image-rendering:pixelated;height:128px;width:128px;"]);
34960
-
34961
- (function (ImgSide) {
34962
- ImgSide["right"] = "right";
34963
- ImgSide["left"] = "left";
34964
- })(exports.ImgSide || (exports.ImgSide = {}));
34965
- var NPCMultiDialog = function NPCMultiDialog(_ref) {
34966
- var _textAndTypeArray$sli;
34967
- var _onClose = _ref.onClose,
34968
- textAndTypeArray = _ref.textAndTypeArray;
34969
- var _useState = React.useState(false),
34970
- showGoNextIndicator = _useState[0],
34971
- setShowGoNextIndicator = _useState[1];
34972
- var _useState2 = React.useState(0),
34973
- slide = _useState2[0],
34974
- setSlide = _useState2[1];
34975
- var onHandleSpacePress = function onHandleSpacePress(event) {
34976
- if (event.code === 'Space') {
34977
- if (slide < (textAndTypeArray == null ? void 0 : textAndTypeArray.length) - 1) {
34978
- setSlide(function (prev) {
34979
- return prev + 1;
34980
- });
34981
- } else {
34982
- // if there's no more text chunks, close the dialog
34983
- _onClose();
34984
- }
34985
- }
34986
- };
34987
- React.useEffect(function () {
34988
- document.addEventListener('keydown', onHandleSpacePress);
34989
- return function () {
34990
- return document.removeEventListener('keydown', onHandleSpacePress);
34991
- };
34992
- }, [slide]);
34993
- return React__default.createElement(RPGUIContainer, {
34994
- type: exports.RPGUIContainerTypes.FramedGold,
34995
- width: '50%',
34996
- height: '180px'
34997
- }, React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$h, null, ((_textAndTypeArray$sli = textAndTypeArray[slide]) == null ? void 0 : _textAndTypeArray$sli.imageSide) === 'right' && React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer$2, {
34998
- flex: '70%'
34999
- }, React__default.createElement(NPCDialogText, {
35000
- onStartStep: function onStartStep() {
35001
- return setShowGoNextIndicator(false);
35002
- },
35003
- onEndStep: function onEndStep() {
35004
- return setShowGoNextIndicator(true);
35005
- },
35006
- text: textAndTypeArray[slide].text || 'No text provided.',
35007
- onClose: function onClose() {
35008
- if (_onClose) {
35009
- _onClose();
35010
- }
35011
- }
35012
- })), React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
35013
- src: textAndTypeArray[slide].imagePath || img$8
35014
- })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator$1, {
35015
- right: '10.5rem',
35016
- src: img$7
35017
- })), textAndTypeArray[slide].imageSide === 'left' && React__default.createElement(React__default.Fragment, null, React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
35018
- src: textAndTypeArray[slide].imagePath || img$8
35019
- })), React__default.createElement(TextContainer$2, {
35020
- flex: '70%'
35021
- }, React__default.createElement(NPCDialogText, {
35022
- onStartStep: function onStartStep() {
35023
- return setShowGoNextIndicator(false);
35024
- },
35025
- onEndStep: function onEndStep() {
35026
- return setShowGoNextIndicator(true);
35027
- },
35028
- text: textAndTypeArray[slide].text || 'No text provided.',
35029
- onClose: function onClose() {
35030
- if (_onClose) {
35031
- _onClose();
35032
- }
35033
- }
35034
- })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator$1, {
35035
- right: '1rem',
35036
- src: img$7
35037
- }))), ")"));
35038
- };
35039
- var Container$h = /*#__PURE__*/styled.div.withConfig({
35040
- displayName: "NPCMultiDialog__Container",
35041
- componentId: "sc-rvu5wg-0"
35042
- })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
35043
- var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
35044
- displayName: "NPCMultiDialog__TextContainer",
35045
- componentId: "sc-rvu5wg-1"
35046
- })(["flex:", " 0 0;width:355px;"], function (_ref2) {
35047
- var flex = _ref2.flex;
35048
- return flex;
35049
- });
35050
- var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
35051
- displayName: "NPCMultiDialog__ThumbnailContainer",
35052
- componentId: "sc-rvu5wg-2"
35053
- })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
35054
- var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
35055
- displayName: "NPCMultiDialog__NPCThumbnail",
35056
- componentId: "sc-rvu5wg-3"
35057
- })(["image-rendering:pixelated;height:128px;width:128px;"]);
35058
- var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
35059
- displayName: "NPCMultiDialog__PressSpaceIndicator",
35060
- componentId: "sc-rvu5wg-4"
35061
- })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref3) {
35062
- var right = _ref3.right;
35063
- return right;
35064
- });
35065
-
35066
- var HistoryDialog = function HistoryDialog(_ref) {
35067
- var backgroundImgPath = _ref.backgroundImgPath,
35068
- fullCoverBackground = _ref.fullCoverBackground,
35069
- questions = _ref.questions,
35070
- answers = _ref.answers,
35071
- text = _ref.text,
35072
- imagePath = _ref.imagePath,
35073
- textAndTypeArray = _ref.textAndTypeArray,
35074
- onClose = _ref.onClose;
35075
- var _useState = React.useState(0),
35076
- img = _useState[0],
35077
- setImage = _useState[1];
35078
- var onHandleSpacePress = function onHandleSpacePress(event) {
35079
- if (event.code === 'Space') {
35080
- if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
35081
- setImage(function (prev) {
35082
- return prev + 1;
35083
- });
35084
- } else {
35085
- // if there's no more text chunks, close the dialog
35086
- onClose();
35087
- }
35088
- }
35089
- };
35090
- React.useEffect(function () {
35091
- document.addEventListener('keydown', onHandleSpacePress);
35092
- return function () {
35093
- return document.removeEventListener('keydown', onHandleSpacePress);
35094
- };
35095
- }, [backgroundImgPath]);
35096
- return React__default.createElement(BackgroundContainer, {
35097
- imgPath: backgroundImgPath[img],
35098
- fullImg: fullCoverBackground
35099
- }, React__default.createElement(DialogContainer, null, textAndTypeArray ? React__default.createElement(NPCMultiDialog, {
35100
- textAndTypeArray: textAndTypeArray,
35101
- onClose: onClose
35102
- }) : questions && answers ? React__default.createElement(QuestionDialog, {
35103
- questions: questions,
35104
- answers: answers,
35105
- onClose: onClose
35106
- }) : text && imagePath ? React__default.createElement(NPCDialog, {
35107
- text: text,
35108
- imagePath: imagePath,
35109
- onClose: onClose,
35110
- type: exports.NPCDialogType.TextAndThumbnail
35111
- }) : React__default.createElement(NPCDialog, {
35112
- text: text,
35113
- onClose: onClose,
35114
- type: exports.NPCDialogType.TextOnly
35115
- })));
35116
- };
35117
- var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
35118
- displayName: "HistoryDialog__BackgroundContainer",
35119
- componentId: "sc-u6oe75-0"
35120
- })(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
35121
- return props.imgPath;
35122
- }, function (props) {
35123
- return props.imgPath ? 'cover' : 'auto';
35124
- });
35125
- var DialogContainer = /*#__PURE__*/styled.div.withConfig({
35126
- displayName: "HistoryDialog__DialogContainer",
35127
- componentId: "sc-u6oe75-1"
35128
- })(["display:flex;justify-content:center;padding-top:200px;"]);
35129
-
35130
- var SlotsContainer = function SlotsContainer(_ref) {
35131
- var children = _ref.children,
35132
- title = _ref.title,
35133
- onClose = _ref.onClose,
35134
- _onPositionChange = _ref.onPositionChange,
35135
- _onPositionChangeEnd = _ref.onPositionChangeEnd,
35136
- _onPositionChangeStart = _ref.onPositionChangeStart,
35137
- onOutsideClick = _ref.onOutsideClick,
35138
- initialPosition = _ref.initialPosition,
35139
- scale = _ref.scale;
35140
- return React__default.createElement(DraggableContainer, {
35141
- title: title,
35142
- type: exports.RPGUIContainerTypes.Framed,
35143
- onCloseButton: function onCloseButton() {
35144
- if (onClose) {
35145
- onClose();
35146
- }
35147
- },
35148
- width: "400px",
35149
- cancelDrag: ".item-container-body, #shortcuts_list",
35150
- onPositionChange: function onPositionChange(_ref2) {
35151
- var x = _ref2.x,
35152
- y = _ref2.y;
35153
- if (_onPositionChange) {
35154
- _onPositionChange({
35155
- x: x,
35156
- y: y
35157
- });
35158
- }
35159
- },
35160
- onPositionChangeEnd: function onPositionChangeEnd(_ref3) {
35161
- var x = _ref3.x,
35162
- y = _ref3.y;
35163
- if (_onPositionChangeEnd) {
35164
- _onPositionChangeEnd({
35165
- x: x,
35166
- y: y
35167
- });
35168
- }
35169
- },
35170
- onPositionChangeStart: function onPositionChangeStart(_ref4) {
35171
- var x = _ref4.x,
35172
- y = _ref4.y;
35173
- if (_onPositionChangeStart) {
35174
- _onPositionChangeStart({
35175
- x: x,
35176
- y: y
35177
- });
35178
- }
35179
- },
35180
- onOutsideClick: onOutsideClick,
35181
- initialPosition: initialPosition,
35182
- scale: scale
35183
- }, children);
35184
- };
35185
-
35186
- (function (RangeSliderType) {
35187
- RangeSliderType["Slider"] = "rpgui-slider";
35188
- RangeSliderType["GoldSlider"] = "rpgui-slider golden";
35189
- })(exports.RangeSliderType || (exports.RangeSliderType = {}));
35190
- var RangeSlider = function RangeSlider(_ref) {
35191
- var type = _ref.type,
35192
- valueMin = _ref.valueMin,
35193
- valueMax = _ref.valueMax,
35194
- width = _ref.width,
35195
- _onChange = _ref.onChange,
35196
- value = _ref.value;
35197
- var sliderId = uuid.v4();
35198
- var containerRef = React.useRef(null);
35199
- var _useState = React.useState(0),
35200
- left = _useState[0],
35201
- setLeft = _useState[1];
35202
- React.useEffect(function () {
35203
- var _containerRef$current;
35204
- var calculatedWidth = ((_containerRef$current = containerRef.current) == null ? void 0 : _containerRef$current.clientWidth) || 0;
35205
- setLeft(Math.max((value - valueMin) / (valueMax - valueMin) * (calculatedWidth - 35) + 10));
35206
- }, [value, valueMin, valueMax]);
35207
- var typeClass = type === exports.RangeSliderType.GoldSlider ? 'golden' : '';
35208
- return React__default.createElement("div", {
35209
- style: {
35210
- width: width,
35211
- position: 'relative'
35212
- },
35213
- className: "rpgui-slider-container " + typeClass,
35214
- id: "rpgui-slider-" + sliderId,
35215
- ref: containerRef
35216
- }, React__default.createElement("div", {
35217
- style: {
35218
- pointerEvents: 'none'
35219
- }
35220
- }, React__default.createElement("div", {
35221
- className: "rpgui-slider-track " + typeClass
35222
- }), React__default.createElement("div", {
35223
- className: "rpgui-slider-left-edge " + typeClass
35224
- }), React__default.createElement("div", {
35225
- className: "rpgui-slider-right-edge " + typeClass
35226
- }), React__default.createElement("div", {
35227
- className: "rpgui-slider-thumb " + typeClass,
35228
- style: {
35229
- left: left
35230
- }
35231
- })), React__default.createElement(Input$1, {
35232
- type: "range",
35233
- style: {
35234
- width: width
35235
- },
35236
- min: valueMin,
35237
- max: valueMax,
35238
- onChange: function onChange(e) {
35239
- return _onChange(Number(e.target.value));
35240
- },
35241
- value: value,
35242
- className: "rpgui-cursor-point"
35243
- }));
35244
- };
35245
- var Input$1 = /*#__PURE__*/styled.input.withConfig({
35246
- displayName: "RangeSlider__Input",
35247
- componentId: "sc-v8mte9-0"
35248
- })(["opacity:0;position:absolute;width:100%;height:100%;top:0;left:0;margin-top:-5px;"]);
35249
-
35250
- var ItemQuantitySelector = function ItemQuantitySelector(_ref) {
35251
- var quantity = _ref.quantity,
35252
- onConfirm = _ref.onConfirm,
34712
+ var ItemQuantitySelector = function ItemQuantitySelector(_ref) {
34713
+ var quantity = _ref.quantity,
34714
+ onConfirm = _ref.onConfirm,
35253
34715
  onClose = _ref.onClose;
35254
34716
  var _useState = React.useState(quantity),
35255
34717
  value = _useState[0],
@@ -35371,7 +34833,7 @@ var ShortcutsSetter = function ShortcutsSetter(_ref) {
35371
34833
  return word[0];
35372
34834
  }));
35373
34835
  };
35374
- return React__default.createElement(Container$i, null, React__default.createElement("p", null, "Shortcuts:"), React__default.createElement(List, {
34836
+ return React__default.createElement(Container$e, null, React__default.createElement("p", null, "Shortcuts:"), React__default.createElement(List, {
35375
34837
  id: "shortcuts_list"
35376
34838
  }, Array.from({
35377
34839
  length: 6
@@ -35387,7 +34849,7 @@ var ShortcutsSetter = function ShortcutsSetter(_ref) {
35387
34849
  }, getContent(i));
35388
34850
  })));
35389
34851
  };
35390
- var Container$i = /*#__PURE__*/styled.div.withConfig({
34852
+ var Container$e = /*#__PURE__*/styled.div.withConfig({
35391
34853
  displayName: "ShortcutsSetter__Container",
35392
34854
  componentId: "sc-xuouuf-0"
35393
34855
  })(["p{margin:0;margin-left:0.5rem;}"]);
@@ -35530,135 +34992,460 @@ var ItemContainer$1 = function ItemContainer(_ref) {
35530
34992
  }
35531
34993
  }))));
35532
34994
  };
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);"]);
34995
+ var ItemsContainer = /*#__PURE__*/styled.div.withConfig({
34996
+ displayName: "ItemContainer__ItemsContainer",
34997
+ componentId: "sc-15y5p9l-0"
34998
+ })(["display:flex;justify-content:center;flex-wrap:wrap;"]);
34999
+ var QuantitySelectorContainer = /*#__PURE__*/styled.div.withConfig({
35000
+ displayName: "ItemContainer__QuantitySelectorContainer",
35001
+ componentId: "sc-15y5p9l-1"
35002
+ })(["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);"]);
35003
+
35004
+ var ItemSelector = function ItemSelector(_ref) {
35005
+ var atlasIMG = _ref.atlasIMG,
35006
+ atlasJSON = _ref.atlasJSON,
35007
+ options = _ref.options,
35008
+ onClose = _ref.onClose,
35009
+ onSelect = _ref.onSelect;
35010
+ var _useState = React.useState(),
35011
+ selectedValue = _useState[0],
35012
+ setSelectedValue = _useState[1];
35013
+ var handleClick = function handleClick() {
35014
+ var element = document.querySelector("input[name='test']:checked");
35015
+ var elementValue = element.value;
35016
+ setSelectedValue(elementValue);
35017
+ };
35018
+ React.useEffect(function () {
35019
+ if (selectedValue) {
35020
+ onSelect(selectedValue);
35021
+ }
35022
+ }, [selectedValue]);
35023
+ return React__default.createElement(DraggableContainer, {
35024
+ type: exports.RPGUIContainerTypes.Framed,
35025
+ width: "500px",
35026
+ cancelDrag: ".equipment-container-body .arrow-selector",
35027
+ onCloseButton: function onCloseButton() {
35028
+ if (onClose) {
35029
+ onClose();
35030
+ }
35031
+ }
35032
+ }, React__default.createElement("div", {
35033
+ style: {
35034
+ width: '100%'
35035
+ }
35036
+ }, React__default.createElement(Title$3, null, 'Harvesting instruments'), React__default.createElement(Subtitle$1, null, 'Use the tool, you need it'), React__default.createElement("hr", {
35037
+ className: "golden"
35038
+ })), React__default.createElement(RadioInputScroller$1, null, options == null ? void 0 : options.map(function (option, index) {
35039
+ return React__default.createElement(RadioOptionsWrapper$1, {
35040
+ key: index
35041
+ }, React__default.createElement(SpriteAtlasWrapper$1, null, React__default.createElement(SpriteFromAtlas, {
35042
+ atlasIMG: atlasIMG,
35043
+ atlasJSON: atlasJSON,
35044
+ spriteKey: option.imageKey,
35045
+ imgScale: 3
35046
+ })), React__default.createElement("div", null, React__default.createElement("input", {
35047
+ className: "rpgui-radio",
35048
+ type: "radio",
35049
+ value: option.name,
35050
+ name: "test"
35051
+ }), React__default.createElement("label", {
35052
+ onPointerDown: handleClick,
35053
+ style: {
35054
+ display: 'flex',
35055
+ alignItems: 'center'
35056
+ }
35057
+ }, option.name, " ", React__default.createElement("br", null), option.description)));
35058
+ })), React__default.createElement(ButtonWrapper$1, null, React__default.createElement(Button, {
35059
+ buttonType: exports.ButtonTypes.RPGUIButton,
35060
+ onPointerDown: onClose
35061
+ }, "Cancel"), React__default.createElement(Button, {
35062
+ buttonType: exports.ButtonTypes.RPGUIButton
35063
+ }, "Select")));
35064
+ };
35065
+ var Title$3 = /*#__PURE__*/styled.h1.withConfig({
35066
+ displayName: "ItemSelector__Title",
35067
+ componentId: "sc-gptoxp-0"
35068
+ })(["font-size:0.6rem;color:yellow !important;"]);
35069
+ var Subtitle$1 = /*#__PURE__*/styled.h1.withConfig({
35070
+ displayName: "ItemSelector__Subtitle",
35071
+ componentId: "sc-gptoxp-1"
35072
+ })(["font-size:0.4rem;color:yellow !important;"]);
35073
+ var RadioInputScroller$1 = /*#__PURE__*/styled.div.withConfig({
35074
+ displayName: "ItemSelector__RadioInputScroller",
35075
+ componentId: "sc-gptoxp-2"
35076
+ })(["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;"]);
35077
+ var SpriteAtlasWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35078
+ displayName: "ItemSelector__SpriteAtlasWrapper",
35079
+ componentId: "sc-gptoxp-3"
35080
+ })(["margin-right:40px;"]);
35081
+ var RadioOptionsWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35082
+ displayName: "ItemSelector__RadioOptionsWrapper",
35083
+ componentId: "sc-gptoxp-4"
35084
+ })(["display:flex;align-items:stretch;margin-bottom:40px;"]);
35085
+ var ButtonWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35086
+ displayName: "ItemSelector__ButtonWrapper",
35087
+ componentId: "sc-gptoxp-5"
35088
+ })(["display:flex;justify-content:space-around;padding-top:20px;width:100%;"]);
35089
+
35090
+ var ListMenu = function ListMenu(_ref) {
35091
+ var options = _ref.options,
35092
+ onSelected = _ref.onSelected,
35093
+ x = _ref.x,
35094
+ y = _ref.y;
35095
+ return React__default.createElement(Container$f, {
35096
+ x: x,
35097
+ y: y
35098
+ }, React__default.createElement("ul", {
35099
+ className: "rpgui-list-imp",
35100
+ style: {
35101
+ overflow: 'hidden'
35102
+ }
35103
+ }, options.map(function (params, index) {
35104
+ return React__default.createElement(ListElement$1, {
35105
+ key: (params == null ? void 0 : params.id) || index,
35106
+ onPointerDown: function onPointerDown() {
35107
+ onSelected(params == null ? void 0 : params.id);
35108
+ }
35109
+ }, (params == null ? void 0 : params.text) || 'No text');
35110
+ })));
35111
+ };
35112
+ var Container$f = /*#__PURE__*/styled.div.withConfig({
35113
+ displayName: "ListMenu__Container",
35114
+ componentId: "sc-i9097t-0"
35115
+ })(["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) {
35116
+ return props.y || 0;
35117
+ }, function (props) {
35118
+ return props.x || 0;
35119
+ }, uiFonts.size.xsmall);
35120
+ var ListElement$1 = /*#__PURE__*/styled.li.withConfig({
35121
+ displayName: "ListMenu__ListElement",
35122
+ componentId: "sc-i9097t-1"
35123
+ })(["margin-right:0.5rem;"]);
35124
+
35125
+ var img$6 = '';
35126
+
35127
+ var img$7 = '';
35128
+
35129
+ (function (ImgSide) {
35130
+ ImgSide["right"] = "right";
35131
+ ImgSide["left"] = "left";
35132
+ })(exports.ImgSide || (exports.ImgSide = {}));
35133
+ var NPCMultiDialog = function NPCMultiDialog(_ref) {
35134
+ var _textAndTypeArray$sli;
35135
+ var _onClose = _ref.onClose,
35136
+ textAndTypeArray = _ref.textAndTypeArray;
35137
+ var _useState = React.useState(false),
35138
+ showGoNextIndicator = _useState[0],
35139
+ setShowGoNextIndicator = _useState[1];
35140
+ var _useState2 = React.useState(0),
35141
+ slide = _useState2[0],
35142
+ setSlide = _useState2[1];
35143
+ var onHandleSpacePress = function onHandleSpacePress(event) {
35144
+ if (event.code === 'Space') {
35145
+ if (slide < (textAndTypeArray == null ? void 0 : textAndTypeArray.length) - 1) {
35146
+ setSlide(function (prev) {
35147
+ return prev + 1;
35148
+ });
35149
+ } else {
35150
+ // if there's no more text chunks, close the dialog
35151
+ _onClose();
35152
+ }
35153
+ }
35154
+ };
35155
+ React.useEffect(function () {
35156
+ document.addEventListener('keydown', onHandleSpacePress);
35157
+ return function () {
35158
+ return document.removeEventListener('keydown', onHandleSpacePress);
35159
+ };
35160
+ }, [slide]);
35161
+ return React__default.createElement(RPGUIContainer, {
35162
+ type: exports.RPGUIContainerTypes.FramedGold,
35163
+ width: '50%',
35164
+ height: '180px'
35165
+ }, React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$g, null, ((_textAndTypeArray$sli = textAndTypeArray[slide]) == null ? void 0 : _textAndTypeArray$sli.imageSide) === 'right' && React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer, {
35166
+ flex: '70%'
35167
+ }, React__default.createElement(NPCDialogText, {
35168
+ onStartStep: function onStartStep() {
35169
+ return setShowGoNextIndicator(false);
35170
+ },
35171
+ onEndStep: function onEndStep() {
35172
+ return setShowGoNextIndicator(true);
35173
+ },
35174
+ text: textAndTypeArray[slide].text || 'No text provided.',
35175
+ onClose: function onClose() {
35176
+ if (_onClose) {
35177
+ _onClose();
35178
+ }
35179
+ }
35180
+ })), React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
35181
+ src: textAndTypeArray[slide].imagePath || img$6
35182
+ })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator, {
35183
+ right: '10.5rem',
35184
+ src: img$7
35185
+ })), textAndTypeArray[slide].imageSide === 'left' && React__default.createElement(React__default.Fragment, null, React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
35186
+ src: textAndTypeArray[slide].imagePath || img$6
35187
+ })), React__default.createElement(TextContainer, {
35188
+ flex: '70%'
35189
+ }, React__default.createElement(NPCDialogText, {
35190
+ onStartStep: function onStartStep() {
35191
+ return setShowGoNextIndicator(false);
35192
+ },
35193
+ onEndStep: function onEndStep() {
35194
+ return setShowGoNextIndicator(true);
35195
+ },
35196
+ text: textAndTypeArray[slide].text || 'No text provided.',
35197
+ onClose: function onClose() {
35198
+ if (_onClose) {
35199
+ _onClose();
35200
+ }
35201
+ }
35202
+ })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator, {
35203
+ right: '1rem',
35204
+ src: img$7
35205
+ }))), ")"));
35206
+ };
35207
+ var Container$g = /*#__PURE__*/styled.div.withConfig({
35208
+ displayName: "NPCMultiDialog__Container",
35209
+ componentId: "sc-rvu5wg-0"
35210
+ })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
35211
+ var TextContainer = /*#__PURE__*/styled.div.withConfig({
35212
+ displayName: "NPCMultiDialog__TextContainer",
35213
+ componentId: "sc-rvu5wg-1"
35214
+ })(["flex:", " 0 0;width:355px;"], function (_ref2) {
35215
+ var flex = _ref2.flex;
35216
+ return flex;
35217
+ });
35218
+ var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
35219
+ displayName: "NPCMultiDialog__ThumbnailContainer",
35220
+ componentId: "sc-rvu5wg-2"
35221
+ })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
35222
+ var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
35223
+ displayName: "NPCMultiDialog__NPCThumbnail",
35224
+ componentId: "sc-rvu5wg-3"
35225
+ })(["image-rendering:pixelated;height:128px;width:128px;"]);
35226
+ var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
35227
+ displayName: "NPCMultiDialog__PressSpaceIndicator",
35228
+ componentId: "sc-rvu5wg-4"
35229
+ })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref3) {
35230
+ var right = _ref3.right;
35231
+ return right;
35232
+ });
35233
+
35234
+ //@ts-ignore
35235
+ var useEventListener = function useEventListener(type, handler, el) {
35236
+ if (el === void 0) {
35237
+ el = window;
35238
+ }
35239
+ var savedHandler = React__default.useRef();
35240
+ React__default.useEffect(function () {
35241
+ savedHandler.current = handler;
35242
+ }, [handler]);
35243
+ React__default.useEffect(function () {
35244
+ //@ts-ignore
35245
+ var listener = function listener(e) {
35246
+ return savedHandler.current(e);
35247
+ };
35248
+ el.addEventListener(type, listener);
35249
+ return function () {
35250
+ el.removeEventListener(type, listener);
35251
+ };
35252
+ }, [type, el]);
35253
+ };
35254
+
35255
+ var DynamicText = function DynamicText(_ref) {
35256
+ var text = _ref.text,
35257
+ onFinish = _ref.onFinish,
35258
+ onStart = _ref.onStart;
35259
+ var _useState = React.useState(''),
35260
+ textState = _useState[0],
35261
+ setTextState = _useState[1];
35262
+ React.useEffect(function () {
35263
+ var i = 0;
35264
+ var interval = setInterval(function () {
35265
+ // on every interval, show one more character
35266
+ if (i === 0) {
35267
+ if (onStart) {
35268
+ onStart();
35269
+ }
35270
+ }
35271
+ if (i < text.length) {
35272
+ setTextState(text.substring(0, i + 1));
35273
+ i++;
35274
+ } else {
35275
+ clearInterval(interval);
35276
+ if (onFinish) {
35277
+ onFinish();
35278
+ }
35279
+ }
35280
+ }, 50);
35281
+ return function () {
35282
+ clearInterval(interval);
35283
+ };
35284
+ }, [text]);
35285
+ return React__default.createElement(TextContainer$1, null, textState);
35286
+ };
35287
+ var TextContainer$1 = /*#__PURE__*/styled.p.withConfig({
35288
+ displayName: "DynamicText__TextContainer",
35289
+ componentId: "sc-1ggl9nd-0"
35290
+ })(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]);
35541
35291
 
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 = React.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);
35292
+ var QuestionDialog = function QuestionDialog(_ref) {
35293
+ var questions = _ref.questions,
35294
+ answers = _ref.answers,
35295
+ onClose = _ref.onClose;
35296
+ var _useState = React.useState(questions[0]),
35297
+ currentQuestion = _useState[0],
35298
+ setCurrentQuestion = _useState[1];
35299
+ var _useState2 = React.useState(false),
35300
+ canShowAnswers = _useState2[0],
35301
+ setCanShowAnswers = _useState2[1];
35302
+ var onGetFirstAnswer = function onGetFirstAnswer() {
35303
+ if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {
35304
+ return null;
35305
+ }
35306
+ var firstAnswerId = currentQuestion.answerIds[0];
35307
+ return answers.find(function (answer) {
35308
+ return answer.id === firstAnswerId;
35309
+ });
35555
35310
  };
35311
+ var _useState3 = React.useState(onGetFirstAnswer()),
35312
+ currentAnswer = _useState3[0],
35313
+ setCurrentAnswer = _useState3[1];
35556
35314
  React.useEffect(function () {
35557
- if (selectedValue) {
35558
- onSelect(selectedValue);
35315
+ setCurrentAnswer(onGetFirstAnswer());
35316
+ }, [currentQuestion]);
35317
+ var onGetAnswers = function onGetAnswers(answerIds) {
35318
+ return answerIds.map(function (answerId) {
35319
+ return answers.find(function (answer) {
35320
+ return answer.id === answerId;
35321
+ });
35322
+ });
35323
+ };
35324
+ var onKeyPress = function onKeyPress(e) {
35325
+ switch (e.key) {
35326
+ case 'ArrowDown':
35327
+ // select next answer, if any.
35328
+ // if no next answer, select first answer
35329
+ // const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(
35330
+ // (answer) => answer?.id === currentAnswer!.id + 1
35331
+ // );
35332
+ var nextAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
35333
+ return (answer == null ? void 0 : answer.id) === currentAnswer.id + 1;
35334
+ });
35335
+ var nextAnswerID = currentQuestion.answerIds[nextAnswerIndex];
35336
+ var nextAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
35337
+ return (answer == null ? void 0 : answer.id) === nextAnswerID;
35338
+ });
35339
+ setCurrentAnswer(nextAnswer || onGetFirstAnswer());
35340
+ break;
35341
+ case 'ArrowUp':
35342
+ // select previous answer, if any.
35343
+ // if no previous answer, select last answer
35344
+ var previousAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
35345
+ return (answer == null ? void 0 : answer.id) === currentAnswer.id - 1;
35346
+ });
35347
+ var previousAnswerID = currentQuestion.answerIds && currentQuestion.answerIds[previousAnswerIndex];
35348
+ var previousAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
35349
+ return (answer == null ? void 0 : answer.id) === previousAnswerID;
35350
+ });
35351
+ if (previousAnswer) {
35352
+ setCurrentAnswer(previousAnswer);
35353
+ } else {
35354
+ setCurrentAnswer(onGetAnswers(currentQuestion.answerIds).pop());
35355
+ }
35356
+ break;
35357
+ case 'Enter':
35358
+ setCanShowAnswers(false);
35359
+ if (!(currentAnswer != null && currentAnswer.nextQuestionId)) {
35360
+ onClose();
35361
+ return;
35362
+ } else {
35363
+ setCurrentQuestion(questions.find(function (question) {
35364
+ return question.id === currentAnswer.nextQuestionId;
35365
+ }));
35366
+ }
35367
+ break;
35559
35368
  }
35560
- }, [selectedValue]);
35561
- return React__default.createElement(DraggableContainer, {
35562
- type: exports.RPGUIContainerTypes.Framed,
35563
- width: "500px",
35564
- cancelDrag: ".equipment-container-body .arrow-selector",
35565
- onCloseButton: function onCloseButton() {
35566
- if (onClose) {
35567
- onClose();
35568
- }
35369
+ };
35370
+ useEventListener('keydown', onKeyPress);
35371
+ var onAnswerClick = function onAnswerClick(answer) {
35372
+ setCanShowAnswers(false);
35373
+ if (answer.nextQuestionId) {
35374
+ // if there is a next question, go to it
35375
+ setCurrentQuestion(questions.find(function (question) {
35376
+ return question.id === answer.nextQuestionId;
35377
+ }));
35378
+ } else {
35379
+ // else, finish dialog!
35380
+ onClose();
35569
35381
  }
35570
- }, React__default.createElement("div", {
35571
- style: {
35572
- width: '100%'
35382
+ };
35383
+ var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
35384
+ var answerIds = currentQuestion.answerIds;
35385
+ if (!answerIds) {
35386
+ return null;
35573
35387
  }
35574
- }, React__default.createElement(Title$3, null, 'Harvesting instruments'), React__default.createElement(Subtitle$1, null, 'Use the tool, you need it'), React__default.createElement("hr", {
35575
- className: "golden"
35576
- })), React__default.createElement(RadioInputScroller$1, null, options == null ? void 0 : options.map(function (option, index) {
35577
- return React__default.createElement(RadioOptionsWrapper$1, {
35578
- key: index
35579
- }, React__default.createElement(SpriteAtlasWrapper$1, null, React__default.createElement(SpriteFromAtlas, {
35580
- atlasIMG: atlasIMG,
35581
- atlasJSON: atlasJSON,
35582
- spriteKey: option.imageKey,
35583
- imgScale: 3
35584
- })), React__default.createElement("div", null, React__default.createElement("input", {
35585
- className: "rpgui-radio",
35586
- type: "radio",
35587
- value: option.name,
35588
- name: "test"
35589
- }), React__default.createElement("label", {
35590
- onPointerDown: handleClick,
35591
- style: {
35592
- display: 'flex',
35593
- alignItems: 'center'
35594
- }
35595
- }, option.name, " ", React__default.createElement("br", null), option.description)));
35596
- })), React__default.createElement(ButtonWrapper$1, null, React__default.createElement(Button, {
35597
- buttonType: exports.ButtonTypes.RPGUIButton,
35598
- onPointerDown: onClose
35599
- }, "Cancel"), React__default.createElement(Button, {
35600
- buttonType: exports.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__default.createElement(Container$j, {
35634
- x: x,
35635
- y: y
35636
- }, React__default.createElement("ul", {
35637
- className: "rpgui-list-imp",
35638
- style: {
35639
- overflow: 'hidden'
35388
+ var answers = onGetAnswers(answerIds);
35389
+ if (!answers) {
35390
+ return null;
35640
35391
  }
35641
- }, options.map(function (params, index) {
35642
- return React__default.createElement(ListElement$1, {
35643
- key: (params == null ? void 0 : params.id) || index,
35644
- onPointerDown: function onPointerDown() {
35645
- onSelected(params == null ? void 0 : params.id);
35392
+ return answers.map(function (answer) {
35393
+ var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
35394
+ var selectedColor = isSelected ? 'yellow' : 'white';
35395
+ if (answer) {
35396
+ return React__default.createElement(AnswerRow, {
35397
+ key: "answer_" + answer.id
35398
+ }, React__default.createElement(AnswerSelectedIcon, {
35399
+ color: selectedColor
35400
+ }, isSelected ? 'X' : null), React__default.createElement(Answer, {
35401
+ key: answer.id,
35402
+ onPointerDown: function onPointerDown() {
35403
+ return onAnswerClick(answer);
35404
+ },
35405
+ color: selectedColor
35406
+ }, answer.text));
35646
35407
  }
35647
- }, (params == null ? void 0 : params.text) || 'No text');
35648
- })));
35408
+ return null;
35409
+ });
35410
+ };
35411
+ return React__default.createElement(Container$h, null, React__default.createElement(QuestionContainer, null, React__default.createElement(DynamicText, {
35412
+ text: currentQuestion.text,
35413
+ onStart: function onStart() {
35414
+ return setCanShowAnswers(false);
35415
+ },
35416
+ onFinish: function onFinish() {
35417
+ return setCanShowAnswers(true);
35418
+ }
35419
+ })), canShowAnswers && React__default.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
35649
35420
  };
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;"]);
35421
+ var Container$h = /*#__PURE__*/styled.div.withConfig({
35422
+ displayName: "QuestionDialog__Container",
35423
+ componentId: "sc-bxc5u0-0"
35424
+ })(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
35425
+ var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
35426
+ displayName: "QuestionDialog__QuestionContainer",
35427
+ componentId: "sc-bxc5u0-1"
35428
+ })(["flex:100%;width:100%;"]);
35429
+ var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
35430
+ displayName: "QuestionDialog__AnswersContainer",
35431
+ componentId: "sc-bxc5u0-2"
35432
+ })(["flex:100%;"]);
35433
+ var Answer = /*#__PURE__*/styled.p.withConfig({
35434
+ displayName: "QuestionDialog__Answer",
35435
+ componentId: "sc-bxc5u0-3"
35436
+ })(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
35437
+ return props.color;
35438
+ });
35439
+ var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
35440
+ displayName: "QuestionDialog__AnswerSelectedIcon",
35441
+ componentId: "sc-bxc5u0-4"
35442
+ })(["flex:5% 0 0;color:", " !important;"], function (props) {
35443
+ return props.color;
35444
+ });
35445
+ var AnswerRow = /*#__PURE__*/styled.div.withConfig({
35446
+ displayName: "QuestionDialog__AnswerRow",
35447
+ componentId: "sc-bxc5u0-5"
35448
+ })(["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;}"]);
35662
35449
 
35663
35450
  var ProgressBar = function ProgressBar(_ref) {
35664
35451
  var max = _ref.max,
@@ -35677,7 +35464,7 @@ var ProgressBar = function ProgressBar(_ref) {
35677
35464
  }
35678
35465
  return value * 100 / max;
35679
35466
  };
35680
- return React__default.createElement(Container$k, {
35467
+ return React__default.createElement(Container$i, {
35681
35468
  className: "rpgui-progress",
35682
35469
  "data-value": calculatePercentageValue(max, value) / 100,
35683
35470
  "data-rpguitype": "progress",
@@ -35706,7 +35493,7 @@ var TextOverlay$1 = /*#__PURE__*/styled.div.withConfig({
35706
35493
  displayName: "ProgressBar__TextOverlay",
35707
35494
  componentId: "sc-qa6fzh-1"
35708
35495
  })(["width:100%;position:relative;"]);
35709
- var Container$k = /*#__PURE__*/styled.div.withConfig({
35496
+ var Container$i = /*#__PURE__*/styled.div.withConfig({
35710
35497
  displayName: "ProgressBar__Container",
35711
35498
  componentId: "sc-qa6fzh-2"
35712
35499
  })(["display:flex;flex-direction:column;min-width:", "px;width:", "%;justify-content:start;align-items:flex-start;", ""], function (props) {
@@ -35717,7 +35504,7 @@ var Container$k = /*#__PURE__*/styled.div.withConfig({
35717
35504
  return props.style;
35718
35505
  });
35719
35506
 
35720
- var img$9 = '';
35507
+ var img$8 = '';
35721
35508
 
35722
35509
  var QuestInfo = function QuestInfo(_ref) {
35723
35510
  var quests = _ref.quests,
@@ -35761,7 +35548,7 @@ var QuestInfo = function QuestInfo(_ref) {
35761
35548
  }), React__default.createElement(QuestContainer, null, React__default.createElement(TitleContainer$1, {
35762
35549
  className: "drag-handler"
35763
35550
  }, React__default.createElement(Title$4, null, React__default.createElement(Thumbnail, {
35764
- src: quests[currentIndex].thumbnail || img$9
35551
+ src: quests[currentIndex].thumbnail || img$8
35765
35552
  }), quests[currentIndex].title), React__default.createElement(QuestSplitDiv, null, React__default.createElement("hr", {
35766
35553
  className: "golden"
35767
35554
  }))), React__default.createElement(Content, null, React__default.createElement("p", null, quests[currentIndex].description)), React__default.createElement(QuestColumn, {
@@ -35780,7 +35567,7 @@ var QuestInfo = function QuestInfo(_ref) {
35780
35567
  })))) : React__default.createElement(QuestsContainer, null, React__default.createElement(QuestContainer, null, React__default.createElement(TitleContainer$1, {
35781
35568
  className: "drag-handler"
35782
35569
  }, React__default.createElement(Title$4, null, React__default.createElement(Thumbnail, {
35783
- src: quests[0].thumbnail || img$9
35570
+ src: quests[0].thumbnail || img$8
35784
35571
  }), quests[0].title), React__default.createElement(QuestSplitDiv, null, React__default.createElement("hr", {
35785
35572
  className: "golden"
35786
35573
  }))), React__default.createElement(Content, null, React__default.createElement("p", null, quests[0].description)), React__default.createElement(QuestColumn, {
@@ -36031,7 +35818,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
36031
35818
  bgColor = _ref$bgColor === void 0 ? 'red' : _ref$bgColor,
36032
35819
  _ref$margin = _ref.margin,
36033
35820
  margin = _ref$margin === void 0 ? 20 : _ref$margin;
36034
- return React__default.createElement(Container$l, {
35821
+ return React__default.createElement(Container$j, {
36035
35822
  className: "simple-progress-bar"
36036
35823
  }, React__default.createElement(ProgressBarContainer, {
36037
35824
  margin: margin
@@ -36040,7 +35827,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
36040
35827
  bgColor: bgColor
36041
35828
  }))));
36042
35829
  };
36043
- var Container$l = /*#__PURE__*/styled.div.withConfig({
35830
+ var Container$j = /*#__PURE__*/styled.div.withConfig({
36044
35831
  displayName: "SimpleProgressBar__Container",
36045
35832
  componentId: "sc-mbeil3-0"
36046
35833
  })(["display:flex;justify-content:center;align-items:center;width:100%;"]);
@@ -36271,7 +36058,7 @@ var Spell = function Spell(_ref) {
36271
36058
  isSettingShortcut = _ref.isSettingShortcut,
36272
36059
  minMagicLevelRequired = _ref.minMagicLevelRequired;
36273
36060
  var disabled = isSettingShortcut ? charMagicLevel < minMagicLevelRequired : manaCost > charMana || charMagicLevel < minMagicLevelRequired;
36274
- return React__default.createElement(Container$m, {
36061
+ return React__default.createElement(Container$k, {
36275
36062
  disabled: disabled,
36276
36063
  onPointerDown: onPointerDown == null ? void 0 : onPointerDown.bind(null, spellKey),
36277
36064
  isSettingShortcut: isSettingShortcut && !disabled,
@@ -36284,7 +36071,7 @@ var Spell = function Spell(_ref) {
36284
36071
  className: "mana"
36285
36072
  }, manaCost)));
36286
36073
  };
36287
- var Container$m = /*#__PURE__*/styled.button.withConfig({
36074
+ var Container$k = /*#__PURE__*/styled.button.withConfig({
36288
36075
  displayName: "Spell__Container",
36289
36076
  componentId: "sc-j96fa2-0"
36290
36077
  })(["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) {
@@ -36371,7 +36158,7 @@ var Spellbook = function Spellbook(_ref) {
36371
36158
  height: "inherit",
36372
36159
  cancelDrag: "#spellbook-search, #shortcuts_list, .spell",
36373
36160
  scale: scale
36374
- }, React__default.createElement(Container$n, null, React__default.createElement(Title$7, null, "Learned Spells"), React__default.createElement(ShortcutsSetter, {
36161
+ }, React__default.createElement(Container$l, null, React__default.createElement(Title$7, null, "Learned Spells"), React__default.createElement(ShortcutsSetter, {
36375
36162
  setSettingShortcutIndex: setSettingShortcutIndex,
36376
36163
  settingShortcutIndex: settingShortcutIndex,
36377
36164
  shortcuts: shortcuts,
@@ -36403,7 +36190,7 @@ var Title$7 = /*#__PURE__*/styled.h1.withConfig({
36403
36190
  displayName: "Spellbook__Title",
36404
36191
  componentId: "sc-r02nfq-0"
36405
36192
  })(["font-size:", " !important;margin-bottom:0 !important;"], uiFonts.size.large);
36406
- var Container$n = /*#__PURE__*/styled.div.withConfig({
36193
+ var Container$l = /*#__PURE__*/styled.div.withConfig({
36407
36194
  displayName: "Spellbook__Container",
36408
36195
  componentId: "sc-r02nfq-1"
36409
36196
  })(["width:100%;height:100%;color:white;display:flex;flex-direction:column;"]);
@@ -36417,16 +36204,16 @@ var TextArea = function TextArea(_ref) {
36417
36204
  return React__default.createElement("textarea", Object.assign({}, props));
36418
36205
  };
36419
36206
 
36420
- var img$a = '';
36207
+ var img$9 = '';
36421
36208
 
36422
- var img$b = '';
36209
+ var img$a = '';
36423
36210
 
36424
- var img$c = '';
36211
+ var img$b = '';
36425
36212
 
36426
36213
  var DayNightPeriod = function DayNightPeriod(_ref) {
36427
36214
  var _periodOfDaySrcFiles;
36428
36215
  var periodOfDay = _ref.periodOfDay;
36429
- var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[shared.PeriodOfDay.Morning] = img$b, _periodOfDaySrcFiles[shared.PeriodOfDay.Afternoon] = img$a, _periodOfDaySrcFiles[shared.PeriodOfDay.Night] = img$c, _periodOfDaySrcFiles);
36216
+ var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[shared.PeriodOfDay.Morning] = img$a, _periodOfDaySrcFiles[shared.PeriodOfDay.Afternoon] = img$9, _periodOfDaySrcFiles[shared.PeriodOfDay.Night] = img$b, _periodOfDaySrcFiles);
36430
36217
  return React__default.createElement(GifContainer, null, React__default.createElement("img", {
36431
36218
  src: periodOfDaySrcFiles[periodOfDay]
36432
36219
  }));
@@ -36436,7 +36223,7 @@ var GifContainer = /*#__PURE__*/styled.div.withConfig({
36436
36223
  componentId: "sc-10t97fw-0"
36437
36224
  })(["width:100%;img{width:67%;}"]);
36438
36225
 
36439
- var img$d = '';
36226
+ var img$c = '';
36440
36227
 
36441
36228
  var TimeWidget = function TimeWidget(_ref) {
36442
36229
  var onClose = _ref.onClose,
@@ -36454,7 +36241,7 @@ var TimeWidget = function TimeWidget(_ref) {
36454
36241
  var WidgetContainer = /*#__PURE__*/styled.div.withConfig({
36455
36242
  displayName: "TimeWidget__WidgetContainer",
36456
36243
  componentId: "sc-1ja236h-0"
36457
- })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$d);
36244
+ })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$c);
36458
36245
  var Time = /*#__PURE__*/styled.div.withConfig({
36459
36246
  displayName: "TimeWidget__Time",
36460
36247
  componentId: "sc-1ja236h-1"
@@ -36703,17 +36490,230 @@ var Truncate = function Truncate(_ref) {
36703
36490
  var _ref$maxLines = _ref.maxLines,
36704
36491
  maxLines = _ref$maxLines === void 0 ? 1 : _ref$maxLines,
36705
36492
  children = _ref.children;
36706
- return React__default.createElement(Container$o, {
36493
+ return React__default.createElement(Container$m, {
36707
36494
  maxLines: maxLines
36708
36495
  }, children);
36709
36496
  };
36710
- var Container$o = /*#__PURE__*/styled.div.withConfig({
36497
+ var Container$m = /*#__PURE__*/styled.div.withConfig({
36711
36498
  displayName: "Truncate__Container",
36712
36499
  componentId: "sc-6x00qb-0"
36713
36500
  })(["display:-webkit-box;max-width:100%;max-height:100%;-webkit-line-clamp:", ";-webkit-box-orient:vertical;overflow:hidden;"], function (props) {
36714
36501
  return props.maxLines;
36715
36502
  });
36716
36503
 
36504
+ var IS_MOBILE_OR_TABLET = /*#__PURE__*/shared.isMobileOrTablet();
36505
+
36506
+ var chunkString = function chunkString(str, length) {
36507
+ return str.match(new RegExp('.{1,' + length + '}', 'g'));
36508
+ };
36509
+
36510
+ var img$d = '';
36511
+
36512
+ var NPCDialogText = function NPCDialogText(_ref) {
36513
+ var text = _ref.text,
36514
+ onClose = _ref.onClose,
36515
+ onEndStep = _ref.onEndStep,
36516
+ onStartStep = _ref.onStartStep,
36517
+ type = _ref.type;
36518
+ var windowSize = React.useRef([window.innerWidth, window.innerHeight]);
36519
+ function maxCharacters(width) {
36520
+ // Set the font size to 16 pixels
36521
+ var fontSize = 11.2;
36522
+ // Calculate the number of characters that can fit in one line
36523
+ var charactersPerLine = Math.floor(width / 2 / fontSize);
36524
+ // Calculate the number of lines that can fit in the div
36525
+ var linesPerDiv = Math.floor(180 / fontSize);
36526
+ // Calculate the maximum number of characters that can fit in the div
36527
+ var maxCharacters = charactersPerLine * linesPerDiv;
36528
+ // Return the maximum number of characters
36529
+ return Math.round(maxCharacters / 5);
36530
+ }
36531
+ var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
36532
+ var _useState = React.useState(0),
36533
+ chunkIndex = _useState[0],
36534
+ setChunkIndex = _useState[1];
36535
+ var onHandleSpacePress = function onHandleSpacePress(event) {
36536
+ if (event.code === 'Space') {
36537
+ goToNextStep();
36538
+ }
36539
+ };
36540
+ var goToNextStep = function goToNextStep() {
36541
+ var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
36542
+ if (hasNextChunk) {
36543
+ setChunkIndex(function (prev) {
36544
+ return prev + 1;
36545
+ });
36546
+ } else {
36547
+ // if there's no more text chunks, close the dialog
36548
+ onClose();
36549
+ }
36550
+ };
36551
+ React.useEffect(function () {
36552
+ document.addEventListener('keydown', onHandleSpacePress);
36553
+ return function () {
36554
+ return document.removeEventListener('keydown', onHandleSpacePress);
36555
+ };
36556
+ }, [chunkIndex]);
36557
+ var _useState2 = React.useState(false),
36558
+ showGoNextIndicator = _useState2[0],
36559
+ setShowGoNextIndicator = _useState2[1];
36560
+ return React__default.createElement(Container$n, null, React__default.createElement(DynamicText, {
36561
+ text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
36562
+ onFinish: function onFinish() {
36563
+ setShowGoNextIndicator(true);
36564
+ onEndStep && onEndStep();
36565
+ },
36566
+ onStart: function onStart() {
36567
+ setShowGoNextIndicator(false);
36568
+ onStartStep && onStartStep();
36569
+ }
36570
+ }), showGoNextIndicator && React__default.createElement(PressSpaceIndicator$1, {
36571
+ right: type === exports.NPCDialogType.TextOnly ? '1rem' : '10.5rem',
36572
+ src: IS_MOBILE_OR_TABLET ? img$d : img$7,
36573
+ onPointerDown: function onPointerDown() {
36574
+ goToNextStep();
36575
+ }
36576
+ }));
36577
+ };
36578
+ var Container$n = /*#__PURE__*/styled.div.withConfig({
36579
+ displayName: "NPCDialogText__Container",
36580
+ componentId: "sc-1cxkdh9-0"
36581
+ })([""]);
36582
+ var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
36583
+ displayName: "NPCDialogText__PressSpaceIndicator",
36584
+ componentId: "sc-1cxkdh9-1"
36585
+ })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
36586
+ var right = _ref2.right;
36587
+ return right;
36588
+ });
36589
+
36590
+ (function (NPCDialogType) {
36591
+ NPCDialogType["TextOnly"] = "TextOnly";
36592
+ NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
36593
+ })(exports.NPCDialogType || (exports.NPCDialogType = {}));
36594
+ var NPCDialog = function NPCDialog(_ref) {
36595
+ var text = _ref.text,
36596
+ type = _ref.type,
36597
+ _onClose = _ref.onClose,
36598
+ imagePath = _ref.imagePath,
36599
+ _ref$isQuestionDialog = _ref.isQuestionDialog,
36600
+ isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
36601
+ questions = _ref.questions,
36602
+ answers = _ref.answers;
36603
+ return React__default.createElement(RPGUIContainer, {
36604
+ type: exports.RPGUIContainerTypes.FramedGold,
36605
+ width: isQuestionDialog ? '600px' : '80%',
36606
+ height: '180px'
36607
+ }, isQuestionDialog && questions && answers ? React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer$2, {
36608
+ flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
36609
+ }, React__default.createElement(QuestionDialog, {
36610
+ questions: questions,
36611
+ answers: answers,
36612
+ onClose: function onClose() {
36613
+ if (_onClose) {
36614
+ _onClose();
36615
+ }
36616
+ }
36617
+ })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
36618
+ src: imagePath || img$6
36619
+ }))) : React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$o, null, React__default.createElement(TextContainer$2, {
36620
+ flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
36621
+ }, React__default.createElement(NPCDialogText, {
36622
+ type: type,
36623
+ text: text || 'No text provided.',
36624
+ onClose: function onClose() {
36625
+ if (_onClose) {
36626
+ _onClose();
36627
+ }
36628
+ }
36629
+ })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
36630
+ src: imagePath || img$6
36631
+ })))));
36632
+ };
36633
+ var Container$o = /*#__PURE__*/styled.div.withConfig({
36634
+ displayName: "NPCDialog__Container",
36635
+ componentId: "sc-1b4aw74-0"
36636
+ })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
36637
+ var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
36638
+ displayName: "NPCDialog__TextContainer",
36639
+ componentId: "sc-1b4aw74-1"
36640
+ })(["flex:", " 0 0;width:355px;"], function (_ref2) {
36641
+ var flex = _ref2.flex;
36642
+ return flex;
36643
+ });
36644
+ var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
36645
+ displayName: "NPCDialog__ThumbnailContainer",
36646
+ componentId: "sc-1b4aw74-2"
36647
+ })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
36648
+ var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
36649
+ displayName: "NPCDialog__NPCThumbnail",
36650
+ componentId: "sc-1b4aw74-3"
36651
+ })(["image-rendering:pixelated;height:128px;width:128px;"]);
36652
+
36653
+ var HistoryDialog = function HistoryDialog(_ref) {
36654
+ var backgroundImgPath = _ref.backgroundImgPath,
36655
+ fullCoverBackground = _ref.fullCoverBackground,
36656
+ questions = _ref.questions,
36657
+ answers = _ref.answers,
36658
+ text = _ref.text,
36659
+ imagePath = _ref.imagePath,
36660
+ textAndTypeArray = _ref.textAndTypeArray,
36661
+ onClose = _ref.onClose;
36662
+ var _useState = React.useState(0),
36663
+ img = _useState[0],
36664
+ setImage = _useState[1];
36665
+ var onHandleSpacePress = function onHandleSpacePress(event) {
36666
+ if (event.code === 'Space') {
36667
+ if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
36668
+ setImage(function (prev) {
36669
+ return prev + 1;
36670
+ });
36671
+ } else {
36672
+ // if there's no more text chunks, close the dialog
36673
+ onClose();
36674
+ }
36675
+ }
36676
+ };
36677
+ React.useEffect(function () {
36678
+ document.addEventListener('keydown', onHandleSpacePress);
36679
+ return function () {
36680
+ return document.removeEventListener('keydown', onHandleSpacePress);
36681
+ };
36682
+ }, [backgroundImgPath]);
36683
+ return React__default.createElement(BackgroundContainer, {
36684
+ imgPath: backgroundImgPath[img],
36685
+ fullImg: fullCoverBackground
36686
+ }, React__default.createElement(DialogContainer, null, textAndTypeArray ? React__default.createElement(NPCMultiDialog, {
36687
+ textAndTypeArray: textAndTypeArray,
36688
+ onClose: onClose
36689
+ }) : questions && answers ? React__default.createElement(QuestionDialog, {
36690
+ questions: questions,
36691
+ answers: answers,
36692
+ onClose: onClose
36693
+ }) : text && imagePath ? React__default.createElement(NPCDialog, {
36694
+ text: text,
36695
+ imagePath: imagePath,
36696
+ onClose: onClose,
36697
+ type: exports.NPCDialogType.TextAndThumbnail
36698
+ }) : React__default.createElement(NPCDialog, {
36699
+ text: text,
36700
+ onClose: onClose,
36701
+ type: exports.NPCDialogType.TextOnly
36702
+ })));
36703
+ };
36704
+ var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
36705
+ displayName: "HistoryDialog__BackgroundContainer",
36706
+ componentId: "sc-u6oe75-0"
36707
+ })(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
36708
+ return props.imgPath;
36709
+ }, function (props) {
36710
+ return props.imgPath ? 'cover' : 'auto';
36711
+ });
36712
+ var DialogContainer = /*#__PURE__*/styled.div.withConfig({
36713
+ displayName: "HistoryDialog__DialogContainer",
36714
+ componentId: "sc-u6oe75-1"
36715
+ })(["display:flex;justify-content:center;padding-top:200px;"]);
36716
+
36717
36717
  exports.Button = Button;
36718
36718
  exports.CharacterSelection = CharacterSelection;
36719
36719
  exports.Chat = Chat;