@rpg-engine/long-bow 0.3.62 → 0.3.63

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 +937 -925
  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 +744 -732
  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 +153 -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 +193 -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
@@ -34145,509 +34145,374 @@ var EquipmentColumn = /*#__PURE__*/styled.div.withConfig({
34145
34145
  componentId: "sc-1wuddg2-1"
34146
34146
  })(["display:flex;justify-content:center;flex-wrap:wrap;flex-direction:column;touch-action:none;"]);
34147
34147
 
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();
34148
+ var IS_MOBILE_OR_TABLET = /*#__PURE__*/shared.isMobileOrTablet();
34149
+
34150
+ var chunkString = function chunkString(str, length) {
34151
+ return str.match(new RegExp('.{1,' + length + '}', 'g'));
34152
+ };
34153
+
34154
+ var DynamicText = function DynamicText(_ref) {
34155
+ var text = _ref.text,
34156
+ onFinish = _ref.onFinish,
34157
+ onStart = _ref.onStart;
34158
+ var _useState = React.useState(''),
34159
+ textState = _useState[0],
34160
+ setTextState = _useState[1];
34161
+ React.useEffect(function () {
34162
+ var i = 0;
34163
+ var interval = setInterval(function () {
34164
+ // on every interval, show one more character
34165
+ if (i === 0) {
34166
+ if (onStart) {
34167
+ onStart();
34168
+ }
34161
34169
  }
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
- });
34170
+ if (i < text.length) {
34171
+ setTextState(text.substring(0, i + 1));
34172
+ i++;
34173
+ } else {
34174
+ clearInterval(interval);
34175
+ if (onFinish) {
34176
+ onFinish();
34177
+ }
34173
34178
  }
34174
- },
34175
- onOutsideClick: onOutsideClick,
34176
- initialPosition: initialPosition
34177
- }, children);
34179
+ }, 50);
34180
+ return function () {
34181
+ clearInterval(interval);
34182
+ };
34183
+ }, [text]);
34184
+ return React__default.createElement(TextContainer, null, textState);
34178
34185
  };
34186
+ var TextContainer = /*#__PURE__*/styled.p.withConfig({
34187
+ displayName: "DynamicText__TextContainer",
34188
+ componentId: "sc-1ggl9nd-0"
34189
+ })(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]);
34179
34190
 
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);
34191
+ var img$6 = '';
34192
+
34193
+ var img$7 = '';
34194
+
34195
+ var NPCDialogText = function NPCDialogText(_ref) {
34196
+ var text = _ref.text,
34197
+ onClose = _ref.onClose,
34198
+ onEndStep = _ref.onEndStep,
34199
+ onStartStep = _ref.onStartStep,
34200
+ type = _ref.type;
34201
+ var windowSize = React.useRef([window.innerWidth, window.innerHeight]);
34202
+ function maxCharacters(width) {
34203
+ // Set the font size to 16 pixels
34204
+ var fontSize = 11.2;
34205
+ // Calculate the number of characters that can fit in one line
34206
+ var charactersPerLine = Math.floor(width / 2 / fontSize);
34207
+ // Calculate the number of lines that can fit in the div
34208
+ var linesPerDiv = Math.floor(180 / fontSize);
34209
+ // Calculate the maximum number of characters that can fit in the div
34210
+ var maxCharacters = charactersPerLine * linesPerDiv;
34211
+ // Return the maximum number of characters
34212
+ return Math.round(maxCharacters / 5);
34213
+ }
34214
+ var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
34193
34215
  var _useState = React.useState(0),
34194
- left = _useState[0],
34195
- setLeft = _useState[1];
34216
+ chunkIndex = _useState[0],
34217
+ setChunkIndex = _useState[1];
34218
+ var onHandleSpacePress = function onHandleSpacePress(event) {
34219
+ if (event.code === 'Space') {
34220
+ goToNextStep();
34221
+ }
34222
+ };
34223
+ var goToNextStep = function goToNextStep() {
34224
+ var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
34225
+ if (hasNextChunk) {
34226
+ setChunkIndex(function (prev) {
34227
+ return prev + 1;
34228
+ });
34229
+ } else {
34230
+ // if there's no more text chunks, close the dialog
34231
+ onClose();
34232
+ }
34233
+ };
34196
34234
  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'
34235
+ document.addEventListener('keydown', onHandleSpacePress);
34236
+ return function () {
34237
+ return document.removeEventListener('keydown', onHandleSpacePress);
34238
+ };
34239
+ }, [chunkIndex]);
34240
+ var _useState2 = React.useState(false),
34241
+ showGoNextIndicator = _useState2[0],
34242
+ setShowGoNextIndicator = _useState2[1];
34243
+ return React__default.createElement(Container$b, null, React__default.createElement(DynamicText, {
34244
+ text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
34245
+ onFinish: function onFinish() {
34246
+ setShowGoNextIndicator(true);
34247
+ onEndStep && onEndStep();
34206
34248
  },
34207
- className: "rpgui-slider-container " + typeClass,
34208
- id: "rpgui-slider-" + sliderId,
34209
- ref: containerRef
34210
- }, React__default.createElement("div", {
34211
- style: {
34212
- pointerEvents: 'none'
34249
+ onStart: function onStart() {
34250
+ setShowGoNextIndicator(false);
34251
+ onStartStep && onStartStep();
34213
34252
  }
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
34253
+ }), showGoNextIndicator && React__default.createElement(PressSpaceIndicator, {
34254
+ right: type === exports.NPCDialogType.TextOnly ? '1rem' : '10.5rem',
34255
+ src: IS_MOBILE_OR_TABLET ? img$6 : img$7,
34256
+ onPointerDown: function onPointerDown() {
34257
+ goToNextStep();
34224
34258
  }
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
34259
  }));
34238
34260
  };
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;"]);
34261
+ var Container$b = /*#__PURE__*/styled.div.withConfig({
34262
+ displayName: "NPCDialogText__Container",
34263
+ componentId: "sc-1cxkdh9-0"
34264
+ })([""]);
34265
+ var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
34266
+ displayName: "NPCDialogText__PressSpaceIndicator",
34267
+ componentId: "sc-1cxkdh9-1"
34268
+ })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
34269
+ var right = _ref2.right;
34270
+ return right;
34271
+ });
34243
34272
 
