@rpg-engine/long-bow 0.3.57 → 0.3.59

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 (157) hide show
  1. package/LICENSE +20 -20
  2. package/README.md +181 -181
  3. package/dist/components/CircularController/CircularController.d.ts +7 -4
  4. package/dist/components/Item/Inventory/ItemContainer.d.ts +4 -1
  5. package/dist/components/Item/Inventory/ItemSlot.d.ts +1 -0
  6. package/dist/components/Shortcuts/Shortcuts.d.ts +12 -0
  7. package/dist/components/Shortcuts/ShortcutsSetter.d.ts +12 -0
  8. package/dist/components/Shortcuts/SingleShortcut.d.ts +1 -0
  9. package/dist/components/Spellbook/Spellbook.d.ts +5 -3
  10. package/dist/components/Spellbook/constants.d.ts +3 -3
  11. package/dist/index.d.ts +1 -1
  12. package/dist/long-bow.cjs.development.js +1168 -1025
  13. package/dist/long-bow.cjs.development.js.map +1 -1
  14. package/dist/long-bow.cjs.production.min.js +1 -1
  15. package/dist/long-bow.cjs.production.min.js.map +1 -1
  16. package/dist/long-bow.esm.js +831 -687
  17. package/dist/long-bow.esm.js.map +1 -1
  18. package/dist/stories/{QuickSpells.stories.d.ts → Shortcuts.stories.d.ts} +2 -2
  19. package/package.json +100 -100
  20. package/src/components/Abstractions/SlotsContainer.tsx +45 -45
  21. package/src/components/Arrow/SelectArrow.tsx +69 -69
  22. package/src/components/Arrow/img/arrow01-left-clicked.png +0 -0
  23. package/src/components/Arrow/img/arrow01-left.png +0 -0
  24. package/src/components/Arrow/img/arrow01-right-clicked.png +0 -0
  25. package/src/components/Arrow/img/arrow01-right.png +0 -0
  26. package/src/components/Arrow/img/arrow02-left-clicked.png +0 -0
  27. package/src/components/Arrow/img/arrow02-left.png +0 -0
  28. package/src/components/Arrow/img/arrow02-right-clicked.png +0 -0
  29. package/src/components/Arrow/img/arrow02-right.png +0 -0
  30. package/src/components/Button.tsx +40 -40
  31. package/src/components/Character/CharacterSelection.tsx +96 -96
  32. package/src/components/CharacterStatus/CharacterStatus.tsx +120 -120
  33. package/src/components/Chat/Chat.tsx +195 -195
  34. package/src/components/Chatdeprecated/ChatDeprecated.tsx +198 -198
  35. package/src/components/CheckButton.tsx +65 -65
  36. package/src/components/CircularController/CircularController.tsx +245 -162
  37. package/src/components/CraftBook/CraftBook.tsx +224 -224
  38. package/src/components/CraftBook/MockItems.ts +46 -46
  39. package/src/components/DraggableContainer.tsx +153 -153
  40. package/src/components/Dropdown.tsx +90 -90
  41. package/src/components/DropdownSelectorContainer.tsx +42 -42
  42. package/src/components/Equipment/EquipmentSet.tsx +190 -190
  43. package/src/components/HistoryDialog.tsx +104 -104
  44. package/src/components/Input.tsx +15 -15
  45. package/src/components/Item/Cards/ItemTooltip.tsx +33 -33
  46. package/src/components/Item/Inventory/ErrorBoundary.tsx +42 -42
  47. package/src/components/Item/Inventory/ItemContainer.tsx +210 -175
  48. package/src/components/Item/Inventory/ItemContainerTypes.ts +6 -6
  49. package/src/components/Item/Inventory/ItemQuantitySelector.tsx +138 -138
  50. package/src/components/Item/Inventory/ItemSlot.tsx +501 -467
  51. package/src/components/Item/Inventory/itemContainerHelper.ts +156 -156
  52. package/src/components/ListMenu.tsx +63 -63
  53. package/src/components/Multitab/Tab.tsx +66 -66
  54. package/src/components/Multitab/TabBody.tsx +13 -13
  55. package/src/components/Multitab/TabsContainer.tsx +97 -97
  56. package/src/components/NPCDialog/NPCDialog.tsx +121 -121
  57. package/src/components/NPCDialog/NPCDialogText.tsx +113 -113
  58. package/src/components/NPCDialog/NPCMultiDialog.tsx +159 -159
  59. package/src/components/NPCDialog/QuestionDialog/QuestionDialog.tsx +237 -237
  60. package/src/components/ProgressBar.tsx +92 -92
  61. package/src/components/PropertySelect/PropertySelect.tsx +106 -106
  62. package/src/components/QuestInfo/QuestInfo.tsx +230 -230
  63. package/src/components/QuestList.tsx +129 -129
  64. package/src/components/RPGUIContainer.tsx +47 -47
  65. package/src/components/RPGUIForceRenderStart.tsx +45 -45
  66. package/src/components/RPGUIRoot.tsx +14 -14
  67. package/src/components/RadioButton.tsx +53 -53
  68. package/src/components/RadioInput/RadioButton.tsx +96 -96
  69. package/src/components/RadioInput/RadioInput.tsx +102 -102
  70. package/src/components/RadioInput/instruments.ts +15 -15
  71. package/src/components/RangeSlider.tsx +78 -78
  72. package/src/components/RelativeListMenu.tsx +83 -83
  73. package/src/components/ScrollList.tsx +79 -79
  74. package/src/components/Shortcuts/Shortcuts.tsx +129 -0
  75. package/src/components/Shortcuts/ShortcutsSetter.tsx +132 -0
  76. package/src/components/Shortcuts/SingleShortcut.ts +61 -0
  77. package/src/components/SimpleProgressBar.tsx +62 -62
  78. package/src/components/SkillProgressBar.tsx +133 -133
  79. package/src/components/SkillsContainer.tsx +198 -198
  80. package/src/components/Spellbook/Spell.tsx +201 -201
  81. package/src/components/Spellbook/Spellbook.tsx +150 -144
  82. package/src/components/Spellbook/constants.ts +8 -12
  83. package/src/components/Spellbook/mockSpells.ts +60 -60
  84. package/src/components/StaticBook/StaticBook.tsx +103 -103
  85. package/src/components/TextArea.tsx +11 -11
  86. package/src/components/TimeWidget/DayNightPeriod/DayNightPeriod.tsx +35 -35
  87. package/src/components/TimeWidget/TimeWidget.tsx +63 -63
  88. package/src/components/TradingMenu/TradingItemRow.tsx +193 -193
  89. package/src/components/TradingMenu/TradingMenu.tsx +203 -203
  90. package/src/components/TradingMenu/items.mock.ts +96 -96
  91. package/src/components/Truncate.tsx +25 -25
  92. package/src/components/itemSelector/ItemSelector.tsx +136 -136
  93. package/src/components/shared/Column.tsx +16 -16
  94. package/src/components/shared/Ellipsis.tsx +65 -65
  95. package/src/components/shared/SpriteFromAtlas.tsx +102 -102
  96. package/src/components/typography/DynamicText.tsx +49 -49
  97. package/src/constants/uiColors.ts +20 -20
  98. package/src/constants/uiDevices.ts +3 -3
  99. package/src/constants/uiFonts.ts +12 -12
  100. package/src/hooks/useEventListener.ts +21 -21
  101. package/src/hooks/useOutsideAlerter.ts +25 -25
  102. package/src/index.tsx +40 -40
  103. package/src/libs/StringHelpers.ts +3 -3
  104. package/src/mocks/atlas/entities/entities.json +20215 -20215
  105. package/src/mocks/atlas/icons/icons.json +735 -735
  106. package/src/mocks/atlas/items/items.json +12086 -12086
  107. package/src/mocks/equipmentSet.mocks.ts +393 -393
  108. package/src/mocks/itemContainer.mocks.ts +562 -560
  109. package/src/mocks/skills.mocks.ts +128 -128
  110. package/src/stories/Arrow.stories.tsx +26 -26
  111. package/src/stories/Button.stories.tsx +36 -36
  112. package/src/stories/CharacterSelection.stories.tsx +45 -45
  113. package/src/stories/CharacterStatus.stories.tsx +29 -29
  114. package/src/stories/Chat.stories.tsx +187 -187
  115. package/src/stories/ChatDeprecated.stories.tsx +170 -170
  116. package/src/stories/CheckButton.stories.tsx +48 -48
  117. package/src/stories/CircullarController.stories.tsx +37 -33
  118. package/src/stories/CraftBook.stories.tsx +40 -40
  119. package/src/stories/DayNightPeriod.stories.tsx +27 -27
  120. package/src/stories/DraggableContainer.stories.tsx +28 -28
  121. package/src/stories/Dropdown.stories.tsx +46 -46
  122. package/src/stories/DropdownSelectorContainer.stories.tsx +41 -41
  123. package/src/stories/EquipmentSet.stories.tsx +65 -65
  124. package/src/stories/HistoryDialog.stories.tsx +61 -61
  125. package/src/stories/ItemContainer.stories.tsx +198 -124
  126. package/src/stories/ItemQuantitySelector.stories.tsx +26 -26
  127. package/src/stories/ItemSelector.stories.tsx +77 -77
  128. package/src/stories/ItemTradingComponent.stories.tsx +35 -35
  129. package/src/stories/ListMenu.stories.tsx +56 -56
  130. package/src/stories/Multitab.stories.tsx +51 -51
  131. package/src/stories/NPCDialog.stories.tsx +130 -130
  132. package/src/stories/NPCMultiDialog.stories.tsx +71 -71
  133. package/src/stories/ProgressBar.stories.tsx +23 -23
  134. package/src/stories/PropertySelect.stories.tsx +40 -40
  135. package/src/stories/QuestInfo.stories.tsx +107 -107
  136. package/src/stories/QuestList.stories.tsx +82 -82
  137. package/src/stories/RPGUIContainers.stories.tsx +42 -42
  138. package/src/stories/RadioButton.stories.tsx +49 -49
  139. package/src/stories/RadioInput.stories.tsx +34 -34
  140. package/src/stories/RangeSlider.stories.tsx +64 -64
  141. package/src/stories/ScrollList.stories.tsx +85 -85
  142. package/src/stories/Shortcuts.stories.tsx +39 -0
  143. package/src/stories/SimpleProgressBar.stories.tsx +22 -22
  144. package/src/stories/SkillProgressBar.stories.tsx +34 -34
  145. package/src/stories/SkillsContainer.stories.tsx +35 -35
  146. package/src/stories/Spellbook.stories.tsx +104 -107
  147. package/src/stories/StaticBook.stories.tsx +32 -32
  148. package/src/stories/Text.stories.tsx +42 -42
  149. package/src/stories/TimeWidget.stories.tsx +27 -27
  150. package/src/stories/TradingMenu.stories.tsx +45 -45
  151. package/src/types/eventTypes.ts +4 -4
  152. package/src/types/index.d.ts +2 -2
  153. package/dist/components/Spellbook/QuickSpells.d.ts +0 -10
  154. package/dist/components/Spellbook/SpellbookShortcuts.d.ts +0 -10
  155. package/src/components/Spellbook/QuickSpells.tsx +0 -120
  156. package/src/components/Spellbook/SpellbookShortcuts.tsx +0 -77
  157. package/src/stories/QuickSpells.stories.tsx +0 -38
@@ -33054,62 +33054,20 @@ var CheckButton = function CheckButton(_ref) {
33054
33054
  }));
33055
33055
  };
33056
33056
 
