@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
@@ -33895,14 +33895,16 @@ var ItemSlot = /*#__PURE__*/mobxReactLite.observer(function (_ref) {
33895
33895
  var resetItem = function resetItem() {
33896
33896
  setTooltipVisible(false);
33897
33897
  setWasDragged(false);
33898
- setIsFocused(false);
33899
33898
  };
33900
33899
  var onSuccesfulDrag = function onSuccesfulDrag(quantity) {
33901
33900
  resetItem();
33902
- if (quantity === -1) setDragPosition({
33903
- x: 0,
33904
- y: 0
33905
- });else if (item) {
33901
+ if (quantity === -1) {
33902
+ setDragPosition({
33903
+ x: 0,
33904
+ y: 0
33905
+ });
33906
+ setIsFocused(false);
33907
+ } else if (item) {
33906
33908
  onDragEnd(quantity);
33907
33909
  }
33908
33910
  };
@@ -33959,6 +33961,7 @@ var ItemSlot = /*#__PURE__*/mobxReactLite.observer(function (_ref) {
33959
33961
  if (item.stackQty && item.stackQty !== 1 && openQuantitySelector) openQuantitySelector(item.stackQty, onSuccesfulDrag);else onSuccesfulDrag(item.stackQty);
33960
33962
  } else {
33961
33963
  resetItem();
33964
+ setIsFocused(false);
33962
33965
  setDragPosition({
33963
33966
  x: 0,
33964
33967
  y: 0
@@ -34152,388 +34155,439 @@ var EquipmentColumn = /*#__PURE__*/styled.div.withConfig({
34152
34155
  componentId: "sc-1wuddg2-1"
34153
34156
  })(["display:flex;justify-content:center;flex-wrap:wrap;flex-direction:column;touch-action:none;"]);
34154
34157
 
34155
- var IS_MOBILE_OR_TABLET = /*#__PURE__*/shared.isMobileOrTablet();
34156
-
34157
- var chunkString = function chunkString(str, length) {
34158
- return str.match(new RegExp('.{1,' + length + '}', 'g'));
34159
- };
34160
-
34161
- var DynamicText = function DynamicText(_ref) {
34162
- var text = _ref.text,
34163
- onFinish = _ref.onFinish,
34164
- onStart = _ref.onStart;
34165
- var _useState = React.useState(''),
34166
- textState = _useState[0],
34167
- setTextState = _useState[1];
34168
- React.useEffect(function () {
34169
- var i = 0;
34170
- var interval = setInterval(function () {
34171
- // on every interval, show one more character
34172
- if (i === 0) {
34173
- if (onStart) {
34174
- onStart();
34175
- }
34158
+ var SlotsContainer = function SlotsContainer(_ref) {
34159
+ var children = _ref.children,
34160
+ title = _ref.title,
34161
+ onClose = _ref.onClose,
34162
+ _onPositionChange = _ref.onPositionChange,
34163
+ onOutsideClick = _ref.onOutsideClick,
34164
+ initialPosition = _ref.initialPosition;
34165
+ return React__default.createElement(DraggableContainer, {
34166
+ title: title,
34167
+ type: exports.RPGUIContainerTypes.Framed,
34168
+ onCloseButton: function onCloseButton() {
34169
+ if (onClose) {
34170
+ onClose();
34176
34171
  }
34177
- if (i < text.length) {
34178
- setTextState(text.substring(0, i + 1));
34179
- i++;
34180
- } else {
34181
- clearInterval(interval);
34182
- if (onFinish) {
34183
- onFinish();
34184
- }
34172
+ },
34173
+ width: "330px",
34174
+ cancelDrag: ".item-container-body",
34175
+ onPositionChange: function onPositionChange(_ref2) {
34176
+ var x = _ref2.x,
34177
+ y = _ref2.y;
34178
+ if (_onPositionChange) {
34179
+ _onPositionChange({
34180
+ x: x,
34181
+ y: y
34182
+ });
34185
34183
  }
34186
- }, 50);
34187
- return function () {
34188
- clearInterval(interval);
34189
- };
34190
- }, [text]);
34191
- return React__default.createElement(TextContainer, null, textState);
34184
+ },
34185
+ onOutsideClick: onOutsideClick,
34186
+ initialPosition: initialPosition
34187
+ }, children);
34192
34188
  };
34193
- var TextContainer = /*#__PURE__*/styled.p.withConfig({
34194
- displayName: "DynamicText__TextContainer",
34195
- componentId: "sc-1ggl9nd-0"
34196
- })(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]);
34197
-
34198
- var img$6 = '';
34199
-
34200
- var img$7 = '';
34201
34189
 
34202
- var NPCDialogText = function NPCDialogText(_ref) {
34203
- var text = _ref.text,
34204
- onClose = _ref.onClose,
34205
- onEndStep = _ref.onEndStep,
34206
- onStartStep = _ref.onStartStep,
34207
- type = _ref.type;
34208
- var windowSize = React.useRef([window.innerWidth, window.innerHeight]);
34209
- function maxCharacters(width) {
34210
- // Set the font size to 16 pixels
34211
- var fontSize = 11.2;
34212
- // Calculate the number of characters that can fit in one line
34213
- var charactersPerLine = Math.floor(width / 2 / fontSize);
34214
- // Calculate the number of lines that can fit in the div
34215
- var linesPerDiv = Math.floor(180 / fontSize);
34216
- // Calculate the maximum number of characters that can fit in the div
34217
- var maxCharacters = charactersPerLine * linesPerDiv;
34218
- // Return the maximum number of characters
34219
- return Math.round(maxCharacters / 5);
34220
- }
34221
- var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
34190
+ (function (RangeSliderType) {
34191
+ RangeSliderType["Slider"] = "rpgui-slider";
34192
+ RangeSliderType["GoldSlider"] = "rpgui-slider golden";
34193
+ })(exports.RangeSliderType || (exports.RangeSliderType = {}));
34194
+ var RangeSlider = function RangeSlider(_ref) {
34195
+ var type = _ref.type,
34196
+ valueMin = _ref.valueMin,
34197
+ valueMax = _ref.valueMax,
34198
+ width = _ref.width,
34199
+ _onChange = _ref.onChange,
34200
+ value = _ref.value;
34201
+ var sliderId = uuid.v4();
34202
+ var containerRef = React.useRef(null);
34222
34203
  var _useState = React.useState(0),
34223
- chunkIndex = _useState[0],
34224
- setChunkIndex = _useState[1];
34225
- var onHandleSpacePress = function onHandleSpacePress(event) {
34226
- if (event.code === 'Space') {
34227
- goToNextStep();
34228
- }
34229
- };
34230
- var goToNextStep = function goToNextStep() {
34231
- var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
34232
- if (hasNextChunk) {
34233
- setChunkIndex(function (prev) {
34234
- return prev + 1;
34235
- });
34236
- } else {
34237
- // if there's no more text chunks, close the dialog
34238
- onClose();
34239
- }
34240
- };
34204
+ left = _useState[0],
34205
+ setLeft = _useState[1];
34241
34206
  React.useEffect(function () {
34242
- document.addEventListener('keydown', onHandleSpacePress);
34243
- return function () {
34244
- return document.removeEventListener('keydown', onHandleSpacePress);
34245
- };
34246
- }, [chunkIndex]);
34247
- var _useState2 = React.useState(false),
34248
- showGoNextIndicator = _useState2[0],
34249
- setShowGoNextIndicator = _useState2[1];
34250
- return React__default.createElement(Container$b, null, React__default.createElement(DynamicText, {
34251
- text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
34252
- onFinish: function onFinish() {
34253
- setShowGoNextIndicator(true);
34254
- onEndStep && onEndStep();
34207
+ var _containerRef$current;
34208
+ var calculatedWidth = ((_containerRef$current = containerRef.current) == null ? void 0 : _containerRef$current.clientWidth) || 0;
34209
+ setLeft(Math.max((value - valueMin) / (valueMax - valueMin) * (calculatedWidth - 35) + 10));
34210
+ }, [value, valueMin, valueMax]);
34211
+ var typeClass = type === exports.RangeSliderType.GoldSlider ? 'golden' : '';
34212
+ return React__default.createElement("div", {
34213
+ style: {
34214
+ width: width,
34215
+ position: 'relative'
34255
34216
  },
34256
- onStart: function onStart() {
34257
- setShowGoNextIndicator(false);
34258
- onStartStep && onStartStep();
34217
+ className: "rpgui-slider-container " + typeClass,
34218
+ id: "rpgui-slider-" + sliderId,
34219
+ ref: containerRef
34220
+ }, React__default.createElement("div", {
34221
+ style: {
34222
+ pointerEvents: 'none'
34259
34223
  }
34260
- }), showGoNextIndicator && React__default.createElement(PressSpaceIndicator, {
34261
- right: type === exports.NPCDialogType.TextOnly ? '1rem' : '10.5rem',
34262
- src: IS_MOBILE_OR_TABLET ? img$6 : img$7,
34263
- onClick: function onClick() {
34264
- goToNextStep();
34224
+ }, React__default.createElement("div", {
34225
+ className: "rpgui-slider-track " + typeClass
34226
+ }), React__default.createElement("div", {
34227
+ className: "rpgui-slider-left-edge " + typeClass
34228
+ }), React__default.createElement("div", {
34229
+ className: "rpgui-slider-right-edge " + typeClass
34230
+ }), React__default.createElement("div", {
34231
+ className: "rpgui-slider-thumb " + typeClass,
34232
+ style: {
34233
+ left: left
34265
34234
  }
34235
+ })), React__default.createElement(Input$1, {
34236
+ type: "range",
34237
+ style: {
34238
+ width: width
34239
+ },
34240
+ min: valueMin,
34241
+ max: valueMax,
34242
+ onChange: function onChange(e) {
34243
+ return _onChange(Number(e.target.value));
34244
+ },
34245
+ value: value,
34246
+ className: "rpgui-cursor-point"
34266
34247
  }));
34267
34248
  };
34268
- var Container$b = /*#__PURE__*/styled.div.withConfig({
34269
- displayName: "NPCDialogText__Container",
34270
- componentId: "sc-1cxkdh9-0"
34271
- })([""]);
34272
- var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
34273
- displayName: "NPCDialogText__PressSpaceIndicator",
34274
- componentId: "sc-1cxkdh9-1"
34275
- })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
34276
- var right = _ref2.right;
34277
- return right;
34278
- });
34279
-
34280
- //@ts-ignore
34281
- var useEventListener = function useEventListener(type, handler, el) {
34282
- if (el === void 0) {
34283
- el = window;
34284
- }
34285
- var savedHandler = React__default.useRef();
34286
- React__default.useEffect(function () {
34287
- savedHandler.current = handler;
34288
- }, [handler]);
34289
- React__default.useEffect(function () {
34290
- //@ts-ignore
34291
- var listener = function listener(e) {
34292
- return savedHandler.current(e);
34293
- };
34294
- el.addEventListener(type, listener);
34295
- return function () {
34296
- el.removeEventListener(type, listener);
34297
- };
34298
- }, [type, el]);
34299
- };
34249
+ var Input$1 = /*#__PURE__*/styled.input.withConfig({
34250
+ displayName: "RangeSlider__Input",
34251
+ componentId: "sc-v8mte9-0"
34252
+ })(["opacity:0;position:absolute;width:100%;height:100%;top:0;left:0;margin-top:-5px;"]);
34300
34253
 
34301
- var QuestionDialog = function QuestionDialog(_ref) {
34302
- var questions = _ref.questions,
34303
- answers = _ref.answers,
34254
+ var ItemQuantitySelector = function ItemQuantitySelector(_ref) {
34255
+ var quantity = _ref.quantity,
34256
+ onConfirm = _ref.onConfirm,
34304
34257
  onClose = _ref.onClose;
34305
- var _useState = React.useState(questions[0]),
34306
- currentQuestion = _useState[0],
34307
- setCurrentQuestion = _useState[1];
34308
- var _useState2 = React.useState(false),
34309
- canShowAnswers = _useState2[0],
34310
- setCanShowAnswers = _useState2[1];
34311
- var onGetFirstAnswer = function onGetFirstAnswer() {
34312
- if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {
34313
- return null;
34314
- }
34315
- var firstAnswerId = currentQuestion.answerIds[0];
34316
- return answers.find(function (answer) {
34317
- return answer.id === firstAnswerId;
34318
- });
34319
- };
34320
- var _useState3 = React.useState(onGetFirstAnswer()),
34321
- currentAnswer = _useState3[0],
34322
- setCurrentAnswer = _useState3[1];
34258
+ var _useState = React.useState(quantity),
34259
+ value = _useState[0],
34260
+ setValue = _useState[1];
34261
+ var inputRef = React.useRef(null);
34323
34262
  React.useEffect(function () {
34324
- setCurrentAnswer(onGetFirstAnswer());
34325
- }, [currentQuestion]);
34326
- var onGetAnswers = function onGetAnswers(answerIds) {
34327
- return answerIds.map(function (answerId) {
34328
- return answers.find(function (answer) {
34329
- return answer.id === answerId;
34330
- });
34331
- });
34332
- };
34333
- var onKeyPress = function onKeyPress(e) {
34334
- switch (e.key) {
34335
- case 'ArrowDown':
34336
- // select next answer, if any.
34337
- // if no next answer, select first answer
34338
- // const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(
34339
- // (answer) => answer?.id === currentAnswer!.id + 1
34340
- // );
34341
- var nextAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34342
- return (answer == null ? void 0 : answer.id) === currentAnswer.id + 1;
34343
- });
34344
- var nextAnswerID = currentQuestion.answerIds[nextAnswerIndex];
34345
- var nextAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34346
- return (answer == null ? void 0 : answer.id) === nextAnswerID;
34347
- });
34348
- setCurrentAnswer(nextAnswer || onGetFirstAnswer());
34349
- break;
34350
- case 'ArrowUp':
34351
- // select previous answer, if any.
34352
- // if no previous answer, select last answer
34353
- var previousAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34354
- return (answer == null ? void 0 : answer.id) === currentAnswer.id - 1;
34355
- });
34356
- var previousAnswerID = currentQuestion.answerIds && currentQuestion.answerIds[previousAnswerIndex];
34357
- var previousAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34358
- return (answer == null ? void 0 : answer.id) === previousAnswerID;
34359
- });
34360
- if (previousAnswer) {
34361
- setCurrentAnswer(previousAnswer);
34362
- } else {
34363
- setCurrentAnswer(onGetAnswers(currentQuestion.answerIds).pop());
34364
- }
34365
- break;
34366
- case 'Enter':
34367
- setCanShowAnswers(false);
34368
- if (!(currentAnswer != null && currentAnswer.nextQuestionId)) {
34263
+ if (inputRef.current) {
34264
+ inputRef.current.focus();
34265
+ inputRef.current.select();
34266
+ var closeSelector = function closeSelector(e) {
34267
+ if (e.key === 'Escape') {
34369
34268
  onClose();
34370
- return;
34371
- } else {
34372
- setCurrentQuestion(questions.find(function (question) {
34373
- return question.id === currentAnswer.nextQuestionId;
34374
- }));
34375
34269
  }
34376
- break;
34377
- }
34378
- };
34379
- useEventListener('keydown', onKeyPress);
34380
- var onAnswerClick = function onAnswerClick(answer) {
34381
- setCanShowAnswers(false);
34382
- if (answer.nextQuestionId) {
34383
- // if there is a next question, go to it
34384
- setCurrentQuestion(questions.find(function (question) {
34385
- return question.id === answer.nextQuestionId;
34386
- }));
34387
- } else {
34388
- // else, finish dialog!
34389
- onClose();
34390
- }
34391
- };
34392
- var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
34393
- var answerIds = currentQuestion.answerIds;
34394
- if (!answerIds) {
34395
- return null;
34396
- }
34397
- var answers = onGetAnswers(answerIds);
34398
- if (!answers) {
34399
- return null;
34270
+ };
34271
+ document.addEventListener('keydown', closeSelector);
34272
+ return function () {
34273
+ document.removeEventListener('keydown', closeSelector);
34274
+ };
34400
34275
  }
34401
- return answers.map(function (answer) {
34402
- var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
34403
- var selectedColor = isSelected ? 'yellow' : 'white';
34404
- if (answer) {
34405
- return React__default.createElement(AnswerRow, {
34406
- key: "answer_" + answer.id
34407
- }, React__default.createElement(AnswerSelectedIcon, {
34408
- color: selectedColor
34409
- }, isSelected ? 'X' : null), React__default.createElement(Answer, {
34410
- key: answer.id,
34411
- onClick: function onClick() {
34412
- return onAnswerClick(answer);
34413
- },
34414
- color: selectedColor
34415
- }, answer.text));
34416
- }
34417
- return null;
34418
- });
34419
- };
34420
- return React__default.createElement(Container$c, null, React__default.createElement(QuestionContainer, null, React__default.createElement(DynamicText, {
34421
- text: currentQuestion.text,
34422
- onStart: function onStart() {
34423
- return setCanShowAnswers(false);
34276
+ return function () {};
34277
+ }, []);
34278
+ return React__default.createElement(StyledContainer, {
34279
+ type: exports.RPGUIContainerTypes.Framed,
34280
+ width: "25rem"
34281
+ }, React__default.createElement(CloseButton$2, {
34282
+ className: "container-close",
34283
+ onClick: onClose,
34284
+ onTouchStart: onClose
34285
+ }, "X"), React__default.createElement("h2", null, "Select quantity to move"), React__default.createElement(StyledForm, {
34286
+ style: {
34287
+ width: '100%'
34424
34288
  },
34425
- onFinish: function onFinish() {
34426
- return setCanShowAnswers(true);
34427
- }
34428
- })), canShowAnswers && React__default.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
34429
- };
34430
- var Container$c = /*#__PURE__*/styled.div.withConfig({
34431
- displayName: "QuestionDialog__Container",
34432
- componentId: "sc-bxc5u0-0"
34433
- })(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
34434
- var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
34435
- displayName: "QuestionDialog__QuestionContainer",
34436
- componentId: "sc-bxc5u0-1"
34437
- })(["flex:100%;width:100%;"]);
34438
- var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
34439
- displayName: "QuestionDialog__AnswersContainer",
34440
- componentId: "sc-bxc5u0-2"
34441
- })(["flex:100%;"]);
34442
- var Answer = /*#__PURE__*/styled.p.withConfig({
34443
- displayName: "QuestionDialog__Answer",
34444
- componentId: "sc-bxc5u0-3"
34445
- })(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
34446
- return props.color;
34447
- });
34448
- var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
34449
- displayName: "QuestionDialog__AnswerSelectedIcon",
34450
- componentId: "sc-bxc5u0-4"
34451
- })(["flex:5% 0 0;color:", " !important;"], function (props) {
34452
- return props.color;
34453
- });
34454
- var AnswerRow = /*#__PURE__*/styled.div.withConfig({
34455
- displayName: "QuestionDialog__AnswerRow",
34456
- componentId: "sc-bxc5u0-5"
34457
- })(["display:flex;flex-wrap:wrap;justify-content:center;align-items:center;margin-bottom:0.5rem;height:22px;p{line-height:unset;margin-top:0;margin-bottom:0rem;}"]);
34458
-
34459
- var img$8 = '';
34460
-
34461
- (function (NPCDialogType) {
34462
- NPCDialogType["TextOnly"] = "TextOnly";
34463
- NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
34464
- })(exports.NPCDialogType || (exports.NPCDialogType = {}));
34465
- var NPCDialog = function NPCDialog(_ref) {
34466
- var text = _ref.text,
34467
- type = _ref.type,
34468
- _onClose = _ref.onClose,
34469
- imagePath = _ref.imagePath,
34470
- _ref$isQuestionDialog = _ref.isQuestionDialog,
34471
- isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
34472
- questions = _ref.questions,
34473
- answers = _ref.answers;
34474
- return React__default.createElement(RPGUIContainer, {
34475
- type: exports.RPGUIContainerTypes.FramedGold,
34476
- width: isQuestionDialog ? '600px' : '80%',
34477
- height: '180px'
34478
- }, isQuestionDialog && questions && answers ? React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer$1, {
34479
- flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
34480
- }, React__default.createElement(QuestionDialog, {
34481
- questions: questions,
34482
- answers: answers,
34483
- onClose: function onClose() {
34484
- if (_onClose) {
34485
- _onClose();
34289
+ onSubmit: function onSubmit(e) {
34290
+ e.preventDefault();
34291
+ var numberValue = Number(value);
34292
+ if (Number.isNaN(numberValue)) {
34293
+ return;
34486
34294
  }
34487
- }
34488
- })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
34489
- src: imagePath || img$8
34490
- }))) : React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$d, null, React__default.createElement(TextContainer$1, {
34491
- flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
34492
- }, React__default.createElement(NPCDialogText, {
34493
- type: type,
34494
- text: text || 'No text provided.',
34495
- onClose: function onClose() {
34496
- if (_onClose) {
34497
- _onClose();
34295
+ onConfirm(Math.max(1, Math.min(quantity, numberValue)));
34296
+ },
34297
+ noValidate: true
34298
+ }, React__default.createElement(StyledInput, {
34299
+ innerRef: inputRef,
34300
+ placeholder: "Enter quantity",
34301
+ type: "number",
34302
+ min: 1,
34303
+ max: quantity,
34304
+ value: value,
34305
+ onChange: function onChange(e) {
34306
+ if (Number(e.target.value) >= quantity) {
34307
+ setValue(quantity);
34308
+ return;
34498
34309
  }
34310
+ setValue(e.target.value);
34311
+ },
34312
+ onBlur: function onBlur(e) {
34313
+ var newValue = Math.max(1, Math.min(quantity, Number(e.target.value)));
34314
+ setValue(newValue);
34499
34315
  }
34500
- })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
34501
- src: imagePath || img$8
34502
- })))));
34316
+ }), React__default.createElement(RangeSlider, {
34317
+ type: exports.RangeSliderType.Slider,
34318
+ valueMin: 1,
34319
+ valueMax: quantity,
34320
+ width: "100%",
34321
+ onChange: setValue,
34322
+ value: value
34323
+ }), React__default.createElement(Button, {
34324
+ buttonType: exports.ButtonTypes.RPGUIButton,
34325
+ type: "submit"
34326
+ }, "Confirm")));
34503
34327
  };