34244
- var ItemQuantitySelector = function ItemQuantitySelector(_ref) {
34245
- var quantity = _ref.quantity,
34246
- onConfirm = _ref.onConfirm,
34273
+ //@ts-ignore
34274
+ var useEventListener = function useEventListener(type, handler, el) {
34275
+ if (el === void 0) {
34276
+ el = window;
34277
+ }
34278
+ var savedHandler = React__default.useRef();
34279
+ React__default.useEffect(function () {
34280
+ savedHandler.current = handler;
34281
+ }, [handler]);
34282
+ React__default.useEffect(function () {
34283
+ //@ts-ignore
34284
+ var listener = function listener(e) {
34285
+ return savedHandler.current(e);
34286
+ };
34287
+ el.addEventListener(type, listener);
34288
+ return function () {
34289
+ el.removeEventListener(type, listener);
34290
+ };
34291
+ }, [type, el]);
34292
+ };
34293
+
34294
+ var QuestionDialog = function QuestionDialog(_ref) {
34295
+ var questions = _ref.questions,
34296
+ answers = _ref.answers,
34247
34297
  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
- };
34298
+ var _useState = React.useState(questions[0]),
34299
+ currentQuestion = _useState[0],
34300
+ setCurrentQuestion = _useState[1];
34301
+ var _useState2 = React.useState(false),
34302
+ canShowAnswers = _useState2[0],
34303
+ setCanShowAnswers = _useState2[1];
34304
+ var onGetFirstAnswer = function onGetFirstAnswer() {
34305
+ if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {
34306
+ return null;
34265
34307
  }
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
- }
34308
+ var firstAnswerId = currentQuestion.answerIds[0];
34309
+ return answers.find(function (answer) {
34310
+ return answer.id === firstAnswerId;
34311
+ });
34312
+ };
34313
+ var _useState3 = React.useState(onGetFirstAnswer()),
34314
+ currentAnswer = _useState3[0],
34315
+ setCurrentAnswer = _useState3[1];
34316
+ React.useEffect(function () {
34317
+ setCurrentAnswer(onGetFirstAnswer());
34318
+ }, [currentQuestion]);
34319
+ var onGetAnswers = function onGetAnswers(answerIds) {
34320
+ return answerIds.map(function (answerId) {
34321
+ return answers.find(function (answer) {
34322
+ return answer.id === answerId;
34361
34323
  });
34324
+ });
34325
+ };
34326
+ var onKeyPress = function onKeyPress(e) {
34327
+ switch (e.key) {
34328
+ case 'ArrowDown':
34329
+ // select next answer, if any.
34330
+ // if no next answer, select first answer
34331
+ // const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(
34332
+ // (answer) => answer?.id === currentAnswer!.id + 1
34333
+ // );
34334
+ var nextAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34335
+ return (answer == null ? void 0 : answer.id) === currentAnswer.id + 1;
34336
+ });
34337
+ var nextAnswerID = currentQuestion.answerIds[nextAnswerIndex];
34338
+ var nextAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34339
+ return (answer == null ? void 0 : answer.id) === nextAnswerID;
34340
+ });
34341
+ setCurrentAnswer(nextAnswer || onGetFirstAnswer());
34342
+ break;
34343
+ case 'ArrowUp':
34344
+ // select previous answer, if any.
34345
+ // if no previous answer, select last answer
34346
+ var previousAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34347
+ return (answer == null ? void 0 : answer.id) === currentAnswer.id - 1;
34348
+ });
34349
+ var previousAnswerID = currentQuestion.answerIds && currentQuestion.answerIds[previousAnswerIndex];
34350
+ var previousAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34351
+ return (answer == null ? void 0 : answer.id) === previousAnswerID;
34352
+ });
34353
+ if (previousAnswer) {
34354
+ setCurrentAnswer(previousAnswer);
34355
+ } else {
34356
+ setCurrentAnswer(onGetAnswers(currentQuestion.answerIds).pop());
34357
+ }
34358
+ break;
34359
+ case 'Enter':
34360
+ setCanShowAnswers(false);
34361
+ if (!(currentAnswer != null && currentAnswer.nextQuestionId)) {
34362
+ onClose();
34363
+ return;
34364
+ } else {
34365
+ setCurrentQuestion(questions.find(function (question) {
34366
+ return question.id === currentAnswer.nextQuestionId;
34367
+ }));
34368
+ }
34369
+ break;
34362
34370
  }
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
34371
  };
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
34372
+ useEventListener('keydown', onKeyPress);
34373
+ var onAnswerClick = function onAnswerClick(answer) {
34374
+ setCanShowAnswers(false);
34375
+ if (answer.nextQuestionId) {
34376
+ // if there is a next question, go to it
34377
+ setCurrentQuestion(questions.find(function (question) {
34378
+ return question.id === answer.nextQuestionId;
34481
34379
  }));
34380
+ } else {
34381
+ // else, finish dialog!
34382
+ onClose();
34482
34383
  }
34483
- return slots;
34484
34384
  };
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
- });
34385
+ var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
34386
+ var answerIds = currentQuestion.answerIds;
34387
+ if (!answerIds) {
34388
+ return null;
34515
34389
  }
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);
34390
+ var answers = onGetAnswers(answerIds);
34391
+ if (!answers) {
34392
+ return null;
34544
34393
  }
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();
34394
+ return answers.map(function (answer) {
34395
+ var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
34396
+ var selectedColor = isSelected ? 'yellow' : 'white';
34397
+ if (answer) {
34398
+ return React__default.createElement(AnswerRow, {
34399
+ key: "answer_" + answer.id
34400
+ }, React__default.createElement(AnswerSelectedIcon, {
34401
+ color: selectedColor
34402
+ }, isSelected ? 'X' : null), React__default.createElement(Answer, {
34403
+ key: answer.id,
34404
+ onPointerDown: function onPointerDown() {
34405
+ return onAnswerClick(answer);
34406
+ },
34407
+ color: selectedColor
34408
+ }, answer.text));
34553
34409
  }
34410
+ return null;
34411
+ });
34412
+ };
34413
+ return React__default.createElement(Container$c, null, React__default.createElement(QuestionContainer, null, React__default.createElement(DynamicText, {
34414
+ text: currentQuestion.text,
34415
+ onStart: function onStart() {
34416
+ return setCanShowAnswers(false);
34417
+ },
34418
+ onFinish: function onFinish() {
34419
+ return setCanShowAnswers(true);
34554
34420
  }
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")));
34421
+ })), canShowAnswers && React__default.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
34587
34422
  };
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%;"]);
34423
+ var Container$c = /*#__PURE__*/styled.div.withConfig({
34424
+ displayName: "QuestionDialog__Container",
34425
+ componentId: "sc-bxc5u0-0"
34426
+ })(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
34427
+ var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
34428
+ displayName: "QuestionDialog__QuestionContainer",
34429
+ componentId: "sc-bxc5u0-1"
34430
+ })(["flex:100%;width:100%;"]);
34431
+ var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
34432
+ displayName: "QuestionDialog__AnswersContainer",
34433
+ componentId: "sc-bxc5u0-2"
34434
+ })(["flex:100%;"]);
34435
+ var Answer = /*#__PURE__*/styled.p.withConfig({
34436
+ displayName: "QuestionDialog__Answer",
34437
+ componentId: "sc-bxc5u0-3"
34438
+ })(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
34439
+ return props.color;
34440
+ });
34441
+ var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
34442
+ displayName: "QuestionDialog__AnswerSelectedIcon",
34443
+ componentId: "sc-bxc5u0-4"
34444
+ })(["flex:5% 0 0;color:", " !important;"], function (props) {
34445
+ return props.color;
34446
+ });
34447
+ var AnswerRow = /*#__PURE__*/styled.div.withConfig({
34448
+ displayName: "QuestionDialog__AnswerRow",
34449
+ componentId: "sc-bxc5u0-5"
34450
+ })(["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
34451
 
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'
34452
+ var img$8 = '';
34453
+
34454
+ (function (NPCDialogType) {
34455
+ NPCDialogType["TextOnly"] = "TextOnly";
34456
+ NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
34457
+ })(exports.NPCDialogType || (exports.NPCDialogType = {}));
34458
+ var NPCDialog = function NPCDialog(_ref) {
34459
+ var text = _ref.text,
34460
+ type = _ref.type,
34461
+ _onClose = _ref.onClose,
34462
+ imagePath = _ref.imagePath,
34463
+ _ref$isQuestionDialog = _ref.isQuestionDialog,
34464
+ isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
34465
+ questions = _ref.questions,
34466
+ answers = _ref.answers;
34467
+ return React__default.createElement(RPGUIContainer, {
34468
+ type: exports.RPGUIContainerTypes.FramedGold,
34469
+ width: isQuestionDialog ? '600px' : '80%',
34470
+ height: '180px'
34471
+ }, isQuestionDialog && questions && answers ? React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer$1, {
34472
+ flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
34473
+ }, React__default.createElement(QuestionDialog, {
34474
+ questions: questions,
34475
+ answers: answers,
34476
+ onClose: function onClose() {
34477
+ if (_onClose) {
34478
+ _onClose();
34479
+ }
34625
34480
  }
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);
34481
+ })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
34482
+ src: imagePath || img$8
34483
+ }))) : React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$d, null, React__default.createElement(TextContainer$1, {
34484
+ flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
34485
+ }, React__default.createElement(NPCDialogText, {
34486
+ type: type,
34487
+ text: text || 'No text provided.',
34488
+ onClose: function onClose() {
34489
+ if (_onClose) {
34490
+ _onClose();
34631
34491
  }
34632
- }, (params == null ? void 0 : params.text) || 'No text');
34633
- })));
34492
+ }
34493
+ })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
34494
+ src: imagePath || img$8
34495
+ })))));
34634
34496
  };
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 = '';
34497
+ var Container$d = /*#__PURE__*/styled.div.withConfig({
34498
+ displayName: "NPCDialog__Container",
34499
+ componentId: "sc-1b4aw74-0"
34500
+ })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
34501
+ var TextContainer$1 = /*#__PURE__*/styled.div.withConfig({
34502
+ displayName: "NPCDialog__TextContainer",
34503
+ componentId: "sc-1b4aw74-1"
34504
+ })(["flex:", " 0 0;width:355px;"], function (_ref2) {
34505
+ var flex = _ref2.flex;
34506
+ return flex;
34507
+ });
34508
+ var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
34509
+ displayName: "NPCDialog__ThumbnailContainer",
34510
+ componentId: "sc-1b4aw74-2"
34511
+ })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
34512
+ var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
34513
+ displayName: "NPCDialog__NPCThumbnail",
34514
+ componentId: "sc-1b4aw74-3"
34515
+ })(["image-rendering:pixelated;height:128px;width:128px;"]);
34651
34516
 