33057
- var QuickSpells = function QuickSpells(_ref) {
33058
- var quickSpells = _ref.quickSpells,
33059
- onSpellCast = _ref.onSpellCast,
33060
- mana = _ref.mana,
33061
- _ref$isBlockedCasting = _ref.isBlockedCastingByKeyboard,
33062
- isBlockedCastingByKeyboard = _ref$isBlockedCasting === void 0 ? false : _ref$isBlockedCasting;
33063
- React.useEffect(function () {
33064
- var handleKeyDown = function handleKeyDown(e) {
33065
- if (isBlockedCastingByKeyboard) return;
33066
- var shortcutIndex = Number(e.key) - 1;
33067
- if (shortcutIndex >= 0 && shortcutIndex <= 3) {
33068
- var shortcut = quickSpells[shortcutIndex];
33069
- if (shortcut != null && shortcut.key && mana >= (shortcut == null ? void 0 : shortcut.manaCost)) {
33070
- onSpellCast(shortcut.key);
33071
- }
33072
- }
33073
- };
33074
- window.addEventListener('keydown', handleKeyDown);
33075
- return function () {
33076
- window.removeEventListener('keydown', handleKeyDown);
33077
- };
33078
- }, [quickSpells, isBlockedCastingByKeyboard]);
33079
- return React__default.createElement(List, null, Array.from({
33080
- length: 4
33081
- }).map(function (_, i) {
33082
- var _quickSpells$i, _quickSpells$i2, _quickSpells$i3, _quickSpells$i4, _quickSpells$i5;
33083
- return React__default.createElement(SpellShortcut, {
33084
- key: i,
33085
- onPointerDown: onSpellCast.bind(null, (_quickSpells$i = quickSpells[i]) == null ? void 0 : _quickSpells$i.key),
33086
- disabled: mana < ((_quickSpells$i2 = quickSpells[i]) == null ? void 0 : _quickSpells$i2.manaCost)
33087
- }, React__default.createElement("span", {
33088
- className: "mana"
33089
- }, ((_quickSpells$i3 = quickSpells[i]) == null ? void 0 : _quickSpells$i3.key) && ((_quickSpells$i4 = quickSpells[i]) == null ? void 0 : _quickSpells$i4.manaCost)), React__default.createElement("span", {
33090
- className: "magicWords"
33091
- }, (_quickSpells$i5 = quickSpells[i]) == null ? void 0 : _quickSpells$i5.magicWords.split(' ').map(function (word) {
33092
- return word[0];
33093
- })), React__default.createElement("span", {
33094
- className: "keyboard"
33095
- }, i + 1));
33096
- }));
33097
- };
33098
- var SpellShortcut = /*#__PURE__*/styled.button.withConfig({
33099
- displayName: "QuickSpells__SpellShortcut",
33100
- componentId: "sc-41yq7s-0"
33101
- })(["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:", ";}.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);
33102
- var List = /*#__PURE__*/styled.p.withConfig({
33103
- displayName: "QuickSpells__List",
33104
- componentId: "sc-41yq7s-1"
33105
- })(["width:100%;display:flex;align-items:center;justify-content:center;gap:0.5rem;box-sizing:border-box;margin:0 !important;"]);
33057
+ var SingleShortcut = /*#__PURE__*/styled.button.withConfig({
33058
+ displayName: "SingleShortcut",
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);
33106
33061
 
33107
33062
  var CircularController = function CircularController(_ref) {
33108
- var onActionPointerDown = _ref.onActionPointerDown,
33063
+ var onActionClick = _ref.onActionClick,
33109
33064
  onCancelClick = _ref.onCancelClick,
33110
- onSpellClick = _ref.onSpellClick,
33065
+ onShortcutClick = _ref.onShortcutClick,
33111
33066
  mana = _ref.mana,
33112
- spells = _ref.spells;
33067
+ shortcuts = _ref.shortcuts,
33068
+ inventory = _ref.inventory,
33069
+ atlasIMG = _ref.atlasIMG,
33070
+ atlasJSON = _ref.atlasJSON;
33113
33071
  var onTouchStart = function onTouchStart(e) {
33114
33072
  var target = e.target;
33115
33073
  target == null ? void 0 : target.classList.add('active');
@@ -33121,28 +33079,73 @@ var CircularController = function CircularController(_ref) {
33121
33079
  }, 100);
33122
33080
  action();
33123
33081
  };
33124
- return React__default.createElement(ButtonsContainer, null, React__default.createElement(SpellsContainer, null, Array.from({
33125
- length: 4
33126
- }).map(function (_, i) {
33127
- var variant = i === 0 ? 'top' : i === 3 ? 'bottom' : '';
33128
- var spell = spells[i];
33129
- var onSpellClickBinded = spell ? onSpellClick.bind(null, spell.key) : function () {};
33082
+ var renderShortcut = function renderShortcut(i) {
33083
+ var _shortcuts$i, _shortcuts$i2, _shortcuts$i4, _payload$manaCost;
33084
+ var variant = '';
33085
+ if (i === 0) variant = 'top';else if (i >= 3) variant = "bottom-" + (i - 3);
33086
+ var onShortcutClickBinded = ((_shortcuts$i = shortcuts[i]) == null ? void 0 : _shortcuts$i.type) !== shared.ShortcutType.None ? onShortcutClick.bind(null, i) : function () {};
33087
+ if (((_shortcuts$i2 = shortcuts[i]) == null ? void 0 : _shortcuts$i2.type) === shared.ShortcutType.Item) {
33088
+ var _shortcuts$i3;
33089
+ var _payload = (_shortcuts$i3 = shortcuts[i]) == null ? void 0 : _shortcuts$i3.payload;
33090
+ var itemsFromEquipment = [];
33091
+ if (inventory) {
33092
+ Object.keys(inventory.slots).forEach(function (i) {
33093
+ var _inventory$slots$inde;
33094
+ var index = parseInt(i);
33095
+ if (((_inventory$slots$inde = inventory.slots[index]) == null ? void 0 : _inventory$slots$inde.key) === (_payload == null ? void 0 : _payload.key)) {
33096
+ itemsFromEquipment.push(inventory.slots[index]);
33097
+ }
33098
+ });
33099
+ }
33100
+ var totalQty = itemsFromEquipment.reduce(function (acc, item) {
33101
+ return acc + ((item == null ? void 0 : item.stackQty) || 1);
33102
+ }, 0);
33103
+ return React__default.createElement(StyledShortcut, {
33104
+ key: i,
33105
+ onTouchStart: onTouchStart,
33106
+ onTouchEnd: onTouchEnd.bind(null, onShortcutClickBinded),
33107
+ disabled: false,
33108
+ className: variant
33109
+ }, _payload && React__default.createElement(SpriteFromAtlas, {
33110
+ atlasIMG: atlasIMG,
33111
+ atlasJSON: atlasJSON,
33112
+ spriteKey: shared.getItemTextureKeyPath({
33113
+ key: _payload.texturePath,
33114
+ texturePath: _payload.texturePath,
33115
+ stackQty: _payload.stackQty || 1
33116
+ }, atlasJSON),
33117
+ width: 32,
33118
+ height: 32,
33119
+ imgScale: 1.4,
33120
+ imgStyle: {
33121
+ left: '4px'
33122
+ }
33123
+ }), React__default.createElement("span", {
33124
+ className: "qty"
33125
+ }, totalQty));
33126
+ }
33127
+ var payload = (_shortcuts$i4 = shortcuts[i]) == null ? void 0 : _shortcuts$i4.payload;
33130
33128
  return React__default.createElement(StyledShortcut, {
33131
33129
  key: i,
33132
- disabled: mana < (spell == null ? void 0 : spell.manaCost),
33133
33130
  onTouchStart: onTouchStart,
33134
- onTouchEnd: onTouchEnd.bind(null, onSpellClickBinded),
33131
+ onTouchEnd: onTouchEnd.bind(null, onShortcutClickBinded),
33132
+ disabled: mana < ((_payload$manaCost = payload == null ? void 0 : payload.manaCost) != null ? _payload$manaCost : 0),
33135
33133
  className: variant
33136
33134
  }, React__default.createElement("span", {
33137
33135
  className: "mana"
33138
- }, (spell == null ? void 0 : spell.key) && (spell == null ? void 0 : spell.manaCost)), React__default.createElement("span", {
33136
+ }, payload && payload.manaCost), React__default.createElement("span", {
33139
33137
  className: "magicWords"
33140
- }, spell == null ? void 0 : spell.magicWords.split(' ').map(function (word) {
33138
+ }, payload == null ? void 0 : payload.magicWords.split(' ').map(function (word) {
33141
33139
  return word[0];
33142
33140
  })));
33141
+ };
33142
+ return React__default.createElement(ButtonsContainer, null, React__default.createElement(ShortcutsContainer, null, Array.from({
33143
+ length: 6
33144
+ }).map(function (_, i) {
33145
+ return renderShortcut(i);
33143
33146
  })), React__default.createElement(Button$2, {
33144
33147
  onTouchStart: onTouchStart,
33145
- onTouchEnd: onTouchEnd.bind(null, onActionPointerDown)
33148
+ onTouchEnd: onTouchEnd.bind(null, onActionClick)
33146
33149
  }, React__default.createElement("div", {
33147
33150
  className: "rpgui-icon sword"
33148
33151
  })), React__default.createElement(CancelButton, {
@@ -33153,7 +33156,7 @@ var CircularController = function CircularController(_ref) {
33153
33156
  var Button$2 = /*#__PURE__*/styled.button.withConfig({
33154
33157
  displayName: "CircularController__Button",
33155
33158
  componentId: "sc-1fewf3h-0"
33156
- })(["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;&.active{background-color:", ";}.sword{transform:rotate(-45deg);height:2.5rem;width:1.9rem;pointer-events:none;}"], uiColors.lightGray, uiColors.darkGray, uiColors.gray);
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);
33157
33160
  var CancelButton = /*#__PURE__*/styled(Button$2).withConfig({
33158
33161
  displayName: "CircularController__CancelButton",
33159
33162
  componentId: "sc-1fewf3h-1"
@@ -33162,14 +33165,14 @@ var ButtonsContainer = /*#__PURE__*/styled.div.withConfig({
33162
33165
  displayName: "CircularController__ButtonsContainer",
33163
33166
  componentId: "sc-1fewf3h-2"
33164
33167
  })(["display:flex;align-items:center;justify-content:center;gap:0.5rem;"]);
33165
- var SpellsContainer = /*#__PURE__*/styled.div.withConfig({
33166
- displayName: "CircularController__SpellsContainer",
33168
+ var ShortcutsContainer = /*#__PURE__*/styled.div.withConfig({
33169
+ displayName: "CircularController__ShortcutsContainer",
33167
33170
  componentId: "sc-1fewf3h-3"
33168
- })(["display:flex;align-items:center;justify-content:center;gap:0.4rem;flex-direction:column;.top{transform:translate(93%,25%);}.bottom{transform:translate(93%,-25%);}"]);
33169
- var StyledShortcut = /*#__PURE__*/styled(SpellShortcut).withConfig({
33171
+ })(["display:flex;align-items:center;justify-content:center;gap:0.5rem;flex-direction:column;margin-top:3rem;.top{transform:translate(93%,25%);}.bottom-0{transform:translate(93%,-25%);}.bottom-1{transform:translate(-120%,calc(-5.5rem));}.bottom-2{transform:translate(-30%,calc(-5.5rem - 25%));}"]);
33172
+ var StyledShortcut = /*#__PURE__*/styled(SingleShortcut).withConfig({
33170
33173
  displayName: "CircularController__StyledShortcut",
33171
33174
  componentId: "sc-1fewf3h-4"
33172
- })(["width:2.5rem;height:2.5rem;transition:background-color 0.1s;.mana{font-size:0.5rem;}&:hover,&:focus,&:active{background-color:", ";}&.active{background-color:", ";}"], uiColors.lightGray, uiColors.gray);
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);
33173
33176
 
33174
33177
  function useOutsideClick(ref, id) {
33175
33178
  React.useEffect(function () {
@@ -33734,7 +33737,8 @@ var ItemSlot = /*#__PURE__*/mobxReactLite.observer(function (_ref) {
33734
33737
  checkIfItemCanBeMoved = _ref.checkIfItemCanBeMoved,
33735
33738
  openQuantitySelector = _ref.openQuantitySelector,
33736
33739
  checkIfItemShouldDragEnd = _ref.checkIfItemShouldDragEnd,
33737
- dragScale = _ref.dragScale;
33740
+ dragScale = _ref.dragScale,
33741
+ isSelectingShortcut = _ref.isSelectingShortcut;
33738
33742
  var _useState = React.useState(false),
33739
33743
  isTooltipVisible = _useState[0],
33740
33744
  setTooltipVisible = _useState[1];
@@ -33898,12 +33902,14 @@ var ItemSlot = /*#__PURE__*/mobxReactLite.observer(function (_ref) {
33898
33902
  bubbles: true
33899
33903
  });
33900
33904
  (_document$elementFrom = document.elementFromPoint(clientX, clientY)) == null ? void 0 : _document$elementFrom.dispatchEvent(simulatedEvent);
33901
- }
33905
+ },
33906
+ isSelectingShortcut: isSelectingShortcut && ((item == null ? void 0 : item.type) === shared.ItemType.Consumable || (item == null ? void 0 : item.type) === shared.ItemType.Tool)
33902
33907
  }, React__default.createElement(Draggable, {
33908
+ axis: isSelectingShortcut ? 'none' : 'both',
33903
33909
  defaultClassName: item ? 'draggable' : 'empty-slot',
33904
33910
  scale: dragScale,
33905
33911
  onStop: function onStop(e, data) {
33906
- if (wasDragged && item) {
33912
+ if (wasDragged && item && !isSelectingShortcut) {
33907
33913
  var _e$target;
33908
33914
  //@ts-ignore
33909
33915
  var classes = Array.from((_e$target = e.target) == null ? void 0 : _e$target.classList);
@@ -33941,12 +33947,12 @@ var ItemSlot = /*#__PURE__*/mobxReactLite.observer(function (_ref) {
33941
33947
  }
33942
33948
  }, 100);
33943
33949
  } else if (item) {
33944
- if (!isContextMenuDisabled) setIsContextMenuVisible(!isContextMenuVisible);
33950
+ if (!isContextMenuDisabled && !isSelectingShortcut) setIsContextMenuVisible(!isContextMenuVisible);
33945
33951
  onPointerDown(item.type, containerType, item);
33946
33952
  }
33947
33953
  },
33948
33954
  onStart: function onStart() {
33949
- if (!item) {
33955
+ if (!item || isSelectingShortcut) {
33950
33956
  return;
33951
33957
  }
33952
33958
  if (onDragStart) {
@@ -34008,7 +34014,7 @@ var rarityColor = function rarityColor(item) {
34008
34014
  var Container$a = /*#__PURE__*/styled.div.withConfig({
34009
34015
  displayName: "ItemSlot__Container",
34010
34016
  componentId: "sc-l2j5ef-0"
34011
- })(["margin:0.1rem;.sprite-from-atlas-img{position:relative;top:1.5rem;left:1.5rem;border-color:", ";box-shadow:", " inset,", ";}position:relative;"], function (_ref2) {
34017
+ })(["margin:0.1rem;.sprite-from-atlas-img{position:relative;top:1.5rem;left:1.5rem;border-color:", ";box-shadow:", " inset,", ";}position:relative;&::before{content:'';position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;border-radius:12px;pointer-events:none;animation:", ";@keyframes bg-color-change{0%{background-color:rgba(255 255 255 / 0.5);}50%{background-color:transparent;}100%{background-color:rgba(255 255 255 / 0.5);}}}"], function (_ref2) {
34012
34018
  var item = _ref2.item;
34013
34019
  return rarityColor(item);
34014
34020
  }, function (_ref3) {
@@ -34017,6 +34023,9 @@ var Container$a = /*#__PURE__*/styled.div.withConfig({
34017
34023
  }, function (_ref4) {
34018
34024
  var item = _ref4.item;
34019
34025
  return "0 0 4px 3px " + rarityColor(item);
34026
+ }, function (_ref5) {
34027
+ var isSelectingShortcut = _ref5.isSelectingShortcut;
34028
+ return isSelectingShortcut ? 'bg-color-change 1s infinite' : 'none';
34020
34029
  });
34021
34030
  var ItemContainer = /*#__PURE__*/styled.div.withConfig({
34022
34031
  displayName: "ItemSlot__ItemContainer",
@@ -34127,501 +34136,533 @@ var EquipmentColumn = /*#__PURE__*/styled.div.withConfig({
34127
34136
  componentId: "sc-1wuddg2-1"
34128
34137
  })(["display:flex;justify-content:center;flex-wrap:wrap;flex-direction:column;touch-action:none;"]);
34129
34138
 
34130
- var IS_MOBILE_OR_TABLET = /*#__PURE__*/shared.isMobileOrTablet();
34131
-
34132
- var chunkString = function chunkString(str, length) {
34133
- return str.match(new RegExp('.{1,' + length + '}', 'g'));
34134
- };
34135
-
34136
- var DynamicText = function DynamicText(_ref) {
34137
- var text = _ref.text,
34138
- onFinish = _ref.onFinish,
34139
- onStart = _ref.onStart;
34140
- var _useState = React.useState(''),
34141
- textState = _useState[0],
34142
- setTextState = _useState[1];
34143
- React.useEffect(function () {
34144
- var i = 0;
34145
- var interval = setInterval(function () {
34146
- // on every interval, show one more character
34147
- if (i === 0) {
34148
- if (onStart) {
34149
- onStart();
34150
- }
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();
34151
34152
  }
34152
- if (i < text.length) {
34153
- setTextState(text.substring(0, i + 1));
34154
- i++;
34155
- } else {
34156
- clearInterval(interval);
34157
- if (onFinish) {
34158
- onFinish();
34159
- }
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
+ });
34160
34164
  }
34161
- }, 50);
34162
- return function () {
34163
- clearInterval(interval);
34164
- };
34165
- }, [text]);
34166
- return React__default.createElement(TextContainer, null, textState);
34165
+ },
34166
+ onOutsideClick: onOutsideClick,
34167
+ initialPosition: initialPosition
34168
+ }, children);
34167
34169
  };
34168
- var TextContainer = /*#__PURE__*/styled.p.withConfig({
34169
- displayName: "DynamicText__TextContainer",
34170
- componentId: "sc-1ggl9nd-0"
34171
- })(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]);
34172
34170
 
34173
- var img$6 = '';
34174
-
34175
- var img$7 = '';
34176
-
34177
- var NPCDialogText = function NPCDialogText(_ref) {
34178
- var text = _ref.text,
34179
- onClose = _ref.onClose,
34180
- onEndStep = _ref.onEndStep,
34181
- onStartStep = _ref.onStartStep,
34182
- type = _ref.type;
34183
- var windowSize = React.useRef([window.innerWidth, window.innerHeight]);
34184
- function maxCharacters(width) {
34185
- // Set the font size to 16 pixels
34186
- var fontSize = 11.2;
34187
- // Calculate the number of characters that can fit in one line
34188
- var charactersPerLine = Math.floor(width / 2 / fontSize);
34189
- // Calculate the number of lines that can fit in the div
34190
- var linesPerDiv = Math.floor(180 / fontSize);
34191
- // Calculate the maximum number of characters that can fit in the div
34192
- var maxCharacters = charactersPerLine * linesPerDiv;
34193
- // Return the maximum number of characters
34194
- return Math.round(maxCharacters / 5);
34195
- }
34196
- var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
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);
34197
34184
  var _useState = React.useState(0),
34198
- chunkIndex = _useState[0],
34199
- setChunkIndex = _useState[1];
34200
- var onHandleSpacePress = function onHandleSpacePress(event) {
34201
- if (event.code === 'Space') {
34202
- goToNextStep();
34203
- }
34204
- };
34205
- var goToNextStep = function goToNextStep() {
34206
- var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
34207
- if (hasNextChunk) {
34208
- setChunkIndex(function (prev) {
34209
- return prev + 1;
34210
- });
34211
- } else {
34212
- // if there's no more text chunks, close the dialog
34213
- onClose();
34214
- }
34215
- };
34185
+ left = _useState[0],
34186
+ setLeft = _useState[1];
34216
34187
  React.useEffect(function () {
34217
- document.addEventListener('keydown', onHandleSpacePress);
34218
- return function () {
34219
- return document.removeEventListener('keydown', onHandleSpacePress);
34220
- };
34221
- }, [chunkIndex]);
34222
- var _useState2 = React.useState(false),
34223
- showGoNextIndicator = _useState2[0],
34224
- setShowGoNextIndicator = _useState2[1];
34225
- return React__default.createElement(Container$b, null, React__default.createElement(DynamicText, {
34226
- text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
34227
- onFinish: function onFinish() {
34228
- setShowGoNextIndicator(true);
34229
- onEndStep && onEndStep();
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'
34230
34197
  },
34231
- onStart: function onStart() {
34232
- setShowGoNextIndicator(false);
34233
- onStartStep && onStartStep();
34198
+ className: "rpgui-slider-container " + typeClass,
34199
+ id: "rpgui-slider-" + sliderId,
34200
+ ref: containerRef
34201
+ }, React__default.createElement("div", {
34202
+ style: {
34203
+ pointerEvents: 'none'
34234
34204
  }
34235
- }), showGoNextIndicator && React__default.createElement(PressSpaceIndicator, {
34236
- right: type === exports.NPCDialogType.TextOnly ? '1rem' : '10.5rem',
34237
- src: IS_MOBILE_OR_TABLET ? img$6 : img$7,
34238
- onPointerDown: function onPointerDown() {
34239
- goToNextStep();
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
34240
34215
  }
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"
34241
34228
  }));
34242
34229
  };
34243
- var Container$b = /*#__PURE__*/styled.div.withConfig({
34244
- displayName: "NPCDialogText__Container",
34245
- componentId: "sc-1cxkdh9-0"
34246
- })([""]);
34247
- var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
34248
- displayName: "NPCDialogText__PressSpaceIndicator",
34249
- componentId: "sc-1cxkdh9-1"
34250
- })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
34251
- var right = _ref2.right;
34252
- return right;
34253
- });
34254
-
34255
- //@ts-ignore
34256
- var useEventListener = function useEventListener(type, handler, el) {
34257
- if (el === void 0) {
34258
- el = window;
34259
- }
34260
- var savedHandler = React__default.useRef();
34261
- React__default.useEffect(function () {
34262
- savedHandler.current = handler;
34263
- }, [handler]);
34264
- React__default.useEffect(function () {
34265
- //@ts-ignore
34266
- var listener = function listener(e) {
34267
- return savedHandler.current(e);
34268
- };
34269
- el.addEventListener(type, listener);
34270
- return function () {
34271
- el.removeEventListener(type, listener);
34272
- };
34273
- }, [type, el]);
34274
- };
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;"]);
34275
34234
 
34276
- var QuestionDialog = function QuestionDialog(_ref) {
34277
- var questions = _ref.questions,
34278
- answers = _ref.answers,
34235
+ var ItemQuantitySelector = function ItemQuantitySelector(_ref) {
34236
+ var quantity = _ref.quantity,
34237
+ onConfirm = _ref.onConfirm,
34279
34238
  onClose = _ref.onClose;
34280
- var _useState = React.useState(questions[0]),
34281
- currentQuestion = _useState[0],
34282
- setCurrentQuestion = _useState[1];
34283
- var _useState2 = React.useState(false),
34284
- canShowAnswers = _useState2[0],
34285
- setCanShowAnswers = _useState2[1];
34286
- var onGetFirstAnswer = function onGetFirstAnswer() {
34287
- if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {
34288
- return null;
34289
- }
34290
- var firstAnswerId = currentQuestion.answerIds[0];
34291
- return answers.find(function (answer) {
34292
- return answer.id === firstAnswerId;
34293
- });
34294
- };
34295
- var _useState3 = React.useState(onGetFirstAnswer()),
34296
- currentAnswer = _useState3[0],
34297
- setCurrentAnswer = _useState3[1];
34239
+ var _useState = React.useState(quantity),
34240
+ value = _useState[0],
34241
+ setValue = _useState[1];
34242
+ var inputRef = React.useRef(null);
34298
34243
  React.useEffect(function () {
34299
- setCurrentAnswer(onGetFirstAnswer());
34300
- }, [currentQuestion]);
34301
- var onGetAnswers = function onGetAnswers(answerIds) {
34302
- return answerIds.map(function (answerId) {
34303
- return answers.find(function (answer) {
34304
- return answer.id === answerId;
34305
- });
34306
- });
34307
- };
34308
- var onKeyPress = function onKeyPress(e) {
34309
- switch (e.key) {
34310
- case 'ArrowDown':
34311
- // select next answer, if any.
34312
- // if no next answer, select first answer
34313
- // const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(
34314
- // (answer) => answer?.id === currentAnswer!.id + 1
34315
- // );
34316
- var nextAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34317
- return (answer == null ? void 0 : answer.id) === currentAnswer.id + 1;
34318
- });
34319
- var nextAnswerID = currentQuestion.answerIds[nextAnswerIndex];
34320
- var nextAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34321
- return (answer == null ? void 0 : answer.id) === nextAnswerID;
34322
- });
34323
- setCurrentAnswer(nextAnswer || onGetFirstAnswer());
34324
- break;
34325
- case 'ArrowUp':
34326
- // select previous answer, if any.
34327
- // if no previous answer, select last answer
34328
- var previousAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34329
- return (answer == null ? void 0 : answer.id) === currentAnswer.id - 1;
34330
- });
34331
- var previousAnswerID = currentQuestion.answerIds && currentQuestion.answerIds[previousAnswerIndex];
34332
- var previousAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34333
- return (answer == null ? void 0 : answer.id) === previousAnswerID;
34334
- });
34335
- if (previousAnswer) {
34336
- setCurrentAnswer(previousAnswer);
34337
- } else {
34338
- setCurrentAnswer(onGetAnswers(currentQuestion.answerIds).pop());
34339
- }
34340
- break;
34341
- case 'Enter':
34342
- setCanShowAnswers(false);
34343
- if (!(currentAnswer != null && currentAnswer.nextQuestionId)) {
34244
+ if (inputRef.current) {
34245
+ inputRef.current.focus();
34246
+ inputRef.current.select();
34247
+ var closeSelector = function closeSelector(e) {
34248
+ if (e.key === 'Escape') {
34344
34249
  onClose();
34345
- return;
34346
- } else {
34347
- setCurrentQuestion(questions.find(function (question) {
34348
- return question.id === currentAnswer.nextQuestionId;
34349
- }));
34350
34250
  }
34351
- break;
34352
- }
34353
- };
34354
- useEventListener('keydown', onKeyPress);
34355
- var onAnswerClick = function onAnswerClick(answer) {
34356
- setCanShowAnswers(false);
34357
- if (answer.nextQuestionId) {
34358
- // if there is a next question, go to it
34359
- setCurrentQuestion(questions.find(function (question) {
34360
- return question.id === answer.nextQuestionId;
34361
- }));
34362
- } else {
34363
- // else, finish dialog!
34364
- onClose();
34365
- }
34366
- };
34367
- var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
34368
- var answerIds = currentQuestion.answerIds;
34369
- if (!answerIds) {
34370
- return null;
34371
- }
34372
- var answers = onGetAnswers(answerIds);
34373
- if (!answers) {
34374
- return null;
34251
+ };
34252
+ document.addEventListener('keydown', closeSelector);
34253
+ return function () {
34254
+ document.removeEventListener('keydown', closeSelector);
34255
+ };
34375
34256
  }
34376
- return answers.map(function (answer) {
34377
- var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
34378
- var selectedColor = isSelected ? 'yellow' : 'white';
34379
- if (answer) {
34380
- return React__default.createElement(AnswerRow, {
34381
- key: "answer_" + answer.id
34382
- }, React__default.createElement(AnswerSelectedIcon, {
34383
- color: selectedColor
34384
- }, isSelected ? 'X' : null), React__default.createElement(Answer, {
34385
- key: answer.id,
34386
- onPointerDown: function onPointerDown() {
34387
- return onAnswerClick(answer);
34388
- },
34389
- color: selectedColor
34390
- }, answer.text));
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;
34391
34274
  }
34392
- return null;
34393
- });
34394
- };
34395
- return React__default.createElement(Container$c, null, React__default.createElement(QuestionContainer, null, React__default.createElement(DynamicText, {
34396
- text: currentQuestion.text,
34397
- onStart: function onStart() {
34398
- return setCanShowAnswers(false);
34275
+ onConfirm(Math.max(1, Math.min(quantity, numberValue)));
34399
34276
  },
34400
- onFinish: function onFinish() {
34401
- return setCanShowAnswers(true);
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);
34402
34295
  }
34403
- })), canShowAnswers && React__default.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
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")));
34404
34307
  };
34405
- var Container$c = /*#__PURE__*/styled.div.withConfig({
34406
- displayName: "QuestionDialog__Container",
34407
- componentId: "sc-bxc5u0-0"
34408
- })(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
34409
- var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
34410
- displayName: "QuestionDialog__QuestionContainer",
34411
- componentId: "sc-bxc5u0-1"
34412
- })(["flex:100%;width:100%;"]);
34413
- var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
34414
- displayName: "QuestionDialog__AnswersContainer",
34415
- componentId: "sc-bxc5u0-2"
34416
- })(["flex:100%;"]);
34417
- var Answer = /*#__PURE__*/styled.p.withConfig({
34418
- displayName: "QuestionDialog__Answer",
34419
- componentId: "sc-bxc5u0-3"
34420
- })(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
34421
- return props.color;
34422
- });
34423
- var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
34424
- displayName: "QuestionDialog__AnswerSelectedIcon",
34425
- componentId: "sc-bxc5u0-4"
34426
- })(["flex:5% 0 0;color:", " !important;"], function (props) {
34427
- return props.color;
34428
- });
34429
- var AnswerRow = /*#__PURE__*/styled.div.withConfig({
34430
- displayName: "QuestionDialog__AnswerRow",
34431
- componentId: "sc-bxc5u0-5"
34432
- })(["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;}"]);
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;"]);
34433
34324
 
34434
- var img$8 = '';
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
+ }
34352
+ });
34353
+ }
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
+ };
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;"]);
34435
34390
 
