@rpg-engine/long-bow 0.3.80 → 0.3.82

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 (149) hide show
  1. package/LICENSE +20 -20
  2. package/README.md +181 -181
  3. package/dist/components/Abstractions/ModalPortal.d.ts +6 -0
  4. package/dist/long-bow.cjs.development.js +805 -807
  5. package/dist/long-bow.cjs.development.js.map +1 -1
  6. package/dist/long-bow.cjs.production.min.js +1 -1
  7. package/dist/long-bow.cjs.production.min.js.map +1 -1
  8. package/dist/long-bow.esm.js +808 -810
  9. package/dist/long-bow.esm.js.map +1 -1
  10. package/package.json +100 -100
  11. package/src/components/Abstractions/ModalPortal.tsx +22 -0
  12. package/src/components/Abstractions/SlotsContainer.tsx +48 -48
  13. package/src/components/Arrow/SelectArrow.tsx +69 -69
  14. package/src/components/Arrow/img/arrow01-left-clicked.png +0 -0
  15. package/src/components/Arrow/img/arrow01-left.png +0 -0
  16. package/src/components/Arrow/img/arrow01-right-clicked.png +0 -0
  17. package/src/components/Arrow/img/arrow01-right.png +0 -0
  18. package/src/components/Arrow/img/arrow02-left-clicked.png +0 -0
  19. package/src/components/Arrow/img/arrow02-left.png +0 -0
  20. package/src/components/Arrow/img/arrow02-right-clicked.png +0 -0
  21. package/src/components/Arrow/img/arrow02-right.png +0 -0
  22. package/src/components/Button.tsx +40 -40
  23. package/src/components/Character/CharacterSelection.tsx +96 -96
  24. package/src/components/CharacterStatus/CharacterStatus.tsx +120 -120
  25. package/src/components/Chat/Chat.tsx +196 -195
  26. package/src/components/Chatdeprecated/ChatDeprecated.tsx +198 -198
  27. package/src/components/CheckButton.tsx +65 -65
  28. package/src/components/CircularController/CircularController.tsx +248 -248
  29. package/src/components/CraftBook/CraftBook.tsx +241 -241
  30. package/src/components/CraftBook/MockItems.ts +77 -77
  31. package/src/components/DraggableContainer.tsx +156 -156
  32. package/src/components/Dropdown.tsx +90 -90
  33. package/src/components/DropdownSelectorContainer.tsx +42 -42
  34. package/src/components/Equipment/EquipmentSet.tsx +191 -191
  35. package/src/components/HistoryDialog.tsx +104 -104
  36. package/src/components/Input.tsx +15 -15
  37. package/src/components/Item/Cards/ItemInfo.tsx +252 -252
  38. package/src/components/Item/Cards/ItemInfoDisplay.tsx +128 -128
  39. package/src/components/Item/Cards/ItemInfoWrapper.tsx +62 -62
  40. package/src/components/Item/Cards/ItemTooltip.tsx +83 -85
  41. package/src/components/Item/Cards/MobileItemTooltip.tsx +149 -134
  42. package/src/components/Item/Inventory/ErrorBoundary.tsx +42 -42
  43. package/src/components/Item/Inventory/ItemContainer.tsx +218 -215
  44. package/src/components/Item/Inventory/ItemContainerTypes.ts +6 -6
  45. package/src/components/Item/Inventory/ItemQuantitySelector.tsx +138 -138
  46. package/src/components/Item/Inventory/ItemSlot.tsx +546 -544
  47. package/src/components/Item/Inventory/itemContainerHelper.ts +156 -156
  48. package/src/components/ListMenu.tsx +63 -63
  49. package/src/components/Multitab/Tab.tsx +66 -66
  50. package/src/components/Multitab/TabBody.tsx +13 -13
  51. package/src/components/Multitab/TabsContainer.tsx +97 -97
  52. package/src/components/NPCDialog/NPCDialog.tsx +121 -121
  53. package/src/components/NPCDialog/NPCDialogText.tsx +113 -113
  54. package/src/components/NPCDialog/NPCMultiDialog.tsx +159 -159
  55. package/src/components/NPCDialog/QuestionDialog/QuestionDialog.tsx +237 -237
  56. package/src/components/ProgressBar.tsx +92 -92
  57. package/src/components/PropertySelect/PropertySelect.tsx +106 -106
  58. package/src/components/QuestInfo/QuestInfo.tsx +233 -233
  59. package/src/components/QuestList.tsx +135 -135
  60. package/src/components/RPGUIContainer.tsx +47 -47
  61. package/src/components/RPGUIForceRenderStart.tsx +45 -45
  62. package/src/components/RPGUIRoot.tsx +14 -14
  63. package/src/components/RadioButton.tsx +53 -53
  64. package/src/components/RadioInput/RadioButton.tsx +96 -96
  65. package/src/components/RadioInput/RadioInput.tsx +102 -102
  66. package/src/components/RadioInput/instruments.ts +15 -15
  67. package/src/components/RangeSlider.tsx +78 -78
  68. package/src/components/RelativeListMenu.tsx +83 -83
  69. package/src/components/ScrollList.tsx +79 -79
  70. package/src/components/Shortcuts/Shortcuts.tsx +151 -151
  71. package/src/components/Shortcuts/ShortcutsSetter.tsx +132 -132
  72. package/src/components/Shortcuts/SingleShortcut.ts +62 -62
  73. package/src/components/SimpleProgressBar.tsx +62 -62
  74. package/src/components/SkillProgressBar.tsx +133 -133
  75. package/src/components/SkillsContainer.tsx +206 -206
  76. package/src/components/Spellbook/Spell.tsx +201 -201
  77. package/src/components/Spellbook/Spellbook.tsx +153 -153
  78. package/src/components/Spellbook/constants.ts +8 -8
  79. package/src/components/Spellbook/mockSpells.ts +60 -60
  80. package/src/components/StaticBook/StaticBook.tsx +103 -103
  81. package/src/components/TextArea.tsx +11 -11
  82. package/src/components/TimeWidget/DayNightPeriod/DayNightPeriod.tsx +35 -35
  83. package/src/components/TimeWidget/TimeWidget.tsx +65 -65
  84. package/src/components/TradingMenu/TradingItemRow.tsx +198 -198
  85. package/src/components/TradingMenu/TradingMenu.tsx +216 -216
  86. package/src/components/TradingMenu/items.mock.ts +48 -48
  87. package/src/components/Truncate.tsx +25 -25
  88. package/src/components/itemSelector/ItemSelector.tsx +136 -136
  89. package/src/components/shared/Column.tsx +16 -16
  90. package/src/components/shared/Ellipsis.tsx +65 -65
  91. package/src/components/shared/SpriteFromAtlas.tsx +104 -104
  92. package/src/components/typography/DynamicText.tsx +49 -49
  93. package/src/constants/uiColors.ts +20 -20
  94. package/src/constants/uiDevices.ts +3 -3
  95. package/src/constants/uiFonts.ts +12 -12
  96. package/src/hooks/useEventListener.ts +21 -21
  97. package/src/hooks/useOutsideAlerter.ts +25 -25
  98. package/src/index.tsx +40 -40
  99. package/src/libs/StringHelpers.ts +3 -3
  100. package/src/mocks/atlas/entities/entities.json +20215 -20215
  101. package/src/mocks/atlas/icons/icons.json +735 -735
  102. package/src/mocks/atlas/items/items.json +12086 -12086
  103. package/src/mocks/equipmentSet.mocks.ts +391 -391
  104. package/src/mocks/itemContainer.mocks.ts +563 -563
  105. package/src/mocks/skills.mocks.ts +128 -128
  106. package/src/stories/Arrow.stories.tsx +26 -26
  107. package/src/stories/Button.stories.tsx +36 -36
  108. package/src/stories/CharacterSelection.stories.tsx +45 -45
  109. package/src/stories/CharacterStatus.stories.tsx +29 -29
  110. package/src/stories/Chat.stories.tsx +187 -187
  111. package/src/stories/ChatDeprecated.stories.tsx +170 -170
  112. package/src/stories/CheckButton.stories.tsx +48 -48
  113. package/src/stories/CircullarController.stories.tsx +37 -37
  114. package/src/stories/CraftBook.stories.tsx +42 -42
  115. package/src/stories/DayNightPeriod.stories.tsx +27 -27
  116. package/src/stories/DraggableContainer.stories.tsx +28 -28
  117. package/src/stories/Dropdown.stories.tsx +46 -46
  118. package/src/stories/DropdownSelectorContainer.stories.tsx +41 -41
  119. package/src/stories/EquipmentSet.stories.tsx +65 -65
  120. package/src/stories/HistoryDialog.stories.tsx +61 -61
  121. package/src/stories/ItemContainer.stories.tsx +200 -200
  122. package/src/stories/ItemInfoDisplay.stories.tsx +33 -33
  123. package/src/stories/ItemQuantitySelector.stories.tsx +26 -26
  124. package/src/stories/ItemSelector.stories.tsx +77 -77
  125. package/src/stories/ItemTradingComponent.stories.tsx +35 -35
  126. package/src/stories/ListMenu.stories.tsx +56 -56
  127. package/src/stories/Multitab.stories.tsx +51 -51
  128. package/src/stories/NPCDialog.stories.tsx +130 -130
  129. package/src/stories/NPCMultiDialog.stories.tsx +71 -71
  130. package/src/stories/ProgressBar.stories.tsx +23 -23
  131. package/src/stories/PropertySelect.stories.tsx +40 -40
  132. package/src/stories/QuestInfo.stories.tsx +107 -107
  133. package/src/stories/QuestList.stories.tsx +82 -82
  134. package/src/stories/RPGUIContainers.stories.tsx +42 -42
  135. package/src/stories/RadioButton.stories.tsx +49 -49
  136. package/src/stories/RadioInput.stories.tsx +34 -34
  137. package/src/stories/RangeSlider.stories.tsx +64 -64
  138. package/src/stories/ScrollList.stories.tsx +85 -85
  139. package/src/stories/Shortcuts.stories.tsx +39 -39
  140. package/src/stories/SimpleProgressBar.stories.tsx +22 -22
  141. package/src/stories/SkillProgressBar.stories.tsx +34 -34
  142. package/src/stories/SkillsContainer.stories.tsx +35 -35
  143. package/src/stories/Spellbook.stories.tsx +104 -104
  144. package/src/stories/StaticBook.stories.tsx +32 -32
  145. package/src/stories/Text.stories.tsx +42 -42
  146. package/src/stories/TimeWidget.stories.tsx +27 -27
  147. package/src/stories/TradingMenu.stories.tsx +47 -47
  148. package/src/types/eventTypes.ts +4 -4
  149. package/src/types/index.d.ts +2 -2
@@ -1,11 +1,12 @@
1
1
  import React, { Component, useState, useEffect, useRef, useMemo, Fragment } from 'react';
2
2
  import styled from 'styled-components';
3
- import { GRID_WIDTH, GRID_HEIGHT, ShortcutType, getItemTextureKeyPath, ItemContainerType, ItemType, ItemSocketEventsDisplayLabels, ActionsForInventory, ActionsForEquipmentSet, ActionsForLoot, ActionsForMapContainer, ItemRarities, ItemSubType, ItemSlotType, getSPForLevel, PeriodOfDay, isMobileOrTablet } from '@rpg-engine/shared';
3
+ import { GRID_WIDTH, GRID_HEIGHT, ShortcutType, getItemTextureKeyPath, ItemContainerType, ItemType, ItemSocketEventsDisplayLabels, ActionsForInventory, ActionsForEquipmentSet, ActionsForLoot, ActionsForMapContainer, ItemRarities, ItemSubType, ItemSlotType, isMobileOrTablet, getSPForLevel, PeriodOfDay } from '@rpg-engine/shared';
4
4
  import dayjs from 'dayjs';
5
5
  import { ErrorBoundary as ErrorBoundary$1 } from 'react-error-boundary';
6
6
  import { RxPaperPlane } from 'react-icons/rx';
7
7
  import Draggable from 'react-draggable';
8
8
  import { v4 } from 'uuid';
9
+ import ReactDOM from 'react-dom';
9
10
  import { camelCase } from 'lodash-es';
10
11
  import { observer } from 'mobx-react-lite';
11
12
  import 'rpgui/rpgui.min.css';
@@ -32738,6 +32739,7 @@ var Chat = function Chat(_ref) {
32738
32739
  };
32739
32740
  var handleSubmit = function handleSubmit(event) {
32740
32741
  event.preventDefault();
32742
+ if (!message || message.trim() === '') return;
32741
32743
  onSendChatMessage(message);
32742
32744
  setMessage('');
32743
32745
  };
@@ -33360,6 +33362,18 @@ var DropdownOptions = /*#__PURE__*/styled.ul.withConfig({
33360
33362
  return props.opened ? 'block' : 'none';
33361
33363
  });
33362
33364
 
33365
+ var modalRoot = /*#__PURE__*/document.getElementById('modal-root');
33366
+ var ModalPortal = function ModalPortal(_ref) {
33367
+ var children = _ref.children;
33368
+ return ReactDOM.createPortal(React.createElement(Container$8, {
33369
+ className: "rpgui-content"
33370
+ }, children), modalRoot);
33371
+ };
33372
+ var Container$8 = /*#__PURE__*/styled.div.withConfig({
33373
+ displayName: "ModalPortal__Container",
33374
+ componentId: "sc-dgmp04-0"
33375
+ })(["position:static !important;"]);
33376
+
33363
33377
  var RelativeListMenu = function RelativeListMenu(_ref) {
33364
33378
  var options = _ref.options,
33365
33379
  onSelected = _ref.onSelected,
@@ -33381,7 +33395,7 @@ var RelativeListMenu = function RelativeListMenu(_ref) {
33381
33395
  document.removeEventListener('clickOutside', function (_e) {});
33382
33396
  };
33383
33397
  }, []);
