@rpg-engine/long-bow 0.3.62 → 0.3.64

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 (142) hide show
  1. package/LICENSE +20 -20
  2. package/README.md +181 -181
  3. package/dist/long-bow.cjs.development.js +924 -913
  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 +738 -727
  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 +69 -69
  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 +40 -40
  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 +198 -198
  25. package/src/components/CheckButton.tsx +65 -65
  26. package/src/components/CircularController/CircularController.tsx +248 -248
  27. package/src/components/CraftBook/CraftBook.tsx +227 -227
  28. package/src/components/CraftBook/MockItems.ts +46 -46
  29. package/src/components/DraggableContainer.tsx +165 -153
  30. package/src/components/Dropdown.tsx +90 -90
  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 +210 -210
  38. package/src/components/Item/Inventory/ItemContainerTypes.ts +6 -6
  39. package/src/components/Item/Inventory/ItemQuantitySelector.tsx +138 -138
  40. package/src/components/Item/Inventory/ItemSlot.tsx +501 -501
  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 +66 -66
  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 +106 -106
  52. package/src/components/QuestInfo/QuestInfo.tsx +230 -230
  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 +96 -96
  59. package/src/components/RadioInput/RadioInput.tsx +102 -102
  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/Shortcuts/Shortcuts.tsx +151 -151
  65. package/src/components/Shortcuts/ShortcutsSetter.tsx +132 -132
  66. package/src/components/Shortcuts/SingleShortcut.ts +62 -62
  67. package/src/components/SimpleProgressBar.tsx +62 -62
  68. package/src/components/SkillProgressBar.tsx +133 -133
  69. package/src/components/SkillsContainer.tsx +198 -198
  70. package/src/components/Spellbook/Spell.tsx +201 -201
  71. package/src/components/Spellbook/Spellbook.tsx +150 -150
  72. package/src/components/Spellbook/constants.ts +8 -8
  73. package/src/components/Spellbook/mockSpells.ts +60 -60
  74. package/src/components/StaticBook/StaticBook.tsx +103 -103
  75. package/src/components/TextArea.tsx +11 -11
  76. package/src/components/TimeWidget/DayNightPeriod/DayNightPeriod.tsx +35 -35
  77. package/src/components/TimeWidget/TimeWidget.tsx +63 -63
  78. package/src/components/TradingMenu/TradingItemRow.tsx +181 -181
  79. package/src/components/TradingMenu/TradingMenu.tsx +203 -203
  80. package/src/components/TradingMenu/items.mock.ts +96 -96
  81. package/src/components/Truncate.tsx +25 -25
  82. package/src/components/itemSelector/ItemSelector.tsx +136 -136
  83. package/src/components/shared/Column.tsx +16 -16
  84. package/src/components/shared/Ellipsis.tsx +65 -65
  85. package/src/components/shared/SpriteFromAtlas.tsx +102 -102
  86. package/src/components/typography/DynamicText.tsx +49 -49
  87. package/src/constants/uiColors.ts +20 -20
  88. package/src/constants/uiDevices.ts +3 -3
  89. package/src/constants/uiFonts.ts +12 -12
  90. package/src/hooks/useEventListener.ts +21 -21
  91. package/src/hooks/useOutsideAlerter.ts +25 -25
  92. package/src/index.tsx +40 -40
  93. package/src/libs/StringHelpers.ts +3 -3
  94. package/src/mocks/atlas/entities/entities.json +20215 -20215
  95. package/src/mocks/atlas/icons/icons.json +735 -735
  96. package/src/mocks/atlas/items/items.json +12086 -12086
  97. package/src/mocks/equipmentSet.mocks.ts +393 -393
  98. package/src/mocks/itemContainer.mocks.ts +562 -562
  99. package/src/mocks/skills.mocks.ts +128 -128
  100. package/src/stories/Arrow.stories.tsx +26 -26
  101. package/src/stories/Button.stories.tsx +36 -36
  102. package/src/stories/CharacterSelection.stories.tsx +45 -45
  103. package/src/stories/CharacterStatus.stories.tsx +29 -29
  104. package/src/stories/Chat.stories.tsx +187 -187
  105. package/src/stories/ChatDeprecated.stories.tsx +170 -170
  106. package/src/stories/CheckButton.stories.tsx +48 -48
  107. package/src/stories/CircullarController.stories.tsx +37 -37
  108. package/src/stories/CraftBook.stories.tsx +40 -40
  109. package/src/stories/DayNightPeriod.stories.tsx +27 -27
  110. package/src/stories/DraggableContainer.stories.tsx +28 -28
  111. package/src/stories/Dropdown.stories.tsx +46 -46
  112. package/src/stories/DropdownSelectorContainer.stories.tsx +41 -41
  113. package/src/stories/EquipmentSet.stories.tsx +65 -65
  114. package/src/stories/HistoryDialog.stories.tsx +61 -61
  115. package/src/stories/ItemContainer.stories.tsx +198 -198
  116. package/src/stories/ItemQuantitySelector.stories.tsx +26 -26
  117. package/src/stories/ItemSelector.stories.tsx +77 -77
  118. package/src/stories/ItemTradingComponent.stories.tsx +35 -35
  119. package/src/stories/ListMenu.stories.tsx +56 -56
  120. package/src/stories/Multitab.stories.tsx +51 -51
  121. package/src/stories/NPCDialog.stories.tsx +130 -130
  122. package/src/stories/NPCMultiDialog.stories.tsx +71 -71
  123. package/src/stories/ProgressBar.stories.tsx +23 -23
  124. package/src/stories/PropertySelect.stories.tsx +40 -40
  125. package/src/stories/QuestInfo.stories.tsx +107 -107
  126. package/src/stories/QuestList.stories.tsx +82 -82
  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/Shortcuts.stories.tsx +39 -39
  133. package/src/stories/SimpleProgressBar.stories.tsx +22 -22
  134. package/src/stories/SkillProgressBar.stories.tsx +34 -34
  135. package/src/stories/SkillsContainer.stories.tsx +35 -35
  136. package/src/stories/Spellbook.stories.tsx +104 -104
  137. package/src/stories/StaticBook.stories.tsx +32 -32
  138. package/src/stories/Text.stories.tsx +42 -42
  139. package/src/stories/TimeWidget.stories.tsx +27 -27
  140. package/src/stories/TradingMenu.stories.tsx +45 -45
  141. package/src/types/eventTypes.ts +4 -4
  142. package/src/types/index.d.ts +2 -2
@@ -33224,6 +33224,17 @@ var DraggableContainer = function DraggableContainer(_ref) {
33224
33224
  } : _ref$initialPosition;
33225
33225
  var draggableRef = React.useRef(null);
33226
33226
  useOutsideClick(draggableRef, 'item-container');
