@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
@@ -1,6 +1,6 @@
1
1
  import React, { Component, useState, useEffect, useRef, useMemo, Fragment } from 'react';
2
2
  import styled from 'styled-components';
3
- import { GRID_WIDTH, GRID_HEIGHT, ItemSubType, ItemContainerType, ItemType, ItemSocketEventsDisplayLabels, ActionsForInventory, ActionsForEquipmentSet, ActionsForLoot, ActionsForMapContainer, ItemRarities, getItemTextureKeyPath, ItemSlotType, getSPForLevel, PeriodOfDay, isMobileOrTablet } from '@rpg-engine/shared';
3
+ import { GRID_WIDTH, GRID_HEIGHT, ItemSubType, ItemContainerType, ItemType, ItemSocketEventsDisplayLabels, ActionsForInventory, ActionsForEquipmentSet, ActionsForLoot, ActionsForMapContainer, ItemRarities, getItemTextureKeyPath, ItemSlotType, isMobileOrTablet, getSPForLevel, PeriodOfDay } from '@rpg-engine/shared';
4
4
  import dayjs from 'dayjs';
5
5
  import { ErrorBoundary as ErrorBoundary$1 } from 'react-error-boundary';
6
6
  import { RxPaperPlane } from 'react-icons/rx';
@@ -9,7 +9,6 @@ import { v4 } from 'uuid';
9
9
  import { observer } from 'mobx-react-lite';
10
10
  import 'rpgui/rpgui.min.css';
11
11
  import 'rpgui/rpgui.min.js';
12
- import _ from 'lodash-es';
13
12
  import capitalize from 'lodash-es/capitalize';
14
13
 
