@rpg-engine/long-bow 0.3.59 → 0.3.61

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 +948 -922
  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 +829 -803
  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 -245
  27. package/src/components/CraftBook/CraftBook.tsx +227 -224
  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 -129
  65. package/src/components/Shortcuts/ShortcutsSetter.tsx +132 -132
  66. package/src/components/Shortcuts/SingleShortcut.ts +62 -61
  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 -193
  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
@@ -33057,7 +33057,7 @@ var CheckButton = function CheckButton(_ref) {
33057
33057
  var SingleShortcut = /*#__PURE__*/styled.button.withConfig({
33058
33058
  displayName: "SingleShortcut",
33059
33059
  componentId: "sc-vz5ev8-0"
33060
- })(["width:3rem;height:3rem;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;position:relative;span{pointer-events:none;}.mana{position:absolute;top:-5px;right:0;font-size:0.65rem;color:", ";}.qty{position:absolute;top:-5px;right:0;font-size:0.65rem;}.magicWords{margin-top:4px;}.keyboard{position:absolute;bottom:-5px;left:0;font-size:0.65rem;color:", ";}&:hover,&:focus{background-color:", ";}&:active{background-color:", ";}&:disabled{opacity:0.5;}"], uiColors.lightGray, uiColors.darkGray, uiColors.blue, uiColors.yellow, uiColors.darkGray, uiColors.gray);
33060
+ })(["width:3rem;height:3rem;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;position:relative;span{pointer-events:none;}.mana{position:absolute;top:-5px;right:0;font-size:0.65rem;color:", ";}.qty{position:absolute;top:-5px;right:0;font-size:0.65rem;}.magicWords{margin-top:4px;}.keyboard{position:absolute;bottom:-5px;left:0;font-size:0.65rem;color:", ";}&:hover,&:focus{background-color:", ";}&:active{background-color:", ";border-color:", ";}&:disabled{opacity:0.5;}"], uiColors.lightGray, uiColors.darkGray, uiColors.blue, uiColors.yellow, uiColors.darkGray, uiColors.gray, uiColors.yellow);
33061
33061
 
33062
33062
  var CircularController = function CircularController(_ref) {
33063
33063
  var onActionClick = _ref.onActionClick,
@@ -33119,6 +33119,9 @@ var CircularController = function CircularController(_ref) {
33119
33119
  imgScale: 1.4,
33120
33120
  imgStyle: {
33121
33121
  left: '4px'
33122
+ },
33123
+ containerStyle: {
33124
+ pointerEvents: 'none'
33122
33125
  }
33123
33126
  }), React__default.createElement("span", {
33124
33127
  className: "qty"
@@ -33156,7 +33159,7 @@ var CircularController = function CircularController(_ref) {
33156
33159
  var Button$2 = /*#__PURE__*/styled.button.withConfig({
33157
33160
  displayName: "CircularController__Button",
33158
33161
  componentId: "sc-1fewf3h-0"
33159
- })(["width:4.3rem;height:4.3rem;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;position:relative;transition:background-color 0.1s;margin-top:-3rem;&.active{background-color:", ";}.sword{transform:rotate(-45deg);height:2.5rem;width:1.9rem;pointer-events:none;}"], uiColors.lightGray, uiColors.darkGray, uiColors.gray);
33162
+ })(["width:4.3rem;height:4.3rem;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;position:relative;transition:all 0.1s;margin-top:-3rem;&.active{background-color:", ";border-color:", ";}.sword{transform:rotate(-45deg);height:2.5rem;width:1.9rem;pointer-events:none;}"], uiColors.lightGray, uiColors.darkGray, uiColors.gray, uiColors.yellow);
33160
33163
  var CancelButton = /*#__PURE__*/styled(Button$2).withConfig({
33161
33164
  displayName: "CircularController__CancelButton",
33162
33165
  componentId: "sc-1fewf3h-1"
@@ -33172,7 +33175,7 @@ var ShortcutsContainer = /*#__PURE__*/styled.div.withConfig({
33172
33175
  var StyledShortcut = /*#__PURE__*/styled(SingleShortcut).withConfig({
33173
33176
  displayName: "CircularController__StyledShortcut",
33174
33177
  componentId: "sc-1fewf3h-4"
33175
- })(["width:2.5rem;height:2.5rem;transition:background-color 0.1s;.mana,.qty{font-size:0.5rem;}&:hover,&:focus,&:active{background-color:", ";}&.active{background-color:", ";}"], uiColors.lightGray, uiColors.gray);
33178
+ })(["width:2.5rem;height:2.5rem;transition:all 0.1s;.mana,.qty{font-size:0.5rem;}&:hover,&:focus,&:active{background-color:", ";}&.active{background-color:", ";border-color:", ";}"], uiColors.lightGray, uiColors.gray, uiColors.yellow);
33176
33179
 
33177
33180
  function useOutsideClick(ref, id) {
33178
33181
  React.useEffect(function () {
@@ -33456,6 +33459,12 @@ var CraftBook = function CraftBook(_ref) {
33456
33459
  onPointerDown: function onPointerDown() {
33457
33460
  handleClick(option.key);
33458
33461
  },
33462
+ onTouchEnd: function onTouchEnd() {
33463
+ setIsShown({
33464
+ show: true,
33465
+ index: index
33466
+ });
33467
+ },
33459
33468
  style: {
33460
33469
  display: 'flex',
33461
33470
  alignItems: 'center'
@@ -34136,509 +34145,374 @@ var EquipmentColumn = /*#__PURE__*/styled.div.withConfig({
34136
34145
  componentId: "sc-1wuddg2-1"
34137
34146
  })(["display:flex;justify-content:center;flex-wrap:wrap;flex-direction:column;touch-action:none;"]);
34138
34147
 
34139
- var SlotsContainer = function SlotsContainer(_ref) {
34140
- var children = _ref.children,
34141
- title = _ref.title,
34142
- onClose = _ref.onClose,
34143
- _onPositionChange = _ref.onPositionChange,
34144
- onOutsideClick = _ref.onOutsideClick,
34145
- initialPosition = _ref.initialPosition;
34146
- return React__default.createElement(DraggableContainer, {
34147
- title: title,
34148
- type: exports.RPGUIContainerTypes.Framed,
34149
- onCloseButton: function onCloseButton() {
34150
- if (onClose) {
34151
- 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
+ }
34152
34169
  }
34153
- },
34154
- width: "400px",
34155
- cancelDrag: ".item-container-body, #shortcuts_list",
34156
- onPositionChange: function onPositionChange(_ref2) {
34157
- var x = _ref2.x,
34158
- y = _ref2.y;
34159
- if (_onPositionChange) {
34160
- _onPositionChange({
34161
- x: x,
34162
- y: y
34163
- });
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
+ }
34164
34178
  }
34165
- },
34166
- onOutsideClick: onOutsideClick,
34167
- initialPosition: initialPosition
34168
- }, children);
34179
+ }, 50);
34180
+ return function () {
34181
+ clearInterval(interval);
34182
+ };
34183
+ }, [text]);
34184
+ return React__default.createElement(TextContainer, null, textState);
34169
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;"]);
34170
34190
 
34171
- (function (RangeSliderType) {
34172
- RangeSliderType["Slider"] = "rpgui-slider";
34173
- RangeSliderType["GoldSlider"] = "rpgui-slider golden";
34174
- })(exports.RangeSliderType || (exports.RangeSliderType = {}));
34175
- var RangeSlider = function RangeSlider(_ref) {
34176
- var type = _ref.type,
34177
- valueMin = _ref.valueMin,
34178
- valueMax = _ref.valueMax,
34179
- width = _ref.width,
34180
- _onChange = _ref.onChange,
34181
- value = _ref.value;
34182
- var sliderId = uuid.v4();
34183
- 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]));
34184
34215
  var _useState = React.useState(0),
34185
- left = _useState[0],
34186
- 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
+ };
34187
34234
  React.useEffect(function () {
34188
- var _containerRef$current;
34189
- var calculatedWidth = ((_containerRef$current = containerRef.current) == null ? void 0 : _containerRef$current.clientWidth) || 0;
34190
- setLeft(Math.max((value - valueMin) / (valueMax - valueMin) * (calculatedWidth - 35) + 10));
34191
- }, [value, valueMin, valueMax]);
34192
- var typeClass = type === exports.RangeSliderType.GoldSlider ? 'golden' : '';
34193
- return React__default.createElement("div", {
34194
- style: {
34195
- width: width,
34196
- 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();
34197
34248
  },
34198
- className: "rpgui-slider-container " + typeClass,
34199
- id: "rpgui-slider-" + sliderId,
34200
- ref: containerRef
34201
- }, React__default.createElement("div", {
34202
- style: {
34203
- pointerEvents: 'none'
34249
+ onStart: function onStart() {
34250
+ setShowGoNextIndicator(false);
34251
+ onStartStep && onStartStep();
34204
34252
  }
34205
- }, React__default.createElement("div", {
34206
- className: "rpgui-slider-track " + typeClass
34207
- }), React__default.createElement("div", {
34208
- className: "rpgui-slider-left-edge " + typeClass
34209
- }), React__default.createElement("div", {
34210
- className: "rpgui-slider-right-edge " + typeClass
34211
- }), React__default.createElement("div", {
34212
- className: "rpgui-slider-thumb " + typeClass,
34213
- style: {
34214
- 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();
34215
34258
  }
34216
- })), React__default.createElement(Input$1, {
34217
- type: "range",
34218
- style: {
34219
- width: width
34220
- },
34221
- min: valueMin,
34222
- max: valueMax,
34223
- onChange: function onChange(e) {
34224
- return _onChange(Number(e.target.value));
34225
- },
34226
- value: value,
34227
- className: "rpgui-cursor-point"
34228
34259
  }));
34229
34260
  };
