@rpg-engine/long-bow 0.3.45 → 0.3.47

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 (139) hide show
  1. package/LICENSE +20 -20
  2. package/README.md +181 -181
  3. package/dist/long-bow.cjs.development.js +705 -709
  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 +708 -712
  8. package/dist/long-bow.esm.js.map +1 -1
  9. package/package.json +100 -101
  10. package/src/components/Abstractions/SlotsContainer.tsx +45 -45
  11. package/src/components/Arrow/SelectArrow.tsx +65 -65
  12. package/src/components/Arrow/img/arrow01-left-clicked.png +0 -0
  13. package/src/components/Arrow/img/arrow01-left.png +0 -0
  14. package/src/components/Arrow/img/arrow01-right-clicked.png +0 -0
  15. package/src/components/Arrow/img/arrow01-right.png +0 -0
  16. package/src/components/Arrow/img/arrow02-left-clicked.png +0 -0
  17. package/src/components/Arrow/img/arrow02-left.png +0 -0
  18. package/src/components/Arrow/img/arrow02-right-clicked.png +0 -0
  19. package/src/components/Arrow/img/arrow02-right.png +0 -0
  20. package/src/components/Button.tsx +41 -41
  21. package/src/components/Character/CharacterSelection.tsx +96 -96
  22. package/src/components/Chat/Chat.tsx +194 -194
  23. package/src/components/Chatdeprecated/ChatDeprecated.tsx +200 -200
  24. package/src/components/CheckButton.tsx +65 -65
  25. package/src/components/CircularController/CircularController.tsx +162 -162
  26. package/src/components/CraftBook/CraftBook.tsx +230 -230
  27. package/src/components/CraftBook/MockItems.ts +46 -46
  28. package/src/components/DraggableContainer.tsx +154 -154
  29. package/src/components/Dropdown.tsx +96 -96
  30. package/src/components/DropdownSelectorContainer.tsx +42 -42
  31. package/src/components/Equipment/EquipmentSet.tsx +190 -190
  32. package/src/components/HistoryDialog.tsx +104 -104
  33. package/src/components/Input.tsx +15 -15
  34. package/src/components/Item/Cards/ItemTooltip.tsx +33 -33
  35. package/src/components/Item/Inventory/ErrorBoundary.tsx +42 -42
  36. package/src/components/Item/Inventory/ItemContainer.tsx +175 -175
  37. package/src/components/Item/Inventory/ItemContainerTypes.ts +6 -6
  38. package/src/components/Item/Inventory/ItemQuantitySelector.tsx +142 -142
  39. package/src/components/Item/Inventory/ItemSlot.tsx +465 -466
  40. package/src/components/Item/Inventory/itemContainerHelper.ts +156 -156
  41. package/src/components/ListMenu.tsx +63 -63
  42. package/src/components/Multitab/Tab.tsx +57 -57
  43. package/src/components/Multitab/TabBody.tsx +13 -13
  44. package/src/components/Multitab/TabsContainer.tsx +97 -97
  45. package/src/components/NPCDialog/NPCDialog.tsx +121 -121
  46. package/src/components/NPCDialog/NPCDialogText.tsx +113 -113
  47. package/src/components/NPCDialog/NPCMultiDialog.tsx +159 -159
  48. package/src/components/NPCDialog/QuestionDialog/QuestionDialog.tsx +237 -237
  49. package/src/components/ProgressBar.tsx +92 -92
  50. package/src/components/PropertySelect/PropertySelect.tsx +114 -114
  51. package/src/components/QuestInfo/QuestInfo.tsx +232 -232
  52. package/src/components/QuestList.tsx +129 -129
  53. package/src/components/RPGUIContainer.tsx +47 -47
  54. package/src/components/RPGUIForceRenderStart.tsx +45 -45
  55. package/src/components/RPGUIRoot.tsx +14 -14
  56. package/src/components/RadioButton.tsx +53 -53
  57. package/src/components/RadioInput/RadioButton.tsx +98 -98
  58. package/src/components/RadioInput/RadioInput.tsx +98 -98
  59. package/src/components/RadioInput/instruments.ts +15 -15
  60. package/src/components/RangeSlider.tsx +78 -78
  61. package/src/components/RelativeListMenu.tsx +83 -83
  62. package/src/components/ScrollList.tsx +79 -79
  63. package/src/components/SimpleProgressBar.tsx +62 -62
  64. package/src/components/SkillProgressBar.tsx +133 -133
  65. package/src/components/SkillsContainer.tsx +167 -167
  66. package/src/components/Spellbook/QuickSpells.tsx +120 -120
  67. package/src/components/Spellbook/Spell.tsx +201 -201
  68. package/src/components/Spellbook/Spellbook.tsx +144 -144
  69. package/src/components/Spellbook/SpellbookShortcuts.tsx +77 -77
  70. package/src/components/Spellbook/constants.ts +12 -12
  71. package/src/components/Spellbook/mockSpells.ts +60 -60
  72. package/src/components/StaticBook/StaticBook.tsx +105 -105
  73. package/src/components/TextArea.tsx +11 -11
  74. package/src/components/TimeWidget/DayNightPeriod/DayNightPeriod.tsx +35 -35
  75. package/src/components/TimeWidget/TimeWidget.tsx +63 -63
  76. package/src/components/TradingMenu/TradingItemRow.tsx +197 -197
  77. package/src/components/TradingMenu/TradingMenu.tsx +203 -203
  78. package/src/components/TradingMenu/items.mock.ts +36 -36
  79. package/src/components/Truncate.tsx +25 -25
  80. package/src/components/itemSelector/ItemSelector.tsx +136 -136
  81. package/src/components/shared/Column.tsx +16 -16
  82. package/src/components/shared/Ellipsis.tsx +65 -65
  83. package/src/components/shared/SpriteFromAtlas.tsx +102 -102
  84. package/src/components/typography/DynamicText.tsx +49 -49
  85. package/src/constants/uiColors.ts +20 -20
  86. package/src/constants/uiDevices.ts +3 -5
  87. package/src/constants/uiFonts.ts +12 -12
  88. package/src/hooks/useEventListener.ts +21 -21
  89. package/src/hooks/useOutsideAlerter.ts +25 -25
  90. package/src/index.tsx +40 -40
  91. package/src/libs/StringHelpers.ts +3 -3
  92. package/src/mocks/atlas/entities/entities.json +20215 -20215
  93. package/src/mocks/atlas/icons/icons.json +735 -735
  94. package/src/mocks/atlas/items/items.json +12086 -12086
  95. package/src/mocks/equipmentSet.mocks.ts +393 -393
  96. package/src/mocks/itemContainer.mocks.ts +560 -560
  97. package/src/mocks/skills.mocks.ts +128 -128
  98. package/src/stories/Arrow.stories.tsx +26 -26
  99. package/src/stories/Button.stories.tsx +36 -36
  100. package/src/stories/CharacterSelection.stories.tsx +45 -45
  101. package/src/stories/Chat.stories.tsx +187 -187
  102. package/src/stories/ChatDeprecated.stories.tsx +170 -170
  103. package/src/stories/CheckButton.stories.tsx +48 -48
  104. package/src/stories/CircullarController.stories.tsx +33 -33
  105. package/src/stories/CraftBook.stories.tsx +40 -40
  106. package/src/stories/DayNightPeriod.stories.tsx +27 -27
  107. package/src/stories/DraggableContainer.stories.tsx +28 -28
  108. package/src/stories/Dropdown.stories.tsx +46 -46
  109. package/src/stories/DropdownSelectorContainer.stories.tsx +41 -41
  110. package/src/stories/EquipmentSet.stories.tsx +65 -65
  111. package/src/stories/HistoryDialog.stories.tsx +61 -61
  112. package/src/stories/ItemContainer.stories.tsx +124 -124
  113. package/src/stories/ItemQuantitySelector.stories.tsx +26 -26
  114. package/src/stories/ItemSelector.stories.tsx +77 -77
  115. package/src/stories/ItemTradingComponent.stories.tsx +35 -35
  116. package/src/stories/ListMenu.stories.tsx +56 -56
  117. package/src/stories/Multitab.stories.tsx +51 -51
  118. package/src/stories/NPCDialog.stories.tsx +130 -130
  119. package/src/stories/NPCMultiDialog.stories.tsx +71 -71
  120. package/src/stories/ProgressBar.stories.tsx +23 -23
  121. package/src/stories/PropertySelect.stories.tsx +40 -40
  122. package/src/stories/QuestInfo.stories.tsx +107 -107
  123. package/src/stories/QuestList.stories.tsx +82 -82
  124. package/src/stories/QuickSpells.stories.tsx +38 -38
  125. package/src/stories/RPGUIContainers.stories.tsx +42 -42
  126. package/src/stories/RadioButton.stories.tsx +49 -49
  127. package/src/stories/RadioInput.stories.tsx +34 -34
  128. package/src/stories/RangeSlider.stories.tsx +64 -64
  129. package/src/stories/ScrollList.stories.tsx +85 -85
  130. package/src/stories/SimpleProgressBar.stories.tsx +22 -22
  131. package/src/stories/SkillProgressBar.stories.tsx +34 -34
  132. package/src/stories/SkillsContainer.stories.tsx +35 -35
  133. package/src/stories/Spellbook.stories.tsx +107 -107
  134. package/src/stories/StaticBook.stories.tsx +32 -32
  135. package/src/stories/Text.stories.tsx +42 -42
  136. package/src/stories/TimeWidget.stories.tsx +27 -27
  137. package/src/stories/TradingMenu.stories.tsx +45 -45
  138. package/src/types/eventTypes.ts +4 -4
  139. package/src/types/index.d.ts +2 -2