33227
+ React.useEffect(function () {
33228
+ var handleKeyDown = function handleKeyDown(event) {
33229
+ if (event.key === 'Escape' && onCloseButton) {
33230
+ onCloseButton();
33231
+ }
33232
+ };
33233
+ document.addEventListener('keydown', handleKeyDown);
33234
+ return function () {
33235
+ document.removeEventListener('keydown', handleKeyDown);
33236
+ };
33237
+ }, [onCloseButton]);
33227
33238
  React.useEffect(function () {
33228
33239
  document.addEventListener('clickOutside', function (event) {
33229
33240
  var e = event;
@@ -34145,509 +34156,374 @@ var EquipmentColumn = /*#__PURE__*/styled.div.withConfig({
34145
34156
  componentId: "sc-1wuddg2-1"
34146
34157
  })(["display:flex;justify-content:center;flex-wrap:wrap;flex-direction:column;touch-action:none;"]);
34147
34158
 
34148
- var SlotsContainer = function SlotsContainer(_ref) {
34149
- var children = _ref.children,
34150
- title = _ref.title,
34151
- onClose = _ref.onClose,
34152
- _onPositionChange = _ref.onPositionChange,
34153
- onOutsideClick = _ref.onOutsideClick,
34154
- initialPosition = _ref.initialPosition;
34155
- return React__default.createElement(DraggableContainer, {
34156
- title: title,
34157
- type: exports.RPGUIContainerTypes.Framed,
34158
- onCloseButton: function onCloseButton() {
34159
- if (onClose) {
34160
- onClose();
34159
+ var IS_MOBILE_OR_TABLET = /*#__PURE__*/shared.isMobileOrTablet();
34160
+
34161
+ var chunkString = function chunkString(str, length) {
34162
+ return str.match(new RegExp('.{1,' + length + '}', 'g'));
34163
+ };
34164
+
34165
+ var DynamicText = function DynamicText(_ref) {
34166
+ var text = _ref.text,
34167
+ onFinish = _ref.onFinish,
34168
+ onStart = _ref.onStart;
34169
+ var _useState = React.useState(''),
34170
+ textState = _useState[0],
34171
+ setTextState = _useState[1];
34172
+ React.useEffect(function () {
34173
+ var i = 0;
34174
+ var interval = setInterval(function () {
34175
+ // on every interval, show one more character
34176
+ if (i === 0) {
34177
+ if (onStart) {
34178
+ onStart();
34179
+ }
34161
34180
  }
34162
- },
34163
- width: "400px",
34164
- cancelDrag: ".item-container-body, #shortcuts_list",
34165
- onPositionChange: function onPositionChange(_ref2) {
34166
- var x = _ref2.x,
34167
- y = _ref2.y;
34168
- if (_onPositionChange) {
34169
- _onPositionChange({
34170
- x: x,
34171
- y: y
34172
- });
34181
+ if (i < text.length) {
34182
+ setTextState(text.substring(0, i + 1));
34183
+ i++;
34184
+ } else {
34185
+ clearInterval(interval);
34186
+ if (onFinish) {
34187
+ onFinish();
34188
+ }
34173
34189
  }
34174
- },
34175
- onOutsideClick: onOutsideClick,
34176
- initialPosition: initialPosition
34177
- }, children);
34190
+ }, 50);
34191
+ return function () {
34192
+ clearInterval(interval);
34193
+ };
34194
+ }, [text]);
34195
+ return React__default.createElement(TextContainer, null, textState);
34178
34196
  };
34197
+ var TextContainer = /*#__PURE__*/styled.p.withConfig({
34198
+ displayName: "DynamicText__TextContainer",
34199
+ componentId: "sc-1ggl9nd-0"
34200
+ })(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]);
34179
34201
 
34180
- (function (RangeSliderType) {
34181
- RangeSliderType["Slider"] = "rpgui-slider";
34182
- RangeSliderType["GoldSlider"] = "rpgui-slider golden";
34183
- })(exports.RangeSliderType || (exports.RangeSliderType = {}));
34184
- var RangeSlider = function RangeSlider(_ref) {
34185
- var type = _ref.type,
34186
- valueMin = _ref.valueMin,
34187
- valueMax = _ref.valueMax,
34188
- width = _ref.width,
34189
- _onChange = _ref.onChange,
34190
- value = _ref.value;
34191
- var sliderId = uuid.v4();
34192
- var containerRef = React.useRef(null);
34202
+ var img$6 = '';
34203
+
34204
+ var img$7 = '';
34205
+
34206
+ var NPCDialogText = function NPCDialogText(_ref) {
34207
+ var text = _ref.text,
34208
+ onClose = _ref.onClose,
34209
+ onEndStep = _ref.onEndStep,
34210
+ onStartStep = _ref.onStartStep,
34211
+ type = _ref.type;
34212
+ var windowSize = React.useRef([window.innerWidth, window.innerHeight]);
34213
+ function maxCharacters(width) {
34214
+ // Set the font size to 16 pixels
34215
+ var fontSize = 11.2;
34216
+ // Calculate the number of characters that can fit in one line
34217
+ var charactersPerLine = Math.floor(width / 2 / fontSize);
34218
+ // Calculate the number of lines that can fit in the div
34219
+ var linesPerDiv = Math.floor(180 / fontSize);
34220
+ // Calculate the maximum number of characters that can fit in the div
34221
+ var maxCharacters = charactersPerLine * linesPerDiv;
34222
+ // Return the maximum number of characters
34223
+ return Math.round(maxCharacters / 5);
34224
+ }
34225
+ var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
34193
34226
  var _useState = React.useState(0),
34194
- left = _useState[0],
34195
- setLeft = _useState[1];
34227
+ chunkIndex = _useState[0],
34228
+ setChunkIndex = _useState[1];
34229
+ var onHandleSpacePress = function onHandleSpacePress(event) {
34230
+ if (event.code === 'Space') {
34231
+ goToNextStep();
34232
+ }
34233
+ };
34234
+ var goToNextStep = function goToNextStep() {
34235
+ var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
34236
+ if (hasNextChunk) {
34237
+ setChunkIndex(function (prev) {
34238
+ return prev + 1;
34239
+ });
34240
+ } else {
34241
+ // if there's no more text chunks, close the dialog
34242
+ onClose();
34243
+ }
34244
+ };
34196
34245
  React.useEffect(function () {
34197
- var _containerRef$current;
34198
- var calculatedWidth = ((_containerRef$current = containerRef.current) == null ? void 0 : _containerRef$current.clientWidth) || 0;
34199
- setLeft(Math.max((value - valueMin) / (valueMax - valueMin) * (calculatedWidth - 35) + 10));
34200
- }, [value, valueMin, valueMax]);
34201
- var typeClass = type === exports.RangeSliderType.GoldSlider ? 'golden' : '';
34202
- return React__default.createElement("div", {
34203
- style: {
34204
- width: width,
34205
- position: 'relative'
34246
+ document.addEventListener('keydown', onHandleSpacePress);
34247
+ return function () {
34248
+ return document.removeEventListener('keydown', onHandleSpacePress);
34249
+ };
34250
+ }, [chunkIndex]);
34251
+ var _useState2 = React.useState(false),
34252
+ showGoNextIndicator = _useState2[0],
34253
+ setShowGoNextIndicator = _useState2[1];
34254
+ return React__default.createElement(Container$b, null, React__default.createElement(DynamicText, {
34255
+ text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
34256
+ onFinish: function onFinish() {
34257
+ setShowGoNextIndicator(true);
34258
+ onEndStep && onEndStep();
34206
34259
  },
34207
- className: "rpgui-slider-container " + typeClass,
34208
- id: "rpgui-slider-" + sliderId,
34209
- ref: containerRef
34210
- }, React__default.createElement("div", {
34211
- style: {
34212
- pointerEvents: 'none'
34260
+ onStart: function onStart() {
34261
+ setShowGoNextIndicator(false);
34262
+ onStartStep && onStartStep();
34213
34263
  }
34214
- }, React__default.createElement("div", {
34215
- className: "rpgui-slider-track " + typeClass
34216
- }), React__default.createElement("div", {
34217
- className: "rpgui-slider-left-edge " + typeClass
34218
- }), React__default.createElement("div", {
34219
- className: "rpgui-slider-right-edge " + typeClass
34220
- }), React__default.createElement("div", {
34221
- className: "rpgui-slider-thumb " + typeClass,
34222
- style: {
34223
- left: left
34264
+ }), showGoNextIndicator && React__default.createElement(PressSpaceIndicator, {
34265
+ right: type === exports.NPCDialogType.TextOnly ? '1rem' : '10.5rem',
34266
+ src: IS_MOBILE_OR_TABLET ? img$6 : img$7,
34267
+ onPointerDown: function onPointerDown() {
34268
+ goToNextStep();
34224
34269
  }
34225
- })), React__default.createElement(Input$1, {
34226
- type: "range",
34227
- style: {
34228
- width: width
34229
- },
34230
- min: valueMin,
34231
- max: valueMax,
34232
- onChange: function onChange(e) {
34233
- return _onChange(Number(e.target.value));
34234
- },
34235
- value: value,
34236
- className: "rpgui-cursor-point"
34237
34270
  }));
34238
34271
  };
34239
- var Input$1 = /*#__PURE__*/styled.input.withConfig({
34240
- displayName: "RangeSlider__Input",
34241
- componentId: "sc-v8mte9-0"
34242
- })(["opacity:0;position:absolute;width:100%;height:100%;top:0;left:0;margin-top:-5px;"]);
34272
+ var Container$b = /*#__PURE__*/styled.div.withConfig({
34273
+ displayName: "NPCDialogText__Container",
34274
+ componentId: "sc-1cxkdh9-0"
34275
+ })([""]);
34276
+ var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
34277
+ displayName: "NPCDialogText__PressSpaceIndicator",
34278
+ componentId: "sc-1cxkdh9-1"
34279
+ })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
34280
+ var right = _ref2.right;
34281
+ return right;
34282
+ });
34243
34283
 
34244
- var ItemQuantitySelector = function ItemQuantitySelector(_ref) {
34245
- var quantity = _ref.quantity,
34246
- onConfirm = _ref.onConfirm,
34284
+ //@ts-ignore
34285
+ var useEventListener = function useEventListener(type, handler, el) {
34286
+ if (el === void 0) {
34287
+ el = window;
34288
+ }
34289
+ var savedHandler = React__default.useRef();
34290
+ React__default.useEffect(function () {
34291
+ savedHandler.current = handler;
34292
+ }, [handler]);
34293
+ React__default.useEffect(function () {
34294
+ //@ts-ignore
34295
+ var listener = function listener(e) {
34296
+ return savedHandler.current(e);
34297
+ };
34298
+ el.addEventListener(type, listener);
34299
+ return function () {
34300
+ el.removeEventListener(type, listener);
34301
+ };
34302
+ }, [type, el]);
34303
+ };
34304
+
34305
+ var QuestionDialog = function QuestionDialog(_ref) {
34306
+ var questions = _ref.questions,
34307
+ answers = _ref.answers,
34247
34308
  onClose = _ref.onClose;
34248
- var _useState = React.useState(quantity),
34249
- value = _useState[0],
34250
- setValue = _useState[1];
34251
- var inputRef = React.useRef(null);
34252
- React.useEffect(function () {
34253
- if (inputRef.current) {
34254
- inputRef.current.focus();
34255
- inputRef.current.select();
34256
- var closeSelector = function closeSelector(e) {
34257
- if (e.key === 'Escape') {
34258
- onClose();
34259
- }
34260
- };
34261
- document.addEventListener('keydown', closeSelector);
34262
- return function () {
34263
- document.removeEventListener('keydown', closeSelector);
34264
- };
34309
+ var _useState = React.useState(questions[0]),
34310
+ currentQuestion = _useState[0],
34311
+ setCurrentQuestion = _useState[1];
34312
+ var _useState2 = React.useState(false),
34313
+ canShowAnswers = _useState2[0],
34314
+ setCanShowAnswers = _useState2[1];
34315
+ var onGetFirstAnswer = function onGetFirstAnswer() {
34316
+ if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {
34317
+ return null;
34265
34318
  }
34266
- return function () {};
34267
- }, []);
34268
- return React__default.createElement(StyledContainer, {
34269
- type: exports.RPGUIContainerTypes.Framed,
34270
- width: "25rem"
34271
- }, React__default.createElement(CloseButton$2, {
34272
- className: "container-close",
34273
- onPointerDown: onClose
34274
- }, "X"), React__default.createElement("h2", null, "Select quantity to move"), React__default.createElement(StyledForm, {
34275
- style: {
34276
- width: '100%'
34277
- },
34278
- onSubmit: function onSubmit(e) {
34279
- e.preventDefault();
34280
- var numberValue = Number(value);
34281
- if (Number.isNaN(numberValue)) {
34282
- return;
34283
- }
34284
- onConfirm(Math.max(1, Math.min(quantity, numberValue)));
34285
- },
34286
- noValidate: true
34287
- }, React__default.createElement(StyledInput, {
34288
- innerRef: inputRef,
34289
- placeholder: "Enter quantity",
34290
- type: "number",
34291
- min: 1,
34292
- max: quantity,
34293
- value: value,
34294
- onChange: function onChange(e) {
34295
- if (Number(e.target.value) >= quantity) {
34296
- setValue(quantity);
34297
- return;
34298
- }
34299
- setValue(e.target.value);
34300
- },
34301
- onBlur: function onBlur(e) {
34302
- var newValue = Math.max(1, Math.min(quantity, Number(e.target.value)));
34303
- setValue(newValue);
34304
- }
34305
- }), React__default.createElement(RangeSlider, {
34306
- type: exports.RangeSliderType.Slider,
34307
- valueMin: 1,
34308
- valueMax: quantity,
34309
- width: "100%",
34310
- onChange: setValue,
34311
- value: value
34312
- }), React__default.createElement(Button, {
34313
- buttonType: exports.ButtonTypes.RPGUIButton,
34314
- type: "submit"
34315
- }, "Confirm")));
34316
- };
34317
- var StyledContainer = /*#__PURE__*/styled(RPGUIContainer).withConfig({
34318
- displayName: "ItemQuantitySelector__StyledContainer",
34319
- componentId: "sc-yfdtpn-0"
34320
- })(["display:flex;flex-direction:column;align-items:center;"]);
34321
- var StyledForm = /*#__PURE__*/styled.form.withConfig({
34322
- displayName: "ItemQuantitySelector__StyledForm",
34323
- componentId: "sc-yfdtpn-1"
34324
- })(["display:flex;flex-direction:column;align-items:center;width:100%;"]);
34325
- var StyledInput = /*#__PURE__*/styled(Input).withConfig({
34326
- displayName: "ItemQuantitySelector__StyledInput",
34327
- componentId: "sc-yfdtpn-2"
34328
- })(["text-align:center;&::-webkit-outer-spin-button,&::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}&[type='number']{-moz-appearance:textfield;}"]);
34329
- var CloseButton$2 = /*#__PURE__*/styled.div.withConfig({
34330
- displayName: "ItemQuantitySelector__CloseButton",
34331
- componentId: "sc-yfdtpn-3"
34332
- })(["position:absolute;top:3px;right:0px;color:white;z-index:22;font-size:0.8rem;"]);
34333
-
34334
- var ShortcutsSetter = function ShortcutsSetter(_ref) {
34335
- var setSettingShortcutIndex = _ref.setSettingShortcutIndex,
34336
- settingShortcutIndex = _ref.settingShortcutIndex,
34337
- shortcuts = _ref.shortcuts,
34338
- removeShortcut = _ref.removeShortcut,
34339
- atlasJSON = _ref.atlasJSON,
34340
- atlasIMG = _ref.atlasIMG;
34341
- var getContent = function getContent(index) {
34342
- var _shortcuts$index, _shortcuts$index3;
34343
- if (((_shortcuts$index = shortcuts[index]) == null ? void 0 : _shortcuts$index.type) === shared.ShortcutType.Item) {
34344
- var _shortcuts$index2;
34345
- var _payload = (_shortcuts$index2 = shortcuts[index]) == null ? void 0 : _shortcuts$index2.payload;
34346
- if (!_payload) return null;
34347
- return React__default.createElement(SpriteFromAtlas, {
34348
- atlasIMG: atlasIMG,
34349
- atlasJSON: atlasJSON,
34350
- spriteKey: shared.getItemTextureKeyPath({
34351
- key: _payload.texturePath,
34352
- texturePath: _payload.texturePath,
34353
- stackQty: _payload.stackQty || 1
34354
- }, atlasJSON),
34355
- width: 32,
34356
- height: 32,
34357
- imgScale: 1.6,
34358
- imgStyle: {
34359
- left: '5px'
34360
- }
34319
+ var firstAnswerId = currentQuestion.answerIds[0];
34320
+ return answers.find(function (answer) {
34321
+ return answer.id === firstAnswerId;
34322
+ });
34323
+ };
34324
+ var _useState3 = React.useState(onGetFirstAnswer()),
34325
+ currentAnswer = _useState3[0],
34326
+ setCurrentAnswer = _useState3[1];
34327
+ React.useEffect(function () {
34328
+ setCurrentAnswer(onGetFirstAnswer());
34329
+ }, [currentQuestion]);
34330
+ var onGetAnswers = function onGetAnswers(answerIds) {
34331
+ return answerIds.map(function (answerId) {
34332
+ return answers.find(function (answer) {
34333
+ return answer.id === answerId;
34361
34334
  });
34335
+ });
34336
+ };
34337
+ var onKeyPress = function onKeyPress(e) {
34338
+ switch (e.key) {
34339
+ case 'ArrowDown':
34340
+ // select next answer, if any.
34341
+ // if no next answer, select first answer
34342
+ // const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(
34343
+ // (answer) => answer?.id === currentAnswer!.id + 1
34344
+ // );
34345
+ var nextAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34346
+ return (answer == null ? void 0 : answer.id) === currentAnswer.id + 1;
34347
+ });
34348
+ var nextAnswerID = currentQuestion.answerIds[nextAnswerIndex];
34349
+ var nextAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34350
+ return (answer == null ? void 0 : answer.id) === nextAnswerID;
34351
+ });
34352
+ setCurrentAnswer(nextAnswer || onGetFirstAnswer());
34353
+ break;
34354
+ case 'ArrowUp':
34355
+ // select previous answer, if any.
34356
+ // if no previous answer, select last answer
34357
+ var previousAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34358
+ return (answer == null ? void 0 : answer.id) === currentAnswer.id - 1;
34359
+ });
34360
+ var previousAnswerID = currentQuestion.answerIds && currentQuestion.answerIds[previousAnswerIndex];
34361
+ var previousAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34362
+ return (answer == null ? void 0 : answer.id) === previousAnswerID;
34363
+ });
34364
+ if (previousAnswer) {
34365
+ setCurrentAnswer(previousAnswer);
34366
+ } else {
34367
+ setCurrentAnswer(onGetAnswers(currentQuestion.answerIds).pop());
34368
+ }
34369
+ break;
34370
+ case 'Enter':
34371
+ setCanShowAnswers(false);
34372
+ if (!(currentAnswer != null && currentAnswer.nextQuestionId)) {
34373
+ onClose();
34374
+ return;
34375
+ } else {
34376
+ setCurrentQuestion(questions.find(function (question) {
34377
+ return question.id === currentAnswer.nextQuestionId;
34378
+ }));
34379
+ }
34380
+ break;
34362
34381
  }
34363
- var payload = (_shortcuts$index3 = shortcuts[index]) == null ? void 0 : _shortcuts$index3.payload;
34364
- return React__default.createElement("span", null, payload == null ? void 0 : payload.magicWords.split(' ').map(function (word) {
34365
- return word[0];
34366
- }));
34367
34382
  };
34368
- return React__default.createElement(Container$b, null, React__default.createElement("p", null, "Shortcuts:"), React__default.createElement(List, {
34369
- id: "shortcuts_list"
34370
- }, Array.from({
34371
- length: 6
34372
- }).map(function (_, i) {
34373
- return React__default.createElement(Shortcut, {
34374
- key: i,
34375
- onPointerDown: function onPointerDown() {
34376
- removeShortcut(i);
34377
- if (!shortcuts[i] || shortcuts[i].type === shared.ShortcutType.None) setSettingShortcutIndex(i);
34378
- },
34379
- disabled: settingShortcutIndex !== -1 && settingShortcutIndex !== i,
34380
- isBeingSet: settingShortcutIndex === i
34381
- }, getContent(i));
34382
- })));
34383
- };
34384
- var Container$b = /*#__PURE__*/styled.div.withConfig({
34385
- displayName: "ShortcutsSetter__Container",
34386
- componentId: "sc-xuouuf-0"
34387
- })(["p{margin:0;margin-left:0.5rem;}"]);
34388
- var Shortcut = /*#__PURE__*/styled.button.withConfig({
34389
- displayName: "ShortcutsSetter__Shortcut",
34390
- componentId: "sc-xuouuf-1"
34391
- })(["width:2.6rem;height:2.6rem;background-color:", ";border:2px solid ", ";border-radius:50%;text-transform:uppercase;font-size:0.7rem;font-weight:bold;display:flex;align-items:center;justify-content:center;span{margin-top:4px;}&:hover,&:focus{background-color:", ";}&:active{background-color:", ";}&:disabled{opacity:0.5;}"], uiColors.lightGray, function (_ref2) {
34392
- var isBeingSet = _ref2.isBeingSet;
34393
- return isBeingSet ? uiColors.yellow : uiColors.darkGray;
34394
- }, uiColors.darkGray, uiColors.gray);
34395
- var List = /*#__PURE__*/styled.div.withConfig({
34396
- displayName: "ShortcutsSetter__List",
34397
- componentId: "sc-xuouuf-2"
34398
- })(["width:100%;display:flex;align-items:center;gap:0.5rem;padding-bottom:0.5rem;padding-left:0.5rem;box-sizing:border-box;margin:0 !important;"]);
34399
-
34400
- var ItemContainer$1 = function ItemContainer(_ref) {
34401
- var itemContainer = _ref.itemContainer,
34402
- onClose = _ref.onClose,
34403
- _onMouseOver = _ref.onMouseOver,
34404
- _onSelected = _ref.onSelected,
34405
- onItemClick = _ref.onItemClick,
34406
- type = _ref.type,
34407
- atlasJSON = _ref.atlasJSON,
34408
- atlasIMG = _ref.atlasIMG,
34409
- _ref$disableContextMe = _ref.disableContextMenu,
34410
- disableContextMenu = _ref$disableContextMe === void 0 ? false : _ref$disableContextMe,
34411
- onItemDragEnd = _ref.onItemDragEnd,
34412
- onItemDragStart = _ref.onItemDragStart,
34413
- onItemPlaceDrop = _ref.onItemPlaceDrop,
34414
- _onOutsideDrop = _ref.onOutsideDrop,
34415
- checkIfItemCanBeMoved = _ref.checkIfItemCanBeMoved,
34416
- initialPosition = _ref.initialPosition,
34417
- checkIfItemShouldDragEnd = _ref.checkIfItemShouldDragEnd,
34418
- dragScale = _ref.dragScale,
34419
- shortcuts = _ref.shortcuts,
34420
- setItemShortcut = _ref.setItemShortcut,
34421
- removeShortcut = _ref.removeShortcut;
34422
- var _useState = React.useState({
34423
- isOpen: false,
34424
- maxQuantity: 1,
34425
- callback: function callback(_quantity) {}
34426
- }),
34427
- quantitySelect = _useState[0],
34428
- setQuantitySelect = _useState[1];
34429
- var _useState2 = React.useState(-1),
34430
- settingShortcutIndex = _useState2[0],
34431
- setSettingShortcutIndex = _useState2[1];
34432
- var onRenderSlots = function onRenderSlots() {
34433
- var slots = [];
34434
- for (var i = 0; i < itemContainer.slotQty; i++) {
34435
- var _itemContainer$slots;
34436
- slots.push(React__default.createElement(ItemSlot, {
34437
- isContextMenuDisabled: disableContextMenu,
34438
- key: i,
34439
- slotIndex: i,
34440
- item: ((_itemContainer$slots = itemContainer.slots) == null ? void 0 : _itemContainer$slots[i]) || null,
34441
- itemContainerType: type,
34442
- onMouseOver: function onMouseOver(event, slotIndex, item) {
34443
- if (_onMouseOver) _onMouseOver(event, slotIndex, item);
34444
- },
34445
- onPointerDown: function onPointerDown(itemType, containerType, item) {
34446
- if (settingShortcutIndex !== -1) {
34447
- setSettingShortcutIndex(-1);
34448
- if (itemType === shared.ItemType.Consumable || itemType === shared.ItemType.Tool) {
34449
- setItemShortcut == null ? void 0 : setItemShortcut(item.key, settingShortcutIndex);
34450
- }
34451
- } else if (onItemClick) onItemClick(item, itemType, containerType);
34452
- },
34453
- onSelected: function onSelected(optionId, item) {
34454
- if (_onSelected) _onSelected(optionId, item);
34455
- },
34456
- onDragStart: function onDragStart(item, slotIndex, itemContainerType) {
34457
- if (onItemDragStart) onItemDragStart(item, slotIndex, itemContainerType);
34458
- },
34459
- onDragEnd: function onDragEnd(quantity) {
34460
- if (onItemDragEnd) onItemDragEnd(quantity);
34461
- },
34462
- dragScale: dragScale,
34463
- checkIfItemCanBeMoved: checkIfItemCanBeMoved,
34464
- checkIfItemShouldDragEnd: checkIfItemShouldDragEnd,
34465
- openQuantitySelector: function openQuantitySelector(maxQuantity, callback) {
34466
- setQuantitySelect({
34467
- isOpen: true,
34468
- maxQuantity: maxQuantity,
34469
- callback: callback
34470
- });
34471
- },
34472
- onPlaceDrop: function onPlaceDrop(item, slotIndex, itemContainerType) {
34473
- if (onItemPlaceDrop) onItemPlaceDrop(item, slotIndex, itemContainerType);
34474
- },
34475
- onOutsideDrop: function onOutsideDrop(item, position) {
34476
- if (_onOutsideDrop) _onOutsideDrop(item, position);
34477
- },
34478
- atlasIMG: atlasIMG,
34479
- atlasJSON: atlasJSON,
34480
- isSelectingShortcut: settingShortcutIndex !== -1
34383
+ useEventListener('keydown', onKeyPress);
34384
+ var onAnswerClick = function onAnswerClick(answer) {
34385
+ setCanShowAnswers(false);
34386
+ if (answer.nextQuestionId) {
34387
+ // if there is a next question, go to it
34388
+ setCurrentQuestion(questions.find(function (question) {
34389
+ return question.id === answer.nextQuestionId;
34481
34390
  }));
34391
+ } else {
34392
+ // else, finish dialog!
34393
+ onClose();
34482
34394
  }
34483
- return slots;
34484
34395
  };
34485
- return React__default.createElement(React__default.Fragment, null, React__default.createElement(SlotsContainer, {
34486
- title: itemContainer.name || 'Container',
34487
- onClose: onClose,
34488
- initialPosition: initialPosition
34489
- }, type === shared.ItemContainerType.Inventory && shortcuts && removeShortcut && React__default.createElement(ShortcutsSetter, {
34490
- setSettingShortcutIndex: setSettingShortcutIndex,
34491
- settingShortcutIndex: settingShortcutIndex,
34492
- shortcuts: shortcuts,
34493
- removeShortcut: removeShortcut,
34494
- atlasIMG: atlasIMG,
34495
- atlasJSON: atlasJSON
34496
- }), React__default.createElement(ItemsContainer, {
34497
- className: "item-container-body"
34498
- }, onRenderSlots())), quantitySelect.isOpen && React__default.createElement(QuantitySelectorContainer, null, React__default.createElement(ItemQuantitySelector, {
34499
- quantity: quantitySelect.maxQuantity,
34500
- onConfirm: function onConfirm(quantity) {
34501
- quantitySelect.callback(quantity);
34502
- setQuantitySelect({
34503
- isOpen: false,
34504
- maxQuantity: 1,
34505
- callback: function callback() {}
34506
- });
34507
- },
34508
- onClose: function onClose() {
34509
- quantitySelect.callback(-1);
34510
- setQuantitySelect({
34511
- isOpen: false,
34512
- maxQuantity: 1,
34513
- callback: function callback() {}
34514
- });
34396
+ var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
34397
+ var answerIds = currentQuestion.answerIds;
34398
+ if (!answerIds) {
34399
+ return null;
34515
34400
  }
34516
- })));
34517
- };
34518
- var ItemsContainer = /*#__PURE__*/styled.div.withConfig({
34519
- displayName: "ItemContainer__ItemsContainer",
34520
- componentId: "sc-15y5p9l-0"
34521
- })(["display:flex;justify-content:center;flex-wrap:wrap;"]);
34522
- var QuantitySelectorContainer = /*#__PURE__*/styled.div.withConfig({
34523
- displayName: "ItemContainer__QuantitySelectorContainer",
34524
- componentId: "sc-15y5p9l-1"
34525
- })(["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);"]);
34526
-
34527
- var ItemSelector = function ItemSelector(_ref) {
34528
- var atlasIMG = _ref.atlasIMG,
34529
- atlasJSON = _ref.atlasJSON,
34530
- options = _ref.options,
34531
- onClose = _ref.onClose,
34532
- onSelect = _ref.onSelect;
34533
- var _useState = React.useState(),
34534
- selectedValue = _useState[0],
34535
- setSelectedValue = _useState[1];
34536
- var handleClick = function handleClick() {
34537
- var element = document.querySelector("input[name='test']:checked");
34538
- var elementValue = element.value;
34539
- setSelectedValue(elementValue);
34540
- };
34541
- React.useEffect(function () {
34542
- if (selectedValue) {
34543
- onSelect(selectedValue);
34401
+ var answers = onGetAnswers(answerIds);
34402
+ if (!answers) {
34403
+ return null;
34544
34404
  }
34545
- }, [selectedValue]);
34546
- return React__default.createElement(DraggableContainer, {
34547
- type: exports.RPGUIContainerTypes.Framed,
34548
- width: "500px",
34549
- cancelDrag: ".equipment-container-body .arrow-selector",
34550
- onCloseButton: function onCloseButton() {
34551
- if (onClose) {
34552
- onClose();
34405
+ return answers.map(function (answer) {
34406
+ var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
34407
+ var selectedColor = isSelected ? 'yellow' : 'white';
34408
+ if (answer) {
34409
+ return React__default.createElement(AnswerRow, {
34410
+ key: "answer_" + answer.id
34411
+ }, React__default.createElement(AnswerSelectedIcon, {
34412
+ color: selectedColor
34413
+ }, isSelected ? 'X' : null), React__default.createElement(Answer, {
34414
+ key: answer.id,
34415
+ onPointerDown: function onPointerDown() {
34416
+ return onAnswerClick(answer);
34417
+ },
34418
+ color: selectedColor
34419
+ }, answer.text));
34553
34420
  }
34421
+ return null;
34422
+ });
34423
+ };
34424
+ return React__default.createElement(Container$c, null, React__default.createElement(QuestionContainer, null, React__default.createElement(DynamicText, {
34425
+ text: currentQuestion.text,
34426
+ onStart: function onStart() {
34427
+ return setCanShowAnswers(false);
34428
+ },
34429
+ onFinish: function onFinish() {
34430
+ return setCanShowAnswers(true);
34554
34431
  }
34555
- }, React__default.createElement("div", {
34556
- style: {
34557
- width: '100%'
34558
- }
34559
- }, React__default.createElement(Title$2, null, 'Harvesting instruments'), React__default.createElement(Subtitle$1, null, 'Use the tool, you need it'), React__default.createElement("hr", {
34560
- className: "golden"
34561
- })), React__default.createElement(RadioInputScroller$1, null, options == null ? void 0 : options.map(function (option, index) {
34562
- return React__default.createElement(RadioOptionsWrapper$1, {
34563
- key: index
34564
- }, React__default.createElement(SpriteAtlasWrapper$1, null, React__default.createElement(SpriteFromAtlas, {
34565
- atlasIMG: atlasIMG,
34566
- atlasJSON: atlasJSON,
34567
- spriteKey: option.imageKey,
34568
- imgScale: 3
34569
- })), React__default.createElement("div", null, React__default.createElement("input", {
34570
- className: "rpgui-radio",
34571
- type: "radio",
34572
- value: option.name,
34573
- name: "test"
34574
- }), React__default.createElement("label", {
34575
- onPointerDown: handleClick,
34576
- style: {
34577
- display: 'flex',
34578
- alignItems: 'center'
34579
- }
34580
- }, option.name, " ", React__default.createElement("br", null), option.description)));
34581
- })), React__default.createElement(ButtonWrapper$1, null, React__default.createElement(Button, {
34582
- buttonType: exports.ButtonTypes.RPGUIButton,
34583
- onPointerDown: onClose
34584
- }, "Cancel"), React__default.createElement(Button, {
34585
- buttonType: exports.ButtonTypes.RPGUIButton
34586
- }, "Select")));
34432
+ })), canShowAnswers && React__default.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
34587
34433
  };
34588
- var Title$2 = /*#__PURE__*/styled.h1.withConfig({
34589
- displayName: "ItemSelector__Title",
34590
- componentId: "sc-gptoxp-0"
34591
- })(["font-size:0.6rem;color:yellow !important;"]);
34592
- var Subtitle$1 = /*#__PURE__*/styled.h1.withConfig({
34593
- displayName: "ItemSelector__Subtitle",
34594
- componentId: "sc-gptoxp-1"
34595
- })(["font-size:0.4rem;color:yellow !important;"]);
34596
- var RadioInputScroller$1 = /*#__PURE__*/styled.div.withConfig({
34597
- displayName: "ItemSelector__RadioInputScroller",
34598
- componentId: "sc-gptoxp-2"
34599
- })(["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;"]);
34600
- var SpriteAtlasWrapper$1 = /*#__PURE__*/styled.div.withConfig({
34601
- displayName: "ItemSelector__SpriteAtlasWrapper",
34602
- componentId: "sc-gptoxp-3"
34603
- })(["margin-right:40px;"]);
34604
- var RadioOptionsWrapper$1 = /*#__PURE__*/styled.div.withConfig({
34605
- displayName: "ItemSelector__RadioOptionsWrapper",
34606
- componentId: "sc-gptoxp-4"
34607
- })(["display:flex;align-items:stretch;margin-bottom:40px;"]);
34608
- var ButtonWrapper$1 = /*#__PURE__*/styled.div.withConfig({
34609
- displayName: "ItemSelector__ButtonWrapper",
34610
- componentId: "sc-gptoxp-5"
34611
- })(["display:flex;justify-content:space-around;padding-top:20px;width:100%;"]);
34434
+ var Container$c = /*#__PURE__*/styled.div.withConfig({
34435
+ displayName: "QuestionDialog__Container",
34436
+ componentId: "sc-bxc5u0-0"
34437
+ })(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
34438
+ var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
34439
+ displayName: "QuestionDialog__QuestionContainer",
34440
+ componentId: "sc-bxc5u0-1"
34441
+ })(["flex:100%;width:100%;"]);
34442
+ var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
34443
+ displayName: "QuestionDialog__AnswersContainer",
34444
+ componentId: "sc-bxc5u0-2"
34445
+ })(["flex:100%;"]);
34446
+ var Answer = /*#__PURE__*/styled.p.withConfig({
34447
+ displayName: "QuestionDialog__Answer",
34448
+ componentId: "sc-bxc5u0-3"
34449
+ })(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
34450
+ return props.color;
34451
+ });
34452
+ var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
34453
+ displayName: "QuestionDialog__AnswerSelectedIcon",
34454
+ componentId: "sc-bxc5u0-4"
34455
+ })(["flex:5% 0 0;color:", " !important;"], function (props) {
34456
+ return props.color;
34457
+ });
34458
+ var AnswerRow = /*#__PURE__*/styled.div.withConfig({
34459
+ displayName: "QuestionDialog__AnswerRow",
34460
+ componentId: "sc-bxc5u0-5"
34461
+ })(["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;}"]);
34612
34462
 
34613
- var ListMenu = function ListMenu(_ref) {
34614
- var options = _ref.options,
34615
- onSelected = _ref.onSelected,
34616
- x = _ref.x,
34617
- y = _ref.y;
34618
- return React__default.createElement(Container$c, {
34619
- x: x,
34620
- y: y
34621
- }, React__default.createElement("ul", {
34622
- className: "rpgui-list-imp",
34623
- style: {
34624
- overflow: 'hidden'
34463
+ var img$8 = '';
34464
+
34465
+ (function (NPCDialogType) {
34466
+ NPCDialogType["TextOnly"] = "TextOnly";
34467
+ NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
34468
+ })(exports.NPCDialogType || (exports.NPCDialogType = {}));
34469
+ var NPCDialog = function NPCDialog(_ref) {
34470
+ var text = _ref.text,
34471
+ type = _ref.type,
34472
+ _onClose = _ref.onClose,
34473
+ imagePath = _ref.imagePath,
34474
+ _ref$isQuestionDialog = _ref.isQuestionDialog,
34475
+ isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
34476
+ questions = _ref.questions,
34477
+ answers = _ref.answers;
34478
+ return React__default.createElement(RPGUIContainer, {
34479
+ type: exports.RPGUIContainerTypes.FramedGold,
34480
+ width: isQuestionDialog ? '600px' : '80%',
34481
+ height: '180px'
34482
+ }, isQuestionDialog && questions && answers ? React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer$1, {
34483
+ flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
34484
+ }, React__default.createElement(QuestionDialog, {
34485
+ questions: questions,
34486
+ answers: answers,
34487
+ onClose: function onClose() {
34488
+ if (_onClose) {
34489
+ _onClose();
34490
+ }
34625
34491
  }
34626
- }, options.map(function (params, index) {
34627
- return React__default.createElement(ListElement$1, {
34628
- key: (params == null ? void 0 : params.id) || index,
34629
- onPointerDown: function onPointerDown() {
34630
- onSelected(params == null ? void 0 : params.id);
34492
+ })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
34493
+ src: imagePath || img$8
34494
+ }))) : React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$d, null, React__default.createElement(TextContainer$1, {
34495
+ flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
34496
+ }, React__default.createElement(NPCDialogText, {
34497
+ type: type,
34498
+ text: text || 'No text provided.',
34499
+ onClose: function onClose() {
34500
+ if (_onClose) {
34501
+ _onClose();
34631
34502
  }
34632
- }, (params == null ? void 0 : params.text) || 'No text');
34633
- })));
34503
+ }
34504
+ })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
34505
+ src: imagePath || img$8
34506
+ })))));
34634
34507
  };
34635
- var Container$c = /*#__PURE__*/styled.div.withConfig({
34636
- displayName: "ListMenu__Container",
34637
- componentId: "sc-i9097t-0"
34638
- })(["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) {
34639
- return props.y || 0;
34640
- }, function (props) {
34641
- return props.x || 0;
34642
- }, uiFonts.size.xsmall);
34643
- var ListElement$1 = /*#__PURE__*/styled.li.withConfig({
34644
- displayName: "ListMenu__ListElement",
34645
- componentId: "sc-i9097t-1"
34646
- })(["margin-right:0.5rem;"]);
34647
-
34648
- var img$6 = '';
34649
-
34650
- var img$7 = '';
34508
+ var Container$d = /*#__PURE__*/styled.div.withConfig({
34509
+ displayName: "NPCDialog__Container",
34510
+ componentId: "sc-1b4aw74-0"
34511
+ })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
34512
+ var TextContainer$1 = /*#__PURE__*/styled.div.withConfig({
34513
+ displayName: "NPCDialog__TextContainer",
34514
+ componentId: "sc-1b4aw74-1"
34515
+ })(["flex:", " 0 0;width:355px;"], function (_ref2) {
34516
+ var flex = _ref2.flex;
34517
+ return flex;
34518
+ });
34519
+ var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
34520
+ displayName: "NPCDialog__ThumbnailContainer",
34521
+ componentId: "sc-1b4aw74-2"
34522
+ })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
34523
+ var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
34524
+ displayName: "NPCDialog__NPCThumbnail",
34525
+ componentId: "sc-1b4aw74-3"
34526
+ })(["image-rendering:pixelated;height:128px;width:128px;"]);
34651
34527
 