34436
- (function (NPCDialogType) {
34437
- NPCDialogType["TextOnly"] = "TextOnly";
34438
- NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
34439
- })(exports.NPCDialogType || (exports.NPCDialogType = {}));
34440
- var NPCDialog = function NPCDialog(_ref) {
34441
- var text = _ref.text,
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,
34442
34397
  type = _ref.type,
34443
- _onClose = _ref.onClose,
34444
- imagePath = _ref.imagePath,
34445
- _ref$isQuestionDialog = _ref.isQuestionDialog,
34446
- isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
34447
- questions = _ref.questions,
34448
- answers = _ref.answers;
34449
- return React__default.createElement(RPGUIContainer, {
34450
- type: exports.RPGUIContainerTypes.FramedGold,
34451
- width: isQuestionDialog ? '600px' : '80%',
34452
- height: '180px'
34453
- }, isQuestionDialog && questions && answers ? React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer$1, {
34454
- flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
34455
- }, React__default.createElement(QuestionDialog, {
34456
- questions: questions,
34457
- answers: answers,
34458
- onClose: function onClose() {
34459
- if (_onClose) {
34460
- _onClose();
34461
- }
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
34472
+ }));
34462
34473
  }
34463
- })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
34464
- src: imagePath || img$8
34465
- }))) : React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$d, null, React__default.createElement(TextContainer$1, {
34466
- flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
34467
- }, React__default.createElement(NPCDialogText, {
34468
- type: type,
34469
- text: text || 'No text provided.',
34474
+ return slots;
34475
+ };
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
+ },
34470
34499
  onClose: function onClose() {
34471
- if (_onClose) {
34472
- _onClose();
34473
- }
34500
+ quantitySelect.callback(-1);
34501
+ setQuantitySelect({
34502
+ isOpen: false,
34503
+ maxQuantity: 1,
34504
+ callback: function callback() {}
34505
+ });
34474
34506
  }
34475
- })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
34476
- src: imagePath || img$8
34477
- })))));
34507
+ })));
34478
34508
  };