34230
- var Input$1 = /*#__PURE__*/styled.input.withConfig({
34231
- displayName: "RangeSlider__Input",
34232
- componentId: "sc-v8mte9-0"
34233
- })(["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
+ });
34234
34272
 
34235
- var ItemQuantitySelector = function ItemQuantitySelector(_ref) {
34236
- var quantity = _ref.quantity,
34237
- 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,
34238
34297
  onClose = _ref.onClose;
34239
- var _useState = React.useState(quantity),
34240
- value = _useState[0],
34241
- setValue = _useState[1];
34242
- var inputRef = React.useRef(null);
34243
- React.useEffect(function () {
34244
- if (inputRef.current) {
34245
- inputRef.current.focus();
34246
- inputRef.current.select();
34247
- var closeSelector = function closeSelector(e) {
34248
- if (e.key === 'Escape') {
34249
- onClose();
34250
- }
34251
- };
34252
- document.addEventListener('keydown', closeSelector);
34253
- return function () {
34254
- document.removeEventListener('keydown', closeSelector);
34255
- };
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;
34256
34307
  }
34257
- return function () {};
34258
- }, []);
34259
- return React__default.createElement(StyledContainer, {
34260
- type: exports.RPGUIContainerTypes.Framed,
34261
- width: "25rem"
34262
- }, React__default.createElement(CloseButton$2, {
34263
- className: "container-close",
34264
- onPointerDown: onClose
34265
- }, "X"), React__default.createElement("h2", null, "Select quantity to move"), React__default.createElement(StyledForm, {
34266
- style: {
34267
- width: '100%'
34268
- },
34269
- onSubmit: function onSubmit(e) {
34270
- e.preventDefault();
34271
- var numberValue = Number(value);
34272
- if (Number.isNaN(numberValue)) {
34273
- return;
34274
- }
34275
- onConfirm(Math.max(1, Math.min(quantity, numberValue)));
34276
- },
34277
- noValidate: true
34278
- }, React__default.createElement(StyledInput, {
34279
- innerRef: inputRef,
34280
- placeholder: "Enter quantity",
34281
- type: "number",
34282
- min: 1,
34283
- max: quantity,
34284
- value: value,
34285
- onChange: function onChange(e) {
34286
- if (Number(e.target.value) >= quantity) {
34287
- setValue(quantity);
34288
- return;
34289
- }
34290
- setValue(e.target.value);
34291
- },
34292
- onBlur: function onBlur(e) {
34293
- var newValue = Math.max(1, Math.min(quantity, Number(e.target.value)));
34294
- setValue(newValue);
34295
- }
34296
- }), React__default.createElement(RangeSlider, {
34297
- type: exports.RangeSliderType.Slider,
34298
- valueMin: 1,
34299
- valueMax: quantity,
34300
- width: "100%",
34301
- onChange: setValue,
34302
- value: value
34303
- }), React__default.createElement(Button, {
34304
- buttonType: exports.ButtonTypes.RPGUIButton,
34305
- type: "submit"
34306
- }, "Confirm")));
34307
- };
34308
- var StyledContainer = /*#__PURE__*/styled(RPGUIContainer).withConfig({
34309
- displayName: "ItemQuantitySelector__StyledContainer",
34310
- componentId: "sc-yfdtpn-0"
34311
- })(["display:flex;flex-direction:column;align-items:center;"]);
34312
- var StyledForm = /*#__PURE__*/styled.form.withConfig({
34313
- displayName: "ItemQuantitySelector__StyledForm",
34314
- componentId: "sc-yfdtpn-1"
34315
- })(["display:flex;flex-direction:column;align-items:center;width:100%;"]);
34316
- var StyledInput = /*#__PURE__*/styled(Input).withConfig({
34317
- displayName: "ItemQuantitySelector__StyledInput",
34318
- componentId: "sc-yfdtpn-2"
34319
- })(["text-align:center;&::-webkit-outer-spin-button,&::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}&[type='number']{-moz-appearance:textfield;}"]);
34320
- var CloseButton$2 = /*#__PURE__*/styled.div.withConfig({
34321
- displayName: "ItemQuantitySelector__CloseButton",
34322
- componentId: "sc-yfdtpn-3"
34323
- })(["position:absolute;top:3px;right:0px;color:white;z-index:22;font-size:0.8rem;"]);
34324
-
34325
- var ShortcutsSetter = function ShortcutsSetter(_ref) {
34326
- var setSettingShortcutIndex = _ref.setSettingShortcutIndex,
34327
- settingShortcutIndex = _ref.settingShortcutIndex,
34328
- shortcuts = _ref.shortcuts,
34329
- removeShortcut = _ref.removeShortcut,
34330
- atlasJSON = _ref.atlasJSON,
34331
- atlasIMG = _ref.atlasIMG;
34332
- var getContent = function getContent(index) {
34333
- var _shortcuts$index, _shortcuts$index3;
34334
- if (((_shortcuts$index = shortcuts[index]) == null ? void 0 : _shortcuts$index.type) === shared.ShortcutType.Item) {
34335
- var _shortcuts$index2;
34336
- var _payload = (_shortcuts$index2 = shortcuts[index]) == null ? void 0 : _shortcuts$index2.payload;
34337
- if (!_payload) return null;
34338
- return React__default.createElement(SpriteFromAtlas, {
34339
- atlasIMG: atlasIMG,
34340
- atlasJSON: atlasJSON,
34341
- spriteKey: shared.getItemTextureKeyPath({
34342
- key: _payload.texturePath,
34343
- texturePath: _payload.texturePath,
34344
- stackQty: _payload.stackQty || 1
34345
- }, atlasJSON),
34346
- width: 32,
34347
- height: 32,
34348
- imgScale: 1.6,
34349
- imgStyle: {
34350
- left: '5px'
34351
- }
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;
34352
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;
34353
34370
  }
34354
- var payload = (_shortcuts$index3 = shortcuts[index]) == null ? void 0 : _shortcuts$index3.payload;
34355
- return React__default.createElement("span", null, payload == null ? void 0 : payload.magicWords.split(' ').map(function (word) {
34356
- return word[0];
34357
- }));
34358
34371
  };
34359
- return React__default.createElement(Container$b, null, React__default.createElement("p", null, "Shortcuts:"), React__default.createElement(List, {
34360
- id: "shortcuts_list"
34361
- }, Array.from({
34362
- length: 6
34363
- }).map(function (_, i) {
34364
- return React__default.createElement(Shortcut, {
34365
- key: i,
34366
- onPointerDown: function onPointerDown() {
34367
- removeShortcut(i);
34368
- if (!shortcuts[i] || shortcuts[i].type === shared.ShortcutType.None) setSettingShortcutIndex(i);
34369
- },
34370
- disabled: settingShortcutIndex !== -1 && settingShortcutIndex !== i,
34371
- isBeingSet: settingShortcutIndex === i
34372
- }, getContent(i));
34373
- })));
34374
- };
34375
- var Container$b = /*#__PURE__*/styled.div.withConfig({
34376
- displayName: "ShortcutsSetter__Container",
34377
- componentId: "sc-xuouuf-0"
34378
- })(["p{margin:0;margin-left:0.5rem;}"]);
34379
- var Shortcut = /*#__PURE__*/styled.button.withConfig({
34380
- displayName: "ShortcutsSetter__Shortcut",
34381
- componentId: "sc-xuouuf-1"
34382
- })(["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) {
34383
- var isBeingSet = _ref2.isBeingSet;
34384
- return isBeingSet ? uiColors.yellow : uiColors.darkGray;
34385
- }, uiColors.darkGray, uiColors.gray);
34386
- var List = /*#__PURE__*/styled.div.withConfig({
34387
- displayName: "ShortcutsSetter__List",
34388
- componentId: "sc-xuouuf-2"
34389
- })(["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;"]);
34390
-
34391
- var ItemContainer$1 = function ItemContainer(_ref) {
34392
- var itemContainer = _ref.itemContainer,
34393
- onClose = _ref.onClose,
34394
- _onMouseOver = _ref.onMouseOver,
34395
- _onSelected = _ref.onSelected,
34396
- onItemClick = _ref.onItemClick,
34397
- type = _ref.type,
34398
- atlasJSON = _ref.atlasJSON,
34399
- atlasIMG = _ref.atlasIMG,
34400
- _ref$disableContextMe = _ref.disableContextMenu,
34401
- disableContextMenu = _ref$disableContextMe === void 0 ? false : _ref$disableContextMe,
34402
- onItemDragEnd = _ref.onItemDragEnd,
34403
- onItemDragStart = _ref.onItemDragStart,
34404
- onItemPlaceDrop = _ref.onItemPlaceDrop,
34405
- _onOutsideDrop = _ref.onOutsideDrop,
34406
- checkIfItemCanBeMoved = _ref.checkIfItemCanBeMoved,
34407
- initialPosition = _ref.initialPosition,
34408
- checkIfItemShouldDragEnd = _ref.checkIfItemShouldDragEnd,
34409
- dragScale = _ref.dragScale,
34410
- shortcuts = _ref.shortcuts,
34411
- setItemShortcut = _ref.setItemShortcut,
34412
- removeShortcut = _ref.removeShortcut;
34413
- var _useState = React.useState({
34414
- isOpen: false,
34415
- maxQuantity: 1,
34416
- callback: function callback(_quantity) {}
34417
- }),
34418
- quantitySelect = _useState[0],
34419
- setQuantitySelect = _useState[1];
34420
- var _useState2 = React.useState(-1),
34421
- settingShortcutIndex = _useState2[0],
34422
- setSettingShortcutIndex = _useState2[1];
34423
- var onRenderSlots = function onRenderSlots() {
34424
- var slots = [];
34425
- for (var i = 0; i < itemContainer.slotQty; i++) {
34426
- var _itemContainer$slots;
34427
- slots.push(React__default.createElement(ItemSlot, {
34428
- isContextMenuDisabled: disableContextMenu,
34429
- key: i,
34430
- slotIndex: i,
34431
- item: ((_itemContainer$slots = itemContainer.slots) == null ? void 0 : _itemContainer$slots[i]) || null,
34432
- itemContainerType: type,
34433
- onMouseOver: function onMouseOver(event, slotIndex, item) {
34434
- if (_onMouseOver) _onMouseOver(event, slotIndex, item);
34435
- },
34436
- onPointerDown: function onPointerDown(itemType, containerType, item) {
34437
- if (settingShortcutIndex !== -1) {
34438
- setSettingShortcutIndex(-1);
34439
- if (itemType === shared.ItemType.Consumable || itemType === shared.ItemType.Tool) {
34440
- setItemShortcut == null ? void 0 : setItemShortcut(item.key, settingShortcutIndex);
34441
- }
34442
- } else if (onItemClick) onItemClick(item, itemType, containerType);
34443
- },
34444
- onSelected: function onSelected(optionId, item) {
34445
- if (_onSelected) _onSelected(optionId, item);
34446
- },
34447
- onDragStart: function onDragStart(item, slotIndex, itemContainerType) {
34448
- if (onItemDragStart) onItemDragStart(item, slotIndex, itemContainerType);
34449
- },
34450
- onDragEnd: function onDragEnd(quantity) {
34451
- if (onItemDragEnd) onItemDragEnd(quantity);
34452
- },
34453
- dragScale: dragScale,
34454
- checkIfItemCanBeMoved: checkIfItemCanBeMoved,
34455
- checkIfItemShouldDragEnd: checkIfItemShouldDragEnd,
34456
- openQuantitySelector: function openQuantitySelector(maxQuantity, callback) {
34457
- setQuantitySelect({
34458
- isOpen: true,
34459
- maxQuantity: maxQuantity,
34460
- callback: callback
34461
- });
34462
- },
34463
- onPlaceDrop: function onPlaceDrop(item, slotIndex, itemContainerType) {
34464
- if (onItemPlaceDrop) onItemPlaceDrop(item, slotIndex, itemContainerType);
34465
- },
34466
- onOutsideDrop: function onOutsideDrop(item, position) {
34467
- if (_onOutsideDrop) _onOutsideDrop(item, position);
34468
- },
34469
- atlasIMG: atlasIMG,
34470
- atlasJSON: atlasJSON,
34471
- 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;
34472
34379
  }));
34380
+ } else {
34381
+ // else, finish dialog!
34382
+ onClose();
34473
34383
  }
34474
- return slots;
34475
34384
  };
34476
- return React__default.createElement(React__default.Fragment, null, React__default.createElement(SlotsContainer, {
34477
- title: itemContainer.name || 'Container',
34478
- onClose: onClose,
34479
- initialPosition: initialPosition
34480
- }, type === shared.ItemContainerType.Inventory && shortcuts && removeShortcut && React__default.createElement(ShortcutsSetter, {
34481
- setSettingShortcutIndex: setSettingShortcutIndex,
34482
- settingShortcutIndex: settingShortcutIndex,
34483
- shortcuts: shortcuts,
34484
- removeShortcut: removeShortcut,
34485
- atlasIMG: atlasIMG,
34486
- atlasJSON: atlasJSON
34487
- }), React__default.createElement(ItemsContainer, {
34488
- className: "item-container-body"
34489
- }, onRenderSlots())), quantitySelect.isOpen && React__default.createElement(QuantitySelectorContainer, null, React__default.createElement(ItemQuantitySelector, {
34490
- quantity: quantitySelect.maxQuantity,
34491
- onConfirm: function onConfirm(quantity) {
34492
- quantitySelect.callback(quantity);
34493
- setQuantitySelect({
34494
- isOpen: false,
34495
- maxQuantity: 1,
34496
- callback: function callback() {}
34497
- });
34498
- },
34499
- onClose: function onClose() {
34500
- quantitySelect.callback(-1);
34501
- setQuantitySelect({
34502
- isOpen: false,
34503
- maxQuantity: 1,
34504
- callback: function callback() {}
34505
- });
34385
+ var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
34386
+ var answerIds = currentQuestion.answerIds;
34387
+ if (!answerIds) {
34388
+ return null;
34506
34389
  }
34507
- })));
34508
- };
34509
- var ItemsContainer = /*#__PURE__*/styled.div.withConfig({
34510
- displayName: "ItemContainer__ItemsContainer",
34511
- componentId: "sc-15y5p9l-0"
34512
- })(["display:flex;justify-content:center;flex-wrap:wrap;"]);
34513
- var QuantitySelectorContainer = /*#__PURE__*/styled.div.withConfig({
34514
- displayName: "ItemContainer__QuantitySelectorContainer",
34515
- componentId: "sc-15y5p9l-1"
34516
- })(["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);"]);
34517
-
34518
- var ItemSelector = function ItemSelector(_ref) {
34519
- var atlasIMG = _ref.atlasIMG,
34520
- atlasJSON = _ref.atlasJSON,
34521
- options = _ref.options,
34522
- onClose = _ref.onClose,
34523
- onSelect = _ref.onSelect;
34524
- var _useState = React.useState(),
34525
- selectedValue = _useState[0],
34526
- setSelectedValue = _useState[1];
34527
- var handleClick = function handleClick() {
34528
- var element = document.querySelector("input[name='test']:checked");
34529
- var elementValue = element.value;
34530
- setSelectedValue(elementValue);
34531
- };
34532
- React.useEffect(function () {
34533
- if (selectedValue) {
34534
- onSelect(selectedValue);
34390
+ var answers = onGetAnswers(answerIds);
34391
+ if (!answers) {
34392
+ return null;
34535
34393
  }
34536
- }, [selectedValue]);
34537
- return React__default.createElement(DraggableContainer, {
34538
- type: exports.RPGUIContainerTypes.Framed,
34539
- width: "500px",
34540
- cancelDrag: ".equipment-container-body .arrow-selector",
34541
- onCloseButton: function onCloseButton() {
34542
- if (onClose) {
34543
- 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));
34544
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);
34545
34420
  }
34546
- }, React__default.createElement("div", {
34547
- style: {
34548
- width: '100%'
34549
- }
34550
- }, React__default.createElement(Title$2, null, 'Harvesting instruments'), React__default.createElement(Subtitle$1, null, 'Use the tool, you need it'), React__default.createElement("hr", {
34551
- className: "golden"
34552
- })), React__default.createElement(RadioInputScroller$1, null, options == null ? void 0 : options.map(function (option, index) {
34553
- return React__default.createElement(RadioOptionsWrapper$1, {
34554
- key: index
34555
- }, React__default.createElement(SpriteAtlasWrapper$1, null, React__default.createElement(SpriteFromAtlas, {
34556
- atlasIMG: atlasIMG,
34557
- atlasJSON: atlasJSON,
34558
- spriteKey: option.imageKey,
34559
- imgScale: 3
34560
- })), React__default.createElement("div", null, React__default.createElement("input", {
34561
- className: "rpgui-radio",
34562
- type: "radio",
34563
- value: option.name,
34564
- name: "test"
34565
- }), React__default.createElement("label", {
34566
- onPointerDown: handleClick,
34567
- style: {
34568
- display: 'flex',
34569
- alignItems: 'center'
34570
- }
34571
- }, option.name, " ", React__default.createElement("br", null), option.description)));
34572
- })), React__default.createElement(ButtonWrapper$1, null, React__default.createElement(Button, {
34573
- buttonType: exports.ButtonTypes.RPGUIButton,
34574
- onPointerDown: onClose
34575
- }, "Cancel"), React__default.createElement(Button, {
34576
- buttonType: exports.ButtonTypes.RPGUIButton
34577
- }, "Select")));
34421
+ })), canShowAnswers && React__default.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
34578
34422
  };
