@rpg-engine/long-bow 0.3.49 → 0.3.51

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 (141) hide show
  1. package/LICENSE +20 -20
  2. package/README.md +181 -181
  3. package/dist/long-bow.cjs.development.js +877 -867
  4. package/dist/long-bow.cjs.development.js.map +1 -1
  5. package/dist/long-bow.cjs.production.min.js +1 -1
  6. package/dist/long-bow.cjs.production.min.js.map +1 -1
  7. package/dist/long-bow.esm.js +728 -718
  8. package/dist/long-bow.esm.js.map +1 -1
  9. package/package.json +100 -100
  10. package/src/components/Abstractions/SlotsContainer.tsx +45 -45
  11. package/src/components/Arrow/SelectArrow.tsx +65 -65
  12. package/src/components/Arrow/img/arrow01-left-clicked.png +0 -0
  13. package/src/components/Arrow/img/arrow01-left.png +0 -0
  14. package/src/components/Arrow/img/arrow01-right-clicked.png +0 -0
  15. package/src/components/Arrow/img/arrow01-right.png +0 -0
  16. package/src/components/Arrow/img/arrow02-left-clicked.png +0 -0
  17. package/src/components/Arrow/img/arrow02-left.png +0 -0
  18. package/src/components/Arrow/img/arrow02-right-clicked.png +0 -0
  19. package/src/components/Arrow/img/arrow02-right.png +0 -0
  20. package/src/components/Button.tsx +41 -41
  21. package/src/components/Character/CharacterSelection.tsx +96 -96
  22. package/src/components/CharacterStatus/CharacterStatus.tsx +120 -120
  23. package/src/components/Chat/Chat.tsx +195 -195
  24. package/src/components/Chatdeprecated/ChatDeprecated.tsx +200 -200
  25. package/src/components/CheckButton.tsx +65 -65
  26. package/src/components/CircularController/CircularController.tsx +162 -162
  27. package/src/components/CraftBook/CraftBook.tsx +235 -235
  28. package/src/components/CraftBook/MockItems.ts +46 -46
  29. package/src/components/DraggableContainer.tsx +154 -154
  30. package/src/components/Dropdown.tsx +96 -96
  31. package/src/components/DropdownSelectorContainer.tsx +42 -42
  32. package/src/components/Equipment/EquipmentSet.tsx +190 -190
  33. package/src/components/HistoryDialog.tsx +104 -104
  34. package/src/components/Input.tsx +15 -15
  35. package/src/components/Item/Cards/ItemTooltip.tsx +33 -33
  36. package/src/components/Item/Inventory/ErrorBoundary.tsx +42 -42
  37. package/src/components/Item/Inventory/ItemContainer.tsx +175 -175
  38. package/src/components/Item/Inventory/ItemContainerTypes.ts +6 -6
  39. package/src/components/Item/Inventory/ItemQuantitySelector.tsx +142 -142
  40. package/src/components/Item/Inventory/ItemSlot.tsx +467 -465
  41. package/src/components/Item/Inventory/itemContainerHelper.ts +156 -156
  42. package/src/components/ListMenu.tsx +63 -63
  43. package/src/components/Multitab/Tab.tsx +57 -57
  44. package/src/components/Multitab/TabBody.tsx +13 -13
  45. package/src/components/Multitab/TabsContainer.tsx +97 -97
  46. package/src/components/NPCDialog/NPCDialog.tsx +121 -121
  47. package/src/components/NPCDialog/NPCDialogText.tsx +113 -113
  48. package/src/components/NPCDialog/NPCMultiDialog.tsx +159 -159
  49. package/src/components/NPCDialog/QuestionDialog/QuestionDialog.tsx +237 -237
  50. package/src/components/ProgressBar.tsx +92 -92
  51. package/src/components/PropertySelect/PropertySelect.tsx +114 -114
  52. package/src/components/QuestInfo/QuestInfo.tsx +232 -232
  53. package/src/components/QuestList.tsx +129 -129
  54. package/src/components/RPGUIContainer.tsx +47 -47
  55. package/src/components/RPGUIForceRenderStart.tsx +45 -45
  56. package/src/components/RPGUIRoot.tsx +14 -14
  57. package/src/components/RadioButton.tsx +53 -53
  58. package/src/components/RadioInput/RadioButton.tsx +98 -98
  59. package/src/components/RadioInput/RadioInput.tsx +98 -98
  60. package/src/components/RadioInput/instruments.ts +15 -15
  61. package/src/components/RangeSlider.tsx +78 -78
  62. package/src/components/RelativeListMenu.tsx +83 -83
  63. package/src/components/ScrollList.tsx +79 -79
  64. package/src/components/SimpleProgressBar.tsx +62 -62
  65. package/src/components/SkillProgressBar.tsx +133 -133
  66. package/src/components/SkillsContainer.tsx +200 -191
  67. package/src/components/Spellbook/QuickSpells.tsx +120 -120
  68. package/src/components/Spellbook/Spell.tsx +201 -201
  69. package/src/components/Spellbook/Spellbook.tsx +144 -144
  70. package/src/components/Spellbook/SpellbookShortcuts.tsx +77 -77
  71. package/src/components/Spellbook/constants.ts +12 -12
  72. package/src/components/Spellbook/mockSpells.ts +60 -60
  73. package/src/components/StaticBook/StaticBook.tsx +105 -105
  74. package/src/components/TextArea.tsx +11 -11
  75. package/src/components/TimeWidget/DayNightPeriod/DayNightPeriod.tsx +35 -35
  76. package/src/components/TimeWidget/TimeWidget.tsx +63 -63
  77. package/src/components/TradingMenu/TradingItemRow.tsx +197 -197
  78. package/src/components/TradingMenu/TradingMenu.tsx +203 -203
  79. package/src/components/TradingMenu/items.mock.ts +37 -37
  80. package/src/components/Truncate.tsx +25 -25
  81. package/src/components/itemSelector/ItemSelector.tsx +136 -136
  82. package/src/components/shared/Column.tsx +16 -16
  83. package/src/components/shared/Ellipsis.tsx +65 -65
  84. package/src/components/shared/SpriteFromAtlas.tsx +102 -102
  85. package/src/components/typography/DynamicText.tsx +49 -49
  86. package/src/constants/uiColors.ts +20 -20
  87. package/src/constants/uiDevices.ts +3 -3
  88. package/src/constants/uiFonts.ts +12 -12
  89. package/src/hooks/useEventListener.ts +21 -21
  90. package/src/hooks/useOutsideAlerter.ts +25 -25
  91. package/src/index.tsx +40 -40
  92. package/src/libs/StringHelpers.ts +3 -3
  93. package/src/mocks/atlas/entities/entities.json +20215 -20215
  94. package/src/mocks/atlas/icons/icons.json +735 -735
  95. package/src/mocks/atlas/items/items.json +12086 -12086
  96. package/src/mocks/equipmentSet.mocks.ts +393 -393
  97. package/src/mocks/itemContainer.mocks.ts +560 -560
  98. package/src/mocks/skills.mocks.ts +128 -128
  99. package/src/stories/Arrow.stories.tsx +26 -26
  100. package/src/stories/Button.stories.tsx +36 -36
  101. package/src/stories/CharacterSelection.stories.tsx +45 -45
  102. package/src/stories/CharacterStatus.stories.tsx +29 -29
  103. package/src/stories/Chat.stories.tsx +187 -187
  104. package/src/stories/ChatDeprecated.stories.tsx +170 -170
  105. package/src/stories/CheckButton.stories.tsx +48 -48
  106. package/src/stories/CircullarController.stories.tsx +33 -33
  107. package/src/stories/CraftBook.stories.tsx +40 -40
  108. package/src/stories/DayNightPeriod.stories.tsx +27 -27
  109. package/src/stories/DraggableContainer.stories.tsx +28 -28
  110. package/src/stories/Dropdown.stories.tsx +46 -46
  111. package/src/stories/DropdownSelectorContainer.stories.tsx +41 -41
  112. package/src/stories/EquipmentSet.stories.tsx +65 -65
  113. package/src/stories/HistoryDialog.stories.tsx +61 -61
  114. package/src/stories/ItemContainer.stories.tsx +124 -124
  115. package/src/stories/ItemQuantitySelector.stories.tsx +26 -26
  116. package/src/stories/ItemSelector.stories.tsx +77 -77
  117. package/src/stories/ItemTradingComponent.stories.tsx +35 -35
  118. package/src/stories/ListMenu.stories.tsx +56 -56
  119. package/src/stories/Multitab.stories.tsx +51 -51
  120. package/src/stories/NPCDialog.stories.tsx +130 -130
  121. package/src/stories/NPCMultiDialog.stories.tsx +71 -71
  122. package/src/stories/ProgressBar.stories.tsx +23 -23
  123. package/src/stories/PropertySelect.stories.tsx +40 -40
  124. package/src/stories/QuestInfo.stories.tsx +107 -107
  125. package/src/stories/QuestList.stories.tsx +82 -82
  126. package/src/stories/QuickSpells.stories.tsx +38 -38
  127. package/src/stories/RPGUIContainers.stories.tsx +42 -42
  128. package/src/stories/RadioButton.stories.tsx +49 -49
  129. package/src/stories/RadioInput.stories.tsx +34 -34
  130. package/src/stories/RangeSlider.stories.tsx +64 -64
  131. package/src/stories/ScrollList.stories.tsx +85 -85
  132. package/src/stories/SimpleProgressBar.stories.tsx +22 -22
  133. package/src/stories/SkillProgressBar.stories.tsx +34 -34
  134. package/src/stories/SkillsContainer.stories.tsx +35 -35
  135. package/src/stories/Spellbook.stories.tsx +107 -107
  136. package/src/stories/StaticBook.stories.tsx +32 -32
  137. package/src/stories/Text.stories.tsx +42 -42
  138. package/src/stories/TimeWidget.stories.tsx +27 -27
  139. package/src/stories/TradingMenu.stories.tsx +45 -45
  140. package/src/types/eventTypes.ts +4 -4
  141. 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, isMobileOrTablet, getSPForLevel, PeriodOfDay } from '@rpg-engine/shared';