34652
34528
  (function (ImgSide) {
34653
34529
  ImgSide["right"] = "right";
@@ -34685,7 +34561,7 @@ var NPCMultiDialog = function NPCMultiDialog(_ref) {
34685
34561
  type: exports.RPGUIContainerTypes.FramedGold,
34686
34562
  width: '50%',
34687
34563
  height: '180px'
34688
- }, React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$d, null, ((_textAndTypeArray$sli = textAndTypeArray[slide]) == null ? void 0 : _textAndTypeArray$sli.imageSide) === 'right' && React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer, {
34564
+ }, 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, {
34689
34565
  flex: '70%'
34690
34566
  }, React__default.createElement(NPCDialogText, {
34691
34567
  onStartStep: function onStartStep() {
@@ -34700,14 +34576,14 @@ var NPCMultiDialog = function NPCMultiDialog(_ref) {
34700
34576
  _onClose();
34701
34577
  }
34702
34578
  }
34703
- })), React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
34704
- src: textAndTypeArray[slide].imagePath || img$6
34705
- })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator, {
34579
+ })), React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
34580
+ src: textAndTypeArray[slide].imagePath || img$8
34581
+ })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator$1, {
34706
34582
  right: '10.5rem',
34707
34583
  src: img$7
34708
- })), textAndTypeArray[slide].imageSide === 'left' && React__default.createElement(React__default.Fragment, null, React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
34709
- src: textAndTypeArray[slide].imagePath || img$6
34710
- })), React__default.createElement(TextContainer, {
34584
+ })), textAndTypeArray[slide].imageSide === 'left' && React__default.createElement(React__default.Fragment, null, React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
34585
+ src: textAndTypeArray[slide].imagePath || img$8
34586
+ })), React__default.createElement(TextContainer$2, {
34711
34587
  flex: '70%'
34712
34588
  }, React__default.createElement(NPCDialogText, {
34713
34589
  onStartStep: function onStartStep() {
@@ -34722,31 +34598,31 @@ var NPCMultiDialog = function NPCMultiDialog(_ref) {
34722
34598
  _onClose();
34723
34599
  }
34724
34600
  }
34725
- })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator, {
34601
+ })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator$1, {
34726
34602
  right: '1rem',
34727
34603
  src: img$7
34728
34604
  }))), ")"));