34579
- var Title$2 = /*#__PURE__*/styled.h1.withConfig({
34580
- displayName: "ItemSelector__Title",
34581
- componentId: "sc-gptoxp-0"
34582
- })(["font-size:0.6rem;color:yellow !important;"]);
34583
- var Subtitle$1 = /*#__PURE__*/styled.h1.withConfig({
34584
- displayName: "ItemSelector__Subtitle",
34585
- componentId: "sc-gptoxp-1"
34586
- })(["font-size:0.4rem;color:yellow !important;"]);
34587
- var RadioInputScroller$1 = /*#__PURE__*/styled.div.withConfig({
34588
- displayName: "ItemSelector__RadioInputScroller",
34589
- componentId: "sc-gptoxp-2"
34590
- })(["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;"]);
34591
- var SpriteAtlasWrapper$1 = /*#__PURE__*/styled.div.withConfig({
34592
- displayName: "ItemSelector__SpriteAtlasWrapper",
34593
- componentId: "sc-gptoxp-3"
34594
- })(["margin-right:40px;"]);
34595
- var RadioOptionsWrapper$1 = /*#__PURE__*/styled.div.withConfig({
34596
- displayName: "ItemSelector__RadioOptionsWrapper",
34597
- componentId: "sc-gptoxp-4"
34598
- })(["display:flex;align-items:stretch;margin-bottom:40px;"]);
34599
- var ButtonWrapper$1 = /*#__PURE__*/styled.div.withConfig({
34600
- displayName: "ItemSelector__ButtonWrapper",
34601
- componentId: "sc-gptoxp-5"
34602
- })(["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;}"]);
34603
34451
 