34479
- var Container$d = /*#__PURE__*/styled.div.withConfig({
34480
- displayName: "NPCDialog__Container",
34481
- componentId: "sc-1b4aw74-0"
34482
- })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
34483
- var TextContainer$1 = /*#__PURE__*/styled.div.withConfig({
34484
- displayName: "NPCDialog__TextContainer",
34485
- componentId: "sc-1b4aw74-1"
34486
- })(["flex:", " 0 0;width:355px;"], function (_ref2) {
34487
- var flex = _ref2.flex;
34488
- return flex;
34489
- });
34490
- var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
34491
- displayName: "NPCDialog__ThumbnailContainer",
34492
- componentId: "sc-1b4aw74-2"
34493
- })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
34494
- var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
34495
- displayName: "NPCDialog__NPCThumbnail",
34496
- componentId: "sc-1b4aw74-3"
34497
- })(["image-rendering:pixelated;height:128px;width:128px;"]);
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);"]);
34498
34517
 
34499
- (function (ImgSide) {
34500
- ImgSide["right"] = "right";
34501
- ImgSide["left"] = "left";
34502
- })(exports.ImgSide || (exports.ImgSide = {}));
34503
- var NPCMultiDialog = function NPCMultiDialog(_ref) {
34504
- var _textAndTypeArray$sli;
34505
- var _onClose = _ref.onClose,
34506
- textAndTypeArray = _ref.textAndTypeArray;
34507
- var _useState = React.useState(false),
34508
- showGoNextIndicator = _useState[0],
34509
- setShowGoNextIndicator = _useState[1];
34510
- var _useState2 = React.useState(0),
34511
- slide = _useState2[0],
34512
- setSlide = _useState2[1];
34513
- var onHandleSpacePress = function onHandleSpacePress(event) {
34514
- if (event.code === 'Space') {
34515
- if (slide < (textAndTypeArray == null ? void 0 : textAndTypeArray.length) - 1) {
34516
- setSlide(function (prev) {
34517
- return prev + 1;
34518
- });
34519
- } else {
34520
- // if there's no more text chunks, close the dialog
34521
- _onClose();
34522
- }
34523
- }
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);
34524
34531
  };
34525
34532
  React.useEffect(function () {
34526
- document.addEventListener('keydown', onHandleSpacePress);
34527
- return function () {
34528
- return document.removeEventListener('keydown', onHandleSpacePress);
34529
- };
34530
- }, [slide]);
34531
- return React__default.createElement(RPGUIContainer, {
34532
- type: exports.RPGUIContainerTypes.FramedGold,
34533
- width: '50%',
34534
- height: '180px'
34535
- }, 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, {
34536
- flex: '70%'
34537
- }, React__default.createElement(NPCDialogText, {
34538
- onStartStep: function onStartStep() {
34539
- return setShowGoNextIndicator(false);
34540
- },
34541
- onEndStep: function onEndStep() {
34542
- return setShowGoNextIndicator(true);
34543
- },
34544
- text: textAndTypeArray[slide].text || 'No text provided.',
34545
- onClose: function onClose() {
34546
- if (_onClose) {
34547
- _onClose();
34548
- }
34533
+ if (selectedValue) {
34534
+ onSelect(selectedValue);
34549
34535
  }
34550
- })), React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
34551
- src: textAndTypeArray[slide].imagePath || img$8
34552
- })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator$1, {
34553
- right: '10.5rem',
34554
- src: img$7
34555
- })), textAndTypeArray[slide].imageSide === 'left' && React__default.createElement(React__default.Fragment, null, React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
34556
- src: textAndTypeArray[slide].imagePath || img$8
34557
- })), React__default.createElement(TextContainer$2, {
34558
- flex: '70%'
34559
- }, React__default.createElement(NPCDialogText, {
34560
- onStartStep: function onStartStep() {
34561
- return setShowGoNextIndicator(false);
34562
- },
34563
- onEndStep: function onEndStep() {
34564
- return setShowGoNextIndicator(true);
34565
- },
34566
- text: textAndTypeArray[slide].text || 'No text provided.',
34567
- onClose: function onClose() {
34568
- if (_onClose) {
34569
- _onClose();
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();
34570
34544
  }
34571
34545
  }
34572
- })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator$1, {
34573
- right: '1rem',
34574
- src: img$7
34575
- }))), ")"));
34576
- };
34577
- var Container$e = /*#__PURE__*/styled.div.withConfig({
34578
- displayName: "NPCMultiDialog__Container",
34579
- componentId: "sc-rvu5wg-0"
34580
- })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
34581
- var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
34582
- displayName: "NPCMultiDialog__TextContainer",
34583
- componentId: "sc-rvu5wg-1"
34584
- })(["flex:", " 0 0;width:355px;"], function (_ref2) {
34585
- var flex = _ref2.flex;
34586
- return flex;
34587
- });
34588
- var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
34589
- displayName: "NPCMultiDialog__ThumbnailContainer",
34590
- componentId: "sc-rvu5wg-2"
34591
- })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
34592
- var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
34593
- displayName: "NPCMultiDialog__NPCThumbnail",
34594
- componentId: "sc-rvu5wg-3"
34595
- })(["image-rendering:pixelated;height:128px;width:128px;"]);
34596
- var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
34597
- displayName: "NPCMultiDialog__PressSpaceIndicator",
34598
- componentId: "sc-rvu5wg-4"
34599
- })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref3) {
34600
- var right = _ref3.right;
34601
- return right;
34602
- });
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")));
34578
+ };
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%;"]);
34603
34603
 