33384
- return React.createElement(Container$8, {
33398
+ return React.createElement(Container$9, {
33385
33399
  fontSize: fontSize,
33386
33400
  ref: ref
33387
33401
  }, React.createElement("ul", {
@@ -33398,7 +33412,7 @@ var RelativeListMenu = function RelativeListMenu(_ref) {
33398
33412
  }, (params == null ? void 0 : params.text) || 'No text');
33399
33413
  })));
33400
33414
  };
33401
- var Container$8 = /*#__PURE__*/styled.div.withConfig({
33415
+ var Container$9 = /*#__PURE__*/styled.div.withConfig({
33402
33416
  displayName: "RelativeListMenu__Container",
33403
33417
  componentId: "sc-7hohf-0"
33404
33418
  })(["position:absolute;top:1rem;left:4rem;display:flex;flex-direction:column;width:max-content;justify-content:start;align-items:flex-start;li{font-size:", "em;}"], function (props) {
@@ -33420,24 +33434,17 @@ var MobileItemTooltip = function MobileItemTooltip(_ref) {
33420
33434
  options = _ref.options,
33421
33435
  onSelected = _ref.onSelected;
33422
33436
  var ref = useRef(null);
33423
- useEffect(function () {
33424
- var current = ref.current;
33425
- if (current) {
33426
- // Adjust the position to be on whole window
33427
- var rect = current.getBoundingClientRect();
33428
- var x = -rect.x * 100 / (scale * 100);
33429
- var y = -rect.y * 100 / (scale * 100);
33430
- current.style.transform = "translate(" + x + "px, " + y + "px)";
33431
- current.style.opacity = '0.92';
33432
- }
33433
- return;
33434
- }, []);
33435
- return React.createElement(Container$9, {
33437
+ var handleFadeOut = function handleFadeOut() {
33438
+ var _ref$current;
33439
+ (_ref$current = ref.current) == null ? void 0 : _ref$current.classList.add('fadeOut');
33440
+ };
33441
+ return React.createElement(ModalPortal, null, React.createElement(Container$a, {
33436
33442
  ref: ref,
33437
33443
  onTouchEnd: function onTouchEnd() {
33444
+ handleFadeOut();
33438
33445
  setTimeout(function () {
33439
33446
  closeTooltip();
33440
- }, 10);
33447
+ }, 100);
33441
33448
  },
33442
33449
  scale: scale
33443
33450
  }, React.createElement(ItemInfoDisplay, {
@@ -33450,24 +33457,19 @@ var MobileItemTooltip = function MobileItemTooltip(_ref) {
33450
33457
  return React.createElement(Option, {
33451
33458
  key: option.id,
33452
33459
  onTouchEnd: function onTouchEnd() {
33460
+ handleFadeOut();
33453
33461
  setTimeout(function () {
33454
33462
  onSelected == null ? void 0 : onSelected(option.id);
33455
33463
  closeTooltip();
33456
- }, 10);
33464
+ }, 100);
33457
33465
  }
33458
33466
  }, option.text);
33459
- })));
33467
+ }))));
33460
33468
  };
33461
- var Container$9 = /*#__PURE__*/styled.div.withConfig({
33469
+ var Container$a = /*#__PURE__*/styled.div.withConfig({
33462
33470
  displayName: "MobileItemTooltip__Container",
33463
33471
  componentId: "sc-ku4p1j-0"
33464
- })(["position:fixed;z-index:50;left:0;top:0;opacity:0;width:", ";height:", ";background-color:rgba(0 0 0 / 0.5);display:flex;justify-content:center;align-items:center;gap:0.5rem;@media (max-width:580px){flex-direction:column;}"], function (_ref2) {
33465
- var scale = _ref2.scale;
33466
- return "calc(100vw * 100 / " + scale * 100 + ")";
33467
- }, function (_ref3) {
33468
- var scale = _ref3.scale;
33469
- return "calc(100vh * 100 / " + scale * 100 + ")";
33470
- });
33472
+ })(["position:absolute;z-index:100;left:0;top:0;width:100vw;height:100vh;background-color:rgba(0 0 0 / 0.5);display:flex;justify-content:center;align-items:center;gap:0.5rem;transition:opacity 0.08s;animation:fadeIn 0.1s forwards;@keyframes fadeIn{0%{opacity:0;}100%{opacity:0.92;}}@keyframes fadeOut{0%{opacity:0.92;}100%{opacity:0;}}&.fadeOut{animation:fadeOut 0.1s forwards;}@media (max-width:580px){flex-direction:column;}"]);
33471
33473
  var OptionsContainer = /*#__PURE__*/styled.div.withConfig({
33472
33474
  displayName: "MobileItemTooltip__OptionsContainer",
33473
33475
  componentId: "sc-ku4p1j-1"
@@ -33475,7 +33477,7 @@ var OptionsContainer = /*#__PURE__*/styled.div.withConfig({
33475
33477
  var Option = /*#__PURE__*/styled.button.withConfig({
33476
33478
  displayName: "MobileItemTooltip__Option",
33477
33479
  componentId: "sc-ku4p1j-2"
33478
- })(["padding:1rem;background-color:#333;color:white;border:none;border-radius:3px;width:8rem;transition:background-color 0.2s;&:hover{background-color:#555;}@media (max-width:580px){padding:1rem 0.5rem;}"]);
33480
+ })(["padding:1rem;background-color:#333;color:white;border:none;border-radius:3px;width:8rem;transition:background-color 0.1s;&:hover{background-color:#555;}@media (max-width:580px){padding:1rem 0.5rem;}"]);
33479
33481
 
33480
33482
  var generateContextMenuListOptions = function generateContextMenuListOptions(actionsByTypeList) {
33481
33483
  var contextMenu = actionsByTypeList.map(function (action) {
@@ -33670,7 +33672,7 @@ var ItemSlot = /*#__PURE__*/observer(function (_ref) {
33670
33672
  maxWidth: "48px"
33671
33673
  }, React.createElement(ItemQty, {
33672
33674
  className: qtyClassName
33673
- }, " ", stackQty, " ")));
33675
+ }, Math.round(stackQty * 100) / 100, ' ')));
33674
33676
  }
33675
33677
  return undefined;
33676
33678
  };
@@ -33764,7 +33766,7 @@ var ItemSlot = /*#__PURE__*/observer(function (_ref) {
33764
33766
  onDragEnd(quantity);
33765
33767
  }
33766
33768
  };
33767
- return React.createElement(Container$a, {
33769
+ return React.createElement(Container$b, {
33768
33770
  item: item,
33769
33771
  className: "rpgui-icon empty-slot",
33770
33772
  onMouseUp: function onMouseUp() {
@@ -33915,7 +33917,7 @@ var rarityColor = function rarityColor(item) {
33915
33917
  return null;
33916
33918
  }
33917
33919
  };
33918
- var Container$a = /*#__PURE__*/styled.div.withConfig({
33920
+ var Container$b = /*#__PURE__*/styled.div.withConfig({
33919
33921
  displayName: "ItemSlot__Container",
33920
33922
  componentId: "sc-l2j5ef-0"
33921
33923
  })(["margin:0.1rem;.sprite-from-atlas-img--item{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) {
@@ -34026,13 +34028,13 @@ var ItemInfo = function ItemInfo(_ref) {
34026
34028
  }));
34027
34029
  });
34028
34030
  };
34029
- return React.createElement(Container$b, {
34031
+ return React.createElement(Container$c, {
34030
34032
  item: item
34031
34033
  }, React.createElement(Header, null, React.createElement("div", null, React.createElement(Title$1, null, item.name), item.rarity !== 'Common' && React.createElement(Rarity, {
34032
34034
  item: item
34033
- }, item.rarity), React.createElement(Type, null, item.subType)), React.createElement(AllowedSlots, null, renderAvaibleSlots())), renderStatistics(), item.isTwoHanded && React.createElement(Statistic, null, "Two handed"), React.createElement(Description, null, item.description), item.maxStackSize && item.maxStackSize !== 1 && React.createElement(StackInfo, null, "x", (_item$stackQty = item.stackQty) != null ? _item$stackQty : 1, "(", item.maxStackSize, ")"), renderMissingStatistic().length > 0 && React.createElement(MissingStatistics, null, React.createElement(Statistic, null, "Equipped Diff"), itemToCompare && renderMissingStatistic()));
34035
+ }, item.rarity), React.createElement(Type, null, item.subType)), React.createElement(AllowedSlots, null, renderAvaibleSlots())), renderStatistics(), item.isTwoHanded && React.createElement(Statistic, null, "Two handed"), React.createElement(Description, null, item.description), item.maxStackSize && item.maxStackSize !== 1 && React.createElement(StackInfo, null, "x", Math.round(((_item$stackQty = item.stackQty) != null ? _item$stackQty : 1) * 100) / 100, "(", item.maxStackSize, ")"), renderMissingStatistic().length > 0 && React.createElement(MissingStatistics, null, React.createElement(Statistic, null, "Equipped Diff"), itemToCompare && renderMissingStatistic()));
34034
34036
  };