34504
- var Container$d = /*#__PURE__*/styled.div.withConfig({
34505
- displayName: "NPCDialog__Container",
34506
- componentId: "sc-1b4aw74-0"
34507
- })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
34508
- var TextContainer$1 = /*#__PURE__*/styled.div.withConfig({
34509
- displayName: "NPCDialog__TextContainer",
34510
- componentId: "sc-1b4aw74-1"
34511
- })(["flex:", " 0 0;width:355px;"], function (_ref2) {
34512
- var flex = _ref2.flex;
34513
- return flex;
34514
- });
34515
- var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
34516
- displayName: "NPCDialog__ThumbnailContainer",
34517
- componentId: "sc-1b4aw74-2"
34518
- })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
34519
- var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
34520
- displayName: "NPCDialog__NPCThumbnail",
34521
- componentId: "sc-1b4aw74-3"
34522
- })(["image-rendering:pixelated;height:128px;width:128px;"]);
34328
+ var StyledContainer = /*#__PURE__*/styled(RPGUIContainer).withConfig({
34329
+ displayName: "ItemQuantitySelector__StyledContainer",
34330
+ componentId: "sc-yfdtpn-0"
34331
+ })(["display:flex;flex-direction:column;align-items:center;"]);
34332
+ var StyledForm = /*#__PURE__*/styled.form.withConfig({
34333
+ displayName: "ItemQuantitySelector__StyledForm",
34334
+ componentId: "sc-yfdtpn-1"
34335
+ })(["display:flex;flex-direction:column;align-items:center;width:100%;"]);
34336
+ var StyledInput = /*#__PURE__*/styled(Input).withConfig({
34337
+ displayName: "ItemQuantitySelector__StyledInput",
34338
+ componentId: "sc-yfdtpn-2"
34339
+ })(["text-align:center;&::-webkit-outer-spin-button,&::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}&[type='number']{-moz-appearance:textfield;}"]);
34340
+ var CloseButton$2 = /*#__PURE__*/styled.div.withConfig({
34341
+ displayName: "ItemQuantitySelector__CloseButton",
34342
+ componentId: "sc-yfdtpn-3"
34343
+ })(["position:absolute;top:3px;right:0px;color:white;z-index:22;font-size:0.8rem;"]);
34523
34344
 