34729
34605
  };
34730
- var Container$d = /*#__PURE__*/styled.div.withConfig({
34606
+ var Container$e = /*#__PURE__*/styled.div.withConfig({
34731
34607
  displayName: "NPCMultiDialog__Container",
34732
34608
  componentId: "sc-rvu5wg-0"
34733
34609
  })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
34734
- var TextContainer = /*#__PURE__*/styled.div.withConfig({
34610
+ var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
34735
34611
  displayName: "NPCMultiDialog__TextContainer",
34736
34612
  componentId: "sc-rvu5wg-1"
34737
34613
  })(["flex:", " 0 0;width:355px;"], function (_ref2) {
34738
34614
  var flex = _ref2.flex;
34739
34615
  return flex;
34740
34616
  });
34741
- var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
34617
+ var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
34742
34618
  displayName: "NPCMultiDialog__ThumbnailContainer",
34743
34619
  componentId: "sc-rvu5wg-2"
34744
34620
  })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
34745
- var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
34621
+ var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
34746
34622
  displayName: "NPCMultiDialog__NPCThumbnail",
34747
34623
  componentId: "sc-rvu5wg-3"
34748
34624
  })(["image-rendering:pixelated;height:128px;width:128px;"]);
34749
- var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
34625
+ var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
34750
34626
  displayName: "NPCMultiDialog__PressSpaceIndicator",
34751
34627
  componentId: "sc-rvu5wg-4"
34752
34628
  })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref3) {
@@ -34754,221 +34630,569 @@ var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
34754
34630
  return right;
34755
34631
  });
34756
34632
 
34757
- //@ts-ignore
34758
- var useEventListener = function useEventListener(type, handler, el) {
34759
- if (el === void 0) {
34760
- el = window;
34761
- }
34762
- var savedHandler = React__default.useRef();
34763
- React__default.useEffect(function () {
34764
- savedHandler.current = handler;
34765
- }, [handler]);
34766
- React__default.useEffect(function () {
34767
- //@ts-ignore
34768
- var listener = function listener(e) {
34769
- return savedHandler.current(e);
34770
- };
34771
- el.addEventListener(type, listener);
34633
+ var HistoryDialog = function HistoryDialog(_ref) {
34634
+ var backgroundImgPath = _ref.backgroundImgPath,
34635
+ fullCoverBackground = _ref.fullCoverBackground,
34636
+ questions = _ref.questions,
34637
+ answers = _ref.answers,
34638
+ text = _ref.text,
34639
+ imagePath = _ref.imagePath,
34640
+ textAndTypeArray = _ref.textAndTypeArray,
34641
+ onClose = _ref.onClose;
34642
+ var _useState = React.useState(0),
34643
+ img = _useState[0],
34644
+ setImage = _useState[1];
34645
+ var onHandleSpacePress = function onHandleSpacePress(event) {
34646
+ if (event.code === 'Space') {
34647
+ if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
34648
+ setImage(function (prev) {
34649
+ return prev + 1;
34650
+ });
34651
+ } else {
34652
+ // if there's no more text chunks, close the dialog
34653
+ onClose();
34654
+ }
34655
+ }
34656
+ };
34657
+ React.useEffect(function () {
34658
+ document.addEventListener('keydown', onHandleSpacePress);
34772
34659
  return function () {
34773
- el.removeEventListener(type, listener);
34660
+ return document.removeEventListener('keydown', onHandleSpacePress);
34774
34661
  };
34775
- }, [type, el]);
34662
+ }, [backgroundImgPath]);
34663
+ return React__default.createElement(BackgroundContainer, {
34664
+ imgPath: backgroundImgPath[img],
34665
+ fullImg: fullCoverBackground
34666
+ }, React__default.createElement(DialogContainer, null, textAndTypeArray ? React__default.createElement(NPCMultiDialog, {
34667
+ textAndTypeArray: textAndTypeArray,
34668
+ onClose: onClose
34669
+ }) : questions && answers ? React__default.createElement(QuestionDialog, {
34670
+ questions: questions,
34671
+ answers: answers,
34672
+ onClose: onClose
34673
+ }) : text && imagePath ? React__default.createElement(NPCDialog, {
34674
+ text: text,
34675
+ imagePath: imagePath,
34676
+ onClose: onClose,
34677
+ type: exports.NPCDialogType.TextAndThumbnail
34678
+ }) : React__default.createElement(NPCDialog, {
34679
+ text: text,
34680
+ onClose: onClose,
34681
+ type: exports.NPCDialogType.TextOnly
34682
+ })));
34776
34683
  };