15
14
  function _extends() {
@@ -32785,7 +32784,8 @@ var Chat = function Chat(_ref) {
32785
32784
  autoComplete: "off",
32786
32785
  onFocus: onFocus,
32787
32786
  onBlur: onBlur,
32788
- onTouchStart: onFocus
32787
+ onTouchStart: onFocus,
32788
+ autoFocus: true
32789
32789
  })), React.createElement(Column, {
32790
32790
  justifyContent: "flex-end"
32791
32791
  }, React.createElement(Button$1, {
@@ -33445,7 +33445,14 @@ var CraftBook = function CraftBook(_ref) {
33445
33445
  spriteKey: option.texturePath,
33446
33446
  imgScale: 3,
33447
33447
  grayScale: !option.canCraft
33448
- })), React.createElement("div", null, React.createElement("input", {
33448
+ })), React.createElement("div", null, React.createElement("div", {
33449
+ onClick: function onClick() {
33450
+ return handleClick(option.key);
33451
+ },
33452
+ onTouchStart: function onTouchStart() {
33453
+ return handleClick(option.key);
33454
+ }
33455
+ }, React.createElement("input", {
33449
33456
  className: "rpgui-radio",
33450
33457
  type: "radio",
33451
33458
  value: option.name,
@@ -33481,7 +33488,7 @@ var CraftBook = function CraftBook(_ref) {
33481
33488
  index: index
33482
33489
  });
33483
33490
  }
33484
- }, modifyString(option.name)), isShown && isShown.index === index && option.ingredients.map(function (option, index) {
33491
+ }, modifyString(option.name))), isShown && isShown.index === index && option.ingredients.map(function (option, index) {
33485
33492
  return React.createElement(Recipes, {
33486
33493
  key: index
33487
33494
  }, React.createElement(SpriteFromAtlas, {
@@ -34140,6 +34147,546 @@ var EquipmentColumn = /*#__PURE__*/styled.div.withConfig({
34140
34147
  componentId: "sc-1wuddg2-1"
34141
34148
  })(["display:flex;justify-content:center;flex-wrap:wrap;flex-direction:column;touch-action:none;"]);
34142
34149
 
34150
+ var IS_MOBILE_OR_TABLET = /*#__PURE__*/isMobileOrTablet();
34151
+
34152
+ var chunkString = function chunkString(str, length) {
34153
+ return str.match(new RegExp('.{1,' + length + '}', 'g'));
34154
+ };
34155
+
34156
+ var DynamicText = function DynamicText(_ref) {
34157
+ var text = _ref.text,
34158
+ onFinish = _ref.onFinish,
34159
+ onStart = _ref.onStart;
34160
+ var _useState = useState(''),
34161
+ textState = _useState[0],
34162
+ setTextState = _useState[1];
34163
+ useEffect(function () {
34164
+ var i = 0;
34165
+ var interval = setInterval(function () {
34166
+ // on every interval, show one more character
34167
+ if (i === 0) {
34168
+ if (onStart) {
34169
+ onStart();
34170
+ }
34171
+ }
34172
+ if (i < text.length) {
34173
+ setTextState(text.substring(0, i + 1));
34174
+ i++;
34175
+ } else {
34176
+ clearInterval(interval);
34177
+ if (onFinish) {
34178
+ onFinish();
34179
+ }
34180
+ }
34181
+ }, 50);
34182
+ return function () {
34183
+ clearInterval(interval);
34184
+ };
34185
+ }, [text]);
34186
+ return React.createElement(TextContainer, null, textState);
34187
+ };
34188
+ var TextContainer = /*#__PURE__*/styled.p.withConfig({
34189
+ displayName: "DynamicText__TextContainer",
34190
+ componentId: "sc-1ggl9nd-0"
34191
+ })(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]);
34192
+
34193
+ var img$6 = '';
34194
+
34195
+ var img$7 = '';
34196
+
34197
+ var NPCDialogText = function NPCDialogText(_ref) {
34198
+ var text = _ref.text,
34199
+ onClose = _ref.onClose,
34200
+ onEndStep = _ref.onEndStep,
34201
+ onStartStep = _ref.onStartStep,
34202
+ type = _ref.type;
34203
+ var windowSize = useRef([window.innerWidth, window.innerHeight]);
34204
+ function maxCharacters(width) {
34205
+ // Set the font size to 16 pixels
34206
+ var fontSize = 11.2;
34207
+ // Calculate the number of characters that can fit in one line
34208
+ var charactersPerLine = Math.floor(width / 2 / fontSize);
34209
+ // Calculate the number of lines that can fit in the div
34210
+ var linesPerDiv = Math.floor(180 / fontSize);
34211
+ // Calculate the maximum number of characters that can fit in the div
34212
+ var maxCharacters = charactersPerLine * linesPerDiv;
34213
+ // Return the maximum number of characters
34214
+ return Math.round(maxCharacters / 5);
34215
+ }
34216
+ var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
34217
+ var _useState = useState(0),
34218
+ chunkIndex = _useState[0],
34219
+ setChunkIndex = _useState[1];
34220
+ var onHandleSpacePress = function onHandleSpacePress(event) {
34221
+ if (event.code === 'Space') {
34222
+ goToNextStep();
34223
+ }
34224
+ };
34225
+ var goToNextStep = function goToNextStep() {
34226
+ var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
34227
+ if (hasNextChunk) {
34228
+ setChunkIndex(function (prev) {
34229
+ return prev + 1;
34230
+ });
34231
+ } else {
34232
+ // if there's no more text chunks, close the dialog
34233
+ onClose();
34234
+ }
34235
+ };
34236
+ useEffect(function () {
34237
+ document.addEventListener('keydown', onHandleSpacePress);
34238
+ return function () {
34239
+ return document.removeEventListener('keydown', onHandleSpacePress);
34240
+ };
34241
+ }, [chunkIndex]);
34242
+ var _useState2 = useState(false),
34243
+ showGoNextIndicator = _useState2[0],
34244
+ setShowGoNextIndicator = _useState2[1];
34245
+ return React.createElement(Container$b, null, React.createElement(DynamicText, {
34246
+ text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
34247
+ onFinish: function onFinish() {
34248
+ setShowGoNextIndicator(true);
34249
+ onEndStep && onEndStep();
34250
+ },
34251
+ onStart: function onStart() {
34252
+ setShowGoNextIndicator(false);
34253
+ onStartStep && onStartStep();
34254
+ }
34255
+ }), showGoNextIndicator && React.createElement(PressSpaceIndicator, {
34256
+ right: type === NPCDialogType.TextOnly ? '1rem' : '10.5rem',
34257
+ src: IS_MOBILE_OR_TABLET ? img$6 : img$7,
34258
+ onClick: function onClick() {
34259
+ goToNextStep();
34260
+ }
34261
+ }));
34262
+ };
34263
+ var Container$b = /*#__PURE__*/styled.div.withConfig({
34264
+ displayName: "NPCDialogText__Container",
34265
+ componentId: "sc-1cxkdh9-0"
34266
+ })([""]);
34267
+ var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
34268
+ displayName: "NPCDialogText__PressSpaceIndicator",
34269
+ componentId: "sc-1cxkdh9-1"
34270
+ })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
34271
+ var right = _ref2.right;
34272
+ return right;
34273
+ });
34274
+
34275
+ //@ts-ignore
34276
+ var useEventListener = function useEventListener(type, handler, el) {
34277
+ if (el === void 0) {
34278
+ el = window;
34279
+ }
34280
+ var savedHandler = React.useRef();
34281
+ React.useEffect(function () {
34282
+ savedHandler.current = handler;
34283
+ }, [handler]);
34284
+ React.useEffect(function () {
34285
+ //@ts-ignore
34286
+ var listener = function listener(e) {
34287
+ return savedHandler.current(e);
34288
+ };
34289
+ el.addEventListener(type, listener);
34290
+ return function () {
34291
+ el.removeEventListener(type, listener);
34292
+ };
34293
+ }, [type, el]);
34294
+ };
34295
+
34296
+ var QuestionDialog = function QuestionDialog(_ref) {
34297
+ var questions = _ref.questions,
34298
+ answers = _ref.answers,
34299
+ onClose = _ref.onClose;
34300
+ var _useState = useState(questions[0]),
34301
+ currentQuestion = _useState[0],
34302
+ setCurrentQuestion = _useState[1];
34303
+ var _useState2 = useState(false),
34304
+ canShowAnswers = _useState2[0],
34305
+ setCanShowAnswers = _useState2[1];
34306
+ var onGetFirstAnswer = function onGetFirstAnswer() {
34307
+ if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {
34308
+ return null;
34309
+ }
34310
+ var firstAnswerId = currentQuestion.answerIds[0];
34311
+ return answers.find(function (answer) {
34312
+ return answer.id === firstAnswerId;
34313
+ });
34314
+ };
34315
+ var _useState3 = useState(onGetFirstAnswer()),
34316
+ currentAnswer = _useState3[0],
34317
+ setCurrentAnswer = _useState3[1];
34318
+ useEffect(function () {
34319
+ setCurrentAnswer(onGetFirstAnswer());
34320
+ }, [currentQuestion]);
34321
+ var onGetAnswers = function onGetAnswers(answerIds) {
34322
+ return answerIds.map(function (answerId) {
34323
+ return answers.find(function (answer) {
34324
+ return answer.id === answerId;
34325
+ });
34326
+ });
34327
+ };
34328
+ var onKeyPress = function onKeyPress(e) {
34329
+ switch (e.key) {
34330
+ case 'ArrowDown':
34331
+ // select next answer, if any.
34332
+ // if no next answer, select first answer
34333
+ // const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(
34334
+ // (answer) => answer?.id === currentAnswer!.id + 1
34335
+ // );
34336
+ var nextAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34337
+ return (answer == null ? void 0 : answer.id) === currentAnswer.id + 1;
34338
+ });
34339
+ var nextAnswerID = currentQuestion.answerIds[nextAnswerIndex];
34340
+ var nextAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34341
+ return (answer == null ? void 0 : answer.id) === nextAnswerID;
34342
+ });
34343
+ setCurrentAnswer(nextAnswer || onGetFirstAnswer());
34344
+ break;
34345
+ case 'ArrowUp':
34346
+ // select previous answer, if any.
34347
+ // if no previous answer, select last answer
34348
+ var previousAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34349
+ return (answer == null ? void 0 : answer.id) === currentAnswer.id - 1;
34350
+ });
34351
+ var previousAnswerID = currentQuestion.answerIds && currentQuestion.answerIds[previousAnswerIndex];
34352
+ var previousAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34353
+ return (answer == null ? void 0 : answer.id) === previousAnswerID;
34354
+ });
34355
+ if (previousAnswer) {
34356
+ setCurrentAnswer(previousAnswer);
34357
+ } else {
34358
+ setCurrentAnswer(onGetAnswers(currentQuestion.answerIds).pop());
34359
+ }
34360
+ break;
34361
+ case 'Enter':
34362
+ setCanShowAnswers(false);
34363
+ if (!(currentAnswer != null && currentAnswer.nextQuestionId)) {
34364
+ onClose();
34365
+ return;
34366
+ } else {
34367
+ setCurrentQuestion(questions.find(function (question) {
34368
+ return question.id === currentAnswer.nextQuestionId;
34369
+ }));
34370
+ }
34371
+ break;
34372
+ }
34373
+ };
34374
+ useEventListener('keydown', onKeyPress);
34375
+ var onAnswerClick = function onAnswerClick(answer) {
34376
+ setCanShowAnswers(false);
34377
+ if (answer.nextQuestionId) {
34378
+ // if there is a next question, go to it
34379
+ setCurrentQuestion(questions.find(function (question) {
34380
+ return question.id === answer.nextQuestionId;
34381
+ }));
34382
+ } else {
34383
+ // else, finish dialog!
34384
+ onClose();
34385
+ }
34386
+ };
34387
+ var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
34388
+ var answerIds = currentQuestion.answerIds;
34389
+ if (!answerIds) {
34390
+ return null;
34391
+ }
34392
+ var answers = onGetAnswers(answerIds);
34393
+ if (!answers) {
34394
+ return null;
34395
+ }
34396
+ return answers.map(function (answer) {
34397
+ var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
34398
+ var selectedColor = isSelected ? 'yellow' : 'white';
34399
+ if (answer) {
34400
+ return React.createElement(AnswerRow, {
34401
+ key: "answer_" + answer.id
34402
+ }, React.createElement(AnswerSelectedIcon, {
34403
+ color: selectedColor
34404
+ }, isSelected ? 'X' : null), React.createElement(Answer, {
34405
+ key: answer.id,
34406
+ onClick: function onClick() {
34407
+ return onAnswerClick(answer);
34408
+ },
34409
+ color: selectedColor
34410
+ }, answer.text));
34411
+ }
34412
+ return null;
34413
+ });
34414
+ };
34415
+ return React.createElement(Container$c, null, React.createElement(QuestionContainer, null, React.createElement(DynamicText, {
34416
+ text: currentQuestion.text,
34417
+ onStart: function onStart() {
34418
+ return setCanShowAnswers(false);
34419
+ },
34420
+ onFinish: function onFinish() {
34421
+ return setCanShowAnswers(true);
34422
+ }
34423
+ })), canShowAnswers && React.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
34424
+ };
34425
+ var Container$c = /*#__PURE__*/styled.div.withConfig({
34426
+ displayName: "QuestionDialog__Container",
34427
+ componentId: "sc-bxc5u0-0"
34428
+ })(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
34429
+ var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
34430
+ displayName: "QuestionDialog__QuestionContainer",
34431
+ componentId: "sc-bxc5u0-1"
34432
+ })(["flex:100%;width:100%;"]);
34433
+ var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
34434
+ displayName: "QuestionDialog__AnswersContainer",
34435
+ componentId: "sc-bxc5u0-2"
34436
+ })(["flex:100%;"]);
34437
+ var Answer = /*#__PURE__*/styled.p.withConfig({
34438
+ displayName: "QuestionDialog__Answer",
34439
+ componentId: "sc-bxc5u0-3"
34440
+ })(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
34441
+ return props.color;
34442
+ });
34443
+ var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
34444
+ displayName: "QuestionDialog__AnswerSelectedIcon",
34445
+ componentId: "sc-bxc5u0-4"
34446
+ })(["flex:5% 0 0;color:", " !important;"], function (props) {
34447
+ return props.color;
34448
+ });
34449
+ var AnswerRow = /*#__PURE__*/styled.div.withConfig({
34450
+ displayName: "QuestionDialog__AnswerRow",
34451
+ componentId: "sc-bxc5u0-5"
34452
+ })(["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;}"]);
34453
+
34454
+ var img$8 = '';
34455
+
34456
+ var NPCDialogType;
34457
+ (function (NPCDialogType) {
34458
+ NPCDialogType["TextOnly"] = "TextOnly";
34459
+ NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
34460
+ })(NPCDialogType || (NPCDialogType = {}));
34461
+ var NPCDialog = function NPCDialog(_ref) {
34462
+ var text = _ref.text,
34463
+ type = _ref.type,
34464
+ _onClose = _ref.onClose,
34465
+ imagePath = _ref.imagePath,
34466
+ _ref$isQuestionDialog = _ref.isQuestionDialog,
34467
+ isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
34468
+ questions = _ref.questions,
34469
+ answers = _ref.answers;
34470
+ return React.createElement(RPGUIContainer, {
34471
+ type: RPGUIContainerTypes.FramedGold,
34472
+ width: isQuestionDialog ? '600px' : '80%',
34473
+ height: '180px'
34474
+ }, isQuestionDialog && questions && answers ? React.createElement(React.Fragment, null, React.createElement(TextContainer$1, {
34475
+ flex: type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'
34476
+ }, React.createElement(QuestionDialog, {
34477
+ questions: questions,
34478
+ answers: answers,
34479
+ onClose: function onClose() {
34480
+ if (_onClose) {
34481
+ _onClose();
34482
+ }
34483
+ }
34484
+ })), type === NPCDialogType.TextAndThumbnail && React.createElement(ThumbnailContainer, null, React.createElement(NPCThumbnail, {
34485
+ src: imagePath || img$8
34486
+ }))) : React.createElement(React.Fragment, null, React.createElement(Container$d, null, React.createElement(TextContainer$1, {
34487
+ flex: type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'
34488
+ }, React.createElement(NPCDialogText, {
34489
+ type: type,
34490
+ text: text || 'No text provided.',
34491
+ onClose: function onClose() {
34492
+ if (_onClose) {
34493
+ _onClose();
34494
+ }
34495
+ }
34496
+ })), type === NPCDialogType.TextAndThumbnail && React.createElement(ThumbnailContainer, null, React.createElement(NPCThumbnail, {
34497
+ src: imagePath || img$8
34498
+ })))));
34499
+ };
34500
+ var Container$d = /*#__PURE__*/styled.div.withConfig({
34501
+ displayName: "NPCDialog__Container",
34502
+ componentId: "sc-1b4aw74-0"
34503
+ })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
34504
+ var TextContainer$1 = /*#__PURE__*/styled.div.withConfig({
34505
+ displayName: "NPCDialog__TextContainer",
34506
+ componentId: "sc-1b4aw74-1"
34507
+ })(["flex:", " 0 0;width:355px;"], function (_ref2) {
34508
+ var flex = _ref2.flex;
34509
+ return flex;
34510
+ });
34511
+ var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
34512
+ displayName: "NPCDialog__ThumbnailContainer",
34513
+ componentId: "sc-1b4aw74-2"
34514
+ })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
34515
+ var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
34516
+ displayName: "NPCDialog__NPCThumbnail",
34517
+ componentId: "sc-1b4aw74-3"
34518
+ })(["image-rendering:pixelated;height:128px;width:128px;"]);
34519
+
34520
+ var ImgSide;
34521
+ (function (ImgSide) {
34522
+ ImgSide["right"] = "right";
34523
+ ImgSide["left"] = "left";
34524
+ })(ImgSide || (ImgSide = {}));
34525
+ var NPCMultiDialog = function NPCMultiDialog(_ref) {
34526
+ var _textAndTypeArray$sli;
34527
+ var _onClose = _ref.onClose,
34528
+ textAndTypeArray = _ref.textAndTypeArray;
34529
+ var _useState = useState(false),
34530
+ showGoNextIndicator = _useState[0],
34531
+ setShowGoNextIndicator = _useState[1];
34532
+ var _useState2 = useState(0),
34533
+ slide = _useState2[0],
34534
+ setSlide = _useState2[1];
34535
+ var onHandleSpacePress = function onHandleSpacePress(event) {
34536
+ if (event.code === 'Space') {
34537
+ if (slide < (textAndTypeArray == null ? void 0 : textAndTypeArray.length) - 1) {
34538
+ setSlide(function (prev) {
34539
+ return prev + 1;
34540
+ });
34541
+ } else {
34542
+ // if there's no more text chunks, close the dialog
34543
+ _onClose();
34544
+ }
34545
+ }
34546
+ };
34547
+ useEffect(function () {
34548
+ document.addEventListener('keydown', onHandleSpacePress);
34549
+ return function () {
34550
+ return document.removeEventListener('keydown', onHandleSpacePress);
34551
+ };
34552
+ }, [slide]);
34553
+ return React.createElement(RPGUIContainer, {
34554
+ type: RPGUIContainerTypes.FramedGold,
34555
+ width: '50%',
34556
+ height: '180px'
34557
+ }, 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, {
34558
+ flex: '70%'
34559
+ }, React.createElement(NPCDialogText, {
34560
+ onStartStep: function onStartStep() {
34561
+ return setShowGoNextIndicator(false);
34562
+ },
34563
+ onEndStep: function onEndStep() {
34564
+ return setShowGoNextIndicator(true);
34565
+ },
34566
+ text: textAndTypeArray[slide].text || 'No text provided.',
34567
+ onClose: function onClose() {
34568
+ if (_onClose) {
34569
+ _onClose();
34570
+ }
34571
+ }
34572
+ })), React.createElement(ThumbnailContainer$1, null, React.createElement(NPCThumbnail$1, {
34573
+ src: textAndTypeArray[slide].imagePath || img$8
34574
+ })), showGoNextIndicator && React.createElement(PressSpaceIndicator$1, {
34575
+ right: '10.5rem',
34576
+ src: img$7
34577
+ })), textAndTypeArray[slide].imageSide === 'left' && React.createElement(React.Fragment, null, React.createElement(ThumbnailContainer$1, null, React.createElement(NPCThumbnail$1, {
34578
+ src: textAndTypeArray[slide].imagePath || img$8
34579
+ })), React.createElement(TextContainer$2, {
34580
+ flex: '70%'
34581
+ }, React.createElement(NPCDialogText, {
34582
+ onStartStep: function onStartStep() {
34583
+ return setShowGoNextIndicator(false);
34584
+ },
34585
+ onEndStep: function onEndStep() {
34586
+ return setShowGoNextIndicator(true);
34587
+ },
34588
+ text: textAndTypeArray[slide].text || 'No text provided.',
34589
+ onClose: function onClose() {
34590
+ if (_onClose) {
34591
+ _onClose();
34592
+ }
34593
+ }
34594
+ })), showGoNextIndicator && React.createElement(PressSpaceIndicator$1, {
34595
+ right: '1rem',
34596
+ src: img$7
34597
+ }))), ")"));
34598
+ };
34599
+ var Container$e = /*#__PURE__*/styled.div.withConfig({
34600
+ displayName: "NPCMultiDialog__Container",
34601
+ componentId: "sc-rvu5wg-0"
34602
+ })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
34603
+ var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
34604
+ displayName: "NPCMultiDialog__TextContainer",
34605
+ componentId: "sc-rvu5wg-1"
34606
+ })(["flex:", " 0 0;width:355px;"], function (_ref2) {
34607
+ var flex = _ref2.flex;
34608
+ return flex;
34609
+ });
34610
+ var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
34611
+ displayName: "NPCMultiDialog__ThumbnailContainer",
34612
+ componentId: "sc-rvu5wg-2"
34613
+ })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
34614
+ var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
34615
+ displayName: "NPCMultiDialog__NPCThumbnail",
34616
+ componentId: "sc-rvu5wg-3"
34617
+ })(["image-rendering:pixelated;height:128px;width:128px;"]);
34618
+ var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
34619
+ displayName: "NPCMultiDialog__PressSpaceIndicator",
34620
+ componentId: "sc-rvu5wg-4"
34621
+ })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref3) {
34622
+ var right = _ref3.right;
34623
+ return right;
34624
+ });
34625
+
34626
+ var HistoryDialog = function HistoryDialog(_ref) {
34627
+ var backgroundImgPath = _ref.backgroundImgPath,
34628
+ fullCoverBackground = _ref.fullCoverBackground,
34629
+ questions = _ref.questions,
34630
+ answers = _ref.answers,
34631
+ text = _ref.text,
34632
+ imagePath = _ref.imagePath,
34633
+ textAndTypeArray = _ref.textAndTypeArray,
34634
+ onClose = _ref.onClose;
34635
+ var _useState = useState(0),
34636
+ img = _useState[0],
34637
+ setImage = _useState[1];
34638
+ var onHandleSpacePress = function onHandleSpacePress(event) {
34639
+ if (event.code === 'Space') {
34640
+ if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
34641
+ setImage(function (prev) {
34642
+ return prev + 1;
34643
+ });
34644
+ } else {
34645
+ // if there's no more text chunks, close the dialog
34646
+ onClose();
34647
+ }
34648
+ }
34649
+ };
34650
+ useEffect(function () {
34651
+ document.addEventListener('keydown', onHandleSpacePress);
34652
+ return function () {
34653
+ return document.removeEventListener('keydown', onHandleSpacePress);
34654
+ };
34655
+ }, [backgroundImgPath]);
34656
+ return React.createElement(BackgroundContainer, {
34657
+ imgPath: backgroundImgPath[img],
34658
+ fullImg: fullCoverBackground
34659
+ }, React.createElement(DialogContainer, null, textAndTypeArray ? React.createElement(NPCMultiDialog, {
34660
+ textAndTypeArray: textAndTypeArray,
34661
+ onClose: onClose
34662
+ }) : questions && answers ? React.createElement(QuestionDialog, {
34663
+ questions: questions,
34664
+ answers: answers,
34665
+ onClose: onClose
34666
+ }) : text && imagePath ? React.createElement(NPCDialog, {
34667
+ text: text,
34668
+ imagePath: imagePath,
34669
+ onClose: onClose,
34670
+ type: NPCDialogType.TextAndThumbnail
34671
+ }) : React.createElement(NPCDialog, {
34672
+ text: text,
34673
+ onClose: onClose,
34674
+ type: NPCDialogType.TextOnly
34675
+ })));
34676
+ };
34677
+ var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
34678
+ displayName: "HistoryDialog__BackgroundContainer",
34679
+ componentId: "sc-u6oe75-0"
34680
+ })(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
34681
+ return props.imgPath;
34682
+ }, function (props) {
34683
+ return props.imgPath ? 'cover' : 'auto';
34684
+ });
34685
+ var DialogContainer = /*#__PURE__*/styled.div.withConfig({
34686
+ displayName: "HistoryDialog__DialogContainer",
34687
+ componentId: "sc-u6oe75-1"
34688
+ })(["display:flex;justify-content:center;padding-top:200px;"]);
34689
+
34143
34690
  var SlotsContainer = function SlotsContainer(_ref) {
34144
34691
  var children = _ref.children,
34145
34692
  title = _ref.title,
@@ -34381,507 +34928,181 @@ var ItemContainer$1 = function ItemContainer(_ref) {
34381
34928
  },
34382
34929
  dragScale: dragScale,
34383
34930
  checkIfItemCanBeMoved: checkIfItemCanBeMoved,
34384
- checkIfItemShouldDragEnd: checkIfItemShouldDragEnd,
34385
- openQuantitySelector: function openQuantitySelector(maxQuantity, callback) {
34386
- setQuantitySelect({
34387
- isOpen: true,
34388
- maxQuantity: maxQuantity,
34389
- callback: callback
34390
- });
34391
- },
34392
- onPlaceDrop: function onPlaceDrop(item, slotIndex, itemContainerType) {
34393
- if (onItemPlaceDrop) onItemPlaceDrop(item, slotIndex, itemContainerType);
34394
- },
34395
- onOutsideDrop: function onOutsideDrop(item, position) {
34396
- if (_onOutsideDrop) _onOutsideDrop(item, position);
34397
- },
34398
- atlasIMG: atlasIMG,
34399
- atlasJSON: atlasJSON
34400
- }));
34401
- }
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;
34931
+ checkIfItemShouldDragEnd: checkIfItemShouldDragEnd,
34932
+ openQuantitySelector: function openQuantitySelector(maxQuantity, callback) {
34933
+ setQuantitySelect({
34934
+ isOpen: true,
34935
+ maxQuantity: maxQuantity,
34936
+ callback: callback
34937
+ });
34938
+ },
34939
+ onPlaceDrop: function onPlaceDrop(item, slotIndex, itemContainerType) {
34940
+ if (onItemPlaceDrop) onItemPlaceDrop(item, slotIndex, itemContainerType);
34941
+ },
34942
+ onOutsideDrop: function onOutsideDrop(item, position) {
34943
+ if (_onOutsideDrop) _onOutsideDrop(item, position);
34944
+ },
34945
+ atlasIMG: atlasIMG,
34946
+ atlasJSON: atlasJSON
34947
+ }));
34741
34948
  }