34604
- var ListMenu = function ListMenu(_ref) {
34605
- var options = _ref.options,
34606
- onSelected = _ref.onSelected,
34607
- x = _ref.x,
34608
- y = _ref.y;
34609
- return React__default.createElement(Container$c, {
34610
- x: x,
34611
- y: y
34612
- }, React__default.createElement("ul", {
34613
- className: "rpgui-list-imp",
34614
- style: {
34615
- 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
+ }
34616
34480
  }
34617
- }, options.map(function (params, index) {
34618
- return React__default.createElement(ListElement$1, {
34619
- key: (params == null ? void 0 : params.id) || index,
34620
- onPointerDown: function onPointerDown() {
34621
- 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();
34622
34491
  }
34623
- }, (params == null ? void 0 : params.text) || 'No text');
34624
- })));
34492
+ }
34493
+ })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
34494
+ src: imagePath || img$8
34495
+ })))));
34625
34496
  };
34626
- var Container$c = /*#__PURE__*/styled.div.withConfig({
34627
- displayName: "ListMenu__Container",
34628
- componentId: "sc-i9097t-0"
34629
- })(["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) {
34630
- return props.y || 0;
34631
- }, function (props) {
34632
- return props.x || 0;
34633
- }, uiFonts.size.xsmall);
34634
- var ListElement$1 = /*#__PURE__*/styled.li.withConfig({
34635
- displayName: "ListMenu__ListElement",
34636
- componentId: "sc-i9097t-1"
34637
- })(["margin-right:0.5rem;"]);
34638
-
34639
- var img$6 = '';
34640
-
34641
- 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;"]);
34642
34516
 
34643
34517
  (function (ImgSide) {
34644
34518
  ImgSide["right"] = "right";
@@ -34676,7 +34550,7 @@ var NPCMultiDialog = function NPCMultiDialog(_ref) {
34676
34550
  type: exports.RPGUIContainerTypes.FramedGold,
34677
34551
  width: '50%',
34678
34552
  height: '180px'
34679
- }, 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, {
34680
34554
  flex: '70%'
34681
34555
  }, React__default.createElement(NPCDialogText, {
34682
34556
  onStartStep: function onStartStep() {
@@ -34691,14 +34565,14 @@ var NPCMultiDialog = function NPCMultiDialog(_ref) {
34691
34565
  _onClose();
34692
34566
  }
34693
34567
  }
34694
- })), React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
34695
- src: textAndTypeArray[slide].imagePath || img$6
34696
- })), 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, {
34697
34571
  right: '10.5rem',
34698
34572
  src: img$7
34699
- })), textAndTypeArray[slide].imageSide === 'left' && React__default.createElement(React__default.Fragment, null, React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
34700
- src: textAndTypeArray[slide].imagePath || img$6
34701
- })), 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, {
34702
34576
  flex: '70%'
34703
34577
  }, React__default.createElement(NPCDialogText, {
34704
34578
  onStartStep: function onStartStep() {
@@ -34713,31 +34587,31 @@ var NPCMultiDialog = function NPCMultiDialog(_ref) {
34713
34587
  _onClose();
34714
34588
  }
34715
34589
  }
34716
- })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator, {
34590
+ })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator$1, {
34717
34591
  right: '1rem',
34718
34592
  src: img$7
34719
34593
  }))), ")"));
34720
34594
  };
34721
- var Container$d = /*#__PURE__*/styled.div.withConfig({
34595
+ var Container$e = /*#__PURE__*/styled.div.withConfig({
34722
34596
  displayName: "NPCMultiDialog__Container",
34723
34597
  componentId: "sc-rvu5wg-0"
34724
34598
  })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
34725
- var TextContainer = /*#__PURE__*/styled.div.withConfig({
34599
+ var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
34726
34600
  displayName: "NPCMultiDialog__TextContainer",
34727
34601
  componentId: "sc-rvu5wg-1"
34728
34602
  })(["flex:", " 0 0;width:355px;"], function (_ref2) {
34729
34603
  var flex = _ref2.flex;
34730
34604
  return flex;
34731
34605
  });
34732
- var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
34606
+ var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
34733
34607
  displayName: "NPCMultiDialog__ThumbnailContainer",
34734
34608
  componentId: "sc-rvu5wg-2"
34735
34609
  })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