34604
- var HistoryDialog = function HistoryDialog(_ref) {
34605
- var backgroundImgPath = _ref.backgroundImgPath,
34606
- fullCoverBackground = _ref.fullCoverBackground,
34607
- questions = _ref.questions,
34608
- answers = _ref.answers,
34609
- text = _ref.text,
34610
- imagePath = _ref.imagePath,
34611
- textAndTypeArray = _ref.textAndTypeArray,
34612
- onClose = _ref.onClose;
34613
- var _useState = React.useState(0),
34614
- img = _useState[0],
34615
- setImage = _useState[1];
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'
34616
+ }
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);
34622
+ }
34623
+ }, (params == null ? void 0 : params.text) || 'No text');
34624
+ })));
34625
+ };
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 = '';
34642
+
34643
+ (function (ImgSide) {
34644
+ ImgSide["right"] = "right";
34645
+ ImgSide["left"] = "left";
34646
+ })(exports.ImgSide || (exports.ImgSide = {}));
34647
+ var NPCMultiDialog = function NPCMultiDialog(_ref) {
34648
+ var _textAndTypeArray$sli;
34649
+ var _onClose = _ref.onClose,
34650
+ textAndTypeArray = _ref.textAndTypeArray;
34651
+ var _useState = React.useState(false),
34652
+ showGoNextIndicator = _useState[0],
34653
+ setShowGoNextIndicator = _useState[1];
34654
+ var _useState2 = React.useState(0),
34655
+ slide = _useState2[0],
34656
+ setSlide = _useState2[1];
34616
34657
  var onHandleSpacePress = function onHandleSpacePress(event) {
34617
34658
  if (event.code === 'Space') {
34618
- if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
34619
- setImage(function (prev) {
34659
+ if (slide < (textAndTypeArray == null ? void 0 : textAndTypeArray.length) - 1) {
34660
+ setSlide(function (prev) {
34620
34661
  return prev + 1;
34621
34662
  });
34622
34663
  } else {
34623
34664
  // if there's no more text chunks, close the dialog
34624
- onClose();
34665
+ _onClose();
34625
34666
  }
34626
34667
  }
34627
34668
  };
@@ -34630,455 +34671,295 @@ var HistoryDialog = function HistoryDialog(_ref) {
34630
34671
  return function () {
34631
34672
  return document.removeEventListener('keydown', onHandleSpacePress);
34632
34673
  };
34633
- }, [backgroundImgPath]);
34634
- return React__default.createElement(BackgroundContainer, {
34635
- imgPath: backgroundImgPath[img],
34636
- fullImg: fullCoverBackground
34637
- }, React__default.createElement(DialogContainer, null, textAndTypeArray ? React__default.createElement(NPCMultiDialog, {
34638
- textAndTypeArray: textAndTypeArray,
34639
- onClose: onClose
34640
- }) : questions && answers ? React__default.createElement(QuestionDialog, {
34641
- questions: questions,
34642
- answers: answers,
34643
- onClose: onClose
34644
- }) : text && imagePath ? React__default.createElement(NPCDialog, {
34645
- text: text,
34646
- imagePath: imagePath,
34647
- onClose: onClose,
34648
- type: exports.NPCDialogType.TextAndThumbnail
34649
- }) : React__default.createElement(NPCDialog, {
34650
- text: text,
34651
- onClose: onClose,
34652
- type: exports.NPCDialogType.TextOnly
34653
- })));
34654
- };
34655
- var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
34656
- displayName: "HistoryDialog__BackgroundContainer",
34657
- componentId: "sc-u6oe75-0"
34658
- })(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
34659
- return props.imgPath;
34660
- }, function (props) {
34661
- return props.imgPath ? 'cover' : 'auto';
34662
- });
34663
- var DialogContainer = /*#__PURE__*/styled.div.withConfig({
34664
- displayName: "HistoryDialog__DialogContainer",
34665
- componentId: "sc-u6oe75-1"
34666
- })(["display:flex;justify-content:center;padding-top:200px;"]);
34667
-
34668
- var SlotsContainer = function SlotsContainer(_ref) {
34669
- var children = _ref.children,
34670
- title = _ref.title,
34671
- onClose = _ref.onClose,
34672
- _onPositionChange = _ref.onPositionChange,
34673
- onOutsideClick = _ref.onOutsideClick,
34674
- initialPosition = _ref.initialPosition;
34675
- return React__default.createElement(DraggableContainer, {
34676
- title: title,
34677
- type: exports.RPGUIContainerTypes.Framed,
34678
- onCloseButton: function onCloseButton() {
34679
- if (onClose) {
34680
- onClose();
34681
- }
34674
+ }, [slide]);
34675
+ return React__default.createElement(RPGUIContainer, {
34676
+ type: exports.RPGUIContainerTypes.FramedGold,
34677
+ width: '50%',
34678
+ 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, {
34680
+ flex: '70%'
34681
+ }, React__default.createElement(NPCDialogText, {
34682
+ onStartStep: function onStartStep() {
34683
+ return setShowGoNextIndicator(false);
34682
34684
  },
34683
- width: "330px",
34684
- cancelDrag: ".item-container-body",
34685
- onPositionChange: function onPositionChange(_ref2) {
34686
- var x = _ref2.x,
34687
- y = _ref2.y;
34688
- if (_onPositionChange) {
34689
- _onPositionChange({
34690
- x: x,
34691
- y: y
34692
- });
34685
+ onEndStep: function onEndStep() {
34686
+ return setShowGoNextIndicator(true);
34687
+ },
34688
+ text: textAndTypeArray[slide].text || 'No text provided.',
34689
+ onClose: function onClose() {
34690
+ if (_onClose) {
34691
+ _onClose();
34693
34692
  }
34693
+ }
34694
+ })), React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
34695
+ src: textAndTypeArray[slide].imagePath || img$6
34696
+ })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator, {
34697
+ right: '10.5rem',
34698
+ 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, {
34702
+ flex: '70%'
34703
+ }, React__default.createElement(NPCDialogText, {
34704
+ onStartStep: function onStartStep() {
34705
+ return setShowGoNextIndicator(false);
34694
34706
  },
34695
- onOutsideClick: onOutsideClick,
34696
- initialPosition: initialPosition
34697
- }, children);
34698
- };
34699
-
34700
- (function (RangeSliderType) {
34701
- RangeSliderType["Slider"] = "rpgui-slider";
34702
- RangeSliderType["GoldSlider"] = "rpgui-slider golden";
34703
- })(exports.RangeSliderType || (exports.RangeSliderType = {}));
34704
- var RangeSlider = function RangeSlider(_ref) {
34705
- var type = _ref.type,
34706
- valueMin = _ref.valueMin,
34707
- valueMax = _ref.valueMax,
34708
- width = _ref.width,
34709
- _onChange = _ref.onChange,
34710
- value = _ref.value;
34711
- var sliderId = uuid.v4();
34712
- var containerRef = React.useRef(null);
34713
- var _useState = React.useState(0),
34714
- left = _useState[0],
34715
- setLeft = _useState[1];
34716
- React.useEffect(function () {
34717
- var _containerRef$current;
34718
- var calculatedWidth = ((_containerRef$current = containerRef.current) == null ? void 0 : _containerRef$current.clientWidth) || 0;
34719
- setLeft(Math.max((value - valueMin) / (valueMax - valueMin) * (calculatedWidth - 35) + 10));
34720
- }, [value, valueMin, valueMax]);
34721
- var typeClass = type === exports.RangeSliderType.GoldSlider ? 'golden' : '';
34722
- return React__default.createElement("div", {
34723
- style: {
34724
- width: width,
34725
- position: 'relative'
34707
+ onEndStep: function onEndStep() {
34708
+ return setShowGoNextIndicator(true);
34726
34709
  },
34727
- className: "rpgui-slider-container " + typeClass,
34728
- id: "rpgui-slider-" + sliderId,
34729
- ref: containerRef
34730
- }, React__default.createElement("div", {
34731
- style: {
34732
- pointerEvents: 'none'
34733
- }
34734
- }, React__default.createElement("div", {
34735
- className: "rpgui-slider-track " + typeClass
34736
- }), React__default.createElement("div", {
34737
- className: "rpgui-slider-left-edge " + typeClass
34738
- }), React__default.createElement("div", {
34739
- className: "rpgui-slider-right-edge " + typeClass
34740
- }), React__default.createElement("div", {
34741
- className: "rpgui-slider-thumb " + typeClass,
34742
- style: {
34743
- left: left
34710
+ text: textAndTypeArray[slide].text || 'No text provided.',
34711
+ onClose: function onClose() {
34712
+ if (_onClose) {
34713
+ _onClose();
34714
+ }
34744
34715
  }
34745
- })), React__default.createElement(Input$1, {
34746
- type: "range",
34747
- style: {
34748
- width: width
34749
- },
34750
- min: valueMin,
34751
- max: valueMax,
34752
- onChange: function onChange(e) {
34753
- return _onChange(Number(e.target.value));
34754
- },
34755
- value: value,
34756
- className: "rpgui-cursor-point"
34757
- }));
34716
+ })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator, {
34717
+ right: '1rem',
34718
+ src: img$7
34719
+ }))), ")"));
34758
34720
  };
34759
- var Input$1 = /*#__PURE__*/styled.input.withConfig({
34760
- displayName: "RangeSlider__Input",
34761
- componentId: "sc-v8mte9-0"
34762
- })(["opacity:0;position:absolute;width:100%;height:100%;top:0;left:0;margin-top:-5px;"]);
34721
+ var Container$d = /*#__PURE__*/styled.div.withConfig({
34722
+ displayName: "NPCMultiDialog__Container",
34723
+ componentId: "sc-rvu5wg-0"
34724
+ })(["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({
34726
+ displayName: "NPCMultiDialog__TextContainer",
34727
+ componentId: "sc-rvu5wg-1"
34728
+ })(["flex:", " 0 0;width:355px;"], function (_ref2) {
34729
+ var flex = _ref2.flex;
34730
+ return flex;
34731
+ });
34732
+ var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
34733
+ displayName: "NPCMultiDialog__ThumbnailContainer",
34734
+ componentId: "sc-rvu5wg-2"
34735
+ })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
34736
+ var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
34737
+ displayName: "NPCMultiDialog__NPCThumbnail",
34738
+ componentId: "sc-rvu5wg-3"
34739
+ })(["image-rendering:pixelated;height:128px;width:128px;"]);
34740
+ var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
34741
+ displayName: "NPCMultiDialog__PressSpaceIndicator",
34742
+ componentId: "sc-rvu5wg-4"
34743
+ })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref3) {
34744
+ var right = _ref3.right;
34745
+ return right;
34746
+ });
34763
34747
 