34035
- var Container$b = /*#__PURE__*/styled.div.withConfig({
34037
+ var Container$c = /*#__PURE__*/styled.div.withConfig({
34036
34038
  displayName: "ItemInfo__Container",
34037
34039
  componentId: "sc-1xm4q8k-0"
34038
34040
  })(["color:white;background-color:#222;border-radius:5px;padding:0.5rem;font-size:", ";border:3px solid ", ";height:max-content;width:15rem;@media (max-width:580px){width:80vw;}"], uiFonts.size.small, function (_ref2) {
@@ -34145,22 +34147,18 @@ var ItemTooltip = function ItemTooltip(_ref) {
34145
34147
  var ref = useRef(null);
34146
34148
  useEffect(function () {
34147
34149
  var current = ref.current;
34148
- var initialOffset;
34149
34150
  if (current) {
34150
34151
  var handleMouseMove = function handleMouseMove(event) {
34151
34152
  var clientX = event.clientX,
34152
34153
  clientY = event.clientY;
34153
34154
  // Adjust the position of the tooltip based on the mouse position
34154
34155
  var rect = current.getBoundingClientRect();
34155
- if (!initialOffset) {
34156
- initialOffset = rect;
34157
- }
34158
34156
  var tooltipWidth = rect.width;
34159
34157
  var tooltipHeight = rect.height;
34160
34158
  var isOffScreenRight = clientX + tooltipWidth + offset > window.innerWidth;
34161
34159
  var isOffScreenBottom = clientY + tooltipHeight + offset > window.innerHeight;
34162
- var x = (isOffScreenRight ? clientX - tooltipWidth - offset : clientX + offset) - initialOffset.x;
34163
- var y = (isOffScreenBottom ? clientY - tooltipHeight - offset : clientY + offset) - initialOffset.y;
34160
+ var x = isOffScreenRight ? clientX - tooltipWidth - offset : clientX + offset;
34161
+ var y = isOffScreenBottom ? clientY - tooltipHeight - offset : clientY + offset;
34164
34162
  current.style.transform = "translate(" + x + "px, " + y + "px)";
34165
34163
  current.style.opacity = '1';
34166
34164
  };
@@ -34171,19 +34169,19 @@ var ItemTooltip = function ItemTooltip(_ref) {
34171
34169
  }
34172
34170
  return;
34173
34171
  }, []);
34174
- return React.createElement(Container$c, {
34172
+ return React.createElement(ModalPortal, null, React.createElement(Container$d, {
34175
34173
  ref: ref
34176
34174
  }, React.createElement(ItemInfoDisplay, {
34177
34175
  item: item,
34178
34176
  atlasIMG: atlasIMG,
34179
34177
  atlasJSON: atlasJSON,
34180
34178
  equipmentSet: equipmentSet
34181
- }));
34179
+ })));
34182
34180
  };
34183
- var Container$c = /*#__PURE__*/styled.div.withConfig({
34181
+ var Container$d = /*#__PURE__*/styled.div.withConfig({
34184
34182
  displayName: "ItemTooltip__Container",
34185
34183
  componentId: "sc-11d9r7x-0"
34186
- })(["position:fixed;z-index:50;pointer-events:none;left:0;top:0;opacity:0;"]);
34184
+ })(["position:absolute;z-index:100;pointer-events:none;left:0;top:0;opacity:0;transition:opacity 0.08s;"]);
34187
34185
 
34188
34186
  var ItemInfoWrapper = function ItemInfoWrapper(_ref) {
34189
34187
  var children = _ref.children,
@@ -34525,230 +34523,770 @@ var EquipmentColumn = /*#__PURE__*/styled.div.withConfig({
34525
34523
  componentId: "sc-1wuddg2-1"
34526
34524
  })(["display:flex;justify-content:center;flex-wrap:wrap;flex-direction:column;touch-action:none;"]);
34527
34525
 
34528
- var SlotsContainer = function SlotsContainer(_ref) {
34529
- var children = _ref.children,
34530
- title = _ref.title,
34531
- onClose = _ref.onClose,
34532
- _onPositionChange = _ref.onPositionChange,
34533
- onOutsideClick = _ref.onOutsideClick,
34534
- initialPosition = _ref.initialPosition,
34535
- scale = _ref.scale;
34536
- return React.createElement(DraggableContainer, {
34537
- title: title,
34538
- type: RPGUIContainerTypes.Framed,
34539
- onCloseButton: function onCloseButton() {
34540
- if (onClose) {
34541
- onClose();
34526
+ var IS_MOBILE_OR_TABLET = /*#__PURE__*/isMobileOrTablet();
34527
+
34528
+ var chunkString = function chunkString(str, length) {
34529
+ return str.match(new RegExp('.{1,' + length + '}', 'g'));
34530
+ };
34531
+
34532
+ var DynamicText = function DynamicText(_ref) {
34533
+ var text = _ref.text,
34534
+ onFinish = _ref.onFinish,
34535
+ onStart = _ref.onStart;
34536
+ var _useState = useState(''),
34537
+ textState = _useState[0],
34538
+ setTextState = _useState[1];
34539
+ useEffect(function () {
34540
+ var i = 0;
34541
+ var interval = setInterval(function () {
34542
+ // on every interval, show one more character
34543
+ if (i === 0) {
34544
+ if (onStart) {
34545
+ onStart();
34546
+ }
34542
34547
  }
34543
- },
34544
- width: "400px",
34545
- cancelDrag: ".item-container-body, #shortcuts_list",
34546
- onPositionChange: function onPositionChange(_ref2) {
34547
- var x = _ref2.x,
34548
- y = _ref2.y;
34549
- if (_onPositionChange) {
34550
- _onPositionChange({
34551
- x: x,
34552
- y: y
34553
- });
34548
+ if (i < text.length) {
34549
+ setTextState(text.substring(0, i + 1));
34550
+ i++;
34551
+ } else {
34552
+ clearInterval(interval);
34553
+ if (onFinish) {
34554
+ onFinish();
34555
+ }
34554
34556
  }
34555
- },
34556
- onOutsideClick: onOutsideClick,
34557
- initialPosition: initialPosition,
34558
- scale: scale
34559
- }, children);
34557
+ }, 50);
34558
+ return function () {
34559
+ clearInterval(interval);
34560
+ };
34561
+ }, [text]);
34562
+ return React.createElement(TextContainer, null, textState);
34560
34563
  };
34564
+ var TextContainer = /*#__PURE__*/styled.p.withConfig({
34565
+ displayName: "DynamicText__TextContainer",
34566
+ componentId: "sc-1ggl9nd-0"
34567
+ })(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]);
34561
34568
 
34562
- var RangeSliderType;
34563
- (function (RangeSliderType) {
34564
- RangeSliderType["Slider"] = "rpgui-slider";
34565
- RangeSliderType["GoldSlider"] = "rpgui-slider golden";
34566
- })(RangeSliderType || (RangeSliderType = {}));
34567
- var RangeSlider = function RangeSlider(_ref) {
34568
- var type = _ref.type,
34569
- valueMin = _ref.valueMin,
34570
- valueMax = _ref.valueMax,
34571
- width = _ref.width,
34572
- _onChange = _ref.onChange,
34573
- value = _ref.value;
34574
- var sliderId = v4();
34575
- var containerRef = useRef(null);
34569
+ var img$6 = '';
34570
+
34571
+ var img$7 = '';
34572
+
34573
+ var NPCDialogText = function NPCDialogText(_ref) {
34574
+ var text = _ref.text,
34575
+ onClose = _ref.onClose,
34576
+ onEndStep = _ref.onEndStep,
34577
+ onStartStep = _ref.onStartStep,
34578
+ type = _ref.type;
34579
+ var windowSize = useRef([window.innerWidth, window.innerHeight]);
34580
+ function maxCharacters(width) {
34581
+ // Set the font size to 16 pixels
34582
+ var fontSize = 11.2;
34583
+ // Calculate the number of characters that can fit in one line
34584
+ var charactersPerLine = Math.floor(width / 2 / fontSize);
34585
+ // Calculate the number of lines that can fit in the div
34586
+ var linesPerDiv = Math.floor(180 / fontSize);
34587
+ // Calculate the maximum number of characters that can fit in the div
34588
+ var maxCharacters = charactersPerLine * linesPerDiv;
34589
+ // Return the maximum number of characters
34590
+ return Math.round(maxCharacters / 5);
34591
+ }
34592
+ var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
34576
34593
  var _useState = useState(0),
34577
- left = _useState[0],
34578
- setLeft = _useState[1];
34594
+ chunkIndex = _useState[0],
34595
+ setChunkIndex = _useState[1];
34596
+ var onHandleSpacePress = function onHandleSpacePress(event) {
34597
+ if (event.code === 'Space') {
34598
+ goToNextStep();
34599
+ }
34600
+ };
34601
+ var goToNextStep = function goToNextStep() {
34602
+ var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
34603
+ if (hasNextChunk) {
34604
+ setChunkIndex(function (prev) {
34605
+ return prev + 1;
34606
+ });
34607
+ } else {
34608
+ // if there's no more text chunks, close the dialog
34609
+ onClose();
34610
+ }
34611
+ };
34579
34612
  useEffect(function () {
34580
- var _containerRef$current;
34581
- var calculatedWidth = ((_containerRef$current = containerRef.current) == null ? void 0 : _containerRef$current.clientWidth) || 0;
34582
- setLeft(Math.max((value - valueMin) / (valueMax - valueMin) * (calculatedWidth - 35) + 10));
34583
- }, [value, valueMin, valueMax]);
34584
- var typeClass = type === RangeSliderType.GoldSlider ? 'golden' : '';
34585
- return React.createElement("div", {
34586
- style: {
34587
- width: width,
34588
- position: 'relative'
34613
+ document.addEventListener('keydown', onHandleSpacePress);
34614
+ return function () {
34615
+ return document.removeEventListener('keydown', onHandleSpacePress);
34616
+ };
34617
+ }, [chunkIndex]);
34618
+ var _useState2 = useState(false),
34619
+ showGoNextIndicator = _useState2[0],
34620
+ setShowGoNextIndicator = _useState2[1];
34621
+ return React.createElement(Container$e, null, React.createElement(DynamicText, {
34622
+ text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
34623
+ onFinish: function onFinish() {
34624
+ setShowGoNextIndicator(true);
34625
+ onEndStep && onEndStep();
34589
34626
  },
34590
- className: "rpgui-slider-container " + typeClass,
34591
- id: "rpgui-slider-" + sliderId,
34592
- ref: containerRef
34593
- }, React.createElement("div", {
34594
- style: {
34595
- pointerEvents: 'none'
34627
+ onStart: function onStart() {
34628
+ setShowGoNextIndicator(false);
34629
+ onStartStep && onStartStep();
34596
34630
  }
34597
- }, React.createElement("div", {
34598
- className: "rpgui-slider-track " + typeClass
34599
- }), React.createElement("div", {
34600
- className: "rpgui-slider-left-edge " + typeClass
34601
- }), React.createElement("div", {
34602
- className: "rpgui-slider-right-edge " + typeClass
34603
- }), React.createElement("div", {
34604
- className: "rpgui-slider-thumb " + typeClass,
34605
- style: {
34606
- left: left
34631
+ }), showGoNextIndicator && React.createElement(PressSpaceIndicator, {
34632
+ right: type === NPCDialogType.TextOnly ? '1rem' : '10.5rem',
34633
+ src: IS_MOBILE_OR_TABLET ? img$6 : img$7,
34634
+ onPointerDown: function onPointerDown() {
34635
+ goToNextStep();
34607
34636
  }
34608
- })), React.createElement(Input$1, {
34609
- type: "range",
34610
- style: {
34611
- width: width
34612
- },
34613
- min: valueMin,
34614
- max: valueMax,
34615
- onChange: function onChange(e) {
34616
- return _onChange(Number(e.target.value));
34617
- },
34618
- value: value,
34619
- className: "rpgui-cursor-point"
34620
34637
  }));
34621
34638
  };
34622
- var Input$1 = /*#__PURE__*/styled.input.withConfig({
34623
- displayName: "RangeSlider__Input",
34624
- componentId: "sc-v8mte9-0"
34625
- })(["opacity:0;position:absolute;width:100%;height:100%;top:0;left:0;margin-top:-5px;"]);
34639
+ var Container$e = /*#__PURE__*/styled.div.withConfig({
34640
+ displayName: "NPCDialogText__Container",
34641
+ componentId: "sc-1cxkdh9-0"
34642
+ })([""]);
34643
+ var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
34644
+ displayName: "NPCDialogText__PressSpaceIndicator",
34645
+ componentId: "sc-1cxkdh9-1"
34646
+ })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
34647
+ var right = _ref2.right;
34648
+ return right;
34649
+ });
34626
34650
 
34627
- var ItemQuantitySelector = function ItemQuantitySelector(_ref) {
34628
- var quantity = _ref.quantity,
34629
- onConfirm = _ref.onConfirm,
34651
+ //@ts-ignore
34652
+ var useEventListener = function useEventListener(type, handler, el) {
34653
+ if (el === void 0) {
34654
+ el = window;
34655
+ }
34656
+ var savedHandler = React.useRef();
34657
+ React.useEffect(function () {
34658
+ savedHandler.current = handler;
34659
+ }, [handler]);
34660
+ React.useEffect(function () {
34661
+ //@ts-ignore
34662
+ var listener = function listener(e) {
34663
+ return savedHandler.current(e);
34664
+ };
34665
+ el.addEventListener(type, listener);
34666
+ return function () {
34667
+ el.removeEventListener(type, listener);
34668
+ };
34669
+ }, [type, el]);
34670
+ };
34671
+
34672
+ var QuestionDialog = function QuestionDialog(_ref) {
34673
+ var questions = _ref.questions,
34674
+ answers = _ref.answers,
34630
34675
  onClose = _ref.onClose;
34631
- var _useState = useState(quantity),
34632
- value = _useState[0],
34633
- setValue = _useState[1];
34634
- var inputRef = useRef(null);
34676
+ var _useState = useState(questions[0]),
34677
+ currentQuestion = _useState[0],
34678
+ setCurrentQuestion = _useState[1];
34679
+ var _useState2 = useState(false),
34680
+ canShowAnswers = _useState2[0],
34681
+ setCanShowAnswers = _useState2[1];
34682
+ var onGetFirstAnswer = function onGetFirstAnswer() {
34683
+ if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {
34684
+ return null;
34685
+ }
34686
+ var firstAnswerId = currentQuestion.answerIds[0];
34687
+ return answers.find(function (answer) {
34688
+ return answer.id === firstAnswerId;
34689
+ });
34690
+ };
34691
+ var _useState3 = useState(onGetFirstAnswer()),
34692
+ currentAnswer = _useState3[0],
34693
+ setCurrentAnswer = _useState3[1];
34635
34694
  useEffect(function () {
34636
- if (inputRef.current) {
34637
- inputRef.current.focus();
34638
- inputRef.current.select();
34639
- var closeSelector = function closeSelector(e) {
34640
- if (e.key === 'Escape') {
34695
+ setCurrentAnswer(onGetFirstAnswer());
34696
+ }, [currentQuestion]);
34697
+ var onGetAnswers = function onGetAnswers(answerIds) {
34698
+ return answerIds.map(function (answerId) {
34699
+ return answers.find(function (answer) {
34700
+ return answer.id === answerId;
34701
+ });
34702
+ });
34703
+ };
34704
+ var onKeyPress = function onKeyPress(e) {
34705
+ switch (e.key) {
34706
+ case 'ArrowDown':
34707
+ // select next answer, if any.
34708
+ // if no next answer, select first answer
34709
+ // const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(
34710
+ // (answer) => answer?.id === currentAnswer!.id + 1
34711
+ // );
34712
+ var nextAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34713
+ return (answer == null ? void 0 : answer.id) === currentAnswer.id + 1;
34714
+ });
34715
+ var nextAnswerID = currentQuestion.answerIds[nextAnswerIndex];
34716
+ var nextAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34717
+ return (answer == null ? void 0 : answer.id) === nextAnswerID;
34718
+ });
34719
+ setCurrentAnswer(nextAnswer || onGetFirstAnswer());
34720
+ break;
34721
+ case 'ArrowUp':
34722
+ // select previous answer, if any.
34723
+ // if no previous answer, select last answer
34724
+ var previousAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34725
+ return (answer == null ? void 0 : answer.id) === currentAnswer.id - 1;
34726
+ });
34727
+ var previousAnswerID = currentQuestion.answerIds && currentQuestion.answerIds[previousAnswerIndex];
34728
+ var previousAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34729
+ return (answer == null ? void 0 : answer.id) === previousAnswerID;
34730
+ });
34731
+ if (previousAnswer) {
34732
+ setCurrentAnswer(previousAnswer);
34733
+ } else {
34734
+ setCurrentAnswer(onGetAnswers(currentQuestion.answerIds).pop());
34735
+ }
34736
+ break;
34737
+ case 'Enter':
34738
+ setCanShowAnswers(false);
34739
+ if (!(currentAnswer != null && currentAnswer.nextQuestionId)) {
34641
34740
  onClose();
34741
+ return;
34742
+ } else {
34743
+ setCurrentQuestion(questions.find(function (question) {
34744
+ return question.id === currentAnswer.nextQuestionId;
34745
+ }));
34642
34746
  }
34643
- };
34644
- document.addEventListener('keydown', closeSelector);
34645
- return function () {
34646
- document.removeEventListener('keydown', closeSelector);
34647
- };
34747
+ break;
34648
34748
  }
34649
- return function () {};
34650
- }, []);
34651
- return React.createElement(StyledContainer, {
34652
- type: RPGUIContainerTypes.Framed,
34653
- width: "25rem"
34654
- }, React.createElement(CloseButton$2, {
34655
- className: "container-close",
34656
- onPointerDown: onClose
34657
- }, "X"), React.createElement("h2", null, "Select quantity to move"), React.createElement(StyledForm, {
34658
- style: {
34659
- width: '100%'
34660
- },
34661
- onSubmit: function onSubmit(e) {
34662
- e.preventDefault();
34663
- var numberValue = Number(value);
34664
- if (Number.isNaN(numberValue)) {
34665
- return;
34666
- }
34667
- onConfirm(Math.max(1, Math.min(quantity, numberValue)));
34668
- },
34669
- noValidate: true
34670
- }, React.createElement(StyledInput, {
34671
- innerRef: inputRef,
34672
- placeholder: "Enter quantity",
34673
- type: "number",
34674
- min: 1,
34675
- max: quantity,
34676
- value: value,
34677
- onChange: function onChange(e) {
34678
- if (Number(e.target.value) >= quantity) {
34679
- setValue(quantity);
34680
- return;
34749
+ };
34750
+ useEventListener('keydown', onKeyPress);
34751
+ var onAnswerClick = function onAnswerClick(answer) {
34752
+ setCanShowAnswers(false);
34753
+ if (answer.nextQuestionId) {
34754
+ // if there is a next question, go to it
34755
+ setCurrentQuestion(questions.find(function (question) {
34756
+ return question.id === answer.nextQuestionId;
34757
+ }));
34758
+ } else {
34759
+ // else, finish dialog!
34760
+ onClose();
34761
+ }
34762
+ };
34763
+ var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
34764
+ var answerIds = currentQuestion.answerIds;
34765
+ if (!answerIds) {
34766
+ return null;
34767
+ }
34768
+ var answers = onGetAnswers(answerIds);
34769
+ if (!answers) {
34770
+ return null;
34771
+ }
34772
+ return answers.map(function (answer) {
34773
+ var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
34774
+ var selectedColor = isSelected ? 'yellow' : 'white';
34775
+ if (answer) {
34776
+ return React.createElement(AnswerRow, {
34777
+ key: "answer_" + answer.id
34778
+ }, React.createElement(AnswerSelectedIcon, {
34779
+ color: selectedColor
34780
+ }, isSelected ? 'X' : null), React.createElement(Answer, {
34781
+ key: answer.id,
34782
+ onPointerDown: function onPointerDown() {
34783
+ return onAnswerClick(answer);
34784
+ },
34785
+ color: selectedColor
34786
+ }, answer.text));
34681
34787
  }
34682
- setValue(e.target.value);
34788
+ return null;
34789
+ });
34790
+ };
34791
+ return React.createElement(Container$f, null, React.createElement(QuestionContainer, null, React.createElement(DynamicText, {
34792
+ text: currentQuestion.text,
34793
+ onStart: function onStart() {
34794
+ return setCanShowAnswers(false);
34683
34795
  },
34684
- onBlur: function onBlur(e) {
34685
- var newValue = Math.max(1, Math.min(quantity, Number(e.target.value)));
34686
- setValue(newValue);
34796
+ onFinish: function onFinish() {
34797
+ return setCanShowAnswers(true);
34687
34798
  }
34688
- }), React.createElement(RangeSlider, {
34689
- type: RangeSliderType.Slider,
34690
- valueMin: 1,
34691
- valueMax: quantity,
34692
- width: "100%",
34693
- onChange: setValue,
34694
- value: value
34695
- }), React.createElement(Button, {
34696
- buttonType: ButtonTypes.RPGUIButton,
34697
- type: "submit"
34698
- }, "Confirm")));
34799
+ })), canShowAnswers && React.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
34699
34800
  };
34700
- var StyledContainer = /*#__PURE__*/styled(RPGUIContainer).withConfig({
34701
- displayName: "ItemQuantitySelector__StyledContainer",
34702
- componentId: "sc-yfdtpn-0"
34703
- })(["display:flex;flex-direction:column;align-items:center;"]);
34704
- var StyledForm = /*#__PURE__*/styled.form.withConfig({
34705
- displayName: "ItemQuantitySelector__StyledForm",
34706
- componentId: "sc-yfdtpn-1"
34707
- })(["display:flex;flex-direction:column;align-items:center;width:100%;"]);
34708
- var StyledInput = /*#__PURE__*/styled(Input).withConfig({
34709
- displayName: "ItemQuantitySelector__StyledInput",
34710
- componentId: "sc-yfdtpn-2"
34711
- })(["text-align:center;&::-webkit-outer-spin-button,&::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}&[type='number']{-moz-appearance:textfield;}"]);
34712
- var CloseButton$2 = /*#__PURE__*/styled.div.withConfig({
34713
- displayName: "ItemQuantitySelector__CloseButton",
34714
- componentId: "sc-yfdtpn-3"
34715
- })(["position:absolute;top:3px;right:0px;color:white;z-index:22;font-size:0.8rem;"]);
34801
+ var Container$f = /*#__PURE__*/styled.div.withConfig({
34802
+ displayName: "QuestionDialog__Container",
34803
+ componentId: "sc-bxc5u0-0"
34804
+ })(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
34805
+ var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
34806
+ displayName: "QuestionDialog__QuestionContainer",
34807
+ componentId: "sc-bxc5u0-1"
34808
+ })(["flex:100%;width:100%;"]);
34809
+ var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
34810
+ displayName: "QuestionDialog__AnswersContainer",
34811
+ componentId: "sc-bxc5u0-2"
34812
+ })(["flex:100%;"]);
34813
+ var Answer = /*#__PURE__*/styled.p.withConfig({
34814
+ displayName: "QuestionDialog__Answer",
34815
+ componentId: "sc-bxc5u0-3"
34816
+ })(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
34817
+ return props.color;
34818
+ });
34819
+ var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
34820
+ displayName: "QuestionDialog__AnswerSelectedIcon",
34821
+ componentId: "sc-bxc5u0-4"
34822
+ })(["flex:5% 0 0;color:", " !important;"], function (props) {
34823
+ return props.color;
34824
+ });
34825
+ var AnswerRow = /*#__PURE__*/styled.div.withConfig({
34826
+ displayName: "QuestionDialog__AnswerRow",
34827
+ componentId: "sc-bxc5u0-5"
34828
+ })(["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;}"]);
34716
34829
 