34736
- var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
34610
+ var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
34737
34611
  displayName: "NPCMultiDialog__NPCThumbnail",
34738
34612
  componentId: "sc-rvu5wg-3"
34739
34613
  })(["image-rendering:pixelated;height:128px;width:128px;"]);
34740
- var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
34614
+ var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
34741
34615
  displayName: "NPCMultiDialog__PressSpaceIndicator",
34742
34616
  componentId: "sc-rvu5wg-4"
34743
34617
  })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref3) {
@@ -34745,221 +34619,569 @@ var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
34745
34619
  return right;
34746
34620
  });
34747
34621
 
34748
- //@ts-ignore
34749
- var useEventListener = function useEventListener(type, handler, el) {
34750
- if (el === void 0) {
34751
- el = window;
34752
- }
34753
- var savedHandler = React__default.useRef();
34754
- React__default.useEffect(function () {
34755
- savedHandler.current = handler;
34756
- }, [handler]);
34757
- React__default.useEffect(function () {
34758
- //@ts-ignore
34759
- var listener = function listener(e) {
34760
- return savedHandler.current(e);
34761
- };
34762
- 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);
34763
34648
  return function () {
34764
- el.removeEventListener(type, listener);
34649
+ return document.removeEventListener('keydown', onHandleSpacePress);
34765
34650
  };
34766
- }, [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
+ })));
34767
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;"]);
34768
34685
 
34769
- var DynamicText = function DynamicText(_ref) {
34770
- var text = _ref.text,
34771
- onFinish = _ref.onFinish,
34772
- onStart = _ref.onStart;
34773
- var _useState = React.useState(''),
34774
- textState = _useState[0],
34775
- 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);
34776
34790
  React.useEffect(function () {
34777
- var i = 0;
34778
- var interval = setInterval(function () {
34779
- // on every interval, show one more character
34780
- if (i === 0) {
34781
- if (onStart) {
34782
- 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();
34783
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;
34784
34821
  }
34785
- if (i < text.length) {
34786
- setTextState(text.substring(0, i + 1));
34787
- i++;
34788
- } else {
34789
- clearInterval(interval);
34790
- if (onFinish) {
34791
- onFinish();
34792
- }
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;
34793
34836
  }
34794
- }, 50);
34795
- return function () {
34796
- clearInterval(interval);
34797
- };
34798
- }, [text]);
34799
- 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")));
34800
34854
  };
34801
- var TextContainer$1 = /*#__PURE__*/styled.p.withConfig({
34802
- displayName: "DynamicText__TextContainer",
34803
- componentId: "sc-1ggl9nd-0"
34804
- })(["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;"]);
34805
34871
 
34806
- var QuestionDialog = function QuestionDialog(_ref) {
34807
- var questions = _ref.questions,
34808
- answers = _ref.answers,
34809
- onClose = _ref.onClose;
34810
- var _useState = React.useState(questions[0]),
34811
- currentQuestion = _useState[0],
34812
- setCurrentQuestion = _useState[1];
34813
- var _useState2 = React.useState(false),
34814
- canShowAnswers = _useState2[0],
34815
- setCanShowAnswers = _useState2[1];
34816
- var onGetFirstAnswer = function onGetFirstAnswer() {
34817
- if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {
34818
- 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
+ }));
34819
35020
  }
34820
- var firstAnswerId = currentQuestion.answerIds[0];
34821
- return answers.find(function (answer) {
34822
- return answer.id === firstAnswerId;
34823
- });
35021
+ return slots;
34824
35022
  };
34825
- var _useState3 = React.useState(onGetFirstAnswer()),
34826
- currentAnswer = _useState3[0],
34827
- setCurrentAnswer = _useState3[1];
34828
- React.useEffect(function () {
34829
- setCurrentAnswer(onGetFirstAnswer());
34830
- }, [currentQuestion]);
34831
- var onGetAnswers = function onGetAnswers(answerIds) {
34832
- return answerIds.map(function (answerId) {
34833
- return answers.find(function (answer) {
34834
- 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() {}
34835
35052
  });
34836
- });
34837
- };
34838
- var onKeyPress = function onKeyPress(e) {
34839
- switch (e.key) {
34840
- case 'ArrowDown':
34841
- // select next answer, if any.
34842
- // if no next answer, select first answer
34843
- // const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(
34844
- // (answer) => answer?.id === currentAnswer!.id + 1
34845
- // );
34846
- var nextAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34847
- return (answer == null ? void 0 : answer.id) === currentAnswer.id + 1;
34848
- });
34849
- var nextAnswerID = currentQuestion.answerIds[nextAnswerIndex];
34850
- var nextAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34851
- return (answer == null ? void 0 : answer.id) === nextAnswerID;
34852
- });
34853
- setCurrentAnswer(nextAnswer || onGetFirstAnswer());
34854
- break;
34855
- case 'ArrowUp':
34856
- // select previous answer, if any.
34857
- // if no previous answer, select last answer
34858
- var previousAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34859
- return (answer == null ? void 0 : answer.id) === currentAnswer.id - 1;
34860
- });
34861
- var previousAnswerID = currentQuestion.answerIds && currentQuestion.answerIds[previousAnswerIndex];
34862
- var previousAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34863
- return (answer == null ? void 0 : answer.id) === previousAnswerID;
34864
- });
34865
- if (previousAnswer) {
34866
- setCurrentAnswer(previousAnswer);
34867
- } else {
34868
- setCurrentAnswer(onGetAnswers(currentQuestion.answerIds).pop());
34869
- }
34870
- break;
34871
- case 'Enter':
34872
- setCanShowAnswers(false);
34873
- if (!(currentAnswer != null && currentAnswer.nextQuestionId)) {
34874
- onClose();
34875
- return;
34876
- } else {
34877
- setCurrentQuestion(questions.find(function (question) {
34878
- return question.id === currentAnswer.nextQuestionId;
34879
- }));
34880
- }
34881
- break;
34882
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);
34883
35078
  };
34884
- useEventListener('keydown', onKeyPress);
34885
- var onAnswerClick = function onAnswerClick(answer) {
34886
- setCanShowAnswers(false);
34887
- if (answer.nextQuestionId) {
34888
- // if there is a next question, go to it
34889
- setCurrentQuestion(questions.find(function (question) {
34890
- return question.id === answer.nextQuestionId;
34891
- }));
34892
- } else {
34893
- // else, finish dialog!
34894
- onClose();
35079
+ React.useEffect(function () {
35080
+ if (selectedValue) {
35081
+ onSelect(selectedValue);
34895
35082
  }
34896
- };
34897
- var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
34898
- var answerIds = currentQuestion.answerIds;
34899
- if (!answerIds) {
34900
- 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
+ }
34901
35092
  }
34902
- var answers = onGetAnswers(answerIds);
34903
- if (!answers) {
34904
- return null;
35093
+ }, React__default.createElement("div", {
35094
+ style: {
35095
+ width: '100%'
34905
35096
  }
34906
- return answers.map(function (answer) {
34907
- var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
34908
- var selectedColor = isSelected ? 'yellow' : 'white';
34909
- if (answer) {
34910
- return React__default.createElement(AnswerRow, {
34911
- key: "answer_" + answer.id
34912
- }, React__default.createElement(AnswerSelectedIcon, {
34913
- color: selectedColor
34914
- }, isSelected ? 'X' : null), React__default.createElement(Answer, {
34915
- key: answer.id,
34916
- onPointerDown: function onPointerDown() {
34917
- return onAnswerClick(answer);
34918
- },
34919
- color: selectedColor
34920
- }, 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'
34921
35117
  }
34922
- return null;
34923
- });
34924
- };
34925
- return React__default.createElement(Container$e, null, React__default.createElement(QuestionContainer, null, React__default.createElement(DynamicText, {
34926
- text: currentQuestion.text,
34927
- onStart: function onStart() {
34928
- return setCanShowAnswers(false);
34929
- },
34930
- onFinish: function onFinish() {
34931
- return setCanShowAnswers(true);
34932
- }
34933
- })), 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")));
34934
35125
  };
34935
- var Container$e = /*#__PURE__*/styled.div.withConfig({
34936
- displayName: "QuestionDialog__Container",
34937
- componentId: "sc-bxc5u0-0"
34938
- })(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
34939
- var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
34940
- displayName: "QuestionDialog__QuestionContainer",
34941
- componentId: "sc-bxc5u0-1"
34942
- })(["flex:100%;width:100%;"]);
34943
- var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
34944
- displayName: "QuestionDialog__AnswersContainer",
34945
- componentId: "sc-bxc5u0-2"
34946
- })(["flex:100%;"]);
34947
- var Answer = /*#__PURE__*/styled.p.withConfig({
34948
- displayName: "QuestionDialog__Answer",
34949
- componentId: "sc-bxc5u0-3"
34950
- })(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
34951
- return props.color;
34952
- });
34953
- var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
34954
- displayName: "QuestionDialog__AnswerSelectedIcon",
34955
- componentId: "sc-bxc5u0-4"
34956
- })(["flex:5% 0 0;color:", " !important;"], function (props) {
34957
- return props.color;
34958
- });
34959
- var AnswerRow = /*#__PURE__*/styled.div.withConfig({
34960
- displayName: "QuestionDialog__AnswerRow",
34961
- componentId: "sc-bxc5u0-5"
34962
- })(["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;"]);
34963
35185
 