34684
+ var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
34685
+ displayName: "HistoryDialog__BackgroundContainer",
34686
+ componentId: "sc-u6oe75-0"
34687
+ })(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
34688
+ return props.imgPath;
34689
+ }, function (props) {
34690
+ return props.imgPath ? 'cover' : 'auto';
34691
+ });
34692
+ var DialogContainer = /*#__PURE__*/styled.div.withConfig({
34693
+ displayName: "HistoryDialog__DialogContainer",
34694
+ componentId: "sc-u6oe75-1"
34695
+ })(["display:flex;justify-content:center;padding-top:200px;"]);
34777
34696
 
34778
- var DynamicText = function DynamicText(_ref) {
34779
- var text = _ref.text,
34780
- onFinish = _ref.onFinish,
34781
- onStart = _ref.onStart;
34782
- var _useState = React.useState(''),
34783
- textState = _useState[0],
34784
- setTextState = _useState[1];
34697
+ var SlotsContainer = function SlotsContainer(_ref) {
34698
+ var children = _ref.children,
34699
+ title = _ref.title,
34700
+ onClose = _ref.onClose,
34701
+ _onPositionChange = _ref.onPositionChange,
34702
+ onOutsideClick = _ref.onOutsideClick,
34703
+ initialPosition = _ref.initialPosition;
34704
+ return React__default.createElement(DraggableContainer, {
34705
+ title: title,
34706
+ type: exports.RPGUIContainerTypes.Framed,
34707
+ onCloseButton: function onCloseButton() {
34708
+ if (onClose) {
34709
+ onClose();
34710
+ }
34711
+ },
34712
+ width: "400px",
34713
+ cancelDrag: ".item-container-body, #shortcuts_list",
34714
+ onPositionChange: function onPositionChange(_ref2) {
34715
+ var x = _ref2.x,
34716
+ y = _ref2.y;
34717
+ if (_onPositionChange) {
34718
+ _onPositionChange({
34719
+ x: x,
34720
+ y: y
34721
+ });
34722
+ }
34723
+ },
34724
+ onOutsideClick: onOutsideClick,
34725
+ initialPosition: initialPosition
34726
+ }, children);
34727
+ };
34728
+
34729
+ (function (RangeSliderType) {
34730
+ RangeSliderType["Slider"] = "rpgui-slider";
34731
+ RangeSliderType["GoldSlider"] = "rpgui-slider golden";
34732
+ })(exports.RangeSliderType || (exports.RangeSliderType = {}));
34733
+ var RangeSlider = function RangeSlider(_ref) {
34734
+ var type = _ref.type,
34735
+ valueMin = _ref.valueMin,
34736
+ valueMax = _ref.valueMax,
34737
+ width = _ref.width,
34738
+ _onChange = _ref.onChange,
34739
+ value = _ref.value;
34740
+ var sliderId = uuid.v4();
34741
+ var containerRef = React.useRef(null);
34742
+ var _useState = React.useState(0),
34743
+ left = _useState[0],
34744
+ setLeft = _useState[1];
34745
+ React.useEffect(function () {
34746
+ var _containerRef$current;
34747
+ var calculatedWidth = ((_containerRef$current = containerRef.current) == null ? void 0 : _containerRef$current.clientWidth) || 0;
34748
+ setLeft(Math.max((value - valueMin) / (valueMax - valueMin) * (calculatedWidth - 35) + 10));
34749
+ }, [value, valueMin, valueMax]);
34750
+ var typeClass = type === exports.RangeSliderType.GoldSlider ? 'golden' : '';
34751
+ return React__default.createElement("div", {
34752
+ style: {
34753
+ width: width,
34754
+ position: 'relative'
34755
+ },
34756
+ className: "rpgui-slider-container " + typeClass,
34757
+ id: "rpgui-slider-" + sliderId,
34758
+ ref: containerRef
34759
+ }, React__default.createElement("div", {
34760
+ style: {
34761
+ pointerEvents: 'none'
34762
+ }
34763
+ }, React__default.createElement("div", {
34764
+ className: "rpgui-slider-track " + typeClass
34765
+ }), React__default.createElement("div", {
34766
+ className: "rpgui-slider-left-edge " + typeClass
34767
+ }), React__default.createElement("div", {
34768
+ className: "rpgui-slider-right-edge " + typeClass
34769
+ }), React__default.createElement("div", {
34770
+ className: "rpgui-slider-thumb " + typeClass,
34771
+ style: {
34772
+ left: left
34773
+ }
34774
+ })), React__default.createElement(Input$1, {
34775
+ type: "range",
34776
+ style: {
34777
+ width: width
34778
+ },
34779
+ min: valueMin,
34780
+ max: valueMax,
34781
+ onChange: function onChange(e) {
34782
+ return _onChange(Number(e.target.value));
34783
+ },
34784
+ value: value,
34785
+ className: "rpgui-cursor-point"
34786
+ }));
34787
+ };
34788
+ var Input$1 = /*#__PURE__*/styled.input.withConfig({
34789
+ displayName: "RangeSlider__Input",
34790
+ componentId: "sc-v8mte9-0"
34791
+ })(["opacity:0;position:absolute;width:100%;height:100%;top:0;left:0;margin-top:-5px;"]);
34792
+
34793
+ var ItemQuantitySelector = function ItemQuantitySelector(_ref) {
34794
+ var quantity = _ref.quantity,
34795
+ onConfirm = _ref.onConfirm,
34796
+ onClose = _ref.onClose;
34797
+ var _useState = React.useState(quantity),
34798
+ value = _useState[0],
34799
+ setValue = _useState[1];
34800
+ var inputRef = React.useRef(null);
34785
34801
  React.useEffect(function () {
34786
- var i = 0;
34787
- var interval = setInterval(function () {
34788
- // on every interval, show one more character
34789
- if (i === 0) {
34790
- if (onStart) {
34791
- onStart();
34802
+ if (inputRef.current) {
34803
+ inputRef.current.focus();
34804
+ inputRef.current.select();
34805
+ var closeSelector = function closeSelector(e) {
34806
+ if (e.key === 'Escape') {
34807
+ onClose();
34792
34808
  }
34809
+ };
34810
+ document.addEventListener('keydown', closeSelector);
34811
+ return function () {
34812
+ document.removeEventListener('keydown', closeSelector);
34813
+ };
34814
+ }
34815
+ return function () {};
34816
+ }, []);
34817
+ return React__default.createElement(StyledContainer, {
34818
+ type: exports.RPGUIContainerTypes.Framed,
34819
+ width: "25rem"
34820
+ }, React__default.createElement(CloseButton$2, {
34821
+ className: "container-close",
34822
+ onPointerDown: onClose
34823
+ }, "X"), React__default.createElement("h2", null, "Select quantity to move"), React__default.createElement(StyledForm, {
34824
+ style: {
34825
+ width: '100%'
34826
+ },
34827
+ onSubmit: function onSubmit(e) {
34828
+ e.preventDefault();
34829
+ var numberValue = Number(value);
34830
+ if (Number.isNaN(numberValue)) {
34831
+ return;
34793
34832
  }
34794
- if (i < text.length) {
34795
- setTextState(text.substring(0, i + 1));
34796
- i++;
34797
- } else {
34798
- clearInterval(interval);
34799
- if (onFinish) {
34800
- onFinish();
34801
- }
34833
+ onConfirm(Math.max(1, Math.min(quantity, numberValue)));
34834
+ },
34835
+ noValidate: true
34836
+ }, React__default.createElement(StyledInput, {
34837
+ innerRef: inputRef,
34838
+ placeholder: "Enter quantity",
34839
+ type: "number",
34840
+ min: 1,
34841
+ max: quantity,
34842
+ value: value,
34843
+ onChange: function onChange(e) {
34844
+ if (Number(e.target.value) >= quantity) {
34845
+ setValue(quantity);
34846
+ return;
34802
34847
  }
34803
- }, 50);
34804
- return function () {
34805
- clearInterval(interval);
34806
- };
34807
- }, [text]);
34808
- return React__default.createElement(TextContainer$1, null, textState);
34848
+ setValue(e.target.value);
34849
+ },
34850
+ onBlur: function onBlur(e) {
34851
+ var newValue = Math.max(1, Math.min(quantity, Number(e.target.value)));
34852
+ setValue(newValue);
34853
+ }
34854
+ }), React__default.createElement(RangeSlider, {
34855
+ type: exports.RangeSliderType.Slider,
34856
+ valueMin: 1,
34857
+ valueMax: quantity,
34858
+ width: "100%",
34859
+ onChange: setValue,
34860
+ value: value
34861
+ }), React__default.createElement(Button, {
34862
+ buttonType: exports.ButtonTypes.RPGUIButton,
34863
+ type: "submit"
34864
+ }, "Confirm")));
34809
34865
  };
34810
- var TextContainer$1 = /*#__PURE__*/styled.p.withConfig({
34811
- displayName: "DynamicText__TextContainer",
34812
- componentId: "sc-1ggl9nd-0"
34813
- })(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]);
34866
+ var StyledContainer = /*#__PURE__*/styled(RPGUIContainer).withConfig({
34867
+ displayName: "ItemQuantitySelector__StyledContainer",
34868
+ componentId: "sc-yfdtpn-0"
34869
+ })(["display:flex;flex-direction:column;align-items:center;"]);
34870
+ var StyledForm = /*#__PURE__*/styled.form.withConfig({
34871
+ displayName: "ItemQuantitySelector__StyledForm",
34872
+ componentId: "sc-yfdtpn-1"
34873
+ })(["display:flex;flex-direction:column;align-items:center;width:100%;"]);
34874
+ var StyledInput = /*#__PURE__*/styled(Input).withConfig({
34875
+ displayName: "ItemQuantitySelector__StyledInput",
34876
+ componentId: "sc-yfdtpn-2"
34877
+ })(["text-align:center;&::-webkit-outer-spin-button,&::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}&[type='number']{-moz-appearance:textfield;}"]);
34878
+ var CloseButton$2 = /*#__PURE__*/styled.div.withConfig({
34879
+ displayName: "ItemQuantitySelector__CloseButton",
34880
+ componentId: "sc-yfdtpn-3"
34881
+ })(["position:absolute;top:3px;right:0px;color:white;z-index:22;font-size:0.8rem;"]);
34814
34882
 
34815
- var QuestionDialog = function QuestionDialog(_ref) {
34816
- var questions = _ref.questions,
34817
- answers = _ref.answers,
34818
- onClose = _ref.onClose;
34819
- var _useState = React.useState(questions[0]),
34820
- currentQuestion = _useState[0],
34821
- setCurrentQuestion = _useState[1];
34822
- var _useState2 = React.useState(false),
34823
- canShowAnswers = _useState2[0],
34824
- setCanShowAnswers = _useState2[1];
34825
- var onGetFirstAnswer = function onGetFirstAnswer() {
34826
- if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {
34827
- return null;
34883
+ var ShortcutsSetter = function ShortcutsSetter(_ref) {
34884
+ var setSettingShortcutIndex = _ref.setSettingShortcutIndex,
34885
+ settingShortcutIndex = _ref.settingShortcutIndex,
34886
+ shortcuts = _ref.shortcuts,
34887
+ removeShortcut = _ref.removeShortcut,
34888
+ atlasJSON = _ref.atlasJSON,
34889
+ atlasIMG = _ref.atlasIMG;
34890
+ var getContent = function getContent(index) {
34891
+ var _shortcuts$index, _shortcuts$index3;
34892
+ if (((_shortcuts$index = shortcuts[index]) == null ? void 0 : _shortcuts$index.type) === shared.ShortcutType.Item) {
34893
+ var _shortcuts$index2;
34894
+ var _payload = (_shortcuts$index2 = shortcuts[index]) == null ? void 0 : _shortcuts$index2.payload;
34895
+ if (!_payload) return null;
34896
+ return React__default.createElement(SpriteFromAtlas, {
34897
+ atlasIMG: atlasIMG,
34898
+ atlasJSON: atlasJSON,
34899
+ spriteKey: shared.getItemTextureKeyPath({
34900
+ key: _payload.texturePath,
34901
+ texturePath: _payload.texturePath,
34902
+ stackQty: _payload.stackQty || 1
34903
+ }, atlasJSON),
34904
+ width: 32,
34905
+ height: 32,
34906
+ imgScale: 1.6,
34907
+ imgStyle: {
34908
+ left: '5px'
34909
+ }
34910
+ });
34911
+ }
34912
+ var payload = (_shortcuts$index3 = shortcuts[index]) == null ? void 0 : _shortcuts$index3.payload;
34913
+ return React__default.createElement("span", null, payload == null ? void 0 : payload.magicWords.split(' ').map(function (word) {
34914
+ return word[0];
34915
+ }));
34916
+ };
34917
+ return React__default.createElement(Container$f, null, React__default.createElement("p", null, "Shortcuts:"), React__default.createElement(List, {
34918
+ id: "shortcuts_list"
34919
+ }, Array.from({
34920
+ length: 6
34921
+ }).map(function (_, i) {
34922
+ return React__default.createElement(Shortcut, {
34923
+ key: i,
34924
+ onPointerDown: function onPointerDown() {
34925
+ removeShortcut(i);
34926
+ if (!shortcuts[i] || shortcuts[i].type === shared.ShortcutType.None) setSettingShortcutIndex(i);
34927
+ },
34928
+ disabled: settingShortcutIndex !== -1 && settingShortcutIndex !== i,
34929
+ isBeingSet: settingShortcutIndex === i
34930
+ }, getContent(i));
34931
+ })));
34932
+ };
34933
+ var Container$f = /*#__PURE__*/styled.div.withConfig({
34934
+ displayName: "ShortcutsSetter__Container",
34935
+ componentId: "sc-xuouuf-0"
34936
+ })(["p{margin:0;margin-left:0.5rem;}"]);
34937
+ var Shortcut = /*#__PURE__*/styled.button.withConfig({
34938
+ displayName: "ShortcutsSetter__Shortcut",
34939
+ componentId: "sc-xuouuf-1"
34940
+ })(["width:2.6rem;height:2.6rem;background-color:", ";border:2px solid ", ";border-radius:50%;text-transform:uppercase;font-size:0.7rem;font-weight:bold;display:flex;align-items:center;justify-content:center;span{margin-top:4px;}&:hover,&:focus{background-color:", ";}&:active{background-color:", ";}&:disabled{opacity:0.5;}"], uiColors.lightGray, function (_ref2) {
34941
+ var isBeingSet = _ref2.isBeingSet;
34942
+ return isBeingSet ? uiColors.yellow : uiColors.darkGray;
34943
+ }, uiColors.darkGray, uiColors.gray);
34944
+ var List = /*#__PURE__*/styled.div.withConfig({
34945
+ displayName: "ShortcutsSetter__List",
34946
+ componentId: "sc-xuouuf-2"
34947
+ })(["width:100%;display:flex;align-items:center;gap:0.5rem;padding-bottom:0.5rem;padding-left:0.5rem;box-sizing:border-box;margin:0 !important;"]);
34948
+
34949
+ var ItemContainer$1 = function ItemContainer(_ref) {
34950
+ var itemContainer = _ref.itemContainer,
34951
+ onClose = _ref.onClose,
34952
+ _onMouseOver = _ref.onMouseOver,
34953
+ _onSelected = _ref.onSelected,
34954
+ onItemClick = _ref.onItemClick,
34955
+ type = _ref.type,
34956
+ atlasJSON = _ref.atlasJSON,
34957
+ atlasIMG = _ref.atlasIMG,
34958
+ _ref$disableContextMe = _ref.disableContextMenu,
34959
+ disableContextMenu = _ref$disableContextMe === void 0 ? false : _ref$disableContextMe,
34960
+ onItemDragEnd = _ref.onItemDragEnd,
34961
+ onItemDragStart = _ref.onItemDragStart,
34962
+ onItemPlaceDrop = _ref.onItemPlaceDrop,
34963
+ _onOutsideDrop = _ref.onOutsideDrop,
34964
+ checkIfItemCanBeMoved = _ref.checkIfItemCanBeMoved,
34965
+ initialPosition = _ref.initialPosition,
34966
+ checkIfItemShouldDragEnd = _ref.checkIfItemShouldDragEnd,
34967
+ dragScale = _ref.dragScale,
34968
+ shortcuts = _ref.shortcuts,
34969
+ setItemShortcut = _ref.setItemShortcut,
34970
+ removeShortcut = _ref.removeShortcut;
34971
+ var _useState = React.useState({
34972
+ isOpen: false,
34973
+ maxQuantity: 1,
34974
+ callback: function callback(_quantity) {}
34975
+ }),
34976
+ quantitySelect = _useState[0],
34977
+ setQuantitySelect = _useState[1];
34978
+ var _useState2 = React.useState(-1),
34979
+ settingShortcutIndex = _useState2[0],
34980
+ setSettingShortcutIndex = _useState2[1];
34981
+ var onRenderSlots = function onRenderSlots() {
34982
+ var slots = [];
34983
+ for (var i = 0; i < itemContainer.slotQty; i++) {
34984
+ var _itemContainer$slots;
34985
+ slots.push(React__default.createElement(ItemSlot, {
34986
+ isContextMenuDisabled: disableContextMenu,
34987
+ key: i,
34988
+ slotIndex: i,
34989
+ item: ((_itemContainer$slots = itemContainer.slots) == null ? void 0 : _itemContainer$slots[i]) || null,
34990
+ itemContainerType: type,
34991
+ onMouseOver: function onMouseOver(event, slotIndex, item) {
34992
+ if (_onMouseOver) _onMouseOver(event, slotIndex, item);
34993
+ },
34994
+ onPointerDown: function onPointerDown(itemType, containerType, item) {
34995
+ if (settingShortcutIndex !== -1) {
34996
+ setSettingShortcutIndex(-1);
34997
+ if (itemType === shared.ItemType.Consumable || itemType === shared.ItemType.Tool) {
34998
+ setItemShortcut == null ? void 0 : setItemShortcut(item.key, settingShortcutIndex);
34999
+ }
35000
+ } else if (onItemClick) onItemClick(item, itemType, containerType);
35001
+ },
35002
+ onSelected: function onSelected(optionId, item) {
35003
+ if (_onSelected) _onSelected(optionId, item);
35004
+ },
35005
+ onDragStart: function onDragStart(item, slotIndex, itemContainerType) {
35006
+ if (onItemDragStart) onItemDragStart(item, slotIndex, itemContainerType);
35007
+ },
35008
+ onDragEnd: function onDragEnd(quantity) {
35009
+ if (onItemDragEnd) onItemDragEnd(quantity);
35010
+ },
35011
+ dragScale: dragScale,
35012
+ checkIfItemCanBeMoved: checkIfItemCanBeMoved,
35013
+ checkIfItemShouldDragEnd: checkIfItemShouldDragEnd,
35014
+ openQuantitySelector: function openQuantitySelector(maxQuantity, callback) {
35015
+ setQuantitySelect({
35016
+ isOpen: true,
35017
+ maxQuantity: maxQuantity,
35018
+ callback: callback
35019
+ });
35020
+ },
35021
+ onPlaceDrop: function onPlaceDrop(item, slotIndex, itemContainerType) {
35022
+ if (onItemPlaceDrop) onItemPlaceDrop(item, slotIndex, itemContainerType);
35023
+ },
35024
+ onOutsideDrop: function onOutsideDrop(item, position) {
35025
+ if (_onOutsideDrop) _onOutsideDrop(item, position);
35026
+ },
35027
+ atlasIMG: atlasIMG,
35028
+ atlasJSON: atlasJSON,
35029
+ isSelectingShortcut: settingShortcutIndex !== -1
35030
+ }));
34828
35031
  }
34829
- var firstAnswerId = currentQuestion.answerIds[0];
34830
- return answers.find(function (answer) {
34831
- return answer.id === firstAnswerId;
34832
- });
35032
+ return slots;
34833
35033
  };
34834
- var _useState3 = React.useState(onGetFirstAnswer()),
34835
- currentAnswer = _useState3[0],
34836
- setCurrentAnswer = _useState3[1];
34837
- React.useEffect(function () {
34838
- setCurrentAnswer(onGetFirstAnswer());
34839
- }, [currentQuestion]);
34840
- var onGetAnswers = function onGetAnswers(answerIds) {
34841
- return answerIds.map(function (answerId) {
34842
- return answers.find(function (answer) {
34843
- return answer.id === answerId;
35034
+ return React__default.createElement(React__default.Fragment, null, React__default.createElement(SlotsContainer, {
35035
+ title: itemContainer.name || 'Container',
35036
+ onClose: onClose,
35037
+ initialPosition: initialPosition
35038
+ }, type === shared.ItemContainerType.Inventory && shortcuts && removeShortcut && React__default.createElement(ShortcutsSetter, {
35039
+ setSettingShortcutIndex: setSettingShortcutIndex,
35040
+ settingShortcutIndex: settingShortcutIndex,
35041
+ shortcuts: shortcuts,
35042
+ removeShortcut: removeShortcut,
35043
+ atlasIMG: atlasIMG,
35044
+ atlasJSON: atlasJSON
35045
+ }), React__default.createElement(ItemsContainer, {
35046
+ className: "item-container-body"
35047
+ }, onRenderSlots())), quantitySelect.isOpen && React__default.createElement(QuantitySelectorContainer, null, React__default.createElement(ItemQuantitySelector, {
35048
+ quantity: quantitySelect.maxQuantity,
35049
+ onConfirm: function onConfirm(quantity) {
35050
+ quantitySelect.callback(quantity);
35051
+ setQuantitySelect({
35052
+ isOpen: false,
35053
+ maxQuantity: 1,
35054
+ callback: function callback() {}
35055
+ });
35056
+ },
35057
+ onClose: function onClose() {
35058
+ quantitySelect.callback(-1);
35059
+ setQuantitySelect({
35060
+ isOpen: false,
35061
+ maxQuantity: 1,
35062
+ callback: function callback() {}
34844
35063
  });
34845
- });
34846
- };
34847
- var onKeyPress = function onKeyPress(e) {
34848
- switch (e.key) {
34849
- case 'ArrowDown':
34850
- // select next answer, if any.
34851
- // if no next answer, select first answer
34852
- // const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(
34853
- // (answer) => answer?.id === currentAnswer!.id + 1
34854
- // );
34855
- var nextAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34856
- return (answer == null ? void 0 : answer.id) === currentAnswer.id + 1;
34857
- });
34858
- var nextAnswerID = currentQuestion.answerIds[nextAnswerIndex];
34859
- var nextAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34860
- return (answer == null ? void 0 : answer.id) === nextAnswerID;
34861
- });
34862
- setCurrentAnswer(nextAnswer || onGetFirstAnswer());
34863
- break;
34864
- case 'ArrowUp':
34865
- // select previous answer, if any.
34866
- // if no previous answer, select last answer
34867
- var previousAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34868
- return (answer == null ? void 0 : answer.id) === currentAnswer.id - 1;
34869
- });
34870
- var previousAnswerID = currentQuestion.answerIds && currentQuestion.answerIds[previousAnswerIndex];
34871
- var previousAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34872
- return (answer == null ? void 0 : answer.id) === previousAnswerID;
34873
- });
34874
- if (previousAnswer) {
34875
- setCurrentAnswer(previousAnswer);
34876
- } else {
34877
- setCurrentAnswer(onGetAnswers(currentQuestion.answerIds).pop());
34878
- }
34879
- break;
34880
- case 'Enter':
34881
- setCanShowAnswers(false);
34882
- if (!(currentAnswer != null && currentAnswer.nextQuestionId)) {
34883
- onClose();
34884
- return;
34885
- } else {
34886
- setCurrentQuestion(questions.find(function (question) {
34887
- return question.id === currentAnswer.nextQuestionId;
34888
- }));
34889
- }
34890
- break;
34891
35064
  }
35065
+ })));
35066
+ };
35067
+ var ItemsContainer = /*#__PURE__*/styled.div.withConfig({
35068
+ displayName: "ItemContainer__ItemsContainer",
35069
+ componentId: "sc-15y5p9l-0"
35070
+ })(["display:flex;justify-content:center;flex-wrap:wrap;"]);
35071
+ var QuantitySelectorContainer = /*#__PURE__*/styled.div.withConfig({
35072
+ displayName: "ItemContainer__QuantitySelectorContainer",
35073
+ componentId: "sc-15y5p9l-1"
35074
+ })(["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);"]);
35075
+
35076
+ var ItemSelector = function ItemSelector(_ref) {
35077
+ var atlasIMG = _ref.atlasIMG,
35078
+ atlasJSON = _ref.atlasJSON,
35079
+ options = _ref.options,
35080
+ onClose = _ref.onClose,
35081
+ onSelect = _ref.onSelect;
35082
+ var _useState = React.useState(),
35083
+ selectedValue = _useState[0],
35084
+ setSelectedValue = _useState[1];
35085
+ var handleClick = function handleClick() {
35086
+ var element = document.querySelector("input[name='test']:checked");
35087
+ var elementValue = element.value;
35088
+ setSelectedValue(elementValue);
34892
35089
  };
34893
- useEventListener('keydown', onKeyPress);
34894
- var onAnswerClick = function onAnswerClick(answer) {
34895
- setCanShowAnswers(false);
34896
- if (answer.nextQuestionId) {
34897
- // if there is a next question, go to it
34898
- setCurrentQuestion(questions.find(function (question) {
34899
- return question.id === answer.nextQuestionId;
34900
- }));
34901
- } else {
34902
- // else, finish dialog!
34903
- onClose();
35090
+ React.useEffect(function () {
35091
+ if (selectedValue) {
35092
+ onSelect(selectedValue);
34904
35093
  }
34905
- };
34906
- var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
34907
- var answerIds = currentQuestion.answerIds;
34908
- if (!answerIds) {
34909
- return null;
35094
+ }, [selectedValue]);
35095
+ return React__default.createElement(DraggableContainer, {
35096
+ type: exports.RPGUIContainerTypes.Framed,
35097
+ width: "500px",
35098
+ cancelDrag: ".equipment-container-body .arrow-selector",
35099
+ onCloseButton: function onCloseButton() {
35100
+ if (onClose) {
35101
+ onClose();
35102
+ }
34910
35103
  }
34911
- var answers = onGetAnswers(answerIds);
34912
- if (!answers) {
34913
- return null;
35104
+ }, React__default.createElement("div", {
35105
+ style: {
35106
+ width: '100%'
34914
35107
  }
34915
- return answers.map(function (answer) {
34916
- var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
34917
- var selectedColor = isSelected ? 'yellow' : 'white';
34918
- if (answer) {
34919
- return React__default.createElement(AnswerRow, {
34920
- key: "answer_" + answer.id
34921
- }, React__default.createElement(AnswerSelectedIcon, {
34922
- color: selectedColor
34923
- }, isSelected ? 'X' : null), React__default.createElement(Answer, {
34924
- key: answer.id,
34925
- onPointerDown: function onPointerDown() {
34926
- return onAnswerClick(answer);
34927
- },
34928
- color: selectedColor
34929
- }, answer.text));
35108
+ }, React__default.createElement(Title$2, null, 'Harvesting instruments'), React__default.createElement(Subtitle$1, null, 'Use the tool, you need it'), React__default.createElement("hr", {
35109
+ className: "golden"
35110
+ })), React__default.createElement(RadioInputScroller$1, null, options == null ? void 0 : options.map(function (option, index) {
35111
+ return React__default.createElement(RadioOptionsWrapper$1, {
35112
+ key: index
35113
+ }, React__default.createElement(SpriteAtlasWrapper$1, null, React__default.createElement(SpriteFromAtlas, {
35114
+ atlasIMG: atlasIMG,
35115
+ atlasJSON: atlasJSON,
35116
+ spriteKey: option.imageKey,
35117
+ imgScale: 3
35118
+ })), React__default.createElement("div", null, React__default.createElement("input", {
35119
+ className: "rpgui-radio",
35120
+ type: "radio",
35121
+ value: option.name,
35122
+ name: "test"
35123
+ }), React__default.createElement("label", {
35124
+ onPointerDown: handleClick,
35125
+ style: {
35126
+ display: 'flex',
35127
+ alignItems: 'center'
34930
35128
  }
34931
- return null;
34932
- });
34933
- };
34934
- return React__default.createElement(Container$e, null, React__default.createElement(QuestionContainer, null, React__default.createElement(DynamicText, {
34935
- text: currentQuestion.text,
34936
- onStart: function onStart() {
34937
- return setCanShowAnswers(false);
34938
- },
34939
- onFinish: function onFinish() {
34940
- return setCanShowAnswers(true);
35129
+ }, option.name, " ", React__default.createElement("br", null), option.description)));
35130
+ })), React__default.createElement(ButtonWrapper$1, null, React__default.createElement(Button, {
35131
+ buttonType: exports.ButtonTypes.RPGUIButton,
35132
+ onPointerDown: onClose
35133
+ }, "Cancel"), React__default.createElement(Button, {
35134
+ buttonType: exports.ButtonTypes.RPGUIButton
35135
+ }, "Select")));
35136
+ };
35137
+ var Title$2 = /*#__PURE__*/styled.h1.withConfig({
35138
+ displayName: "ItemSelector__Title",
35139
+ componentId: "sc-gptoxp-0"
35140
+ })(["font-size:0.6rem;color:yellow !important;"]);
35141
+ var Subtitle$1 = /*#__PURE__*/styled.h1.withConfig({
35142
+ displayName: "ItemSelector__Subtitle",
35143
+ componentId: "sc-gptoxp-1"
35144
+ })(["font-size:0.4rem;color:yellow !important;"]);
35145
+ var RadioInputScroller$1 = /*#__PURE__*/styled.div.withConfig({
35146
+ displayName: "ItemSelector__RadioInputScroller",
35147
+ componentId: "sc-gptoxp-2"
35148
+ })(["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;"]);
35149
+ var SpriteAtlasWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35150
+ displayName: "ItemSelector__SpriteAtlasWrapper",
35151
+ componentId: "sc-gptoxp-3"
35152
+ })(["margin-right:40px;"]);
35153
+ var RadioOptionsWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35154
+ displayName: "ItemSelector__RadioOptionsWrapper",
35155
+ componentId: "sc-gptoxp-4"
35156
+ })(["display:flex;align-items:stretch;margin-bottom:40px;"]);
35157
+ var ButtonWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35158
+ displayName: "ItemSelector__ButtonWrapper",
35159
+ componentId: "sc-gptoxp-5"
35160
+ })(["display:flex;justify-content:space-around;padding-top:20px;width:100%;"]);
35161
+
35162
+ var ListMenu = function ListMenu(_ref) {
35163
+ var options = _ref.options,
35164
+ onSelected = _ref.onSelected,
35165
+ x = _ref.x,
35166
+ y = _ref.y;
35167
+ return React__default.createElement(Container$g, {
35168
+ x: x,
35169
+ y: y
35170
+ }, React__default.createElement("ul", {
35171
+ className: "rpgui-list-imp",
35172
+ style: {
35173
+ overflow: 'hidden'
34941
35174
  }
34942
- })), canShowAnswers && React__default.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
35175
+ }, options.map(function (params, index) {
35176
+ return React__default.createElement(ListElement$1, {
35177
+ key: (params == null ? void 0 : params.id) || index,
35178
+ onPointerDown: function onPointerDown() {
35179
+ onSelected(params == null ? void 0 : params.id);
35180
+ }
35181
+ }, (params == null ? void 0 : params.text) || 'No text');
35182
+ })));
34943
35183
  };