34717
- var ShortcutsSetter = function ShortcutsSetter(_ref) {
34718
- var setSettingShortcutIndex = _ref.setSettingShortcutIndex,
34719
- settingShortcutIndex = _ref.settingShortcutIndex,
34720
- shortcuts = _ref.shortcuts,
34721
- removeShortcut = _ref.removeShortcut,
34722
- atlasJSON = _ref.atlasJSON,
34723
- atlasIMG = _ref.atlasIMG;
34724
- var getContent = function getContent(index) {
34725
- var _shortcuts$index, _shortcuts$index3;
34726
- if (((_shortcuts$index = shortcuts[index]) == null ? void 0 : _shortcuts$index.type) === ShortcutType.Item) {
34727
- var _shortcuts$index2;
34728
- var _payload = (_shortcuts$index2 = shortcuts[index]) == null ? void 0 : _shortcuts$index2.payload;
34729
- if (!_payload) return null;
34730
- return React.createElement(SpriteFromAtlas, {
34731
- atlasIMG: atlasIMG,
34732
- atlasJSON: atlasJSON,
34733
- spriteKey: getItemTextureKeyPath({
34734
- key: _payload.texturePath,
34735
- texturePath: _payload.texturePath,
34736
- stackQty: _payload.stackQty || 1
34737
- }, atlasJSON),
34738
- width: 32,
34739
- height: 32,
34740
- imgScale: 1.6,
34741
- imgStyle: {
34742
- left: '5px'
34743
- }
34744
- });
34745
- }
34746
- var payload = (_shortcuts$index3 = shortcuts[index]) == null ? void 0 : _shortcuts$index3.payload;
34747
- return React.createElement("span", null, payload == null ? void 0 : payload.magicWords.split(' ').map(function (word) {
34748
- return word[0];
34749
- }));
34750
- };
34751
- return React.createElement(Container$d, null, React.createElement("p", null, "Shortcuts:"), React.createElement(List, {
34830
+ var img$8 = '';
34831
+
34832
+ var NPCDialogType;
34833
+ (function (NPCDialogType) {
34834
+ NPCDialogType["TextOnly"] = "TextOnly";
34835
+ NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
34836
+ })(NPCDialogType || (NPCDialogType = {}));
34837
+ var NPCDialog = function NPCDialog(_ref) {
34838
+ var text = _ref.text,
34839
+ type = _ref.type,
34840
+ _onClose = _ref.onClose,
34841
+ imagePath = _ref.imagePath,
34842
+ _ref$isQuestionDialog = _ref.isQuestionDialog,
34843
+ isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
34844
+ questions = _ref.questions,
34845
+ answers = _ref.answers;
34846
+ return React.createElement(RPGUIContainer, {
34847
+ type: RPGUIContainerTypes.FramedGold,
34848
+ width: isQuestionDialog ? '600px' : '80%',
34849
+ height: '180px'
34850
+ }, isQuestionDialog && questions && answers ? React.createElement(React.Fragment, null, React.createElement(TextContainer$1, {
34851
+ flex: type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'
34852
+ }, React.createElement(QuestionDialog, {
34853
+ questions: questions,
34854
+ answers: answers,
34855
+ onClose: function onClose() {
34856
+ if (_onClose) {
34857
+ _onClose();
34858
+ }
34859
+ }
34860
+ })), type === NPCDialogType.TextAndThumbnail && React.createElement(ThumbnailContainer, null, React.createElement(NPCThumbnail, {
34861
+ src: imagePath || img$8
34862
+ }))) : React.createElement(React.Fragment, null, React.createElement(Container$g, null, React.createElement(TextContainer$1, {
34863
+ flex: type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'
34864
+ }, React.createElement(NPCDialogText, {
34865
+ type: type,
34866
+ text: text || 'No text provided.',
34867
+ onClose: function onClose() {
34868
+ if (_onClose) {
34869
+ _onClose();
34870
+ }
34871
+ }
34872
+ })), type === NPCDialogType.TextAndThumbnail && React.createElement(ThumbnailContainer, null, React.createElement(NPCThumbnail, {
34873
+ src: imagePath || img$8
34874
+ })))));
34875
+ };
34876
+ var Container$g = /*#__PURE__*/styled.div.withConfig({
34877
+ displayName: "NPCDialog__Container",
34878
+ componentId: "sc-1b4aw74-0"
34879
+ })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
34880
+ var TextContainer$1 = /*#__PURE__*/styled.div.withConfig({
34881
+ displayName: "NPCDialog__TextContainer",
34882
+ componentId: "sc-1b4aw74-1"
34883
+ })(["flex:", " 0 0;width:355px;"], function (_ref2) {
34884
+ var flex = _ref2.flex;
34885
+ return flex;
34886
+ });
34887
+ var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
34888
+ displayName: "NPCDialog__ThumbnailContainer",
34889
+ componentId: "sc-1b4aw74-2"
34890
+ })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
34891
+ var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
34892
+ displayName: "NPCDialog__NPCThumbnail",
34893
+ componentId: "sc-1b4aw74-3"
34894
+ })(["image-rendering:pixelated;height:128px;width:128px;"]);
34895
+
34896
+ var ImgSide;
34897
+ (function (ImgSide) {
34898
+ ImgSide["right"] = "right";
34899
+ ImgSide["left"] = "left";
34900
+ })(ImgSide || (ImgSide = {}));
34901
+ var NPCMultiDialog = function NPCMultiDialog(_ref) {
34902
+ var _textAndTypeArray$sli;
34903
+ var _onClose = _ref.onClose,
34904
+ textAndTypeArray = _ref.textAndTypeArray;
34905
+ var _useState = useState(false),
34906
+ showGoNextIndicator = _useState[0],
34907
+ setShowGoNextIndicator = _useState[1];
34908
+ var _useState2 = useState(0),
34909
+ slide = _useState2[0],
34910
+ setSlide = _useState2[1];
34911
+ var onHandleSpacePress = function onHandleSpacePress(event) {
34912
+ if (event.code === 'Space') {
34913
+ if (slide < (textAndTypeArray == null ? void 0 : textAndTypeArray.length) - 1) {
34914
+ setSlide(function (prev) {
34915
+ return prev + 1;
34916
+ });
34917
+ } else {
34918
+ // if there's no more text chunks, close the dialog
34919
+ _onClose();
34920
+ }
34921
+ }
34922
+ };
34923
+ useEffect(function () {
34924
+ document.addEventListener('keydown', onHandleSpacePress);
34925
+ return function () {
34926
+ return document.removeEventListener('keydown', onHandleSpacePress);
34927
+ };
34928
+ }, [slide]);
34929
+ return React.createElement(RPGUIContainer, {
34930
+ type: RPGUIContainerTypes.FramedGold,
34931
+ width: '50%',
34932
+ height: '180px'
34933
+ }, React.createElement(React.Fragment, null, React.createElement(Container$h, null, ((_textAndTypeArray$sli = textAndTypeArray[slide]) == null ? void 0 : _textAndTypeArray$sli.imageSide) === 'right' && React.createElement(React.Fragment, null, React.createElement(TextContainer$2, {
34934
+ flex: '70%'
34935
+ }, React.createElement(NPCDialogText, {
34936
+ onStartStep: function onStartStep() {
34937
+ return setShowGoNextIndicator(false);
34938
+ },
34939
+ onEndStep: function onEndStep() {
34940
+ return setShowGoNextIndicator(true);
34941
+ },
34942
+ text: textAndTypeArray[slide].text || 'No text provided.',
34943
+ onClose: function onClose() {
34944
+ if (_onClose) {
34945
+ _onClose();
34946
+ }
34947
+ }
34948
+ })), React.createElement(ThumbnailContainer$1, null, React.createElement(NPCThumbnail$1, {
34949
+ src: textAndTypeArray[slide].imagePath || img$8
34950
+ })), showGoNextIndicator && React.createElement(PressSpaceIndicator$1, {
34951
+ right: '10.5rem',
34952
+ src: img$7
34953
+ })), textAndTypeArray[slide].imageSide === 'left' && React.createElement(React.Fragment, null, React.createElement(ThumbnailContainer$1, null, React.createElement(NPCThumbnail$1, {
34954
+ src: textAndTypeArray[slide].imagePath || img$8
34955
+ })), React.createElement(TextContainer$2, {
34956
+ flex: '70%'
34957
+ }, React.createElement(NPCDialogText, {
34958
+ onStartStep: function onStartStep() {
34959
+ return setShowGoNextIndicator(false);
34960
+ },
34961
+ onEndStep: function onEndStep() {
34962
+ return setShowGoNextIndicator(true);
34963
+ },
34964
+ text: textAndTypeArray[slide].text || 'No text provided.',
34965
+ onClose: function onClose() {
34966
+ if (_onClose) {
34967
+ _onClose();
34968
+ }
34969
+ }
34970
+ })), showGoNextIndicator && React.createElement(PressSpaceIndicator$1, {
34971
+ right: '1rem',
34972
+ src: img$7
34973
+ }))), ")"));
34974
+ };
34975
+ var Container$h = /*#__PURE__*/styled.div.withConfig({
34976
+ displayName: "NPCMultiDialog__Container",
34977
+ componentId: "sc-rvu5wg-0"
34978
+ })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
34979
+ var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
34980
+ displayName: "NPCMultiDialog__TextContainer",
34981
+ componentId: "sc-rvu5wg-1"
34982
+ })(["flex:", " 0 0;width:355px;"], function (_ref2) {
34983
+ var flex = _ref2.flex;
34984
+ return flex;
34985
+ });
34986
+ var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
34987
+ displayName: "NPCMultiDialog__ThumbnailContainer",
34988
+ componentId: "sc-rvu5wg-2"
34989
+ })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
34990
+ var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
34991
+ displayName: "NPCMultiDialog__NPCThumbnail",
34992
+ componentId: "sc-rvu5wg-3"
34993
+ })(["image-rendering:pixelated;height:128px;width:128px;"]);
34994
+ var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
34995
+ displayName: "NPCMultiDialog__PressSpaceIndicator",
34996
+ componentId: "sc-rvu5wg-4"
34997
+ })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref3) {
34998
+ var right = _ref3.right;
34999
+ return right;
35000
+ });
35001
+
35002
+ var HistoryDialog = function HistoryDialog(_ref) {
35003
+ var backgroundImgPath = _ref.backgroundImgPath,
35004
+ fullCoverBackground = _ref.fullCoverBackground,
35005
+ questions = _ref.questions,
35006
+ answers = _ref.answers,
35007
+ text = _ref.text,
35008
+ imagePath = _ref.imagePath,
35009
+ textAndTypeArray = _ref.textAndTypeArray,
35010
+ onClose = _ref.onClose;
35011
+ var _useState = useState(0),
35012
+ img = _useState[0],
35013
+ setImage = _useState[1];
35014
+ var onHandleSpacePress = function onHandleSpacePress(event) {
35015
+ if (event.code === 'Space') {
35016
+ if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
35017
+ setImage(function (prev) {
35018
+ return prev + 1;
35019
+ });
35020
+ } else {
35021
+ // if there's no more text chunks, close the dialog
35022
+ onClose();
35023
+ }
35024
+ }
35025
+ };
35026
+ useEffect(function () {
35027
+ document.addEventListener('keydown', onHandleSpacePress);
35028
+ return function () {
35029
+ return document.removeEventListener('keydown', onHandleSpacePress);
35030
+ };
35031
+ }, [backgroundImgPath]);
35032
+ return React.createElement(BackgroundContainer, {
35033
+ imgPath: backgroundImgPath[img],
35034
+ fullImg: fullCoverBackground
35035
+ }, React.createElement(DialogContainer, null, textAndTypeArray ? React.createElement(NPCMultiDialog, {
35036
+ textAndTypeArray: textAndTypeArray,
35037
+ onClose: onClose
35038
+ }) : questions && answers ? React.createElement(QuestionDialog, {
35039
+ questions: questions,
35040
+ answers: answers,
35041
+ onClose: onClose
35042
+ }) : text && imagePath ? React.createElement(NPCDialog, {
35043
+ text: text,
35044
+ imagePath: imagePath,
35045
+ onClose: onClose,
35046
+ type: NPCDialogType.TextAndThumbnail
35047
+ }) : React.createElement(NPCDialog, {
35048
+ text: text,
35049
+ onClose: onClose,
35050
+ type: NPCDialogType.TextOnly
35051
+ })));
35052
+ };
35053
+ var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
35054
+ displayName: "HistoryDialog__BackgroundContainer",
35055
+ componentId: "sc-u6oe75-0"
35056
+ })(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
35057
+ return props.imgPath;
35058
+ }, function (props) {
35059
+ return props.imgPath ? 'cover' : 'auto';
35060
+ });
35061
+ var DialogContainer = /*#__PURE__*/styled.div.withConfig({
35062
+ displayName: "HistoryDialog__DialogContainer",
35063
+ componentId: "sc-u6oe75-1"
35064
+ })(["display:flex;justify-content:center;padding-top:200px;"]);
35065
+
35066
+ var SlotsContainer = function SlotsContainer(_ref) {
35067
+ var children = _ref.children,
35068
+ title = _ref.title,
35069
+ onClose = _ref.onClose,
35070
+ _onPositionChange = _ref.onPositionChange,
35071
+ onOutsideClick = _ref.onOutsideClick,
35072
+ initialPosition = _ref.initialPosition,
35073
+ scale = _ref.scale;
35074
+ return React.createElement(DraggableContainer, {
35075
+ title: title,
35076
+ type: RPGUIContainerTypes.Framed,
35077
+ onCloseButton: function onCloseButton() {
35078
+ if (onClose) {
35079
+ onClose();
35080
+ }
35081
+ },
35082
+ width: "400px",
35083
+ cancelDrag: ".item-container-body, #shortcuts_list",
35084
+ onPositionChange: function onPositionChange(_ref2) {
35085
+ var x = _ref2.x,
35086
+ y = _ref2.y;
35087
+ if (_onPositionChange) {
35088
+ _onPositionChange({
35089
+ x: x,
35090
+ y: y
35091
+ });
35092
+ }
35093
+ },
35094
+ onOutsideClick: onOutsideClick,
35095
+ initialPosition: initialPosition,
35096
+ scale: scale
35097
+ }, children);
35098
+ };
35099
+
35100
+ var RangeSliderType;
35101
+ (function (RangeSliderType) {
35102
+ RangeSliderType["Slider"] = "rpgui-slider";
35103
+ RangeSliderType["GoldSlider"] = "rpgui-slider golden";
35104
+ })(RangeSliderType || (RangeSliderType = {}));
35105
+ var RangeSlider = function RangeSlider(_ref) {
35106
+ var type = _ref.type,
35107
+ valueMin = _ref.valueMin,
35108
+ valueMax = _ref.valueMax,
35109
+ width = _ref.width,
35110
+ _onChange = _ref.onChange,
35111
+ value = _ref.value;
35112
+ var sliderId = v4();
35113
+ var containerRef = useRef(null);
35114
+ var _useState = useState(0),
35115
+ left = _useState[0],
35116
+ setLeft = _useState[1];
35117
+ useEffect(function () {
35118
+ var _containerRef$current;
35119
+ var calculatedWidth = ((_containerRef$current = containerRef.current) == null ? void 0 : _containerRef$current.clientWidth) || 0;
35120
+ setLeft(Math.max((value - valueMin) / (valueMax - valueMin) * (calculatedWidth - 35) + 10));
35121
+ }, [value, valueMin, valueMax]);
35122
+ var typeClass = type === RangeSliderType.GoldSlider ? 'golden' : '';
35123
+ return React.createElement("div", {
35124
+ style: {
35125
+ width: width,
35126
+ position: 'relative'
35127
+ },
35128
+ className: "rpgui-slider-container " + typeClass,
35129
+ id: "rpgui-slider-" + sliderId,
35130
+ ref: containerRef
35131
+ }, React.createElement("div", {
35132
+ style: {
35133
+ pointerEvents: 'none'
35134
+ }
35135
+ }, React.createElement("div", {
35136
+ className: "rpgui-slider-track " + typeClass
35137
+ }), React.createElement("div", {
35138
+ className: "rpgui-slider-left-edge " + typeClass
35139
+ }), React.createElement("div", {
35140
+ className: "rpgui-slider-right-edge " + typeClass
35141
+ }), React.createElement("div", {
35142
+ className: "rpgui-slider-thumb " + typeClass,
35143
+ style: {
35144
+ left: left
35145
+ }
35146
+ })), React.createElement(Input$1, {
35147
+ type: "range",
35148
+ style: {
35149
+ width: width
35150
+ },
35151
+ min: valueMin,
35152
+ max: valueMax,
35153
+ onChange: function onChange(e) {
35154
+ return _onChange(Number(e.target.value));
35155
+ },
35156
+ value: value,
35157
+ className: "rpgui-cursor-point"
35158
+ }));
35159
+ };
35160
+ var Input$1 = /*#__PURE__*/styled.input.withConfig({
35161
+ displayName: "RangeSlider__Input",
35162
+ componentId: "sc-v8mte9-0"
35163
+ })(["opacity:0;position:absolute;width:100%;height:100%;top:0;left:0;margin-top:-5px;"]);
35164
+
35165
+ var ItemQuantitySelector = function ItemQuantitySelector(_ref) {
35166
+ var quantity = _ref.quantity,
35167
+ onConfirm = _ref.onConfirm,
35168
+ onClose = _ref.onClose;
35169
+ var _useState = useState(quantity),
35170
+ value = _useState[0],
35171
+ setValue = _useState[1];
35172
+ var inputRef = useRef(null);
35173
+ useEffect(function () {
35174
+ if (inputRef.current) {
35175
+ inputRef.current.focus();
35176
+ inputRef.current.select();
35177
+ var closeSelector = function closeSelector(e) {
35178
+ if (e.key === 'Escape') {
35179
+ onClose();
35180
+ }
35181
+ };
35182
+ document.addEventListener('keydown', closeSelector);
35183
+ return function () {
35184
+ document.removeEventListener('keydown', closeSelector);
35185
+ };
35186
+ }
35187
+ return function () {};
35188
+ }, []);
35189
+ return React.createElement(StyledContainer, {
35190
+ type: RPGUIContainerTypes.Framed,
35191
+ width: "25rem"
35192
+ }, React.createElement(CloseButton$2, {
35193
+ className: "container-close",
35194
+ onPointerDown: onClose
35195
+ }, "X"), React.createElement("h2", null, "Select quantity to move"), React.createElement(StyledForm, {
35196
+ style: {
35197
+ width: '100%'
35198
+ },
35199
+ onSubmit: function onSubmit(e) {
35200
+ e.preventDefault();
35201
+ var numberValue = Number(value);
35202
+ if (Number.isNaN(numberValue)) {
35203
+ return;
35204
+ }
35205
+ onConfirm(Math.max(1, Math.min(quantity, numberValue)));
35206
+ },
35207
+ noValidate: true
35208
+ }, React.createElement(StyledInput, {
35209
+ innerRef: inputRef,
35210
+ placeholder: "Enter quantity",
35211
+ type: "number",
35212
+ min: 1,
35213
+ max: quantity,
35214
+ value: value,
35215
+ onChange: function onChange(e) {
35216
+ if (Number(e.target.value) >= quantity) {
35217
+ setValue(quantity);
35218
+ return;
35219
+ }
35220
+ setValue(e.target.value);
35221
+ },
35222
+ onBlur: function onBlur(e) {
35223
+ var newValue = Math.max(1, Math.min(quantity, Number(e.target.value)));
35224
+ setValue(newValue);
35225
+ }
35226
+ }), React.createElement(RangeSlider, {
35227
+ type: RangeSliderType.Slider,
35228
+ valueMin: 1,
35229
+ valueMax: quantity,
35230
+ width: "100%",
35231
+ onChange: setValue,
35232
+ value: value
35233
+ }), React.createElement(Button, {
35234
+ buttonType: ButtonTypes.RPGUIButton,
35235
+ type: "submit"
35236
+ }, "Confirm")));
35237
+ };
35238
+ var StyledContainer = /*#__PURE__*/styled(RPGUIContainer).withConfig({
35239
+ displayName: "ItemQuantitySelector__StyledContainer",
35240
+ componentId: "sc-yfdtpn-0"
35241
+ })(["display:flex;flex-direction:column;align-items:center;"]);
35242
+ var StyledForm = /*#__PURE__*/styled.form.withConfig({
35243
+ displayName: "ItemQuantitySelector__StyledForm",
35244
+ componentId: "sc-yfdtpn-1"
35245
+ })(["display:flex;flex-direction:column;align-items:center;width:100%;"]);
35246
+ var StyledInput = /*#__PURE__*/styled(Input).withConfig({
35247
+ displayName: "ItemQuantitySelector__StyledInput",
35248
+ componentId: "sc-yfdtpn-2"
35249
+ })(["text-align:center;&::-webkit-outer-spin-button,&::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}&[type='number']{-moz-appearance:textfield;}"]);
35250
+ var CloseButton$2 = /*#__PURE__*/styled.div.withConfig({
35251
+ displayName: "ItemQuantitySelector__CloseButton",
35252
+ componentId: "sc-yfdtpn-3"
35253
+ })(["position:absolute;top:3px;right:0px;color:white;z-index:22;font-size:0.8rem;"]);
35254
+
35255
+ var ShortcutsSetter = function ShortcutsSetter(_ref) {
35256
+ var setSettingShortcutIndex = _ref.setSettingShortcutIndex,
35257
+ settingShortcutIndex = _ref.settingShortcutIndex,
35258
+ shortcuts = _ref.shortcuts,
35259
+ removeShortcut = _ref.removeShortcut,
35260
+ atlasJSON = _ref.atlasJSON,
35261
+ atlasIMG = _ref.atlasIMG;
35262
+ var getContent = function getContent(index) {
35263
+ var _shortcuts$index, _shortcuts$index3;
35264
+ if (((_shortcuts$index = shortcuts[index]) == null ? void 0 : _shortcuts$index.type) === ShortcutType.Item) {
35265
+ var _shortcuts$index2;
35266
+ var _payload = (_shortcuts$index2 = shortcuts[index]) == null ? void 0 : _shortcuts$index2.payload;
35267
+ if (!_payload) return null;
35268
+ return React.createElement(SpriteFromAtlas, {
35269
+ atlasIMG: atlasIMG,
35270
+ atlasJSON: atlasJSON,
35271
+ spriteKey: getItemTextureKeyPath({
35272
+ key: _payload.texturePath,
35273
+ texturePath: _payload.texturePath,
35274
+ stackQty: _payload.stackQty || 1
35275
+ }, atlasJSON),
35276
+ width: 32,
35277
+ height: 32,
35278
+ imgScale: 1.6,
35279
+ imgStyle: {
35280
+ left: '5px'
35281
+ }
35282
+ });
35283
+ }
35284
+ var payload = (_shortcuts$index3 = shortcuts[index]) == null ? void 0 : _shortcuts$index3.payload;
35285
+ return React.createElement("span", null, payload == null ? void 0 : payload.magicWords.split(' ').map(function (word) {
35286
+ return word[0];
35287
+ }));
35288
+ };
35289
+ return React.createElement(Container$i, null, React.createElement("p", null, "Shortcuts:"), React.createElement(List, {
34752
35290
  id: "shortcuts_list"
34753
35291
  }, Array.from({
34754
35292
  length: 6
@@ -34764,7 +35302,7 @@ var ShortcutsSetter = function ShortcutsSetter(_ref) {
34764
35302
  }, getContent(i));
34765
35303
  })));