3
+ import { GRID_WIDTH, GRID_HEIGHT, ItemSubType, ItemContainerType, ItemType, ItemSocketEventsDisplayLabels, ActionsForInventory, ActionsForEquipmentSet, ActionsForLoot, ActionsForMapContainer, ItemRarities, getItemTextureKeyPath, ItemSlotType, getSPForLevel, PeriodOfDay, isMobileOrTablet } from '@rpg-engine/shared';
4
4
  import dayjs from 'dayjs';
5
5
  import { ErrorBoundary as ErrorBoundary$1 } from 'react-error-boundary';
6
6
  import { RxPaperPlane } from 'react-icons/rx';
@@ -33890,14 +33890,16 @@ var ItemSlot = /*#__PURE__*/observer(function (_ref) {
33890
33890
  var resetItem = function resetItem() {
33891
33891
  setTooltipVisible(false);
33892
33892
  setWasDragged(false);
33893
- setIsFocused(false);
33894
33893
  };
33895
33894
  var onSuccesfulDrag = function onSuccesfulDrag(quantity) {
33896
33895
  resetItem();
33897
- if (quantity === -1) setDragPosition({
33898
- x: 0,
33899
- y: 0
33900
- });else if (item) {
33896
+ if (quantity === -1) {
33897
+ setDragPosition({
33898
+ x: 0,
33899
+ y: 0
33900
+ });
33901
+ setIsFocused(false);
33902
+ } else if (item) {
33901
33903
  onDragEnd(quantity);
33902
33904
  }
33903
33905
  };
@@ -33954,6 +33956,7 @@ var ItemSlot = /*#__PURE__*/observer(function (_ref) {
33954
33956
  if (item.stackQty && item.stackQty !== 1 && openQuantitySelector) openQuantitySelector(item.stackQty, onSuccesfulDrag);else onSuccesfulDrag(item.stackQty);
33955
33957
  } else {
33956
33958
  resetItem();
33959
+ setIsFocused(false);
33957
33960
  setDragPosition({
33958
33961
  x: 0,
33959
33962
  y: 0
@@ -34147,546 +34150,6 @@ var EquipmentColumn = /*#__PURE__*/styled.div.withConfig({
34147
34150
  componentId: "sc-1wuddg2-1"
34148
34151
  })(["display:flex;justify-content:center;flex-wrap:wrap;flex-direction:column;touch-action:none;"]);
34149
34152
 
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
-
34690
34153
  var SlotsContainer = function SlotsContainer(_ref) {
34691
34154
  var children = _ref.children,
34692
34155
  title = _ref.title,
@@ -34946,163 +34409,489 @@ var ItemContainer$1 = function ItemContainer(_ref) {
34946
34409
  atlasJSON: atlasJSON
34947
34410
  }));
34948
34411
  }
34949
- return slots;
34412
+ return slots;
34413
+ };
34414
+ return React.createElement(React.Fragment, null, React.createElement(SlotsContainer, {
34415
+ title: itemContainer.name || 'Container',
34416
+ onClose: onClose,
34417
+ initialPosition: initialPosition
34418
+ }, React.createElement(ItemsContainer, {
34419
+ className: "item-container-body"
34420
+ }, onRenderSlots())), quantitySelect.isOpen && React.createElement(QuantitySelectorContainer, null, React.createElement(ItemQuantitySelector, {
34421
+ quantity: quantitySelect.maxQuantity,
34422
+ onConfirm: function onConfirm(quantity) {
34423
+ quantitySelect.callback(quantity);
34424
+ setQuantitySelect({
34425
+ isOpen: false,
34426
+ maxQuantity: 1,
34427
+ callback: function callback() {}
34428
+ });
34429
+ },
34430
+ onClose: function onClose() {
34431
+ quantitySelect.callback(-1);
34432
+ setQuantitySelect({
34433
+ isOpen: false,
34434
+ maxQuantity: 1,
34435
+ callback: function callback() {}
34436
+ });
34437
+ }
34438
+ })));
34439
+ };
34440
+ var ItemsContainer = /*#__PURE__*/styled.div.withConfig({
34441
+ displayName: "ItemContainer__ItemsContainer",
34442
+ componentId: "sc-15y5p9l-0"
34443
+ })(["max-width:280px;display:flex;justify-content:center;flex-wrap:wrap;"]);
34444
+ var QuantitySelectorContainer = /*#__PURE__*/styled.div.withConfig({
34445
+ displayName: "ItemContainer__QuantitySelectorContainer",
34446
+ componentId: "sc-15y5p9l-1"
34447
+ })(["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);"]);
34448
+
34449
+ var ItemSelector = function ItemSelector(_ref) {
34450
+ var atlasIMG = _ref.atlasIMG,
34451
+ atlasJSON = _ref.atlasJSON,
34452
+ options = _ref.options,
34453
+ onClose = _ref.onClose,
34454
+ onSelect = _ref.onSelect;
34455
+ var _useState = useState(),
34456
+ selectedValue = _useState[0],
34457
+ setSelectedValue = _useState[1];
34458
+ var handleClick = function handleClick() {
34459
+ var element = document.querySelector("input[name='test']:checked");
34460
+ var elementValue = element.value;
34461
+ setSelectedValue(elementValue);
34462
+ };
34463
+ useEffect(function () {
34464
+ if (selectedValue) {
34465
+ onSelect(selectedValue);
34466
+ }
34467
+ }, [selectedValue]);
34468
+ return React.createElement(DraggableContainer, {
34469
+ type: RPGUIContainerTypes.Framed,
34470
+ width: "500px",
34471
+ cancelDrag: ".equipment-container-body .arrow-selector",
34472
+ onCloseButton: function onCloseButton() {
34473
+ if (onClose) {
34474
+ onClose();
34475
+ }
34476
+ }
34477
+ }, React.createElement("div", {
34478
+ style: {
34479
+ width: '100%'
34480
+ }
34481
+ }, React.createElement(Title$2, null, 'Harvesting instruments'), React.createElement(Subtitle$1, null, 'Use the tool, you need it'), React.createElement("hr", {
34482
+ className: "golden"
34483
+ })), React.createElement(RadioInputScroller$1, null, options == null ? void 0 : options.map(function (option, index) {
34484
+ return React.createElement(RadioOptionsWrapper$1, {
34485
+ key: index
34486
+ }, React.createElement(SpriteAtlasWrapper$1, null, React.createElement(SpriteFromAtlas, {
34487
+ atlasIMG: atlasIMG,
34488
+ atlasJSON: atlasJSON,
34489
+ spriteKey: option.imageKey,
34490
+ imgScale: 3
34491
+ })), React.createElement("div", null, React.createElement("input", {
34492
+ className: "rpgui-radio",
34493
+ type: "radio",
34494
+ value: option.name,
34495
+ name: "test"
34496
+ }), React.createElement("label", {
34497
+ onClick: handleClick,
34498
+ style: {
34499
+ display: 'flex',
34500
+ alignItems: 'center'
34501
+ }
34502
+ }, option.name, " ", React.createElement("br", null), option.description)));
34503
+ })), React.createElement(ButtonWrapper$1, null, React.createElement(Button, {
34504
+ buttonType: ButtonTypes.RPGUIButton,
34505
+ onClick: onClose
34506
+ }, "Cancel"), React.createElement(Button, {
34507
+ buttonType: ButtonTypes.RPGUIButton
34508
+ }, "Select")));
34509
+ };
34510
+ var Title$2 = /*#__PURE__*/styled.h1.withConfig({
34511
+ displayName: "ItemSelector__Title",
34512
+ componentId: "sc-gptoxp-0"
34513
+ })(["font-size:0.6rem;color:yellow !important;"]);
34514
+ var Subtitle$1 = /*#__PURE__*/styled.h1.withConfig({
34515
+ displayName: "ItemSelector__Subtitle",
34516
+ componentId: "sc-gptoxp-1"
34517
+ })(["font-size:0.4rem;color:yellow !important;"]);
34518
+ var RadioInputScroller$1 = /*#__PURE__*/styled.div.withConfig({
34519
+ displayName: "ItemSelector__RadioInputScroller",
34520
+ componentId: "sc-gptoxp-2"
34521
+ })(["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;"]);
34522
+ var SpriteAtlasWrapper$1 = /*#__PURE__*/styled.div.withConfig({
34523
+ displayName: "ItemSelector__SpriteAtlasWrapper",
34524
+ componentId: "sc-gptoxp-3"
34525
+ })(["margin-right:40px;"]);
34526
+ var RadioOptionsWrapper$1 = /*#__PURE__*/styled.div.withConfig({
34527
+ displayName: "ItemSelector__RadioOptionsWrapper",
34528
+ componentId: "sc-gptoxp-4"
34529
+ })(["display:flex;align-items:stretch;margin-bottom:40px;"]);
34530
+ var ButtonWrapper$1 = /*#__PURE__*/styled.div.withConfig({
34531
+ displayName: "ItemSelector__ButtonWrapper",
34532
+ componentId: "sc-gptoxp-5"
34533
+ })(["display:flex;justify-content:space-around;padding-top:20px;width:100%;"]);
34534
+
34535
+ var ListMenu = function ListMenu(_ref) {
34536
+ var options = _ref.options,
34537
+ onSelected = _ref.onSelected,
34538
+ x = _ref.x,
34539
+ y = _ref.y;
34540
+ return React.createElement(Container$b, {
34541
+ x: x,
34542
+ y: y
34543
+ }, React.createElement("ul", {
34544
+ className: "rpgui-list-imp",
34545
+ style: {
34546
+ overflow: 'hidden'
34547
+ }
34548
+ }, options.map(function (params, index) {
34549
+ return React.createElement(ListElement$1, {
34550
+ key: (params == null ? void 0 : params.id) || index,
34551
+ onClick: function onClick() {
34552
+ onSelected(params == null ? void 0 : params.id);
34553
+ }
34554
+ }, (params == null ? void 0 : params.text) || 'No text');
34555
+ })));
34556
+ };
34557
+ var Container$b = /*#__PURE__*/styled.div.withConfig({
34558
+ displayName: "ListMenu__Container",
34559
+ componentId: "sc-i9097t-0"
34560
+ })(["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) {
34561
+ return props.y || 0;
34562
+ }, function (props) {
34563
+ return props.x || 0;
34564
+ }, uiFonts.size.xsmall);
34565
+ var ListElement$1 = /*#__PURE__*/styled.li.withConfig({
34566
+ displayName: "ListMenu__ListElement",
34567
+ componentId: "sc-i9097t-1"
34568
+ })(["margin-right:0.5rem;"]);
34569
+
34570
+ var img$6 = '';
34571
+
34572
+ var img$7 = '';
34573
+
34574
+ var ImgSide;
34575
+ (function (ImgSide) {
34576
+ ImgSide["right"] = "right";
34577
+ ImgSide["left"] = "left";
34578
+ })(ImgSide || (ImgSide = {}));
34579
+ var NPCMultiDialog = function NPCMultiDialog(_ref) {
34580
+ var _textAndTypeArray$sli;
34581
+ var _onClose = _ref.onClose,
34582
+ textAndTypeArray = _ref.textAndTypeArray;
34583
+ var _useState = useState(false),
34584
+ showGoNextIndicator = _useState[0],
34585
+ setShowGoNextIndicator = _useState[1];
34586
+ var _useState2 = useState(0),
34587
+ slide = _useState2[0],
34588
+ setSlide = _useState2[1];
34589
+ var onHandleSpacePress = function onHandleSpacePress(event) {
34590
+ if (event.code === 'Space') {
34591
+ if (slide < (textAndTypeArray == null ? void 0 : textAndTypeArray.length) - 1) {
34592
+ setSlide(function (prev) {
34593
+ return prev + 1;
34594
+ });
34595
+ } else {
34596
+ // if there's no more text chunks, close the dialog
34597
+ _onClose();
34598
+ }
34599
+ }
34600
+ };
34601
+ useEffect(function () {
34602
+ document.addEventListener('keydown', onHandleSpacePress);
34603
+ return function () {
34604
+ return document.removeEventListener('keydown', onHandleSpacePress);
34605
+ };
34606
+ }, [slide]);
34607
+ return React.createElement(RPGUIContainer, {
34608
+ type: RPGUIContainerTypes.FramedGold,
34609
+ width: '50%',
34610
+ height: '180px'
34611
+ }, 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, {
34612
+ flex: '70%'
34613
+ }, React.createElement(NPCDialogText, {
34614
+ onStartStep: function onStartStep() {
34615
+ return setShowGoNextIndicator(false);
34616
+ },
34617
+ onEndStep: function onEndStep() {
34618
+ return setShowGoNextIndicator(true);
34619
+ },
34620
+ text: textAndTypeArray[slide].text || 'No text provided.',
34621
+ onClose: function onClose() {
34622
+ if (_onClose) {
34623
+ _onClose();
34624
+ }
34625
+ }
34626
+ })), React.createElement(ThumbnailContainer, null, React.createElement(NPCThumbnail, {
34627
+ src: textAndTypeArray[slide].imagePath || img$6
34628
+ })), showGoNextIndicator && React.createElement(PressSpaceIndicator, {
34629
+ right: '10.5rem',
34630
+ src: img$7
34631
+ })), textAndTypeArray[slide].imageSide === 'left' && React.createElement(React.Fragment, null, React.createElement(ThumbnailContainer, null, React.createElement(NPCThumbnail, {
34632
+ src: textAndTypeArray[slide].imagePath || img$6
34633
+ })), React.createElement(TextContainer, {
34634
+ flex: '70%'
34635
+ }, React.createElement(NPCDialogText, {
34636
+ onStartStep: function onStartStep() {
34637
+ return setShowGoNextIndicator(false);
34638
+ },
34639
+ onEndStep: function onEndStep() {
34640
+ return setShowGoNextIndicator(true);
34641
+ },
34642
+ text: textAndTypeArray[slide].text || 'No text provided.',
34643
+ onClose: function onClose() {
34644
+ if (_onClose) {
34645
+ _onClose();
34646
+ }
34647
+ }
34648
+ })), showGoNextIndicator && React.createElement(PressSpaceIndicator, {
34649
+ right: '1rem',
34650
+ src: img$7
34651
+ }))), ")"));
34652
+ };
34653
+ var Container$c = /*#__PURE__*/styled.div.withConfig({
34654
+ displayName: "NPCMultiDialog__Container",
34655
+ componentId: "sc-rvu5wg-0"
34656
+ })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
34657
+ var TextContainer = /*#__PURE__*/styled.div.withConfig({
34658
+ displayName: "NPCMultiDialog__TextContainer",
34659
+ componentId: "sc-rvu5wg-1"
34660
+ })(["flex:", " 0 0;width:355px;"], function (_ref2) {
34661
+ var flex = _ref2.flex;
34662
+ return flex;
34663
+ });
34664
+ var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
34665
+ displayName: "NPCMultiDialog__ThumbnailContainer",
34666
+ componentId: "sc-rvu5wg-2"
34667
+ })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
34668
+ var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
34669
+ displayName: "NPCMultiDialog__NPCThumbnail",
34670
+ componentId: "sc-rvu5wg-3"
34671
+ })(["image-rendering:pixelated;height:128px;width:128px;"]);
34672
+ var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
34673
+ displayName: "NPCMultiDialog__PressSpaceIndicator",
34674
+ componentId: "sc-rvu5wg-4"
34675
+ })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref3) {
34676
+ var right = _ref3.right;
34677
+ return right;
34678
+ });
34679
+
34680
+ //@ts-ignore
34681
+ var useEventListener = function useEventListener(type, handler, el) {
34682
+ if (el === void 0) {
34683
+ el = window;
34684
+ }
34685
+ var savedHandler = React.useRef();
34686
+ React.useEffect(function () {
34687
+ savedHandler.current = handler;
34688
+ }, [handler]);
34689
+ React.useEffect(function () {
34690
+ //@ts-ignore
34691
+ var listener = function listener(e) {
34692
+ return savedHandler.current(e);
34693
+ };
34694
+ el.addEventListener(type, listener);
34695
+ return function () {
34696
+ el.removeEventListener(type, listener);
34697
+ };
34698
+ }, [type, el]);
34699
+ };
34700
+
34701
+ var DynamicText = function DynamicText(_ref) {
34702
+ var text = _ref.text,
34703
+ onFinish = _ref.onFinish,
34704
+ onStart = _ref.onStart;
34705
+ var _useState = useState(''),
34706
+ textState = _useState[0],
34707
+ setTextState = _useState[1];
34708
+ useEffect(function () {
34709
+ var i = 0;
34710
+ var interval = setInterval(function () {
34711
+ // on every interval, show one more character
34712
+ if (i === 0) {
34713
+ if (onStart) {
34714
+ onStart();
34715
+ }
34716
+ }
34717
+ if (i < text.length) {
34718
+ setTextState(text.substring(0, i + 1));
34719
+ i++;
34720
+ } else {
34721
+ clearInterval(interval);
34722
+ if (onFinish) {
34723
+ onFinish();
34724
+ }
34725
+ }
34726
+ }, 50);
34727
+ return function () {
34728
+ clearInterval(interval);
34729
+ };
34730
+ }, [text]);
34731
+ return React.createElement(TextContainer$1, null, textState);
34732
+ };
34733
+ var TextContainer$1 = /*#__PURE__*/styled.p.withConfig({
34734
+ displayName: "DynamicText__TextContainer",
34735
+ componentId: "sc-1ggl9nd-0"
34736
+ })(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]);
34737
+
34738
+ var QuestionDialog = function QuestionDialog(_ref) {
34739
+ var questions = _ref.questions,
34740
+ answers = _ref.answers,
34741
+ onClose = _ref.onClose;
34742
+ var _useState = useState(questions[0]),
34743
+ currentQuestion = _useState[0],
34744
+ setCurrentQuestion = _useState[1];
34745
+ var _useState2 = useState(false),
34746
+ canShowAnswers = _useState2[0],
34747
+ setCanShowAnswers = _useState2[1];
34748
+ var onGetFirstAnswer = function onGetFirstAnswer() {
34749
+ if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {
34750
+ return null;
34751
+ }
34752
+ var firstAnswerId = currentQuestion.answerIds[0];
34753
+ return answers.find(function (answer) {
34754
+ return answer.id === firstAnswerId;
34755
+ });
34950
34756
  };
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
+ var _useState3 = useState(onGetFirstAnswer()),
34758
+ currentAnswer = _useState3[0],
34759
+ setCurrentAnswer = _useState3[1];
34760
+ useEffect(function () {
34761
+ setCurrentAnswer(onGetFirstAnswer());
34762
+ }, [currentQuestion]);
34763
+ var onGetAnswers = function onGetAnswers(answerIds) {
34764
+ return answerIds.map(function (answerId) {
34765
+ return answers.find(function (answer) {
34766
+ return answer.id === answerId;
34973
34767
  });
34768
+ });
34769
+ };
34770
+ var onKeyPress = function onKeyPress(e) {
34771
+ switch (e.key) {
34772
+ case 'ArrowDown':
34773
+ // select next answer, if any.
34774
+ // if no next answer, select first answer
34775
+ // const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(
34776
+ // (answer) => answer?.id === currentAnswer!.id + 1
34777
+ // );
34778
+ var nextAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34779
+ return (answer == null ? void 0 : answer.id) === currentAnswer.id + 1;
34780
+ });
34781
+ var nextAnswerID = currentQuestion.answerIds[nextAnswerIndex];
34782
+ var nextAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34783
+ return (answer == null ? void 0 : answer.id) === nextAnswerID;
34784
+ });
34785
+ setCurrentAnswer(nextAnswer || onGetFirstAnswer());
34786
+ break;
34787
+ case 'ArrowUp':
34788
+ // select previous answer, if any.
34789
+ // if no previous answer, select last answer
34790
+ var previousAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34791
+ return (answer == null ? void 0 : answer.id) === currentAnswer.id - 1;
34792
+ });
34793
+ var previousAnswerID = currentQuestion.answerIds && currentQuestion.answerIds[previousAnswerIndex];
34794
+ var previousAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34795
+ return (answer == null ? void 0 : answer.id) === previousAnswerID;
34796
+ });
34797
+ if (previousAnswer) {
34798
+ setCurrentAnswer(previousAnswer);
34799
+ } else {
34800
+ setCurrentAnswer(onGetAnswers(currentQuestion.answerIds).pop());
34801
+ }
34802
+ break;
34803
+ case 'Enter':
34804
+ setCanShowAnswers(false);
34805
+ if (!(currentAnswer != null && currentAnswer.nextQuestionId)) {
34806
+ onClose();
34807
+ return;
34808
+ } else {
34809
+ setCurrentQuestion(questions.find(function (question) {
34810
+ return question.id === currentAnswer.nextQuestionId;
34811
+ }));
34812
+ }
34813
+ break;
34974
34814
  }
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);
34999
34815
  };