34764
- var ItemQuantitySelector = function ItemQuantitySelector(_ref) {
34765
- var quantity = _ref.quantity,
34766
- onConfirm = _ref.onConfirm,
34767
- onClose = _ref.onClose;
34768
- var _useState = React.useState(quantity),
34769
- value = _useState[0],
34770
- setValue = _useState[1];
34771
- var inputRef = React.useRef(null);
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);
34763
+ return function () {
34764
+ el.removeEventListener(type, listener);
34765
+ };
34766
+ }, [type, el]);
34767
+ };
34768
+
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];
34772
34776
  React.useEffect(function () {
34773
- if (inputRef.current) {
34774
- inputRef.current.focus();
34775
- inputRef.current.select();
34776
- var closeSelector = function closeSelector(e) {
34777
- if (e.key === 'Escape') {
34778
- onClose();
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();
34779
34783
  }
34780
- };
34781
- document.addEventListener('keydown', closeSelector);
34782
- return function () {
34783
- document.removeEventListener('keydown', closeSelector);
34784
- };
34785
- }
34786
- return function () {};
34787
- }, []);
34788
- return React__default.createElement(StyledContainer, {
34789
- type: exports.RPGUIContainerTypes.Framed,
34790
- width: "25rem"
34791
- }, React__default.createElement(CloseButton$2, {
34792
- className: "container-close",
34793
- onPointerDown: onClose
34794
- }, "X"), React__default.createElement("h2", null, "Select quantity to move"), React__default.createElement(StyledForm, {
34795
- style: {
34796
- width: '100%'
34797
- },
34798
- onSubmit: function onSubmit(e) {
34799
- e.preventDefault();
34800
- var numberValue = Number(value);
34801
- if (Number.isNaN(numberValue)) {
34802
- return;
34803
34784
  }
34804
- onConfirm(Math.max(1, Math.min(quantity, numberValue)));
34805
- },
34806
- noValidate: true
34807
- }, React__default.createElement(StyledInput, {
34808
- innerRef: inputRef,
34809
- placeholder: "Enter quantity",
34810
- type: "number",
34811
- min: 1,
34812
- max: quantity,
34813
- value: value,
34814
- onChange: function onChange(e) {
34815
- if (Number(e.target.value) >= quantity) {
34816
- setValue(quantity);
34817
- return;
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
+ }
34818
34793
  }
34819
- setValue(e.target.value);
34820
- },
34821
- onBlur: function onBlur(e) {
34822
- var newValue = Math.max(1, Math.min(quantity, Number(e.target.value)));
34823
- setValue(newValue);
34824
- }
34825
- }), React__default.createElement(RangeSlider, {
34826
- type: exports.RangeSliderType.Slider,
34827
- valueMin: 1,
34828
- valueMax: quantity,
34829
- width: "100%",
34830
- onChange: setValue,
34831
- value: value
34832
- }), React__default.createElement(Button, {
34833
- buttonType: exports.ButtonTypes.RPGUIButton,
34834
- type: "submit"
34835
- }, "Confirm")));
34794
+ }, 50);
34795
+ return function () {
34796
+ clearInterval(interval);
34797
+ };
34798
+ }, [text]);
34799
+ return React__default.createElement(TextContainer$1, null, textState);
34836
34800
  };
34837
- var StyledContainer = /*#__PURE__*/styled(RPGUIContainer).withConfig({
34838
- displayName: "ItemQuantitySelector__StyledContainer",
34839
- componentId: "sc-yfdtpn-0"
34840
- })(["display:flex;flex-direction:column;align-items:center;"]);
34841
- var StyledForm = /*#__PURE__*/styled.form.withConfig({
34842
- displayName: "ItemQuantitySelector__StyledForm",
34843
- componentId: "sc-yfdtpn-1"
34844
- })(["display:flex;flex-direction:column;align-items:center;width:100%;"]);
34845
- var StyledInput = /*#__PURE__*/styled(Input).withConfig({
34846
- displayName: "ItemQuantitySelector__StyledInput",
34847
- componentId: "sc-yfdtpn-2"
34848
- })(["text-align:center;&::-webkit-outer-spin-button,&::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}&[type='number']{-moz-appearance:textfield;}"]);
34849
- var CloseButton$2 = /*#__PURE__*/styled.div.withConfig({
34850
- displayName: "ItemQuantitySelector__CloseButton",
34851
- componentId: "sc-yfdtpn-3"
34852
- })(["position:absolute;top:3px;right:0px;color:white;z-index:22;font-size:0.8rem;"]);
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;"]);
34853
34805
 
34854
- var ItemContainer$1 = function ItemContainer(_ref) {
34855
- var itemContainer = _ref.itemContainer,
34856
- onClose = _ref.onClose,
34857
- _onMouseOver = _ref.onMouseOver,
34858
- _onSelected = _ref.onSelected,
34859
- onItemClick = _ref.onItemClick,
34860
- type = _ref.type,
34861
- atlasJSON = _ref.atlasJSON,
34862
- atlasIMG = _ref.atlasIMG,
34863
- _ref$disableContextMe = _ref.disableContextMenu,
34864
- disableContextMenu = _ref$disableContextMe === void 0 ? false : _ref$disableContextMe,
34865
- onItemDragEnd = _ref.onItemDragEnd,
34866
- onItemDragStart = _ref.onItemDragStart,
34867
- onItemPlaceDrop = _ref.onItemPlaceDrop,
34868
- _onOutsideDrop = _ref.onOutsideDrop,
34869
- checkIfItemCanBeMoved = _ref.checkIfItemCanBeMoved,
34870
- initialPosition = _ref.initialPosition,
34871
- checkIfItemShouldDragEnd = _ref.checkIfItemShouldDragEnd,
34872
- dragScale = _ref.dragScale;
34873
- var _useState = React.useState({
34874
- isOpen: false,
34875
- maxQuantity: 1,
34876
- callback: function callback(_quantity) {}
34877
- }),
34878
- quantitySelect = _useState[0],
34879
- setQuantitySelect = _useState[1];
34880
- var onRenderSlots = function onRenderSlots() {
34881
- var slots = [];
34882
- for (var i = 0; i < itemContainer.slotQty; i++) {
34883
- var _itemContainer$slots;
34884
- slots.push(React__default.createElement(ItemSlot, {
34885
- isContextMenuDisabled: disableContextMenu,
34886
- key: i,
34887
- slotIndex: i,
34888
- item: ((_itemContainer$slots = itemContainer.slots) == null ? void 0 : _itemContainer$slots[i]) || null,
34889
- itemContainerType: type,
34890
- onMouseOver: function onMouseOver(event, slotIndex, item) {
34891
- if (_onMouseOver) _onMouseOver(event, slotIndex, item);
34892
- },
34893
- onPointerDown: function onPointerDown(ItemType, ContainerType, item) {
34894
- if (onItemClick) onItemClick(item, ItemType, ContainerType);
34895
- },
34896
- onSelected: function onSelected(optionId, item) {
34897
- if (_onSelected) _onSelected(optionId, item);
34898
- },
34899
- onDragStart: function onDragStart(item, slotIndex, itemContainerType) {
34900
- if (onItemDragStart) onItemDragStart(item, slotIndex, itemContainerType);
34901
- },
34902
- onDragEnd: function onDragEnd(quantity) {
34903
- if (onItemDragEnd) onItemDragEnd(quantity);
34904
- },
34905
- dragScale: dragScale,
34906
- checkIfItemCanBeMoved: checkIfItemCanBeMoved,
34907
- checkIfItemShouldDragEnd: checkIfItemShouldDragEnd,
34908
- openQuantitySelector: function openQuantitySelector(maxQuantity, callback) {
34909
- setQuantitySelect({
34910
- isOpen: true,
34911
- maxQuantity: maxQuantity,
34912
- callback: callback
34913
- });
34914
- },
34915
- onPlaceDrop: function onPlaceDrop(item, slotIndex, itemContainerType) {
34916
- if (onItemPlaceDrop) onItemPlaceDrop(item, slotIndex, itemContainerType);
34917
- },
34918
- onOutsideDrop: function onOutsideDrop(item, position) {
34919
- if (_onOutsideDrop) _onOutsideDrop(item, position);
34920
- },
34921
- atlasIMG: atlasIMG,
34922
- atlasJSON: atlasJSON
34923
- }));
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;
34924
34819
  }
34925
- return slots;
34820
+ var firstAnswerId = currentQuestion.answerIds[0];
34821
+ return answers.find(function (answer) {
34822
+ return answer.id === firstAnswerId;
34823
+ });
34926
34824
  };
34927
- return React__default.createElement(React__default.Fragment, null, React__default.createElement(SlotsContainer, {
34928
- title: itemContainer.name || 'Container',
34929
- onClose: onClose,
34930
- initialPosition: initialPosition
34931
- }, React__default.createElement(ItemsContainer, {
34932
- className: "item-container-body"
34933
- }, onRenderSlots())), quantitySelect.isOpen && React__default.createElement(QuantitySelectorContainer, null, React__default.createElement(ItemQuantitySelector, {
34934
- quantity: quantitySelect.maxQuantity,
34935
- onConfirm: function onConfirm(quantity) {
34936
- quantitySelect.callback(quantity);
34937
- setQuantitySelect({
34938
- isOpen: false,
34939
- maxQuantity: 1,
34940
- callback: function callback() {}
34941
- });
34942
- },
34943
- onClose: function onClose() {
34944
- quantitySelect.callback(-1);
34945
- setQuantitySelect({
34946
- isOpen: false,
34947
- maxQuantity: 1,
34948
- callback: function callback() {}
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;
34949
34835
  });
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;
34950
34882
  }
34951
- })));
34952
- };
34953
- var ItemsContainer = /*#__PURE__*/styled.div.withConfig({
34954
- displayName: "ItemContainer__ItemsContainer",
34955
- componentId: "sc-15y5p9l-0"
34956
- })(["max-width:280px;display:flex;justify-content:center;flex-wrap:wrap;"]);
34957
- var QuantitySelectorContainer = /*#__PURE__*/styled.div.withConfig({
34958
- displayName: "ItemContainer__QuantitySelectorContainer",
34959
- componentId: "sc-15y5p9l-1"
34960
- })(["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);"]);
34961
-
34962
- var ItemSelector = function ItemSelector(_ref) {
34963
- var atlasIMG = _ref.atlasIMG,
34964
- atlasJSON = _ref.atlasJSON,
34965
- options = _ref.options,
34966
- onClose = _ref.onClose,
34967
- onSelect = _ref.onSelect;
34968
- var _useState = React.useState(),
34969
- selectedValue = _useState[0],
34970
- setSelectedValue = _useState[1];
34971
- var handleClick = function handleClick() {
34972
- var element = document.querySelector("input[name='test']:checked");
34973
- var elementValue = element.value;
34974
- setSelectedValue(elementValue);
34975
34883
  };
34976
- React.useEffect(function () {
34977
- if (selectedValue) {
34978
- onSelect(selectedValue);
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();
34979
34895
  }
34980
- }, [selectedValue]);
34981
- return React__default.createElement(DraggableContainer, {
34982
- type: exports.RPGUIContainerTypes.Framed,
34983
- width: "500px",
34984
- cancelDrag: ".equipment-container-body .arrow-selector",
34985
- onCloseButton: function onCloseButton() {
34986
- if (onClose) {
34987
- onClose();
34988
- }
34896
+ };
34897
+ var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
34898
+ var answerIds = currentQuestion.answerIds;
34899
+ if (!answerIds) {
34900
+ return null;
34989
34901
  }
34990
- }, React__default.createElement("div", {
34991
- style: {
34992
- width: '100%'
34902
+ var answers = onGetAnswers(answerIds);
34903
+ if (!answers) {
34904
+ return null;
34993
34905
  }
34994
- }, React__default.createElement(Title$2, null, 'Harvesting instruments'), React__default.createElement(Subtitle$1, null, 'Use the tool, you need it'), React__default.createElement("hr", {
34995
- className: "golden"
34996
- })), React__default.createElement(RadioInputScroller$1, null, options == null ? void 0 : options.map(function (option, index) {
34997
- return React__default.createElement(RadioOptionsWrapper$1, {
34998
- key: index
34999
- }, React__default.createElement(SpriteAtlasWrapper$1, null, React__default.createElement(SpriteFromAtlas, {
35000
- atlasIMG: atlasIMG,
35001
- atlasJSON: atlasJSON,
35002
- spriteKey: option.imageKey,
35003
- imgScale: 3
35004
- })), React__default.createElement("div", null, React__default.createElement("input", {
35005
- className: "rpgui-radio",
35006
- type: "radio",
35007
- value: option.name,
35008
- name: "test"
35009
- }), React__default.createElement("label", {
35010
- onPointerDown: handleClick,
35011
- style: {
35012
- display: 'flex',
35013
- alignItems: 'center'
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));
35014
34921
  }
35015
- }, option.name, " ", React__default.createElement("br", null), option.description)));
35016
- })), React__default.createElement(ButtonWrapper$1, null, React__default.createElement(Button, {
35017
- buttonType: exports.ButtonTypes.RPGUIButton,
35018
- onPointerDown: onClose
35019
- }, "Cancel"), React__default.createElement(Button, {
35020
- buttonType: exports.ButtonTypes.RPGUIButton
35021
- }, "Select")));
35022
- };
35023
- var Title$2 = /*#__PURE__*/styled.h1.withConfig({
35024
- displayName: "ItemSelector__Title",
35025
- componentId: "sc-gptoxp-0"
35026
- })(["font-size:0.6rem;color:yellow !important;"]);
35027
- var Subtitle$1 = /*#__PURE__*/styled.h1.withConfig({
35028
- displayName: "ItemSelector__Subtitle",
35029
- componentId: "sc-gptoxp-1"
35030
- })(["font-size:0.4rem;color:yellow !important;"]);
35031
- var RadioInputScroller$1 = /*#__PURE__*/styled.div.withConfig({
35032
- displayName: "ItemSelector__RadioInputScroller",
35033
- componentId: "sc-gptoxp-2"
35034
- })(["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;"]);
35035
- var SpriteAtlasWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35036
- displayName: "ItemSelector__SpriteAtlasWrapper",
35037
- componentId: "sc-gptoxp-3"
35038
- })(["margin-right:40px;"]);
35039
- var RadioOptionsWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35040
- displayName: "ItemSelector__RadioOptionsWrapper",
35041
- componentId: "sc-gptoxp-4"
35042
- })(["display:flex;align-items:stretch;margin-bottom:40px;"]);
35043
- var ButtonWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35044
- displayName: "ItemSelector__ButtonWrapper",
35045
- componentId: "sc-gptoxp-5"
35046
- })(["display:flex;justify-content:space-around;padding-top:20px;width:100%;"]);
35047
-
35048
- var ListMenu = function ListMenu(_ref) {
35049
- var options = _ref.options,
35050
- onSelected = _ref.onSelected,
35051
- x = _ref.x,
35052
- y = _ref.y;
35053
- return React__default.createElement(Container$f, {
35054
- x: x,
35055
- y: y
35056
- }, React__default.createElement("ul", {
35057
- className: "rpgui-list-imp",
35058
- style: {
35059
- overflow: 'hidden'
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);
35060
34932
  }
35061
- }, options.map(function (params, index) {
35062
- return React__default.createElement(ListElement$1, {
35063
- key: (params == null ? void 0 : params.id) || index,
35064
- onPointerDown: function onPointerDown() {
35065
- onSelected(params == null ? void 0 : params.id);
35066
- }
35067
- }, (params == null ? void 0 : params.text) || 'No text');
35068
- })));
34933
+ })), canShowAnswers && React__default.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
35069
34934
  };