34742
- var firstAnswerId = currentQuestion.answerIds[0];
34743
- return answers.find(function (answer) {
34744
- return answer.id === firstAnswerId;
34745
- });
34949
+ return slots;
34746
34950
  };
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;
34951
+ return React.createElement(React.Fragment, null, React.createElement(SlotsContainer, {
34952
+ title: itemContainer.name || 'Container',
34953
+ onClose: onClose,
34954
+ initialPosition: initialPosition
34955
+ }, React.createElement(ItemsContainer, {
34956
+ className: "item-container-body"
34957
+ }, onRenderSlots())), quantitySelect.isOpen && React.createElement(QuantitySelectorContainer, null, React.createElement(ItemQuantitySelector, {
34958
+ quantity: quantitySelect.maxQuantity,
34959
+ onConfirm: function onConfirm(quantity) {
34960
+ quantitySelect.callback(quantity);
34961
+ setQuantitySelect({
34962
+ isOpen: false,
34963
+ maxQuantity: 1,
34964
+ callback: function callback() {}
34965
+ });
34966
+ },
34967
+ onClose: function onClose() {
34968
+ quantitySelect.callback(-1);
34969
+ setQuantitySelect({
34970
+ isOpen: false,
34971
+ maxQuantity: 1,
34972
+ callback: function callback() {}
34757
34973
  });
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;
34804
34974
  }
34975
+ })));
34976
+ };
34977
+ var ItemsContainer = /*#__PURE__*/styled.div.withConfig({
34978
+ displayName: "ItemContainer__ItemsContainer",
34979
+ componentId: "sc-15y5p9l-0"
34980
+ })(["max-width:280px;display:flex;justify-content:center;flex-wrap:wrap;"]);
34981
+ var QuantitySelectorContainer = /*#__PURE__*/styled.div.withConfig({
34982
+ displayName: "ItemContainer__QuantitySelectorContainer",
34983
+ componentId: "sc-15y5p9l-1"
34984
+ })(["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);"]);
34985
+
34986
+ var ItemSelector = function ItemSelector(_ref) {
34987
+ var atlasIMG = _ref.atlasIMG,
34988
+ atlasJSON = _ref.atlasJSON,
34989
+ options = _ref.options,
34990
+ onClose = _ref.onClose,
34991
+ onSelect = _ref.onSelect;
34992
+ var _useState = useState(),
34993
+ selectedValue = _useState[0],
34994
+ setSelectedValue = _useState[1];
34995
+ var handleClick = function handleClick() {
34996
+ var element = document.querySelector("input[name='test']:checked");
34997
+ var elementValue = element.value;
34998
+ setSelectedValue(elementValue);
34805
34999
  };
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
+ useEffect(function () {
35001
+ if (selectedValue) {
35002
+ onSelect(selectedValue);
34817
35003
  }
34818
- };
34819
- var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
34820
- var answerIds = currentQuestion.answerIds;
34821
- if (!answerIds) {
34822
- return null;
35004
+ }, [selectedValue]);
35005
+ return React.createElement(DraggableContainer, {
35006
+ type: RPGUIContainerTypes.Framed,
35007
+ width: "500px",
35008
+ cancelDrag: ".equipment-container-body .arrow-selector",
35009
+ onCloseButton: function onCloseButton() {
35010
+ if (onClose) {
35011
+ onClose();
35012
+ }
34823
35013
  }
34824
- var answers = onGetAnswers(answerIds);
34825
- if (!answers) {
34826
- return null;
35014
+ }, React.createElement("div", {
35015
+ style: {
35016
+ width: '100%'
34827
35017
  }
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));
35018
+ }, React.createElement(Title$2, null, 'Harvesting instruments'), React.createElement(Subtitle$1, null, 'Use the tool, you need it'), React.createElement("hr", {
35019
+ className: "golden"
35020
+ })), React.createElement(RadioInputScroller$1, null, options == null ? void 0 : options.map(function (option, index) {
35021
+ return React.createElement(RadioOptionsWrapper$1, {
35022
+ key: index
35023
+ }, React.createElement(SpriteAtlasWrapper$1, null, React.createElement(SpriteFromAtlas, {
35024
+ atlasIMG: atlasIMG,
35025
+ atlasJSON: atlasJSON,
35026
+ spriteKey: option.imageKey,
35027
+ imgScale: 3
35028
+ })), React.createElement("div", null, React.createElement("input", {
35029
+ className: "rpgui-radio",
35030
+ type: "radio",
35031
+ value: option.name,
35032
+ name: "test"
35033
+ }), React.createElement("label", {
35034
+ onClick: handleClick,
35035
+ style: {
35036
+ display: 'flex',
35037
+ alignItems: 'center'
34843
35038
  }
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);
35039
+ }, option.name, " ", React.createElement("br", null), option.description)));
35040
+ })), React.createElement(ButtonWrapper$1, null, React.createElement(Button, {
35041
+ buttonType: ButtonTypes.RPGUIButton,
35042
+ onClick: onClose
35043
+ }, "Cancel"), React.createElement(Button, {
35044
+ buttonType: ButtonTypes.RPGUIButton
35045
+ }, "Select")));
35046
+ };
35047
+ var Title$2 = /*#__PURE__*/styled.h1.withConfig({
35048
+ displayName: "ItemSelector__Title",
35049
+ componentId: "sc-gptoxp-0"
35050
+ })(["font-size:0.6rem;color:yellow !important;"]);
35051
+ var Subtitle$1 = /*#__PURE__*/styled.h1.withConfig({
35052
+ displayName: "ItemSelector__Subtitle",
35053
+ componentId: "sc-gptoxp-1"
35054
+ })(["font-size:0.4rem;color:yellow !important;"]);
35055
+ var RadioInputScroller$1 = /*#__PURE__*/styled.div.withConfig({
35056
+ displayName: "ItemSelector__RadioInputScroller",
35057
+ componentId: "sc-gptoxp-2"
35058
+ })(["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;"]);
35059
+ var SpriteAtlasWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35060
+ displayName: "ItemSelector__SpriteAtlasWrapper",
35061
+ componentId: "sc-gptoxp-3"
35062
+ })(["margin-right:40px;"]);
35063
+ var RadioOptionsWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35064
+ displayName: "ItemSelector__RadioOptionsWrapper",
35065
+ componentId: "sc-gptoxp-4"
35066
+ })(["display:flex;align-items:stretch;margin-bottom:40px;"]);
35067
+ var ButtonWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35068
+ displayName: "ItemSelector__ButtonWrapper",
35069
+ componentId: "sc-gptoxp-5"
35070
+ })(["display:flex;justify-content:space-around;padding-top:20px;width:100%;"]);
35071
+
35072
+ var ListMenu = function ListMenu(_ref) {
35073
+ var options = _ref.options,
35074
+ onSelected = _ref.onSelected,
35075
+ x = _ref.x,
35076
+ y = _ref.y;
35077
+ return React.createElement(Container$f, {
35078
+ x: x,
35079
+ y: y
35080
+ }, React.createElement("ul", {
35081
+ className: "rpgui-list-imp",
35082
+ style: {
35083
+ overflow: 'hidden'
34854
35084
  }
34855
- })), canShowAnswers && React.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
35085
+ }, options.map(function (params, index) {
35086
+ return React.createElement(ListElement$1, {
35087
+ key: (params == null ? void 0 : params.id) || index,
35088
+ onClick: function onClick() {
35089
+ onSelected(params == null ? void 0 : params.id);
35090
+ }
35091
+ }, (params == null ? void 0 : params.text) || 'No text');
35092
+ })));
34856
35093
  };
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;}"]);
35094
+ var Container$f = /*#__PURE__*/styled.div.withConfig({
35095
+ displayName: "ListMenu__Container",
35096
+ componentId: "sc-i9097t-0"
35097
+ })(["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) {
35098
+ return props.y || 0;
35099
+ }, function (props) {
35100
+ return props.x || 0;
35101
+ }, uiFonts.size.xsmall);
35102
+ var ListElement$1 = /*#__PURE__*/styled.li.withConfig({
35103
+ displayName: "ListMenu__ListElement",
35104
+ componentId: "sc-i9097t-1"
35105
+ })(["margin-right:0.5rem;"]);
34885
35106
 