34652
34517
  (function (ImgSide) {
34653
34518
  ImgSide["right"] = "right";
@@ -34685,7 +34550,7 @@ var NPCMultiDialog = function NPCMultiDialog(_ref) {
34685
34550
  type: exports.RPGUIContainerTypes.FramedGold,
34686
34551
  width: '50%',
34687
34552
  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, {
34553
+ }, 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
34554
  flex: '70%'
34690
34555
  }, React__default.createElement(NPCDialogText, {
34691
34556
  onStartStep: function onStartStep() {
@@ -34700,14 +34565,14 @@ var NPCMultiDialog = function NPCMultiDialog(_ref) {
34700
34565
  _onClose();
34701
34566
  }
34702
34567
  }
34703
- })), React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
34704
- src: textAndTypeArray[slide].imagePath || img$6
34705
- })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator, {
34568
+ })), React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
34569
+ src: textAndTypeArray[slide].imagePath || img$8
34570
+ })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator$1, {
34706
34571
  right: '10.5rem',
34707
34572
  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, {
34573
+ })), textAndTypeArray[slide].imageSide === 'left' && React__default.createElement(React__default.Fragment, null, React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
34574
+ src: textAndTypeArray[slide].imagePath || img$8
34575
+ })), React__default.createElement(TextContainer$2, {
34711
34576
  flex: '70%'
34712
34577
  }, React__default.createElement(NPCDialogText, {
34713
34578
  onStartStep: function onStartStep() {
@@ -34722,31 +34587,31 @@ var NPCMultiDialog = function NPCMultiDialog(_ref) {
34722
34587
  _onClose();
34723
34588
  }
34724
34589
  }
34725
- })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator, {
34590
+ })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator$1, {
34726
34591
  right: '1rem',
34727
34592
  src: img$7
34728
34593
  }))), ")"));
34729
34594
  };
34730
- var Container$d = /*#__PURE__*/styled.div.withConfig({
34595
+ var Container$e = /*#__PURE__*/styled.div.withConfig({
34731
34596
  displayName: "NPCMultiDialog__Container",
34732
34597
  componentId: "sc-rvu5wg-0"
34733
34598
  })(["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({
34599
+ var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
34735
34600
  displayName: "NPCMultiDialog__TextContainer",
34736
34601
  componentId: "sc-rvu5wg-1"
34737
34602
  })(["flex:", " 0 0;width:355px;"], function (_ref2) {
34738
34603
  var flex = _ref2.flex;
34739
34604
  return flex;
34740
34605
  });
34741
- var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
34606
+ var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
34742
34607
  displayName: "NPCMultiDialog__ThumbnailContainer",
34743
34608
  componentId: "sc-rvu5wg-2"
34744
34609
  })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
34745
- var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
34610
+ var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
34746
34611
  displayName: "NPCMultiDialog__NPCThumbnail",
34747
34612
  componentId: "sc-rvu5wg-3"
34748
34613
  })(["image-rendering:pixelated;height:128px;width:128px;"]);
34749
- var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
34614
+ var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
34750
34615
  displayName: "NPCMultiDialog__PressSpaceIndicator",
34751
34616
  componentId: "sc-rvu5wg-4"
34752
34617
  })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref3) {
@@ -34754,221 +34619,569 @@ var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
34754
34619
  return right;
34755
34620
  });
34756
34621
 
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);
34622
+ var HistoryDialog = function HistoryDialog(_ref) {
34623
+ var backgroundImgPath = _ref.backgroundImgPath,
34624
+ fullCoverBackground = _ref.fullCoverBackground,
34625
+ questions = _ref.questions,
34626
+ answers = _ref.answers,
34627
+ text = _ref.text,
34628
+ imagePath = _ref.imagePath,
34629
+ textAndTypeArray = _ref.textAndTypeArray,
34630
+ onClose = _ref.onClose;
34631
+ var _useState = React.useState(0),
34632
+ img = _useState[0],
34633
+ setImage = _useState[1];
34634
+ var onHandleSpacePress = function onHandleSpacePress(event) {
34635
+ if (event.code === 'Space') {
34636
+ if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
34637
+ setImage(function (prev) {
34638
+ return prev + 1;
34639
+ });
34640
+ } else {
34641
+ // if there's no more text chunks, close the dialog
34642
+ onClose();
34643
+ }
34644
+ }
34645
+ };
34646
+ React.useEffect(function () {
34647
+ document.addEventListener('keydown', onHandleSpacePress);
34772
34648
  return function () {
34773
- el.removeEventListener(type, listener);
34649
+ return document.removeEventListener('keydown', onHandleSpacePress);
34774
34650
  };
34775
- }, [type, el]);
34651
+ }, [backgroundImgPath]);
34652
+ return React__default.createElement(BackgroundContainer, {
34653
+ imgPath: backgroundImgPath[img],
34654
+ fullImg: fullCoverBackground
34655
+ }, React__default.createElement(DialogContainer, null, textAndTypeArray ? React__default.createElement(NPCMultiDialog, {
34656
+ textAndTypeArray: textAndTypeArray,
34657
+ onClose: onClose
34658
+ }) : questions && answers ? React__default.createElement(QuestionDialog, {
34659
+ questions: questions,
34660
+ answers: answers,
34661
+ onClose: onClose
34662
+ }) : text && imagePath ? React__default.createElement(NPCDialog, {
34663
+ text: text,
34664
+ imagePath: imagePath,
34665
+ onClose: onClose,
34666
+ type: exports.NPCDialogType.TextAndThumbnail
34667
+ }) : React__default.createElement(NPCDialog, {
34668
+ text: text,
34669
+ onClose: onClose,
34670
+ type: exports.NPCDialogType.TextOnly
34671
+ })));
34776
34672
  };