34524
- (function (ImgSide) {
34525
- ImgSide["right"] = "right";
34526
- ImgSide["left"] = "left";
34527
- })(exports.ImgSide || (exports.ImgSide = {}));
34528
- var NPCMultiDialog = function NPCMultiDialog(_ref) {
34529
- var _textAndTypeArray$sli;
34530
- var _onClose = _ref.onClose,
34531
- textAndTypeArray = _ref.textAndTypeArray;
34532
- var _useState = React.useState(false),
34533
- showGoNextIndicator = _useState[0],
34534
- setShowGoNextIndicator = _useState[1];
34535
- var _useState2 = React.useState(0),
34536
- slide = _useState2[0],
34345
+ var ItemContainer$1 = function ItemContainer(_ref) {
34346
+ var itemContainer = _ref.itemContainer,
34347
+ onClose = _ref.onClose,
34348
+ _onMouseOver = _ref.onMouseOver,
34349
+ _onSelected = _ref.onSelected,
34350
+ onItemClick = _ref.onItemClick,
34351
+ type = _ref.type,
34352
+ atlasJSON = _ref.atlasJSON,
34353
+ atlasIMG = _ref.atlasIMG,
34354
+ _ref$disableContextMe = _ref.disableContextMenu,
34355
+ disableContextMenu = _ref$disableContextMe === void 0 ? false : _ref$disableContextMe,
34356
+ onItemDragEnd = _ref.onItemDragEnd,
34357
+ onItemDragStart = _ref.onItemDragStart,
34358
+ onItemPlaceDrop = _ref.onItemPlaceDrop,
34359
+ _onOutsideDrop = _ref.onOutsideDrop,
34360
+ checkIfItemCanBeMoved = _ref.checkIfItemCanBeMoved,
34361
+ initialPosition = _ref.initialPosition,
34362
+ checkIfItemShouldDragEnd = _ref.checkIfItemShouldDragEnd,
34363
+ dragScale = _ref.dragScale;
34364
+ var _useState = React.useState({
34365
+ isOpen: false,
34366
+ maxQuantity: 1,
34367
+ callback: function callback(_quantity) {}
34368
+ }),
34369
+ quantitySelect = _useState[0],
34370
+ setQuantitySelect = _useState[1];
34371
+ var onRenderSlots = function onRenderSlots() {
34372
+ var slots = [];
34373
+ for (var i = 0; i < itemContainer.slotQty; i++) {
34374
+ var _itemContainer$slots;
34375
+ slots.push(React__default.createElement(ItemSlot, {
34376
+ isContextMenuDisabled: disableContextMenu,
34377
+ key: i,
34378
+ slotIndex: i,
34379
+ item: ((_itemContainer$slots = itemContainer.slots) == null ? void 0 : _itemContainer$slots[i]) || null,
34380
+ itemContainerType: type,
34381
+ onMouseOver: function onMouseOver(event, slotIndex, item) {
34382
+ if (_onMouseOver) _onMouseOver(event, slotIndex, item);
34383
+ },
34384
+ onClick: function onClick(ItemType, ContainerType, item) {
34385
+ if (onItemClick) onItemClick(item, ItemType, ContainerType);
34386
+ },
34387
+ onSelected: function onSelected(optionId, item) {
34388
+ if (_onSelected) _onSelected(optionId, item);
34389
+ },
34390
+ onDragStart: function onDragStart(item, slotIndex, itemContainerType) {
34391
+ if (onItemDragStart) onItemDragStart(item, slotIndex, itemContainerType);
34392
+ },
34393
+ onDragEnd: function onDragEnd(quantity) {
34394
+ if (onItemDragEnd) onItemDragEnd(quantity);
34395
+ },
34396
+ dragScale: dragScale,
34397
+ checkIfItemCanBeMoved: checkIfItemCanBeMoved,
34398
+ checkIfItemShouldDragEnd: checkIfItemShouldDragEnd,
34399
+ openQuantitySelector: function openQuantitySelector(maxQuantity, callback) {
34400
+ setQuantitySelect({
34401
+ isOpen: true,
34402
+ maxQuantity: maxQuantity,
34403
+ callback: callback
34404
+ });
34405
+ },
34406
+ onPlaceDrop: function onPlaceDrop(item, slotIndex, itemContainerType) {
34407
+ if (onItemPlaceDrop) onItemPlaceDrop(item, slotIndex, itemContainerType);
34408
+ },
34409
+ onOutsideDrop: function onOutsideDrop(item, position) {
34410
+ if (_onOutsideDrop) _onOutsideDrop(item, position);
34411
+ },
34412
+ atlasIMG: atlasIMG,
34413
+ atlasJSON: atlasJSON
34414
+ }));
34415
+ }
34416
+ return slots;
34417
+ };
34418
+ return React__default.createElement(React__default.Fragment, null, React__default.createElement(SlotsContainer, {
34419
+ title: itemContainer.name || 'Container',
34420
+ onClose: onClose,
34421
+ initialPosition: initialPosition
34422
+ }, React__default.createElement(ItemsContainer, {
34423
+ className: "item-container-body"
34424
+ }, onRenderSlots())), quantitySelect.isOpen && React__default.createElement(QuantitySelectorContainer, null, React__default.createElement(ItemQuantitySelector, {
34425
+ quantity: quantitySelect.maxQuantity,
34426
+ onConfirm: function onConfirm(quantity) {
34427
+ quantitySelect.callback(quantity);
34428
+ setQuantitySelect({
34429
+ isOpen: false,
34430
+ maxQuantity: 1,
34431
+ callback: function callback() {}
34432
+ });
34433
+ },
34434
+ onClose: function onClose() {
34435
+ quantitySelect.callback(-1);
34436
+ setQuantitySelect({
34437
+ isOpen: false,
34438
+ maxQuantity: 1,
34439
+ callback: function callback() {}
34440
+ });
34441
+ }
34442
+ })));
34443
+ };
34444
+ var ItemsContainer = /*#__PURE__*/styled.div.withConfig({
34445
+ displayName: "ItemContainer__ItemsContainer",
34446
+ componentId: "sc-15y5p9l-0"
34447
+ })(["max-width:280px;display:flex;justify-content:center;flex-wrap:wrap;"]);
34448
+ var QuantitySelectorContainer = /*#__PURE__*/styled.div.withConfig({
34449
+ displayName: "ItemContainer__QuantitySelectorContainer",
34450
+ componentId: "sc-15y5p9l-1"
34451
+ })(["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);"]);
34452
+
34453
+ var ItemSelector = function ItemSelector(_ref) {
34454
+ var atlasIMG = _ref.atlasIMG,
34455
+ atlasJSON = _ref.atlasJSON,
34456
+ options = _ref.options,
34457
+ onClose = _ref.onClose,
34458
+ onSelect = _ref.onSelect;
34459
+ var _useState = React.useState(),
34460
+ selectedValue = _useState[0],
34461
+ setSelectedValue = _useState[1];
34462
+ var handleClick = function handleClick() {
34463
+ var element = document.querySelector("input[name='test']:checked");
34464
+ var elementValue = element.value;
34465
+ setSelectedValue(elementValue);
34466
+ };
34467
+ React.useEffect(function () {
34468
+ if (selectedValue) {
34469
+ onSelect(selectedValue);
34470
+ }
34471
+ }, [selectedValue]);
34472
+ return React__default.createElement(DraggableContainer, {
34473
+ type: exports.RPGUIContainerTypes.Framed,
34474
+ width: "500px",
34475
+ cancelDrag: ".equipment-container-body .arrow-selector",
34476
+ onCloseButton: function onCloseButton() {
34477
+ if (onClose) {
34478
+ onClose();
34479
+ }
34480
+ }
34481
+ }, React__default.createElement("div", {
34482
+ style: {
34483
+ width: '100%'
34484
+ }
34485
+ }, React__default.createElement(Title$2, null, 'Harvesting instruments'), React__default.createElement(Subtitle$1, null, 'Use the tool, you need it'), React__default.createElement("hr", {
34486
+ className: "golden"
34487
+ })), React__default.createElement(RadioInputScroller$1, null, options == null ? void 0 : options.map(function (option, index) {
34488
+ return React__default.createElement(RadioOptionsWrapper$1, {
34489
+ key: index
34490
+ }, React__default.createElement(SpriteAtlasWrapper$1, null, React__default.createElement(SpriteFromAtlas, {
34491
+ atlasIMG: atlasIMG,
34492
+ atlasJSON: atlasJSON,
34493
+ spriteKey: option.imageKey,
34494
+ imgScale: 3
34495
+ })), React__default.createElement("div", null, React__default.createElement("input", {
34496
+ className: "rpgui-radio",
34497
+ type: "radio",
34498
+ value: option.name,
34499
+ name: "test"
34500
+ }), React__default.createElement("label", {
34501
+ onClick: handleClick,
34502
+ style: {
34503
+ display: 'flex',
34504
+ alignItems: 'center'
34505
+ }
34506
+ }, option.name, " ", React__default.createElement("br", null), option.description)));
34507
+ })), React__default.createElement(ButtonWrapper$1, null, React__default.createElement(Button, {
34508
+ buttonType: exports.ButtonTypes.RPGUIButton,
34509
+ onClick: onClose
34510
+ }, "Cancel"), React__default.createElement(Button, {
34511
+ buttonType: exports.ButtonTypes.RPGUIButton
34512
+ }, "Select")));
34513
+ };
34514
+ var Title$2 = /*#__PURE__*/styled.h1.withConfig({
34515
+ displayName: "ItemSelector__Title",
34516
+ componentId: "sc-gptoxp-0"
34517
+ })(["font-size:0.6rem;color:yellow !important;"]);
34518
+ var Subtitle$1 = /*#__PURE__*/styled.h1.withConfig({
34519
+ displayName: "ItemSelector__Subtitle",
34520
+ componentId: "sc-gptoxp-1"
34521
+ })(["font-size:0.4rem;color:yellow !important;"]);
34522
+ var RadioInputScroller$1 = /*#__PURE__*/styled.div.withConfig({
34523
+ displayName: "ItemSelector__RadioInputScroller",
34524
+ componentId: "sc-gptoxp-2"
34525
+ })(["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;"]);
34526
+ var SpriteAtlasWrapper$1 = /*#__PURE__*/styled.div.withConfig({
34527
+ displayName: "ItemSelector__SpriteAtlasWrapper",
34528
+ componentId: "sc-gptoxp-3"
34529
+ })(["margin-right:40px;"]);
34530
+ var RadioOptionsWrapper$1 = /*#__PURE__*/styled.div.withConfig({
34531
+ displayName: "ItemSelector__RadioOptionsWrapper",
34532
+ componentId: "sc-gptoxp-4"
34533
+ })(["display:flex;align-items:stretch;margin-bottom:40px;"]);
34534
+ var ButtonWrapper$1 = /*#__PURE__*/styled.div.withConfig({
34535
+ displayName: "ItemSelector__ButtonWrapper",
34536
+ componentId: "sc-gptoxp-5"
34537
+ })(["display:flex;justify-content:space-around;padding-top:20px;width:100%;"]);
34538
+
34539
+ var ListMenu = function ListMenu(_ref) {
34540
+ var options = _ref.options,
34541
+ onSelected = _ref.onSelected,
34542
+ x = _ref.x,
34543
+ y = _ref.y;
34544
+ return React__default.createElement(Container$b, {
34545
+ x: x,
34546
+ y: y
34547
+ }, React__default.createElement("ul", {
34548
+ className: "rpgui-list-imp",
34549
+ style: {
34550
+ overflow: 'hidden'
34551
+ }
34552
+ }, options.map(function (params, index) {
34553
+ return React__default.createElement(ListElement$1, {
34554
+ key: (params == null ? void 0 : params.id) || index,
34555
+ onClick: function onClick() {
34556
+ onSelected(params == null ? void 0 : params.id);
34557
+ }
34558
+ }, (params == null ? void 0 : params.text) || 'No text');
34559
+ })));
34560
+ };
34561
+ var Container$b = /*#__PURE__*/styled.div.withConfig({
34562
+ displayName: "ListMenu__Container",
34563
+ componentId: "sc-i9097t-0"
34564
+ })(["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) {
34565
+ return props.y || 0;
34566
+ }, function (props) {
34567
+ return props.x || 0;
34568
+ }, uiFonts.size.xsmall);
34569
+ var ListElement$1 = /*#__PURE__*/styled.li.withConfig({
34570
+ displayName: "ListMenu__ListElement",
34571
+ componentId: "sc-i9097t-1"
34572
+ })(["margin-right:0.5rem;"]);
34573
+
34574
+ var img$6 = '';
34575
+
34576
+ var img$7 = '';
34577
+
34578
+ (function (ImgSide) {
34579
+ ImgSide["right"] = "right";
34580
+ ImgSide["left"] = "left";
34581
+ })(exports.ImgSide || (exports.ImgSide = {}));
34582
+ var NPCMultiDialog = function NPCMultiDialog(_ref) {
34583
+ var _textAndTypeArray$sli;
34584
+ var _onClose = _ref.onClose,
34585
+ textAndTypeArray = _ref.textAndTypeArray;
34586
+ var _useState = React.useState(false),
34587
+ showGoNextIndicator = _useState[0],
34588
+ setShowGoNextIndicator = _useState[1];
34589
+ var _useState2 = React.useState(0),
34590
+ slide = _useState2[0],
34537
34591
  setSlide = _useState2[1];
34538
34592
  var onHandleSpacePress = function onHandleSpacePress(event) {
34539
34593
  if (event.code === 'Space') {
@@ -34557,7 +34611,7 @@ var NPCMultiDialog = function NPCMultiDialog(_ref) {
34557
34611
  type: exports.RPGUIContainerTypes.FramedGold,
34558
34612
  width: '50%',
34559
34613
  height: '180px'
34560
- }, React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$e, null, ((_textAndTypeArray$sli = textAndTypeArray[slide]) == null ? void 0 : _textAndTypeArray$sli.imageSide) === 'right' && React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer$2, {
34614
+ }, React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$c, null, ((_textAndTypeArray$sli = textAndTypeArray[slide]) == null ? void 0 : _textAndTypeArray$sli.imageSide) === 'right' && React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer, {
34561
34615
  flex: '70%'
34562
34616
  }, React__default.createElement(NPCDialogText, {
34563
34617
  onStartStep: function onStartStep() {
@@ -34572,14 +34626,14 @@ var NPCMultiDialog = function NPCMultiDialog(_ref) {
34572
34626
  _onClose();
34573
34627
  }
34574
34628
  }
34575
- })), React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
34576
- src: textAndTypeArray[slide].imagePath || img$8
34577
- })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator$1, {
34629
+ })), React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
34630
+ src: textAndTypeArray[slide].imagePath || img$6
34631
+ })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator, {
34578
34632
  right: '10.5rem',
34579
34633
  src: img$7
34580
- })), textAndTypeArray[slide].imageSide === 'left' && React__default.createElement(React__default.Fragment, null, React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
34581
- src: textAndTypeArray[slide].imagePath || img$8
34582
- })), React__default.createElement(TextContainer$2, {
34634
+ })), textAndTypeArray[slide].imageSide === 'left' && React__default.createElement(React__default.Fragment, null, React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
34635
+ src: textAndTypeArray[slide].imagePath || img$6
34636
+ })), React__default.createElement(TextContainer, {
34583
34637
  flex: '70%'
34584
34638
  }, React__default.createElement(NPCDialogText, {
34585
34639
  onStartStep: function onStartStep() {
@@ -34594,31 +34648,31 @@ var NPCMultiDialog = function NPCMultiDialog(_ref) {
34594
34648
  _onClose();
34595
34649
  }
34596
34650
  }
34597
- })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator$1, {
34651
+ })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator, {
34598
34652
  right: '1rem',
34599
34653
  src: img$7
34600
34654
  }))), ")"));