@@ -1,13 +1,12 @@
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, ItemSubType, ItemContainerType, ItemType, ItemSocketEventsDisplayLabels, ActionsForInventory, ActionsForEquipmentSet, ActionsForLoot, ActionsForMapContainer, ItemRarities, getItemTextureKeyPath, ItemSlotType, getSPForLevel, PeriodOfDay } from '@rpg-engine/shared';
3
+ import { GRID_WIDTH, GRID_HEIGHT, ItemSubType, ItemContainerType, ItemType, ItemSocketEventsDisplayLabels, ActionsForInventory, ActionsForEquipmentSet, ActionsForLoot, ActionsForMapContainer, ItemRarities, getItemTextureKeyPath, 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';
7
7
  import Draggable from 'react-draggable';
8
8
  import { v4 } from 'uuid';
9
9
  import { observer } from 'mobx-react-lite';
10
- import isMobile from 'is-mobile';
11
10
  import 'rpgui/rpgui.min.css';
12
11
  import 'rpgui/rpgui.min.js';
13
12
  import _ from 'lodash-es';
@@ -33884,6 +33883,7 @@ var ItemSlot = /*#__PURE__*/observer(function (_ref) {
33884
33883
  var resetItem = function resetItem() {
33885
33884
  setTooltipVisible(false);
33886
33885
  setWasDragged(false);
33886
+ setIsFocused(false);
33887
33887
  };
33888
33888
  var onSuccesfulDrag = function onSuccesfulDrag(quantity) {
33889
33889
  resetItem();
@@ -33892,7 +33892,6 @@ var ItemSlot = /*#__PURE__*/observer(function (_ref) {
33892
33892
  y: 0
33893
33893
  });else if (item) {
33894
33894
  onDragEnd(quantity);
33895
- resetItem();
33896
33895
  }
33897
33896
  };
33898
33897
  return React.createElement(Container$a, {
@@ -33948,7 +33947,6 @@ var ItemSlot = /*#__PURE__*/observer(function (_ref) {
33948
33947
  if (item.stackQty && item.stackQty !== 1 && openQuantitySelector) openQuantitySelector(item.stackQty, onSuccesfulDrag);else onSuccesfulDrag(item.stackQty);
33949
33948
  } else {
33950
33949
  resetItem();
33951
- setIsFocused(false);
33952
33950
  setDragPosition({
33953
33951
  x: 0,
33954
33952
  y: 0
@@ -34142,548 +34140,6 @@ var EquipmentColumn = /*#__PURE__*/styled.div.withConfig({
34142
34140
  componentId: "sc-1wuddg2-1"
34143
34141
  })(["display:flex;justify-content:center;flex-wrap:wrap;flex-direction:column;touch-action:none;"]);
34144
34142
 
34145
- var IS_MOBILE_OR_TABLET = /*#__PURE__*/isMobile({
34146
- tablet: true
34147
- });
34148
-
34149
- var chunkString = function chunkString(str, length) {
34150
- return str.match(new RegExp('.{1,' + length + '}', 'g'));
34151
- };
34152
-
34153
- var DynamicText = function DynamicText(_ref) {
34154
- var text = _ref.text,
34155
- onFinish = _ref.onFinish,
34156
- onStart = _ref.onStart;
34157
- var _useState = useState(''),
34158
- textState = _useState[0],
34159
- setTextState = _useState[1];
34160
- useEffect(function () {
34161
- var i = 0;
34162
- var interval = setInterval(function () {
34163
- // on every interval, show one more character
34164
- if (i === 0) {
34165
- if (onStart) {
34166
- onStart();
34167
- }
34168
- }
34169
- if (i < text.length) {
34170
- setTextState(text.substring(0, i + 1));
34171
- i++;
34172
- } else {
34173
- clearInterval(interval);
34174
- if (onFinish) {
34175
- onFinish();
34176
- }
34177
- }
34178
- }, 50);
34179
- return function () {
34180
- clearInterval(interval);
34181
- };
34182
- }, [text]);
34183
- return React.createElement(TextContainer, null, textState);
34184
- };
34185
- var TextContainer = /*#__PURE__*/styled.p.withConfig({
34186
- displayName: "DynamicText__TextContainer",
34187
- componentId: "sc-1ggl9nd-0"
34188
- })(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]);
34189
-
34190
- var img$6 = '';
34191
-
34192
- var img$7 = '';
34193
-
34194
- var NPCDialogText = function NPCDialogText(_ref) {
34195
- var text = _ref.text,
34196
- onClose = _ref.onClose,
34197
- onEndStep = _ref.onEndStep,
34198
- onStartStep = _ref.onStartStep,
34199
- type = _ref.type;
34200
- var windowSize = useRef([window.innerWidth, window.innerHeight]);
34201
- function maxCharacters(width) {
34202
- // Set the font size to 16 pixels
34203
- var fontSize = 11.2;
34204
- // Calculate the number of characters that can fit in one line
34205
- var charactersPerLine = Math.floor(width / 2 / fontSize);
34206
- // Calculate the number of lines that can fit in the div
34207
- var linesPerDiv = Math.floor(180 / fontSize);
34208
- // Calculate the maximum number of characters that can fit in the div
34209
- var maxCharacters = charactersPerLine * linesPerDiv;
34210
- // Return the maximum number of characters
34211
- return Math.round(maxCharacters / 5);
34212
- }
34213
- var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
34214
- var _useState = useState(0),
34215
- chunkIndex = _useState[0],
34216
- setChunkIndex = _useState[1];
34217
- var onHandleSpacePress = function onHandleSpacePress(event) {
34218
- if (event.code === 'Space') {
34219
- goToNextStep();
34220
- }
34221
- };
34222
- var goToNextStep = function goToNextStep() {
34223
- var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
34224
- if (hasNextChunk) {
34225
- setChunkIndex(function (prev) {
34226
- return prev + 1;
34227
- });
34228
- } else {
34229
- // if there's no more text chunks, close the dialog
34230
- onClose();
34231
- }
34232
- };
34233
- useEffect(function () {
34234
- document.addEventListener('keydown', onHandleSpacePress);
34235
- return function () {
34236
- return document.removeEventListener('keydown', onHandleSpacePress);
34237
- };
34238
- }, [chunkIndex]);
34239
- var _useState2 = useState(false),
34240
- showGoNextIndicator = _useState2[0],
34241
- setShowGoNextIndicator = _useState2[1];
34242
- return React.createElement(Container$b, null, React.createElement(DynamicText, {
34243
- text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
34244
- onFinish: function onFinish() {
34245
- setShowGoNextIndicator(true);
34246
- onEndStep && onEndStep();
34247
- },
34248
- onStart: function onStart() {
34249
- setShowGoNextIndicator(false);
34250
- onStartStep && onStartStep();
34251
- }
34252
- }), showGoNextIndicator && React.createElement(PressSpaceIndicator, {
34253
- right: type === NPCDialogType.TextOnly ? '1rem' : '10.5rem',
34254
- src: IS_MOBILE_OR_TABLET ? img$6 : img$7,
34255
- onClick: function onClick() {
34256
- goToNextStep();
34257
- }
34258
- }));
34259
- };
34260
- var Container$b = /*#__PURE__*/styled.div.withConfig({
34261
- displayName: "NPCDialogText__Container",
34262
- componentId: "sc-1cxkdh9-0"
34263
- })([""]);
34264
- var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
34265
- displayName: "NPCDialogText__PressSpaceIndicator",
34266
- componentId: "sc-1cxkdh9-1"
34267
- })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
34268
- var right = _ref2.right;
34269
- return right;
34270
- });
34271
-
34272
- //@ts-ignore
34273
- var useEventListener = function useEventListener(type, handler, el) {
34274
- if (el === void 0) {
34275
- el = window;
34276
- }
34277
- var savedHandler = React.useRef();
34278
- React.useEffect(function () {
34279
- savedHandler.current = handler;
34280
- }, [handler]);
34281
- React.useEffect(function () {
34282
- //@ts-ignore
34283
- var listener = function listener(e) {
34284
- return savedHandler.current(e);
34285
- };
34286
- el.addEventListener(type, listener);
34287
- return function () {
34288
- el.removeEventListener(type, listener);
34289
- };
34290
- }, [type, el]);
34291
- };
34292
-
34293
- var QuestionDialog = function QuestionDialog(_ref) {
34294
- var questions = _ref.questions,
34295
- answers = _ref.answers,
34296
- onClose = _ref.onClose;
34297
- var _useState = useState(questions[0]),
34298
- currentQuestion = _useState[0],
34299
- setCurrentQuestion = _useState[1];
34300
- var _useState2 = useState(false),
34301
- canShowAnswers = _useState2[0],
34302
- setCanShowAnswers = _useState2[1];
34303
- var onGetFirstAnswer = function onGetFirstAnswer() {
34304
- if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {
34305
- return null;
34306
- }
34307
- var firstAnswerId = currentQuestion.answerIds[0];
34308
- return answers.find(function (answer) {
34309
- return answer.id === firstAnswerId;
34310
- });
34311
- };
34312
- var _useState3 = useState(onGetFirstAnswer()),
34313
- currentAnswer = _useState3[0],
34314
- setCurrentAnswer = _useState3[1];
34315
- useEffect(function () {
34316
- setCurrentAnswer(onGetFirstAnswer());
34317
- }, [currentQuestion]);
34318
- var onGetAnswers = function onGetAnswers(answerIds) {
34319
- return answerIds.map(function (answerId) {
34320
- return answers.find(function (answer) {
34321
- return answer.id === answerId;
34322
- });
34323
- });
34324
- };
34325
- var onKeyPress = function onKeyPress(e) {
34326
- switch (e.key) {
34327
- case 'ArrowDown':
34328
- // select next answer, if any.
34329
- // if no next answer, select first answer
34330
- // const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(
34331
- // (answer) => answer?.id === currentAnswer!.id + 1
34332
- // );
34333
- var nextAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34334
- return (answer == null ? void 0 : answer.id) === currentAnswer.id + 1;
34335
- });
34336
- var nextAnswerID = currentQuestion.answerIds[nextAnswerIndex];
34337
- var nextAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34338
- return (answer == null ? void 0 : answer.id) === nextAnswerID;
34339
- });
34340
- setCurrentAnswer(nextAnswer || onGetFirstAnswer());
34341
- break;
34342
- case 'ArrowUp':
34343
- // select previous answer, if any.
34344
- // if no previous answer, select last answer
34345
- var previousAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34346
- return (answer == null ? void 0 : answer.id) === currentAnswer.id - 1;
34347
- });
34348
- var previousAnswerID = currentQuestion.answerIds && currentQuestion.answerIds[previousAnswerIndex];
34349
- var previousAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34350
- return (answer == null ? void 0 : answer.id) === previousAnswerID;
34351
- });
34352
- if (previousAnswer) {
34353
- setCurrentAnswer(previousAnswer);
34354
- } else {
34355
- setCurrentAnswer(onGetAnswers(currentQuestion.answerIds).pop());
34356
- }
34357
- break;
34358
- case 'Enter':
34359
- setCanShowAnswers(false);
34360
- if (!(currentAnswer != null && currentAnswer.nextQuestionId)) {
34361
- onClose();
34362
- return;
34363
- } else {
34364
- setCurrentQuestion(questions.find(function (question) {
34365
- return question.id === currentAnswer.nextQuestionId;
34366
- }));
34367
- }
34368
- break;
34369
- }
34370
- };
34371
- useEventListener('keydown', onKeyPress);
34372
- var onAnswerClick = function onAnswerClick(answer) {
34373
- setCanShowAnswers(false);
34374
- if (answer.nextQuestionId) {
34375
- // if there is a next question, go to it
34376
- setCurrentQuestion(questions.find(function (question) {
34377
- return question.id === answer.nextQuestionId;
34378
- }));
34379
- } else {
34380
- // else, finish dialog!
34381
- onClose();
34382
- }
34383
- };
34384
- var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
34385
- var answerIds = currentQuestion.answerIds;
34386
- if (!answerIds) {
34387
- return null;
34388
- }
34389
- var answers = onGetAnswers(answerIds);
34390
- if (!answers) {
34391
- return null;
34392
- }
34393
- return answers.map(function (answer) {
34394
- var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
34395
- var selectedColor = isSelected ? 'yellow' : 'white';
34396
- if (answer) {
34397
- return React.createElement(AnswerRow, {
34398
- key: "answer_" + answer.id
34399
- }, React.createElement(AnswerSelectedIcon, {
34400
- color: selectedColor
34401
- }, isSelected ? 'X' : null), React.createElement(Answer, {
34402
- key: answer.id,
34403
- onClick: function onClick() {
34404
- return onAnswerClick(answer);
34405
- },
34406
- color: selectedColor
34407
- }, answer.text));
34408
- }
34409
- return null;
34410
- });
34411
- };
34412
- return React.createElement(Container$c, null, React.createElement(QuestionContainer, null, React.createElement(DynamicText, {
34413
- text: currentQuestion.text,
34414
- onStart: function onStart() {
34415
- return setCanShowAnswers(false);
34416
- },
34417
- onFinish: function onFinish() {
34418
- return setCanShowAnswers(true);
34419
- }
34420
- })), canShowAnswers && React.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
34421
- };
34422
- var Container$c = /*#__PURE__*/styled.div.withConfig({
34423
- displayName: "QuestionDialog__Container",
34424
- componentId: "sc-bxc5u0-0"
34425
- })(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
34426
- var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
34427
- displayName: "QuestionDialog__QuestionContainer",
34428
- componentId: "sc-bxc5u0-1"
34429
- })(["flex:100%;width:100%;"]);
34430
- var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
34431
- displayName: "QuestionDialog__AnswersContainer",
34432
- componentId: "sc-bxc5u0-2"
34433
- })(["flex:100%;"]);
34434
- var Answer = /*#__PURE__*/styled.p.withConfig({
34435
- displayName: "QuestionDialog__Answer",
34436
- componentId: "sc-bxc5u0-3"
34437
- })(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
34438
- return props.color;
34439
- });
34440
- var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
34441
- displayName: "QuestionDialog__AnswerSelectedIcon",
34442
- componentId: "sc-bxc5u0-4"
34443
- })(["flex:5% 0 0;color:", " !important;"], function (props) {
34444
- return props.color;
34445
- });
34446
- var AnswerRow = /*#__PURE__*/styled.div.withConfig({
34447
- displayName: "QuestionDialog__AnswerRow",
34448
- componentId: "sc-bxc5u0-5"
34449
- })(["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;}"]);
34450
-
34451
- var img$8 = '';
34452
-
34453
- var NPCDialogType;
34454
- (function (NPCDialogType) {
34455
- NPCDialogType["TextOnly"] = "TextOnly";
34456
- NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
34457
- })(NPCDialogType || (NPCDialogType = {}));
34458
- var NPCDialog = function NPCDialog(_ref) {
34459
- var text = _ref.text,
34460
- type = _ref.type,
34461
- _onClose = _ref.onClose,
34462
- imagePath = _ref.imagePath,
34463
- _ref$isQuestionDialog = _ref.isQuestionDialog,
34464
- isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
34465
- questions = _ref.questions,
34466
- answers = _ref.answers;
34467
- return React.createElement(RPGUIContainer, {
34468
- type: RPGUIContainerTypes.FramedGold,
34469
- width: isQuestionDialog ? '600px' : '80%',
34470
- height: '180px'
34471
- }, isQuestionDialog && questions && answers ? React.createElement(React.Fragment, null, React.createElement(TextContainer$1, {
34472
- flex: type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'
34473
- }, React.createElement(QuestionDialog, {
34474
- questions: questions,
34475
- answers: answers,
34476
- onClose: function onClose() {
34477
- if (_onClose) {
34478
- _onClose();
34479
- }
34480
- }
34481
- })), type === NPCDialogType.TextAndThumbnail && React.createElement(ThumbnailContainer, null, React.createElement(NPCThumbnail, {
34482
- src: imagePath || img$8
34483
- }))) : React.createElement(React.Fragment, null, React.createElement(Container$d, null, React.createElement(TextContainer$1, {
34484
- flex: type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'
34485
- }, React.createElement(NPCDialogText, {
34486
- type: type,
34487
- text: text || 'No text provided.',
34488
- onClose: function onClose() {
34489
- if (_onClose) {
34490
- _onClose();
34491
- }
34492
- }
34493
- })), type === NPCDialogType.TextAndThumbnail && React.createElement(ThumbnailContainer, null, React.createElement(NPCThumbnail, {
34494
- src: imagePath || img$8
34495
- })))));
34496
- };
34497
- var Container$d = /*#__PURE__*/styled.div.withConfig({
34498
- displayName: "NPCDialog__Container",
34499
- componentId: "sc-1b4aw74-0"
34500
- })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
34501
- var TextContainer$1 = /*#__PURE__*/styled.div.withConfig({
34502
- displayName: "NPCDialog__TextContainer",
34503
- componentId: "sc-1b4aw74-1"
34504
- })(["flex:", " 0 0;width:355px;"], function (_ref2) {
34505
- var flex = _ref2.flex;
34506
- return flex;
34507
- });
34508
- var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
34509
- displayName: "NPCDialog__ThumbnailContainer",
34510
- componentId: "sc-1b4aw74-2"
34511
- })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
34512
- var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
34513
- displayName: "NPCDialog__NPCThumbnail",
34514
- componentId: "sc-1b4aw74-3"
34515
- })(["image-rendering:pixelated;height:128px;width:128px;"]);
34516
-
34517
- var ImgSide;
34518
- (function (ImgSide) {
34519
- ImgSide["right"] = "right";
34520
- ImgSide["left"] = "left";
34521
- })(ImgSide || (ImgSide = {}));
34522
- var NPCMultiDialog = function NPCMultiDialog(_ref) {
34523
- var _textAndTypeArray$sli;
34524
- var _onClose = _ref.onClose,
34525
- textAndTypeArray = _ref.textAndTypeArray;
34526
- var _useState = useState(false),
34527
- showGoNextIndicator = _useState[0],
34528
- setShowGoNextIndicator = _useState[1];
34529
- var _useState2 = useState(0),
34530
- slide = _useState2[0],
34531
- setSlide = _useState2[1];
34532
- var onHandleSpacePress = function onHandleSpacePress(event) {
34533
- if (event.code === 'Space') {
34534
- if (slide < (textAndTypeArray == null ? void 0 : textAndTypeArray.length) - 1) {
34535
- setSlide(function (prev) {
34536
- return prev + 1;
34537
- });
34538
- } else {
34539
- // if there's no more text chunks, close the dialog
34540
- _onClose();
34541
- }
34542
- }
34543
- };
34544
- useEffect(function () {
34545
- document.addEventListener('keydown', onHandleSpacePress);
34546
- return function () {
34547
- return document.removeEventListener('keydown', onHandleSpacePress);
34548
- };
34549
- }, [slide]);
34550
- return React.createElement(RPGUIContainer, {
34551
- type: RPGUIContainerTypes.FramedGold,
34552
- width: '50%',
34553
- height: '180px'
34554
- }, React.createElement(React.Fragment, null, React.createElement(Container$e, null, ((_textAndTypeArray$sli = textAndTypeArray[slide]) == null ? void 0 : _textAndTypeArray$sli.imageSide) === 'right' && React.createElement(React.Fragment, null, React.createElement(TextContainer$2, {
34555
- flex: '70%'
34556
- }, React.createElement(NPCDialogText, {
34557
- onStartStep: function onStartStep() {
34558
- return setShowGoNextIndicator(false);
34559
- },
34560
- onEndStep: function onEndStep() {
34561
- return setShowGoNextIndicator(true);
34562
- },
34563
- text: textAndTypeArray[slide].text || 'No text provided.',
34564
- onClose: function onClose() {
34565
- if (_onClose) {
34566
- _onClose();
34567
- }
34568
- }
34569
- })), React.createElement(ThumbnailContainer$1, null, React.createElement(NPCThumbnail$1, {
34570
- src: textAndTypeArray[slide].imagePath || img$8
34571
- })), showGoNextIndicator && React.createElement(PressSpaceIndicator$1, {
34572
- right: '10.5rem',
34573
- src: img$7
34574
- })), textAndTypeArray[slide].imageSide === 'left' && React.createElement(React.Fragment, null, React.createElement(ThumbnailContainer$1, null, React.createElement(NPCThumbnail$1, {
34575
- src: textAndTypeArray[slide].imagePath || img$8
34576
- })), React.createElement(TextContainer$2, {
34577
- flex: '70%'
34578
- }, React.createElement(NPCDialogText, {
34579
- onStartStep: function onStartStep() {
34580
- return setShowGoNextIndicator(false);
34581
- },
34582
- onEndStep: function onEndStep() {
34583
- return setShowGoNextIndicator(true);
34584
- },
34585
- text: textAndTypeArray[slide].text || 'No text provided.',
34586
- onClose: function onClose() {
34587
- if (_onClose) {
34588
- _onClose();
34589
- }
34590
- }
34591
- })), showGoNextIndicator && React.createElement(PressSpaceIndicator$1, {
34592
- right: '1rem',
34593
- src: img$7
34594
- }))), ")"));
34595
- };
34596
- var Container$e = /*#__PURE__*/styled.div.withConfig({
34597
- displayName: "NPCMultiDialog__Container",
34598
- componentId: "sc-rvu5wg-0"
34599
- })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
34600
- var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
34601
- displayName: "NPCMultiDialog__TextContainer",
34602
- componentId: "sc-rvu5wg-1"
34603
- })(["flex:", " 0 0;width:355px;"], function (_ref2) {
34604
- var flex = _ref2.flex;
34605
- return flex;
34606
- });
34607
- var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
34608
- displayName: "NPCMultiDialog__ThumbnailContainer",
34609
- componentId: "sc-rvu5wg-2"
34610
- })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
34611
- var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
34612
- displayName: "NPCMultiDialog__NPCThumbnail",
34613
- componentId: "sc-rvu5wg-3"
34614
- })(["image-rendering:pixelated;height:128px;width:128px;"]);
34615
- var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
34616
- displayName: "NPCMultiDialog__PressSpaceIndicator",
34617
- componentId: "sc-rvu5wg-4"
34618
- })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref3) {
34619
- var right = _ref3.right;
34620
- return right;
34621
- });
34622
-
34623
- var HistoryDialog = function HistoryDialog(_ref) {
34624
- var backgroundImgPath = _ref.backgroundImgPath,
34625
- fullCoverBackground = _ref.fullCoverBackground,
34626
- questions = _ref.questions,
34627
- answers = _ref.answers,
34628
- text = _ref.text,
34629
- imagePath = _ref.imagePath,
34630
- textAndTypeArray = _ref.textAndTypeArray,
34631
- onClose = _ref.onClose;
34632
- var _useState = useState(0),
34633
- img = _useState[0],
34634
- setImage = _useState[1];
34635
- var onHandleSpacePress = function onHandleSpacePress(event) {
34636
- if (event.code === 'Space') {
34637
- if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
34638
- setImage(function (prev) {
34639
- return prev + 1;
34640
- });
34641
- } else {
34642
- // if there's no more text chunks, close the dialog
34643
- onClose();
34644
- }
34645
- }
34646
- };
34647
- useEffect(function () {
34648
- document.addEventListener('keydown', onHandleSpacePress);
34649
- return function () {
34650
- return document.removeEventListener('keydown', onHandleSpacePress);
34651
- };
34652
- }, [backgroundImgPath]);
34653
- return React.createElement(BackgroundContainer, {
34654
- imgPath: backgroundImgPath[img],
34655
- fullImg: fullCoverBackground
34656
- }, React.createElement(DialogContainer, null, textAndTypeArray ? React.createElement(NPCMultiDialog, {
34657
- textAndTypeArray: textAndTypeArray,
34658
- onClose: onClose
34659
- }) : questions && answers ? React.createElement(QuestionDialog, {
34660
- questions: questions,
34661
- answers: answers,
34662
- onClose: onClose
34663
- }) : text && imagePath ? React.createElement(NPCDialog, {
34664
- text: text,
34665
- imagePath: imagePath,
34666
- onClose: onClose,
34667
- type: NPCDialogType.TextAndThumbnail
34668
- }) : React.createElement(NPCDialog, {
34669
- text: text,
34670
- onClose: onClose,
34671
- type: NPCDialogType.TextOnly
34672
- })));
34673
- };
34674
- var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
34675
- displayName: "HistoryDialog__BackgroundContainer",
34676
- componentId: "sc-u6oe75-0"
34677
- })(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
34678
- return props.imgPath;
34679
- }, function (props) {
34680
- return props.imgPath ? 'cover' : 'auto';
34681
- });
34682
- var DialogContainer = /*#__PURE__*/styled.div.withConfig({
34683
- displayName: "HistoryDialog__DialogContainer",
34684
- componentId: "sc-u6oe75-1"
34685
- })(["display:flex;justify-content:center;padding-top:200px;"]);
34686
-
34687
34143
  var SlotsContainer = function SlotsContainer(_ref) {
34688
34144
  var children = _ref.children,
34689
34145
  title = _ref.title,
@@ -34943,163 +34399,489 @@ var ItemContainer$1 = function ItemContainer(_ref) {
34943
34399
  atlasJSON: atlasJSON
34944
34400
  }));