34964
35186
  var ProgressBar = function ProgressBar(_ref) {
34965
35187
  var max = _ref.max,
@@ -34978,7 +35200,7 @@ var ProgressBar = function ProgressBar(_ref) {
34978
35200
  }
34979
35201
  return value * 100 / max;
34980
35202
  };
34981
- return React__default.createElement(Container$f, {
35203
+ return React__default.createElement(Container$h, {
34982
35204
  className: "rpgui-progress",
34983
35205
  "data-value": calculatePercentageValue(max, value) / 100,
34984
35206
  "data-rpguitype": "progress",
@@ -35007,7 +35229,7 @@ var TextOverlay$1 = /*#__PURE__*/styled.div.withConfig({
35007
35229
  displayName: "ProgressBar__TextOverlay",
35008
35230
  componentId: "sc-qa6fzh-1"
35009
35231
  })(["width:100%;position:relative;"]);
35010
- var Container$f = /*#__PURE__*/styled.div.withConfig({
35232
+ var Container$h = /*#__PURE__*/styled.div.withConfig({
35011
35233
  displayName: "ProgressBar__Container",
35012
35234
  componentId: "sc-qa6fzh-2"
35013
35235
  })(["display:flex;flex-direction:column;min-width:", "px;width:", "%;justify-content:start;align-items:flex-start;", ""], function (props) {
@@ -35018,7 +35240,7 @@ var Container$f = /*#__PURE__*/styled.div.withConfig({
35018
35240
  return props.style;
35019
35241
  });
35020
35242
 
35021
- var img$8 = '';
35243
+ var img$9 = '';
35022
35244
 
35023
35245
  var QuestInfo = function QuestInfo(_ref) {
35024
35246
  var quests = _ref.quests,
@@ -35060,7 +35282,7 @@ var QuestInfo = function QuestInfo(_ref) {
35060
35282
  }), React__default.createElement(QuestContainer, null, React__default.createElement(TitleContainer$1, {
35061
35283
  className: "drag-handler"
35062
35284
  }, React__default.createElement(Title$3, null, React__default.createElement(Thumbnail, {
35063
- src: quests[currentIndex].thumbnail || img$8
35285
+ src: quests[currentIndex].thumbnail || img$9
35064
35286
  }), quests[currentIndex].title), React__default.createElement(QuestSplitDiv, null, React__default.createElement("hr", {
35065
35287
  className: "golden"
35066
35288
  }))), React__default.createElement(Content, null, React__default.createElement("p", null, quests[currentIndex].description)), React__default.createElement(QuestColumn, {
@@ -35079,7 +35301,7 @@ var QuestInfo = function QuestInfo(_ref) {
35079
35301
  })))) : React__default.createElement(QuestsContainer, null, React__default.createElement(QuestContainer, null, React__default.createElement(TitleContainer$1, {
35080
35302
  className: "drag-handler"
35081
35303
  }, React__default.createElement(Title$3, null, React__default.createElement(Thumbnail, {
35082
- src: quests[0].thumbnail || img$8
35304
+ src: quests[0].thumbnail || img$9
35083
35305
  }), quests[0].title), React__default.createElement(QuestSplitDiv, null, React__default.createElement("hr", {
35084
35306
  className: "golden"
35085
35307
  }))), React__default.createElement(Content, null, React__default.createElement("p", null, quests[0].description)), React__default.createElement(QuestColumn, {
@@ -35231,12 +35453,19 @@ var Shortcuts = function Shortcuts(_ref) {
35231
35453
  atlasJSON = _ref.atlasJSON,
35232
35454
  atlasIMG = _ref.atlasIMG,
35233
35455
  inventory = _ref.inventory;
35456
+ var shortcutsRefs = React.useRef([]);
35234
35457
  React.useEffect(function () {
35235
35458
  var handleKeyDown = function handleKeyDown(e) {
35236
35459
  if (isBlockedCastingByKeyboard) return;
35237
35460
  var shortcutIndex = Number(e.key) - 1;
35238
35461
  if (shortcutIndex >= 0 && shortcutIndex <= 5) {
35462
+ var _shortcutsRefs$curren;
35239
35463
  onShortcutCast(shortcutIndex);
35464
+ (_shortcutsRefs$curren = shortcutsRefs.current[shortcutIndex]) == null ? void 0 : _shortcutsRefs$curren.classList.add('active');
35465
+ setTimeout(function () {
35466
+ var _shortcutsRefs$curren2;
35467
+ (_shortcutsRefs$curren2 = shortcutsRefs.current[shortcutIndex]) == null ? void 0 : _shortcutsRefs$curren2.classList.remove('active');
35468
+ }, 150);
35240
35469
  }
35241
35470
  };
35242
35471
  window.addEventListener('keydown', handleKeyDown);
@@ -35264,10 +35493,13 @@ var Shortcuts = function Shortcuts(_ref) {
35264
35493
  var totalQty = itemsFromEquipment.reduce(function (acc, item) {
35265
35494
  return acc + ((item == null ? void 0 : item.stackQty) || 1);
35266
35495
  }, 0);
35267
- return React__default.createElement(SingleShortcut, {
35496
+ return React__default.createElement(StyledShortcut$1, {
35268
35497
  key: i,
35269
35498
  onPointerDown: onShortcutCast.bind(null, i),
35270
- disabled: false
35499
+ disabled: false,
35500
+ ref: function ref(el) {
35501
+ if (el) shortcutsRefs.current[i] = el;
35502
+ }
35271
35503
  }, _payload && React__default.createElement(SpriteFromAtlas, {
35272
35504
  atlasIMG: atlasIMG,
35273
35505
  atlasJSON: atlasJSON,
@@ -35285,10 +35517,13 @@ var Shortcuts = function Shortcuts(_ref) {
35285
35517
  }, i + 1));
35286
35518
  }
35287
35519
  var payload = (_shortcuts$i3 = shortcuts[i]) == null ? void 0 : _shortcuts$i3.payload;
35288
- return React__default.createElement(SingleShortcut, {
35520
+ return React__default.createElement(StyledShortcut$1, {
35289
35521
  key: i,
35290
35522
  onPointerDown: onShortcutCast.bind(null, i),
35291
- disabled: mana < ((_payload$manaCost = payload == null ? void 0 : payload.manaCost) != null ? _payload$manaCost : 0)
35523
+ disabled: mana < ((_payload$manaCost = payload == null ? void 0 : payload.manaCost) != null ? _payload$manaCost : 0),
35524
+ ref: function ref(el) {
35525
+ if (el) shortcutsRefs.current[i] = el;
35526
+ }
35292
35527
  }, React__default.createElement("span", {
35293
35528
  className: "mana"
35294
35529
  }, payload && payload.manaCost), React__default.createElement("span", {
@@ -35300,9 +35535,13 @@ var Shortcuts = function Shortcuts(_ref) {
35300
35535
  }, i + 1));
35301
35536
  }));
35302
35537
  };
35538
+ var StyledShortcut$1 = /*#__PURE__*/styled(SingleShortcut).withConfig({
35539
+ displayName: "Shortcuts__StyledShortcut",
35540
+ componentId: "sc-kgtsi7-0"
35541
+ })(["transition:all 0.15s;&.active{background-color:", ";border-color:", ";}"], uiColors.gray, uiColors.yellow);
35303
35542
  var List$1 = /*#__PURE__*/styled.p.withConfig({
35304
35543
  displayName: "Shortcuts__List",
35305
- componentId: "sc-kgtsi7-0"
35544
+ componentId: "sc-kgtsi7-1"
35306
35545
  })(["width:100%;display:flex;align-items:center;justify-content:center;gap:0.5rem;box-sizing:border-box;margin:0 !important;"]);
35307
35546
 
35308
35547
  var SimpleProgressBar = function SimpleProgressBar(_ref) {
@@ -35311,7 +35550,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
35311
35550
  bgColor = _ref$bgColor === void 0 ? 'red' : _ref$bgColor,
35312
35551
  _ref$margin = _ref.margin,
35313
35552
  margin = _ref$margin === void 0 ? 20 : _ref$margin;
35314
- return React__default.createElement(Container$g, {
35553
+ return React__default.createElement(Container$i, {
35315
35554
  className: "simple-progress-bar"
35316
35555
  }, React__default.createElement(ProgressBarContainer, {
35317
35556
  margin: margin
@@ -35320,7 +35559,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
35320
35559
  bgColor: bgColor
35321
35560
  }))));
35322
35561
  };
35323
- var Container$g = /*#__PURE__*/styled.div.withConfig({
35562
+ var Container$i = /*#__PURE__*/styled.div.withConfig({
35324
35563
  displayName: "SimpleProgressBar__Container",
35325
35564
  componentId: "sc-mbeil3-0"
35326
35565
  })(["display:flex;justify-content:center;align-items:center;width:100%;"]);
@@ -35547,7 +35786,7 @@ var Spell = function Spell(_ref) {
35547
35786
  isSettingShortcut = _ref.isSettingShortcut,
35548
35787
  minMagicLevelRequired = _ref.minMagicLevelRequired;
35549
35788
  var disabled = isSettingShortcut ? charMagicLevel < minMagicLevelRequired : manaCost > charMana || charMagicLevel < minMagicLevelRequired;
35550
- return React__default.createElement(Container$h, {
35789
+ return React__default.createElement(Container$j, {
35551
35790
  disabled: disabled,
35552
35791
  onPointerDown: onPointerDown == null ? void 0 : onPointerDown.bind(null, spellKey),
35553
35792
  isSettingShortcut: isSettingShortcut && !disabled,
@@ -35560,7 +35799,7 @@ var Spell = function Spell(_ref) {
35560
35799
  className: "mana"
35561
35800
  }, manaCost)));
35562
35801
  };
35563
- var Container$h = /*#__PURE__*/styled.button.withConfig({
35802
+ var Container$j = /*#__PURE__*/styled.button.withConfig({
35564
35803
  displayName: "Spell__Container",
35565
35804
  componentId: "sc-j96fa2-0"
35566
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) {
@@ -35645,7 +35884,7 @@ var Spellbook = function Spellbook(_ref) {
35645
35884
  width: "inherit",
35646
35885
  height: "inherit",
35647
35886
  cancelDrag: "#spellbook-search, #shortcuts_list, .spell"
35648
- }, 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, {
35649
35888
  setSettingShortcutIndex: setSettingShortcutIndex,
35650
35889
  settingShortcutIndex: settingShortcutIndex,
35651
35890
  shortcuts: shortcuts,
@@ -35677,7 +35916,7 @@ var Title$6 = /*#__PURE__*/styled.h1.withConfig({
35677
35916
  displayName: "Spellbook__Title",
35678
35917
  componentId: "sc-r02nfq-0"
35679
35918
  })(["font-size:", " !important;margin-bottom:0 !important;"], uiFonts.size.large);
35680
- var Container$i = /*#__PURE__*/styled.div.withConfig({
35919
+ var Container$k = /*#__PURE__*/styled.div.withConfig({
35681
35920
  displayName: "Spellbook__Container",
35682
35921
  componentId: "sc-r02nfq-1"
35683
35922
  })(["width:100%;height:100%;color:white;display:flex;flex-direction:column;"]);
@@ -35691,16 +35930,16 @@ var TextArea = function TextArea(_ref) {
35691
35930
  return React__default.createElement("textarea", Object.assign({}, props));
35692
35931
  };
35693
35932
 
35694
- var img$9 = '';
35933
+ var img$a = '';
35695
35934
 
35696
- var img$a = '';
35935
+ var img$b = '';
35697
35936
 
35698
- var img$b = '';
35937
+ var img$c = '';
35699
35938
 
35700
35939
  var DayNightPeriod = function DayNightPeriod(_ref) {
35701
35940
  var _periodOfDaySrcFiles;
35702
35941
  var periodOfDay = _ref.periodOfDay;
35703
- 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);
35704
35943
  return React__default.createElement(GifContainer, null, React__default.createElement("img", {
35705
35944
  src: periodOfDaySrcFiles[periodOfDay]
35706
35945
  }));
@@ -35710,7 +35949,7 @@ var GifContainer = /*#__PURE__*/styled.div.withConfig({
35710
35949
  componentId: "sc-10t97fw-0"
35711
35950
  })(["width:100%;img{width:67%;}"]);
35712
35951
 
35713
- var img$c = '';
35952
+ var img$d = '';
35714
35953
 
35715
35954
  var TimeWidget = function TimeWidget(_ref) {
35716
35955
  var onClose = _ref.onClose,
@@ -35725,7 +35964,7 @@ var TimeWidget = function TimeWidget(_ref) {
35725
35964
  var WidgetContainer = /*#__PURE__*/styled.div.withConfig({
35726
35965
  displayName: "TimeWidget__WidgetContainer",
35727
35966
  componentId: "sc-1ja236h-0"
35728
- })(["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);
35729
35968
  var Time = /*#__PURE__*/styled.div.withConfig({
35730
35969
  displayName: "TimeWidget__Time",
35731
35970
  componentId: "sc-1ja236h-1"
@@ -35973,230 +36212,17 @@ var Truncate = function Truncate(_ref) {
35973
36212
  var _ref$maxLines = _ref.maxLines,
35974
36213
  maxLines = _ref$maxLines === void 0 ? 1 : _ref$maxLines,
35975
36214
  children = _ref.children;
35976
- return React__default.createElement(Container$j, {
36215
+ return React__default.createElement(Container$l, {
35977
36216
  maxLines: maxLines
35978
36217
  }, children);
35979
36218
  };
35980
- var Container$j = /*#__PURE__*/styled.div.withConfig({
36219
+ var Container$l = /*#__PURE__*/styled.div.withConfig({
35981
36220
  displayName: "Truncate__Container",
35982
36221
  componentId: "sc-6x00qb-0"
35983
36222
  })(["display:-webkit-box;max-width:100%;max-height:100%;-webkit-line-clamp:", ";-webkit-box-orient:vertical;overflow:hidden;"], function (props) {
35984
36223
  return props.maxLines;
35985
36224
  });
35986
36225
 
35987
- var IS_MOBILE_OR_TABLET = /*#__PURE__*/shared.isMobileOrTablet();
35988
-
35989
- var chunkString = function chunkString(str, length) {
35990
- return str.match(new RegExp('.{1,' + length + '}', 'g'));
35991
- };
35992
-
35993
- var img$d = '';
35994
-
35995
- var NPCDialogText = function NPCDialogText(_ref) {
35996
- var text = _ref.text,
35997
- onClose = _ref.onClose,
35998
- onEndStep = _ref.onEndStep,
35999
- onStartStep = _ref.onStartStep,
36000
- type = _ref.type;
36001
- var windowSize = React.useRef([window.innerWidth, window.innerHeight]);
36002
- function maxCharacters(width) {
36003
- // Set the font size to 16 pixels
36004
- var fontSize = 11.2;
36005
- // Calculate the number of characters that can fit in one line
36006
- var charactersPerLine = Math.floor(width / 2 / fontSize);
36007
- // Calculate the number of lines that can fit in the div
36008
- var linesPerDiv = Math.floor(180 / fontSize);
36009
- // Calculate the maximum number of characters that can fit in the div
36010
- var maxCharacters = charactersPerLine * linesPerDiv;
36011
- // Return the maximum number of characters
36012
- return Math.round(maxCharacters / 5);
36013
- }
36014
- var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
36015
- var _useState = React.useState(0),
36016
- chunkIndex = _useState[0],
36017
- setChunkIndex = _useState[1];
36018
- var onHandleSpacePress = function onHandleSpacePress(event) {
36019
- if (event.code === 'Space') {
36020
- goToNextStep();
36021
- }
36022
- };
36023
- var goToNextStep = function goToNextStep() {
36024
- var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
36025
- if (hasNextChunk) {
36026
- setChunkIndex(function (prev) {
36027
- return prev + 1;
36028
- });
36029
- } else {
36030
- // if there's no more text chunks, close the dialog
36031
- onClose();
36032
- }
36033
- };
36034
- React.useEffect(function () {
36035
- document.addEventListener('keydown', onHandleSpacePress);
36036
- return function () {
36037
- return document.removeEventListener('keydown', onHandleSpacePress);
36038
- };
36039
- }, [chunkIndex]);
36040
- var _useState2 = React.useState(false),
36041
- showGoNextIndicator = _useState2[0],
36042
- setShowGoNextIndicator = _useState2[1];
36043
- return React__default.createElement(Container$k, null, React__default.createElement(DynamicText, {
36044
- text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
36045
- onFinish: function onFinish() {
36046
- setShowGoNextIndicator(true);
36047
- onEndStep && onEndStep();
36048
- },
36049
- onStart: function onStart() {
36050
- setShowGoNextIndicator(false);
36051
- onStartStep && onStartStep();
36052
- }
36053
- }), showGoNextIndicator && React__default.createElement(PressSpaceIndicator$1, {
36054
- right: type === exports.NPCDialogType.TextOnly ? '1rem' : '10.5rem',
36055
- src: IS_MOBILE_OR_TABLET ? img$d : img$7,
36056
- onPointerDown: function onPointerDown() {
36057
- goToNextStep();
36058
- }
36059
- }));
36060
- };
36061
- var Container$k = /*#__PURE__*/styled.div.withConfig({
36062
- displayName: "NPCDialogText__Container",
36063
- componentId: "sc-1cxkdh9-0"
36064
- })([""]);
36065
- var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
36066
- displayName: "NPCDialogText__PressSpaceIndicator",
36067
- componentId: "sc-1cxkdh9-1"
36068
- })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
36069
- var right = _ref2.right;
36070
- return right;
36071
- });
36072
-
36073
- (function (NPCDialogType) {
36074
- NPCDialogType["TextOnly"] = "TextOnly";
36075
- NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
36076
- })(exports.NPCDialogType || (exports.NPCDialogType = {}));
36077
- var NPCDialog = function NPCDialog(_ref) {
36078
- var text = _ref.text,
36079
- type = _ref.type,
36080
- _onClose = _ref.onClose,
36081
- imagePath = _ref.imagePath,
36082
- _ref$isQuestionDialog = _ref.isQuestionDialog,
36083
- isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
36084
- questions = _ref.questions,
36085
- answers = _ref.answers;
36086
- return React__default.createElement(RPGUIContainer, {
36087
- type: exports.RPGUIContainerTypes.FramedGold,
36088
- width: isQuestionDialog ? '600px' : '80%',
36089
- height: '180px'
36090
- }, isQuestionDialog && questions && answers ? React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer$2, {
36091
- flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
36092
- }, React__default.createElement(QuestionDialog, {
36093
- questions: questions,
36094
- answers: answers,
36095
- onClose: function onClose() {
36096
- if (_onClose) {
36097
- _onClose();
36098
- }
36099
- }
36100
- })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
36101
- src: imagePath || img$6
36102
- }))) : React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$l, null, React__default.createElement(TextContainer$2, {
36103
- flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
36104
- }, React__default.createElement(NPCDialogText, {
36105
- type: type,
36106
- text: text || 'No text provided.',
36107
- onClose: function onClose() {
36108
- if (_onClose) {
36109
- _onClose();
36110
- }
36111
- }
36112
- })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
36113
- src: imagePath || img$6
36114
- })))));
36115
- };
36116
- var Container$l = /*#__PURE__*/styled.div.withConfig({
36117
- displayName: "NPCDialog__Container",
36118
- componentId: "sc-1b4aw74-0"
36119
- })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
36120
- var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
36121
- displayName: "NPCDialog__TextContainer",
36122
- componentId: "sc-1b4aw74-1"
36123
- })(["flex:", " 0 0;width:355px;"], function (_ref2) {
36124
- var flex = _ref2.flex;
36125
- return flex;
36126
- });
36127
- var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
36128
- displayName: "NPCDialog__ThumbnailContainer",
36129
- componentId: "sc-1b4aw74-2"
36130
- })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
36131
- var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
36132
- displayName: "NPCDialog__NPCThumbnail",
36133
- componentId: "sc-1b4aw74-3"
36134
- })(["image-rendering:pixelated;height:128px;width:128px;"]);
36135
-
36136
- var HistoryDialog = function HistoryDialog(_ref) {
36137
- var backgroundImgPath = _ref.backgroundImgPath,
36138
- fullCoverBackground = _ref.fullCoverBackground,
36139
- questions = _ref.questions,
36140
- answers = _ref.answers,
36141
- text = _ref.text,
36142
- imagePath = _ref.imagePath,
36143
- textAndTypeArray = _ref.textAndTypeArray,
36144
- onClose = _ref.onClose;
36145
- var _useState = React.useState(0),
36146
- img = _useState[0],
36147
- setImage = _useState[1];
36148
- var onHandleSpacePress = function onHandleSpacePress(event) {
36149
- if (event.code === 'Space') {
36150
- if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
36151
- setImage(function (prev) {
36152
- return prev + 1;
36153
- });
36154
- } else {
36155
- // if there's no more text chunks, close the dialog
36156
- onClose();
36157
- }
36158
- }
36159
- };
36160
- React.useEffect(function () {
36161
- document.addEventListener('keydown', onHandleSpacePress);
36162
- return function () {
36163
- return document.removeEventListener('keydown', onHandleSpacePress);
36164
- };
36165
- }, [backgroundImgPath]);
36166
- return React__default.createElement(BackgroundContainer, {
36167
- imgPath: backgroundImgPath[img],
36168
- fullImg: fullCoverBackground
36169
- }, React__default.createElement(DialogContainer, null, textAndTypeArray ? React__default.createElement(NPCMultiDialog, {
36170
- textAndTypeArray: textAndTypeArray,
36171
- onClose: onClose
36172
- }) : questions && answers ? React__default.createElement(QuestionDialog, {
36173
- questions: questions,
36174
- answers: answers,
36175
- onClose: onClose
36176
- }) : text && imagePath ? React__default.createElement(NPCDialog, {
36177
- text: text,
36178
- imagePath: imagePath,
36179
- onClose: onClose,
36180
- type: exports.NPCDialogType.TextAndThumbnail
36181
- }) : React__default.createElement(NPCDialog, {
36182
- text: text,
36183
- onClose: onClose,
36184
- type: exports.NPCDialogType.TextOnly
36185
- })));
36186
- };
36187
- var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
36188
- displayName: "HistoryDialog__BackgroundContainer",
36189
- componentId: "sc-u6oe75-0"
36190
- })(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
36191
- return props.imgPath;
36192
- }, function (props) {
36193
- return props.imgPath ? 'cover' : 'auto';
36194
- });
36195
- var DialogContainer = /*#__PURE__*/styled.div.withConfig({
36196
- displayName: "HistoryDialog__DialogContainer",
36197
- componentId: "sc-u6oe75-1"
36198
- })(["display:flex;justify-content:center;padding-top:200px;"]);
36199
-
36200
36226
  exports.Button = Button;
36201
36227
  exports.CharacterSelection = CharacterSelection;
36202
36228
  exports.Chat = Chat;