34601
34655
  };
34602
- var Container$e = /*#__PURE__*/styled.div.withConfig({
34656
+ var Container$c = /*#__PURE__*/styled.div.withConfig({
34603
34657
  displayName: "NPCMultiDialog__Container",
34604
34658
  componentId: "sc-rvu5wg-0"
34605
34659
  })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
34606
- var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
34660
+ var TextContainer = /*#__PURE__*/styled.div.withConfig({
34607
34661
  displayName: "NPCMultiDialog__TextContainer",
34608
34662
  componentId: "sc-rvu5wg-1"
34609
34663
  })(["flex:", " 0 0;width:355px;"], function (_ref2) {
34610
34664
  var flex = _ref2.flex;
34611
34665
  return flex;
34612
34666
  });
34613
- var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
34667
+ var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
34614
34668
  displayName: "NPCMultiDialog__ThumbnailContainer",
34615
34669
  componentId: "sc-rvu5wg-2"
34616
34670
  })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
34617
- var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
34671
+ var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
34618
34672
  displayName: "NPCMultiDialog__NPCThumbnail",
34619
34673
  componentId: "sc-rvu5wg-3"
34620
34674
  })(["image-rendering:pixelated;height:128px;width:128px;"]);
34621
- var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
34675
+ var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
34622
34676
  displayName: "NPCMultiDialog__PressSpaceIndicator",
34623
34677
  componentId: "sc-rvu5wg-4"
34624
34678
  })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref3) {
@@ -34626,485 +34680,221 @@ var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
34626
34680
  return right;
34627
34681
  });
34628
34682
 
34629
- var HistoryDialog = function HistoryDialog(_ref) {
34630
- var backgroundImgPath = _ref.backgroundImgPath,
34631
- fullCoverBackground = _ref.fullCoverBackground,
34632
- questions = _ref.questions,
34633
- answers = _ref.answers,
34634
- text = _ref.text,
34635
- imagePath = _ref.imagePath,
34636
- textAndTypeArray = _ref.textAndTypeArray,
34637
- onClose = _ref.onClose;
34638
- var _useState = React.useState(0),
34639
- img = _useState[0],
34640
- setImage = _useState[1];
34641
- var onHandleSpacePress = function onHandleSpacePress(event) {
34642
- if (event.code === 'Space') {
34643
- if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
34644
- setImage(function (prev) {
34645
- return prev + 1;
34646
- });
34647
- } else {
34648
- // if there's no more text chunks, close the dialog
34649
- onClose();
34650
- }
34651
- }
34652
- };
34653
- React.useEffect(function () {
34654
- document.addEventListener('keydown', onHandleSpacePress);
34683
+ //@ts-ignore
34684
+ var useEventListener = function useEventListener(type, handler, el) {
34685
+ if (el === void 0) {
34686
+ el = window;
34687
+ }
34688
+ var savedHandler = React__default.useRef();
34689
+ React__default.useEffect(function () {
34690
+ savedHandler.current = handler;
34691
+ }, [handler]);
34692
+ React__default.useEffect(function () {
34693
+ //@ts-ignore
34694
+ var listener = function listener(e) {
34695
+ return savedHandler.current(e);
34696
+ };
34697
+ el.addEventListener(type, listener);
34655
34698
  return function () {
34656
- return document.removeEventListener('keydown', onHandleSpacePress);
34699
+ el.removeEventListener(type, listener);
34657
34700
  };
34658
- }, [backgroundImgPath]);
34659
- return React__default.createElement(BackgroundContainer, {
34660
- imgPath: backgroundImgPath[img],
34661
- fullImg: fullCoverBackground
34662
- }, React__default.createElement(DialogContainer, null, textAndTypeArray ? React__default.createElement(NPCMultiDialog, {
34663
- textAndTypeArray: textAndTypeArray,
34664
- onClose: onClose
34665
- }) : questions && answers ? React__default.createElement(QuestionDialog, {
34666
- questions: questions,
34667
- answers: answers,
34668
- onClose: onClose
34669
- }) : text && imagePath ? React__default.createElement(NPCDialog, {
34670
- text: text,
34671
- imagePath: imagePath,
34672
- onClose: onClose,
34673
- type: exports.NPCDialogType.TextAndThumbnail
34674
- }) : React__default.createElement(NPCDialog, {
34675
- text: text,
34676
- onClose: onClose,
34677
- type: exports.NPCDialogType.TextOnly
34678
- })));
34679
- };
34680
- var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
34681
- displayName: "HistoryDialog__BackgroundContainer",
34682
- componentId: "sc-u6oe75-0"
34683
- })(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
34684
- return props.imgPath;
34685
- }, function (props) {
34686
- return props.imgPath ? 'cover' : 'auto';
34687
- });
34688
- var DialogContainer = /*#__PURE__*/styled.div.withConfig({
34689
- displayName: "HistoryDialog__DialogContainer",
34690
- componentId: "sc-u6oe75-1"
34691
- })(["display:flex;justify-content:center;padding-top:200px;"]);
34692
-
34693
- var SlotsContainer = function SlotsContainer(_ref) {
34694
- var children = _ref.children,
34695
- title = _ref.title,
34696
- onClose = _ref.onClose,
34697
- _onPositionChange = _ref.onPositionChange,
34698
- onOutsideClick = _ref.onOutsideClick,
34699
- initialPosition = _ref.initialPosition;
34700
- return React__default.createElement(DraggableContainer, {
34701
- title: title,
34702
- type: exports.RPGUIContainerTypes.Framed,
34703
- onCloseButton: function onCloseButton() {
34704
- if (onClose) {
34705
- onClose();
34706
- }
34707
- },
34708
- width: "330px",
34709
- cancelDrag: ".item-container-body",
34710
- onPositionChange: function onPositionChange(_ref2) {
34711
- var x = _ref2.x,
34712
- y = _ref2.y;
34713
- if (_onPositionChange) {
34714
- _onPositionChange({
34715
- x: x,
34716
- y: y
34717
- });
34718
- }
34719
- },
34720
- onOutsideClick: onOutsideClick,
34721
- initialPosition: initialPosition
34722
- }, children);
34723
- };
34724
-
34725
- (function (RangeSliderType) {
34726
- RangeSliderType["Slider"] = "rpgui-slider";
34727
- RangeSliderType["GoldSlider"] = "rpgui-slider golden";
34728
- })(exports.RangeSliderType || (exports.RangeSliderType = {}));
34729
- var RangeSlider = function RangeSlider(_ref) {
34730
- var type = _ref.type,
34731
- valueMin = _ref.valueMin,
34732
- valueMax = _ref.valueMax,
34733
- width = _ref.width,
34734
- _onChange = _ref.onChange,
34735
- value = _ref.value;
34736
- var sliderId = uuid.v4();
34737
- var containerRef = React.useRef(null);
34738
- var _useState = React.useState(0),
34739
- left = _useState[0],
34740
- setLeft = _useState[1];
34741
- React.useEffect(function () {
34742
- var _containerRef$current;
34743
- var calculatedWidth = ((_containerRef$current = containerRef.current) == null ? void 0 : _containerRef$current.clientWidth) || 0;
34744
- setLeft(Math.max((value - valueMin) / (valueMax - valueMin) * (calculatedWidth - 35) + 10));
34745
- }, [value, valueMin, valueMax]);
34746
- var typeClass = type === exports.RangeSliderType.GoldSlider ? 'golden' : '';
34747
- return React__default.createElement("div", {
34748
- style: {
34749
- width: width,
34750
- position: 'relative'
34751
- },
34752
- className: "rpgui-slider-container " + typeClass,
34753
- id: "rpgui-slider-" + sliderId,
34754
- ref: containerRef
34755
- }, React__default.createElement("div", {
34756
- style: {
34757
- pointerEvents: 'none'
34758
- }
34759
- }, React__default.createElement("div", {
34760
- className: "rpgui-slider-track " + typeClass
34761
- }), React__default.createElement("div", {
34762
- className: "rpgui-slider-left-edge " + typeClass
34763
- }), React__default.createElement("div", {
34764
- className: "rpgui-slider-right-edge " + typeClass
34765
- }), React__default.createElement("div", {
34766
- className: "rpgui-slider-thumb " + typeClass,
34767
- style: {
34768
- left: left
34769
- }
34770
- })), React__default.createElement(Input$1, {
34771
- type: "range",
34772
- style: {
34773
- width: width
34774
- },
34775
- min: valueMin,
34776
- max: valueMax,
34777
- onChange: function onChange(e) {
34778
- return _onChange(Number(e.target.value));
34779
- },
34780
- value: value,
34781
- className: "rpgui-cursor-point"
34782
- }));
34701
+ }, [type, el]);
34783
34702
  };