35000
- useEffect(function () {
35001
- if (selectedValue) {
35002
- onSelect(selectedValue);
34816
+ useEventListener('keydown', onKeyPress);
34817
+ var onAnswerClick = function onAnswerClick(answer) {
34818
+ setCanShowAnswers(false);
34819
+ if (answer.nextQuestionId) {
34820
+ // if there is a next question, go to it
34821
+ setCurrentQuestion(questions.find(function (question) {
34822
+ return question.id === answer.nextQuestionId;
34823
+ }));
34824
+ } else {
34825
+ // else, finish dialog!
34826
+ onClose();
35003
34827
  }
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
- }
34828
+ };
34829
+ var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
34830
+ var answerIds = currentQuestion.answerIds;
34831
+ if (!answerIds) {
34832
+ return null;
35013
34833
  }
35014
- }, React.createElement("div", {
35015
- style: {
35016
- width: '100%'
34834
+ var answers = onGetAnswers(answerIds);
34835
+ if (!answers) {
34836
+ return null;
35017
34837
  }
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'
34838
+ return answers.map(function (answer) {
34839
+ var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
34840
+ var selectedColor = isSelected ? 'yellow' : 'white';
34841
+ if (answer) {
34842
+ return React.createElement(AnswerRow, {
34843
+ key: "answer_" + answer.id
34844
+ }, React.createElement(AnswerSelectedIcon, {
34845
+ color: selectedColor
34846
+ }, isSelected ? 'X' : null), React.createElement(Answer, {
34847
+ key: answer.id,
34848
+ onClick: function onClick() {
34849
+ return onAnswerClick(answer);
34850
+ },
34851
+ color: selectedColor
34852
+ }, answer.text));
35038
34853
  }
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
+ return null;
34855
+ });
34856
+ };
34857
+ return React.createElement(Container$d, null, React.createElement(QuestionContainer, null, React.createElement(DynamicText, {
34858
+ text: currentQuestion.text,
34859
+ onStart: function onStart() {
34860
+ return setCanShowAnswers(false);
34861
+ },
34862
+ onFinish: function onFinish() {
34863
+ return setCanShowAnswers(true);
35084
34864
  }
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
- })));
34865
+ })), canShowAnswers && React.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
35093
34866
  };
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;"]);
34867
+ var Container$d = /*#__PURE__*/styled.div.withConfig({
34868
+ displayName: "QuestionDialog__Container",
34869
+ componentId: "sc-bxc5u0-0"
34870
+ })(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
34871
+ var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
34872
+ displayName: "QuestionDialog__QuestionContainer",
34873
+ componentId: "sc-bxc5u0-1"
34874
+ })(["flex:100%;width:100%;"]);
34875
+ var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
34876
+ displayName: "QuestionDialog__AnswersContainer",
34877
+ componentId: "sc-bxc5u0-2"
34878
+ })(["flex:100%;"]);
34879
+ var Answer = /*#__PURE__*/styled.p.withConfig({
34880
+ displayName: "QuestionDialog__Answer",
34881
+ componentId: "sc-bxc5u0-3"
34882
+ })(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
34883
+ return props.color;
34884
+ });
34885
+ var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
34886
+ displayName: "QuestionDialog__AnswerSelectedIcon",
34887
+ componentId: "sc-bxc5u0-4"
34888
+ })(["flex:5% 0 0;color:", " !important;"], function (props) {
34889
+ return props.color;
34890
+ });
34891
+ var AnswerRow = /*#__PURE__*/styled.div.withConfig({
34892
+ displayName: "QuestionDialog__AnswerRow",
34893
+ componentId: "sc-bxc5u0-5"
34894
+ })(["display:flex;flex-wrap:wrap;justify-content:center;align-items:center;margin-bottom:0.5rem;height:22px;p{line-height:unset;margin-top:0;margin-bottom:0rem;}"]);
35106
34895
 