34766
35304
  };
34767
- var Container$d = /*#__PURE__*/styled.div.withConfig({
35305
+ var Container$i = /*#__PURE__*/styled.div.withConfig({
34768
35306
  displayName: "ShortcutsSetter__Container",
34769
35307
  componentId: "sc-xuouuf-0"
34770
35308
  })(["p{margin:0;margin-left:0.5rem;}"]);
@@ -34881,7 +35419,7 @@ var ItemContainer$1 = function ItemContainer(_ref) {
34881
35419
  atlasJSON: atlasJSON
34882
35420
  }), React.createElement(ItemsContainer, {
34883
35421
  className: "item-container-body"
34884
- }, onRenderSlots())), quantitySelect.isOpen && React.createElement(QuantitySelectorContainer, null, React.createElement(ItemQuantitySelector, {
35422
+ }, onRenderSlots())), quantitySelect.isOpen && React.createElement(ModalPortal, null, React.createElement(QuantitySelectorContainer, null, React.createElement(ItemQuantitySelector, {
34885
35423
  quantity: quantitySelect.maxQuantity,
34886
35424
  onConfirm: function onConfirm(quantity) {
34887
35425
  quantitySelect.callback(quantity);
@@ -34899,7 +35437,7 @@ var ItemContainer$1 = function ItemContainer(_ref) {
34899
35437
  callback: function callback() {}
34900
35438
  });
34901
35439
  }
34902
- })));
35440
+ }))));
34903
35441
  };