34944
- var Container$e = /*#__PURE__*/styled.div.withConfig({
34945
- displayName: "QuestionDialog__Container",
34946
- componentId: "sc-bxc5u0-0"
34947
- })(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
34948
- var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
34949
- displayName: "QuestionDialog__QuestionContainer",
34950
- componentId: "sc-bxc5u0-1"
34951
- })(["flex:100%;width:100%;"]);
34952
- var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
34953
- displayName: "QuestionDialog__AnswersContainer",
34954
- componentId: "sc-bxc5u0-2"
34955
- })(["flex:100%;"]);
34956
- var Answer = /*#__PURE__*/styled.p.withConfig({
34957
- displayName: "QuestionDialog__Answer",
34958
- componentId: "sc-bxc5u0-3"
34959
- })(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
34960
- return props.color;
34961
- });
34962
- var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
34963
- displayName: "QuestionDialog__AnswerSelectedIcon",
34964
- componentId: "sc-bxc5u0-4"
34965
- })(["flex:5% 0 0;color:", " !important;"], function (props) {
34966
- return props.color;
34967
- });
34968
- var AnswerRow = /*#__PURE__*/styled.div.withConfig({
34969
- displayName: "QuestionDialog__AnswerRow",
34970
- componentId: "sc-bxc5u0-5"
34971
- })(["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;}"]);
35184
+ var Container$g = /*#__PURE__*/styled.div.withConfig({
35185
+ displayName: "ListMenu__Container",
35186
+ componentId: "sc-i9097t-0"
35187
+ })(["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) {
35188
+ return props.y || 0;
35189
+ }, function (props) {
35190
+ return props.x || 0;
35191
+ }, uiFonts.size.xsmall);
35192
+ var ListElement$1 = /*#__PURE__*/styled.li.withConfig({
35193
+ displayName: "ListMenu__ListElement",
35194
+ componentId: "sc-i9097t-1"
35195
+ })(["margin-right:0.5rem;"]);
34972
35196
 