34673
+ var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
34674
+ displayName: "HistoryDialog__BackgroundContainer",
34675
+ componentId: "sc-u6oe75-0"
34676
+ })(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
34677
+ return props.imgPath;
34678
+ }, function (props) {
34679
+ return props.imgPath ? 'cover' : 'auto';
34680
+ });
34681
+ var DialogContainer = /*#__PURE__*/styled.div.withConfig({
34682
+ displayName: "HistoryDialog__DialogContainer",
34683
+ componentId: "sc-u6oe75-1"
34684
+ })(["display:flex;justify-content:center;padding-top:200px;"]);
34777
34685
 
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];
34686
+ var SlotsContainer = function SlotsContainer(_ref) {
34687
+ var children = _ref.children,
34688
+ title = _ref.title,
34689
+ onClose = _ref.onClose,
34690
+ _onPositionChange = _ref.onPositionChange,
34691
+ onOutsideClick = _ref.onOutsideClick,
34692
+ initialPosition = _ref.initialPosition;
34693
+ return React__default.createElement(DraggableContainer, {
34694
+ title: title,
34695
+ type: exports.RPGUIContainerTypes.Framed,
34696
+ onCloseButton: function onCloseButton() {
34697
+ if (onClose) {
34698
+ onClose();
34699
+ }
34700
+ },
34701
+ width: "400px",
34702
+ cancelDrag: ".item-container-body, #shortcuts_list",
34703
+ onPositionChange: function onPositionChange(_ref2) {
34704
+ var x = _ref2.x,
34705
+ y = _ref2.y;
34706
+ if (_onPositionChange) {
34707
+ _onPositionChange({
34708
+ x: x,
34709
+ y: y
34710
+ });
34711
+ }
34712
+ },
34713
+ onOutsideClick: onOutsideClick,
34714
+ initialPosition: initialPosition
34715
+ }, children);
34716
+ };
34717
+
34718
+ (function (RangeSliderType) {
34719
+ RangeSliderType["Slider"] = "rpgui-slider";
34720
+ RangeSliderType["GoldSlider"] = "rpgui-slider golden";
34721
+ })(exports.RangeSliderType || (exports.RangeSliderType = {}));
34722
+ var RangeSlider = function RangeSlider(_ref) {
34723
+ var type = _ref.type,
34724
+ valueMin = _ref.valueMin,
34725
+ valueMax = _ref.valueMax,
34726
+ width = _ref.width,
34727
+ _onChange = _ref.onChange,
34728
+ value = _ref.value;
34729
+ var sliderId = uuid.v4();
34730
+ var containerRef = React.useRef(null);
34731
+ var _useState = React.useState(0),
34732
+ left = _useState[0],
34733
+ setLeft = _useState[1];
34734
+ React.useEffect(function () {
34735
+ var _containerRef$current;
34736
+ var calculatedWidth = ((_containerRef$current = containerRef.current) == null ? void 0 : _containerRef$current.clientWidth) || 0;
34737
+ setLeft(Math.max((value - valueMin) / (valueMax - valueMin) * (calculatedWidth - 35) + 10));
34738
+ }, [value, valueMin, valueMax]);
34739
+ var typeClass = type === exports.RangeSliderType.GoldSlider ? 'golden' : '';
34740
+ return React__default.createElement("div", {
34741
+ style: {
34742
+ width: width,
34743
+ position: 'relative'
34744
+ },
34745
+ className: "rpgui-slider-container " + typeClass,
34746
+ id: "rpgui-slider-" + sliderId,
34747
+ ref: containerRef
34748
+ }, React__default.createElement("div", {
34749
+ style: {
34750
+ pointerEvents: 'none'
34751
+ }
34752
+ }, React__default.createElement("div", {
34753
+ className: "rpgui-slider-track " + typeClass
34754
+ }), React__default.createElement("div", {
34755
+ className: "rpgui-slider-left-edge " + typeClass
34756
+ }), React__default.createElement("div", {
34757
+ className: "rpgui-slider-right-edge " + typeClass
34758
+ }), React__default.createElement("div", {
34759
+ className: "rpgui-slider-thumb " + typeClass,
34760
+ style: {
34761
+ left: left
34762
+ }
34763
+ })), React__default.createElement(Input$1, {
34764
+ type: "range",
34765
+ style: {
34766
+ width: width
34767
+ },
34768
+ min: valueMin,
34769
+ max: valueMax,
34770
+ onChange: function onChange(e) {
34771
+ return _onChange(Number(e.target.value));
34772
+ },
34773
+ value: value,
34774
+ className: "rpgui-cursor-point"
34775
+ }));
34776
+ };
34777
+ var Input$1 = /*#__PURE__*/styled.input.withConfig({
34778
+ displayName: "RangeSlider__Input",
34779
+ componentId: "sc-v8mte9-0"
34780
+ })(["opacity:0;position:absolute;width:100%;height:100%;top:0;left:0;margin-top:-5px;"]);
34781
+
34782
+ var ItemQuantitySelector = function ItemQuantitySelector(_ref) {
34783
+ var quantity = _ref.quantity,
34784
+ onConfirm = _ref.onConfirm,
34785
+ onClose = _ref.onClose;
34786
+ var _useState = React.useState(quantity),
34787
+ value = _useState[0],
34788
+ setValue = _useState[1];
34789
+ var inputRef = React.useRef(null);
34785
34790
  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();
34791
+ if (inputRef.current) {
34792
+ inputRef.current.focus();
34793
+ inputRef.current.select();
34794
+ var closeSelector = function closeSelector(e) {
34795
+ if (e.key === 'Escape') {
34796
+ onClose();
34792
34797
  }
34798
+ };
34799
+ document.addEventListener('keydown', closeSelector);
34800
+ return function () {
34801
+ document.removeEventListener('keydown', closeSelector);
34802
+ };
34803
+ }
34804
+ return function () {};
34805
+ }, []);
34806
+ return React__default.createElement(StyledContainer, {
34807
+ type: exports.RPGUIContainerTypes.Framed,
34808
+ width: "25rem"
34809
+ }, React__default.createElement(CloseButton$2, {
34810
+ className: "container-close",
34811
+ onPointerDown: onClose
34812
+ }, "X"), React__default.createElement("h2", null, "Select quantity to move"), React__default.createElement(StyledForm, {
34813
+ style: {
34814
+ width: '100%'
34815
+ },
34816
+ onSubmit: function onSubmit(e) {
34817
+ e.preventDefault();
34818
+ var numberValue = Number(value);
34819
+ if (Number.isNaN(numberValue)) {
34820
+ return;
34793
34821
  }
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
- }
34822
+ onConfirm(Math.max(1, Math.min(quantity, numberValue)));
34823
+ },
34824
+ noValidate: true
34825
+ }, React__default.createElement(StyledInput, {
34826
+ innerRef: inputRef,
34827
+ placeholder: "Enter quantity",
34828
+ type: "number",
34829
+ min: 1,
34830
+ max: quantity,
34831
+ value: value,
34832
+ onChange: function onChange(e) {
34833
+ if (Number(e.target.value) >= quantity) {
34834
+ setValue(quantity);
34835
+ return;
34802
34836
  }
34803
- }, 50);
34804
- return function () {
34805
- clearInterval(interval);
34806
- };
34807
- }, [text]);
34808
- return React__default.createElement(TextContainer$1, null, textState);
34837
+ setValue(e.target.value);
34838
+ },
34839
+ onBlur: function onBlur(e) {
34840
+ var newValue = Math.max(1, Math.min(quantity, Number(e.target.value)));
34841
+ setValue(newValue);
34842
+ }
34843
+ }), React__default.createElement(RangeSlider, {
34844
+ type: exports.RangeSliderType.Slider,
34845
+ valueMin: 1,
34846
+ valueMax: quantity,
34847
+ width: "100%",
34848
+ onChange: setValue,
34849
+ value: value
34850
+ }), React__default.createElement(Button, {
34851
+ buttonType: exports.ButtonTypes.RPGUIButton,
34852
+ type: "submit"
34853
+ }, "Confirm")));
34809
34854
  };
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;"]);
34855
+ var StyledContainer = /*#__PURE__*/styled(RPGUIContainer).withConfig({
34856
+ displayName: "ItemQuantitySelector__StyledContainer",
34857
+ componentId: "sc-yfdtpn-0"
34858
+ })(["display:flex;flex-direction:column;align-items:center;"]);
34859
+ var StyledForm = /*#__PURE__*/styled.form.withConfig({
34860
+ displayName: "ItemQuantitySelector__StyledForm",
34861
+ componentId: "sc-yfdtpn-1"
34862
+ })(["display:flex;flex-direction:column;align-items:center;width:100%;"]);
34863
+ var StyledInput = /*#__PURE__*/styled(Input).withConfig({
34864
+ displayName: "ItemQuantitySelector__StyledInput",
34865
+ componentId: "sc-yfdtpn-2"
34866
+ })(["text-align:center;&::-webkit-outer-spin-button,&::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}&[type='number']{-moz-appearance:textfield;}"]);
34867
+ var CloseButton$2 = /*#__PURE__*/styled.div.withConfig({
34868
+ displayName: "ItemQuantitySelector__CloseButton",
34869
+ componentId: "sc-yfdtpn-3"
34870
+ })(["position:absolute;top:3px;right:0px;color:white;z-index:22;font-size:0.8rem;"]);
34814
34871
 
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;
34872
+ var ShortcutsSetter = function ShortcutsSetter(_ref) {
34873
+ var setSettingShortcutIndex = _ref.setSettingShortcutIndex,
34874
+ settingShortcutIndex = _ref.settingShortcutIndex,
34875
+ shortcuts = _ref.shortcuts,
34876
+ removeShortcut = _ref.removeShortcut,
34877
+ atlasJSON = _ref.atlasJSON,
34878
+ atlasIMG = _ref.atlasIMG;
34879
+ var getContent = function getContent(index) {
34880
+ var _shortcuts$index, _shortcuts$index3;
34881
+ if (((_shortcuts$index = shortcuts[index]) == null ? void 0 : _shortcuts$index.type) === shared.ShortcutType.Item) {
34882
+ var _shortcuts$index2;
34883
+ var _payload = (_shortcuts$index2 = shortcuts[index]) == null ? void 0 : _shortcuts$index2.payload;
34884
+ if (!_payload) return null;
34885
+ return React__default.createElement(SpriteFromAtlas, {
34886
+ atlasIMG: atlasIMG,
34887
+ atlasJSON: atlasJSON,
34888
+ spriteKey: shared.getItemTextureKeyPath({
34889
+ key: _payload.texturePath,
34890
+ texturePath: _payload.texturePath,
34891
+ stackQty: _payload.stackQty || 1
34892
+ }, atlasJSON),
34893
+ width: 32,
34894
+ height: 32,
34895
+ imgScale: 1.6,
34896
+ imgStyle: {
34897
+ left: '5px'
34898
+ }
34899
+ });
34900
+ }
34901
+ var payload = (_shortcuts$index3 = shortcuts[index]) == null ? void 0 : _shortcuts$index3.payload;
34902
+ return React__default.createElement("span", null, payload == null ? void 0 : payload.magicWords.split(' ').map(function (word) {
34903
+ return word[0];
34904
+ }));
34905
+ };
34906
+ return React__default.createElement(Container$f, null, React__default.createElement("p", null, "Shortcuts:"), React__default.createElement(List, {
34907
+ id: "shortcuts_list"
34908
+ }, Array.from({
34909
+ length: 6
34910
+ }).map(function (_, i) {
34911
+ return React__default.createElement(Shortcut, {
34912
+ key: i,
34913
+ onPointerDown: function onPointerDown() {
34914
+ removeShortcut(i);
34915
+ if (!shortcuts[i] || shortcuts[i].type === shared.ShortcutType.None) setSettingShortcutIndex(i);
34916
+ },
34917
+ disabled: settingShortcutIndex !== -1 && settingShortcutIndex !== i,
34918
+ isBeingSet: settingShortcutIndex === i
34919
+ }, getContent(i));
34920
+ })));
34921
+ };
34922
+ var Container$f = /*#__PURE__*/styled.div.withConfig({
34923
+ displayName: "ShortcutsSetter__Container",
34924
+ componentId: "sc-xuouuf-0"
34925
+ })(["p{margin:0;margin-left:0.5rem;}"]);
34926
+ var Shortcut = /*#__PURE__*/styled.button.withConfig({
34927
+ displayName: "ShortcutsSetter__Shortcut",
34928
+ componentId: "sc-xuouuf-1"
34929
+ })(["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) {
34930
+ var isBeingSet = _ref2.isBeingSet;
34931
+ return isBeingSet ? uiColors.yellow : uiColors.darkGray;
34932
+ }, uiColors.darkGray, uiColors.gray);
34933
+ var List = /*#__PURE__*/styled.div.withConfig({
34934
+ displayName: "ShortcutsSetter__List",
34935
+ componentId: "sc-xuouuf-2"
34936
+ })(["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;"]);
34937
+
34938
+ var ItemContainer$1 = function ItemContainer(_ref) {
34939
+ var itemContainer = _ref.itemContainer,
34940
+ onClose = _ref.onClose,
34941
+ _onMouseOver = _ref.onMouseOver,
34942
+ _onSelected = _ref.onSelected,
34943
+ onItemClick = _ref.onItemClick,
34944
+ type = _ref.type,
34945
+ atlasJSON = _ref.atlasJSON,
34946
+ atlasIMG = _ref.atlasIMG,
34947
+ _ref$disableContextMe = _ref.disableContextMenu,
34948
+ disableContextMenu = _ref$disableContextMe === void 0 ? false : _ref$disableContextMe,
34949
+ onItemDragEnd = _ref.onItemDragEnd,
34950
+ onItemDragStart = _ref.onItemDragStart,
34951
+ onItemPlaceDrop = _ref.onItemPlaceDrop,
34952
+ _onOutsideDrop = _ref.onOutsideDrop,
34953
+ checkIfItemCanBeMoved = _ref.checkIfItemCanBeMoved,
34954
+ initialPosition = _ref.initialPosition,
34955
+ checkIfItemShouldDragEnd = _ref.checkIfItemShouldDragEnd,
34956
+ dragScale = _ref.dragScale,
34957
+ shortcuts = _ref.shortcuts,
34958
+ setItemShortcut = _ref.setItemShortcut,
34959
+ removeShortcut = _ref.removeShortcut;
34960
+ var _useState = React.useState({
34961
+ isOpen: false,
34962
+ maxQuantity: 1,
34963
+ callback: function callback(_quantity) {}
34964
+ }),
34965
+ quantitySelect = _useState[0],
34966
+ setQuantitySelect = _useState[1];
34967
+ var _useState2 = React.useState(-1),
34968
+ settingShortcutIndex = _useState2[0],
34969
+ setSettingShortcutIndex = _useState2[1];
34970
+ var onRenderSlots = function onRenderSlots() {
34971
+ var slots = [];
34972
+ for (var i = 0; i < itemContainer.slotQty; i++) {
34973
+ var _itemContainer$slots;
34974
+ slots.push(React__default.createElement(ItemSlot, {
34975
+ isContextMenuDisabled: disableContextMenu,
34976
+ key: i,
34977
+ slotIndex: i,
34978
+ item: ((_itemContainer$slots = itemContainer.slots) == null ? void 0 : _itemContainer$slots[i]) || null,
34979
+ itemContainerType: type,
34980
+ onMouseOver: function onMouseOver(event, slotIndex, item) {
34981
+ if (_onMouseOver) _onMouseOver(event, slotIndex, item);
34982
+ },
34983
+ onPointerDown: function onPointerDown(itemType, containerType, item) {
34984
+ if (settingShortcutIndex !== -1) {
34985
+ setSettingShortcutIndex(-1);
34986
+ if (itemType === shared.ItemType.Consumable || itemType === shared.ItemType.Tool) {
34987
+ setItemShortcut == null ? void 0 : setItemShortcut(item.key, settingShortcutIndex);
34988
+ }
34989
+ } else if (onItemClick) onItemClick(item, itemType, containerType);
34990
+ },
34991
+ onSelected: function onSelected(optionId, item) {
34992
+ if (_onSelected) _onSelected(optionId, item);
34993
+ },
34994
+ onDragStart: function onDragStart(item, slotIndex, itemContainerType) {
34995
+ if (onItemDragStart) onItemDragStart(item, slotIndex, itemContainerType);
34996
+ },
34997
+ onDragEnd: function onDragEnd(quantity) {
34998
+ if (onItemDragEnd) onItemDragEnd(quantity);
34999
+ },
35000
+ dragScale: dragScale,
35001
+ checkIfItemCanBeMoved: checkIfItemCanBeMoved,
35002
+ checkIfItemShouldDragEnd: checkIfItemShouldDragEnd,
35003
+ openQuantitySelector: function openQuantitySelector(maxQuantity, callback) {
35004
+ setQuantitySelect({
35005
+ isOpen: true,
35006
+ maxQuantity: maxQuantity,
35007
+ callback: callback
35008
+ });
35009
+ },
35010
+ onPlaceDrop: function onPlaceDrop(item, slotIndex, itemContainerType) {
35011
+ if (onItemPlaceDrop) onItemPlaceDrop(item, slotIndex, itemContainerType);
35012
+ },
35013
+ onOutsideDrop: function onOutsideDrop(item, position) {
35014
+ if (_onOutsideDrop) _onOutsideDrop(item, position);
35015
+ },
35016
+ atlasIMG: atlasIMG,
35017
+ atlasJSON: atlasJSON,
35018
+ isSelectingShortcut: settingShortcutIndex !== -1
35019
+ }));
34828
35020
  }
34829
- var firstAnswerId = currentQuestion.answerIds[0];
34830
- return answers.find(function (answer) {
34831
- return answer.id === firstAnswerId;
34832
- });
35021
+ return slots;
34833
35022
  };
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;
35023
+ return React__default.createElement(React__default.Fragment, null, React__default.createElement(SlotsContainer, {
35024
+ title: itemContainer.name || 'Container',
35025
+ onClose: onClose,
35026
+ initialPosition: initialPosition
35027
+ }, type === shared.ItemContainerType.Inventory && shortcuts && removeShortcut && React__default.createElement(ShortcutsSetter, {
35028
+ setSettingShortcutIndex: setSettingShortcutIndex,
35029
+ settingShortcutIndex: settingShortcutIndex,
35030
+ shortcuts: shortcuts,
35031
+ removeShortcut: removeShortcut,
35032
+ atlasIMG: atlasIMG,
35033
+ atlasJSON: atlasJSON
35034
+ }), React__default.createElement(ItemsContainer, {
35035
+ className: "item-container-body"
35036
+ }, onRenderSlots())), quantitySelect.isOpen && React__default.createElement(QuantitySelectorContainer, null, React__default.createElement(ItemQuantitySelector, {
35037
+ quantity: quantitySelect.maxQuantity,
35038
+ onConfirm: function onConfirm(quantity) {
35039
+ quantitySelect.callback(quantity);
35040
+ setQuantitySelect({
35041
+ isOpen: false,
35042
+ maxQuantity: 1,
35043
+ callback: function callback() {}
35044
+ });
35045
+ },
35046
+ onClose: function onClose() {
35047
+ quantitySelect.callback(-1);
35048
+ setQuantitySelect({
35049
+ isOpen: false,
35050
+ maxQuantity: 1,
35051
+ callback: function callback() {}
34844
35052
  });
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
35053
  }
35054
+ })));
35055
+ };
35056
+ var ItemsContainer = /*#__PURE__*/styled.div.withConfig({
35057
+ displayName: "ItemContainer__ItemsContainer",
35058
+ componentId: "sc-15y5p9l-0"
35059
+ })(["display:flex;justify-content:center;flex-wrap:wrap;"]);
35060
+ var QuantitySelectorContainer = /*#__PURE__*/styled.div.withConfig({
35061
+ displayName: "ItemContainer__QuantitySelectorContainer",
35062
+ componentId: "sc-15y5p9l-1"
35063
+ })(["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);"]);
35064
+
35065
+ var ItemSelector = function ItemSelector(_ref) {
35066
+ var atlasIMG = _ref.atlasIMG,
35067
+ atlasJSON = _ref.atlasJSON,
35068
+ options = _ref.options,
35069
+ onClose = _ref.onClose,
35070
+ onSelect = _ref.onSelect;
35071
+ var _useState = React.useState(),
35072
+ selectedValue = _useState[0],
35073
+ setSelectedValue = _useState[1];
35074
+ var handleClick = function handleClick() {
35075
+ var element = document.querySelector("input[name='test']:checked");
35076
+ var elementValue = element.value;
35077
+ setSelectedValue(elementValue);
34892
35078
  };
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();
35079
+ React.useEffect(function () {
35080
+ if (selectedValue) {
35081
+ onSelect(selectedValue);
34904
35082
  }
34905
- };
34906
- var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
34907
- var answerIds = currentQuestion.answerIds;
34908
- if (!answerIds) {
34909
- return null;
35083
+ }, [selectedValue]);
35084
+ return React__default.createElement(DraggableContainer, {
35085
+ type: exports.RPGUIContainerTypes.Framed,
35086
+ width: "500px",
35087
+ cancelDrag: ".equipment-container-body .arrow-selector",
35088
+ onCloseButton: function onCloseButton() {
35089
+ if (onClose) {
35090
+ onClose();
35091
+ }
34910
35092
  }
34911
- var answers = onGetAnswers(answerIds);
34912
- if (!answers) {
34913
- return null;
35093
+ }, React__default.createElement("div", {
35094
+ style: {
35095
+ width: '100%'
34914
35096
  }
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));
35097
+ }, React__default.createElement(Title$2, null, 'Harvesting instruments'), React__default.createElement(Subtitle$1, null, 'Use the tool, you need it'), React__default.createElement("hr", {
35098
+ className: "golden"
35099
+ })), React__default.createElement(RadioInputScroller$1, null, options == null ? void 0 : options.map(function (option, index) {
35100
+ return React__default.createElement(RadioOptionsWrapper$1, {
35101
+ key: index
35102
+ }, React__default.createElement(SpriteAtlasWrapper$1, null, React__default.createElement(SpriteFromAtlas, {
35103
+ atlasIMG: atlasIMG,
35104
+ atlasJSON: atlasJSON,
35105
+ spriteKey: option.imageKey,
35106
+ imgScale: 3
35107
+ })), React__default.createElement("div", null, React__default.createElement("input", {
35108
+ className: "rpgui-radio",
35109
+ type: "radio",
35110
+ value: option.name,
35111
+ name: "test"
35112
+ }), React__default.createElement("label", {
35113
+ onPointerDown: handleClick,
35114
+ style: {
35115
+ display: 'flex',
35116
+ alignItems: 'center'
34930
35117
  }
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);
34941
- }
34942
- })), canShowAnswers && React__default.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
35118
+ }, option.name, " ", React__default.createElement("br", null), option.description)));
35119
+ })), React__default.createElement(ButtonWrapper$1, null, React__default.createElement(Button, {
35120
+ buttonType: exports.ButtonTypes.RPGUIButton,
35121
+ onPointerDown: onClose
35122
+ }, "Cancel"), React__default.createElement(Button, {
35123
+ buttonType: exports.ButtonTypes.RPGUIButton
35124
+ }, "Select")));
34943
35125
  };
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;}"]);
35126
+ var Title$2 = /*#__PURE__*/styled.h1.withConfig({
35127
+ displayName: "ItemSelector__Title",
35128
+ componentId: "sc-gptoxp-0"
35129
+ })(["font-size:0.6rem;color:yellow !important;"]);
35130
+ var Subtitle$1 = /*#__PURE__*/styled.h1.withConfig({
35131
+ displayName: "ItemSelector__Subtitle",
35132
+ componentId: "sc-gptoxp-1"
35133
+ })(["font-size:0.4rem;color:yellow !important;"]);
35134
+ var RadioInputScroller$1 = /*#__PURE__*/styled.div.withConfig({
35135
+ displayName: "ItemSelector__RadioInputScroller",
35136
+ componentId: "sc-gptoxp-2"
35137
+ })(["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;"]);
35138
+ var SpriteAtlasWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35139
+ displayName: "ItemSelector__SpriteAtlasWrapper",
35140
+ componentId: "sc-gptoxp-3"
35141
+ })(["margin-right:40px;"]);
35142
+ var RadioOptionsWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35143
+ displayName: "ItemSelector__RadioOptionsWrapper",
35144
+ componentId: "sc-gptoxp-4"
35145
+ })(["display:flex;align-items:stretch;margin-bottom:40px;"]);
35146
+ var ButtonWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35147
+ displayName: "ItemSelector__ButtonWrapper",
35148
+ componentId: "sc-gptoxp-5"
35149
+ })(["display:flex;justify-content:space-around;padding-top:20px;width:100%;"]);
35150
+
35151
+ var ListMenu = function ListMenu(_ref) {
35152
+ var options = _ref.options,
35153
+ onSelected = _ref.onSelected,
35154
+ x = _ref.x,
35155
+ y = _ref.y;
35156
+ return React__default.createElement(Container$g, {
35157
+ x: x,
35158
+ y: y
35159
+ }, React__default.createElement("ul", {
35160
+ className: "rpgui-list-imp",
35161
+ style: {
35162
+ overflow: 'hidden'
35163
+ }
35164
+ }, options.map(function (params, index) {
35165
+ return React__default.createElement(ListElement$1, {
35166
+ key: (params == null ? void 0 : params.id) || index,
35167
+ onPointerDown: function onPointerDown() {
35168
+ onSelected(params == null ? void 0 : params.id);
35169
+ }
35170
+ }, (params == null ? void 0 : params.text) || 'No text');
35171
+ })));
35172
+ };
35173
+ var Container$g = /*#__PURE__*/styled.div.withConfig({
35174
+ displayName: "ListMenu__Container",
35175
+ componentId: "sc-i9097t-0"
35176
+ })(["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) {
35177
+ return props.y || 0;
35178
+ }, function (props) {
35179
+ return props.x || 0;
35180
+ }, uiFonts.size.xsmall);
35181
+ var ListElement$1 = /*#__PURE__*/styled.li.withConfig({
35182
+ displayName: "ListMenu__ListElement",
35183
+ componentId: "sc-i9097t-1"
35184
+ })(["margin-right:0.5rem;"]);
34972
35185
 