35107
34896
  var ProgressBar = function ProgressBar(_ref) {
35108
34897
  var max = _ref.max,
@@ -35121,7 +34910,7 @@ var ProgressBar = function ProgressBar(_ref) {
35121
34910
  }
35122
34911
  return value * 100 / max;
35123
34912
  };
35124
- return React.createElement(Container$g, {
34913
+ return React.createElement(Container$e, {
35125
34914
  className: "rpgui-progress",
35126
34915
  "data-value": calculatePercentageValue(max, value) / 100,
35127
34916
  "data-rpguitype": "progress",
@@ -35150,7 +34939,7 @@ var TextOverlay$1 = /*#__PURE__*/styled.div.withConfig({
35150
34939
  displayName: "ProgressBar__TextOverlay",
35151
34940
  componentId: "sc-qa6fzh-1"
35152
34941
  })(["width:100%;position:relative;"]);
35153
- var Container$g = /*#__PURE__*/styled.div.withConfig({
34942
+ var Container$e = /*#__PURE__*/styled.div.withConfig({
35154
34943
  displayName: "ProgressBar__Container",
35155
34944
  componentId: "sc-qa6fzh-2"
35156
34945
  })(["display:flex;flex-direction:column;min-width:", "px;width:", "%;justify-content:start;align-items:flex-start;", ""], function (props) {
@@ -35161,7 +34950,7 @@ var Container$g = /*#__PURE__*/styled.div.withConfig({
35161
34950
  return props.style;
35162
34951
  });
35163
34952
 
35164
- var img$9 = '';
34953
+ var img$8 = '';
35165
34954
 
35166
34955
  var QuestInfo = function QuestInfo(_ref) {
35167
34956
  var quests = _ref.quests,
@@ -35205,7 +34994,7 @@ var QuestInfo = function QuestInfo(_ref) {
35205
34994
  }), React.createElement(QuestContainer, null, React.createElement(TitleContainer$1, {
35206
34995
  className: "drag-handler"
35207
34996
  }, React.createElement(Title$3, null, React.createElement(Thumbnail, {
35208
- src: quests[currentIndex].thumbnail || img$9
34997
+ src: quests[currentIndex].thumbnail || img$8
35209
34998
  }), quests[currentIndex].title), React.createElement(QuestSplitDiv, null, React.createElement("hr", {
35210
34999
  className: "golden"
35211
35000
  }))), React.createElement(Content, null, React.createElement("p", null, quests[currentIndex].description)), React.createElement(QuestColumn, {
@@ -35224,7 +35013,7 @@ var QuestInfo = function QuestInfo(_ref) {
35224
35013
  })))) : React.createElement(QuestsContainer, null, React.createElement(QuestContainer, null, React.createElement(TitleContainer$1, {
35225
35014
  className: "drag-handler"
35226
35015
  }, React.createElement(Title$3, null, React.createElement(Thumbnail, {
35227
- src: quests[0].thumbnail || img$9
35016
+ src: quests[0].thumbnail || img$8
35228
35017
  }), quests[0].title), React.createElement(QuestSplitDiv, null, React.createElement("hr", {
35229
35018
  className: "golden"
35230
35019
  }))), React.createElement(Content, null, React.createElement("p", null, quests[0].description)), React.createElement(QuestColumn, {
@@ -35373,7 +35162,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
35373
35162
  bgColor = _ref$bgColor === void 0 ? 'red' : _ref$bgColor,
35374
35163
  _ref$margin = _ref.margin,
35375
35164
  margin = _ref$margin === void 0 ? 20 : _ref$margin;
35376
- return React.createElement(Container$h, {
35165
+ return React.createElement(Container$f, {
35377
35166
  className: "simple-progress-bar"
35378
35167
  }, React.createElement(ProgressBarContainer, {
35379
35168
  margin: margin
@@ -35382,7 +35171,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
35382
35171
  bgColor: bgColor
35383
35172
  }))));
35384
35173
  };
35385
- var Container$h = /*#__PURE__*/styled.div.withConfig({
35174
+ var Container$f = /*#__PURE__*/styled.div.withConfig({
35386
35175
  displayName: "SimpleProgressBar__Container",
35387
35176
  componentId: "sc-mbeil3-0"
35388
35177
  })(["display:flex;justify-content:center;align-items:center;width:100%;"]);
@@ -35555,11 +35344,14 @@ var SkillsContainer = function SkillsContainer(_ref) {
35555
35344
  return output;
35556
35345
  };
35557
35346
  return React.createElement(SkillsDraggableContainer, {
35558
- title: "Skills"
35347
+ title: "Skills",
35348
+ cancelDrag: "#skillsDiv"
35559
35349
  }, onCloseButton && React.createElement(CloseButton$3, {
35560
35350
  onClick: onCloseButton,
35561
35351
  onTouchStart: onCloseButton
35562
- }, "X"), React.createElement(SkillSplitDiv, null, React.createElement("p", null, "General"), React.createElement("hr", {
35352
+ }, "X"), React.createElement(SkillsContainerDiv, {
35353
+ id: "skillsDiv"
35354
+ }, React.createElement(SkillSplitDiv, null, React.createElement("p", null, "General"), React.createElement("hr", {
35563
35355
  className: "golden"
35564
35356
  }), React.createElement(SkillProgressBar, {
35565
35357
  skillName: 'Level',
@@ -35576,19 +35368,23 @@ var SkillsContainer = function SkillsContainer(_ref) {
35576
35368
  className: "golden"
35577
35369
  })), onRenderSkillCategory('crafting'), React.createElement(SkillSplitDiv, null, React.createElement("p", null, "Basic Attributes"), React.createElement("hr", {
35578
35370
  className: "golden"
35579
- })), onRenderSkillCategory('attributes'));
35371
+ })), onRenderSkillCategory('attributes')));
35580
35372
  };
35581
35373
  var SkillsDraggableContainer = /*#__PURE__*/styled(DraggableContainer).withConfig({
35582
35374
  displayName: "SkillsContainer__SkillsDraggableContainer",
35583
35375
  componentId: "sc-1g0c67q-0"
35584
- })(["border:1px solid black;width:400px;height:90%;overflow-y:scroll;.DraggableContainer__TitleContainer-sc-184mpyl-2{width:auto;height:auto;}"]);
35376
+ })(["border:1px solid black;width:400px;height:90%;.DraggableContainer__TitleContainer-sc-184mpyl-2{width:auto;height:auto;}"]);
35377
+ var SkillsContainerDiv = /*#__PURE__*/styled.div.withConfig({
35378
+ displayName: "SkillsContainer__SkillsContainerDiv",
35379
+ componentId: "sc-1g0c67q-1"
35380
+ })(["width:100%;-webkit-overflow-y:scroll;overflow-y:scroll;height:90%;padding-right:10px;"]);
35585
35381
  var SkillSplitDiv = /*#__PURE__*/styled.div.withConfig({
35586
35382
  displayName: "SkillsContainer__SkillSplitDiv",
35587
- componentId: "sc-1g0c67q-1"
35383
+ componentId: "sc-1g0c67q-2"
35588
35384
  })(["width:100%;font-size:11px;hr{margin:0;margin-bottom:1rem;padding:0px;}p{margin-bottom:0px;}"]);
35589
35385
  var CloseButton$3 = /*#__PURE__*/styled.div.withConfig({
35590
35386
  displayName: "SkillsContainer__CloseButton",
35591
- componentId: "sc-1g0c67q-2"
35387
+ componentId: "sc-1g0c67q-3"
35592
35388
  })(["position:absolute;top:2px;right:2px;color:white;z-index:22;font-size:1.1rem;"]);
35593
35389
 
35594
35390
  var Spell = function Spell(_ref) {
@@ -35603,7 +35399,7 @@ var Spell = function Spell(_ref) {
35603
35399
  isSettingShortcut = _ref.isSettingShortcut,
35604
35400
  minMagicLevelRequired = _ref.minMagicLevelRequired;
35605
35401
  var disabled = isSettingShortcut ? charMagicLevel < minMagicLevelRequired : manaCost > charMana || charMagicLevel < minMagicLevelRequired;
35606
- return React.createElement(Container$i, {
35402
+ return React.createElement(Container$g, {
35607
35403
  disabled: disabled,
35608
35404
  onClick: onClick == null ? void 0 : onClick.bind(null, spellKey),
35609
35405
  isSettingShortcut: isSettingShortcut && !disabled,
@@ -35616,7 +35412,7 @@ var Spell = function Spell(_ref) {
35616
35412
  className: "mana"
35617
35413
  }, manaCost)));
35618
35414
  };
35619
- var Container$i = /*#__PURE__*/styled.button.withConfig({
35415
+ var Container$g = /*#__PURE__*/styled.button.withConfig({
35620
35416
  displayName: "Spell__Container",
35621
35417
  componentId: "sc-j96fa2-0"
35622
35418
  })(["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) {
@@ -35736,7 +35532,7 @@ var Spellbook = function Spellbook(_ref) {
35736
35532
  width: "inherit",
35737
35533
  height: "inherit",
35738
35534
  cancelDrag: "#spellbook-search, #shortcuts_list, .spell"
35739
- }, React.createElement(Container$j, null, React.createElement(Title$6, null, "Learned Spells"), React.createElement(SpellbookShortcuts, {
35535
+ }, React.createElement(Container$h, null, React.createElement(Title$6, null, "Learned Spells"), React.createElement(SpellbookShortcuts, {
35740
35536
  setSettingShortcutIndex: setSettingShortcutIndex,
35741
35537
  settingShortcutIndex: settingShortcutIndex,
35742
35538
  shortcuts: spellShortcuts,
@@ -35766,7 +35562,7 @@ var Title$6 = /*#__PURE__*/styled.h1.withConfig({
35766
35562
  displayName: "Spellbook__Title",
35767
35563
  componentId: "sc-r02nfq-0"
35768
35564
  })(["font-size:", " !important;margin-bottom:0 !important;"], uiFonts.size.large);
35769
- var Container$j = /*#__PURE__*/styled.div.withConfig({
35565
+ var Container$h = /*#__PURE__*/styled.div.withConfig({
35770
35566
  displayName: "Spellbook__Container",
35771
35567
  componentId: "sc-r02nfq-1"
35772
35568
  })(["width:100%;height:100%;color:white;display:flex;flex-direction:column;"]);
@@ -35780,16 +35576,16 @@ var TextArea = function TextArea(_ref) {
35780
35576
  return React.createElement("textarea", Object.assign({}, props));
35781
35577
  };
35782
35578
 
35783
- var img$a = '';
35579
+ var img$9 = '';
35784
35580
 
35785
- var img$b = '';
35581
+ var img$a = '';
35786
35582
 
35787
- var img$c = '';
35583
+ var img$b = '';
35788
35584
 
35789
35585
  var DayNightPeriod = function DayNightPeriod(_ref) {
35790
35586
  var _periodOfDaySrcFiles;
35791
35587
  var periodOfDay = _ref.periodOfDay;
35792
- var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[PeriodOfDay.Morning] = img$b, _periodOfDaySrcFiles[PeriodOfDay.Afternoon] = img$a, _periodOfDaySrcFiles[PeriodOfDay.Night] = img$c, _periodOfDaySrcFiles);
35588
+ var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[PeriodOfDay.Morning] = img$a, _periodOfDaySrcFiles[PeriodOfDay.Afternoon] = img$9, _periodOfDaySrcFiles[PeriodOfDay.Night] = img$b, _periodOfDaySrcFiles);
35793
35589
  return React.createElement(GifContainer, null, React.createElement("img", {
35794
35590
  src: periodOfDaySrcFiles[periodOfDay]
35795
35591
  }));
@@ -35799,7 +35595,7 @@ var GifContainer = /*#__PURE__*/styled.div.withConfig({
35799
35595
  componentId: "sc-10t97fw-0"
35800
35596
  })(["width:100%;img{width:67%;}"]);
35801
35597
 
35802
- var img$d = '';
35598
+ var img$c = '';
35803
35599
 
35804
35600
  var TimeWidget = function TimeWidget(_ref) {
35805
35601
  var onClose = _ref.onClose,
@@ -35814,7 +35610,7 @@ var TimeWidget = function TimeWidget(_ref) {
35814
35610
  var WidgetContainer = /*#__PURE__*/styled.div.withConfig({
35815
35611
  displayName: "TimeWidget__WidgetContainer",
35816
35612
  componentId: "sc-1ja236h-0"
35817
- })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$d);
35613
+ })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$c);
35818
35614
  var Time = /*#__PURE__*/styled.div.withConfig({
35819
35615
  displayName: "TimeWidget__Time",
35820
35616
  componentId: "sc-1ja236h-1"
@@ -36064,16 +35860,230 @@ var Truncate = function Truncate(_ref) {
36064
35860
  var _ref$maxLines = _ref.maxLines,
36065
35861
  maxLines = _ref$maxLines === void 0 ? 1 : _ref$maxLines,
36066
35862
  children = _ref.children;
36067
- return React.createElement(Container$k, {
35863
+ return React.createElement(Container$i, {
36068
35864
  maxLines: maxLines
36069
35865
  }, children);
36070
35866
  };
36071
- var Container$k = /*#__PURE__*/styled.div.withConfig({
35867
+ var Container$i = /*#__PURE__*/styled.div.withConfig({
36072
35868
  displayName: "Truncate__Container",
36073
35869
  componentId: "sc-6x00qb-0"
36074
35870
  })(["display:-webkit-box;max-width:100%;max-height:100%;-webkit-line-clamp:", ";-webkit-box-orient:vertical;overflow:hidden;"], function (props) {
36075
35871
  return props.maxLines;
36076
35872
  });
36077
35873
 
35874
+ var IS_MOBILE_OR_TABLET = /*#__PURE__*/isMobileOrTablet();
35875
+
35876
+ var chunkString = function chunkString(str, length) {
35877
+ return str.match(new RegExp('.{1,' + length + '}', 'g'));
35878
+ };
35879
+
35880
+ var img$d = '';
35881
+
35882
+ var NPCDialogText = function NPCDialogText(_ref) {
35883
+ var text = _ref.text,
35884
+ onClose = _ref.onClose,
35885
+ onEndStep = _ref.onEndStep,
35886
+ onStartStep = _ref.onStartStep,
35887
+ type = _ref.type;
35888
+ var windowSize = useRef([window.innerWidth, window.innerHeight]);
35889
+ function maxCharacters(width) {
35890
+ // Set the font size to 16 pixels
35891
+ var fontSize = 11.2;
35892
+ // Calculate the number of characters that can fit in one line
35893
+ var charactersPerLine = Math.floor(width / 2 / fontSize);
35894
+ // Calculate the number of lines that can fit in the div
35895
+ var linesPerDiv = Math.floor(180 / fontSize);
35896
+ // Calculate the maximum number of characters that can fit in the div
35897
+ var maxCharacters = charactersPerLine * linesPerDiv;
35898
+ // Return the maximum number of characters
35899
+ return Math.round(maxCharacters / 5);
35900
+ }
35901
+ var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
35902
+ var _useState = useState(0),
35903
+ chunkIndex = _useState[0],
35904
+ setChunkIndex = _useState[1];
35905
+ var onHandleSpacePress = function onHandleSpacePress(event) {
35906
+ if (event.code === 'Space') {
35907
+ goToNextStep();
35908
+ }
35909
+ };
35910
+ var goToNextStep = function goToNextStep() {
35911
+ var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
35912
+ if (hasNextChunk) {
35913
+ setChunkIndex(function (prev) {
35914
+ return prev + 1;
35915
+ });
35916
+ } else {
35917
+ // if there's no more text chunks, close the dialog
35918
+ onClose();
35919
+ }
35920
+ };
35921
+ useEffect(function () {
35922
+ document.addEventListener('keydown', onHandleSpacePress);
35923
+ return function () {
35924
+ return document.removeEventListener('keydown', onHandleSpacePress);
35925
+ };
35926
+ }, [chunkIndex]);
35927
+ var _useState2 = useState(false),
35928
+ showGoNextIndicator = _useState2[0],
35929
+ setShowGoNextIndicator = _useState2[1];
35930
+ return React.createElement(Container$j, null, React.createElement(DynamicText, {
35931
+ text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
35932
+ onFinish: function onFinish() {
35933
+ setShowGoNextIndicator(true);
35934
+ onEndStep && onEndStep();
35935
+ },
35936
+ onStart: function onStart() {
35937
+ setShowGoNextIndicator(false);
35938
+ onStartStep && onStartStep();
35939
+ }
35940
+ }), showGoNextIndicator && React.createElement(PressSpaceIndicator$1, {
35941
+ right: type === NPCDialogType.TextOnly ? '1rem' : '10.5rem',
35942
+ src: IS_MOBILE_OR_TABLET ? img$d : img$7,
35943
+ onClick: function onClick() {
35944
+ goToNextStep();
35945
+ }
35946
+ }));
35947
+ };
35948
+ var Container$j = /*#__PURE__*/styled.div.withConfig({
35949
+ displayName: "NPCDialogText__Container",
35950
+ componentId: "sc-1cxkdh9-0"
35951
+ })([""]);
35952
+ var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
35953
+ displayName: "NPCDialogText__PressSpaceIndicator",
35954
+ componentId: "sc-1cxkdh9-1"
35955
+ })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
35956
+ var right = _ref2.right;
35957
+ return right;
35958
+ });
35959
+
35960
+ var NPCDialogType;
35961
+ (function (NPCDialogType) {
35962
+ NPCDialogType["TextOnly"] = "TextOnly";
35963
+ NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
35964
+ })(NPCDialogType || (NPCDialogType = {}));
35965
+ var NPCDialog = function NPCDialog(_ref) {
35966
+ var text = _ref.text,
35967
+ type = _ref.type,
35968
+ _onClose = _ref.onClose,
35969
+ imagePath = _ref.imagePath,
35970
+ _ref$isQuestionDialog = _ref.isQuestionDialog,
35971
+ isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
35972
+ questions = _ref.questions,
35973
+ answers = _ref.answers;
35974
+ return React.createElement(RPGUIContainer, {
35975
+ type: RPGUIContainerTypes.FramedGold,
35976
+ width: isQuestionDialog ? '600px' : '80%',
35977
+ height: '180px'
35978
+ }, isQuestionDialog && questions && answers ? React.createElement(React.Fragment, null, React.createElement(TextContainer$2, {
35979
+ flex: type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'
35980
+ }, React.createElement(QuestionDialog, {
35981
+ questions: questions,
35982
+ answers: answers,
35983
+ onClose: function onClose() {
35984
+ if (_onClose) {
35985
+ _onClose();
35986
+ }
35987
+ }
35988
+ })), type === NPCDialogType.TextAndThumbnail && React.createElement(ThumbnailContainer$1, null, React.createElement(NPCThumbnail$1, {
35989
+ src: imagePath || img$6
35990
+ }))) : React.createElement(React.Fragment, null, React.createElement(Container$k, null, React.createElement(TextContainer$2, {
35991
+ flex: type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'
35992
+ }, React.createElement(NPCDialogText, {
35993
+ type: type,
35994
+ text: text || 'No text provided.',
35995
+ onClose: function onClose() {
35996
+ if (_onClose) {
35997
+ _onClose();
35998
+ }
35999
+ }
36000
+ })), type === NPCDialogType.TextAndThumbnail && React.createElement(ThumbnailContainer$1, null, React.createElement(NPCThumbnail$1, {
36001
+ src: imagePath || img$6
36002
+ })))));
36003
+ };
36004
+ var Container$k = /*#__PURE__*/styled.div.withConfig({
36005
+ displayName: "NPCDialog__Container",
36006
+ componentId: "sc-1b4aw74-0"
36007
+ })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
36008
+ var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
36009
+ displayName: "NPCDialog__TextContainer",
36010
+ componentId: "sc-1b4aw74-1"
36011
+ })(["flex:", " 0 0;width:355px;"], function (_ref2) {
36012
+ var flex = _ref2.flex;
36013
+ return flex;
36014
+ });
36015
+ var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
36016
+ displayName: "NPCDialog__ThumbnailContainer",
36017
+ componentId: "sc-1b4aw74-2"
36018
+ })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
36019
+ var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
36020
+ displayName: "NPCDialog__NPCThumbnail",
36021
+ componentId: "sc-1b4aw74-3"
36022
+ })(["image-rendering:pixelated;height:128px;width:128px;"]);
36023
+
36024
+ var HistoryDialog = function HistoryDialog(_ref) {
36025
+ var backgroundImgPath = _ref.backgroundImgPath,
36026
+ fullCoverBackground = _ref.fullCoverBackground,
36027
+ questions = _ref.questions,
36028
+ answers = _ref.answers,
36029
+ text = _ref.text,
36030
+ imagePath = _ref.imagePath,
36031
+ textAndTypeArray = _ref.textAndTypeArray,
36032
+ onClose = _ref.onClose;
36033
+ var _useState = useState(0),
36034
+ img = _useState[0],
36035
+ setImage = _useState[1];
36036
+ var onHandleSpacePress = function onHandleSpacePress(event) {
36037
+ if (event.code === 'Space') {
36038
+ if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
36039
+ setImage(function (prev) {
36040
+ return prev + 1;
36041
+ });
36042
+ } else {
36043
+ // if there's no more text chunks, close the dialog
36044
+ onClose();
36045
+ }
36046
+ }
36047
+ };
36048
+ useEffect(function () {
36049
+ document.addEventListener('keydown', onHandleSpacePress);
36050
+ return function () {
36051
+ return document.removeEventListener('keydown', onHandleSpacePress);
36052
+ };
36053
+ }, [backgroundImgPath]);
36054
+ return React.createElement(BackgroundContainer, {
36055
+ imgPath: backgroundImgPath[img],
36056
+ fullImg: fullCoverBackground
36057
+ }, React.createElement(DialogContainer, null, textAndTypeArray ? React.createElement(NPCMultiDialog, {
36058
+ textAndTypeArray: textAndTypeArray,
36059
+ onClose: onClose
36060
+ }) : questions && answers ? React.createElement(QuestionDialog, {
36061
+ questions: questions,
36062
+ answers: answers,
36063
+ onClose: onClose
36064
+ }) : text && imagePath ? React.createElement(NPCDialog, {
36065
+ text: text,
36066
+ imagePath: imagePath,
36067
+ onClose: onClose,
36068
+ type: NPCDialogType.TextAndThumbnail
36069
+ }) : React.createElement(NPCDialog, {
36070
+ text: text,
36071
+ onClose: onClose,
36072
+ type: NPCDialogType.TextOnly
36073
+ })));
36074
+ };
36075
+ var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
36076
+ displayName: "HistoryDialog__BackgroundContainer",
36077
+ componentId: "sc-u6oe75-0"
36078
+ })(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
36079
+ return props.imgPath;
36080
+ }, function (props) {
36081
+ return props.imgPath ? 'cover' : 'auto';
36082
+ });
36083
+ var DialogContainer = /*#__PURE__*/styled.div.withConfig({
36084
+ displayName: "HistoryDialog__DialogContainer",
36085
+ componentId: "sc-u6oe75-1"
36086
+ })(["display:flex;justify-content:center;padding-top:200px;"]);
36087
+
36078
36088
  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 };
36079
36089
  //# sourceMappingURL=long-bow.esm.js.map