34945
34401
  }
34946
- return slots;
34402
+ return slots;
34403
+ };
34404
+ return React.createElement(React.Fragment, null, React.createElement(SlotsContainer, {
34405
+ title: itemContainer.name || 'Container',
34406
+ onClose: onClose,
34407
+ initialPosition: initialPosition
34408
+ }, React.createElement(ItemsContainer, {
34409
+ className: "item-container-body"
34410
+ }, onRenderSlots())), quantitySelect.isOpen && React.createElement(QuantitySelectorContainer, null, React.createElement(ItemQuantitySelector, {
34411
+ quantity: quantitySelect.maxQuantity,
34412
+ onConfirm: function onConfirm(quantity) {
34413
+ quantitySelect.callback(quantity);
34414
+ setQuantitySelect({
34415
+ isOpen: false,
34416
+ maxQuantity: 1,
34417
+ callback: function callback() {}
34418
+ });
34419
+ },
34420
+ onClose: function onClose() {
34421
+ quantitySelect.callback(-1);
34422
+ setQuantitySelect({
34423
+ isOpen: false,
34424
+ maxQuantity: 1,
34425
+ callback: function callback() {}
34426
+ });
34427
+ }
34428
+ })));
34429
+ };
34430
+ var ItemsContainer = /*#__PURE__*/styled.div.withConfig({
34431
+ displayName: "ItemContainer__ItemsContainer",
34432
+ componentId: "sc-15y5p9l-0"
34433
+ })(["max-width:280px;display:flex;justify-content:center;flex-wrap:wrap;"]);
34434
+ var QuantitySelectorContainer = /*#__PURE__*/styled.div.withConfig({
34435
+ displayName: "ItemContainer__QuantitySelectorContainer",
34436
+ componentId: "sc-15y5p9l-1"
34437
+ })(["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);"]);
34438
+
34439
+ var ItemSelector = function ItemSelector(_ref) {
34440
+ var atlasIMG = _ref.atlasIMG,
34441
+ atlasJSON = _ref.atlasJSON,
34442
+ options = _ref.options,
34443
+ onClose = _ref.onClose,
34444
+ onSelect = _ref.onSelect;
34445
+ var _useState = useState(),
34446
+ selectedValue = _useState[0],
34447
+ setSelectedValue = _useState[1];
34448
+ var handleClick = function handleClick() {
34449
+ var element = document.querySelector("input[name='test']:checked");
34450
+ var elementValue = element.value;
34451
+ setSelectedValue(elementValue);
34452
+ };
34453
+ useEffect(function () {
34454
+ if (selectedValue) {
34455
+ onSelect(selectedValue);
34456
+ }
34457
+ }, [selectedValue]);
34458
+ return React.createElement(DraggableContainer, {
34459
+ type: RPGUIContainerTypes.Framed,
34460
+ width: "500px",
34461
+ cancelDrag: ".equipment-container-body .arrow-selector",
34462
+ onCloseButton: function onCloseButton() {
34463
+ if (onClose) {
34464
+ onClose();
34465
+ }
34466
+ }
34467
+ }, React.createElement("div", {
34468
+ style: {
34469
+ width: '100%'
34470
+ }
34471
+ }, React.createElement(Title$2, null, 'Harvesting instruments'), React.createElement(Subtitle$1, null, 'Use the tool, you need it'), React.createElement("hr", {
34472
+ className: "golden"
34473
+ })), React.createElement(RadioInputScroller$1, null, options == null ? void 0 : options.map(function (option, index) {
34474
+ return React.createElement(RadioOptionsWrapper$1, {
34475
+ key: index
34476
+ }, React.createElement(SpriteAtlasWrapper$1, null, React.createElement(SpriteFromAtlas, {
34477
+ atlasIMG: atlasIMG,
34478
+ atlasJSON: atlasJSON,
34479
+ spriteKey: option.imageKey,
34480
+ imgScale: 3
34481
+ })), React.createElement("div", null, React.createElement("input", {
34482
+ className: "rpgui-radio",
34483
+ type: "radio",
34484
+ value: option.name,
34485
+ name: "test"
34486
+ }), React.createElement("label", {
34487
+ onClick: handleClick,
34488
+ style: {
34489
+ display: 'flex',
34490
+ alignItems: 'center'
34491
+ }
34492
+ }, option.name, " ", React.createElement("br", null), option.description)));
34493
+ })), React.createElement(ButtonWrapper$1, null, React.createElement(Button, {
34494
+ buttonType: ButtonTypes.RPGUIButton,
34495
+ onClick: onClose
34496
+ }, "Cancel"), React.createElement(Button, {
34497
+ buttonType: ButtonTypes.RPGUIButton
34498
+ }, "Select")));
34499
+ };
34500
+ var Title$2 = /*#__PURE__*/styled.h1.withConfig({
34501
+ displayName: "ItemSelector__Title",
34502
+ componentId: "sc-gptoxp-0"
34503
+ })(["font-size:0.6rem;color:yellow !important;"]);
34504
+ var Subtitle$1 = /*#__PURE__*/styled.h1.withConfig({
34505
+ displayName: "ItemSelector__Subtitle",
34506
+ componentId: "sc-gptoxp-1"
34507
+ })(["font-size:0.4rem;color:yellow !important;"]);
34508
+ var RadioInputScroller$1 = /*#__PURE__*/styled.div.withConfig({
34509
+ displayName: "ItemSelector__RadioInputScroller",
34510
+ componentId: "sc-gptoxp-2"
34511
+ })(["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;"]);
34512
+ var SpriteAtlasWrapper$1 = /*#__PURE__*/styled.div.withConfig({
34513
+ displayName: "ItemSelector__SpriteAtlasWrapper",
34514
+ componentId: "sc-gptoxp-3"
34515
+ })(["margin-right:40px;"]);
34516
+ var RadioOptionsWrapper$1 = /*#__PURE__*/styled.div.withConfig({
34517
+ displayName: "ItemSelector__RadioOptionsWrapper",
34518
+ componentId: "sc-gptoxp-4"
34519
+ })(["display:flex;align-items:stretch;margin-bottom:40px;"]);
34520
+ var ButtonWrapper$1 = /*#__PURE__*/styled.div.withConfig({
34521
+ displayName: "ItemSelector__ButtonWrapper",
34522
+ componentId: "sc-gptoxp-5"
34523
+ })(["display:flex;justify-content:space-around;padding-top:20px;width:100%;"]);
34524
+
34525
+ var ListMenu = function ListMenu(_ref) {
34526
+ var options = _ref.options,
34527
+ onSelected = _ref.onSelected,
34528
+ x = _ref.x,
34529
+ y = _ref.y;
34530
+ return React.createElement(Container$b, {
34531
+ x: x,
34532
+ y: y
34533
+ }, React.createElement("ul", {
34534
+ className: "rpgui-list-imp",
34535
+ style: {
34536
+ overflow: 'hidden'
34537
+ }
34538
+ }, options.map(function (params, index) {
34539
+ return React.createElement(ListElement$1, {
34540
+ key: (params == null ? void 0 : params.id) || index,
34541
+ onClick: function onClick() {
34542
+ onSelected(params == null ? void 0 : params.id);
34543
+ }
34544
+ }, (params == null ? void 0 : params.text) || 'No text');
34545
+ })));
34546
+ };
34547
+ var Container$b = /*#__PURE__*/styled.div.withConfig({
34548
+ displayName: "ListMenu__Container",
34549
+ componentId: "sc-i9097t-0"
34550
+ })(["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) {
34551
+ return props.y || 0;
34552
+ }, function (props) {
34553
+ return props.x || 0;
34554
+ }, uiFonts.size.xsmall);
34555
+ var ListElement$1 = /*#__PURE__*/styled.li.withConfig({
34556
+ displayName: "ListMenu__ListElement",
34557
+ componentId: "sc-i9097t-1"
34558
+ })(["margin-right:0.5rem;"]);
34559
+
34560
+ var img$6 = '';
34561
+
34562
+ var img$7 = '';
34563
+
34564
+ var ImgSide;
34565
+ (function (ImgSide) {
34566
+ ImgSide["right"] = "right";
34567
+ ImgSide["left"] = "left";
34568
+ })(ImgSide || (ImgSide = {}));
34569
+ var NPCMultiDialog = function NPCMultiDialog(_ref) {
34570
+ var _textAndTypeArray$sli;
34571
+ var _onClose = _ref.onClose,
34572
+ textAndTypeArray = _ref.textAndTypeArray;
34573
+ var _useState = useState(false),
34574
+ showGoNextIndicator = _useState[0],
34575
+ setShowGoNextIndicator = _useState[1];
34576
+ var _useState2 = useState(0),
34577
+ slide = _useState2[0],
34578
+ setSlide = _useState2[1];
34579
+ var onHandleSpacePress = function onHandleSpacePress(event) {
34580
+ if (event.code === 'Space') {
34581
+ if (slide < (textAndTypeArray == null ? void 0 : textAndTypeArray.length) - 1) {
34582
+ setSlide(function (prev) {
34583
+ return prev + 1;
34584
+ });
34585
+ } else {
34586
+ // if there's no more text chunks, close the dialog
34587
+ _onClose();
34588
+ }
34589
+ }
34590
+ };
34591
+ useEffect(function () {
34592
+ document.addEventListener('keydown', onHandleSpacePress);
34593
+ return function () {
34594
+ return document.removeEventListener('keydown', onHandleSpacePress);
34595
+ };
34596
+ }, [slide]);
34597
+ return React.createElement(RPGUIContainer, {
34598
+ type: RPGUIContainerTypes.FramedGold,
34599
+ width: '50%',
34600
+ height: '180px'
34601
+ }, React.createElement(React.Fragment, null, React.createElement(Container$c, null, ((_textAndTypeArray$sli = textAndTypeArray[slide]) == null ? void 0 : _textAndTypeArray$sli.imageSide) === 'right' && React.createElement(React.Fragment, null, React.createElement(TextContainer, {
34602
+ flex: '70%'
34603
+ }, React.createElement(NPCDialogText, {
34604
+ onStartStep: function onStartStep() {
34605
+ return setShowGoNextIndicator(false);
34606
+ },
34607
+ onEndStep: function onEndStep() {
34608
+ return setShowGoNextIndicator(true);
34609
+ },
34610
+ text: textAndTypeArray[slide].text || 'No text provided.',
34611
+ onClose: function onClose() {
34612
+ if (_onClose) {
34613
+ _onClose();
34614
+ }
34615
+ }
34616
+ })), React.createElement(ThumbnailContainer, null, React.createElement(NPCThumbnail, {
34617
+ src: textAndTypeArray[slide].imagePath || img$6
34618
+ })), showGoNextIndicator && React.createElement(PressSpaceIndicator, {
34619
+ right: '10.5rem',
34620
+ src: img$7
34621
+ })), textAndTypeArray[slide].imageSide === 'left' && React.createElement(React.Fragment, null, React.createElement(ThumbnailContainer, null, React.createElement(NPCThumbnail, {
34622
+ src: textAndTypeArray[slide].imagePath || img$6
34623
+ })), React.createElement(TextContainer, {
34624
+ flex: '70%'
34625
+ }, React.createElement(NPCDialogText, {
34626
+ onStartStep: function onStartStep() {
34627
+ return setShowGoNextIndicator(false);
34628
+ },
34629
+ onEndStep: function onEndStep() {
34630
+ return setShowGoNextIndicator(true);
34631
+ },
34632
+ text: textAndTypeArray[slide].text || 'No text provided.',
34633
+ onClose: function onClose() {
34634
+ if (_onClose) {
34635
+ _onClose();
34636
+ }
34637
+ }
34638
+ })), showGoNextIndicator && React.createElement(PressSpaceIndicator, {
34639
+ right: '1rem',
34640
+ src: img$7
34641
+ }))), ")"));
34642
+ };
34643
+ var Container$c = /*#__PURE__*/styled.div.withConfig({
34644
+ displayName: "NPCMultiDialog__Container",
34645
+ componentId: "sc-rvu5wg-0"
34646
+ })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
34647
+ var TextContainer = /*#__PURE__*/styled.div.withConfig({
34648
+ displayName: "NPCMultiDialog__TextContainer",
34649
+ componentId: "sc-rvu5wg-1"
34650
+ })(["flex:", " 0 0;width:355px;"], function (_ref2) {
34651
+ var flex = _ref2.flex;
34652
+ return flex;
34653
+ });
34654
+ var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
34655
+ displayName: "NPCMultiDialog__ThumbnailContainer",
34656
+ componentId: "sc-rvu5wg-2"
34657
+ })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
34658
+ var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
34659
+ displayName: "NPCMultiDialog__NPCThumbnail",
34660
+ componentId: "sc-rvu5wg-3"
34661
+ })(["image-rendering:pixelated;height:128px;width:128px;"]);
34662
+ var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
34663
+ displayName: "NPCMultiDialog__PressSpaceIndicator",
34664
+ componentId: "sc-rvu5wg-4"
34665
+ })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref3) {
34666
+ var right = _ref3.right;
34667
+ return right;
34668
+ });
34669
+
34670
+ //@ts-ignore
34671
+ var useEventListener = function useEventListener(type, handler, el) {
34672
+ if (el === void 0) {
34673
+ el = window;
34674
+ }
34675
+ var savedHandler = React.useRef();
34676
+ React.useEffect(function () {
34677
+ savedHandler.current = handler;
34678
+ }, [handler]);
34679
+ React.useEffect(function () {
34680
+ //@ts-ignore
34681
+ var listener = function listener(e) {
34682
+ return savedHandler.current(e);
34683
+ };
34684
+ el.addEventListener(type, listener);
34685
+ return function () {
34686
+ el.removeEventListener(type, listener);
34687
+ };
34688
+ }, [type, el]);
34689
+ };
34690
+
34691
+ var DynamicText = function DynamicText(_ref) {
34692
+ var text = _ref.text,
34693
+ onFinish = _ref.onFinish,
34694
+ onStart = _ref.onStart;
34695
+ var _useState = useState(''),
34696
+ textState = _useState[0],
34697
+ setTextState = _useState[1];
34698
+ useEffect(function () {
34699
+ var i = 0;
34700
+ var interval = setInterval(function () {
34701
+ // on every interval, show one more character
34702
+ if (i === 0) {
34703
+ if (onStart) {
34704
+ onStart();
34705
+ }
34706
+ }
34707
+ if (i < text.length) {
34708
+ setTextState(text.substring(0, i + 1));
34709
+ i++;
34710
+ } else {
34711
+ clearInterval(interval);
34712
+ if (onFinish) {
34713
+ onFinish();
34714
+ }
34715
+ }
34716
+ }, 50);
34717
+ return function () {
34718
+ clearInterval(interval);
34719
+ };
34720
+ }, [text]);
34721
+ return React.createElement(TextContainer$1, null, textState);
34722
+ };
34723
+ var TextContainer$1 = /*#__PURE__*/styled.p.withConfig({
34724
+ displayName: "DynamicText__TextContainer",
34725
+ componentId: "sc-1ggl9nd-0"
34726
+ })(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]);
34727
+
34728
+ var QuestionDialog = function QuestionDialog(_ref) {
34729
+ var questions = _ref.questions,
34730
+ answers = _ref.answers,
34731
+ onClose = _ref.onClose;
34732
+ var _useState = useState(questions[0]),
34733
+ currentQuestion = _useState[0],
34734
+ setCurrentQuestion = _useState[1];
34735
+ var _useState2 = useState(false),
34736
+ canShowAnswers = _useState2[0],
34737
+ setCanShowAnswers = _useState2[1];
34738
+ var onGetFirstAnswer = function onGetFirstAnswer() {
34739
+ if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {
34740
+ return null;
34741
+ }
34742
+ var firstAnswerId = currentQuestion.answerIds[0];
34743
+ return answers.find(function (answer) {
34744
+ return answer.id === firstAnswerId;
34745
+ });
34947
34746
  };
34948
- return React.createElement(React.Fragment, null, React.createElement(SlotsContainer, {
34949
- title: itemContainer.name || 'Container',
34950
- onClose: onClose,
34951
- initialPosition: initialPosition
34952
- }, React.createElement(ItemsContainer, {
34953
- className: "item-container-body"
34954
- }, onRenderSlots())), quantitySelect.isOpen && React.createElement(QuantitySelectorContainer, null, React.createElement(ItemQuantitySelector, {
34955
- quantity: quantitySelect.maxQuantity,
34956
- onConfirm: function onConfirm(quantity) {
34957
- quantitySelect.callback(quantity);
34958
- setQuantitySelect({
34959
- isOpen: false,
34960
- maxQuantity: 1,
34961
- callback: function callback() {}
34962
- });
34963
- },
34964
- onClose: function onClose() {
34965
- quantitySelect.callback(-1);
34966
- setQuantitySelect({
34967
- isOpen: false,
34968
- maxQuantity: 1,
34969
- callback: function callback() {}
34747
+ var _useState3 = useState(onGetFirstAnswer()),
34748
+ currentAnswer = _useState3[0],
34749
+ setCurrentAnswer = _useState3[1];
34750
+ useEffect(function () {
34751
+ setCurrentAnswer(onGetFirstAnswer());
34752
+ }, [currentQuestion]);
34753
+ var onGetAnswers = function onGetAnswers(answerIds) {
34754
+ return answerIds.map(function (answerId) {
34755
+ return answers.find(function (answer) {
34756
+ return answer.id === answerId;
34970
34757
  });
34758
+ });
34759
+ };
34760
+ var onKeyPress = function onKeyPress(e) {
34761
+ switch (e.key) {
34762
+ case 'ArrowDown':
34763
+ // select next answer, if any.
34764
+ // if no next answer, select first answer
34765
+ // const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(
34766
+ // (answer) => answer?.id === currentAnswer!.id + 1
34767
+ // );
34768
+ var nextAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34769
+ return (answer == null ? void 0 : answer.id) === currentAnswer.id + 1;
34770
+ });
34771
+ var nextAnswerID = currentQuestion.answerIds[nextAnswerIndex];
34772
+ var nextAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34773
+ return (answer == null ? void 0 : answer.id) === nextAnswerID;
34774
+ });
34775
+ setCurrentAnswer(nextAnswer || onGetFirstAnswer());
34776
+ break;
34777
+ case 'ArrowUp':
34778
+ // select previous answer, if any.
34779
+ // if no previous answer, select last answer
34780
+ var previousAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34781
+ return (answer == null ? void 0 : answer.id) === currentAnswer.id - 1;
34782
+ });
34783
+ var previousAnswerID = currentQuestion.answerIds && currentQuestion.answerIds[previousAnswerIndex];
34784
+ var previousAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34785
+ return (answer == null ? void 0 : answer.id) === previousAnswerID;
34786
+ });
34787
+ if (previousAnswer) {
34788
+ setCurrentAnswer(previousAnswer);
34789
+ } else {
34790
+ setCurrentAnswer(onGetAnswers(currentQuestion.answerIds).pop());
34791
+ }
34792
+ break;
34793
+ case 'Enter':
34794
+ setCanShowAnswers(false);
34795
+ if (!(currentAnswer != null && currentAnswer.nextQuestionId)) {
34796
+ onClose();
34797
+ return;
34798
+ } else {
34799
+ setCurrentQuestion(questions.find(function (question) {
34800
+ return question.id === currentAnswer.nextQuestionId;
34801
+ }));
34802
+ }
34803
+ break;
34971
34804
  }
34972
- })));
34973
- };
34974
- var ItemsContainer = /*#__PURE__*/styled.div.withConfig({
34975
- displayName: "ItemContainer__ItemsContainer",
34976
- componentId: "sc-15y5p9l-0"
34977
- })(["max-width:280px;display:flex;justify-content:center;flex-wrap:wrap;"]);
34978
- var QuantitySelectorContainer = /*#__PURE__*/styled.div.withConfig({
34979
- displayName: "ItemContainer__QuantitySelectorContainer",
34980
- componentId: "sc-15y5p9l-1"
34981
- })(["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);"]);
34982
-
34983
- var ItemSelector = function ItemSelector(_ref) {
34984
- var atlasIMG = _ref.atlasIMG,
34985
- atlasJSON = _ref.atlasJSON,
34986
- options = _ref.options,
34987
- onClose = _ref.onClose,
34988
- onSelect = _ref.onSelect;
34989
- var _useState = useState(),
34990
- selectedValue = _useState[0],
34991
- setSelectedValue = _useState[1];
34992
- var handleClick = function handleClick() {
34993
- var element = document.querySelector("input[name='test']:checked");
34994
- var elementValue = element.value;
34995
- setSelectedValue(elementValue);
34996
34805
  };
34997
- useEffect(function () {
34998
- if (selectedValue) {
34999
- onSelect(selectedValue);
34806
+ useEventListener('keydown', onKeyPress);
34807
+ var onAnswerClick = function onAnswerClick(answer) {
34808
+ setCanShowAnswers(false);
34809
+ if (answer.nextQuestionId) {
34810
+ // if there is a next question, go to it
34811
+ setCurrentQuestion(questions.find(function (question) {
34812
+ return question.id === answer.nextQuestionId;
34813
+ }));
34814
+ } else {
34815
+ // else, finish dialog!
34816
+ onClose();
35000
34817
  }
35001
- }, [selectedValue]);
35002
- return React.createElement(DraggableContainer, {
35003
- type: RPGUIContainerTypes.Framed,
35004
- width: "500px",
35005
- cancelDrag: ".equipment-container-body .arrow-selector",
35006
- onCloseButton: function onCloseButton() {
35007
- if (onClose) {
35008
- onClose();
35009
- }
34818
+ };
34819
+ var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
34820
+ var answerIds = currentQuestion.answerIds;
34821
+ if (!answerIds) {
34822
+ return null;
35010
34823
  }
35011
- }, React.createElement("div", {
35012
- style: {
35013
- width: '100%'
34824
+ var answers = onGetAnswers(answerIds);
34825
+ if (!answers) {
34826
+ return null;
35014
34827
  }
35015
- }, React.createElement(Title$2, null, 'Harvesting instruments'), React.createElement(Subtitle$1, null, 'Use the tool, you need it'), React.createElement("hr", {
35016
- className: "golden"
35017
- })), React.createElement(RadioInputScroller$1, null, options == null ? void 0 : options.map(function (option, index) {
35018
- return React.createElement(RadioOptionsWrapper$1, {
35019
- key: index
35020
- }, React.createElement(SpriteAtlasWrapper$1, null, React.createElement(SpriteFromAtlas, {
35021
- atlasIMG: atlasIMG,
35022
- atlasJSON: atlasJSON,
35023
- spriteKey: option.imageKey,
35024
- imgScale: 3
35025
- })), React.createElement("div", null, React.createElement("input", {
35026
- className: "rpgui-radio",
35027
- type: "radio",
35028
- value: option.name,
35029
- name: "test"
35030
- }), React.createElement("label", {
35031
- onClick: handleClick,
35032
- style: {
35033
- display: 'flex',
35034
- alignItems: 'center'
34828
+ return answers.map(function (answer) {
34829
+ var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
34830
+ var selectedColor = isSelected ? 'yellow' : 'white';
34831
+ if (answer) {
34832
+ return React.createElement(AnswerRow, {
34833
+ key: "answer_" + answer.id
34834
+ }, React.createElement(AnswerSelectedIcon, {
34835
+ color: selectedColor
34836
+ }, isSelected ? 'X' : null), React.createElement(Answer, {
34837
+ key: answer.id,
34838
+ onClick: function onClick() {
34839
+ return onAnswerClick(answer);
34840
+ },
34841
+ color: selectedColor
34842
+ }, answer.text));
35035
34843
  }
35036
- }, option.name, " ", React.createElement("br", null), option.description)));
35037
- })), React.createElement(ButtonWrapper$1, null, React.createElement(Button, {
35038
- buttonType: ButtonTypes.RPGUIButton,
35039
- onClick: onClose
35040
- }, "Cancel"), React.createElement(Button, {
35041
- buttonType: ButtonTypes.RPGUIButton
35042
- }, "Select")));
35043
- };
35044
- var Title$2 = /*#__PURE__*/styled.h1.withConfig({
35045
- displayName: "ItemSelector__Title",
35046
- componentId: "sc-gptoxp-0"
35047
- })(["font-size:0.6rem;color:yellow !important;"]);
35048
- var Subtitle$1 = /*#__PURE__*/styled.h1.withConfig({
35049
- displayName: "ItemSelector__Subtitle",
35050
- componentId: "sc-gptoxp-1"
35051
- })(["font-size:0.4rem;color:yellow !important;"]);
35052
- var RadioInputScroller$1 = /*#__PURE__*/styled.div.withConfig({
35053
- displayName: "ItemSelector__RadioInputScroller",
35054
- componentId: "sc-gptoxp-2"
35055
- })(["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;"]);
35056
- var SpriteAtlasWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35057
- displayName: "ItemSelector__SpriteAtlasWrapper",
35058
- componentId: "sc-gptoxp-3"
35059
- })(["margin-right:40px;"]);
35060
- var RadioOptionsWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35061
- displayName: "ItemSelector__RadioOptionsWrapper",
35062
- componentId: "sc-gptoxp-4"
35063
- })(["display:flex;align-items:stretch;margin-bottom:40px;"]);
35064
- var ButtonWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35065
- displayName: "ItemSelector__ButtonWrapper",
35066
- componentId: "sc-gptoxp-5"
35067
- })(["display:flex;justify-content:space-around;padding-top:20px;width:100%;"]);
35068
-
35069
- var ListMenu = function ListMenu(_ref) {
35070
- var options = _ref.options,
35071
- onSelected = _ref.onSelected,
35072
- x = _ref.x,
35073
- y = _ref.y;
35074
- return React.createElement(Container$f, {
35075
- x: x,
35076
- y: y
35077
- }, React.createElement("ul", {
35078
- className: "rpgui-list-imp",
35079
- style: {
35080
- overflow: 'hidden'
34844
+ return null;
34845
+ });
34846
+ };
34847
+ return React.createElement(Container$d, null, React.createElement(QuestionContainer, null, React.createElement(DynamicText, {
34848
+ text: currentQuestion.text,
34849
+ onStart: function onStart() {
34850
+ return setCanShowAnswers(false);
34851
+ },
34852
+ onFinish: function onFinish() {
34853
+ return setCanShowAnswers(true);
35081
34854
  }
35082
- }, options.map(function (params, index) {
35083
- return React.createElement(ListElement$1, {
35084
- key: (params == null ? void 0 : params.id) || index,
35085
- onClick: function onClick() {
35086
- onSelected(params == null ? void 0 : params.id);
35087
- }
35088
- }, (params == null ? void 0 : params.text) || 'No text');
35089
- })));
34855
+ })), canShowAnswers && React.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
35090
34856
  };