34784
- var Input$1 = /*#__PURE__*/styled.input.withConfig({
34785
- displayName: "RangeSlider__Input",
34786
- componentId: "sc-v8mte9-0"
34787
- })(["opacity:0;position:absolute;width:100%;height:100%;top:0;left:0;margin-top:-5px;"]);
34788
34703
 
34789
- var ItemQuantitySelector = function ItemQuantitySelector(_ref) {
34790
- var quantity = _ref.quantity,
34791
- onConfirm = _ref.onConfirm,
34792
- onClose = _ref.onClose;
34793
- var _useState = React.useState(quantity),
34794
- value = _useState[0],
34795
- setValue = _useState[1];
34796
- var inputRef = React.useRef(null);
34704
+ var DynamicText = function DynamicText(_ref) {
34705
+ var text = _ref.text,
34706
+ onFinish = _ref.onFinish,
34707
+ onStart = _ref.onStart;
34708
+ var _useState = React.useState(''),
34709
+ textState = _useState[0],
34710
+ setTextState = _useState[1];
34797
34711
  React.useEffect(function () {
34798
- if (inputRef.current) {
34799
- inputRef.current.focus();
34800
- inputRef.current.select();
34801
- var closeSelector = function closeSelector(e) {
34802
- if (e.key === 'Escape') {
34803
- onClose();
34804
- }
34805
- };
34806
- document.addEventListener('keydown', closeSelector);
34807
- return function () {
34808
- document.removeEventListener('keydown', closeSelector);
34809
- };
34810
- }
34811
- return function () {};
34812
- }, []);
34813
- return React__default.createElement(StyledContainer, {
34814
- type: exports.RPGUIContainerTypes.Framed,
34815
- width: "25rem"
34816
- }, React__default.createElement(CloseButton$2, {
34817
- className: "container-close",
34818
- onClick: onClose,
34819
- onTouchStart: onClose
34820
- }, "X"), React__default.createElement("h2", null, "Select quantity to move"), React__default.createElement(StyledForm, {
34821
- style: {
34822
- width: '100%'
34823
- },
34824
- onSubmit: function onSubmit(e) {
34825
- e.preventDefault();
34826
- var numberValue = Number(value);
34827
- if (Number.isNaN(numberValue)) {
34828
- return;
34829
- }
34830
- onConfirm(Math.max(1, Math.min(quantity, numberValue)));
34831
- },
34832
- noValidate: true
34833
- }, React__default.createElement(StyledInput, {
34834
- innerRef: inputRef,
34835
- placeholder: "Enter quantity",
34836
- type: "number",
34837
- min: 1,
34838
- max: quantity,
34839
- value: value,
34840
- onChange: function onChange(e) {
34841
- if (Number(e.target.value) >= quantity) {
34842
- setValue(quantity);
34843
- return;
34844
- }
34845
- setValue(e.target.value);
34846
- },
34847
- onBlur: function onBlur(e) {
34848
- var newValue = Math.max(1, Math.min(quantity, Number(e.target.value)));
34849
- setValue(newValue);
34850
- }
34851
- }), React__default.createElement(RangeSlider, {
34852
- type: exports.RangeSliderType.Slider,
34853
- valueMin: 1,
34854
- valueMax: quantity,
34855
- width: "100%",
34856
- onChange: setValue,
34857
- value: value
34858
- }), React__default.createElement(Button, {
34859
- buttonType: exports.ButtonTypes.RPGUIButton,
34860
- type: "submit"
34861
- }, "Confirm")));
34862
- };
34863
- var StyledContainer = /*#__PURE__*/styled(RPGUIContainer).withConfig({
34864
- displayName: "ItemQuantitySelector__StyledContainer",
34865
- componentId: "sc-yfdtpn-0"
34866
- })(["display:flex;flex-direction:column;align-items:center;"]);
34867
- var StyledForm = /*#__PURE__*/styled.form.withConfig({
34868
- displayName: "ItemQuantitySelector__StyledForm",
34869
- componentId: "sc-yfdtpn-1"
34870
- })(["display:flex;flex-direction:column;align-items:center;width:100%;"]);
34871
- var StyledInput = /*#__PURE__*/styled(Input).withConfig({
34872
- displayName: "ItemQuantitySelector__StyledInput",
34873
- componentId: "sc-yfdtpn-2"
34874
- })(["text-align:center;&::-webkit-outer-spin-button,&::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}&[type='number']{-moz-appearance:textfield;}"]);
34875
- var CloseButton$2 = /*#__PURE__*/styled.div.withConfig({
34876
- displayName: "ItemQuantitySelector__CloseButton",
34877
- componentId: "sc-yfdtpn-3"
34878
- })(["position:absolute;top:3px;right:0px;color:white;z-index:22;font-size:0.8rem;"]);
34879
-
34880
- var ItemContainer$1 = function ItemContainer(_ref) {
34881
- var itemContainer = _ref.itemContainer,
34882
- onClose = _ref.onClose,
34883
- _onMouseOver = _ref.onMouseOver,
34884
- _onSelected = _ref.onSelected,
34885
- onItemClick = _ref.onItemClick,
34886
- type = _ref.type,
34887
- atlasJSON = _ref.atlasJSON,
34888
- atlasIMG = _ref.atlasIMG,
34889
- _ref$disableContextMe = _ref.disableContextMenu,
34890
- disableContextMenu = _ref$disableContextMe === void 0 ? false : _ref$disableContextMe,
34891
- onItemDragEnd = _ref.onItemDragEnd,
34892
- onItemDragStart = _ref.onItemDragStart,
34893
- onItemPlaceDrop = _ref.onItemPlaceDrop,
34894
- _onOutsideDrop = _ref.onOutsideDrop,
34895
- checkIfItemCanBeMoved = _ref.checkIfItemCanBeMoved,
34896
- initialPosition = _ref.initialPosition,
34897
- checkIfItemShouldDragEnd = _ref.checkIfItemShouldDragEnd,
34898
- dragScale = _ref.dragScale;
34899
- var _useState = React.useState({
34900
- isOpen: false,
34901
- maxQuantity: 1,
34902
- callback: function callback(_quantity) {}
34903
- }),
34904
- quantitySelect = _useState[0],
34905
- setQuantitySelect = _useState[1];
34906
- var onRenderSlots = function onRenderSlots() {
34907
- var slots = [];
34908
- for (var i = 0; i < itemContainer.slotQty; i++) {
34909
- var _itemContainer$slots;
34910
- slots.push(React__default.createElement(ItemSlot, {
34911
- isContextMenuDisabled: disableContextMenu,
34912
- key: i,
34913
- slotIndex: i,
34914
- item: ((_itemContainer$slots = itemContainer.slots) == null ? void 0 : _itemContainer$slots[i]) || null,
34915
- itemContainerType: type,
34916
- onMouseOver: function onMouseOver(event, slotIndex, item) {
34917
- if (_onMouseOver) _onMouseOver(event, slotIndex, item);
34918
- },
34919
- onClick: function onClick(ItemType, ContainerType, item) {
34920
- if (onItemClick) onItemClick(item, ItemType, ContainerType);
34921
- },
34922
- onSelected: function onSelected(optionId, item) {
34923
- if (_onSelected) _onSelected(optionId, item);
34924
- },
34925
- onDragStart: function onDragStart(item, slotIndex, itemContainerType) {
34926
- if (onItemDragStart) onItemDragStart(item, slotIndex, itemContainerType);
34927
- },
34928
- onDragEnd: function onDragEnd(quantity) {
34929
- if (onItemDragEnd) onItemDragEnd(quantity);
34930
- },
34931
- dragScale: dragScale,
34932
- checkIfItemCanBeMoved: checkIfItemCanBeMoved,
34933
- checkIfItemShouldDragEnd: checkIfItemShouldDragEnd,
34934
- openQuantitySelector: function openQuantitySelector(maxQuantity, callback) {
34935
- setQuantitySelect({
34936
- isOpen: true,
34937
- maxQuantity: maxQuantity,
34938
- callback: callback
34939
- });
34940
- },
34941
- onPlaceDrop: function onPlaceDrop(item, slotIndex, itemContainerType) {
34942
- if (onItemPlaceDrop) onItemPlaceDrop(item, slotIndex, itemContainerType);
34943
- },
34944
- onOutsideDrop: function onOutsideDrop(item, position) {
34945
- if (_onOutsideDrop) _onOutsideDrop(item, position);
34946
- },
34947
- atlasIMG: atlasIMG,
34948
- atlasJSON: atlasJSON
34949
- }));
34950
- }
34951
- return slots;
34952
- };
34953
- return React__default.createElement(React__default.Fragment, null, React__default.createElement(SlotsContainer, {
34954
- title: itemContainer.name || 'Container',
34955
- onClose: onClose,
34956
- initialPosition: initialPosition
34957
- }, React__default.createElement(ItemsContainer, {
34958
- className: "item-container-body"
34959
- }, onRenderSlots())), quantitySelect.isOpen && React__default.createElement(QuantitySelectorContainer, null, React__default.createElement(ItemQuantitySelector, {
34960
- quantity: quantitySelect.maxQuantity,
34961
- onConfirm: function onConfirm(quantity) {
34962
- quantitySelect.callback(quantity);
34963
- setQuantitySelect({
34964
- isOpen: false,
34965
- maxQuantity: 1,
34966
- callback: function callback() {}
34967
- });
34968
- },
34969
- onClose: function onClose() {
34970
- quantitySelect.callback(-1);
34971
- setQuantitySelect({
34972
- isOpen: false,
34973
- maxQuantity: 1,
34974
- callback: function callback() {}
34975
- });
34976
- }
34977
- })));
34712
+ var i = 0;
34713
+ var interval = setInterval(function () {
34714
+ // on every interval, show one more character
34715
+ if (i === 0) {
34716
+ if (onStart) {
34717
+ onStart();
34718
+ }
34719
+ }
34720
+ if (i < text.length) {
34721
+ setTextState(text.substring(0, i + 1));
34722
+ i++;
34723
+ } else {
34724
+ clearInterval(interval);
34725
+ if (onFinish) {
34726
+ onFinish();
34727
+ }
34728
+ }
34729
+ }, 50);
34730
+ return function () {
34731
+ clearInterval(interval);
34732
+ };
34733
+ }, [text]);
34734
+ return React__default.createElement(TextContainer$1, null, textState);
34978
34735
  };
34979
- var ItemsContainer = /*#__PURE__*/styled.div.withConfig({
34980
- displayName: "ItemContainer__ItemsContainer",
34981
- componentId: "sc-15y5p9l-0"
34982
- })(["max-width:280px;display:flex;justify-content:center;flex-wrap:wrap;"]);
34983
- var QuantitySelectorContainer = /*#__PURE__*/styled.div.withConfig({
34984
- displayName: "ItemContainer__QuantitySelectorContainer",
34985
- componentId: "sc-15y5p9l-1"
34986
- })(["position:absolute;top:0;left:0;width:100vw;height:100vh;z-index:100;display:flex;justify-content:center;align-items:center;background-color:rgba(0,0,0,0.5);"]);
34736
+ var TextContainer$1 = /*#__PURE__*/styled.p.withConfig({
34737
+ displayName: "DynamicText__TextContainer",
34738
+ componentId: "sc-1ggl9nd-0"
34739
+ })(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]);
34987
34740
 