34973
35186
  var ProgressBar = function ProgressBar(_ref) {
34974
35187
  var max = _ref.max,
@@ -34987,7 +35200,7 @@ var ProgressBar = function ProgressBar(_ref) {
34987
35200
  }
34988
35201
  return value * 100 / max;
34989
35202
  };
34990
- return React__default.createElement(Container$f, {
35203
+ return React__default.createElement(Container$h, {
34991
35204
  className: "rpgui-progress",
34992
35205
  "data-value": calculatePercentageValue(max, value) / 100,
34993
35206
  "data-rpguitype": "progress",
@@ -35016,7 +35229,7 @@ var TextOverlay$1 = /*#__PURE__*/styled.div.withConfig({
35016
35229
  displayName: "ProgressBar__TextOverlay",
35017
35230
  componentId: "sc-qa6fzh-1"
35018
35231
  })(["width:100%;position:relative;"]);
35019
- var Container$f = /*#__PURE__*/styled.div.withConfig({
35232
+ var Container$h = /*#__PURE__*/styled.div.withConfig({
35020
35233
  displayName: "ProgressBar__Container",
35021
35234
  componentId: "sc-qa6fzh-2"
35022
35235
  })(["display:flex;flex-direction:column;min-width:", "px;width:", "%;justify-content:start;align-items:flex-start;", ""], function (props) {
@@ -35027,7 +35240,7 @@ var Container$f = /*#__PURE__*/styled.div.withConfig({
35027
35240
  return props.style;
35028
35241
  });
35029
35242
 
35030
- var img$8 = '';
35243
+ var img$9 = '';
35031
35244
 
35032
35245
  var QuestInfo = function QuestInfo(_ref) {
35033
35246
  var quests = _ref.quests,
@@ -35069,7 +35282,7 @@ var QuestInfo = function QuestInfo(_ref) {
35069
35282
  }), React__default.createElement(QuestContainer, null, React__default.createElement(TitleContainer$1, {
35070
35283
  className: "drag-handler"
35071
35284
  }, React__default.createElement(Title$3, null, React__default.createElement(Thumbnail, {
35072
- src: quests[currentIndex].thumbnail || img$8
35285
+ src: quests[currentIndex].thumbnail || img$9
35073
35286
  }), quests[currentIndex].title), React__default.createElement(QuestSplitDiv, null, React__default.createElement("hr", {
35074
35287
  className: "golden"
35075
35288
  }))), React__default.createElement(Content, null, React__default.createElement("p", null, quests[currentIndex].description)), React__default.createElement(QuestColumn, {
@@ -35088,7 +35301,7 @@ var QuestInfo = function QuestInfo(_ref) {
35088
35301
  })))) : React__default.createElement(QuestsContainer, null, React__default.createElement(QuestContainer, null, React__default.createElement(TitleContainer$1, {
35089
35302
  className: "drag-handler"
35090
35303
  }, React__default.createElement(Title$3, null, React__default.createElement(Thumbnail, {
35091
- src: quests[0].thumbnail || img$8
35304
+ src: quests[0].thumbnail || img$9
35092
35305
  }), quests[0].title), React__default.createElement(QuestSplitDiv, null, React__default.createElement("hr", {
35093
35306
  className: "golden"
35094
35307
  }))), React__default.createElement(Content, null, React__default.createElement("p", null, quests[0].description)), React__default.createElement(QuestColumn, {
@@ -35337,7 +35550,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
35337
35550
  bgColor = _ref$bgColor === void 0 ? 'red' : _ref$bgColor,
35338
35551
  _ref$margin = _ref.margin,
35339
35552
  margin = _ref$margin === void 0 ? 20 : _ref$margin;
35340
- return React__default.createElement(Container$g, {
35553
+ return React__default.createElement(Container$i, {
35341
35554
  className: "simple-progress-bar"
35342
35555
  }, React__default.createElement(ProgressBarContainer, {
35343
35556
  margin: margin
@@ -35346,7 +35559,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
35346
35559
  bgColor: bgColor
35347
35560
  }))));
35348
35561
  };
35349
- var Container$g = /*#__PURE__*/styled.div.withConfig({
35562
+ var Container$i = /*#__PURE__*/styled.div.withConfig({
35350
35563
  displayName: "SimpleProgressBar__Container",
35351
35564
  componentId: "sc-mbeil3-0"
35352
35565
  })(["display:flex;justify-content:center;align-items:center;width:100%;"]);
@@ -35573,7 +35786,7 @@ var Spell = function Spell(_ref) {
35573
35786
  isSettingShortcut = _ref.isSettingShortcut,
35574
35787
  minMagicLevelRequired = _ref.minMagicLevelRequired;
35575
35788
  var disabled = isSettingShortcut ? charMagicLevel < minMagicLevelRequired : manaCost > charMana || charMagicLevel < minMagicLevelRequired;
35576
- return React__default.createElement(Container$h, {
35789
+ return React__default.createElement(Container$j, {
35577
35790
  disabled: disabled,
35578
35791
  onPointerDown: onPointerDown == null ? void 0 : onPointerDown.bind(null, spellKey),
35579
35792
  isSettingShortcut: isSettingShortcut && !disabled,
@@ -35586,7 +35799,7 @@ var Spell = function Spell(_ref) {
35586
35799
  className: "mana"
35587
35800
  }, manaCost)));
35588
35801
  };
35589
- var Container$h = /*#__PURE__*/styled.button.withConfig({
35802
+ var Container$j = /*#__PURE__*/styled.button.withConfig({
35590
35803
  displayName: "Spell__Container",
35591
35804
  componentId: "sc-j96fa2-0"
35592
35805
  })(["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 +35884,7 @@ var Spellbook = function Spellbook(_ref) {
35671
35884
  width: "inherit",
35672
35885
  height: "inherit",
35673
35886
  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, {
35887
+ }, React__default.createElement(Container$k, null, React__default.createElement(Title$6, null, "Learned Spells"), React__default.createElement(ShortcutsSetter, {
35675
35888
  setSettingShortcutIndex: setSettingShortcutIndex,
35676
35889
  settingShortcutIndex: settingShortcutIndex,
35677
35890
  shortcuts: shortcuts,
@@ -35703,7 +35916,7 @@ var Title$6 = /*#__PURE__*/styled.h1.withConfig({
35703
35916
  displayName: "Spellbook__Title",
35704
35917
  componentId: "sc-r02nfq-0"
35705
35918
  })(["font-size:", " !important;margin-bottom:0 !important;"], uiFonts.size.large);
35706
- var Container$i = /*#__PURE__*/styled.div.withConfig({
35919
+ var Container$k = /*#__PURE__*/styled.div.withConfig({
35707
35920
  displayName: "Spellbook__Container",
35708
35921
  componentId: "sc-r02nfq-1"
35709
35922
  })(["width:100%;height:100%;color:white;display:flex;flex-direction:column;"]);
@@ -35717,16 +35930,16 @@ var TextArea = function TextArea(_ref) {
35717
35930
  return React__default.createElement("textarea", Object.assign({}, props));
35718
35931
  };
35719
35932
 
35720
- var img$9 = '';
35933
+ var img$a = '';
35721
35934
 
35722
- var img$a = '';
35935
+ var img$b = '';
35723
35936
 
35724
- var img$b = '';
35937
+ var img$c = '';
35725
35938
 
35726
35939
  var DayNightPeriod = function DayNightPeriod(_ref) {
35727
35940
  var _periodOfDaySrcFiles;
35728
35941
  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);
35942
+ var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[shared.PeriodOfDay.Morning] = img$b, _periodOfDaySrcFiles[shared.PeriodOfDay.Afternoon] = img$a, _periodOfDaySrcFiles[shared.PeriodOfDay.Night] = img$c, _periodOfDaySrcFiles);
35730
35943
  return React__default.createElement(GifContainer, null, React__default.createElement("img", {
35731
35944
  src: periodOfDaySrcFiles[periodOfDay]
35732
35945
  }));
@@ -35736,7 +35949,7 @@ var GifContainer = /*#__PURE__*/styled.div.withConfig({
35736
35949
  componentId: "sc-10t97fw-0"
35737
35950
  })(["width:100%;img{width:67%;}"]);
35738
35951
 
35739
- var img$c = '';
35952
+ var img$d = '';
35740
35953
 
35741
35954
  var TimeWidget = function TimeWidget(_ref) {
35742
35955
  var onClose = _ref.onClose,
@@ -35751,7 +35964,7 @@ var TimeWidget = function TimeWidget(_ref) {
35751
35964
  var WidgetContainer = /*#__PURE__*/styled.div.withConfig({
35752
35965
  displayName: "TimeWidget__WidgetContainer",
35753
35966
  componentId: "sc-1ja236h-0"
35754
- })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$c);
35967
+ })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$d);
35755
35968
  var Time = /*#__PURE__*/styled.div.withConfig({
35756
35969
  displayName: "TimeWidget__Time",
35757
35970
  componentId: "sc-1ja236h-1"
@@ -35765,25 +35978,37 @@ var DayNightContainer = /*#__PURE__*/styled.div.withConfig({
35765
35978
  componentId: "sc-1ja236h-3"
35766
35979
  })(["margin-top:-0.3rem;margin-left:-0.3rem;"]);
35767
35980
 
35768
- var outerQty = 10;
35769
35981
  var TradingItemRow = function TradingItemRow(_ref) {
35770
35982
  var atlasIMG = _ref.atlasIMG,
35771
35983
  atlasJSON = _ref.atlasJSON,
35772
35984
  onQuantityChange = _ref.onQuantityChange,
35773
35985
  traderItem = _ref.traderItem,
35774
35986
  selectedQty = _ref.selectedQty;
35775
- var onLeftClick = function onLeftClick(qty) {
35776
- if (qty === void 0) {
35777
- qty = 1;
35987
+ var onLeftClick = function onLeftClick() {
35988
+ if (selectedQty > 0) {
35989
+ var newQuantity = selectedQty - 1;
35990
+ onQuantityChange(traderItem, newQuantity);
35778
35991
  }
35779
- onQuantityChange(traderItem, Math.max(0, selectedQty - qty));
35780
35992
  };
35781
- var onRightClick = function onRightClick(qty) {
35993
+ var onRightClick = function onRightClick() {
35782
35994
  var _traderItem$qty;
35783
- if (qty === void 0) {
35784
- qty = 1;
35995
+ if (selectedQty < ((_traderItem$qty = traderItem.qty) != null ? _traderItem$qty : 999)) {
35996
+ var newQuantity = selectedQty + 1;
35997
+ onQuantityChange(traderItem, newQuantity);
35998
+ }
35999
+ };
36000
+ var onLeftOutClick = function onLeftOutClick() {
36001
+ if (selectedQty >= 10) {
36002
+ var newQuantity = selectedQty - 10;
36003
+ onQuantityChange(traderItem, newQuantity);
36004
+ }
36005
+ };
36006
+ var onRightOutClick = function onRightOutClick() {
36007
+ var _traderItem$qty2;
36008
+ if (selectedQty + 10 <= ((_traderItem$qty2 = traderItem.qty) != null ? _traderItem$qty2 : 999)) {
36009
+ var newQuantity = selectedQty + 10;
36010
+ onQuantityChange(traderItem, newQuantity);
35785
36011
  }
35786
- onQuantityChange(traderItem, Math.min((_traderItem$qty = traderItem.qty) != null ? _traderItem$qty : 999, selectedQty + qty));
35787
36012
  };
35788
36013
  return React__default.createElement(ItemWrapper, null, React__default.createElement(ItemIconContainer, null, React__default.createElement(SpriteContainer$1, null, React__default.createElement(SpriteFromAtlas, {
35789
36014
  atlasIMG: atlasIMG,
@@ -35801,7 +36026,7 @@ var TradingItemRow = function TradingItemRow(_ref) {
35801
36026
  size: 32,
35802
36027
  className: "arrow-selector",
35803
36028
  direction: "left",
35804
- onPointerDown: onLeftClick.bind(null, outerQty)
36029
+ onPointerDown: onLeftOutClick
35805
36030
  }), React__default.createElement(StyledArrow, {
35806
36031
  size: 32,
35807
36032
  className: "arrow-selector",
@@ -35816,7 +36041,7 @@ var TradingItemRow = function TradingItemRow(_ref) {
35816
36041
  size: 32,
35817
36042
  className: "arrow-selector",
35818
36043
  direction: "right",
35819
- onPointerDown: onRightClick.bind(null, outerQty)
36044
+ onPointerDown: onRightOutClick
35820
36045
  })));
35821
36046
  };
35822
36047
  var StyledArrow = /*#__PURE__*/styled(SelectArrow).withConfig({
@@ -35987,230 +36212,17 @@ var Truncate = function Truncate(_ref) {
35987
36212
  var _ref$maxLines = _ref.maxLines,
35988
36213
  maxLines = _ref$maxLines === void 0 ? 1 : _ref$maxLines,
35989
36214
  children = _ref.children;
35990
- return React__default.createElement(Container$j, {
36215
+ return React__default.createElement(Container$l, {
35991
36216
  maxLines: maxLines
35992
36217
  }, children);
35993
36218
  };
35994
- var Container$j = /*#__PURE__*/styled.div.withConfig({
36219
+ var Container$l = /*#__PURE__*/styled.div.withConfig({
35995
36220
  displayName: "Truncate__Container",
35996
36221
  componentId: "sc-6x00qb-0"
35997
36222
  })(["display:-webkit-box;max-width:100%;max-height:100%;-webkit-line-clamp:", ";-webkit-box-orient:vertical;overflow:hidden;"], function (props) {
35998
36223
  return props.maxLines;
35999
36224
  });
36000
36225
 
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
36226
  exports.Button = Button;
36215
36227
  exports.CharacterSelection = CharacterSelection;
36216
36228
  exports.Chat = Chat;