@rpg-engine/long-bow 0.3.47 → 0.3.49

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