35091
- var Container$f = /*#__PURE__*/styled.div.withConfig({
35092
- displayName: "ListMenu__Container",
35093
- componentId: "sc-i9097t-0"
35094
- })(["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) {
35095
- return props.y || 0;
35096
- }, function (props) {
35097
- return props.x || 0;
35098
- }, uiFonts.size.xsmall);
35099
- var ListElement$1 = /*#__PURE__*/styled.li.withConfig({
35100
- displayName: "ListMenu__ListElement",
35101
- componentId: "sc-i9097t-1"
35102
- })(["margin-right:0.5rem;"]);
34857
+ var Container$d = /*#__PURE__*/styled.div.withConfig({
34858
+ displayName: "QuestionDialog__Container",
34859
+ componentId: "sc-bxc5u0-0"
34860
+ })(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
34861
+ var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
34862
+ displayName: "QuestionDialog__QuestionContainer",
34863
+ componentId: "sc-bxc5u0-1"
34864
+ })(["flex:100%;width:100%;"]);
34865
+ var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
34866
+ displayName: "QuestionDialog__AnswersContainer",
34867
+ componentId: "sc-bxc5u0-2"
34868
+ })(["flex:100%;"]);
34869
+ var Answer = /*#__PURE__*/styled.p.withConfig({
34870
+ displayName: "QuestionDialog__Answer",
34871
+ componentId: "sc-bxc5u0-3"
34872
+ })(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
34873
+ return props.color;
34874
+ });
34875
+ var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
34876
+ displayName: "QuestionDialog__AnswerSelectedIcon",
34877
+ componentId: "sc-bxc5u0-4"
34878
+ })(["flex:5% 0 0;color:", " !important;"], function (props) {
34879
+ return props.color;
34880
+ });
34881
+ var AnswerRow = /*#__PURE__*/styled.div.withConfig({
34882
+ displayName: "QuestionDialog__AnswerRow",
34883
+ componentId: "sc-bxc5u0-5"
34884
+ })(["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;}"]);
35103
34885
 