34886
35107
  var ProgressBar = function ProgressBar(_ref) {
34887
35108
  var max = _ref.max,
@@ -34900,7 +35121,7 @@ var ProgressBar = function ProgressBar(_ref) {
34900
35121
  }
34901
35122
  return value * 100 / max;
34902
35123
  };
34903
- return React.createElement(Container$e, {
35124
+ return React.createElement(Container$g, {
34904
35125
  className: "rpgui-progress",
34905
35126
  "data-value": calculatePercentageValue(max, value) / 100,
34906
35127
  "data-rpguitype": "progress",
@@ -34929,7 +35150,7 @@ var TextOverlay$1 = /*#__PURE__*/styled.div.withConfig({
34929
35150
  displayName: "ProgressBar__TextOverlay",
34930
35151
  componentId: "sc-qa6fzh-1"
34931
35152
  })(["width:100%;position:relative;"]);
34932
- var Container$e = /*#__PURE__*/styled.div.withConfig({
35153
+ var Container$g = /*#__PURE__*/styled.div.withConfig({
34933
35154
  displayName: "ProgressBar__Container",
34934
35155
  componentId: "sc-qa6fzh-2"
34935
35156
  })(["display:flex;flex-direction:column;min-width:", "px;width:", "%;justify-content:start;align-items:flex-start;", ""], function (props) {
@@ -34940,7 +35161,7 @@ var Container$e = /*#__PURE__*/styled.div.withConfig({
34940
35161
  return props.style;
34941
35162
  });
34942
35163
 
34943
- var img$8 = '';
35164
+ var img$9 = '';
34944
35165
 
34945
35166
  var QuestInfo = function QuestInfo(_ref) {
34946
35167
  var quests = _ref.quests,
@@ -34984,7 +35205,7 @@ var QuestInfo = function QuestInfo(_ref) {
34984
35205
  }), React.createElement(QuestContainer, null, React.createElement(TitleContainer$1, {
34985
35206
  className: "drag-handler"
34986
35207
  }, React.createElement(Title$3, null, React.createElement(Thumbnail, {
34987
- src: quests[currentIndex].thumbnail || img$8
35208
+ src: quests[currentIndex].thumbnail || img$9
34988
35209
  }), quests[currentIndex].title), React.createElement(QuestSplitDiv, null, React.createElement("hr", {
34989
35210
  className: "golden"
34990
35211
  }))), React.createElement(Content, null, React.createElement("p", null, quests[currentIndex].description)), React.createElement(QuestColumn, {
@@ -35003,7 +35224,7 @@ var QuestInfo = function QuestInfo(_ref) {
35003
35224
  })))) : React.createElement(QuestsContainer, null, React.createElement(QuestContainer, null, React.createElement(TitleContainer$1, {
35004
35225
  className: "drag-handler"
35005
35226
  }, React.createElement(Title$3, null, React.createElement(Thumbnail, {
35006
- src: quests[0].thumbnail || img$8
35227
+ src: quests[0].thumbnail || img$9
35007
35228
  }), quests[0].title), React.createElement(QuestSplitDiv, null, React.createElement("hr", {
35008
35229
  className: "golden"
35009
35230
  }))), React.createElement(Content, null, React.createElement("p", null, quests[0].description)), React.createElement(QuestColumn, {
@@ -35152,7 +35373,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
35152
35373
  bgColor = _ref$bgColor === void 0 ? 'red' : _ref$bgColor,
35153
35374
  _ref$margin = _ref.margin,
35154
35375
  margin = _ref$margin === void 0 ? 20 : _ref$margin;
35155
- return React.createElement(Container$f, {
35376
+ return React.createElement(Container$h, {
35156
35377
  className: "simple-progress-bar"
35157
35378
  }, React.createElement(ProgressBarContainer, {
35158
35379
  margin: margin
@@ -35161,7 +35382,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
35161
35382
  bgColor: bgColor
35162
35383
  }))));
35163
35384
  };
35164
- var Container$f = /*#__PURE__*/styled.div.withConfig({
35385
+ var Container$h = /*#__PURE__*/styled.div.withConfig({
35165
35386
  displayName: "SimpleProgressBar__Container",
35166
35387
  componentId: "sc-mbeil3-0"
35167
35388
  })(["display:flex;justify-content:center;align-items:center;width:100%;"]);
@@ -35284,6 +35505,26 @@ var skillProps = {
35284
35505
  }
35285
35506
  }
35286
35507
  };
35508
+ var skillNameMap = {
35509
+ stamina: 'Stamina',
35510
+ magic: 'Magic',
35511
+ magicResistance: 'Magic Resistance',
35512
+ strength: 'Strength',
35513
+ resistance: 'Resistance',
35514
+ dexterity: 'Dexterity',
35515
+ first: 'Fist',
35516
+ club: 'Club',
35517
+ sword: 'Sword',
35518
+ axe: 'Axe',
35519
+ distance: 'Distance',
35520
+ shielding: 'Shielding',
35521
+ dagger: 'Dagger',
35522
+ fishing: 'Fishing',
35523
+ mining: 'Mining',
35524
+ lumberjacking: 'Lumberjacking',
35525
+ cooking: 'Cooking',
35526
+ alchemy: 'Alchemy'
35527
+ };
35287
35528
  var SkillsContainer = function SkillsContainer(_ref) {
35288
35529
  var onCloseButton = _ref.onCloseButton,
35289
35530
  skill = _ref.skill,
@@ -35301,7 +35542,7 @@ var SkillsContainer = function SkillsContainer(_ref) {
35301
35542
  var skillDetails = skill[key];
35302
35543
  output.push(React.createElement(SkillProgressBar, {
35303
35544
  key: key,
35304
- skillName: _.capitalize(key),
35545
+ skillName: skillNameMap[key],
35305
35546
  bgColor: skillCategoryColor,
35306
35547
  level: skillDetails.level || 0,
35307
35548
  skillPoints: Math.round(skillDetails.skillPoints) || 0,
@@ -35362,7 +35603,7 @@ var Spell = function Spell(_ref) {
35362
35603
  isSettingShortcut = _ref.isSettingShortcut,
35363
35604
  minMagicLevelRequired = _ref.minMagicLevelRequired;
35364
35605
  var disabled = isSettingShortcut ? charMagicLevel < minMagicLevelRequired : manaCost > charMana || charMagicLevel < minMagicLevelRequired;
35365
- return React.createElement(Container$g, {
35606
+ return React.createElement(Container$i, {
35366
35607
  disabled: disabled,
35367
35608
  onClick: onClick == null ? void 0 : onClick.bind(null, spellKey),
35368
35609
  isSettingShortcut: isSettingShortcut && !disabled,
@@ -35375,7 +35616,7 @@ var Spell = function Spell(_ref) {
35375
35616
  className: "mana"
35376
35617
  }, manaCost)));
35377
35618
  };
35378
- var Container$g = /*#__PURE__*/styled.button.withConfig({
35619
+ var Container$i = /*#__PURE__*/styled.button.withConfig({
35379
35620
  displayName: "Spell__Container",
35380
35621
  componentId: "sc-j96fa2-0"
35381
35622
  })(["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) {
@@ -35495,7 +35736,7 @@ var Spellbook = function Spellbook(_ref) {
35495
35736
  width: "inherit",
35496
35737
  height: "inherit",
35497
35738
  cancelDrag: "#spellbook-search, #shortcuts_list, .spell"
35498
- }, React.createElement(Container$h, null, React.createElement(Title$6, null, "Learned Spells"), React.createElement(SpellbookShortcuts, {
35739
+ }, React.createElement(Container$j, null, React.createElement(Title$6, null, "Learned Spells"), React.createElement(SpellbookShortcuts, {
35499
35740
  setSettingShortcutIndex: setSettingShortcutIndex,
35500
35741
  settingShortcutIndex: settingShortcutIndex,
35501
35742
  shortcuts: spellShortcuts,
@@ -35525,7 +35766,7 @@ var Title$6 = /*#__PURE__*/styled.h1.withConfig({
35525
35766
  displayName: "Spellbook__Title",
35526
35767
  componentId: "sc-r02nfq-0"
35527
35768
  })(["font-size:", " !important;margin-bottom:0 !important;"], uiFonts.size.large);
35528
- var Container$h = /*#__PURE__*/styled.div.withConfig({
35769
+ var Container$j = /*#__PURE__*/styled.div.withConfig({
35529
35770
  displayName: "Spellbook__Container",
35530
35771
  componentId: "sc-r02nfq-1"
35531
35772
  })(["width:100%;height:100%;color:white;display:flex;flex-direction:column;"]);
@@ -35539,16 +35780,16 @@ var TextArea = function TextArea(_ref) {
35539
35780
  return React.createElement("textarea", Object.assign({}, props));
35540
35781
  };
35541
35782
 
35542
- var img$9 = '';
35783
+ var img$a = '';
35543
35784
 
35544
- var img$a = '';
35785
+ var img$b = '';
35545
35786
 
35546
- var img$b = '';
35787
+ var img$c = '';
35547
35788
 
35548
35789
  var DayNightPeriod = function DayNightPeriod(_ref) {
35549
35790
  var _periodOfDaySrcFiles;
35550
35791
  var periodOfDay = _ref.periodOfDay;
35551
- var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[PeriodOfDay.Morning] = img$a, _periodOfDaySrcFiles[PeriodOfDay.Afternoon] = img$9, _periodOfDaySrcFiles[PeriodOfDay.Night] = img$b, _periodOfDaySrcFiles);
35792
+ var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[PeriodOfDay.Morning] = img$b, _periodOfDaySrcFiles[PeriodOfDay.Afternoon] = img$a, _periodOfDaySrcFiles[PeriodOfDay.Night] = img$c, _periodOfDaySrcFiles);
35552
35793
  return React.createElement(GifContainer, null, React.createElement("img", {
35553
35794
  src: periodOfDaySrcFiles[periodOfDay]
35554
35795
  }));
@@ -35558,7 +35799,7 @@ var GifContainer = /*#__PURE__*/styled.div.withConfig({
35558
35799
  componentId: "sc-10t97fw-0"
35559
35800
  })(["width:100%;img{width:67%;}"]);
35560
35801
 
35561
- var img$c = '';
35802
+ var img$d = '';
35562
35803
 
35563
35804
  var TimeWidget = function TimeWidget(_ref) {
35564
35805
  var onClose = _ref.onClose,
@@ -35573,7 +35814,7 @@ var TimeWidget = function TimeWidget(_ref) {
35573
35814
  var WidgetContainer = /*#__PURE__*/styled.div.withConfig({
35574
35815
  displayName: "TimeWidget__WidgetContainer",
35575
35816
  componentId: "sc-1ja236h-0"
35576
- })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$c);
35817
+ })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$d);
35577
35818
  var Time = /*#__PURE__*/styled.div.withConfig({
35578
35819
  displayName: "TimeWidget__Time",
35579
35820
  componentId: "sc-1ja236h-1"
@@ -35823,230 +36064,16 @@ var Truncate = function Truncate(_ref) {
35823
36064
  var _ref$maxLines = _ref.maxLines,
35824
36065
  maxLines = _ref$maxLines === void 0 ? 1 : _ref$maxLines,
35825
36066
  children = _ref.children;
35826
- return React.createElement(Container$i, {
36067
+ return React.createElement(Container$k, {
35827
36068
  maxLines: maxLines
35828
36069
  }, children);
35829
36070
  };
35830
- var Container$i = /*#__PURE__*/styled.div.withConfig({
36071
+ var Container$k = /*#__PURE__*/styled.div.withConfig({
35831
36072
  displayName: "Truncate__Container",
35832
36073
  componentId: "sc-6x00qb-0"
35833
36074
  })(["display:-webkit-box;max-width:100%;max-height:100%;-webkit-line-clamp:", ";-webkit-box-orient:vertical;overflow:hidden;"], function (props) {
35834
36075
  return props.maxLines;
35835
36076
  });
35836
36077
 
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
-
36051
36078
  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 };
36052
36079
  //# sourceMappingURL=long-bow.esm.js.map