34988
- var ItemSelector = function ItemSelector(_ref) {
34989
- var atlasIMG = _ref.atlasIMG,
34990
- atlasJSON = _ref.atlasJSON,
34991
- options = _ref.options,
34992
- onClose = _ref.onClose,
34993
- onSelect = _ref.onSelect;
34994
- var _useState = React.useState(),
34995
- selectedValue = _useState[0],
34996
- setSelectedValue = _useState[1];
34997
- var handleClick = function handleClick() {
34998
- var element = document.querySelector("input[name='test']:checked");
34999
- var elementValue = element.value;
35000
- setSelectedValue(elementValue);
34741
+ var QuestionDialog = function QuestionDialog(_ref) {
34742
+ var questions = _ref.questions,
34743
+ answers = _ref.answers,
34744
+ onClose = _ref.onClose;
34745
+ var _useState = React.useState(questions[0]),
34746
+ currentQuestion = _useState[0],
34747
+ setCurrentQuestion = _useState[1];
34748
+ var _useState2 = React.useState(false),
34749
+ canShowAnswers = _useState2[0],
34750
+ setCanShowAnswers = _useState2[1];
34751
+ var onGetFirstAnswer = function onGetFirstAnswer() {
34752
+ if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {
34753
+ return null;
34754
+ }
34755
+ var firstAnswerId = currentQuestion.answerIds[0];
34756
+ return answers.find(function (answer) {
34757
+ return answer.id === firstAnswerId;
34758
+ });
35001
34759
  };
34760
+ var _useState3 = React.useState(onGetFirstAnswer()),
34761
+ currentAnswer = _useState3[0],
34762
+ setCurrentAnswer = _useState3[1];
35002
34763
  React.useEffect(function () {
35003
- if (selectedValue) {
35004
- onSelect(selectedValue);
34764
+ setCurrentAnswer(onGetFirstAnswer());
34765
+ }, [currentQuestion]);
34766
+ var onGetAnswers = function onGetAnswers(answerIds) {
34767
+ return answerIds.map(function (answerId) {
34768
+ return answers.find(function (answer) {
34769
+ return answer.id === answerId;
34770
+ });
34771
+ });
34772
+ };
34773
+ var onKeyPress = function onKeyPress(e) {
34774
+ switch (e.key) {
34775
+ case 'ArrowDown':
34776
+ // select next answer, if any.
34777
+ // if no next answer, select first answer
34778
+ // const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(
34779
+ // (answer) => answer?.id === currentAnswer!.id + 1
34780
+ // );
34781
+ var nextAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34782
+ return (answer == null ? void 0 : answer.id) === currentAnswer.id + 1;
34783
+ });
34784
+ var nextAnswerID = currentQuestion.answerIds[nextAnswerIndex];
34785
+ var nextAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34786
+ return (answer == null ? void 0 : answer.id) === nextAnswerID;
34787
+ });
34788
+ setCurrentAnswer(nextAnswer || onGetFirstAnswer());
34789
+ break;
34790
+ case 'ArrowUp':
34791
+ // select previous answer, if any.
34792
+ // if no previous answer, select last answer
34793
+ var previousAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34794
+ return (answer == null ? void 0 : answer.id) === currentAnswer.id - 1;
34795
+ });
34796
+ var previousAnswerID = currentQuestion.answerIds && currentQuestion.answerIds[previousAnswerIndex];
34797
+ var previousAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34798
+ return (answer == null ? void 0 : answer.id) === previousAnswerID;
34799
+ });
34800
+ if (previousAnswer) {
34801
+ setCurrentAnswer(previousAnswer);
34802
+ } else {
34803
+ setCurrentAnswer(onGetAnswers(currentQuestion.answerIds).pop());
34804
+ }
34805
+ break;
34806
+ case 'Enter':
34807
+ setCanShowAnswers(false);
34808
+ if (!(currentAnswer != null && currentAnswer.nextQuestionId)) {
34809
+ onClose();
34810
+ return;
34811
+ } else {
34812
+ setCurrentQuestion(questions.find(function (question) {
34813
+ return question.id === currentAnswer.nextQuestionId;
34814
+ }));
34815
+ }
34816
+ break;
35005
34817
  }
35006
- }, [selectedValue]);
35007
- return React__default.createElement(DraggableContainer, {
35008
- type: exports.RPGUIContainerTypes.Framed,
35009
- width: "500px",
35010
- cancelDrag: ".equipment-container-body .arrow-selector",
35011
- onCloseButton: function onCloseButton() {
35012
- if (onClose) {
35013
- onClose();
35014
- }
34818
+ };
34819
+ useEventListener('keydown', onKeyPress);
34820
+ var onAnswerClick = function onAnswerClick(answer) {
34821
+ setCanShowAnswers(false);
34822
+ if (answer.nextQuestionId) {
34823
+ // if there is a next question, go to it
34824
+ setCurrentQuestion(questions.find(function (question) {
34825
+ return question.id === answer.nextQuestionId;
34826
+ }));
34827
+ } else {
34828
+ // else, finish dialog!
34829
+ onClose();
35015
34830
  }
35016
- }, React__default.createElement("div", {
35017
- style: {
35018
- width: '100%'
34831
+ };
34832
+ var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
34833
+ var answerIds = currentQuestion.answerIds;
34834
+ if (!answerIds) {
34835
+ return null;
35019
34836
  }
35020
- }, React__default.createElement(Title$2, null, 'Harvesting instruments'), React__default.createElement(Subtitle$1, null, 'Use the tool, you need it'), React__default.createElement("hr", {
35021
- className: "golden"
35022
- })), React__default.createElement(RadioInputScroller$1, null, options == null ? void 0 : options.map(function (option, index) {
35023
- return React__default.createElement(RadioOptionsWrapper$1, {
35024
- key: index
35025
- }, React__default.createElement(SpriteAtlasWrapper$1, null, React__default.createElement(SpriteFromAtlas, {
35026
- atlasIMG: atlasIMG,
35027
- atlasJSON: atlasJSON,
35028
- spriteKey: option.imageKey,
35029
- imgScale: 3
35030
- })), React__default.createElement("div", null, React__default.createElement("input", {
35031
- className: "rpgui-radio",
35032
- type: "radio",
35033
- value: option.name,
35034
- name: "test"
35035
- }), React__default.createElement("label", {
35036
- onClick: handleClick,
35037
- style: {
35038
- display: 'flex',
35039
- alignItems: 'center'
35040
- }
35041
- }, option.name, " ", React__default.createElement("br", null), option.description)));
35042
- })), React__default.createElement(ButtonWrapper$1, null, React__default.createElement(Button, {
35043
- buttonType: exports.ButtonTypes.RPGUIButton,
35044
- onClick: onClose
35045
- }, "Cancel"), React__default.createElement(Button, {
35046
- buttonType: exports.ButtonTypes.RPGUIButton
35047
- }, "Select")));
35048
- };
35049
- var Title$2 = /*#__PURE__*/styled.h1.withConfig({
35050
- displayName: "ItemSelector__Title",
35051
- componentId: "sc-gptoxp-0"
35052
- })(["font-size:0.6rem;color:yellow !important;"]);
35053
- var Subtitle$1 = /*#__PURE__*/styled.h1.withConfig({
35054
- displayName: "ItemSelector__Subtitle",
35055
- componentId: "sc-gptoxp-1"
35056
- })(["font-size:0.4rem;color:yellow !important;"]);
35057
- var RadioInputScroller$1 = /*#__PURE__*/styled.div.withConfig({
35058
- displayName: "ItemSelector__RadioInputScroller",
35059
- componentId: "sc-gptoxp-2"
35060
- })(["padding-left:15px;padding-top:10px;width:100%;margin-top:1rem;align-items:center;margin-left:20px;align-items:flex-start;overflow-y:scroll;height:360px;"]);
35061
- var SpriteAtlasWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35062
- displayName: "ItemSelector__SpriteAtlasWrapper",
35063
- componentId: "sc-gptoxp-3"
35064
- })(["margin-right:40px;"]);
35065
- var RadioOptionsWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35066
- displayName: "ItemSelector__RadioOptionsWrapper",
35067
- componentId: "sc-gptoxp-4"
35068
- })(["display:flex;align-items:stretch;margin-bottom:40px;"]);
35069
- var ButtonWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35070
- displayName: "ItemSelector__ButtonWrapper",
35071
- componentId: "sc-gptoxp-5"
35072
- })(["display:flex;justify-content:space-around;padding-top:20px;width:100%;"]);
35073
-
35074
- var ListMenu = function ListMenu(_ref) {
35075
- var options = _ref.options,
35076
- onSelected = _ref.onSelected,
35077
- x = _ref.x,
35078
- y = _ref.y;
35079
- return React__default.createElement(Container$f, {
35080
- x: x,
35081
- y: y
35082
- }, React__default.createElement("ul", {
35083
- className: "rpgui-list-imp",
35084
- style: {
35085
- overflow: 'hidden'
34837
+ var answers = onGetAnswers(answerIds);
34838
+ if (!answers) {
34839
+ return null;
35086
34840
  }
35087
- }, options.map(function (params, index) {
35088
- return React__default.createElement(ListElement$1, {
35089
- key: (params == null ? void 0 : params.id) || index,
35090
- onClick: function onClick() {
35091
- onSelected(params == null ? void 0 : params.id);
34841
+ return answers.map(function (answer) {
34842
+ var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
34843
+ var selectedColor = isSelected ? 'yellow' : 'white';
34844
+ if (answer) {
34845
+ return React__default.createElement(AnswerRow, {
34846
+ key: "answer_" + answer.id
34847
+ }, React__default.createElement(AnswerSelectedIcon, {
34848
+ color: selectedColor
34849
+ }, isSelected ? 'X' : null), React__default.createElement(Answer, {
34850
+ key: answer.id,
34851
+ onClick: function onClick() {
34852
+ return onAnswerClick(answer);
34853
+ },
34854
+ color: selectedColor
34855
+ }, answer.text));
35092
34856
  }
35093
- }, (params == null ? void 0 : params.text) || 'No text');
35094
- })));
35095
- };
35096
- var Container$f = /*#__PURE__*/styled.div.withConfig({
35097
- displayName: "ListMenu__Container",
35098
- componentId: "sc-i9097t-0"
35099
- })(["display:flex;flex-direction:column;width:100%;justify-content:start;align-items:flex-start;position:absolute;top:", "px;left:", "px;li{font-size:", ";}"], function (props) {
35100
- return props.y || 0;
35101
- }, function (props) {
35102
- return props.x || 0;
35103
- }, uiFonts.size.xsmall);
35104
- var ListElement$1 = /*#__PURE__*/styled.li.withConfig({
35105
- displayName: "ListMenu__ListElement",
35106
- componentId: "sc-i9097t-1"
35107
- })(["margin-right:0.5rem;"]);
34857
+ return null;
34858
+ });
34859
+ };
34860
+ return React__default.createElement(Container$d, null, React__default.createElement(QuestionContainer, null, React__default.createElement(DynamicText, {
34861
+ text: currentQuestion.text,
34862
+ onStart: function onStart() {
34863
+ return setCanShowAnswers(false);
34864
+ },
34865
+ onFinish: function onFinish() {
34866
+ return setCanShowAnswers(true);
34867
+ }
34868
+ })), canShowAnswers && React__default.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
34869
+ };
34870
+ var Container$d = /*#__PURE__*/styled.div.withConfig({
34871
+ displayName: "QuestionDialog__Container",
34872
+ componentId: "sc-bxc5u0-0"
34873
+ })(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
34874
+ var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
34875
+ displayName: "QuestionDialog__QuestionContainer",
34876
+ componentId: "sc-bxc5u0-1"
34877
+ })(["flex:100%;width:100%;"]);
34878
+ var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
34879
+ displayName: "QuestionDialog__AnswersContainer",
34880
+ componentId: "sc-bxc5u0-2"
34881
+ })(["flex:100%;"]);
34882
+ var Answer = /*#__PURE__*/styled.p.withConfig({
34883
+ displayName: "QuestionDialog__Answer",
34884
+ componentId: "sc-bxc5u0-3"
34885
+ })(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
34886
+ return props.color;
34887
+ });
34888
+ var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
34889
+ displayName: "QuestionDialog__AnswerSelectedIcon",
34890
+ componentId: "sc-bxc5u0-4"
34891
+ })(["flex:5% 0 0;color:", " !important;"], function (props) {
34892
+ return props.color;
34893
+ });
34894
+ var AnswerRow = /*#__PURE__*/styled.div.withConfig({
34895
+ displayName: "QuestionDialog__AnswerRow",
34896
+ componentId: "sc-bxc5u0-5"
34897
+ })(["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;}"]);
35108
34898
 