35070
- var Container$f = /*#__PURE__*/styled.div.withConfig({
35071
- displayName: "ListMenu__Container",
35072
- componentId: "sc-i9097t-0"
35073
- })(["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) {
35074
- return props.y || 0;
35075
- }, function (props) {
35076
- return props.x || 0;
35077
- }, uiFonts.size.xsmall);
35078
- var ListElement$1 = /*#__PURE__*/styled.li.withConfig({
35079
- displayName: "ListMenu__ListElement",
35080
- componentId: "sc-i9097t-1"
35081
- })(["margin-right:0.5rem;"]);
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;}"]);
35082
34963
 
35083
34964
  var ProgressBar = function ProgressBar(_ref) {
35084
34965
  var max = _ref.max,
@@ -35097,7 +34978,7 @@ var ProgressBar = function ProgressBar(_ref) {
35097
34978
  }
35098
34979
  return value * 100 / max;
35099
34980
  };
35100
- return React__default.createElement(Container$g, {
34981
+ return React__default.createElement(Container$f, {
35101
34982
  className: "rpgui-progress",
35102
34983
  "data-value": calculatePercentageValue(max, value) / 100,
35103
34984
  "data-rpguitype": "progress",
@@ -35126,7 +35007,7 @@ var TextOverlay$1 = /*#__PURE__*/styled.div.withConfig({
35126
35007
  displayName: "ProgressBar__TextOverlay",
35127
35008
  componentId: "sc-qa6fzh-1"
35128
35009
  })(["width:100%;position:relative;"]);
35129
- var Container$g = /*#__PURE__*/styled.div.withConfig({
35010
+ var Container$f = /*#__PURE__*/styled.div.withConfig({
35130
35011
  displayName: "ProgressBar__Container",
35131
35012
  componentId: "sc-qa6fzh-2"
35132
35013
  })(["display:flex;flex-direction:column;min-width:", "px;width:", "%;justify-content:start;align-items:flex-start;", ""], function (props) {
@@ -35137,7 +35018,7 @@ var Container$g = /*#__PURE__*/styled.div.withConfig({
35137
35018
  return props.style;
35138
35019
  });
35139
35020
 
35140
- var img$9 = '';
35021
+ var img$8 = '';
35141
35022
 
35142
35023
  var QuestInfo = function QuestInfo(_ref) {
35143
35024
  var quests = _ref.quests,
@@ -35179,7 +35060,7 @@ var QuestInfo = function QuestInfo(_ref) {
35179
35060
  }), React__default.createElement(QuestContainer, null, React__default.createElement(TitleContainer$1, {
35180
35061
  className: "drag-handler"
35181
35062
  }, React__default.createElement(Title$3, null, React__default.createElement(Thumbnail, {
35182
- src: quests[currentIndex].thumbnail || img$9
35063
+ src: quests[currentIndex].thumbnail || img$8
35183
35064
  }), quests[currentIndex].title), React__default.createElement(QuestSplitDiv, null, React__default.createElement("hr", {
35184
35065
  className: "golden"
35185
35066
  }))), React__default.createElement(Content, null, React__default.createElement("p", null, quests[currentIndex].description)), React__default.createElement(QuestColumn, {
@@ -35198,7 +35079,7 @@ var QuestInfo = function QuestInfo(_ref) {
35198
35079
  })))) : React__default.createElement(QuestsContainer, null, React__default.createElement(QuestContainer, null, React__default.createElement(TitleContainer$1, {
35199
35080
  className: "drag-handler"
35200
35081
  }, React__default.createElement(Title$3, null, React__default.createElement(Thumbnail, {
35201
- src: quests[0].thumbnail || img$9
35082
+ src: quests[0].thumbnail || img$8
35202
35083
  }), quests[0].title), React__default.createElement(QuestSplitDiv, null, React__default.createElement("hr", {
35203
35084
  className: "golden"
35204
35085
  }))), React__default.createElement(Content, null, React__default.createElement("p", null, quests[0].description)), React__default.createElement(QuestColumn, {
@@ -35331,15 +35212,98 @@ var InputRadio = function InputRadio(_ref) {
35331
35212
  }, element.label), React__default.createElement("br", null));
35332
35213
  }));
35333
35214
  };
35334
-
35335
- //@ts-ignore
35336
- var _RPGUI = RPGUI;
35337
- var RPGUIRoot = function RPGUIRoot(_ref) {
35338
- var children = _ref.children;
35339
- return React__default.createElement("div", {
35340
- className: "rpgui-content"
35341
- }, children);
35342
- };
35215
+
35216
+ //@ts-ignore
35217
+ var _RPGUI = RPGUI;
35218
+ var RPGUIRoot = function RPGUIRoot(_ref) {
35219
+ var children = _ref.children;
35220
+ return React__default.createElement("div", {
35221
+ className: "rpgui-content"
35222
+ }, children);
35223
+ };
35224
+
35225
+ var Shortcuts = function Shortcuts(_ref) {
35226
+ var shortcuts = _ref.shortcuts,
35227
+ onShortcutCast = _ref.onShortcutCast,
35228
+ mana = _ref.mana,
35229
+ _ref$isBlockedCasting = _ref.isBlockedCastingByKeyboard,
35230
+ isBlockedCastingByKeyboard = _ref$isBlockedCasting === void 0 ? false : _ref$isBlockedCasting,
35231
+ atlasJSON = _ref.atlasJSON,
35232
+ atlasIMG = _ref.atlasIMG,
35233
+ inventory = _ref.inventory;
35234
+ React.useEffect(function () {
35235
+ var handleKeyDown = function handleKeyDown(e) {
35236
+ if (isBlockedCastingByKeyboard) return;
35237
+ var shortcutIndex = Number(e.key) - 1;
35238
+ if (shortcutIndex >= 0 && shortcutIndex <= 5) {
35239
+ onShortcutCast(shortcutIndex);
35240
+ }
35241
+ };
35242
+ window.addEventListener('keydown', handleKeyDown);
35243
+ return function () {
35244
+ window.removeEventListener('keydown', handleKeyDown);
35245
+ };
35246
+ }, [shortcuts, isBlockedCastingByKeyboard]);
35247
+ return React__default.createElement(List$1, null, Array.from({
35248
+ length: 6
35249
+ }).map(function (_, i) {
35250
+ var _shortcuts$i, _shortcuts$i3, _payload$manaCost;
35251
+ if (((_shortcuts$i = shortcuts[i]) == null ? void 0 : _shortcuts$i.type) === shared.ShortcutType.Item) {
35252
+ var _shortcuts$i2;
35253
+ var _payload = (_shortcuts$i2 = shortcuts[i]) == null ? void 0 : _shortcuts$i2.payload;
35254
+ var itemsFromEquipment = [];
35255
+ if (inventory) {
35256
+ Object.keys(inventory.slots).forEach(function (i) {
35257
+ var _inventory$slots$inde;
35258
+ var index = parseInt(i);
35259
+ if (((_inventory$slots$inde = inventory.slots[index]) == null ? void 0 : _inventory$slots$inde.key) === (_payload == null ? void 0 : _payload.key)) {
35260
+ itemsFromEquipment.push(inventory.slots[index]);
35261
+ }
35262
+ });
35263
+ }
35264
+ var totalQty = itemsFromEquipment.reduce(function (acc, item) {
35265
+ return acc + ((item == null ? void 0 : item.stackQty) || 1);
35266
+ }, 0);
35267
+ return React__default.createElement(SingleShortcut, {
35268
+ key: i,
35269
+ onPointerDown: onShortcutCast.bind(null, i),
35270
+ disabled: false
35271
+ }, _payload && React__default.createElement(SpriteFromAtlas, {
35272
+ atlasIMG: atlasIMG,
35273
+ atlasJSON: atlasJSON,
35274
+ spriteKey: shared.getItemTextureKeyPath({
35275
+ key: _payload.texturePath,
35276
+ texturePath: _payload.texturePath,
35277
+ stackQty: _payload.stackQty || 1
35278
+ }, atlasJSON),
35279
+ width: 32,
35280
+ height: 32
35281
+ }), React__default.createElement("span", {
35282
+ className: "qty"
35283
+ }, totalQty), React__default.createElement("span", {
35284
+ className: "keyboard"
35285
+ }, i + 1));
35286
+ }
35287
+ var payload = (_shortcuts$i3 = shortcuts[i]) == null ? void 0 : _shortcuts$i3.payload;
35288
+ return React__default.createElement(SingleShortcut, {
35289
+ key: i,
35290
+ onPointerDown: onShortcutCast.bind(null, i),
35291
+ disabled: mana < ((_payload$manaCost = payload == null ? void 0 : payload.manaCost) != null ? _payload$manaCost : 0)
35292
+ }, React__default.createElement("span", {
35293
+ className: "mana"
35294
+ }, payload && payload.manaCost), React__default.createElement("span", {
35295
+ className: "magicWords"
35296
+ }, payload == null ? void 0 : payload.magicWords.split(' ').map(function (word) {
35297
+ return word[0];
35298
+ })), React__default.createElement("span", {
35299
+ className: "keyboard"
35300
+ }, i + 1));
35301
+ }));
35302
+ };
35303
+ var List$1 = /*#__PURE__*/styled.p.withConfig({
35304
+ displayName: "Shortcuts__List",
35305
+ componentId: "sc-kgtsi7-0"
35306
+ })(["width:100%;display:flex;align-items:center;justify-content:center;gap:0.5rem;box-sizing:border-box;margin:0 !important;"]);
35343
35307
 
35344
35308
  var SimpleProgressBar = function SimpleProgressBar(_ref) {
35345
35309
  var value = _ref.value,
@@ -35347,7 +35311,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
35347
35311
  bgColor = _ref$bgColor === void 0 ? 'red' : _ref$bgColor,
35348
35312
  _ref$margin = _ref.margin,
35349
35313
  margin = _ref$margin === void 0 ? 20 : _ref$margin;
35350
- return React__default.createElement(Container$h, {
35314
+ return React__default.createElement(Container$g, {
35351
35315
  className: "simple-progress-bar"
35352
35316
  }, React__default.createElement(ProgressBarContainer, {
35353
35317
  margin: margin
@@ -35356,7 +35320,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
35356
35320
  bgColor: bgColor
35357
35321
  }))));
35358
35322
  };
35359
- var Container$h = /*#__PURE__*/styled.div.withConfig({
35323
+ var Container$g = /*#__PURE__*/styled.div.withConfig({
35360
35324
  displayName: "SimpleProgressBar__Container",
35361
35325
  componentId: "sc-mbeil3-0"
35362
35326
  })(["display:flex;justify-content:center;align-items:center;width:100%;"]);
@@ -35583,7 +35547,7 @@ var Spell = function Spell(_ref) {
35583
35547
  isSettingShortcut = _ref.isSettingShortcut,
35584
35548
  minMagicLevelRequired = _ref.minMagicLevelRequired;
35585
35549
  var disabled = isSettingShortcut ? charMagicLevel < minMagicLevelRequired : manaCost > charMana || charMagicLevel < minMagicLevelRequired;
35586
- return React__default.createElement(Container$i, {
35550
+ return React__default.createElement(Container$h, {
35587
35551
  disabled: disabled,
35588
35552
  onPointerDown: onPointerDown == null ? void 0 : onPointerDown.bind(null, spellKey),
35589
35553
  isSettingShortcut: isSettingShortcut && !disabled,
@@ -35596,7 +35560,7 @@ var Spell = function Spell(_ref) {
35596
35560
  className: "mana"
35597
35561
  }, manaCost)));
35598
35562
  };
35599
- var Container$i = /*#__PURE__*/styled.button.withConfig({
35563
+ var Container$h = /*#__PURE__*/styled.button.withConfig({
35600
35564
  displayName: "Spell__Container",
35601
35565
  componentId: "sc-j96fa2-0"
35602
35566
  })(["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) {
@@ -35632,43 +35596,6 @@ var Overlay = /*#__PURE__*/styled.p.withConfig({
35632
35596
  componentId: "sc-j96fa2-7"
35633
35597
  })(["margin:0 !important;position:absolute;top:0;left:0;width:100%;height:100%;border-radius:1rem;display:flex;justify-content:center;align-items:center;color:", ";font-size:", " !important;font-weight:bold;z-index:10;background-color:rgba(0 0 0 / 0.2);"], uiColors.yellow, uiFonts.size.large);
35634
35598
 
35635
- var SpellbookShortcuts = function SpellbookShortcuts(_ref) {
35636
- var setSettingShortcutIndex = _ref.setSettingShortcutIndex,
35637
- settingShortcutIndex = _ref.settingShortcutIndex,
35638
- shortcuts = _ref.shortcuts,
35639
- removeShortcut = _ref.removeShortcut;
35640
- return React__default.createElement(List$1, {
35641
- id: "shortcuts_list"
35642
- }, "Spells shortcuts:", Array.from({
35643
- length: 4
35644
- }).map(function (_, i) {
35645
- var _shortcuts$i2;
35646
- return React__default.createElement(SpellShortcut$1, {
35647
- key: i,
35648
- onPointerDown: function onPointerDown() {
35649
- var _shortcuts$i;
35650
- removeShortcut(i);
35651
- if (!((_shortcuts$i = shortcuts[i]) != null && _shortcuts$i.key)) setSettingShortcutIndex(i);
35652
- },
35653
- disabled: settingShortcutIndex !== -1 && settingShortcutIndex !== i,
35654
- isBeingSet: settingShortcutIndex === i
35655
- }, React__default.createElement("span", null, (_shortcuts$i2 = shortcuts[i]) == null ? void 0 : _shortcuts$i2.magicWords.split(' ').map(function (word) {
35656
- return word[0];
35657
- })));
35658
- }));
35659
- };
35660
- var SpellShortcut$1 = /*#__PURE__*/styled.button.withConfig({
35661
- displayName: "SpellbookShortcuts__SpellShortcut",
35662
- componentId: "sc-fr4a0d-0"
35663
- })(["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) {
35664
- var isBeingSet = _ref2.isBeingSet;
35665
- return isBeingSet ? uiColors.yellow : uiColors.darkGray;
35666
- }, uiColors.darkGray, uiColors.gray);
35667
- var List$1 = /*#__PURE__*/styled.p.withConfig({
35668
- displayName: "SpellbookShortcuts__List",
35669
- componentId: "sc-fr4a0d-1"
35670
- })(["width:100%;display:flex;align-items:center;justify-content:flex-end;gap:0.5rem;padding:0.5rem;box-sizing:border-box;margin:0 !important;"]);
35671
-
35672
35599
  var Spellbook = function Spellbook(_ref) {
35673
35600
  var onClose = _ref.onClose,
35674
35601
  onInputFocus = _ref.onInputFocus,
@@ -35678,8 +35605,10 @@ var Spellbook = function Spellbook(_ref) {
35678
35605
  mana = _ref.mana,
35679
35606
  onSpellClick = _ref.onSpellClick,
35680
35607
  setSpellShortcut = _ref.setSpellShortcut,
35681
- spellShortcuts = _ref.spellShortcuts,
35682
- removeSpellShortcut = _ref.removeSpellShortcut;
35608
+ shortcuts = _ref.shortcuts,
35609
+ removeShortcut = _ref.removeShortcut,
35610
+ atlasIMG = _ref.atlasIMG,
35611
+ atlasJSON = _ref.atlasJSON;
35683
35612
  var _useState = React.useState(''),
35684
35613
  search = _useState[0],
35685
35614
  setSearch = _useState[1];
@@ -35716,11 +35645,13 @@ var Spellbook = function Spellbook(_ref) {
35716
35645
  width: "inherit",
35717
35646
  height: "inherit",
35718
35647
  cancelDrag: "#spellbook-search, #shortcuts_list, .spell"
35719
- }, React__default.createElement(Container$j, null, React__default.createElement(Title$6, null, "Learned Spells"), React__default.createElement(SpellbookShortcuts, {
35648
+ }, React__default.createElement(Container$i, null, React__default.createElement(Title$6, null, "Learned Spells"), React__default.createElement(ShortcutsSetter, {
35720
35649
  setSettingShortcutIndex: setSettingShortcutIndex,
35721
35650
  settingShortcutIndex: settingShortcutIndex,
35722
- shortcuts: spellShortcuts,
35723
- removeShortcut: removeSpellShortcut
35651
+ shortcuts: shortcuts,
35652
+ removeShortcut: removeShortcut,
35653
+ atlasIMG: atlasIMG,
35654
+ atlasJSON: atlasJSON
35724
35655
  }), React__default.createElement(Input, {
35725
35656
  placeholder: "Search for spell",
35726
35657
  value: search,
@@ -35746,7 +35677,7 @@ var Title$6 = /*#__PURE__*/styled.h1.withConfig({
35746
35677
  displayName: "Spellbook__Title",
35747
35678
  componentId: "sc-r02nfq-0"
35748
35679
  })(["font-size:", " !important;margin-bottom:0 !important;"], uiFonts.size.large);
35749
- var Container$j = /*#__PURE__*/styled.div.withConfig({
35680
+ var Container$i = /*#__PURE__*/styled.div.withConfig({
35750
35681
  displayName: "Spellbook__Container",
35751
35682
  componentId: "sc-r02nfq-1"
35752
35683
  })(["width:100%;height:100%;color:white;display:flex;flex-direction:column;"]);
@@ -35760,16 +35691,16 @@ var TextArea = function TextArea(_ref) {
35760
35691
  return React__default.createElement("textarea", Object.assign({}, props));
35761
35692
  };
35762
35693
 
35763
- var img$a = '';
35694
+ var img$9 = '';
35764
35695
 
35765
- var img$b = '';
35696
+ var img$a = '';
35766
35697
 
35767
- var img$c = '';
35698
+ var img$b = '';
35768
35699
 
35769
35700
  var DayNightPeriod = function DayNightPeriod(_ref) {
35770
35701
  var _periodOfDaySrcFiles;
35771
35702
  var periodOfDay = _ref.periodOfDay;
35772
- var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[shared.PeriodOfDay.Morning] = img$b, _periodOfDaySrcFiles[shared.PeriodOfDay.Afternoon] = img$a, _periodOfDaySrcFiles[shared.PeriodOfDay.Night] = img$c, _periodOfDaySrcFiles);
35703
+ var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[shared.PeriodOfDay.Morning] = img$a, _periodOfDaySrcFiles[shared.PeriodOfDay.Afternoon] = img$9, _periodOfDaySrcFiles[shared.PeriodOfDay.Night] = img$b, _periodOfDaySrcFiles);
35773
35704
  return React__default.createElement(GifContainer, null, React__default.createElement("img", {
35774
35705
  src: periodOfDaySrcFiles[periodOfDay]
35775
35706
  }));
@@ -35779,7 +35710,7 @@ var GifContainer = /*#__PURE__*/styled.div.withConfig({
35779
35710
  componentId: "sc-10t97fw-0"
35780
35711
  })(["width:100%;img{width:67%;}"]);
35781
35712
 
35782
- var img$d = '';
35713
+ var img$c = '';
35783
35714
 
35784
35715
  var TimeWidget = function TimeWidget(_ref) {
35785
35716
  var onClose = _ref.onClose,
@@ -35794,7 +35725,7 @@ var TimeWidget = function TimeWidget(_ref) {
35794
35725
  var WidgetContainer = /*#__PURE__*/styled.div.withConfig({
35795
35726
  displayName: "TimeWidget__WidgetContainer",
35796
35727
  componentId: "sc-1ja236h-0"
35797
- })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$d);
35728
+ })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$c);
35798
35729
  var Time = /*#__PURE__*/styled.div.withConfig({
35799
35730
  displayName: "TimeWidget__Time",
35800
35731
  componentId: "sc-1ja236h-1"
@@ -36042,17 +35973,230 @@ var Truncate = function Truncate(_ref) {
36042
35973
  var _ref$maxLines = _ref.maxLines,
36043
35974
  maxLines = _ref$maxLines === void 0 ? 1 : _ref$maxLines,
36044
35975
  children = _ref.children;
36045
- return React__default.createElement(Container$k, {
35976
+ return React__default.createElement(Container$j, {
36046
35977
  maxLines: maxLines
36047
35978
  }, children);
36048
35979
  };
36049
- var Container$k = /*#__PURE__*/styled.div.withConfig({
35980
+ var Container$j = /*#__PURE__*/styled.div.withConfig({
36050
35981
  displayName: "Truncate__Container",
36051
35982
  componentId: "sc-6x00qb-0"
36052
35983
  })(["display:-webkit-box;max-width:100%;max-height:100%;-webkit-line-clamp:", ";-webkit-box-orient:vertical;overflow:hidden;"], function (props) {
36053
35984
  return props.maxLines;
36054
35985
  });
36055
35986
 
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
+
36056
36200
  exports.Button = Button;
36057
36201
  exports.CharacterSelection = CharacterSelection;
36058
36202
  exports.Chat = Chat;
@@ -36080,13 +36224,12 @@ exports.PropertySelect = PropertySelect;
36080
36224
  exports.QuestInfo = QuestInfo;
36081
36225
  exports.QuestList = QuestList;
36082
36226
  exports.QuestionDialog = QuestionDialog;
36083
- exports.QuickSpells = QuickSpells;
36084
36227
  exports.RPGUIContainer = RPGUIContainer;
36085
36228
  exports.RPGUIRoot = RPGUIRoot;
36086
36229
  exports.RangeSlider = RangeSlider;
36230
+ exports.Shortcuts = Shortcuts;
36087
36231
  exports.SkillProgressBar = SkillProgressBar;
36088
36232
  exports.SkillsContainer = SkillsContainer;
36089
- exports.SpellShortcut = SpellShortcut;
36090
36233
  exports.Spellbook = Spellbook;
36091
36234
  exports.SpriteFromAtlas = SpriteFromAtlas;
36092
36235
  exports.TextArea = TextArea;