34904
35442
  var ItemsContainer = /*#__PURE__*/styled.div.withConfig({
34905
35443
  displayName: "ItemContainer__ItemsContainer",
@@ -35001,7 +35539,7 @@ var ListMenu = function ListMenu(_ref) {
35001
35539
  onSelected = _ref.onSelected,
35002
35540
  x = _ref.x,
35003
35541
  y = _ref.y;
35004
- return React.createElement(Container$e, {
35542
+ return React.createElement(Container$j, {
35005
35543
  x: x,
35006
35544
  y: y
35007
35545
  }, React.createElement("ul", {
@@ -35018,7 +35556,7 @@ var ListMenu = function ListMenu(_ref) {
35018
35556
  }, (params == null ? void 0 : params.text) || 'No text');
35019
35557
  })));
35020
35558
  };
35021
- var Container$e = /*#__PURE__*/styled.div.withConfig({
35559
+ var Container$j = /*#__PURE__*/styled.div.withConfig({
35022
35560
  displayName: "ListMenu__Container",
35023
35561
  componentId: "sc-i9097t-0"
35024
35562
  })(["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) {
@@ -35031,332 +35569,6 @@ var ListElement$1 = /*#__PURE__*/styled.li.withConfig({
35031
35569
  componentId: "sc-i9097t-1"
35032
35570
  })(["margin-right:0.5rem;"]);
35033
35571
 
35034
- var img$6 = '';
35035
-
35036
- var img$7 = '';
35037
-
35038
- var ImgSide;
35039
- (function (ImgSide) {
35040
- ImgSide["right"] = "right";
35041
- ImgSide["left"] = "left";
35042
- })(ImgSide || (ImgSide = {}));
35043
- var NPCMultiDialog = function NPCMultiDialog(_ref) {
35044
- var _textAndTypeArray$sli;
35045
- var _onClose = _ref.onClose,
35046
- textAndTypeArray = _ref.textAndTypeArray;
35047
- var _useState = useState(false),
35048
- showGoNextIndicator = _useState[0],
35049
- setShowGoNextIndicator = _useState[1];
35050
- var _useState2 = useState(0),
35051
- slide = _useState2[0],
35052
- setSlide = _useState2[1];
35053
- var onHandleSpacePress = function onHandleSpacePress(event) {
35054
- if (event.code === 'Space') {
35055
- if (slide < (textAndTypeArray == null ? void 0 : textAndTypeArray.length) - 1) {
35056
- setSlide(function (prev) {
35057
- return prev + 1;
35058
- });
35059
- } else {
35060
- // if there's no more text chunks, close the dialog
35061
- _onClose();
35062
- }
35063
- }
35064
- };
35065
- useEffect(function () {
35066
- document.addEventListener('keydown', onHandleSpacePress);
35067
- return function () {
35068
- return document.removeEventListener('keydown', onHandleSpacePress);
35069
- };
35070
- }, [slide]);
35071
- return React.createElement(RPGUIContainer, {
35072
- type: RPGUIContainerTypes.FramedGold,
35073
- width: '50%',
35074
- height: '180px'
35075
- }, React.createElement(React.Fragment, null, React.createElement(Container$f, null, ((_textAndTypeArray$sli = textAndTypeArray[slide]) == null ? void 0 : _textAndTypeArray$sli.imageSide) === 'right' && React.createElement(React.Fragment, null, React.createElement(TextContainer, {
35076
- flex: '70%'
35077
- }, React.createElement(NPCDialogText, {
35078
- onStartStep: function onStartStep() {
35079
- return setShowGoNextIndicator(false);
35080
- },
35081
- onEndStep: function onEndStep() {
35082
- return setShowGoNextIndicator(true);
35083
- },
35084
- text: textAndTypeArray[slide].text || 'No text provided.',
35085
- onClose: function onClose() {
35086
- if (_onClose) {
35087
- _onClose();
35088
- }
35089
- }
35090
- })), React.createElement(ThumbnailContainer, null, React.createElement(NPCThumbnail, {
35091
- src: textAndTypeArray[slide].imagePath || img$6
35092
- })), showGoNextIndicator && React.createElement(PressSpaceIndicator, {
35093
- right: '10.5rem',
35094
- src: img$7
35095
- })), textAndTypeArray[slide].imageSide === 'left' && React.createElement(React.Fragment, null, React.createElement(ThumbnailContainer, null, React.createElement(NPCThumbnail, {
35096
- src: textAndTypeArray[slide].imagePath || img$6
35097
- })), React.createElement(TextContainer, {
35098
- flex: '70%'
35099
- }, React.createElement(NPCDialogText, {
35100
- onStartStep: function onStartStep() {
35101
- return setShowGoNextIndicator(false);
35102
- },
35103
- onEndStep: function onEndStep() {
35104
- return setShowGoNextIndicator(true);
35105
- },
35106
- text: textAndTypeArray[slide].text || 'No text provided.',
35107
- onClose: function onClose() {
35108
- if (_onClose) {
35109
- _onClose();
35110
- }
35111
- }
35112
- })), showGoNextIndicator && React.createElement(PressSpaceIndicator, {
35113
- right: '1rem',
35114
- src: img$7
35115
- }))), ")"));
35116
- };
35117
- var Container$f = /*#__PURE__*/styled.div.withConfig({
35118
- displayName: "NPCMultiDialog__Container",
35119
- componentId: "sc-rvu5wg-0"
35120
- })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
35121
- var TextContainer = /*#__PURE__*/styled.div.withConfig({
35122
- displayName: "NPCMultiDialog__TextContainer",
35123
- componentId: "sc-rvu5wg-1"
35124
- })(["flex:", " 0 0;width:355px;"], function (_ref2) {
35125
- var flex = _ref2.flex;
35126
- return flex;
35127
- });
35128
- var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
35129
- displayName: "NPCMultiDialog__ThumbnailContainer",
35130
- componentId: "sc-rvu5wg-2"
35131
- })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
35132
- var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
35133
- displayName: "NPCMultiDialog__NPCThumbnail",
35134
- componentId: "sc-rvu5wg-3"
35135
- })(["image-rendering:pixelated;height:128px;width:128px;"]);
35136
- var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
35137
- displayName: "NPCMultiDialog__PressSpaceIndicator",
35138
- componentId: "sc-rvu5wg-4"
35139
- })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref3) {
35140
- var right = _ref3.right;
35141
- return right;
35142
- });
35143
-
35144
- //@ts-ignore
35145
- var useEventListener = function useEventListener(type, handler, el) {
35146
- if (el === void 0) {
35147
- el = window;
35148
- }
35149
- var savedHandler = React.useRef();
35150
- React.useEffect(function () {
35151
- savedHandler.current = handler;
35152
- }, [handler]);
35153
- React.useEffect(function () {
35154
- //@ts-ignore
35155
- var listener = function listener(e) {
35156
- return savedHandler.current(e);
35157
- };
35158
- el.addEventListener(type, listener);
35159
- return function () {
35160
- el.removeEventListener(type, listener);
35161
- };
35162
- }, [type, el]);
35163
- };
35164
-
35165
- var DynamicText = function DynamicText(_ref) {
35166
- var text = _ref.text,
35167
- onFinish = _ref.onFinish,
35168
- onStart = _ref.onStart;
35169
- var _useState = useState(''),
35170
- textState = _useState[0],
35171
- setTextState = _useState[1];
35172
- useEffect(function () {
35173
- var i = 0;
35174
- var interval = setInterval(function () {
35175
- // on every interval, show one more character
35176
- if (i === 0) {
35177
- if (onStart) {
35178
- onStart();
35179
- }
35180
- }
35181
- if (i < text.length) {
35182
- setTextState(text.substring(0, i + 1));
35183
- i++;
35184
- } else {
35185
- clearInterval(interval);
35186
- if (onFinish) {
35187
- onFinish();
35188
- }
35189
- }
35190
- }, 50);
35191
- return function () {
35192
- clearInterval(interval);
35193
- };
35194
- }, [text]);
35195
- return React.createElement(TextContainer$1, null, textState);
35196
- };
35197
- var TextContainer$1 = /*#__PURE__*/styled.p.withConfig({
35198
- displayName: "DynamicText__TextContainer",
35199
- componentId: "sc-1ggl9nd-0"
35200
- })(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]);
35201
-
35202
- var QuestionDialog = function QuestionDialog(_ref) {
35203
- var questions = _ref.questions,
35204
- answers = _ref.answers,
35205
- onClose = _ref.onClose;
35206
- var _useState = useState(questions[0]),
35207
- currentQuestion = _useState[0],
35208
- setCurrentQuestion = _useState[1];
35209
- var _useState2 = useState(false),
35210
- canShowAnswers = _useState2[0],
35211
- setCanShowAnswers = _useState2[1];
35212
- var onGetFirstAnswer = function onGetFirstAnswer() {
35213
- if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {
35214
- return null;
35215
- }
35216
- var firstAnswerId = currentQuestion.answerIds[0];
35217
- return answers.find(function (answer) {
35218
- return answer.id === firstAnswerId;
35219
- });
35220
- };
35221
- var _useState3 = useState(onGetFirstAnswer()),
35222
- currentAnswer = _useState3[0],
35223
- setCurrentAnswer = _useState3[1];
35224
- useEffect(function () {
35225
- setCurrentAnswer(onGetFirstAnswer());
35226
- }, [currentQuestion]);
35227
- var onGetAnswers = function onGetAnswers(answerIds) {
35228
- return answerIds.map(function (answerId) {
35229
- return answers.find(function (answer) {
35230
- return answer.id === answerId;
35231
- });
35232
- });
35233
- };
35234
- var onKeyPress = function onKeyPress(e) {
35235
- switch (e.key) {
35236
- case 'ArrowDown':
35237
- // select next answer, if any.
35238
- // if no next answer, select first answer
35239
- // const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(
35240
- // (answer) => answer?.id === currentAnswer!.id + 1
35241
- // );
35242
- var nextAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
35243
- return (answer == null ? void 0 : answer.id) === currentAnswer.id + 1;
35244
- });
35245
- var nextAnswerID = currentQuestion.answerIds[nextAnswerIndex];
35246
- var nextAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
35247
- return (answer == null ? void 0 : answer.id) === nextAnswerID;
35248
- });
35249
- setCurrentAnswer(nextAnswer || onGetFirstAnswer());
35250
- break;
35251
- case 'ArrowUp':
35252
- // select previous answer, if any.
35253
- // if no previous answer, select last answer
35254
- var previousAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
35255
- return (answer == null ? void 0 : answer.id) === currentAnswer.id - 1;
35256
- });
35257
- var previousAnswerID = currentQuestion.answerIds && currentQuestion.answerIds[previousAnswerIndex];
35258
- var previousAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
35259
- return (answer == null ? void 0 : answer.id) === previousAnswerID;
35260
- });
35261
- if (previousAnswer) {
35262
- setCurrentAnswer(previousAnswer);
35263
- } else {
35264
- setCurrentAnswer(onGetAnswers(currentQuestion.answerIds).pop());
35265
- }
35266
- break;
35267
- case 'Enter':
35268
- setCanShowAnswers(false);
35269
- if (!(currentAnswer != null && currentAnswer.nextQuestionId)) {
35270
- onClose();
35271
- return;
35272
- } else {
35273
- setCurrentQuestion(questions.find(function (question) {
35274
- return question.id === currentAnswer.nextQuestionId;
35275
- }));
35276
- }
35277
- break;
35278
- }
35279
- };
35280
- useEventListener('keydown', onKeyPress);
35281
- var onAnswerClick = function onAnswerClick(answer) {
35282
- setCanShowAnswers(false);
35283
- if (answer.nextQuestionId) {
35284
- // if there is a next question, go to it
35285
- setCurrentQuestion(questions.find(function (question) {
35286
- return question.id === answer.nextQuestionId;
35287
- }));
35288
- } else {
35289
- // else, finish dialog!
35290
- onClose();
35291
- }
35292
- };
35293
- var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
35294
- var answerIds = currentQuestion.answerIds;
35295
- if (!answerIds) {
35296
- return null;
35297
- }
35298
- var answers = onGetAnswers(answerIds);
35299
- if (!answers) {
35300
- return null;
35301
- }
35302
- return answers.map(function (answer) {
35303
- var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
35304
- var selectedColor = isSelected ? 'yellow' : 'white';
35305
- if (answer) {
35306
- return React.createElement(AnswerRow, {
35307
- key: "answer_" + answer.id
35308
- }, React.createElement(AnswerSelectedIcon, {
35309
- color: selectedColor
35310
- }, isSelected ? 'X' : null), React.createElement(Answer, {
35311
- key: answer.id,
35312
- onPointerDown: function onPointerDown() {
35313
- return onAnswerClick(answer);
35314
- },
35315
- color: selectedColor
35316
- }, answer.text));
35317
- }
35318
- return null;
35319
- });
35320
- };
35321
- return React.createElement(Container$g, null, React.createElement(QuestionContainer, null, React.createElement(DynamicText, {
35322
- text: currentQuestion.text,
35323
- onStart: function onStart() {
35324
- return setCanShowAnswers(false);
35325
- },
35326
- onFinish: function onFinish() {
35327
- return setCanShowAnswers(true);
35328
- }
35329
- })), canShowAnswers && React.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
35330
- };
35331
- var Container$g = /*#__PURE__*/styled.div.withConfig({
35332
- displayName: "QuestionDialog__Container",
35333
- componentId: "sc-bxc5u0-0"
35334
- })(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
35335
- var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
35336
- displayName: "QuestionDialog__QuestionContainer",
35337
- componentId: "sc-bxc5u0-1"
35338
- })(["flex:100%;width:100%;"]);
35339
- var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
35340
- displayName: "QuestionDialog__AnswersContainer",
35341
- componentId: "sc-bxc5u0-2"
35342
- })(["flex:100%;"]);
35343
- var Answer = /*#__PURE__*/styled.p.withConfig({
35344
- displayName: "QuestionDialog__Answer",
35345
- componentId: "sc-bxc5u0-3"
35346
- })(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
35347
- return props.color;
35348
- });
35349
- var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
35350
- displayName: "QuestionDialog__AnswerSelectedIcon",
35351
- componentId: "sc-bxc5u0-4"
35352
- })(["flex:5% 0 0;color:", " !important;"], function (props) {
35353
- return props.color;
35354
- });
35355
- var AnswerRow = /*#__PURE__*/styled.div.withConfig({
35356
- displayName: "QuestionDialog__AnswerRow",
35357
- componentId: "sc-bxc5u0-5"
35358
- })(["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;}"]);
35359
-
35360
35572
  var ProgressBar = function ProgressBar(_ref) {
35361
35573
  var max = _ref.max,
35362
35574
  value = _ref.value,
@@ -35374,7 +35586,7 @@ var ProgressBar = function ProgressBar(_ref) {
35374
35586
  }
35375
35587
  return value * 100 / max;
35376
35588
  };