34973
35197
  var ProgressBar = function ProgressBar(_ref) {
34974
35198
  var max = _ref.max,
@@ -34987,7 +35211,7 @@ var ProgressBar = function ProgressBar(_ref) {
34987
35211
  }
34988
35212
  return value * 100 / max;
34989
35213
  };
34990
- return React__default.createElement(Container$f, {
35214
+ return React__default.createElement(Container$h, {
34991
35215
  className: "rpgui-progress",
34992
35216
  "data-value": calculatePercentageValue(max, value) / 100,
34993
35217
  "data-rpguitype": "progress",
@@ -35016,7 +35240,7 @@ var TextOverlay$1 = /*#__PURE__*/styled.div.withConfig({
35016
35240
  displayName: "ProgressBar__TextOverlay",
35017
35241
  componentId: "sc-qa6fzh-1"
35018
35242
  })(["width:100%;position:relative;"]);
35019
- var Container$f = /*#__PURE__*/styled.div.withConfig({
35243
+ var Container$h = /*#__PURE__*/styled.div.withConfig({
35020
35244
  displayName: "ProgressBar__Container",
35021
35245
  componentId: "sc-qa6fzh-2"
35022
35246
  })(["display:flex;flex-direction:column;min-width:", "px;width:", "%;justify-content:start;align-items:flex-start;", ""], function (props) {
@@ -35027,7 +35251,7 @@ var Container$f = /*#__PURE__*/styled.div.withConfig({
35027
35251
  return props.style;
35028
35252
  });
35029
35253
 
35030
- var img$8 = '';
35254
+ var img$9 = '';
35031
35255
 
35032
35256
  var QuestInfo = function QuestInfo(_ref) {
35033
35257
  var quests = _ref.quests,
@@ -35069,7 +35293,7 @@ var QuestInfo = function QuestInfo(_ref) {
35069
35293
  }), React__default.createElement(QuestContainer, null, React__default.createElement(TitleContainer$1, {
35070
35294
  className: "drag-handler"
35071
35295
  }, React__default.createElement(Title$3, null, React__default.createElement(Thumbnail, {
35072
- src: quests[currentIndex].thumbnail || img$8
35296
+ src: quests[currentIndex].thumbnail || img$9
35073
35297
  }), quests[currentIndex].title), React__default.createElement(QuestSplitDiv, null, React__default.createElement("hr", {
35074
35298
  className: "golden"
35075
35299
  }))), React__default.createElement(Content, null, React__default.createElement("p", null, quests[currentIndex].description)), React__default.createElement(QuestColumn, {
@@ -35088,7 +35312,7 @@ var QuestInfo = function QuestInfo(_ref) {
35088
35312
  })))) : React__default.createElement(QuestsContainer, null, React__default.createElement(QuestContainer, null, React__default.createElement(TitleContainer$1, {
35089
35313
  className: "drag-handler"
35090
35314
  }, React__default.createElement(Title$3, null, React__default.createElement(Thumbnail, {
35091
- src: quests[0].thumbnail || img$8
35315
+ src: quests[0].thumbnail || img$9
35092
35316
  }), quests[0].title), React__default.createElement(QuestSplitDiv, null, React__default.createElement("hr", {
35093
35317
  className: "golden"
35094
35318
  }))), React__default.createElement(Content, null, React__default.createElement("p", null, quests[0].description)), React__default.createElement(QuestColumn, {
@@ -35337,7 +35561,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
35337
35561
  bgColor = _ref$bgColor === void 0 ? 'red' : _ref$bgColor,
35338
35562
  _ref$margin = _ref.margin,
35339
35563
  margin = _ref$margin === void 0 ? 20 : _ref$margin;
35340
- return React__default.createElement(Container$g, {
35564
+ return React__default.createElement(Container$i, {
35341
35565
  className: "simple-progress-bar"
35342
35566
  }, React__default.createElement(ProgressBarContainer, {
35343
35567
  margin: margin
@@ -35346,7 +35570,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
35346
35570
  bgColor: bgColor
35347
35571
  }))));
35348
35572
  };
35349
- var Container$g = /*#__PURE__*/styled.div.withConfig({
35573
+ var Container$i = /*#__PURE__*/styled.div.withConfig({
35350
35574
  displayName: "SimpleProgressBar__Container",
35351
35575
  componentId: "sc-mbeil3-0"
35352
35576
  })(["display:flex;justify-content:center;align-items:center;width:100%;"]);
@@ -35573,7 +35797,7 @@ var Spell = function Spell(_ref) {
35573
35797
  isSettingShortcut = _ref.isSettingShortcut,
35574
35798
  minMagicLevelRequired = _ref.minMagicLevelRequired;
35575
35799
  var disabled = isSettingShortcut ? charMagicLevel < minMagicLevelRequired : manaCost > charMana || charMagicLevel < minMagicLevelRequired;
35576
- return React__default.createElement(Container$h, {
35800
+ return React__default.createElement(Container$j, {
35577
35801
  disabled: disabled,
35578
35802
  onPointerDown: onPointerDown == null ? void 0 : onPointerDown.bind(null, spellKey),
35579
35803
  isSettingShortcut: isSettingShortcut && !disabled,
@@ -35586,7 +35810,7 @@ var Spell = function Spell(_ref) {
35586
35810
  className: "mana"
35587
35811
  }, manaCost)));
35588
35812
  };
35589
- var Container$h = /*#__PURE__*/styled.button.withConfig({
35813
+ var Container$j = /*#__PURE__*/styled.button.withConfig({
35590
35814
  displayName: "Spell__Container",
35591
35815
  componentId: "sc-j96fa2-0"
35592
35816
  })(["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) {
@@ -35671,7 +35895,7 @@ var Spellbook = function Spellbook(_ref) {
35671
35895
  width: "inherit",
35672
35896
  height: "inherit",
35673
35897
  cancelDrag: "#spellbook-search, #shortcuts_list, .spell"
35674
- }, React__default.createElement(Container$i, null, React__default.createElement(Title$6, null, "Learned Spells"), React__default.createElement(ShortcutsSetter, {
35898
+ }, React__default.createElement(Container$k, null, React__default.createElement(Title$6, null, "Learned Spells"), React__default.createElement(ShortcutsSetter, {
35675
35899
  setSettingShortcutIndex: setSettingShortcutIndex,
35676
35900
  settingShortcutIndex: settingShortcutIndex,
35677
35901
  shortcuts: shortcuts,
@@ -35703,7 +35927,7 @@ var Title$6 = /*#__PURE__*/styled.h1.withConfig({
35703
35927
  displayName: "Spellbook__Title",
35704
35928
  componentId: "sc-r02nfq-0"
35705
35929
  })(["font-size:", " !important;margin-bottom:0 !important;"], uiFonts.size.large);
35706
- var Container$i = /*#__PURE__*/styled.div.withConfig({
35930
+ var Container$k = /*#__PURE__*/styled.div.withConfig({
35707
35931
  displayName: "Spellbook__Container",
35708
35932
  componentId: "sc-r02nfq-1"
35709
35933
  })(["width:100%;height:100%;color:white;display:flex;flex-direction:column;"]);
@@ -35717,16 +35941,16 @@ var TextArea = function TextArea(_ref) {
35717
35941
  return React__default.createElement("textarea", Object.assign({}, props));
35718
35942
  };
35719
35943
 
35720
- var img$9 = '';
35944
+ var img$a = '';
35721
35945
 
35722
- var img$a = '';
35946
+ var img$b = '';
35723
35947
 
35724
- var img$b = '';
35948
+ var img$c = '';
35725
35949
 
35726
35950
  var DayNightPeriod = function DayNightPeriod(_ref) {
35727
35951
  var _periodOfDaySrcFiles;
35728
35952
  var periodOfDay = _ref.periodOfDay;
35729
- var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[shared.PeriodOfDay.Morning] = img$a, _periodOfDaySrcFiles[shared.PeriodOfDay.Afternoon] = img$9, _periodOfDaySrcFiles[shared.PeriodOfDay.Night] = img$b, _periodOfDaySrcFiles);
35953
+ var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[shared.PeriodOfDay.Morning] = img$b, _periodOfDaySrcFiles[shared.PeriodOfDay.Afternoon] = img$a, _periodOfDaySrcFiles[shared.PeriodOfDay.Night] = img$c, _periodOfDaySrcFiles);
35730
35954
  return React__default.createElement(GifContainer, null, React__default.createElement("img", {
35731
35955
  src: periodOfDaySrcFiles[periodOfDay]
35732
35956
  }));
@@ -35736,7 +35960,7 @@ var GifContainer = /*#__PURE__*/styled.div.withConfig({
35736
35960
  componentId: "sc-10t97fw-0"
35737
35961
  })(["width:100%;img{width:67%;}"]);
35738
35962
 
35739
- var img$c = '';
35963
+ var img$d = '';
35740
35964
 
35741
35965
  var TimeWidget = function TimeWidget(_ref) {
35742
35966
  var onClose = _ref.onClose,
@@ -35751,7 +35975,7 @@ var TimeWidget = function TimeWidget(_ref) {
35751
35975
  var WidgetContainer = /*#__PURE__*/styled.div.withConfig({
35752
35976
  displayName: "TimeWidget__WidgetContainer",
35753
35977
  componentId: "sc-1ja236h-0"
35754
- })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$c);
35978
+ })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$d);
35755
35979
  var Time = /*#__PURE__*/styled.div.withConfig({
35756
35980
  displayName: "TimeWidget__Time",
35757
35981
  componentId: "sc-1ja236h-1"
@@ -35987,230 +36211,17 @@ var Truncate = function Truncate(_ref) {
35987
36211
  var _ref$maxLines = _ref.maxLines,
35988
36212
  maxLines = _ref$maxLines === void 0 ? 1 : _ref$maxLines,
35989
36213
  children = _ref.children;
35990
- return React__default.createElement(Container$j, {
36214
+ return React__default.createElement(Container$l, {
35991
36215
  maxLines: maxLines
35992
36216
  }, children);
35993
36217
  };
35994
- var Container$j = /*#__PURE__*/styled.div.withConfig({
36218
+ var Container$l = /*#__PURE__*/styled.div.withConfig({
35995
36219
  displayName: "Truncate__Container",
35996
36220
  componentId: "sc-6x00qb-0"
35997
36221
  })(["display:-webkit-box;max-width:100%;max-height:100%;-webkit-line-clamp:", ";-webkit-box-orient:vertical;overflow:hidden;"], function (props) {
35998
36222
  return props.maxLines;
35999
36223
  });
36000
36224
 
36001
- var IS_MOBILE_OR_TABLET = /*#__PURE__*/shared.isMobileOrTablet();
36002
-
36003
- var chunkString = function chunkString(str, length) {
36004
- return str.match(new RegExp('.{1,' + length + '}', 'g'));
36005
- };
36006
-
36007
- var img$d = '';
36008
-
36009
- var NPCDialogText = function NPCDialogText(_ref) {
36010
- var text = _ref.text,
36011
- onClose = _ref.onClose,
36012
- onEndStep = _ref.onEndStep,
36013
- onStartStep = _ref.onStartStep,
36014
- type = _ref.type;
36015
- var windowSize = React.useRef([window.innerWidth, window.innerHeight]);
36016
- function maxCharacters(width) {
36017
- // Set the font size to 16 pixels
36018
- var fontSize = 11.2;
36019
- // Calculate the number of characters that can fit in one line
36020
- var charactersPerLine = Math.floor(width / 2 / fontSize);
36021
- // Calculate the number of lines that can fit in the div
36022
- var linesPerDiv = Math.floor(180 / fontSize);
36023
- // Calculate the maximum number of characters that can fit in the div
36024
- var maxCharacters = charactersPerLine * linesPerDiv;
36025
- // Return the maximum number of characters
36026
- return Math.round(maxCharacters / 5);
36027
- }
36028
- var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
36029
- var _useState = React.useState(0),
36030
- chunkIndex = _useState[0],
36031
- setChunkIndex = _useState[1];
36032
- var onHandleSpacePress = function onHandleSpacePress(event) {
36033
- if (event.code === 'Space') {
36034
- goToNextStep();
36035
- }
36036
- };
36037
- var goToNextStep = function goToNextStep() {
36038
- var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
36039
- if (hasNextChunk) {
36040
- setChunkIndex(function (prev) {
36041
- return prev + 1;
36042
- });
36043
- } else {
36044
- // if there's no more text chunks, close the dialog
36045
- onClose();
36046
- }
36047
- };
36048
- React.useEffect(function () {
36049
- document.addEventListener('keydown', onHandleSpacePress);
36050
- return function () {
36051
- return document.removeEventListener('keydown', onHandleSpacePress);
36052
- };
36053
- }, [chunkIndex]);
36054
- var _useState2 = React.useState(false),
36055
- showGoNextIndicator = _useState2[0],
36056
- setShowGoNextIndicator = _useState2[1];
36057
- return React__default.createElement(Container$k, null, React__default.createElement(DynamicText, {
36058
- text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
36059
- onFinish: function onFinish() {
36060
- setShowGoNextIndicator(true);
36061
- onEndStep && onEndStep();
36062
- },
36063
- onStart: function onStart() {
36064
- setShowGoNextIndicator(false);
36065
- onStartStep && onStartStep();
36066
- }
36067
- }), showGoNextIndicator && React__default.createElement(PressSpaceIndicator$1, {
36068
- right: type === exports.NPCDialogType.TextOnly ? '1rem' : '10.5rem',
36069
- src: IS_MOBILE_OR_TABLET ? img$d : img$7,
36070
- onPointerDown: function onPointerDown() {
36071
- goToNextStep();
36072
- }
36073
- }));
36074
- };
36075
- var Container$k = /*#__PURE__*/styled.div.withConfig({
36076
- displayName: "NPCDialogText__Container",
36077
- componentId: "sc-1cxkdh9-0"
36078
- })([""]);
36079
- var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
36080
- displayName: "NPCDialogText__PressSpaceIndicator",
36081
- componentId: "sc-1cxkdh9-1"
36082
- })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
36083
- var right = _ref2.right;
36084
- return right;
36085
- });
36086
-
36087
- (function (NPCDialogType) {
36088
- NPCDialogType["TextOnly"] = "TextOnly";
36089
- NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
36090
- })(exports.NPCDialogType || (exports.NPCDialogType = {}));
36091
- var NPCDialog = function NPCDialog(_ref) {
36092
- var text = _ref.text,
36093
- type = _ref.type,
36094
- _onClose = _ref.onClose,
36095
- imagePath = _ref.imagePath,
36096
- _ref$isQuestionDialog = _ref.isQuestionDialog,
36097
- isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
36098
- questions = _ref.questions,
36099
- answers = _ref.answers;
36100
- return React__default.createElement(RPGUIContainer, {
36101
- type: exports.RPGUIContainerTypes.FramedGold,
36102
- width: isQuestionDialog ? '600px' : '80%',
36103
- height: '180px'
36104
- }, isQuestionDialog && questions && answers ? React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer$2, {
36105
- flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
36106
- }, React__default.createElement(QuestionDialog, {
36107
- questions: questions,
36108
- answers: answers,
36109
- onClose: function onClose() {
36110
- if (_onClose) {
36111
- _onClose();
36112
- }
36113
- }
36114
- })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
36115
- src: imagePath || img$6
36116
- }))) : React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$l, null, React__default.createElement(TextContainer$2, {
36117
- flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
36118
- }, React__default.createElement(NPCDialogText, {
36119
- type: type,
36120
- text: text || 'No text provided.',
36121
- onClose: function onClose() {
36122
- if (_onClose) {
36123
- _onClose();
36124
- }
36125
- }
36126
- })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
36127
- src: imagePath || img$6
36128
- })))));
36129
- };
36130
- var Container$l = /*#__PURE__*/styled.div.withConfig({
36131
- displayName: "NPCDialog__Container",
36132
- componentId: "sc-1b4aw74-0"
36133
- })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
36134
- var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
36135
- displayName: "NPCDialog__TextContainer",
36136
- componentId: "sc-1b4aw74-1"
36137
- })(["flex:", " 0 0;width:355px;"], function (_ref2) {
36138
- var flex = _ref2.flex;
36139
- return flex;
36140
- });
36141
- var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
36142
- displayName: "NPCDialog__ThumbnailContainer",
36143
- componentId: "sc-1b4aw74-2"
36144
- })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
36145
- var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
36146
- displayName: "NPCDialog__NPCThumbnail",
36147
- componentId: "sc-1b4aw74-3"
36148
- })(["image-rendering:pixelated;height:128px;width:128px;"]);
36149
-
36150
- var HistoryDialog = function HistoryDialog(_ref) {
36151
- var backgroundImgPath = _ref.backgroundImgPath,
36152
- fullCoverBackground = _ref.fullCoverBackground,
36153
- questions = _ref.questions,
36154
- answers = _ref.answers,
36155
- text = _ref.text,
36156
- imagePath = _ref.imagePath,
36157
- textAndTypeArray = _ref.textAndTypeArray,
36158
- onClose = _ref.onClose;
36159
- var _useState = React.useState(0),
36160
- img = _useState[0],
36161
- setImage = _useState[1];
36162
- var onHandleSpacePress = function onHandleSpacePress(event) {
36163
- if (event.code === 'Space') {
36164
- if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
36165
- setImage(function (prev) {
36166
- return prev + 1;
36167
- });
36168
- } else {
36169
- // if there's no more text chunks, close the dialog
36170
- onClose();
36171
- }
36172
- }
36173
- };
36174
- React.useEffect(function () {
36175
- document.addEventListener('keydown', onHandleSpacePress);
36176
- return function () {
36177
- return document.removeEventListener('keydown', onHandleSpacePress);
36178
- };
36179
- }, [backgroundImgPath]);
36180
- return React__default.createElement(BackgroundContainer, {
36181
- imgPath: backgroundImgPath[img],
36182
- fullImg: fullCoverBackground
36183
- }, React__default.createElement(DialogContainer, null, textAndTypeArray ? React__default.createElement(NPCMultiDialog, {
36184
- textAndTypeArray: textAndTypeArray,
36185
- onClose: onClose
36186
- }) : questions && answers ? React__default.createElement(QuestionDialog, {
36187
- questions: questions,
36188
- answers: answers,
36189
- onClose: onClose
36190
- }) : text && imagePath ? React__default.createElement(NPCDialog, {
36191
- text: text,
36192
- imagePath: imagePath,
36193
- onClose: onClose,
36194
- type: exports.NPCDialogType.TextAndThumbnail
36195
- }) : React__default.createElement(NPCDialog, {
36196
- text: text,
36197
- onClose: onClose,
36198
- type: exports.NPCDialogType.TextOnly
36199
- })));
36200
- };
36201
- var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
36202
- displayName: "HistoryDialog__BackgroundContainer",
36203
- componentId: "sc-u6oe75-0"
36204
- })(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
36205
- return props.imgPath;
36206
- }, function (props) {
36207
- return props.imgPath ? 'cover' : 'auto';
36208
- });
36209
- var DialogContainer = /*#__PURE__*/styled.div.withConfig({
36210
- displayName: "HistoryDialog__DialogContainer",
36211
- componentId: "sc-u6oe75-1"
36212
- })(["display:flex;justify-content:center;padding-top:200px;"]);
36213
-
36214
36225
  exports.Button = Button;
36215
36226
  exports.CharacterSelection = CharacterSelection;
36216
36227
  exports.Chat = Chat;