35104
34886
  var ProgressBar = function ProgressBar(_ref) {
35105
34887
  var max = _ref.max,
@@ -35118,7 +34900,7 @@ var ProgressBar = function ProgressBar(_ref) {
35118
34900
  }
35119
34901
  return value * 100 / max;
35120
34902
  };
35121
- return React.createElement(Container$g, {
34903
+ return React.createElement(Container$e, {
35122
34904
  className: "rpgui-progress",
35123
34905
  "data-value": calculatePercentageValue(max, value) / 100,
35124
34906
  "data-rpguitype": "progress",
@@ -35147,7 +34929,7 @@ var TextOverlay$1 = /*#__PURE__*/styled.div.withConfig({
35147
34929
  displayName: "ProgressBar__TextOverlay",
35148
34930
  componentId: "sc-qa6fzh-1"
35149
34931
  })(["width:100%;position:relative;"]);
35150
- var Container$g = /*#__PURE__*/styled.div.withConfig({
34932
+ var Container$e = /*#__PURE__*/styled.div.withConfig({
35151
34933
  displayName: "ProgressBar__Container",
35152
34934
  componentId: "sc-qa6fzh-2"
35153
34935
  })(["display:flex;flex-direction:column;min-width:", "px;width:", "%;justify-content:start;align-items:flex-start;", ""], function (props) {
@@ -35158,7 +34940,7 @@ var Container$g = /*#__PURE__*/styled.div.withConfig({
35158
34940
  return props.style;
35159
34941
  });
35160
34942
 
35161
- var img$9 = '';
34943
+ var img$8 = '';
35162
34944
 
35163
34945
  var QuestInfo = function QuestInfo(_ref) {
35164
34946
  var quests = _ref.quests,
@@ -35202,7 +34984,7 @@ var QuestInfo = function QuestInfo(_ref) {
35202
34984
  }), React.createElement(QuestContainer, null, React.createElement(TitleContainer$1, {
35203
34985
  className: "drag-handler"
35204
34986
  }, React.createElement(Title$3, null, React.createElement(Thumbnail, {
35205
- src: quests[currentIndex].thumbnail || img$9
34987
+ src: quests[currentIndex].thumbnail || img$8
35206
34988
  }), quests[currentIndex].title), React.createElement(QuestSplitDiv, null, React.createElement("hr", {
35207
34989
  className: "golden"
35208
34990
  }))), React.createElement(Content, null, React.createElement("p", null, quests[currentIndex].description)), React.createElement(QuestColumn, {
@@ -35221,7 +35003,7 @@ var QuestInfo = function QuestInfo(_ref) {
35221
35003
  })))) : React.createElement(QuestsContainer, null, React.createElement(QuestContainer, null, React.createElement(TitleContainer$1, {
35222
35004
  className: "drag-handler"
35223
35005
  }, React.createElement(Title$3, null, React.createElement(Thumbnail, {
35224
- src: quests[0].thumbnail || img$9
35006
+ src: quests[0].thumbnail || img$8
35225
35007
  }), quests[0].title), React.createElement(QuestSplitDiv, null, React.createElement("hr", {
35226
35008
  className: "golden"
35227
35009
  }))), React.createElement(Content, null, React.createElement("p", null, quests[0].description)), React.createElement(QuestColumn, {
@@ -35370,7 +35152,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
35370
35152
  bgColor = _ref$bgColor === void 0 ? 'red' : _ref$bgColor,
35371
35153
  _ref$margin = _ref.margin,
35372
35154
  margin = _ref$margin === void 0 ? 20 : _ref$margin;
35373
- return React.createElement(Container$h, {
35155
+ return React.createElement(Container$f, {
35374
35156
  className: "simple-progress-bar"
35375
35157
  }, React.createElement(ProgressBarContainer, {
35376
35158
  margin: margin
@@ -35379,7 +35161,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
35379
35161
  bgColor: bgColor
35380
35162
  }))));
35381
35163
  };
35382
- var Container$h = /*#__PURE__*/styled.div.withConfig({
35164
+ var Container$f = /*#__PURE__*/styled.div.withConfig({
35383
35165
  displayName: "SimpleProgressBar__Container",
35384
35166
  componentId: "sc-mbeil3-0"
35385
35167
  })(["display:flex;justify-content:center;align-items:center;width:100%;"]);
@@ -35580,7 +35362,7 @@ var Spell = function Spell(_ref) {
35580
35362
  isSettingShortcut = _ref.isSettingShortcut,
35581
35363
  minMagicLevelRequired = _ref.minMagicLevelRequired;
35582
35364
  var disabled = isSettingShortcut ? charMagicLevel < minMagicLevelRequired : manaCost > charMana || charMagicLevel < minMagicLevelRequired;
35583
- return React.createElement(Container$i, {
35365
+ return React.createElement(Container$g, {
35584
35366
  disabled: disabled,
35585
35367
  onClick: onClick == null ? void 0 : onClick.bind(null, spellKey),
35586
35368
  isSettingShortcut: isSettingShortcut && !disabled,
@@ -35593,7 +35375,7 @@ var Spell = function Spell(_ref) {
35593
35375
  className: "mana"
35594
35376
  }, manaCost)));
35595
35377
  };
35596
- var Container$i = /*#__PURE__*/styled.button.withConfig({
35378
+ var Container$g = /*#__PURE__*/styled.button.withConfig({
35597
35379
  displayName: "Spell__Container",
35598
35380
  componentId: "sc-j96fa2-0"
35599
35381
  })(["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) {
@@ -35713,7 +35495,7 @@ var Spellbook = function Spellbook(_ref) {
35713
35495
  width: "inherit",
35714
35496
  height: "inherit",
35715
35497
  cancelDrag: "#spellbook-search, #shortcuts_list, .spell"
35716
- }, React.createElement(Container$j, null, React.createElement(Title$6, null, "Learned Spells"), React.createElement(SpellbookShortcuts, {
35498
+ }, React.createElement(Container$h, null, React.createElement(Title$6, null, "Learned Spells"), React.createElement(SpellbookShortcuts, {
35717
35499
  setSettingShortcutIndex: setSettingShortcutIndex,
35718
35500
  settingShortcutIndex: settingShortcutIndex,
35719
35501
  shortcuts: spellShortcuts,
@@ -35743,7 +35525,7 @@ var Title$6 = /*#__PURE__*/styled.h1.withConfig({
35743
35525
  displayName: "Spellbook__Title",
35744
35526
  componentId: "sc-r02nfq-0"
35745
35527
  })(["font-size:", " !important;margin-bottom:0 !important;"], uiFonts.size.large);
35746
- var Container$j = /*#__PURE__*/styled.div.withConfig({
35528
+ var Container$h = /*#__PURE__*/styled.div.withConfig({
35747
35529
  displayName: "Spellbook__Container",
35748
35530
  componentId: "sc-r02nfq-1"
35749
35531
  })(["width:100%;height:100%;color:white;display:flex;flex-direction:column;"]);
@@ -35757,16 +35539,16 @@ var TextArea = function TextArea(_ref) {
35757
35539
  return React.createElement("textarea", Object.assign({}, props));
35758
35540
  };
35759
35541
 
35760
- var img$a = '';
35542
+ var img$9 = '';
35761
35543
 
35762
- var img$b = '';
35544
+ var img$a = '';
35763
35545
 
35764
- var img$c = '';
35546
+ var img$b = '';
35765
35547
 
35766
35548
  var DayNightPeriod = function DayNightPeriod(_ref) {
35767
35549
  var _periodOfDaySrcFiles;
35768
35550
  var periodOfDay = _ref.periodOfDay;
35769
- var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[PeriodOfDay.Morning] = img$b, _periodOfDaySrcFiles[PeriodOfDay.Afternoon] = img$a, _periodOfDaySrcFiles[PeriodOfDay.Night] = img$c, _periodOfDaySrcFiles);
35551
+ var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[PeriodOfDay.Morning] = img$a, _periodOfDaySrcFiles[PeriodOfDay.Afternoon] = img$9, _periodOfDaySrcFiles[PeriodOfDay.Night] = img$b, _periodOfDaySrcFiles);
35770
35552
  return React.createElement(GifContainer, null, React.createElement("img", {
35771
35553
  src: periodOfDaySrcFiles[periodOfDay]
35772
35554
  }));
@@ -35776,7 +35558,7 @@ var GifContainer = /*#__PURE__*/styled.div.withConfig({
35776
35558
  componentId: "sc-10t97fw-0"
35777
35559
  })(["width:100%;img{width:67%;}"]);
35778
35560
 
35779
- var img$d = '';
35561
+ var img$c = '';
35780
35562
 
35781
35563
  var TimeWidget = function TimeWidget(_ref) {
35782
35564
  var onClose = _ref.onClose,
@@ -35791,7 +35573,7 @@ var TimeWidget = function TimeWidget(_ref) {
35791
35573
  var WidgetContainer = /*#__PURE__*/styled.div.withConfig({
35792
35574
  displayName: "TimeWidget__WidgetContainer",
35793
35575
  componentId: "sc-1ja236h-0"
35794
- })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$d);
35576
+ })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$c);
35795
35577
  var Time = /*#__PURE__*/styled.div.withConfig({
35796
35578
  displayName: "TimeWidget__Time",
35797
35579
  componentId: "sc-1ja236h-1"
@@ -36041,16 +35823,230 @@ var Truncate = function Truncate(_ref) {
36041
35823
  var _ref$maxLines = _ref.maxLines,
36042
35824
  maxLines = _ref$maxLines === void 0 ? 1 : _ref$maxLines,
36043
35825
  children = _ref.children;
36044
- return React.createElement(Container$k, {
35826
+ return React.createElement(Container$i, {
36045
35827
  maxLines: maxLines
36046
35828
  }, children);
36047
35829
  };
36048
- var Container$k = /*#__PURE__*/styled.div.withConfig({
35830
+ var Container$i = /*#__PURE__*/styled.div.withConfig({
36049
35831
  displayName: "Truncate__Container",
36050
35832
  componentId: "sc-6x00qb-0"
36051
35833
  })(["display:-webkit-box;max-width:100%;max-height:100%;-webkit-line-clamp:", ";-webkit-box-orient:vertical;overflow:hidden;"], function (props) {
36052
35834
  return props.maxLines;
36053
35835
  });
36054
35836
 
35837
+ var IS_MOBILE_OR_TABLET = /*#__PURE__*/isMobileOrTablet();
35838
+
35839
+ var chunkString = function chunkString(str, length) {
35840
+ return str.match(new RegExp('.{1,' + length + '}', 'g'));
35841
+ };
35842
+
35843
+ var img$d = '';
35844
+
35845
+ var NPCDialogText = function NPCDialogText(_ref) {
35846
+ var text = _ref.text,
35847
+ onClose = _ref.onClose,
35848
+ onEndStep = _ref.onEndStep,
35849
+ onStartStep = _ref.onStartStep,
35850
+ type = _ref.type;
35851
+ var windowSize = useRef([window.innerWidth, window.innerHeight]);
35852
+ function maxCharacters(width) {
35853
+ // Set the font size to 16 pixels
35854
+ var fontSize = 11.2;
35855
+ // Calculate the number of characters that can fit in one line
35856
+ var charactersPerLine = Math.floor(width / 2 / fontSize);
35857
+ // Calculate the number of lines that can fit in the div
35858
+ var linesPerDiv = Math.floor(180 / fontSize);
35859
+ // Calculate the maximum number of characters that can fit in the div
35860
+ var maxCharacters = charactersPerLine * linesPerDiv;
35861
+ // Return the maximum number of characters
35862
+ return Math.round(maxCharacters / 5);
35863
+ }
35864
+ var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
35865
+ var _useState = useState(0),
35866
+ chunkIndex = _useState[0],
35867
+ setChunkIndex = _useState[1];
35868
+ var onHandleSpacePress = function onHandleSpacePress(event) {
35869
+ if (event.code === 'Space') {
35870
+ goToNextStep();
35871
+ }
35872
+ };
35873
+ var goToNextStep = function goToNextStep() {
35874
+ var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
35875
+ if (hasNextChunk) {
35876
+ setChunkIndex(function (prev) {
35877
+ return prev + 1;
35878
+ });
35879
+ } else {
35880
+ // if there's no more text chunks, close the dialog
35881
+ onClose();
35882
+ }
35883
+ };
35884
+ useEffect(function () {
35885
+ document.addEventListener('keydown', onHandleSpacePress);
35886
+ return function () {
35887
+ return document.removeEventListener('keydown', onHandleSpacePress);
35888
+ };
35889
+ }, [chunkIndex]);
35890
+ var _useState2 = useState(false),
35891
+ showGoNextIndicator = _useState2[0],
35892
+ setShowGoNextIndicator = _useState2[1];
35893
+ return React.createElement(Container$j, null, React.createElement(DynamicText, {
35894
+ text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
35895
+ onFinish: function onFinish() {
35896
+ setShowGoNextIndicator(true);
35897
+ onEndStep && onEndStep();
35898
+ },
35899
+ onStart: function onStart() {
35900
+ setShowGoNextIndicator(false);
35901
+ onStartStep && onStartStep();
35902
+ }
35903
+ }), showGoNextIndicator && React.createElement(PressSpaceIndicator$1, {
35904
+ right: type === NPCDialogType.TextOnly ? '1rem' : '10.5rem',
35905
+ src: IS_MOBILE_OR_TABLET ? img$d : img$7,
35906
+ onClick: function onClick() {
35907
+ goToNextStep();
35908
+ }
35909
+ }));
35910
+ };
35911
+ var Container$j = /*#__PURE__*/styled.div.withConfig({
35912
+ displayName: "NPCDialogText__Container",
35913
+ componentId: "sc-1cxkdh9-0"
35914
+ })([""]);
35915
+ var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
35916
+ displayName: "NPCDialogText__PressSpaceIndicator",
35917
+ componentId: "sc-1cxkdh9-1"
35918
+ })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
35919
+ var right = _ref2.right;
35920
+ return right;
35921
+ });
35922
+
35923
+ var NPCDialogType;
35924
+ (function (NPCDialogType) {
35925
+ NPCDialogType["TextOnly"] = "TextOnly";
35926
+ NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
35927
+ })(NPCDialogType || (NPCDialogType = {}));
35928
+ var NPCDialog = function NPCDialog(_ref) {
35929
+ var text = _ref.text,
35930
+ type = _ref.type,
35931
+ _onClose = _ref.onClose,
35932
+ imagePath = _ref.imagePath,
35933
+ _ref$isQuestionDialog = _ref.isQuestionDialog,
35934
+ isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
35935
+ questions = _ref.questions,
35936
+ answers = _ref.answers;
35937
+ return React.createElement(RPGUIContainer, {
35938
+ type: RPGUIContainerTypes.FramedGold,
35939
+ width: isQuestionDialog ? '600px' : '80%',
35940
+ height: '180px'
35941
+ }, isQuestionDialog && questions && answers ? React.createElement(React.Fragment, null, React.createElement(TextContainer$2, {
35942
+ flex: type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'
35943
+ }, React.createElement(QuestionDialog, {
35944
+ questions: questions,
35945
+ answers: answers,
35946
+ onClose: function onClose() {
35947
+ if (_onClose) {
35948
+ _onClose();
35949
+ }
35950
+ }
35951
+ })), type === NPCDialogType.TextAndThumbnail && React.createElement(ThumbnailContainer$1, null, React.createElement(NPCThumbnail$1, {
35952
+ src: imagePath || img$6
35953
+ }))) : React.createElement(React.Fragment, null, React.createElement(Container$k, null, React.createElement(TextContainer$2, {
35954
+ flex: type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'
35955
+ }, React.createElement(NPCDialogText, {
35956
+ type: type,
35957
+ text: text || 'No text provided.',
35958
+ onClose: function onClose() {
35959
+ if (_onClose) {
35960
+ _onClose();
35961
+ }
35962
+ }
35963
+ })), type === NPCDialogType.TextAndThumbnail && React.createElement(ThumbnailContainer$1, null, React.createElement(NPCThumbnail$1, {
35964
+ src: imagePath || img$6
35965
+ })))));
35966
+ };
35967
+ var Container$k = /*#__PURE__*/styled.div.withConfig({
35968
+ displayName: "NPCDialog__Container",
35969
+ componentId: "sc-1b4aw74-0"
35970
+ })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
35971
+ var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
35972
+ displayName: "NPCDialog__TextContainer",
35973
+ componentId: "sc-1b4aw74-1"
35974
+ })(["flex:", " 0 0;width:355px;"], function (_ref2) {
35975
+ var flex = _ref2.flex;
35976
+ return flex;
35977
+ });
35978
+ var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
35979
+ displayName: "NPCDialog__ThumbnailContainer",
35980
+ componentId: "sc-1b4aw74-2"
35981
+ })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
35982
+ var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
35983
+ displayName: "NPCDialog__NPCThumbnail",
35984
+ componentId: "sc-1b4aw74-3"
35985
+ })(["image-rendering:pixelated;height:128px;width:128px;"]);
35986
+
35987
+ var HistoryDialog = function HistoryDialog(_ref) {
35988
+ var backgroundImgPath = _ref.backgroundImgPath,
35989
+ fullCoverBackground = _ref.fullCoverBackground,
35990
+ questions = _ref.questions,
35991
+ answers = _ref.answers,
35992
+ text = _ref.text,
35993
+ imagePath = _ref.imagePath,
35994
+ textAndTypeArray = _ref.textAndTypeArray,
35995
+ onClose = _ref.onClose;
35996
+ var _useState = useState(0),
35997
+ img = _useState[0],
35998
+ setImage = _useState[1];
35999
+ var onHandleSpacePress = function onHandleSpacePress(event) {
36000
+ if (event.code === 'Space') {
36001
+ if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
36002
+ setImage(function (prev) {
36003
+ return prev + 1;
36004
+ });
36005
+ } else {
36006
+ // if there's no more text chunks, close the dialog
36007
+ onClose();
36008
+ }
36009
+ }
36010
+ };
36011
+ useEffect(function () {
36012
+ document.addEventListener('keydown', onHandleSpacePress);
36013
+ return function () {
36014
+ return document.removeEventListener('keydown', onHandleSpacePress);
36015
+ };
36016
+ }, [backgroundImgPath]);
36017
+ return React.createElement(BackgroundContainer, {
36018
+ imgPath: backgroundImgPath[img],
36019
+ fullImg: fullCoverBackground
36020
+ }, React.createElement(DialogContainer, null, textAndTypeArray ? React.createElement(NPCMultiDialog, {
36021
+ textAndTypeArray: textAndTypeArray,
36022
+ onClose: onClose
36023
+ }) : questions && answers ? React.createElement(QuestionDialog, {
36024
+ questions: questions,
36025
+ answers: answers,
36026
+ onClose: onClose
36027
+ }) : text && imagePath ? React.createElement(NPCDialog, {
36028
+ text: text,
36029
+ imagePath: imagePath,
36030
+ onClose: onClose,
36031
+ type: NPCDialogType.TextAndThumbnail
36032
+ }) : React.createElement(NPCDialog, {
36033
+ text: text,
36034
+ onClose: onClose,
36035
+ type: NPCDialogType.TextOnly
36036
+ })));
36037
+ };
36038
+ var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
36039
+ displayName: "HistoryDialog__BackgroundContainer",
36040
+ componentId: "sc-u6oe75-0"
36041
+ })(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
36042
+ return props.imgPath;
36043
+ }, function (props) {
36044
+ return props.imgPath ? 'cover' : 'auto';
36045
+ });
36046
+ var DialogContainer = /*#__PURE__*/styled.div.withConfig({
36047
+ displayName: "HistoryDialog__DialogContainer",
36048
+ componentId: "sc-u6oe75-1"
36049
+ })(["display:flex;justify-content:center;padding-top:200px;"]);
36050
+
36055
36051
  export { Button, ButtonTypes, CharacterSelection, Chat, ChatDeprecated, CheckButton, CircularController, CraftBook, DraggableContainer, Dropdown, DropdownSelectorContainer, DynamicText, EquipmentSet, ErrorBoundary, HistoryDialog, ImgSide, Input, InputRadio, ItemContainer$1 as ItemContainer, ItemSelector, ItemSlot, ListMenu, NPCDialog, NPCDialogType, NPCMultiDialog, ProgressBar, PropertySelect, QuestInfo, QuestList, QuestionDialog, QuickSpells, RPGUIContainer, RPGUIContainerTypes, RPGUIRoot, RangeSlider, RangeSliderType, SkillProgressBar, SkillsContainer, SpellShortcut, Spellbook, SpriteFromAtlas, TextArea, TimeWidget, TradingMenu, Truncate, _RPGUI, useEventListener };
36056
36052
  //# sourceMappingURL=long-bow.esm.js.map