35377
- return React.createElement(Container$h, {
35589
+ return React.createElement(Container$k, {
35378
35590
  className: "rpgui-progress",
35379
35591
  "data-value": calculatePercentageValue(max, value) / 100,
35380
35592
  "data-rpguitype": "progress",
@@ -35403,7 +35615,7 @@ var TextOverlay$1 = /*#__PURE__*/styled.div.withConfig({
35403
35615
  displayName: "ProgressBar__TextOverlay",
35404
35616
  componentId: "sc-qa6fzh-1"
35405
35617
  })(["width:100%;position:relative;"]);
35406
- var Container$h = /*#__PURE__*/styled.div.withConfig({
35618
+ var Container$k = /*#__PURE__*/styled.div.withConfig({
35407
35619
  displayName: "ProgressBar__Container",
35408
35620
  componentId: "sc-qa6fzh-2"
35409
35621
  })(["display:flex;flex-direction:column;min-width:", "px;width:", "%;justify-content:start;align-items:flex-start;", ""], function (props) {
@@ -35414,7 +35626,7 @@ var Container$h = /*#__PURE__*/styled.div.withConfig({
35414
35626
  return props.style;
35415
35627
  });
35416
35628
 
35417
- var img$8 = '';
35629
+ var img$9 = '';
35418
35630
 
35419
35631
  var QuestInfo = function QuestInfo(_ref) {
35420
35632
  var quests = _ref.quests,
@@ -35458,7 +35670,7 @@ var QuestInfo = function QuestInfo(_ref) {
35458
35670
  }), React.createElement(QuestContainer, null, React.createElement(TitleContainer$1, {
35459
35671
  className: "drag-handler"
35460
35672
  }, React.createElement(Title$4, null, React.createElement(Thumbnail, {
35461
- src: quests[currentIndex].thumbnail || img$8
35673
+ src: quests[currentIndex].thumbnail || img$9
35462
35674
  }), quests[currentIndex].title), React.createElement(QuestSplitDiv, null, React.createElement("hr", {
35463
35675
  className: "golden"
35464
35676
  }))), React.createElement(Content, null, React.createElement("p", null, quests[currentIndex].description)), React.createElement(QuestColumn, {
@@ -35477,7 +35689,7 @@ var QuestInfo = function QuestInfo(_ref) {
35477
35689
  })))) : React.createElement(QuestsContainer, null, React.createElement(QuestContainer, null, React.createElement(TitleContainer$1, {
35478
35690
  className: "drag-handler"
35479
35691
  }, React.createElement(Title$4, null, React.createElement(Thumbnail, {
35480
- src: quests[0].thumbnail || img$8
35692
+ src: quests[0].thumbnail || img$9
35481
35693
  }), quests[0].title), React.createElement(QuestSplitDiv, null, React.createElement("hr", {
35482
35694
  className: "golden"
35483
35695
  }))), React.createElement(Content, null, React.createElement("p", null, quests[0].description)), React.createElement(QuestColumn, {
@@ -35728,7 +35940,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
35728
35940
  bgColor = _ref$bgColor === void 0 ? 'red' : _ref$bgColor,
35729
35941
  _ref$margin = _ref.margin,
35730
35942
  margin = _ref$margin === void 0 ? 20 : _ref$margin;
35731
- return React.createElement(Container$i, {
35943
+ return React.createElement(Container$l, {
35732
35944
  className: "simple-progress-bar"
35733
35945
  }, React.createElement(ProgressBarContainer, {
35734
35946
  margin: margin
@@ -35737,7 +35949,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
35737
35949
  bgColor: bgColor
35738
35950
  }))));
35739
35951
  };
35740
- var Container$i = /*#__PURE__*/styled.div.withConfig({
35952
+ var Container$l = /*#__PURE__*/styled.div.withConfig({
35741
35953
  displayName: "SimpleProgressBar__Container",
35742
35954
  componentId: "sc-mbeil3-0"
35743
35955
  })(["display:flex;justify-content:center;align-items:center;width:100%;"]);
@@ -35968,7 +36180,7 @@ var Spell = function Spell(_ref) {
35968
36180
  isSettingShortcut = _ref.isSettingShortcut,
35969
36181
  minMagicLevelRequired = _ref.minMagicLevelRequired;
35970
36182
  var disabled = isSettingShortcut ? charMagicLevel < minMagicLevelRequired : manaCost > charMana || charMagicLevel < minMagicLevelRequired;
35971
- return React.createElement(Container$j, {
36183
+ return React.createElement(Container$m, {
35972
36184
  disabled: disabled,
35973
36185
  onPointerDown: onPointerDown == null ? void 0 : onPointerDown.bind(null, spellKey),
35974
36186
  isSettingShortcut: isSettingShortcut && !disabled,
@@ -35981,7 +36193,7 @@ var Spell = function Spell(_ref) {
35981
36193
  className: "mana"
35982
36194
  }, manaCost)));
35983
36195
  };
35984
- var Container$j = /*#__PURE__*/styled.button.withConfig({
36196
+ var Container$m = /*#__PURE__*/styled.button.withConfig({
35985
36197
  displayName: "Spell__Container",
35986
36198
  componentId: "sc-j96fa2-0"
35987
36199
  })(["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) {
@@ -36068,7 +36280,7 @@ var Spellbook = function Spellbook(_ref) {
36068
36280
  height: "inherit",
36069
36281
  cancelDrag: "#spellbook-search, #shortcuts_list, .spell",
36070
36282
  scale: scale
36071
- }, React.createElement(Container$k, null, React.createElement(Title$7, null, "Learned Spells"), React.createElement(ShortcutsSetter, {
36283
+ }, React.createElement(Container$n, null, React.createElement(Title$7, null, "Learned Spells"), React.createElement(ShortcutsSetter, {
36072
36284
  setSettingShortcutIndex: setSettingShortcutIndex,
36073
36285
  settingShortcutIndex: settingShortcutIndex,
36074
36286
  shortcuts: shortcuts,
@@ -36100,7 +36312,7 @@ var Title$7 = /*#__PURE__*/styled.h1.withConfig({
36100
36312
  displayName: "Spellbook__Title",
36101
36313
  componentId: "sc-r02nfq-0"
36102
36314
  })(["font-size:", " !important;margin-bottom:0 !important;"], uiFonts.size.large);
36103
- var Container$k = /*#__PURE__*/styled.div.withConfig({
36315
+ var Container$n = /*#__PURE__*/styled.div.withConfig({
36104
36316
  displayName: "Spellbook__Container",
36105
36317
  componentId: "sc-r02nfq-1"
36106
36318
  })(["width:100%;height:100%;color:white;display:flex;flex-direction:column;"]);
@@ -36114,16 +36326,16 @@ var TextArea = function TextArea(_ref) {
36114
36326
  return React.createElement("textarea", Object.assign({}, props));
36115
36327
  };
36116
36328
 
36117
- var img$9 = '';
36329
+ var img$a = '';
36118
36330
 
36119
- var img$a = '';
36331
+ var img$b = '';
36120
36332
 
36121
- var img$b = '';
36333
+ var img$c = '';
36122
36334
 
36123
36335
  var DayNightPeriod = function DayNightPeriod(_ref) {
36124
36336
  var _periodOfDaySrcFiles;
36125
36337
  var periodOfDay = _ref.periodOfDay;
36126
- var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[PeriodOfDay.Morning] = img$a, _periodOfDaySrcFiles[PeriodOfDay.Afternoon] = img$9, _periodOfDaySrcFiles[PeriodOfDay.Night] = img$b, _periodOfDaySrcFiles);
36338
+ var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[PeriodOfDay.Morning] = img$b, _periodOfDaySrcFiles[PeriodOfDay.Afternoon] = img$a, _periodOfDaySrcFiles[PeriodOfDay.Night] = img$c, _periodOfDaySrcFiles);
36127
36339
  return React.createElement(GifContainer, null, React.createElement("img", {
36128
36340
  src: periodOfDaySrcFiles[periodOfDay]
36129
36341
  }));
@@ -36133,7 +36345,7 @@ var GifContainer = /*#__PURE__*/styled.div.withConfig({
36133
36345
  componentId: "sc-10t97fw-0"
36134
36346
  })(["width:100%;img{width:67%;}"]);
36135
36347
 
36136
- var img$c = '';
36348
+ var img$d = '';
36137
36349
 
36138
36350
  var TimeWidget = function TimeWidget(_ref) {
36139
36351
  var onClose = _ref.onClose,
@@ -36151,7 +36363,7 @@ var TimeWidget = function TimeWidget(_ref) {
36151
36363
  var WidgetContainer = /*#__PURE__*/styled.div.withConfig({
36152
36364
  displayName: "TimeWidget__WidgetContainer",
36153
36365
  componentId: "sc-1ja236h-0"
36154
- })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$c);
36366
+ })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$d);
36155
36367
  var Time = /*#__PURE__*/styled.div.withConfig({
36156
36368
  displayName: "TimeWidget__Time",
36157
36369
  componentId: "sc-1ja236h-1"
@@ -36400,230 +36612,16 @@ var Truncate = function Truncate(_ref) {
36400
36612
  var _ref$maxLines = _ref.maxLines,
36401
36613
  maxLines = _ref$maxLines === void 0 ? 1 : _ref$maxLines,
36402
36614
  children = _ref.children;
36403
- return React.createElement(Container$l, {
36615
+ return React.createElement(Container$o, {
36404
36616
  maxLines: maxLines
36405
36617
  }, children);
36406
36618
  };
36407
- var Container$l = /*#__PURE__*/styled.div.withConfig({
36619
+ var Container$o = /*#__PURE__*/styled.div.withConfig({
36408
36620
  displayName: "Truncate__Container",
36409
36621
  componentId: "sc-6x00qb-0"
36410
36622
  })(["display:-webkit-box;max-width:100%;max-height:100%;-webkit-line-clamp:", ";-webkit-box-orient:vertical;overflow:hidden;"], function (props) {
36411
36623
  return props.maxLines;
36412
36624
  });
36413
36625
 
36414
- var IS_MOBILE_OR_TABLET = /*#__PURE__*/isMobileOrTablet();
36415
-
36416
- var chunkString = function chunkString(str, length) {
36417
- return str.match(new RegExp('.{1,' + length + '}', 'g'));
36418
- };
36419
-
36420
- var img$d = '';
36421
-
36422
- var NPCDialogText = function NPCDialogText(_ref) {
36423
- var text = _ref.text,
36424
- onClose = _ref.onClose,
36425
- onEndStep = _ref.onEndStep,
36426
- onStartStep = _ref.onStartStep,
36427
- type = _ref.type;
36428
- var windowSize = useRef([window.innerWidth, window.innerHeight]);
36429
- function maxCharacters(width) {
36430
- // Set the font size to 16 pixels
36431
- var fontSize = 11.2;
36432
- // Calculate the number of characters that can fit in one line
36433
- var charactersPerLine = Math.floor(width / 2 / fontSize);
36434
- // Calculate the number of lines that can fit in the div
36435
- var linesPerDiv = Math.floor(180 / fontSize);
36436
- // Calculate the maximum number of characters that can fit in the div
36437
- var maxCharacters = charactersPerLine * linesPerDiv;
36438
- // Return the maximum number of characters
36439
- return Math.round(maxCharacters / 5);
36440
- }
36441
- var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
36442
- var _useState = useState(0),
36443
- chunkIndex = _useState[0],
36444
- setChunkIndex = _useState[1];
36445
- var onHandleSpacePress = function onHandleSpacePress(event) {
36446
- if (event.code === 'Space') {
36447
- goToNextStep();
36448
- }
36449
- };
36450
- var goToNextStep = function goToNextStep() {
36451
- var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
36452
- if (hasNextChunk) {
36453
- setChunkIndex(function (prev) {
36454
- return prev + 1;
36455
- });
36456
- } else {
36457
- // if there's no more text chunks, close the dialog
36458
- onClose();
36459
- }
36460
- };
36461
- useEffect(function () {
36462
- document.addEventListener('keydown', onHandleSpacePress);
36463
- return function () {
36464
- return document.removeEventListener('keydown', onHandleSpacePress);
36465
- };
36466
- }, [chunkIndex]);
36467
- var _useState2 = useState(false),
36468
- showGoNextIndicator = _useState2[0],
36469
- setShowGoNextIndicator = _useState2[1];
36470
- return React.createElement(Container$m, null, React.createElement(DynamicText, {
36471
- text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
36472
- onFinish: function onFinish() {
36473
- setShowGoNextIndicator(true);
36474
- onEndStep && onEndStep();
36475
- },
36476
- onStart: function onStart() {
36477
- setShowGoNextIndicator(false);
36478
- onStartStep && onStartStep();
36479
- }
36480
- }), showGoNextIndicator && React.createElement(PressSpaceIndicator$1, {
36481
- right: type === NPCDialogType.TextOnly ? '1rem' : '10.5rem',
36482
- src: IS_MOBILE_OR_TABLET ? img$d : img$7,
36483
- onPointerDown: function onPointerDown() {
36484
- goToNextStep();
36485
- }
36486
- }));
36487
- };
36488
- var Container$m = /*#__PURE__*/styled.div.withConfig({
36489
- displayName: "NPCDialogText__Container",
36490
- componentId: "sc-1cxkdh9-0"
36491
- })([""]);
36492
- var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
36493
- displayName: "NPCDialogText__PressSpaceIndicator",
36494
- componentId: "sc-1cxkdh9-1"
36495
- })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
36496
- var right = _ref2.right;
36497
- return right;
36498
- });
36499
-
36500
- var NPCDialogType;
36501
- (function (NPCDialogType) {
36502
- NPCDialogType["TextOnly"] = "TextOnly";
36503
- NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
36504
- })(NPCDialogType || (NPCDialogType = {}));
36505
- var NPCDialog = function NPCDialog(_ref) {
36506
- var text = _ref.text,
36507
- type = _ref.type,
36508
- _onClose = _ref.onClose,
36509
- imagePath = _ref.imagePath,
36510
- _ref$isQuestionDialog = _ref.isQuestionDialog,
36511
- isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
36512
- questions = _ref.questions,
36513
- answers = _ref.answers;
36514
- return React.createElement(RPGUIContainer, {
36515
- type: RPGUIContainerTypes.FramedGold,
36516
- width: isQuestionDialog ? '600px' : '80%',
36517
- height: '180px'
36518
- }, isQuestionDialog && questions && answers ? React.createElement(React.Fragment, null, React.createElement(TextContainer$2, {
36519
- flex: type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'
36520
- }, React.createElement(QuestionDialog, {
36521
- questions: questions,
36522
- answers: answers,
36523
- onClose: function onClose() {
36524
- if (_onClose) {
36525
- _onClose();
36526
- }
36527
- }
36528
- })), type === NPCDialogType.TextAndThumbnail && React.createElement(ThumbnailContainer$1, null, React.createElement(NPCThumbnail$1, {
36529
- src: imagePath || img$6
36530
- }))) : React.createElement(React.Fragment, null, React.createElement(Container$n, null, React.createElement(TextContainer$2, {
36531
- flex: type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'
36532
- }, React.createElement(NPCDialogText, {
36533
- type: type,
36534
- text: text || 'No text provided.',
36535
- onClose: function onClose() {
36536
- if (_onClose) {
36537
- _onClose();
36538
- }
36539
- }
36540
- })), type === NPCDialogType.TextAndThumbnail && React.createElement(ThumbnailContainer$1, null, React.createElement(NPCThumbnail$1, {
36541
- src: imagePath || img$6
36542
- })))));
36543
- };
36544
- var Container$n = /*#__PURE__*/styled.div.withConfig({
36545
- displayName: "NPCDialog__Container",
36546
- componentId: "sc-1b4aw74-0"
36547
- })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
36548
- var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
36549
- displayName: "NPCDialog__TextContainer",
36550
- componentId: "sc-1b4aw74-1"
36551
- })(["flex:", " 0 0;width:355px;"], function (_ref2) {
36552
- var flex = _ref2.flex;
36553
- return flex;
36554
- });
36555
- var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
36556
- displayName: "NPCDialog__ThumbnailContainer",
36557
- componentId: "sc-1b4aw74-2"
36558
- })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
36559
- var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
36560
- displayName: "NPCDialog__NPCThumbnail",
36561
- componentId: "sc-1b4aw74-3"
36562
- })(["image-rendering:pixelated;height:128px;width:128px;"]);
36563
-
36564
- var HistoryDialog = function HistoryDialog(_ref) {
36565
- var backgroundImgPath = _ref.backgroundImgPath,
36566
- fullCoverBackground = _ref.fullCoverBackground,
36567
- questions = _ref.questions,
36568
- answers = _ref.answers,
36569
- text = _ref.text,
36570
- imagePath = _ref.imagePath,
36571
- textAndTypeArray = _ref.textAndTypeArray,
36572
- onClose = _ref.onClose;
36573
- var _useState = useState(0),
36574
- img = _useState[0],
36575
- setImage = _useState[1];
36576
- var onHandleSpacePress = function onHandleSpacePress(event) {
36577
- if (event.code === 'Space') {
36578
- if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
36579
- setImage(function (prev) {
36580
- return prev + 1;
36581
- });
36582
- } else {
36583
- // if there's no more text chunks, close the dialog
36584
- onClose();
36585
- }
36586
- }
36587
- };
36588
- useEffect(function () {
36589
- document.addEventListener('keydown', onHandleSpacePress);
36590
- return function () {
36591
- return document.removeEventListener('keydown', onHandleSpacePress);
36592
- };
36593
- }, [backgroundImgPath]);
36594
- return React.createElement(BackgroundContainer, {
36595
- imgPath: backgroundImgPath[img],
36596
- fullImg: fullCoverBackground
36597
- }, React.createElement(DialogContainer, null, textAndTypeArray ? React.createElement(NPCMultiDialog, {
36598
- textAndTypeArray: textAndTypeArray,
36599
- onClose: onClose
36600
- }) : questions && answers ? React.createElement(QuestionDialog, {
36601
- questions: questions,
36602
- answers: answers,
36603
- onClose: onClose
36604
- }) : text && imagePath ? React.createElement(NPCDialog, {
36605
- text: text,
36606
- imagePath: imagePath,
36607
- onClose: onClose,
36608
- type: NPCDialogType.TextAndThumbnail
36609
- }) : React.createElement(NPCDialog, {
36610
- text: text,
36611
- onClose: onClose,
36612
- type: NPCDialogType.TextOnly
36613
- })));
36614
- };
36615
- var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
36616
- displayName: "HistoryDialog__BackgroundContainer",
36617
- componentId: "sc-u6oe75-0"
36618
- })(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
36619
- return props.imgPath;
36620
- }, function (props) {
36621
- return props.imgPath ? 'cover' : 'auto';
36622
- });
36623
- var DialogContainer = /*#__PURE__*/styled.div.withConfig({
36624
- displayName: "HistoryDialog__DialogContainer",
36625
- componentId: "sc-u6oe75-1"
36626
- })(["display:flex;justify-content:center;padding-top:200px;"]);
36627
-
36628
36626
  export { Button, ButtonTypes, CharacterSelection, Chat, ChatDeprecated, CheckButton, CircularController, CraftBook, DraggableContainer, Dropdown, DropdownSelectorContainer, DynamicText, EquipmentSet, EquipmentSlotSpriteByType, ErrorBoundary, HistoryDialog, ImgSide, Input, InputRadio, ItemContainer$1 as ItemContainer, ItemSelector, ItemSlot, ListMenu, NPCDialog, NPCDialogType, NPCMultiDialog, ProgressBar, PropertySelect, QuestInfo, QuestList, QuestionDialog, RPGUIContainer, RPGUIContainerTypes, RPGUIRoot, RangeSlider, RangeSliderType, Shortcuts, SkillProgressBar, SkillsContainer, Spellbook, SpriteFromAtlas, TextArea, TimeWidget, TradingMenu, Truncate, _RPGUI, rarityColor, useEventListener };
36629
36627
  //# sourceMappingURL=long-bow.esm.js.map