35109
34899
  var ProgressBar = function ProgressBar(_ref) {
35110
34900
  var max = _ref.max,
@@ -35123,7 +34913,7 @@ var ProgressBar = function ProgressBar(_ref) {
35123
34913
  }
35124
34914
  return value * 100 / max;
35125
34915
  };
35126
- return React__default.createElement(Container$g, {
34916
+ return React__default.createElement(Container$e, {
35127
34917
  className: "rpgui-progress",
35128
34918
  "data-value": calculatePercentageValue(max, value) / 100,
35129
34919
  "data-rpguitype": "progress",
@@ -35152,7 +34942,7 @@ var TextOverlay$1 = /*#__PURE__*/styled.div.withConfig({
35152
34942
  displayName: "ProgressBar__TextOverlay",
35153
34943
  componentId: "sc-qa6fzh-1"
35154
34944
  })(["width:100%;position:relative;"]);
35155
- var Container$g = /*#__PURE__*/styled.div.withConfig({
34945
+ var Container$e = /*#__PURE__*/styled.div.withConfig({
35156
34946
  displayName: "ProgressBar__Container",
35157
34947
  componentId: "sc-qa6fzh-2"
35158
34948
  })(["display:flex;flex-direction:column;min-width:", "px;width:", "%;justify-content:start;align-items:flex-start;", ""], function (props) {
@@ -35163,7 +34953,7 @@ var Container$g = /*#__PURE__*/styled.div.withConfig({
35163
34953
  return props.style;
35164
34954
  });
35165
34955
 
35166
- var img$9 = '';
34956
+ var img$8 = '';
35167
34957
 
35168
34958
  var QuestInfo = function QuestInfo(_ref) {
35169
34959
  var quests = _ref.quests,
@@ -35207,7 +34997,7 @@ var QuestInfo = function QuestInfo(_ref) {
35207
34997
  }), React__default.createElement(QuestContainer, null, React__default.createElement(TitleContainer$1, {
35208
34998
  className: "drag-handler"
35209
34999
  }, React__default.createElement(Title$3, null, React__default.createElement(Thumbnail, {
35210
- src: quests[currentIndex].thumbnail || img$9
35000
+ src: quests[currentIndex].thumbnail || img$8
35211
35001
  }), quests[currentIndex].title), React__default.createElement(QuestSplitDiv, null, React__default.createElement("hr", {
35212
35002
  className: "golden"
35213
35003
  }))), React__default.createElement(Content, null, React__default.createElement("p", null, quests[currentIndex].description)), React__default.createElement(QuestColumn, {
@@ -35226,7 +35016,7 @@ var QuestInfo = function QuestInfo(_ref) {
35226
35016
  })))) : React__default.createElement(QuestsContainer, null, React__default.createElement(QuestContainer, null, React__default.createElement(TitleContainer$1, {
35227
35017
  className: "drag-handler"
35228
35018
  }, React__default.createElement(Title$3, null, React__default.createElement(Thumbnail, {
35229
- src: quests[0].thumbnail || img$9
35019
+ src: quests[0].thumbnail || img$8
35230
35020
  }), quests[0].title), React__default.createElement(QuestSplitDiv, null, React__default.createElement("hr", {
35231
35021
  className: "golden"
35232
35022
  }))), React__default.createElement(Content, null, React__default.createElement("p", null, quests[0].description)), React__default.createElement(QuestColumn, {
@@ -35375,7 +35165,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
35375
35165
  bgColor = _ref$bgColor === void 0 ? 'red' : _ref$bgColor,
35376
35166
  _ref$margin = _ref.margin,
35377
35167
  margin = _ref$margin === void 0 ? 20 : _ref$margin;
35378
- return React__default.createElement(Container$h, {
35168
+ return React__default.createElement(Container$f, {
35379
35169
  className: "simple-progress-bar"
35380
35170
  }, React__default.createElement(ProgressBarContainer, {
35381
35171
  margin: margin
@@ -35384,7 +35174,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
35384
35174
  bgColor: bgColor
35385
35175
  }))));
35386
35176
  };
35387
- var Container$h = /*#__PURE__*/styled.div.withConfig({
35177
+ var Container$f = /*#__PURE__*/styled.div.withConfig({
35388
35178
  displayName: "SimpleProgressBar__Container",
35389
35179
  componentId: "sc-mbeil3-0"
35390
35180
  })(["display:flex;justify-content:center;align-items:center;width:100%;"]);
@@ -35557,11 +35347,14 @@ var SkillsContainer = function SkillsContainer(_ref) {
35557
35347
  return output;
35558
35348
  };
35559
35349
  return React__default.createElement(SkillsDraggableContainer, {
35560
- title: "Skills"
35350
+ title: "Skills",
35351
+ cancelDrag: "#skillsDiv"
35561
35352
  }, onCloseButton && React__default.createElement(CloseButton$3, {
35562
35353
  onClick: onCloseButton,
35563
35354
  onTouchStart: onCloseButton
35564
- }, "X"), React__default.createElement(SkillSplitDiv, null, React__default.createElement("p", null, "General"), React__default.createElement("hr", {
35355
+ }, "X"), React__default.createElement(SkillsContainerDiv, {
35356
+ id: "skillsDiv"
35357
+ }, React__default.createElement(SkillSplitDiv, null, React__default.createElement("p", null, "General"), React__default.createElement("hr", {
35565
35358
  className: "golden"
35566
35359
  }), React__default.createElement(SkillProgressBar, {
35567
35360
  skillName: 'Level',
@@ -35578,19 +35371,23 @@ var SkillsContainer = function SkillsContainer(_ref) {
35578
35371
  className: "golden"
35579
35372
  })), onRenderSkillCategory('crafting'), React__default.createElement(SkillSplitDiv, null, React__default.createElement("p", null, "Basic Attributes"), React__default.createElement("hr", {
35580
35373
  className: "golden"
35581
- })), onRenderSkillCategory('attributes'));
35374
+ })), onRenderSkillCategory('attributes')));
35582
35375
  };
35583
35376
  var SkillsDraggableContainer = /*#__PURE__*/styled(DraggableContainer).withConfig({
35584
35377
  displayName: "SkillsContainer__SkillsDraggableContainer",
35585
35378
  componentId: "sc-1g0c67q-0"
35586
- })(["border:1px solid black;width:400px;height:90%;overflow-y:scroll;.DraggableContainer__TitleContainer-sc-184mpyl-2{width:auto;height:auto;}"]);
35379
+ })(["border:1px solid black;width:400px;height:90%;.DraggableContainer__TitleContainer-sc-184mpyl-2{width:auto;height:auto;}"]);
35380
+ var SkillsContainerDiv = /*#__PURE__*/styled.div.withConfig({
35381
+ displayName: "SkillsContainer__SkillsContainerDiv",
35382
+ componentId: "sc-1g0c67q-1"
35383
+ })(["width:100%;-webkit-overflow-y:scroll;overflow-y:scroll;height:90%;padding-right:10px;"]);
35587
35384
  var SkillSplitDiv = /*#__PURE__*/styled.div.withConfig({
35588
35385
  displayName: "SkillsContainer__SkillSplitDiv",
35589
- componentId: "sc-1g0c67q-1"
35386
+ componentId: "sc-1g0c67q-2"
35590
35387
  })(["width:100%;font-size:11px;hr{margin:0;margin-bottom:1rem;padding:0px;}p{margin-bottom:0px;}"]);
35591
35388
  var CloseButton$3 = /*#__PURE__*/styled.div.withConfig({
35592
35389
  displayName: "SkillsContainer__CloseButton",
35593
- componentId: "sc-1g0c67q-2"
35390
+ componentId: "sc-1g0c67q-3"
35594
35391
  })(["position:absolute;top:2px;right:2px;color:white;z-index:22;font-size:1.1rem;"]);
35595
35392
 
35596
35393
  var Spell = function Spell(_ref) {
@@ -35605,7 +35402,7 @@ var Spell = function Spell(_ref) {
35605
35402
  isSettingShortcut = _ref.isSettingShortcut,
35606
35403
  minMagicLevelRequired = _ref.minMagicLevelRequired;
35607
35404
  var disabled = isSettingShortcut ? charMagicLevel < minMagicLevelRequired : manaCost > charMana || charMagicLevel < minMagicLevelRequired;
35608
- return React__default.createElement(Container$i, {
35405
+ return React__default.createElement(Container$g, {
35609
35406
  disabled: disabled,
35610
35407
  onClick: onClick == null ? void 0 : onClick.bind(null, spellKey),
35611
35408
  isSettingShortcut: isSettingShortcut && !disabled,
@@ -35618,7 +35415,7 @@ var Spell = function Spell(_ref) {
35618
35415
  className: "mana"
35619
35416
  }, manaCost)));
35620
35417
  };
35621
- var Container$i = /*#__PURE__*/styled.button.withConfig({
35418
+ var Container$g = /*#__PURE__*/styled.button.withConfig({
35622
35419
  displayName: "Spell__Container",
35623
35420
  componentId: "sc-j96fa2-0"
35624
35421
  })(["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) {
@@ -35738,7 +35535,7 @@ var Spellbook = function Spellbook(_ref) {
35738
35535
  width: "inherit",
35739
35536
  height: "inherit",
35740
35537
  cancelDrag: "#spellbook-search, #shortcuts_list, .spell"
35741
- }, React__default.createElement(Container$j, null, React__default.createElement(Title$6, null, "Learned Spells"), React__default.createElement(SpellbookShortcuts, {
35538
+ }, React__default.createElement(Container$h, null, React__default.createElement(Title$6, null, "Learned Spells"), React__default.createElement(SpellbookShortcuts, {
35742
35539
  setSettingShortcutIndex: setSettingShortcutIndex,
35743
35540
  settingShortcutIndex: settingShortcutIndex,
35744
35541
  shortcuts: spellShortcuts,
@@ -35768,7 +35565,7 @@ var Title$6 = /*#__PURE__*/styled.h1.withConfig({
35768
35565
  displayName: "Spellbook__Title",
35769
35566
  componentId: "sc-r02nfq-0"
35770
35567
  })(["font-size:", " !important;margin-bottom:0 !important;"], uiFonts.size.large);
35771
- var Container$j = /*#__PURE__*/styled.div.withConfig({
35568
+ var Container$h = /*#__PURE__*/styled.div.withConfig({
35772
35569
  displayName: "Spellbook__Container",
35773
35570
  componentId: "sc-r02nfq-1"
35774
35571
  })(["width:100%;height:100%;color:white;display:flex;flex-direction:column;"]);
@@ -35782,16 +35579,16 @@ var TextArea = function TextArea(_ref) {
35782
35579
  return React__default.createElement("textarea", Object.assign({}, props));
35783
35580
  };
35784
35581
 
35785
- var img$a = '';
35582
+ var img$9 = '';
35786
35583
 
35787
- var img$b = '';
35584
+ var img$a = '';
35788
35585
 
35789
- var img$c = '';
35586
+ var img$b = '';
35790
35587
 
35791
35588
  var DayNightPeriod = function DayNightPeriod(_ref) {
35792
35589
  var _periodOfDaySrcFiles;
35793
35590
  var periodOfDay = _ref.periodOfDay;
35794
- var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[shared.PeriodOfDay.Morning] = img$b, _periodOfDaySrcFiles[shared.PeriodOfDay.Afternoon] = img$a, _periodOfDaySrcFiles[shared.PeriodOfDay.Night] = img$c, _periodOfDaySrcFiles);
35591
+ var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[shared.PeriodOfDay.Morning] = img$a, _periodOfDaySrcFiles[shared.PeriodOfDay.Afternoon] = img$9, _periodOfDaySrcFiles[shared.PeriodOfDay.Night] = img$b, _periodOfDaySrcFiles);
35795
35592
  return React__default.createElement(GifContainer, null, React__default.createElement("img", {
35796
35593
  src: periodOfDaySrcFiles[periodOfDay]
35797
35594
  }));
@@ -35801,7 +35598,7 @@ var GifContainer = /*#__PURE__*/styled.div.withConfig({
35801
35598
  componentId: "sc-10t97fw-0"
35802
35599
  })(["width:100%;img{width:67%;}"]);
35803
35600
 
35804
- var img$d = '';
35601
+ var img$c = '';
35805
35602
 
35806
35603
  var TimeWidget = function TimeWidget(_ref) {
35807
35604
  var onClose = _ref.onClose,
@@ -35816,7 +35613,7 @@ var TimeWidget = function TimeWidget(_ref) {
35816
35613
  var WidgetContainer = /*#__PURE__*/styled.div.withConfig({
35817
35614
  displayName: "TimeWidget__WidgetContainer",
35818
35615
  componentId: "sc-1ja236h-0"
35819
- })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$d);
35616
+ })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$c);
35820
35617
  var Time = /*#__PURE__*/styled.div.withConfig({
35821
35618
  displayName: "TimeWidget__Time",
35822
35619
  componentId: "sc-1ja236h-1"
@@ -36066,17 +35863,230 @@ var Truncate = function Truncate(_ref) {
36066
35863
  var _ref$maxLines = _ref.maxLines,
36067
35864
  maxLines = _ref$maxLines === void 0 ? 1 : _ref$maxLines,
36068
35865
  children = _ref.children;
36069
- return React__default.createElement(Container$k, {
35866
+ return React__default.createElement(Container$i, {
36070
35867
  maxLines: maxLines
36071
35868
  }, children);
36072
35869
  };
36073
- var Container$k = /*#__PURE__*/styled.div.withConfig({
35870
+ var Container$i = /*#__PURE__*/styled.div.withConfig({
36074
35871
  displayName: "Truncate__Container",
36075
35872
  componentId: "sc-6x00qb-0"
36076
35873
  })(["display:-webkit-box;max-width:100%;max-height:100%;-webkit-line-clamp:", ";-webkit-box-orient:vertical;overflow:hidden;"], function (props) {
36077
35874
  return props.maxLines;
36078
35875
  });
36079
35876
 
35877
+ var IS_MOBILE_OR_TABLET = /*#__PURE__*/shared.isMobileOrTablet();
35878
+
35879
+ var chunkString = function chunkString(str, length) {
35880
+ return str.match(new RegExp('.{1,' + length + '}', 'g'));
35881
+ };
35882
+
35883
+ var img$d = '';
35884
+
35885
+ var NPCDialogText = function NPCDialogText(_ref) {
35886
+ var text = _ref.text,
35887
+ onClose = _ref.onClose,
35888
+ onEndStep = _ref.onEndStep,
35889
+ onStartStep = _ref.onStartStep,
35890
+ type = _ref.type;
35891
+ var windowSize = React.useRef([window.innerWidth, window.innerHeight]);
35892
+ function maxCharacters(width) {
35893
+ // Set the font size to 16 pixels
35894
+ var fontSize = 11.2;
35895
+ // Calculate the number of characters that can fit in one line
35896
+ var charactersPerLine = Math.floor(width / 2 / fontSize);
35897
+ // Calculate the number of lines that can fit in the div
35898
+ var linesPerDiv = Math.floor(180 / fontSize);
35899
+ // Calculate the maximum number of characters that can fit in the div
35900
+ var maxCharacters = charactersPerLine * linesPerDiv;
35901
+ // Return the maximum number of characters
35902
+ return Math.round(maxCharacters / 5);
35903
+ }
35904
+ var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
35905
+ var _useState = React.useState(0),
35906
+ chunkIndex = _useState[0],
35907
+ setChunkIndex = _useState[1];
35908
+ var onHandleSpacePress = function onHandleSpacePress(event) {
35909
+ if (event.code === 'Space') {
35910
+ goToNextStep();
35911
+ }
35912
+ };
35913
+ var goToNextStep = function goToNextStep() {
35914
+ var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
35915
+ if (hasNextChunk) {
35916
+ setChunkIndex(function (prev) {
35917
+ return prev + 1;
35918
+ });
35919
+ } else {
35920
+ // if there's no more text chunks, close the dialog
35921
+ onClose();
35922
+ }
35923
+ };
35924
+ React.useEffect(function () {
35925
+ document.addEventListener('keydown', onHandleSpacePress);
35926
+ return function () {
35927
+ return document.removeEventListener('keydown', onHandleSpacePress);
35928
+ };
35929
+ }, [chunkIndex]);
35930
+ var _useState2 = React.useState(false),
35931
+ showGoNextIndicator = _useState2[0],
35932
+ setShowGoNextIndicator = _useState2[1];
35933
+ return React__default.createElement(Container$j, null, React__default.createElement(DynamicText, {
35934
+ text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
35935
+ onFinish: function onFinish() {
35936
+ setShowGoNextIndicator(true);
35937
+ onEndStep && onEndStep();
35938
+ },
35939
+ onStart: function onStart() {
35940
+ setShowGoNextIndicator(false);
35941
+ onStartStep && onStartStep();
35942
+ }
35943
+ }), showGoNextIndicator && React__default.createElement(PressSpaceIndicator$1, {
35944
+ right: type === exports.NPCDialogType.TextOnly ? '1rem' : '10.5rem',
35945
+ src: IS_MOBILE_OR_TABLET ? img$d : img$7,
35946
+ onClick: function onClick() {
35947
+ goToNextStep();
35948
+ }
35949
+ }));
35950
+ };
35951
+ var Container$j = /*#__PURE__*/styled.div.withConfig({
35952
+ displayName: "NPCDialogText__Container",
35953
+ componentId: "sc-1cxkdh9-0"
35954
+ })([""]);
35955
+ var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
35956
+ displayName: "NPCDialogText__PressSpaceIndicator",
35957
+ componentId: "sc-1cxkdh9-1"
35958
+ })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
35959
+ var right = _ref2.right;
35960
+ return right;
35961
+ });
35962
+
35963
+ (function (NPCDialogType) {
35964
+ NPCDialogType["TextOnly"] = "TextOnly";
35965
+ NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
35966
+ })(exports.NPCDialogType || (exports.NPCDialogType = {}));
35967
+ var NPCDialog = function NPCDialog(_ref) {
35968
+ var text = _ref.text,
35969
+ type = _ref.type,
35970
+ _onClose = _ref.onClose,
35971
+ imagePath = _ref.imagePath,
35972
+ _ref$isQuestionDialog = _ref.isQuestionDialog,
35973
+ isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
35974
+ questions = _ref.questions,
35975
+ answers = _ref.answers;
35976
+ return React__default.createElement(RPGUIContainer, {
35977
+ type: exports.RPGUIContainerTypes.FramedGold,
35978
+ width: isQuestionDialog ? '600px' : '80%',
35979
+ height: '180px'
35980
+ }, isQuestionDialog && questions && answers ? React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer$2, {
35981
+ flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
35982
+ }, React__default.createElement(QuestionDialog, {
35983
+ questions: questions,
35984
+ answers: answers,
35985
+ onClose: function onClose() {
35986
+ if (_onClose) {
35987
+ _onClose();
35988
+ }
35989
+ }
35990
+ })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
35991
+ src: imagePath || img$6
35992
+ }))) : React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$k, null, React__default.createElement(TextContainer$2, {
35993
+ flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
35994
+ }, React__default.createElement(NPCDialogText, {
35995
+ type: type,
35996
+ text: text || 'No text provided.',
35997
+ onClose: function onClose() {
35998
+ if (_onClose) {
35999
+ _onClose();
36000
+ }
36001
+ }
36002
+ })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
36003
+ src: imagePath || img$6
36004
+ })))));
36005
+ };
36006
+ var Container$k = /*#__PURE__*/styled.div.withConfig({
36007
+ displayName: "NPCDialog__Container",
36008
+ componentId: "sc-1b4aw74-0"
36009
+ })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
36010
+ var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
36011
+ displayName: "NPCDialog__TextContainer",
36012
+ componentId: "sc-1b4aw74-1"
36013
+ })(["flex:", " 0 0;width:355px;"], function (_ref2) {
36014
+ var flex = _ref2.flex;
36015
+ return flex;
36016
+ });
36017
+ var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
36018
+ displayName: "NPCDialog__ThumbnailContainer",
36019
+ componentId: "sc-1b4aw74-2"
36020
+ })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
36021
+ var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
36022
+ displayName: "NPCDialog__NPCThumbnail",
36023
+ componentId: "sc-1b4aw74-3"
36024
+ })(["image-rendering:pixelated;height:128px;width:128px;"]);
36025
+
36026
+ var HistoryDialog = function HistoryDialog(_ref) {
36027
+ var backgroundImgPath = _ref.backgroundImgPath,
36028
+ fullCoverBackground = _ref.fullCoverBackground,
36029
+ questions = _ref.questions,
36030
+ answers = _ref.answers,
36031
+ text = _ref.text,
36032
+ imagePath = _ref.imagePath,
36033
+ textAndTypeArray = _ref.textAndTypeArray,
36034
+ onClose = _ref.onClose;
36035
+ var _useState = React.useState(0),
36036
+ img = _useState[0],
36037
+ setImage = _useState[1];
36038
+ var onHandleSpacePress = function onHandleSpacePress(event) {
36039
+ if (event.code === 'Space') {
36040
+ if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
36041
+ setImage(function (prev) {
36042
+ return prev + 1;
36043
+ });
36044
+ } else {
36045
+ // if there's no more text chunks, close the dialog
36046
+ onClose();
36047
+ }
36048
+ }
36049
+ };
36050
+ React.useEffect(function () {
36051
+ document.addEventListener('keydown', onHandleSpacePress);
36052
+ return function () {
36053
+ return document.removeEventListener('keydown', onHandleSpacePress);
36054
+ };
36055
+ }, [backgroundImgPath]);
36056
+ return React__default.createElement(BackgroundContainer, {
36057
+ imgPath: backgroundImgPath[img],
36058
+ fullImg: fullCoverBackground
36059
+ }, React__default.createElement(DialogContainer, null, textAndTypeArray ? React__default.createElement(NPCMultiDialog, {
36060
+ textAndTypeArray: textAndTypeArray,
36061
+ onClose: onClose
36062
+ }) : questions && answers ? React__default.createElement(QuestionDialog, {
36063
+ questions: questions,
36064
+ answers: answers,
36065
+ onClose: onClose
36066
+ }) : text && imagePath ? React__default.createElement(NPCDialog, {
36067
+ text: text,
36068
+ imagePath: imagePath,
36069
+ onClose: onClose,
36070
+ type: exports.NPCDialogType.TextAndThumbnail
36071
+ }) : React__default.createElement(NPCDialog, {
36072
+ text: text,
36073
+ onClose: onClose,
36074
+ type: exports.NPCDialogType.TextOnly
36075
+ })));
36076
+ };
36077
+ var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
36078
+ displayName: "HistoryDialog__BackgroundContainer",
36079
+ componentId: "sc-u6oe75-0"
36080
+ })(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
36081
+ return props.imgPath;
36082
+ }, function (props) {
36083
+ return props.imgPath ? 'cover' : 'auto';
36084
+ });
36085
+ var DialogContainer = /*#__PURE__*/styled.div.withConfig({
36086
+ displayName: "HistoryDialog__DialogContainer",
36087
+ componentId: "sc-u6oe75-1"
36088
+ })(["display:flex;justify-content:center;padding-top:200px;"]);
36089
+
36080
36090
  exports.Button = Button;
36081
36091
  exports.CharacterSelection = CharacterSelection;
36082
36092
  exports.Chat = Chat;