@rpg-engine/long-bow 0.3.69 → 0.3.71

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 (158) hide show
  1. package/LICENSE +20 -20
  2. package/README.md +181 -181
  3. package/dist/components/CraftBook/CraftBook.d.ts +2 -1
  4. package/dist/components/Item/Cards/ItemInfo.d.ts +10 -0
  5. package/dist/components/Item/Cards/ItemInfoDisplay.d.ts +9 -0
  6. package/dist/components/Item/Cards/ItemInfoWrapper.d.ts +11 -0
  7. package/dist/components/Item/Cards/ItemTooltip.d.ts +7 -4
  8. package/dist/components/Item/Inventory/ItemContainer.d.ts +2 -1
  9. package/dist/components/Item/Inventory/ItemSlot.d.ts +4 -1
  10. package/dist/components/TradingMenu/TradingItemRow.d.ts +2 -1
  11. package/dist/components/TradingMenu/TradingMenu.d.ts +4 -3
  12. package/dist/components/shared/SpriteFromAtlas.d.ts +1 -0
  13. package/dist/long-bow.cjs.development.js +1220 -949
  14. package/dist/long-bow.cjs.development.js.map +1 -1
  15. package/dist/long-bow.cjs.production.min.js +1 -1
  16. package/dist/long-bow.cjs.production.min.js.map +1 -1
  17. package/dist/long-bow.esm.js +1222 -953
  18. package/dist/long-bow.esm.js.map +1 -1
  19. package/dist/stories/ItemInfoDisplay.stories.d.ts +8 -0
  20. package/dist/stories/TradingMenu.stories.d.ts +2 -2
  21. package/package.json +100 -100
  22. package/src/components/Abstractions/SlotsContainer.tsx +45 -45
  23. package/src/components/Arrow/SelectArrow.tsx +69 -69
  24. package/src/components/Arrow/img/arrow01-left-clicked.png +0 -0
  25. package/src/components/Arrow/img/arrow01-left.png +0 -0
  26. package/src/components/Arrow/img/arrow01-right-clicked.png +0 -0
  27. package/src/components/Arrow/img/arrow01-right.png +0 -0
  28. package/src/components/Arrow/img/arrow02-left-clicked.png +0 -0
  29. package/src/components/Arrow/img/arrow02-left.png +0 -0
  30. package/src/components/Arrow/img/arrow02-right-clicked.png +0 -0
  31. package/src/components/Arrow/img/arrow02-right.png +0 -0
  32. package/src/components/Button.tsx +40 -40
  33. package/src/components/Character/CharacterSelection.tsx +96 -96
  34. package/src/components/CharacterStatus/CharacterStatus.tsx +120 -120
  35. package/src/components/Chat/Chat.tsx +195 -195
  36. package/src/components/Chatdeprecated/ChatDeprecated.tsx +198 -198
  37. package/src/components/CheckButton.tsx +65 -65
  38. package/src/components/CircularController/CircularController.tsx +248 -248
  39. package/src/components/CraftBook/CraftBook.tsx +237 -227
  40. package/src/components/CraftBook/MockItems.ts +41 -46
  41. package/src/components/DraggableContainer.tsx +153 -153
  42. package/src/components/Dropdown.tsx +90 -90
  43. package/src/components/DropdownSelectorContainer.tsx +42 -42
  44. package/src/components/Equipment/EquipmentSet.tsx +190 -190
  45. package/src/components/HistoryDialog.tsx +104 -104
  46. package/src/components/Input.tsx +15 -15
  47. package/src/components/Item/Cards/ItemInfo.tsx +248 -0
  48. package/src/components/Item/Cards/ItemInfoDisplay.tsx +120 -0
  49. package/src/components/Item/Cards/ItemInfoWrapper.tsx +39 -0
  50. package/src/components/Item/Cards/ItemTooltip.tsx +85 -33
  51. package/src/components/Item/Inventory/ErrorBoundary.tsx +42 -42
  52. package/src/components/Item/Inventory/ItemContainer.tsx +214 -210
  53. package/src/components/Item/Inventory/ItemContainerTypes.ts +6 -6
  54. package/src/components/Item/Inventory/ItemQuantitySelector.tsx +138 -138
  55. package/src/components/Item/Inventory/ItemSlot.tsx +512 -501
  56. package/src/components/Item/Inventory/itemContainerHelper.ts +156 -156
  57. package/src/components/ListMenu.tsx +63 -63
  58. package/src/components/Multitab/Tab.tsx +66 -66
  59. package/src/components/Multitab/TabBody.tsx +13 -13
  60. package/src/components/Multitab/TabsContainer.tsx +97 -97
  61. package/src/components/NPCDialog/NPCDialog.tsx +121 -121
  62. package/src/components/NPCDialog/NPCDialogText.tsx +113 -113
  63. package/src/components/NPCDialog/NPCMultiDialog.tsx +159 -159
  64. package/src/components/NPCDialog/QuestionDialog/QuestionDialog.tsx +237 -237
  65. package/src/components/ProgressBar.tsx +92 -92
  66. package/src/components/PropertySelect/PropertySelect.tsx +106 -106
  67. package/src/components/QuestInfo/QuestInfo.tsx +230 -230
  68. package/src/components/QuestList.tsx +129 -129
  69. package/src/components/RPGUIContainer.tsx +47 -47
  70. package/src/components/RPGUIForceRenderStart.tsx +45 -45
  71. package/src/components/RPGUIRoot.tsx +14 -14
  72. package/src/components/RadioButton.tsx +53 -53
  73. package/src/components/RadioInput/RadioButton.tsx +96 -96
  74. package/src/components/RadioInput/RadioInput.tsx +102 -102
  75. package/src/components/RadioInput/instruments.ts +15 -15
  76. package/src/components/RangeSlider.tsx +78 -78
  77. package/src/components/RelativeListMenu.tsx +83 -83
  78. package/src/components/ScrollList.tsx +79 -79
  79. package/src/components/Shortcuts/Shortcuts.tsx +151 -151
  80. package/src/components/Shortcuts/ShortcutsSetter.tsx +132 -132
  81. package/src/components/Shortcuts/SingleShortcut.ts +62 -62
  82. package/src/components/SimpleProgressBar.tsx +62 -62
  83. package/src/components/SkillProgressBar.tsx +133 -133
  84. package/src/components/SkillsContainer.tsx +198 -198
  85. package/src/components/Spellbook/Spell.tsx +201 -201
  86. package/src/components/Spellbook/Spellbook.tsx +150 -150
  87. package/src/components/Spellbook/constants.ts +8 -8
  88. package/src/components/Spellbook/mockSpells.ts +60 -60
  89. package/src/components/StaticBook/StaticBook.tsx +103 -103
  90. package/src/components/TextArea.tsx +11 -11
  91. package/src/components/TimeWidget/DayNightPeriod/DayNightPeriod.tsx +35 -35
  92. package/src/components/TimeWidget/TimeWidget.tsx +63 -63
  93. package/src/components/TradingMenu/TradingItemRow.tsx +195 -181
  94. package/src/components/TradingMenu/TradingMenu.tsx +211 -203
  95. package/src/components/TradingMenu/items.mock.ts +48 -96
  96. package/src/components/Truncate.tsx +25 -25
  97. package/src/components/itemSelector/ItemSelector.tsx +136 -136
  98. package/src/components/shared/Column.tsx +16 -16
  99. package/src/components/shared/Ellipsis.tsx +65 -65
  100. package/src/components/shared/SpriteFromAtlas.tsx +104 -102
  101. package/src/components/typography/DynamicText.tsx +49 -49
  102. package/src/constants/uiColors.ts +20 -20
  103. package/src/constants/uiDevices.ts +3 -3
  104. package/src/constants/uiFonts.ts +12 -12
  105. package/src/hooks/useEventListener.ts +21 -21
  106. package/src/hooks/useOutsideAlerter.ts +25 -25
  107. package/src/index.tsx +40 -40
  108. package/src/libs/StringHelpers.ts +3 -3
  109. package/src/mocks/atlas/entities/entities.json +20215 -20215
  110. package/src/mocks/atlas/icons/icons.json +735 -735
  111. package/src/mocks/atlas/items/items.json +12086 -12086
  112. package/src/mocks/equipmentSet.mocks.ts +391 -393
  113. package/src/mocks/itemContainer.mocks.ts +563 -562
  114. package/src/mocks/skills.mocks.ts +128 -128
  115. package/src/stories/Arrow.stories.tsx +26 -26
  116. package/src/stories/Button.stories.tsx +36 -36
  117. package/src/stories/CharacterSelection.stories.tsx +45 -45
  118. package/src/stories/CharacterStatus.stories.tsx +29 -29
  119. package/src/stories/Chat.stories.tsx +187 -187
  120. package/src/stories/ChatDeprecated.stories.tsx +170 -170
  121. package/src/stories/CheckButton.stories.tsx +48 -48
  122. package/src/stories/CircullarController.stories.tsx +37 -37
  123. package/src/stories/CraftBook.stories.tsx +42 -40
  124. package/src/stories/DayNightPeriod.stories.tsx +27 -27
  125. package/src/stories/DraggableContainer.stories.tsx +28 -28
  126. package/src/stories/Dropdown.stories.tsx +46 -46
  127. package/src/stories/DropdownSelectorContainer.stories.tsx +41 -41
  128. package/src/stories/EquipmentSet.stories.tsx +65 -65
  129. package/src/stories/HistoryDialog.stories.tsx +61 -61
  130. package/src/stories/ItemContainer.stories.tsx +200 -198
  131. package/src/stories/ItemInfoDisplay.stories.tsx +33 -0
  132. package/src/stories/ItemQuantitySelector.stories.tsx +26 -26
  133. package/src/stories/ItemSelector.stories.tsx +77 -77
  134. package/src/stories/ItemTradingComponent.stories.tsx +35 -35
  135. package/src/stories/ListMenu.stories.tsx +56 -56
  136. package/src/stories/Multitab.stories.tsx +51 -51
  137. package/src/stories/NPCDialog.stories.tsx +130 -130
  138. package/src/stories/NPCMultiDialog.stories.tsx +71 -71
  139. package/src/stories/ProgressBar.stories.tsx +23 -23
  140. package/src/stories/PropertySelect.stories.tsx +40 -40
  141. package/src/stories/QuestInfo.stories.tsx +107 -107
  142. package/src/stories/QuestList.stories.tsx +82 -82
  143. package/src/stories/RPGUIContainers.stories.tsx +42 -42
  144. package/src/stories/RadioButton.stories.tsx +49 -49
  145. package/src/stories/RadioInput.stories.tsx +34 -34
  146. package/src/stories/RangeSlider.stories.tsx +64 -64
  147. package/src/stories/ScrollList.stories.tsx +85 -85
  148. package/src/stories/Shortcuts.stories.tsx +39 -39
  149. package/src/stories/SimpleProgressBar.stories.tsx +22 -22
  150. package/src/stories/SkillProgressBar.stories.tsx +34 -34
  151. package/src/stories/SkillsContainer.stories.tsx +35 -35
  152. package/src/stories/Spellbook.stories.tsx +104 -104
  153. package/src/stories/StaticBook.stories.tsx +32 -32
  154. package/src/stories/Text.stories.tsx +42 -42
  155. package/src/stories/TimeWidget.stories.tsx +27 -27
  156. package/src/stories/TradingMenu.stories.tsx +47 -45
  157. package/src/types/eventTypes.ts +4 -4
  158. package/src/types/index.d.ts +2 -2
@@ -13,6 +13,7 @@ var reactErrorBoundary = require('react-error-boundary');
13
13
  var rx = require('react-icons/rx');
14
14
  var Draggable = _interopDefault(require('react-draggable'));
15
15
  var uuid = require('uuid');
16
+ var lodash = require('lodash');
16
17
  var mobxReactLite = require('mobx-react-lite');
17
18
  require('rpgui/rpgui.min.css');
18
19
  require('rpgui/rpgui.min.js');
@@ -113,7 +114,8 @@ var SpriteFromAtlas = function SpriteFromAtlas(_ref) {
113
114
  _ref$grayScale = _ref.grayScale,
114
115
  grayScale = _ref$grayScale === void 0 ? false : _ref$grayScale,
115
116
  _ref$opacity = _ref.opacity,
116
- opacity = _ref$opacity === void 0 ? 1 : _ref$opacity;
117
+ opacity = _ref$opacity === void 0 ? 1 : _ref$opacity,
118
+ imgClassname = _ref.imgClassname;
117
119
  //! If an item is not showing, remember that you MUST run yarn atlas:copy everytime you add a new item to the atlas (it will sync our public folder atlas with src/atlas).
118
120
  //!Due to React's limitations, we cannot import it from the public folder directly!
119
121
  var spriteData = atlasJSON.frames[spriteKey] || atlasJSON.frames['others/no-image.png'];
@@ -125,7 +127,7 @@ var SpriteFromAtlas = function SpriteFromAtlas(_ref) {
125
127
  onPointerDown: onPointerDown,
126
128
  style: containerStyle
127
129
  }, React__default.createElement(ImgSprite, {
128
- className: "sprite-from-atlas-img",
130
+ className: "sprite-from-atlas-img " + (imgClassname || ''),
129
131
  atlasIMG: atlasIMG,
130
132
  frame: spriteData.frame,
131
133
  scale: imgScale,
@@ -33361,200 +33363,6 @@ var DropdownOptions = /*#__PURE__*/styled.ul.withConfig({
33361
33363
  return props.opened ? 'block' : 'none';
33362
33364
  });
33363
33365
 
33364
- var CraftBook = function CraftBook(_ref) {
33365
- var atlasIMG = _ref.atlasIMG,
33366
- atlasJSON = _ref.atlasJSON,
33367
- onClose = _ref.onClose,
33368
- onSelect = _ref.onSelect,
33369
- onCraftItem = _ref.onCraftItem,
33370
- craftablesItems = _ref.craftablesItems;
33371
- var optionsId = 0;
33372
- var _useState = React.useState({
33373
- show: false,
33374
- index: 200
33375
- }),
33376
- isShown = _useState[0],
33377
- setIsShown = _useState[1];
33378
- var _useState2 = React.useState(),
33379
- craftItem = _useState2[0],
33380
- setCraftItem = _useState2[1];
33381
- var getDropdownOptions = function getDropdownOptions() {
33382
- var options = [];
33383
- Object.keys(shared.ItemSubType).forEach(function (key) {
33384
- if (key === 'DeadBody') {
33385
- return; // we can't craft crafting resouces...
33386
- }
33387
-
33388
- options.push({
33389
- id: optionsId,
33390
- value: key,
33391
- option: key
33392
- });
33393
- optionsId += 1;
33394
- });
33395
- return options;
33396
- };
33397
- var modifyString = function modifyString(str) {
33398
- // Split the string by "/" and "."
33399
- var parts = str.split('/');
33400
- var fileName = parts[parts.length - 1];
33401
- parts = fileName.split('.');
33402
- var name = parts[0];
33403
- // Replace all occurrences of "-" with " "
33404
- name = name.replace(/-/g, ' ');
33405
- // Uppercase the first word
33406
- var words = name.split(' ');
33407
- var firstWord = words[0].slice(0, 1).toUpperCase() + words[0].slice(1);
33408
- var modifiedWords = [firstWord].concat(words.slice(1));
33409
- name = modifiedWords.join(' ');
33410
- return name;
33411
- };
33412
- var handleClick = function handleClick(value) {
33413
- setCraftItem(value);
33414
- };
33415
- return React__default.createElement(DraggableContainer, {
33416
- type: exports.RPGUIContainerTypes.Framed,
33417
- width: "500px",
33418
- cancelDrag: ".equipment-container-body .arrow-selector .rpgui-dropdown-imp",
33419
- onCloseButton: function onCloseButton() {
33420
- if (onClose) {
33421
- onClose();
33422
- }
33423
- }
33424
- }, React__default.createElement("div", {
33425
- style: {
33426
- width: '100%'
33427
- }
33428
- }, React__default.createElement(Title$1, null, 'Craftbook'), React__default.createElement(Subtitle, null, 'Select an item to craft'), React__default.createElement("hr", {
33429
- className: "golden"
33430
- })), React__default.createElement(Dropdown, {
33431
- options: getDropdownOptions(),
33432
- onChange: function onChange(value) {
33433
- return onSelect(value);
33434
- }
33435
- }), React__default.createElement(RadioInputScroller, null, craftablesItems == null ? void 0 : craftablesItems.map(function (option, index) {
33436
- return React__default.createElement(RadioOptionsWrapper, {
33437
- key: index
33438
- }, React__default.createElement(SpriteAtlasWrapper, null, React__default.createElement(SpriteFromAtlas, {
33439
- atlasIMG: atlasIMG,
33440
- atlasJSON: atlasJSON,
33441
- spriteKey: option.texturePath,
33442
- imgScale: 3,
33443
- grayScale: !option.canCraft
33444
- })), React__default.createElement("div", null, React__default.createElement("div", {
33445
- onPointerDown: function onPointerDown() {
33446
- return handleClick(option.key);
33447
- }
33448
- }, React__default.createElement("input", {
33449
- className: "rpgui-radio",
33450
- type: "radio",
33451
- value: option.name,
33452
- name: "test",
33453
- disabled: !option.canCraft,
33454
- checked: craftItem === option.key,
33455
- onChange: function onChange() {
33456
- return handleClick(option.key);
33457
- }
33458
- }), React__default.createElement("label", {
33459
- onPointerDown: function onPointerDown() {
33460
- handleClick(option.key);
33461
- },
33462
- onTouchEnd: function onTouchEnd() {
33463
- setIsShown({
33464
- show: true,
33465
- index: index
33466
- });
33467
- },
33468
- style: {
33469
- display: 'flex',
33470
- alignItems: 'center'
33471
- },
33472
- onMouseEnter: function onMouseEnter() {
33473
- return setIsShown({
33474
- show: true,
33475
- index: index
33476
- });
33477
- },
33478
- onMouseLeave: function onMouseLeave() {
33479
- return setIsShown({
33480
- show: false,
33481
- index: index
33482
- });
33483
- }
33484
- }, modifyString(option.name))), isShown && isShown.index === index && option.ingredients.map(function (option, index) {
33485
- return React__default.createElement(Recipes, {
33486
- key: index
33487
- }, React__default.createElement(SpriteFromAtlas, {
33488
- atlasIMG: atlasIMG,
33489
- atlasJSON: atlasJSON,
33490
- spriteKey: option.texturePath,
33491
- imgScale: 1
33492
- }), React__default.createElement(StyledItem, null, modifyString(option.key), " (", option.qty, "x)"));
33493
- })));
33494
- })), React__default.createElement(ButtonWrapper, null, React__default.createElement(Button, {
33495
- buttonType: exports.ButtonTypes.RPGUIButton,
33496
- onPointerDown: onClose
33497
- }, "Cancel"), React__default.createElement(Button, {
33498
- buttonType: exports.ButtonTypes.RPGUIButton,
33499
- onPointerDown: function onPointerDown() {
33500
- return onCraftItem(craftItem);
33501
- }
33502
- }, "Craft")));
33503
- };
33504
- var StyledItem = /*#__PURE__*/styled.div.withConfig({
33505
- displayName: "CraftBook__StyledItem",
33506
- componentId: "sc-19q95ue-0"
33507
- })(["margin-left:10px;"]);
33508
- var Recipes = /*#__PURE__*/styled.div.withConfig({
33509
- displayName: "CraftBook__Recipes",
33510
- componentId: "sc-19q95ue-1"
33511
- })(["font-size:0.6rem;color:yellow !important;margin-bottom:3px;display:flex;align-items:center;.sprite-from-atlas-img{top:0px;left:0px;}"]);
33512
- var Title$1 = /*#__PURE__*/styled.h1.withConfig({
33513
- displayName: "CraftBook__Title",
33514
- componentId: "sc-19q95ue-2"
33515
- })(["font-size:0.6rem;color:yellow !important;"]);
33516
- var Subtitle = /*#__PURE__*/styled.h1.withConfig({
33517
- displayName: "CraftBook__Subtitle",
33518
- componentId: "sc-19q95ue-3"
33519
- })(["font-size:0.4rem;color:yellow !important;"]);
33520
- var RadioInputScroller = /*#__PURE__*/styled.div.withConfig({
33521
- displayName: "CraftBook__RadioInputScroller",
33522
- componentId: "sc-19q95ue-4"
33523
- })(["padding-left:15px;padding-top:10px;width:100%;margin-top:1rem;align-items:center;margin-left:20px;align-items:flex-start;overflow-y:scroll;height:360px;-webkit-overflow-scrolling:touch;"]);
33524
- var SpriteAtlasWrapper = /*#__PURE__*/styled.div.withConfig({
33525
- displayName: "CraftBook__SpriteAtlasWrapper",
33526
- componentId: "sc-19q95ue-5"
33527
- })(["margin-right:40px;"]);
33528
- var RadioOptionsWrapper = /*#__PURE__*/styled.div.withConfig({
33529
- displayName: "CraftBook__RadioOptionsWrapper",
33530
- componentId: "sc-19q95ue-6"
33531
- })(["display:flex;align-items:stretch;margin-bottom:40px;"]);
33532
- var ButtonWrapper = /*#__PURE__*/styled.div.withConfig({
33533
- displayName: "CraftBook__ButtonWrapper",
33534
- componentId: "sc-19q95ue-7"
33535
- })(["display:flex;justify-content:space-around;padding-top:20px;width:100%;"]);
33536
-
33537
- var DropdownSelectorContainer = function DropdownSelectorContainer(_ref) {
33538
- var title = _ref.title,
33539
- onChange = _ref.onChange,
33540
- options = _ref.options,
33541
- details = _ref.details;
33542
- return React__default.createElement("div", null, React__default.createElement("p", null, title), React__default.createElement(Dropdown, {
33543
- options: options.map(function (option, index) {
33544
- return {
33545
- option: option.name,
33546
- value: option.id,
33547
- id: index
33548
- };
33549
- }),
33550
- onChange: onChange
33551
- }), React__default.createElement(Details, null, details));
33552
- };
33553
- var Details = /*#__PURE__*/styled.p.withConfig({
33554
- displayName: "DropdownSelectorContainer__Details",
33555
- componentId: "sc-kaa0h9-0"
33556
- })(["font-size:", " !important;"], uiFonts.size.xsmall);
33557
-
33558
33366
  var RelativeListMenu = function RelativeListMenu(_ref) {
33559
33367
  var options = _ref.options,
33560
33368
  onSelected = _ref.onSelected,
@@ -33604,15 +33412,6 @@ var ListElement = /*#__PURE__*/styled.li.withConfig({
33604
33412
  componentId: "sc-7hohf-1"
33605
33413
  })(["margin-right:0.5rem;"]);
33606
33414
 
33607
- var ItemTooltip = function ItemTooltip(_ref) {
33608
- var label = _ref.label;
33609
- return React__default.createElement(Container$9, null, React__default.createElement("div", null, label));
33610
- };
33611
- var Container$9 = /*#__PURE__*/styled.div.withConfig({
33612
- displayName: "ItemTooltip__Container",
33613
- componentId: "sc-11d9r7x-0"
33614
- })(["z-index:2;position:absolute;top:1rem;left:4rem;font-size:", ";color:white;background-color:black;border-radius:5px;padding:0.5rem;min-width:20px;width:100%;text-align:center;opacity:0.75;"], uiFonts.size.xxsmall);
33615
-
33616
33415
  var generateContextMenuListOptions = function generateContextMenuListOptions(actionsByTypeList) {
33617
33416
  var contextMenu = actionsByTypeList.map(function (action) {
33618
33417
  return {
@@ -33747,7 +33546,8 @@ var ItemSlot = /*#__PURE__*/mobxReactLite.observer(function (_ref) {
33747
33546
  openQuantitySelector = _ref.openQuantitySelector,
33748
33547
  checkIfItemShouldDragEnd = _ref.checkIfItemShouldDragEnd,
33749
33548
  dragScale = _ref.dragScale,
33750
- isSelectingShortcut = _ref.isSelectingShortcut;
33549
+ isSelectingShortcut = _ref.isSelectingShortcut,
33550
+ equipmentSet = _ref.equipmentSet;
33751
33551
  var _useState = React.useState(false),
33752
33552
  isTooltipVisible = _useState[0],
33753
33553
  setTooltipVisible = _useState[1];
@@ -33821,7 +33621,8 @@ var ItemSlot = /*#__PURE__*/mobxReactLite.observer(function (_ref) {
33821
33621
  texturePath: itemToRender.texturePath,
33822
33622
  stackQty: itemToRender.stackQty || 1
33823
33623
  }, atlasJSON),
33824
- imgScale: 3
33624
+ imgScale: 3,
33625
+ imgClassname: "sprite-from-atlas-img--item"
33825
33626
  })));
33826
33627
  }
33827
33628
  var stackInfo = getStackInfo((_itemToRender$_id = itemToRender == null ? void 0 : itemToRender._id) != null ? _itemToRender$_id : '', (_itemToRender$stackQt = itemToRender == null ? void 0 : itemToRender.stackQty) != null ? _itemToRender$stackQt : 0);
@@ -33846,7 +33647,8 @@ var ItemSlot = /*#__PURE__*/mobxReactLite.observer(function (_ref) {
33846
33647
  texturePath: itemToRender.texturePath,
33847
33648
  stackQty: itemToRender.stackQty || 1
33848
33649
  }, atlasJSON),
33849
- imgScale: 3
33650
+ imgScale: 3,
33651
+ imgClassname: "sprite-from-atlas-img--item"
33850
33652
  })));
33851
33653
  var stackInfo = getStackInfo((_itemToRender$_id2 = itemToRender == null ? void 0 : itemToRender._id) != null ? _itemToRender$_id2 : '', (_itemToRender$stackQt2 = itemToRender == null ? void 0 : itemToRender.stackQty) != null ? _itemToRender$stackQt2 : 0);
33852
33654
  if (stackInfo) {
@@ -33863,7 +33665,8 @@ var ItemSlot = /*#__PURE__*/mobxReactLite.observer(function (_ref) {
33863
33665
  spriteKey: EquipmentSlotSpriteByType[slotSpriteMask],
33864
33666
  imgScale: 3,
33865
33667
  grayScale: true,
33866
- opacity: 0.4
33668
+ opacity: 0.4,
33669
+ imgClassname: "sprite-from-atlas-img--item"
33867
33670
  }));
33868
33671
  }
33869
33672
  };
@@ -33893,7 +33696,7 @@ var ItemSlot = /*#__PURE__*/mobxReactLite.observer(function (_ref) {
33893
33696
  onDragEnd(quantity);
33894
33697
  }
33895
33698
  };
33896
- return React__default.createElement(Container$a, {
33699
+ return React__default.createElement(Container$9, {
33897
33700
  item: item,
33898
33701
  className: "rpgui-icon empty-slot",
33899
33702
  onMouseUp: function onMouseUp() {
@@ -33992,7 +33795,10 @@ var ItemSlot = /*#__PURE__*/mobxReactLite.observer(function (_ref) {
33992
33795
  setTooltipVisible(false);
33993
33796
  }
33994
33797
  }, onRenderSlot(item))), isTooltipVisible && item && !isFocused && React__default.createElement(ItemTooltip, {
33995
- label: item.name
33798
+ item: item,
33799
+ atlasIMG: atlasIMG,
33800
+ atlasJSON: atlasJSON,
33801
+ equipmentSet: equipmentSet
33996
33802
  }), !isContextMenuDisabled && isContextMenuVisible && contextActions && React__default.createElement(RelativeListMenu, {
33997
33803
  options: contextActions,
33998
33804
  onSelected: function onSelected(optionId) {
@@ -34017,13 +33823,13 @@ var rarityColor = function rarityColor(item) {
34017
33823
  case shared.ItemRarities.Legendary:
34018
33824
  return 'rgba(255, 191, 0,0.6)';
34019
33825
  default:
34020
- return 'unset';
33826
+ return null;
34021
33827
  }
34022
33828
  };
34023
- var Container$a = /*#__PURE__*/styled.div.withConfig({
33829
+ var Container$9 = /*#__PURE__*/styled.div.withConfig({
34024
33830
  displayName: "ItemSlot__Container",
34025
33831
  componentId: "sc-l2j5ef-0"
34026
- })(["margin:0.1rem;.sprite-from-atlas-img{position:relative;top:1.5rem;left:1.5rem;border-color:", ";box-shadow:", " inset,", ";}position:relative;&::before{content:'';position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;border-radius:12px;pointer-events:none;animation:", ";@keyframes bg-color-change{0%{background-color:rgba(255 255 255 / 0.5);}50%{background-color:transparent;}100%{background-color:rgba(255 255 255 / 0.5);}}}"], function (_ref2) {
33832
+ })(["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) {
34027
33833
  var item = _ref2.item;
34028
33834
  return rarityColor(item);
34029
33835
  }, function (_ref3) {
@@ -34051,6 +33857,459 @@ var ItemQty = /*#__PURE__*/styled.span.withConfig({
34051
33857
  componentId: "sc-l2j5ef-3"
34052
33858
  })(["&.regular{font-size:", ";}&.small{font-size:", ";}&.xsmall{font-size:", ";}"], uiFonts.size.small, uiFonts.size.xsmall, uiFonts.size.xxsmall);
34053
33859
 
33860
+ var statisticsToDisplay = [{
33861
+ key: 'attack'
33862
+ }, {
33863
+ key: 'defense'
33864
+ }, {
33865
+ key: 'maxRange',
33866
+ label: 'Range'
33867
+ }, {
33868
+ key: 'weight',
33869
+ higherIsWorse: true
33870
+ }];
33871
+ var ItemInfo = function ItemInfo(_ref) {
33872
+ var _item$stackQty;
33873
+ var item = _ref.item,
33874
+ itemToCompare = _ref.itemToCompare,
33875
+ atlasIMG = _ref.atlasIMG,
33876
+ atlasJSON = _ref.atlasJSON;
33877
+ var renderStatistics = function renderStatistics() {
33878
+ var statistics = [];
33879
+ for (var _i = 0, _statisticsToDisplay = statisticsToDisplay; _i < _statisticsToDisplay.length; _i++) {
33880
+ var stat = _statisticsToDisplay[_i];
33881
+ var itemStatistic = item[stat.key];
33882
+ if (itemStatistic) {
33883
+ var _itemToCompare$stat$k, _itemToCompare$stat$k2;
33884
+ var label = stat.label || stat.key[0].toUpperCase() + stat.key.slice(1);
33885
+ var isItemToCompare = !!itemToCompare;
33886
+ var isOnlyInOneItem = isItemToCompare && !(itemToCompare != null && itemToCompare[stat.key]);
33887
+ var statDiff = parseInt(itemStatistic.toString()) - parseInt((_itemToCompare$stat$k = itemToCompare == null ? void 0 : (_itemToCompare$stat$k2 = itemToCompare[stat.key]) == null ? void 0 : _itemToCompare$stat$k2.toString()) != null ? _itemToCompare$stat$k : '0');
33888
+ var isDifference = isItemToCompare && statDiff !== 0;
33889
+ var isBetter = statDiff > 0 && !stat.higherIsWorse || statDiff < 0 && stat.higherIsWorse;
33890
+ statistics.push(React__default.createElement(Statistic, {
33891
+ key: stat.key,
33892
+ className: isOnlyInOneItem ? 'better' : ''
33893
+ }, React__default.createElement("div", {
33894
+ className: "label"
33895
+ }, label, ":"), React__default.createElement("div", {
33896
+ className: "value " + (isDifference ? isBetter ? 'better' : 'worse' : '')
33897
+ }, itemStatistic.toString() + " " + (isDifference ? "(" + (statDiff > 0 ? '+' : '') + statDiff + ")" : ''))));
33898
+ }
33899
+ }
33900
+ return statistics;
33901
+ };
33902
+ var renderMissingStatistic = function renderMissingStatistic() {
33903
+ var statistics = [];
33904
+ for (var _i2 = 0, _statisticsToDisplay2 = statisticsToDisplay; _i2 < _statisticsToDisplay2.length; _i2++) {
33905
+ var stat = _statisticsToDisplay2[_i2];
33906
+ var itemToCompareStatistic = itemToCompare == null ? void 0 : itemToCompare[stat.key];
33907
+ if (itemToCompareStatistic && !item[stat.key]) {
33908
+ var label = stat.label || stat.key[0].toUpperCase() + stat.key.slice(1);
33909
+ statistics.push(React__default.createElement(Statistic, {
33910
+ key: stat.key,
33911
+ className: "worse"
33912
+ }, React__default.createElement("div", {
33913
+ className: "label"
33914
+ }, label, ":"), React__default.createElement("div", {
33915
+ className: "value worse"
33916
+ }, itemToCompareStatistic.toString())));
33917
+ }
33918
+ }
33919
+ return statistics;
33920
+ };
33921
+ var renderAvaibleSlots = function renderAvaibleSlots() {
33922
+ if (!item.allowedEquipSlotType) return null;
33923
+ return item.allowedEquipSlotType.map(function (slotType, index) {
33924
+ return React__default.createElement(ErrorBoundary, {
33925
+ key: index
33926
+ }, React__default.createElement(SpriteFromAtlas, {
33927
+ atlasIMG: atlasIMG,
33928
+ atlasJSON: atlasJSON,
33929
+ spriteKey: EquipmentSlotSpriteByType[slotType],
33930
+ imgScale: 2,
33931
+ grayScale: true,
33932
+ opacity: 0.4,
33933
+ containerStyle: {
33934
+ width: '32px',
33935
+ height: '32px'
33936
+ }
33937
+ }));
33938
+ });
33939
+ };
33940
+ return React__default.createElement(Container$a, {
33941
+ item: item
33942
+ }, React__default.createElement(Header, null, React__default.createElement("div", null, React__default.createElement(Title$1, null, item.name), item.rarity !== 'Common' && React__default.createElement(Rarity, {
33943
+ item: item
33944
+ }, item.rarity), React__default.createElement(Type, null, item.subType)), React__default.createElement(AllowedSlots, null, renderAvaibleSlots())), renderStatistics(), item.isTwoHanded && React__default.createElement(Statistic, null, "Two handed"), React__default.createElement(Description, null, item.description), item.maxStackSize && item.maxStackSize !== 1 && React__default.createElement(StackInfo, null, "x", (_item$stackQty = item.stackQty) != null ? _item$stackQty : 1, "(", item.maxStackSize, ")"), renderMissingStatistic().length > 0 && React__default.createElement(MissingStatistics, null, React__default.createElement(Statistic, null, "Equipped Diff"), itemToCompare && renderMissingStatistic()));
33945
+ };
33946
+ var Container$a = /*#__PURE__*/styled.div.withConfig({
33947
+ displayName: "ItemInfo__Container",
33948
+ componentId: "sc-1xm4q8k-0"
33949
+ })(["color:white;background-color:#222;border-radius:5px;padding:0.5rem;width:max-content;font-size:", ";border:3px solid ", ";"], uiFonts.size.small, function (_ref2) {
33950
+ var _rarityColor;
33951
+ var item = _ref2.item;
33952
+ return (_rarityColor = rarityColor(item)) != null ? _rarityColor : uiColors.lightGray;
33953
+ });
33954
+ var Title$1 = /*#__PURE__*/styled.div.withConfig({
33955
+ displayName: "ItemInfo__Title",
33956
+ componentId: "sc-1xm4q8k-1"
33957
+ })(["font-size:", ";font-weight:bold;margin-bottom:0.5rem;display:flex;align-items:center;margin:0;"], uiFonts.size.medium);
33958
+ var Rarity = /*#__PURE__*/styled.div.withConfig({
33959
+ displayName: "ItemInfo__Rarity",
33960
+ componentId: "sc-1xm4q8k-2"
33961
+ })(["font-size:", ";font-weight:normal;margin-top:0.2rem;color:", ";filter:brightness(1.5);"], uiFonts.size.small, function (_ref3) {
33962
+ var item = _ref3.item;
33963
+ return rarityColor(item);
33964
+ });
33965
+ var Type = /*#__PURE__*/styled.div.withConfig({
33966
+ displayName: "ItemInfo__Type",
33967
+ componentId: "sc-1xm4q8k-3"
33968
+ })(["font-size:", ";margin-top:0.2rem;color:", ";"], uiFonts.size.small, uiColors.lightGray);
33969
+ var Statistic = /*#__PURE__*/styled.div.withConfig({
33970
+ displayName: "ItemInfo__Statistic",
33971
+ componentId: "sc-1xm4q8k-4"
33972
+ })(["margin-bottom:0.4rem;.label{display:inline-block;margin-right:0.5rem;color:inherit;}.value{display:inline-block;color:inherit;}&.better,.better{color:", ";}&.worse,.worse{color:", ";}"], uiColors.lightGreen, uiColors.cardinal);
33973
+ var Description = /*#__PURE__*/styled.div.withConfig({
33974
+ displayName: "ItemInfo__Description",
33975
+ componentId: "sc-1xm4q8k-5"
33976
+ })(["margin-top:1.5rem;font-size:", ";color:", ";font-style:italic;width:max-content;max-width:20rem;"], uiFonts.size.small, uiColors.lightGray);
33977
+ var Header = /*#__PURE__*/styled.div.withConfig({
33978
+ displayName: "ItemInfo__Header",
33979
+ componentId: "sc-1xm4q8k-6"
33980
+ })(["display:flex;align-items:center;justify-content:space-between;margin-bottom:0.5rem;"]);
33981
+ var AllowedSlots = /*#__PURE__*/styled.div.withConfig({
33982
+ displayName: "ItemInfo__AllowedSlots",
33983
+ componentId: "sc-1xm4q8k-7"
33984
+ })(["display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:0.5rem;margin-left:2rem;"]);
33985
+ var StackInfo = /*#__PURE__*/styled.div.withConfig({
33986
+ displayName: "ItemInfo__StackInfo",
33987
+ componentId: "sc-1xm4q8k-8"
33988
+ })(["width:100%;text-align:right;font-size:", ";color:", ";margin-top:1rem;"], uiFonts.size.small, uiColors.orange);
33989
+ var MissingStatistics = /*#__PURE__*/styled.div.withConfig({
33990
+ displayName: "ItemInfo__MissingStatistics",
33991
+ componentId: "sc-1xm4q8k-9"
33992
+ })(["margin-top:1rem;color:", ";"], uiColors.cardinal);
33993
+
33994
+ var itemSlotTypes = ['head', 'neck', 'leftHand', 'rightHand', 'ring', 'legs', 'boot', 'accessory', 'armor', 'inventory'];
33995
+ var getSlotType = function getSlotType(itemSlotTypes, slotType, subType) {
33996
+ if (!itemSlotTypes.includes(slotType)) {
33997
+ return subType;
33998
+ }
33999
+ return slotType;
34000
+ };
34001
+ var ItemInfoDisplay = function ItemInfoDisplay(_ref) {
34002
+ var item = _ref.item,
34003
+ atlasIMG = _ref.atlasIMG,
34004
+ atlasJSON = _ref.atlasJSON,
34005
+ equipmentSet = _ref.equipmentSet;
34006
+ var itemToCompare = React.useMemo(function () {
34007
+ var _item$allowedEquipSlo;
34008
+ if (equipmentSet && (_item$allowedEquipSlo = item.allowedEquipSlotType) != null && _item$allowedEquipSlo.length) {
34009
+ var allowedSlotTypeCamelCase = lodash.camelCase(item.allowedEquipSlotType[0]);
34010
+ var itemSubTypeCamelCase = lodash.camelCase(item.subType);
34011
+ var slotType = getSlotType(itemSlotTypes, allowedSlotTypeCamelCase, itemSubTypeCamelCase);
34012
+ var itemFromEquipment = equipmentSet[slotType];
34013
+ if (itemFromEquipment && (!item._id || itemFromEquipment._id !== item._id)) {
34014
+ return itemFromEquipment;
34015
+ }
34016
+ }
34017
+ return undefined;
34018
+ }, [equipmentSet, item]);
34019
+ return React__default.createElement(Flex, null, React__default.createElement(ItemInfo, {
34020
+ item: item,
34021
+ itemToCompare: itemToCompare,
34022
+ atlasIMG: atlasIMG,
34023
+ atlasJSON: atlasJSON
34024
+ }), itemToCompare && React__default.createElement(CompareContainer, null, React__default.createElement(Equipped, null, React__default.createElement("span", null, "Equipped")), React__default.createElement(ItemInfo, {
34025
+ item: itemToCompare,
34026
+ itemToCompare: item,
34027
+ atlasIMG: atlasIMG,
34028
+ atlasJSON: atlasJSON
34029
+ })));
34030
+ };
34031
+ var Flex = /*#__PURE__*/styled.div.withConfig({
34032
+ displayName: "ItemInfoDisplay__Flex",
34033
+ componentId: "sc-1lftdo8-0"
34034
+ })(["display:flex;gap:0.5rem;"]);
34035
+ var Equipped = /*#__PURE__*/styled.div.withConfig({
34036
+ displayName: "ItemInfoDisplay__Equipped",
34037
+ componentId: "sc-1lftdo8-1"
34038
+ })(["position:absolute;bottom:100%;left:50%;transform:translateX(-50%);"]);
34039
+ var CompareContainer = /*#__PURE__*/styled.div.withConfig({
34040
+ displayName: "ItemInfoDisplay__CompareContainer",
34041
+ componentId: "sc-1lftdo8-2"
34042
+ })(["position:relative;"]);
34043
+
34044
+ var offset = 20;
34045
+ var ItemTooltip = function ItemTooltip(_ref) {
34046
+ var item = _ref.item,
34047
+ atlasIMG = _ref.atlasIMG,
34048
+ atlasJSON = _ref.atlasJSON,
34049
+ equipmentSet = _ref.equipmentSet;
34050
+ var ref = React.useRef(null);
34051
+ React.useEffect(function () {
34052
+ var current = ref.current;
34053
+ var initialOffset;
34054
+ if (current) {
34055
+ var handleMouseMove = function handleMouseMove(event) {
34056
+ var clientX = event.clientX,
34057
+ clientY = event.clientY;
34058
+ // Adjust the position of the tooltip based on the mouse position
34059
+ var rect = current.getBoundingClientRect();
34060
+ if (!initialOffset) {
34061
+ initialOffset = rect;
34062
+ }
34063
+ var tooltipWidth = rect.width;
34064
+ var tooltipHeight = rect.height;
34065
+ var isOffScreenRight = clientX + tooltipWidth + offset > window.innerWidth;
34066
+ var isOffScreenBottom = clientY + tooltipHeight + offset > window.innerHeight;
34067
+ var x = (isOffScreenRight ? clientX - tooltipWidth - offset : clientX + offset) - initialOffset.x;
34068
+ var y = (isOffScreenBottom ? clientY - tooltipHeight - offset : clientY + offset) - initialOffset.y;
34069
+ current.style.transform = "translate(" + x + "px, " + y + "px)";
34070
+ current.style.opacity = '1';
34071
+ };
34072
+ window.addEventListener('mousemove', handleMouseMove);
34073
+ return function () {
34074
+ window.removeEventListener('mousemove', handleMouseMove);
34075
+ };
34076
+ }
34077
+ return;
34078
+ }, []);
34079
+ return React__default.createElement(Container$b, {
34080
+ ref: ref
34081
+ }, React__default.createElement(ItemInfoDisplay, {
34082
+ item: item,
34083
+ atlasIMG: atlasIMG,
34084
+ atlasJSON: atlasJSON,
34085
+ equipmentSet: equipmentSet
34086
+ }));
34087
+ };
34088
+ var Container$b = /*#__PURE__*/styled.div.withConfig({
34089
+ displayName: "ItemTooltip__Container",
34090
+ componentId: "sc-11d9r7x-0"
34091
+ })(["position:fixed;z-index:50;pointer-events:none;left:0;top:0;opacity:0;"]);
34092
+
34093
+ var ItemInfoWrapper = function ItemInfoWrapper(_ref) {
34094
+ var children = _ref.children,
34095
+ atlasIMG = _ref.atlasIMG,
34096
+ atlasJSON = _ref.atlasJSON,
34097
+ item = _ref.item,
34098
+ equipmentSet = _ref.equipmentSet;
34099
+ var _useState = React.useState(false),
34100
+ isItemInfoVisible = _useState[0],
34101
+ setIsItemInfoVisible = _useState[1];
34102
+ return React__default.createElement("div", {
34103
+ onMouseEnter: setIsItemInfoVisible.bind(null, true),
34104
+ onMouseLeave: setIsItemInfoVisible.bind(null, false)
34105
+ }, children, isItemInfoVisible && React__default.createElement(ItemTooltip, {
34106
+ atlasIMG: atlasIMG,
34107
+ atlasJSON: atlasJSON,
34108
+ equipmentSet: equipmentSet,
34109
+ item: item
34110
+ }));
34111
+ };
34112
+
34113
+ var CraftBook = function CraftBook(_ref) {
34114
+ var atlasIMG = _ref.atlasIMG,
34115
+ atlasJSON = _ref.atlasJSON,
34116
+ onClose = _ref.onClose,
34117
+ onSelect = _ref.onSelect,
34118
+ onCraftItem = _ref.onCraftItem,
34119
+ craftablesItems = _ref.craftablesItems,
34120
+ equipmentSet = _ref.equipmentSet;
34121
+ var optionsId = 0;
34122
+ var _useState = React.useState({
34123
+ show: false,
34124
+ index: 200
34125
+ }),
34126
+ isShown = _useState[0],
34127
+ setIsShown = _useState[1];
34128
+ var _useState2 = React.useState(),
34129
+ craftItem = _useState2[0],
34130
+ setCraftItem = _useState2[1];
34131
+ var getDropdownOptions = function getDropdownOptions() {
34132
+ var options = [];
34133
+ Object.keys(shared.ItemSubType).forEach(function (key) {
34134
+ if (key === 'DeadBody') {
34135
+ return; // we can't craft crafting resouces...
34136
+ }
34137
+
34138
+ options.push({
34139
+ id: optionsId,
34140
+ value: key,
34141
+ option: key
34142
+ });
34143
+ optionsId += 1;
34144
+ });
34145
+ return options;
34146
+ };
34147
+ var modifyString = function modifyString(str) {
34148
+ // Split the string by "/" and "."
34149
+ var parts = str.split('/');
34150
+ var fileName = parts[parts.length - 1];
34151
+ parts = fileName.split('.');
34152
+ var name = parts[0];
34153
+ // Replace all occurrences of "-" with " "
34154
+ name = name.replace(/-/g, ' ');
34155
+ // Uppercase the first word
34156
+ var words = name.split(' ');
34157
+ var firstWord = words[0].slice(0, 1).toUpperCase() + words[0].slice(1);
34158
+ var modifiedWords = [firstWord].concat(words.slice(1));
34159
+ name = modifiedWords.join(' ');
34160
+ return name;
34161
+ };
34162
+ var handleClick = function handleClick(value) {
34163
+ setCraftItem(value);
34164
+ };
34165
+ return React__default.createElement(DraggableContainer, {
34166
+ type: exports.RPGUIContainerTypes.Framed,
34167
+ width: "500px",
34168
+ cancelDrag: ".equipment-container-body .arrow-selector .rpgui-dropdown-imp",
34169
+ onCloseButton: function onCloseButton() {
34170
+ if (onClose) {
34171
+ onClose();
34172
+ }
34173
+ }
34174
+ }, React__default.createElement("div", {
34175
+ style: {
34176
+ width: '100%'
34177
+ }
34178
+ }, React__default.createElement(Title$2, null, "Craftbook"), React__default.createElement(Subtitle, null, "Select an item to craft"), React__default.createElement("hr", {
34179
+ className: "golden"
34180
+ })), React__default.createElement(Dropdown, {
34181
+ options: getDropdownOptions(),
34182
+ onChange: function onChange(value) {
34183
+ return onSelect(value);
34184
+ }
34185
+ }), React__default.createElement(RadioInputScroller, null, craftablesItems == null ? void 0 : craftablesItems.map(function (option, index) {
34186
+ return React__default.createElement(RadioOptionsWrapper, {
34187
+ key: index
34188
+ }, React__default.createElement(SpriteAtlasWrapper, null, React__default.createElement(ItemInfoWrapper, {
34189
+ item: option,
34190
+ atlasIMG: atlasIMG,
34191
+ atlasJSON: atlasJSON,
34192
+ equipmentSet: equipmentSet
34193
+ }, React__default.createElement(SpriteFromAtlas, {
34194
+ atlasIMG: atlasIMG,
34195
+ atlasJSON: atlasJSON,
34196
+ spriteKey: option.texturePath,
34197
+ imgScale: 3,
34198
+ grayScale: !option.canCraft
34199
+ }))), React__default.createElement("div", null, React__default.createElement("div", {
34200
+ onPointerDown: function onPointerDown() {
34201
+ return handleClick(option.key);
34202
+ }
34203
+ }, React__default.createElement("input", {
34204
+ className: "rpgui-radio",
34205
+ type: "radio",
34206
+ value: option.name,
34207
+ name: "test",
34208
+ disabled: !option.canCraft,
34209
+ checked: craftItem === option.key,
34210
+ onChange: function onChange() {
34211
+ return handleClick(option.key);
34212
+ }
34213
+ }), React__default.createElement("label", {
34214
+ onPointerDown: function onPointerDown() {
34215
+ handleClick(option.key);
34216
+ },
34217
+ onTouchEnd: function onTouchEnd() {
34218
+ setIsShown({
34219
+ show: true,
34220
+ index: index
34221
+ });
34222
+ },
34223
+ style: {
34224
+ display: 'flex',
34225
+ alignItems: 'center'
34226
+ },
34227
+ onMouseEnter: function onMouseEnter() {
34228
+ return setIsShown({
34229
+ show: true,
34230
+ index: index
34231
+ });
34232
+ },
34233
+ onMouseLeave: function onMouseLeave() {
34234
+ return setIsShown({
34235
+ show: false,
34236
+ index: index
34237
+ });
34238
+ }
34239
+ }, modifyString(option.name))), isShown && isShown.index === index && option.ingredients.map(function (option, index) {
34240
+ return React__default.createElement(Recipes, {
34241
+ key: index
34242
+ }, React__default.createElement(SpriteFromAtlas, {
34243
+ atlasIMG: atlasIMG,
34244
+ atlasJSON: atlasJSON,
34245
+ spriteKey: option.texturePath,
34246
+ imgScale: 1
34247
+ }), React__default.createElement(StyledItem, null, modifyString(option.key), " (", option.qty, "x)"));
34248
+ })));
34249
+ })), React__default.createElement(ButtonWrapper, null, React__default.createElement(Button, {
34250
+ buttonType: exports.ButtonTypes.RPGUIButton,
34251
+ onPointerDown: onClose
34252
+ }, "Cancel"), React__default.createElement(Button, {
34253
+ buttonType: exports.ButtonTypes.RPGUIButton,
34254
+ onPointerDown: function onPointerDown() {
34255
+ return onCraftItem(craftItem);
34256
+ }
34257
+ }, "Craft")));
34258
+ };
34259
+ var StyledItem = /*#__PURE__*/styled.div.withConfig({
34260
+ displayName: "CraftBook__StyledItem",
34261
+ componentId: "sc-19q95ue-0"
34262
+ })(["margin-left:10px;"]);
34263
+ var Recipes = /*#__PURE__*/styled.div.withConfig({
34264
+ displayName: "CraftBook__Recipes",
34265
+ componentId: "sc-19q95ue-1"
34266
+ })(["font-size:0.6rem;color:yellow !important;margin-bottom:3px;display:flex;align-items:center;.sprite-from-atlas-img{top:0px;left:0px;}"]);
34267
+ var Title$2 = /*#__PURE__*/styled.h1.withConfig({
34268
+ displayName: "CraftBook__Title",
34269
+ componentId: "sc-19q95ue-2"
34270
+ })(["font-size:0.6rem;color:yellow !important;"]);
34271
+ var Subtitle = /*#__PURE__*/styled.h1.withConfig({
34272
+ displayName: "CraftBook__Subtitle",
34273
+ componentId: "sc-19q95ue-3"
34274
+ })(["font-size:0.4rem;color:yellow !important;"]);
34275
+ var RadioInputScroller = /*#__PURE__*/styled.div.withConfig({
34276
+ displayName: "CraftBook__RadioInputScroller",
34277
+ componentId: "sc-19q95ue-4"
34278
+ })(["padding-left:15px;padding-top:10px;width:100%;margin-top:1rem;align-items:center;margin-left:20px;align-items:flex-start;overflow-y:scroll;height:360px;-webkit-overflow-scrolling:touch;"]);
34279
+ var SpriteAtlasWrapper = /*#__PURE__*/styled.div.withConfig({
34280
+ displayName: "CraftBook__SpriteAtlasWrapper",
34281
+ componentId: "sc-19q95ue-5"
34282
+ })(["margin-right:40px;"]);
34283
+ var RadioOptionsWrapper = /*#__PURE__*/styled.div.withConfig({
34284
+ displayName: "CraftBook__RadioOptionsWrapper",
34285
+ componentId: "sc-19q95ue-6"
34286
+ })(["display:flex;align-items:stretch;margin-bottom:40px;"]);
34287
+ var ButtonWrapper = /*#__PURE__*/styled.div.withConfig({
34288
+ displayName: "CraftBook__ButtonWrapper",
34289
+ componentId: "sc-19q95ue-7"
34290
+ })(["display:flex;justify-content:space-around;padding-top:20px;width:100%;"]);
34291
+
34292
+ var DropdownSelectorContainer = function DropdownSelectorContainer(_ref) {
34293
+ var title = _ref.title,
34294
+ onChange = _ref.onChange,
34295
+ options = _ref.options,
34296
+ details = _ref.details;
34297
+ return React__default.createElement("div", null, React__default.createElement("p", null, title), React__default.createElement(Dropdown, {
34298
+ options: options.map(function (option, index) {
34299
+ return {
34300
+ option: option.name,
34301
+ value: option.id,
34302
+ id: index
34303
+ };
34304
+ }),
34305
+ onChange: onChange
34306
+ }), React__default.createElement(Details, null, details));
34307
+ };
34308
+ var Details = /*#__PURE__*/styled.p.withConfig({
34309
+ displayName: "DropdownSelectorContainer__Details",
34310
+ componentId: "sc-kaa0h9-0"
34311
+ })(["font-size:", " !important;"], uiFonts.size.xsmall);
34312
+
34054
34313
  var EquipmentSet = function EquipmentSet(_ref) {
34055
34314
  var equipmentSet = _ref.equipmentSet,
34056
34315
  onClose = _ref.onClose,
@@ -34145,544 +34404,6 @@ var EquipmentColumn = /*#__PURE__*/styled.div.withConfig({
34145
34404
  componentId: "sc-1wuddg2-1"
34146
34405
  })(["display:flex;justify-content:center;flex-wrap:wrap;flex-direction:column;touch-action:none;"]);
34147
34406
 
34148
- var IS_MOBILE_OR_TABLET = /*#__PURE__*/shared.isMobileOrTablet();
34149
-
34150
- var chunkString = function chunkString(str, length) {
34151
- return str.match(new RegExp('.{1,' + length + '}', 'g'));
34152
- };
34153
-
34154
- var DynamicText = function DynamicText(_ref) {
34155
- var text = _ref.text,
34156
- onFinish = _ref.onFinish,
34157
- onStart = _ref.onStart;
34158
- var _useState = React.useState(''),
34159
- textState = _useState[0],
34160
- setTextState = _useState[1];
34161
- React.useEffect(function () {
34162
- var i = 0;
34163
- var interval = setInterval(function () {
34164
- // on every interval, show one more character
34165
- if (i === 0) {
34166
- if (onStart) {
34167
- onStart();
34168
- }
34169
- }
34170
- if (i < text.length) {
34171
- setTextState(text.substring(0, i + 1));
34172
- i++;
34173
- } else {
34174
- clearInterval(interval);
34175
- if (onFinish) {
34176
- onFinish();
34177
- }
34178
- }
34179
- }, 50);
34180
- return function () {
34181
- clearInterval(interval);
34182
- };
34183
- }, [text]);
34184
- return React__default.createElement(TextContainer, null, textState);
34185
- };
34186
- var TextContainer = /*#__PURE__*/styled.p.withConfig({
34187
- displayName: "DynamicText__TextContainer",
34188
- componentId: "sc-1ggl9nd-0"
34189
- })(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]);
34190
-
34191
- var img$6 = '';
34192
-
34193
- var img$7 = '';
34194
-
34195
- var NPCDialogText = function NPCDialogText(_ref) {
34196
- var text = _ref.text,
34197
- onClose = _ref.onClose,
34198
- onEndStep = _ref.onEndStep,
34199
- onStartStep = _ref.onStartStep,
34200
- type = _ref.type;
34201
- var windowSize = React.useRef([window.innerWidth, window.innerHeight]);
34202
- function maxCharacters(width) {
34203
- // Set the font size to 16 pixels
34204
- var fontSize = 11.2;
34205
- // Calculate the number of characters that can fit in one line
34206
- var charactersPerLine = Math.floor(width / 2 / fontSize);
34207
- // Calculate the number of lines that can fit in the div
34208
- var linesPerDiv = Math.floor(180 / fontSize);
34209
- // Calculate the maximum number of characters that can fit in the div
34210
- var maxCharacters = charactersPerLine * linesPerDiv;
34211
- // Return the maximum number of characters
34212
- return Math.round(maxCharacters / 5);
34213
- }
34214
- var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
34215
- var _useState = React.useState(0),
34216
- chunkIndex = _useState[0],
34217
- setChunkIndex = _useState[1];
34218
- var onHandleSpacePress = function onHandleSpacePress(event) {
34219
- if (event.code === 'Space') {
34220
- goToNextStep();
34221
- }
34222
- };
34223
- var goToNextStep = function goToNextStep() {
34224
- var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
34225
- if (hasNextChunk) {
34226
- setChunkIndex(function (prev) {
34227
- return prev + 1;
34228
- });
34229
- } else {
34230
- // if there's no more text chunks, close the dialog
34231
- onClose();
34232
- }
34233
- };
34234
- React.useEffect(function () {
34235
- document.addEventListener('keydown', onHandleSpacePress);
34236
- return function () {
34237
- return document.removeEventListener('keydown', onHandleSpacePress);
34238
- };
34239
- }, [chunkIndex]);
34240
- var _useState2 = React.useState(false),
34241
- showGoNextIndicator = _useState2[0],
34242
- setShowGoNextIndicator = _useState2[1];
34243
- return React__default.createElement(Container$b, null, React__default.createElement(DynamicText, {
34244
- text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
34245
- onFinish: function onFinish() {
34246
- setShowGoNextIndicator(true);
34247
- onEndStep && onEndStep();
34248
- },
34249
- onStart: function onStart() {
34250
- setShowGoNextIndicator(false);
34251
- onStartStep && onStartStep();
34252
- }
34253
- }), showGoNextIndicator && React__default.createElement(PressSpaceIndicator, {
34254
- right: type === exports.NPCDialogType.TextOnly ? '1rem' : '10.5rem',
34255
- src: IS_MOBILE_OR_TABLET ? img$6 : img$7,
34256
- onPointerDown: function onPointerDown() {
34257
- goToNextStep();
34258
- }
34259
- }));
34260
- };
34261
- var Container$b = /*#__PURE__*/styled.div.withConfig({
34262
- displayName: "NPCDialogText__Container",
34263
- componentId: "sc-1cxkdh9-0"
34264
- })([""]);
34265
- var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
34266
- displayName: "NPCDialogText__PressSpaceIndicator",
34267
- componentId: "sc-1cxkdh9-1"
34268
- })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
34269
- var right = _ref2.right;
34270
- return right;
34271
- });
34272
-
34273
- //@ts-ignore
34274
- var useEventListener = function useEventListener(type, handler, el) {
34275
- if (el === void 0) {
34276
- el = window;
34277
- }
34278
- var savedHandler = React__default.useRef();
34279
- React__default.useEffect(function () {
34280
- savedHandler.current = handler;
34281
- }, [handler]);
34282
- React__default.useEffect(function () {
34283
- //@ts-ignore
34284
- var listener = function listener(e) {
34285
- return savedHandler.current(e);
34286
- };
34287
- el.addEventListener(type, listener);
34288
- return function () {
34289
- el.removeEventListener(type, listener);
34290
- };
34291
- }, [type, el]);
34292
- };
34293
-
34294
- var QuestionDialog = function QuestionDialog(_ref) {
34295
- var questions = _ref.questions,
34296
- answers = _ref.answers,
34297
- onClose = _ref.onClose;
34298
- var _useState = React.useState(questions[0]),
34299
- currentQuestion = _useState[0],
34300
- setCurrentQuestion = _useState[1];
34301
- var _useState2 = React.useState(false),
34302
- canShowAnswers = _useState2[0],
34303
- setCanShowAnswers = _useState2[1];
34304
- var onGetFirstAnswer = function onGetFirstAnswer() {
34305
- if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {
34306
- return null;
34307
- }
34308
- var firstAnswerId = currentQuestion.answerIds[0];
34309
- return answers.find(function (answer) {
34310
- return answer.id === firstAnswerId;
34311
- });
34312
- };
34313
- var _useState3 = React.useState(onGetFirstAnswer()),
34314
- currentAnswer = _useState3[0],
34315
- setCurrentAnswer = _useState3[1];
34316
- React.useEffect(function () {
34317
- setCurrentAnswer(onGetFirstAnswer());
34318
- }, [currentQuestion]);
34319
- var onGetAnswers = function onGetAnswers(answerIds) {
34320
- return answerIds.map(function (answerId) {
34321
- return answers.find(function (answer) {
34322
- return answer.id === answerId;
34323
- });
34324
- });
34325
- };
34326
- var onKeyPress = function onKeyPress(e) {
34327
- switch (e.key) {
34328
- case 'ArrowDown':
34329
- // select next answer, if any.
34330
- // if no next answer, select first answer
34331
- // const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(
34332
- // (answer) => answer?.id === currentAnswer!.id + 1
34333
- // );
34334
- var nextAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34335
- return (answer == null ? void 0 : answer.id) === currentAnswer.id + 1;
34336
- });
34337
- var nextAnswerID = currentQuestion.answerIds[nextAnswerIndex];
34338
- var nextAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34339
- return (answer == null ? void 0 : answer.id) === nextAnswerID;
34340
- });
34341
- setCurrentAnswer(nextAnswer || onGetFirstAnswer());
34342
- break;
34343
- case 'ArrowUp':
34344
- // select previous answer, if any.
34345
- // if no previous answer, select last answer
34346
- var previousAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
34347
- return (answer == null ? void 0 : answer.id) === currentAnswer.id - 1;
34348
- });
34349
- var previousAnswerID = currentQuestion.answerIds && currentQuestion.answerIds[previousAnswerIndex];
34350
- var previousAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
34351
- return (answer == null ? void 0 : answer.id) === previousAnswerID;
34352
- });
34353
- if (previousAnswer) {
34354
- setCurrentAnswer(previousAnswer);
34355
- } else {
34356
- setCurrentAnswer(onGetAnswers(currentQuestion.answerIds).pop());
34357
- }
34358
- break;
34359
- case 'Enter':
34360
- setCanShowAnswers(false);
34361
- if (!(currentAnswer != null && currentAnswer.nextQuestionId)) {
34362
- onClose();
34363
- return;
34364
- } else {
34365
- setCurrentQuestion(questions.find(function (question) {
34366
- return question.id === currentAnswer.nextQuestionId;
34367
- }));
34368
- }
34369
- break;
34370
- }
34371
- };
34372
- useEventListener('keydown', onKeyPress);
34373
- var onAnswerClick = function onAnswerClick(answer) {
34374
- setCanShowAnswers(false);
34375
- if (answer.nextQuestionId) {
34376
- // if there is a next question, go to it
34377
- setCurrentQuestion(questions.find(function (question) {
34378
- return question.id === answer.nextQuestionId;
34379
- }));
34380
- } else {
34381
- // else, finish dialog!
34382
- onClose();
34383
- }
34384
- };
34385
- var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
34386
- var answerIds = currentQuestion.answerIds;
34387
- if (!answerIds) {
34388
- return null;
34389
- }
34390
- var answers = onGetAnswers(answerIds);
34391
- if (!answers) {
34392
- return null;
34393
- }
34394
- return answers.map(function (answer) {
34395
- var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
34396
- var selectedColor = isSelected ? 'yellow' : 'white';
34397
- if (answer) {
34398
- return React__default.createElement(AnswerRow, {
34399
- key: "answer_" + answer.id
34400
- }, React__default.createElement(AnswerSelectedIcon, {
34401
- color: selectedColor
34402
- }, isSelected ? 'X' : null), React__default.createElement(Answer, {
34403
- key: answer.id,
34404
- onPointerDown: function onPointerDown() {
34405
- return onAnswerClick(answer);
34406
- },
34407
- color: selectedColor
34408
- }, answer.text));
34409
- }
34410
- return null;
34411
- });
34412
- };
34413
- return React__default.createElement(Container$c, null, React__default.createElement(QuestionContainer, null, React__default.createElement(DynamicText, {
34414
- text: currentQuestion.text,
34415
- onStart: function onStart() {
34416
- return setCanShowAnswers(false);
34417
- },
34418
- onFinish: function onFinish() {
34419
- return setCanShowAnswers(true);
34420
- }
34421
- })), canShowAnswers && React__default.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
34422
- };
34423
- var Container$c = /*#__PURE__*/styled.div.withConfig({
34424
- displayName: "QuestionDialog__Container",
34425
- componentId: "sc-bxc5u0-0"
34426
- })(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
34427
- var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
34428
- displayName: "QuestionDialog__QuestionContainer",
34429
- componentId: "sc-bxc5u0-1"
34430
- })(["flex:100%;width:100%;"]);
34431
- var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
34432
- displayName: "QuestionDialog__AnswersContainer",
34433
- componentId: "sc-bxc5u0-2"
34434
- })(["flex:100%;"]);
34435
- var Answer = /*#__PURE__*/styled.p.withConfig({
34436
- displayName: "QuestionDialog__Answer",
34437
- componentId: "sc-bxc5u0-3"
34438
- })(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
34439
- return props.color;
34440
- });
34441
- var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
34442
- displayName: "QuestionDialog__AnswerSelectedIcon",
34443
- componentId: "sc-bxc5u0-4"
34444
- })(["flex:5% 0 0;color:", " !important;"], function (props) {
34445
- return props.color;
34446
- });
34447
- var AnswerRow = /*#__PURE__*/styled.div.withConfig({
34448
- displayName: "QuestionDialog__AnswerRow",
34449
- componentId: "sc-bxc5u0-5"
34450
- })(["display:flex;flex-wrap:wrap;justify-content:center;align-items:center;margin-bottom:0.5rem;height:22px;p{line-height:unset;margin-top:0;margin-bottom:0rem;}"]);
34451
-
34452
- var img$8 = '';
34453
-
34454
- (function (NPCDialogType) {
34455
- NPCDialogType["TextOnly"] = "TextOnly";
34456
- NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
34457
- })(exports.NPCDialogType || (exports.NPCDialogType = {}));
34458
- var NPCDialog = function NPCDialog(_ref) {
34459
- var text = _ref.text,
34460
- type = _ref.type,
34461
- _onClose = _ref.onClose,
34462
- imagePath = _ref.imagePath,
34463
- _ref$isQuestionDialog = _ref.isQuestionDialog,
34464
- isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
34465
- questions = _ref.questions,
34466
- answers = _ref.answers;
34467
- return React__default.createElement(RPGUIContainer, {
34468
- type: exports.RPGUIContainerTypes.FramedGold,
34469
- width: isQuestionDialog ? '600px' : '80%',
34470
- height: '180px'
34471
- }, isQuestionDialog && questions && answers ? React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer$1, {
34472
- flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
34473
- }, React__default.createElement(QuestionDialog, {
34474
- questions: questions,
34475
- answers: answers,
34476
- onClose: function onClose() {
34477
- if (_onClose) {
34478
- _onClose();
34479
- }
34480
- }
34481
- })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
34482
- src: imagePath || img$8
34483
- }))) : React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$d, null, React__default.createElement(TextContainer$1, {
34484
- flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
34485
- }, React__default.createElement(NPCDialogText, {
34486
- type: type,
34487
- text: text || 'No text provided.',
34488
- onClose: function onClose() {
34489
- if (_onClose) {
34490
- _onClose();
34491
- }
34492
- }
34493
- })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
34494
- src: imagePath || img$8
34495
- })))));
34496
- };
34497
- var Container$d = /*#__PURE__*/styled.div.withConfig({
34498
- displayName: "NPCDialog__Container",
34499
- componentId: "sc-1b4aw74-0"
34500
- })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
34501
- var TextContainer$1 = /*#__PURE__*/styled.div.withConfig({
34502
- displayName: "NPCDialog__TextContainer",
34503
- componentId: "sc-1b4aw74-1"
34504
- })(["flex:", " 0 0;width:355px;"], function (_ref2) {
34505
- var flex = _ref2.flex;
34506
- return flex;
34507
- });
34508
- var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
34509
- displayName: "NPCDialog__ThumbnailContainer",
34510
- componentId: "sc-1b4aw74-2"
34511
- })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
34512
- var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
34513
- displayName: "NPCDialog__NPCThumbnail",
34514
- componentId: "sc-1b4aw74-3"
34515
- })(["image-rendering:pixelated;height:128px;width:128px;"]);
34516
-
34517
- (function (ImgSide) {
34518
- ImgSide["right"] = "right";
34519
- ImgSide["left"] = "left";
34520
- })(exports.ImgSide || (exports.ImgSide = {}));
34521
- var NPCMultiDialog = function NPCMultiDialog(_ref) {
34522
- var _textAndTypeArray$sli;
34523
- var _onClose = _ref.onClose,
34524
- textAndTypeArray = _ref.textAndTypeArray;
34525
- var _useState = React.useState(false),
34526
- showGoNextIndicator = _useState[0],
34527
- setShowGoNextIndicator = _useState[1];
34528
- var _useState2 = React.useState(0),
34529
- slide = _useState2[0],
34530
- setSlide = _useState2[1];
34531
- var onHandleSpacePress = function onHandleSpacePress(event) {
34532
- if (event.code === 'Space') {
34533
- if (slide < (textAndTypeArray == null ? void 0 : textAndTypeArray.length) - 1) {
34534
- setSlide(function (prev) {
34535
- return prev + 1;
34536
- });
34537
- } else {
34538
- // if there's no more text chunks, close the dialog
34539
- _onClose();
34540
- }
34541
- }
34542
- };
34543
- React.useEffect(function () {
34544
- document.addEventListener('keydown', onHandleSpacePress);
34545
- return function () {
34546
- return document.removeEventListener('keydown', onHandleSpacePress);
34547
- };
34548
- }, [slide]);
34549
- return React__default.createElement(RPGUIContainer, {
34550
- type: exports.RPGUIContainerTypes.FramedGold,
34551
- width: '50%',
34552
- height: '180px'
34553
- }, React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$e, null, ((_textAndTypeArray$sli = textAndTypeArray[slide]) == null ? void 0 : _textAndTypeArray$sli.imageSide) === 'right' && React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer$2, {
34554
- flex: '70%'
34555
- }, React__default.createElement(NPCDialogText, {
34556
- onStartStep: function onStartStep() {
34557
- return setShowGoNextIndicator(false);
34558
- },
34559
- onEndStep: function onEndStep() {
34560
- return setShowGoNextIndicator(true);
34561
- },
34562
- text: textAndTypeArray[slide].text || 'No text provided.',
34563
- onClose: function onClose() {
34564
- if (_onClose) {
34565
- _onClose();
34566
- }
34567
- }
34568
- })), React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
34569
- src: textAndTypeArray[slide].imagePath || img$8
34570
- })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator$1, {
34571
- right: '10.5rem',
34572
- src: img$7
34573
- })), textAndTypeArray[slide].imageSide === 'left' && React__default.createElement(React__default.Fragment, null, React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
34574
- src: textAndTypeArray[slide].imagePath || img$8
34575
- })), React__default.createElement(TextContainer$2, {
34576
- flex: '70%'
34577
- }, React__default.createElement(NPCDialogText, {
34578
- onStartStep: function onStartStep() {
34579
- return setShowGoNextIndicator(false);
34580
- },
34581
- onEndStep: function onEndStep() {
34582
- return setShowGoNextIndicator(true);
34583
- },
34584
- text: textAndTypeArray[slide].text || 'No text provided.',
34585
- onClose: function onClose() {
34586
- if (_onClose) {
34587
- _onClose();
34588
- }
34589
- }
34590
- })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator$1, {
34591
- right: '1rem',
34592
- src: img$7
34593
- }))), ")"));
34594
- };
34595
- var Container$e = /*#__PURE__*/styled.div.withConfig({
34596
- displayName: "NPCMultiDialog__Container",
34597
- componentId: "sc-rvu5wg-0"
34598
- })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
34599
- var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
34600
- displayName: "NPCMultiDialog__TextContainer",
34601
- componentId: "sc-rvu5wg-1"
34602
- })(["flex:", " 0 0;width:355px;"], function (_ref2) {
34603
- var flex = _ref2.flex;
34604
- return flex;
34605
- });
34606
- var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
34607
- displayName: "NPCMultiDialog__ThumbnailContainer",
34608
- componentId: "sc-rvu5wg-2"
34609
- })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
34610
- var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
34611
- displayName: "NPCMultiDialog__NPCThumbnail",
34612
- componentId: "sc-rvu5wg-3"
34613
- })(["image-rendering:pixelated;height:128px;width:128px;"]);
34614
- var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
34615
- displayName: "NPCMultiDialog__PressSpaceIndicator",
34616
- componentId: "sc-rvu5wg-4"
34617
- })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref3) {
34618
- var right = _ref3.right;
34619
- return right;
34620
- });
34621
-
34622
- var HistoryDialog = function HistoryDialog(_ref) {
34623
- var backgroundImgPath = _ref.backgroundImgPath,
34624
- fullCoverBackground = _ref.fullCoverBackground,
34625
- questions = _ref.questions,
34626
- answers = _ref.answers,
34627
- text = _ref.text,
34628
- imagePath = _ref.imagePath,
34629
- textAndTypeArray = _ref.textAndTypeArray,
34630
- onClose = _ref.onClose;
34631
- var _useState = React.useState(0),
34632
- img = _useState[0],
34633
- setImage = _useState[1];
34634
- var onHandleSpacePress = function onHandleSpacePress(event) {
34635
- if (event.code === 'Space') {
34636
- if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
34637
- setImage(function (prev) {
34638
- return prev + 1;
34639
- });
34640
- } else {
34641
- // if there's no more text chunks, close the dialog
34642
- onClose();
34643
- }
34644
- }
34645
- };
34646
- React.useEffect(function () {
34647
- document.addEventListener('keydown', onHandleSpacePress);
34648
- return function () {
34649
- return document.removeEventListener('keydown', onHandleSpacePress);
34650
- };
34651
- }, [backgroundImgPath]);
34652
- return React__default.createElement(BackgroundContainer, {
34653
- imgPath: backgroundImgPath[img],
34654
- fullImg: fullCoverBackground
34655
- }, React__default.createElement(DialogContainer, null, textAndTypeArray ? React__default.createElement(NPCMultiDialog, {
34656
- textAndTypeArray: textAndTypeArray,
34657
- onClose: onClose
34658
- }) : questions && answers ? React__default.createElement(QuestionDialog, {
34659
- questions: questions,
34660
- answers: answers,
34661
- onClose: onClose
34662
- }) : text && imagePath ? React__default.createElement(NPCDialog, {
34663
- text: text,
34664
- imagePath: imagePath,
34665
- onClose: onClose,
34666
- type: exports.NPCDialogType.TextAndThumbnail
34667
- }) : React__default.createElement(NPCDialog, {
34668
- text: text,
34669
- onClose: onClose,
34670
- type: exports.NPCDialogType.TextOnly
34671
- })));
34672
- };
34673
- var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
34674
- displayName: "HistoryDialog__BackgroundContainer",
34675
- componentId: "sc-u6oe75-0"
34676
- })(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
34677
- return props.imgPath;
34678
- }, function (props) {
34679
- return props.imgPath ? 'cover' : 'auto';
34680
- });
34681
- var DialogContainer = /*#__PURE__*/styled.div.withConfig({
34682
- displayName: "HistoryDialog__DialogContainer",
34683
- componentId: "sc-u6oe75-1"
34684
- })(["display:flex;justify-content:center;padding-top:200px;"]);
34685
-
34686
34407
  var SlotsContainer = function SlotsContainer(_ref) {
34687
34408
  var children = _ref.children,
34688
34409
  title = _ref.title,
@@ -34903,7 +34624,7 @@ var ShortcutsSetter = function ShortcutsSetter(_ref) {
34903
34624
  return word[0];
34904
34625
  }));
34905
34626
  };
34906
- return React__default.createElement(Container$f, null, React__default.createElement("p", null, "Shortcuts:"), React__default.createElement(List, {
34627
+ return React__default.createElement(Container$c, null, React__default.createElement("p", null, "Shortcuts:"), React__default.createElement(List, {
34907
34628
  id: "shortcuts_list"
34908
34629
  }, Array.from({
34909
34630
  length: 6
@@ -34919,7 +34640,7 @@ var ShortcutsSetter = function ShortcutsSetter(_ref) {
34919
34640
  }, getContent(i));
34920
34641
  })));
34921
34642
  };
34922
- var Container$f = /*#__PURE__*/styled.div.withConfig({
34643
+ var Container$c = /*#__PURE__*/styled.div.withConfig({
34923
34644
  displayName: "ShortcutsSetter__Container",
34924
34645
  componentId: "sc-xuouuf-0"
34925
34646
  })(["p{margin:0;margin-left:0.5rem;}"]);
@@ -34956,7 +34677,8 @@ var ItemContainer$1 = function ItemContainer(_ref) {
34956
34677
  dragScale = _ref.dragScale,
34957
34678
  shortcuts = _ref.shortcuts,
34958
34679
  setItemShortcut = _ref.setItemShortcut,
34959
- removeShortcut = _ref.removeShortcut;
34680
+ removeShortcut = _ref.removeShortcut,
34681
+ equipmentSet = _ref.equipmentSet;
34960
34682
  var _useState = React.useState({
34961
34683
  isOpen: false,
34962
34684
  maxQuantity: 1,
@@ -35015,173 +34737,499 @@ var ItemContainer$1 = function ItemContainer(_ref) {
35015
34737
  },
35016
34738
  atlasIMG: atlasIMG,
35017
34739
  atlasJSON: atlasJSON,
35018
- isSelectingShortcut: settingShortcutIndex !== -1
34740
+ isSelectingShortcut: settingShortcutIndex !== -1,
34741
+ equipmentSet: equipmentSet
35019
34742
  }));
35020
34743
  }
35021
- return slots;
34744
+ return slots;
34745
+ };
34746
+ return React__default.createElement(React__default.Fragment, null, React__default.createElement(SlotsContainer, {
34747
+ title: itemContainer.name || 'Container',
34748
+ onClose: onClose,
34749
+ initialPosition: initialPosition
34750
+ }, type === shared.ItemContainerType.Inventory && shortcuts && removeShortcut && React__default.createElement(ShortcutsSetter, {
34751
+ setSettingShortcutIndex: setSettingShortcutIndex,
34752
+ settingShortcutIndex: settingShortcutIndex,
34753
+ shortcuts: shortcuts,
34754
+ removeShortcut: removeShortcut,
34755
+ atlasIMG: atlasIMG,
34756
+ atlasJSON: atlasJSON
34757
+ }), React__default.createElement(ItemsContainer, {
34758
+ className: "item-container-body"
34759
+ }, onRenderSlots())), quantitySelect.isOpen && React__default.createElement(QuantitySelectorContainer, null, React__default.createElement(ItemQuantitySelector, {
34760
+ quantity: quantitySelect.maxQuantity,
34761
+ onConfirm: function onConfirm(quantity) {
34762
+ quantitySelect.callback(quantity);
34763
+ setQuantitySelect({
34764
+ isOpen: false,
34765
+ maxQuantity: 1,
34766
+ callback: function callback() {}
34767
+ });
34768
+ },
34769
+ onClose: function onClose() {
34770
+ quantitySelect.callback(-1);
34771
+ setQuantitySelect({
34772
+ isOpen: false,
34773
+ maxQuantity: 1,
34774
+ callback: function callback() {}
34775
+ });
34776
+ }
34777
+ })));
34778
+ };
34779
+ var ItemsContainer = /*#__PURE__*/styled.div.withConfig({
34780
+ displayName: "ItemContainer__ItemsContainer",
34781
+ componentId: "sc-15y5p9l-0"
34782
+ })(["display:flex;justify-content:center;flex-wrap:wrap;"]);
34783
+ var QuantitySelectorContainer = /*#__PURE__*/styled.div.withConfig({
34784
+ displayName: "ItemContainer__QuantitySelectorContainer",
34785
+ componentId: "sc-15y5p9l-1"
34786
+ })(["position:absolute;top:0;left:0;width:100vw;height:100vh;z-index:100;display:flex;justify-content:center;align-items:center;background-color:rgba(0,0,0,0.5);"]);
34787
+
34788
+ var ItemSelector = function ItemSelector(_ref) {
34789
+ var atlasIMG = _ref.atlasIMG,
34790
+ atlasJSON = _ref.atlasJSON,
34791
+ options = _ref.options,
34792
+ onClose = _ref.onClose,
34793
+ onSelect = _ref.onSelect;
34794
+ var _useState = React.useState(),
34795
+ selectedValue = _useState[0],
34796
+ setSelectedValue = _useState[1];
34797
+ var handleClick = function handleClick() {
34798
+ var element = document.querySelector("input[name='test']:checked");
34799
+ var elementValue = element.value;
34800
+ setSelectedValue(elementValue);
34801
+ };
34802
+ React.useEffect(function () {
34803
+ if (selectedValue) {
34804
+ onSelect(selectedValue);
34805
+ }
34806
+ }, [selectedValue]);
34807
+ return React__default.createElement(DraggableContainer, {
34808
+ type: exports.RPGUIContainerTypes.Framed,
34809
+ width: "500px",
34810
+ cancelDrag: ".equipment-container-body .arrow-selector",
34811
+ onCloseButton: function onCloseButton() {
34812
+ if (onClose) {
34813
+ onClose();
34814
+ }
34815
+ }
34816
+ }, React__default.createElement("div", {
34817
+ style: {
34818
+ width: '100%'
34819
+ }
34820
+ }, React__default.createElement(Title$3, null, 'Harvesting instruments'), React__default.createElement(Subtitle$1, null, 'Use the tool, you need it'), React__default.createElement("hr", {
34821
+ className: "golden"
34822
+ })), React__default.createElement(RadioInputScroller$1, null, options == null ? void 0 : options.map(function (option, index) {
34823
+ return React__default.createElement(RadioOptionsWrapper$1, {
34824
+ key: index
34825
+ }, React__default.createElement(SpriteAtlasWrapper$1, null, React__default.createElement(SpriteFromAtlas, {
34826
+ atlasIMG: atlasIMG,
34827
+ atlasJSON: atlasJSON,
34828
+ spriteKey: option.imageKey,
34829
+ imgScale: 3
34830
+ })), React__default.createElement("div", null, React__default.createElement("input", {
34831
+ className: "rpgui-radio",
34832
+ type: "radio",
34833
+ value: option.name,
34834
+ name: "test"
34835
+ }), React__default.createElement("label", {
34836
+ onPointerDown: handleClick,
34837
+ style: {
34838
+ display: 'flex',
34839
+ alignItems: 'center'
34840
+ }
34841
+ }, option.name, " ", React__default.createElement("br", null), option.description)));
34842
+ })), React__default.createElement(ButtonWrapper$1, null, React__default.createElement(Button, {
34843
+ buttonType: exports.ButtonTypes.RPGUIButton,
34844
+ onPointerDown: onClose
34845
+ }, "Cancel"), React__default.createElement(Button, {
34846
+ buttonType: exports.ButtonTypes.RPGUIButton
34847
+ }, "Select")));
34848
+ };
34849
+ var Title$3 = /*#__PURE__*/styled.h1.withConfig({
34850
+ displayName: "ItemSelector__Title",
34851
+ componentId: "sc-gptoxp-0"
34852
+ })(["font-size:0.6rem;color:yellow !important;"]);
34853
+ var Subtitle$1 = /*#__PURE__*/styled.h1.withConfig({
34854
+ displayName: "ItemSelector__Subtitle",
34855
+ componentId: "sc-gptoxp-1"
34856
+ })(["font-size:0.4rem;color:yellow !important;"]);
34857
+ var RadioInputScroller$1 = /*#__PURE__*/styled.div.withConfig({
34858
+ displayName: "ItemSelector__RadioInputScroller",
34859
+ componentId: "sc-gptoxp-2"
34860
+ })(["padding-left:15px;padding-top:10px;width:100%;margin-top:1rem;align-items:center;margin-left:20px;align-items:flex-start;overflow-y:scroll;height:360px;"]);
34861
+ var SpriteAtlasWrapper$1 = /*#__PURE__*/styled.div.withConfig({
34862
+ displayName: "ItemSelector__SpriteAtlasWrapper",
34863
+ componentId: "sc-gptoxp-3"
34864
+ })(["margin-right:40px;"]);
34865
+ var RadioOptionsWrapper$1 = /*#__PURE__*/styled.div.withConfig({
34866
+ displayName: "ItemSelector__RadioOptionsWrapper",
34867
+ componentId: "sc-gptoxp-4"
34868
+ })(["display:flex;align-items:stretch;margin-bottom:40px;"]);
34869
+ var ButtonWrapper$1 = /*#__PURE__*/styled.div.withConfig({
34870
+ displayName: "ItemSelector__ButtonWrapper",
34871
+ componentId: "sc-gptoxp-5"
34872
+ })(["display:flex;justify-content:space-around;padding-top:20px;width:100%;"]);
34873
+
34874
+ var ListMenu = function ListMenu(_ref) {
34875
+ var options = _ref.options,
34876
+ onSelected = _ref.onSelected,
34877
+ x = _ref.x,
34878
+ y = _ref.y;
34879
+ return React__default.createElement(Container$d, {
34880
+ x: x,
34881
+ y: y
34882
+ }, React__default.createElement("ul", {
34883
+ className: "rpgui-list-imp",
34884
+ style: {
34885
+ overflow: 'hidden'
34886
+ }
34887
+ }, options.map(function (params, index) {
34888
+ return React__default.createElement(ListElement$1, {
34889
+ key: (params == null ? void 0 : params.id) || index,
34890
+ onPointerDown: function onPointerDown() {
34891
+ onSelected(params == null ? void 0 : params.id);
34892
+ }
34893
+ }, (params == null ? void 0 : params.text) || 'No text');
34894
+ })));
34895
+ };
34896
+ var Container$d = /*#__PURE__*/styled.div.withConfig({
34897
+ displayName: "ListMenu__Container",
34898
+ componentId: "sc-i9097t-0"
34899
+ })(["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) {
34900
+ return props.y || 0;
34901
+ }, function (props) {
34902
+ return props.x || 0;
34903
+ }, uiFonts.size.xsmall);
34904
+ var ListElement$1 = /*#__PURE__*/styled.li.withConfig({
34905
+ displayName: "ListMenu__ListElement",
34906
+ componentId: "sc-i9097t-1"
34907
+ })(["margin-right:0.5rem;"]);
34908
+
34909
+ var img$6 = '';
34910
+
34911
+ var img$7 = '';
34912
+
34913
+ (function (ImgSide) {
34914
+ ImgSide["right"] = "right";
34915
+ ImgSide["left"] = "left";
34916
+ })(exports.ImgSide || (exports.ImgSide = {}));
34917
+ var NPCMultiDialog = function NPCMultiDialog(_ref) {
34918
+ var _textAndTypeArray$sli;
34919
+ var _onClose = _ref.onClose,
34920
+ textAndTypeArray = _ref.textAndTypeArray;
34921
+ var _useState = React.useState(false),
34922
+ showGoNextIndicator = _useState[0],
34923
+ setShowGoNextIndicator = _useState[1];
34924
+ var _useState2 = React.useState(0),
34925
+ slide = _useState2[0],
34926
+ setSlide = _useState2[1];
34927
+ var onHandleSpacePress = function onHandleSpacePress(event) {
34928
+ if (event.code === 'Space') {
34929
+ if (slide < (textAndTypeArray == null ? void 0 : textAndTypeArray.length) - 1) {
34930
+ setSlide(function (prev) {
34931
+ return prev + 1;
34932
+ });
34933
+ } else {
34934
+ // if there's no more text chunks, close the dialog
34935
+ _onClose();
34936
+ }
34937
+ }
34938
+ };
34939
+ React.useEffect(function () {
34940
+ document.addEventListener('keydown', onHandleSpacePress);
34941
+ return function () {
34942
+ return document.removeEventListener('keydown', onHandleSpacePress);
34943
+ };
34944
+ }, [slide]);
34945
+ return React__default.createElement(RPGUIContainer, {
34946
+ type: exports.RPGUIContainerTypes.FramedGold,
34947
+ width: '50%',
34948
+ height: '180px'
34949
+ }, React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$e, null, ((_textAndTypeArray$sli = textAndTypeArray[slide]) == null ? void 0 : _textAndTypeArray$sli.imageSide) === 'right' && React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer, {
34950
+ flex: '70%'
34951
+ }, React__default.createElement(NPCDialogText, {
34952
+ onStartStep: function onStartStep() {
34953
+ return setShowGoNextIndicator(false);
34954
+ },
34955
+ onEndStep: function onEndStep() {
34956
+ return setShowGoNextIndicator(true);
34957
+ },
34958
+ text: textAndTypeArray[slide].text || 'No text provided.',
34959
+ onClose: function onClose() {
34960
+ if (_onClose) {
34961
+ _onClose();
34962
+ }
34963
+ }
34964
+ })), React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
34965
+ src: textAndTypeArray[slide].imagePath || img$6
34966
+ })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator, {
34967
+ right: '10.5rem',
34968
+ src: img$7
34969
+ })), textAndTypeArray[slide].imageSide === 'left' && React__default.createElement(React__default.Fragment, null, React__default.createElement(ThumbnailContainer, null, React__default.createElement(NPCThumbnail, {
34970
+ src: textAndTypeArray[slide].imagePath || img$6
34971
+ })), React__default.createElement(TextContainer, {
34972
+ flex: '70%'
34973
+ }, React__default.createElement(NPCDialogText, {
34974
+ onStartStep: function onStartStep() {
34975
+ return setShowGoNextIndicator(false);
34976
+ },
34977
+ onEndStep: function onEndStep() {
34978
+ return setShowGoNextIndicator(true);
34979
+ },
34980
+ text: textAndTypeArray[slide].text || 'No text provided.',
34981
+ onClose: function onClose() {
34982
+ if (_onClose) {
34983
+ _onClose();
34984
+ }
34985
+ }
34986
+ })), showGoNextIndicator && React__default.createElement(PressSpaceIndicator, {
34987
+ right: '1rem',
34988
+ src: img$7
34989
+ }))), ")"));
34990
+ };
34991
+ var Container$e = /*#__PURE__*/styled.div.withConfig({
34992
+ displayName: "NPCMultiDialog__Container",
34993
+ componentId: "sc-rvu5wg-0"
34994
+ })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
34995
+ var TextContainer = /*#__PURE__*/styled.div.withConfig({
34996
+ displayName: "NPCMultiDialog__TextContainer",
34997
+ componentId: "sc-rvu5wg-1"
34998
+ })(["flex:", " 0 0;width:355px;"], function (_ref2) {
34999
+ var flex = _ref2.flex;
35000
+ return flex;
35001
+ });
35002
+ var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
35003
+ displayName: "NPCMultiDialog__ThumbnailContainer",
35004
+ componentId: "sc-rvu5wg-2"
35005
+ })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
35006
+ var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
35007
+ displayName: "NPCMultiDialog__NPCThumbnail",
35008
+ componentId: "sc-rvu5wg-3"
35009
+ })(["image-rendering:pixelated;height:128px;width:128px;"]);
35010
+ var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
35011
+ displayName: "NPCMultiDialog__PressSpaceIndicator",
35012
+ componentId: "sc-rvu5wg-4"
35013
+ })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref3) {
35014
+ var right = _ref3.right;
35015
+ return right;
35016
+ });
35017
+
35018
+ //@ts-ignore
35019
+ var useEventListener = function useEventListener(type, handler, el) {
35020
+ if (el === void 0) {
35021
+ el = window;
35022
+ }
35023
+ var savedHandler = React__default.useRef();
35024
+ React__default.useEffect(function () {
35025
+ savedHandler.current = handler;
35026
+ }, [handler]);
35027
+ React__default.useEffect(function () {
35028
+ //@ts-ignore
35029
+ var listener = function listener(e) {
35030
+ return savedHandler.current(e);
35031
+ };
35032
+ el.addEventListener(type, listener);
35033
+ return function () {
35034
+ el.removeEventListener(type, listener);
35035
+ };
35036
+ }, [type, el]);
35037
+ };
35038
+
35039
+ var DynamicText = function DynamicText(_ref) {
35040
+ var text = _ref.text,
35041
+ onFinish = _ref.onFinish,
35042
+ onStart = _ref.onStart;
35043
+ var _useState = React.useState(''),
35044
+ textState = _useState[0],
35045
+ setTextState = _useState[1];
35046
+ React.useEffect(function () {
35047
+ var i = 0;
35048
+ var interval = setInterval(function () {
35049
+ // on every interval, show one more character
35050
+ if (i === 0) {
35051
+ if (onStart) {
35052
+ onStart();
35053
+ }
35054
+ }
35055
+ if (i < text.length) {
35056
+ setTextState(text.substring(0, i + 1));
35057
+ i++;
35058
+ } else {
35059
+ clearInterval(interval);
35060
+ if (onFinish) {
35061
+ onFinish();
35062
+ }
35063
+ }
35064
+ }, 50);
35065
+ return function () {
35066
+ clearInterval(interval);
35067
+ };
35068
+ }, [text]);
35069
+ return React__default.createElement(TextContainer$1, null, textState);
35070
+ };
35071
+ var TextContainer$1 = /*#__PURE__*/styled.p.withConfig({
35072
+ displayName: "DynamicText__TextContainer",
35073
+ componentId: "sc-1ggl9nd-0"
35074
+ })(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]);
35075
+
35076
+ var QuestionDialog = function QuestionDialog(_ref) {
35077
+ var questions = _ref.questions,
35078
+ answers = _ref.answers,
35079
+ onClose = _ref.onClose;
35080
+ var _useState = React.useState(questions[0]),
35081
+ currentQuestion = _useState[0],
35082
+ setCurrentQuestion = _useState[1];
35083
+ var _useState2 = React.useState(false),
35084
+ canShowAnswers = _useState2[0],
35085
+ setCanShowAnswers = _useState2[1];
35086
+ var onGetFirstAnswer = function onGetFirstAnswer() {
35087
+ if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {
35088
+ return null;
35089
+ }
35090
+ var firstAnswerId = currentQuestion.answerIds[0];
35091
+ return answers.find(function (answer) {
35092
+ return answer.id === firstAnswerId;
35093
+ });
35022
35094
  };
35023
- return React__default.createElement(React__default.Fragment, null, React__default.createElement(SlotsContainer, {
35024
- title: itemContainer.name || 'Container',
35025
- onClose: onClose,
35026
- initialPosition: initialPosition
35027
- }, type === shared.ItemContainerType.Inventory && shortcuts && removeShortcut && React__default.createElement(ShortcutsSetter, {
35028
- setSettingShortcutIndex: setSettingShortcutIndex,
35029
- settingShortcutIndex: settingShortcutIndex,
35030
- shortcuts: shortcuts,
35031
- removeShortcut: removeShortcut,
35032
- atlasIMG: atlasIMG,
35033
- atlasJSON: atlasJSON
35034
- }), React__default.createElement(ItemsContainer, {
35035
- className: "item-container-body"
35036
- }, onRenderSlots())), quantitySelect.isOpen && React__default.createElement(QuantitySelectorContainer, null, React__default.createElement(ItemQuantitySelector, {
35037
- quantity: quantitySelect.maxQuantity,
35038
- onConfirm: function onConfirm(quantity) {
35039
- quantitySelect.callback(quantity);
35040
- setQuantitySelect({
35041
- isOpen: false,
35042
- maxQuantity: 1,
35043
- callback: function callback() {}
35044
- });
35045
- },
35046
- onClose: function onClose() {
35047
- quantitySelect.callback(-1);
35048
- setQuantitySelect({
35049
- isOpen: false,
35050
- maxQuantity: 1,
35051
- callback: function callback() {}
35095
+ var _useState3 = React.useState(onGetFirstAnswer()),
35096
+ currentAnswer = _useState3[0],
35097
+ setCurrentAnswer = _useState3[1];
35098
+ React.useEffect(function () {
35099
+ setCurrentAnswer(onGetFirstAnswer());
35100
+ }, [currentQuestion]);
35101
+ var onGetAnswers = function onGetAnswers(answerIds) {
35102
+ return answerIds.map(function (answerId) {
35103
+ return answers.find(function (answer) {
35104
+ return answer.id === answerId;
35052
35105
  });
35106
+ });
35107
+ };
35108
+ var onKeyPress = function onKeyPress(e) {
35109
+ switch (e.key) {
35110
+ case 'ArrowDown':
35111
+ // select next answer, if any.
35112
+ // if no next answer, select first answer
35113
+ // const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(
35114
+ // (answer) => answer?.id === currentAnswer!.id + 1
35115
+ // );
35116
+ var nextAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
35117
+ return (answer == null ? void 0 : answer.id) === currentAnswer.id + 1;
35118
+ });
35119
+ var nextAnswerID = currentQuestion.answerIds[nextAnswerIndex];
35120
+ var nextAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
35121
+ return (answer == null ? void 0 : answer.id) === nextAnswerID;
35122
+ });
35123
+ setCurrentAnswer(nextAnswer || onGetFirstAnswer());
35124
+ break;
35125
+ case 'ArrowUp':
35126
+ // select previous answer, if any.
35127
+ // if no previous answer, select last answer
35128
+ var previousAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
35129
+ return (answer == null ? void 0 : answer.id) === currentAnswer.id - 1;
35130
+ });
35131
+ var previousAnswerID = currentQuestion.answerIds && currentQuestion.answerIds[previousAnswerIndex];
35132
+ var previousAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
35133
+ return (answer == null ? void 0 : answer.id) === previousAnswerID;
35134
+ });
35135
+ if (previousAnswer) {
35136
+ setCurrentAnswer(previousAnswer);
35137
+ } else {
35138
+ setCurrentAnswer(onGetAnswers(currentQuestion.answerIds).pop());
35139
+ }
35140
+ break;
35141
+ case 'Enter':
35142
+ setCanShowAnswers(false);
35143
+ if (!(currentAnswer != null && currentAnswer.nextQuestionId)) {
35144
+ onClose();
35145
+ return;
35146
+ } else {
35147
+ setCurrentQuestion(questions.find(function (question) {
35148
+ return question.id === currentAnswer.nextQuestionId;
35149
+ }));
35150
+ }
35151
+ break;
35053
35152
  }
35054
- })));
35055
- };
35056
- var ItemsContainer = /*#__PURE__*/styled.div.withConfig({
35057
- displayName: "ItemContainer__ItemsContainer",
35058
- componentId: "sc-15y5p9l-0"
35059
- })(["display:flex;justify-content:center;flex-wrap:wrap;"]);
35060
- var QuantitySelectorContainer = /*#__PURE__*/styled.div.withConfig({
35061
- displayName: "ItemContainer__QuantitySelectorContainer",
35062
- componentId: "sc-15y5p9l-1"
35063
- })(["position:absolute;top:0;left:0;width:100vw;height:100vh;z-index:100;display:flex;justify-content:center;align-items:center;background-color:rgba(0,0,0,0.5);"]);
35064
-
35065
- var ItemSelector = function ItemSelector(_ref) {
35066
- var atlasIMG = _ref.atlasIMG,
35067
- atlasJSON = _ref.atlasJSON,
35068
- options = _ref.options,
35069
- onClose = _ref.onClose,
35070
- onSelect = _ref.onSelect;
35071
- var _useState = React.useState(),
35072
- selectedValue = _useState[0],
35073
- setSelectedValue = _useState[1];
35074
- var handleClick = function handleClick() {
35075
- var element = document.querySelector("input[name='test']:checked");
35076
- var elementValue = element.value;
35077
- setSelectedValue(elementValue);
35078
35153
  };
35079
- React.useEffect(function () {
35080
- if (selectedValue) {
35081
- onSelect(selectedValue);
35154
+ useEventListener('keydown', onKeyPress);
35155
+ var onAnswerClick = function onAnswerClick(answer) {
35156
+ setCanShowAnswers(false);
35157
+ if (answer.nextQuestionId) {
35158
+ // if there is a next question, go to it
35159
+ setCurrentQuestion(questions.find(function (question) {
35160
+ return question.id === answer.nextQuestionId;
35161
+ }));
35162
+ } else {
35163
+ // else, finish dialog!
35164
+ onClose();
35082
35165
  }
35083
- }, [selectedValue]);
35084
- return React__default.createElement(DraggableContainer, {
35085
- type: exports.RPGUIContainerTypes.Framed,
35086
- width: "500px",
35087
- cancelDrag: ".equipment-container-body .arrow-selector",
35088
- onCloseButton: function onCloseButton() {
35089
- if (onClose) {
35090
- onClose();
35091
- }
35166
+ };
35167
+ var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
35168
+ var answerIds = currentQuestion.answerIds;
35169
+ if (!answerIds) {
35170
+ return null;
35092
35171
  }
35093
- }, React__default.createElement("div", {
35094
- style: {
35095
- width: '100%'
35172
+ var answers = onGetAnswers(answerIds);
35173
+ if (!answers) {
35174
+ return null;
35096
35175
  }
35097
- }, React__default.createElement(Title$2, null, 'Harvesting instruments'), React__default.createElement(Subtitle$1, null, 'Use the tool, you need it'), React__default.createElement("hr", {
35098
- className: "golden"
35099
- })), React__default.createElement(RadioInputScroller$1, null, options == null ? void 0 : options.map(function (option, index) {
35100
- return React__default.createElement(RadioOptionsWrapper$1, {
35101
- key: index
35102
- }, React__default.createElement(SpriteAtlasWrapper$1, null, React__default.createElement(SpriteFromAtlas, {
35103
- atlasIMG: atlasIMG,
35104
- atlasJSON: atlasJSON,
35105
- spriteKey: option.imageKey,
35106
- imgScale: 3
35107
- })), React__default.createElement("div", null, React__default.createElement("input", {
35108
- className: "rpgui-radio",
35109
- type: "radio",
35110
- value: option.name,
35111
- name: "test"
35112
- }), React__default.createElement("label", {
35113
- onPointerDown: handleClick,
35114
- style: {
35115
- display: 'flex',
35116
- alignItems: 'center'
35176
+ return answers.map(function (answer) {
35177
+ var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
35178
+ var selectedColor = isSelected ? 'yellow' : 'white';
35179
+ if (answer) {
35180
+ return React__default.createElement(AnswerRow, {
35181
+ key: "answer_" + answer.id
35182
+ }, React__default.createElement(AnswerSelectedIcon, {
35183
+ color: selectedColor
35184
+ }, isSelected ? 'X' : null), React__default.createElement(Answer, {
35185
+ key: answer.id,
35186
+ onPointerDown: function onPointerDown() {
35187
+ return onAnswerClick(answer);
35188
+ },
35189
+ color: selectedColor
35190
+ }, answer.text));
35117
35191
  }
35118
- }, option.name, " ", React__default.createElement("br", null), option.description)));
35119
- })), React__default.createElement(ButtonWrapper$1, null, React__default.createElement(Button, {
35120
- buttonType: exports.ButtonTypes.RPGUIButton,
35121
- onPointerDown: onClose
35122
- }, "Cancel"), React__default.createElement(Button, {
35123
- buttonType: exports.ButtonTypes.RPGUIButton
35124
- }, "Select")));
35125
- };
35126
- var Title$2 = /*#__PURE__*/styled.h1.withConfig({
35127
- displayName: "ItemSelector__Title",
35128
- componentId: "sc-gptoxp-0"
35129
- })(["font-size:0.6rem;color:yellow !important;"]);
35130
- var Subtitle$1 = /*#__PURE__*/styled.h1.withConfig({
35131
- displayName: "ItemSelector__Subtitle",
35132
- componentId: "sc-gptoxp-1"
35133
- })(["font-size:0.4rem;color:yellow !important;"]);
35134
- var RadioInputScroller$1 = /*#__PURE__*/styled.div.withConfig({
35135
- displayName: "ItemSelector__RadioInputScroller",
35136
- componentId: "sc-gptoxp-2"
35137
- })(["padding-left:15px;padding-top:10px;width:100%;margin-top:1rem;align-items:center;margin-left:20px;align-items:flex-start;overflow-y:scroll;height:360px;"]);
35138
- var SpriteAtlasWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35139
- displayName: "ItemSelector__SpriteAtlasWrapper",
35140
- componentId: "sc-gptoxp-3"
35141
- })(["margin-right:40px;"]);
35142
- var RadioOptionsWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35143
- displayName: "ItemSelector__RadioOptionsWrapper",
35144
- componentId: "sc-gptoxp-4"
35145
- })(["display:flex;align-items:stretch;margin-bottom:40px;"]);
35146
- var ButtonWrapper$1 = /*#__PURE__*/styled.div.withConfig({
35147
- displayName: "ItemSelector__ButtonWrapper",
35148
- componentId: "sc-gptoxp-5"
35149
- })(["display:flex;justify-content:space-around;padding-top:20px;width:100%;"]);
35150
-
35151
- var ListMenu = function ListMenu(_ref) {
35152
- var options = _ref.options,
35153
- onSelected = _ref.onSelected,
35154
- x = _ref.x,
35155
- y = _ref.y;
35156
- return React__default.createElement(Container$g, {
35157
- x: x,
35158
- y: y
35159
- }, React__default.createElement("ul", {
35160
- className: "rpgui-list-imp",
35161
- style: {
35162
- overflow: 'hidden'
35192
+ return null;
35193
+ });
35194
+ };
35195
+ return React__default.createElement(Container$f, null, React__default.createElement(QuestionContainer, null, React__default.createElement(DynamicText, {
35196
+ text: currentQuestion.text,
35197
+ onStart: function onStart() {
35198
+ return setCanShowAnswers(false);
35199
+ },
35200
+ onFinish: function onFinish() {
35201
+ return setCanShowAnswers(true);
35163
35202
  }
35164
- }, options.map(function (params, index) {
35165
- return React__default.createElement(ListElement$1, {
35166
- key: (params == null ? void 0 : params.id) || index,
35167
- onPointerDown: function onPointerDown() {
35168
- onSelected(params == null ? void 0 : params.id);
35169
- }
35170
- }, (params == null ? void 0 : params.text) || 'No text');
35171
- })));
35203
+ })), canShowAnswers && React__default.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
35172
35204
  };
35173
- var Container$g = /*#__PURE__*/styled.div.withConfig({
35174
- displayName: "ListMenu__Container",
35175
- componentId: "sc-i9097t-0"
35176
- })(["display:flex;flex-direction:column;width:100%;justify-content:start;align-items:flex-start;position:absolute;top:", "px;left:", "px;li{font-size:", ";}"], function (props) {
35177
- return props.y || 0;
35178
- }, function (props) {
35179
- return props.x || 0;
35180
- }, uiFonts.size.xsmall);
35181
- var ListElement$1 = /*#__PURE__*/styled.li.withConfig({
35182
- displayName: "ListMenu__ListElement",
35183
- componentId: "sc-i9097t-1"
35184
- })(["margin-right:0.5rem;"]);
35205
+ var Container$f = /*#__PURE__*/styled.div.withConfig({
35206
+ displayName: "QuestionDialog__Container",
35207
+ componentId: "sc-bxc5u0-0"
35208
+ })(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
35209
+ var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
35210
+ displayName: "QuestionDialog__QuestionContainer",
35211
+ componentId: "sc-bxc5u0-1"
35212
+ })(["flex:100%;width:100%;"]);
35213
+ var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
35214
+ displayName: "QuestionDialog__AnswersContainer",
35215
+ componentId: "sc-bxc5u0-2"
35216
+ })(["flex:100%;"]);
35217
+ var Answer = /*#__PURE__*/styled.p.withConfig({
35218
+ displayName: "QuestionDialog__Answer",
35219
+ componentId: "sc-bxc5u0-3"
35220
+ })(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
35221
+ return props.color;
35222
+ });
35223
+ var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
35224
+ displayName: "QuestionDialog__AnswerSelectedIcon",
35225
+ componentId: "sc-bxc5u0-4"
35226
+ })(["flex:5% 0 0;color:", " !important;"], function (props) {
35227
+ return props.color;
35228
+ });
35229
+ var AnswerRow = /*#__PURE__*/styled.div.withConfig({
35230
+ displayName: "QuestionDialog__AnswerRow",
35231
+ componentId: "sc-bxc5u0-5"
35232
+ })(["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;}"]);
35185
35233
 
35186
35234
  var ProgressBar = function ProgressBar(_ref) {
35187
35235
  var max = _ref.max,
@@ -35200,7 +35248,7 @@ var ProgressBar = function ProgressBar(_ref) {
35200
35248
  }
35201
35249
  return value * 100 / max;
35202
35250
  };
35203
- return React__default.createElement(Container$h, {
35251
+ return React__default.createElement(Container$g, {
35204
35252
  className: "rpgui-progress",
35205
35253
  "data-value": calculatePercentageValue(max, value) / 100,
35206
35254
  "data-rpguitype": "progress",
@@ -35229,7 +35277,7 @@ var TextOverlay$1 = /*#__PURE__*/styled.div.withConfig({
35229
35277
  displayName: "ProgressBar__TextOverlay",
35230
35278
  componentId: "sc-qa6fzh-1"
35231
35279
  })(["width:100%;position:relative;"]);
35232
- var Container$h = /*#__PURE__*/styled.div.withConfig({
35280
+ var Container$g = /*#__PURE__*/styled.div.withConfig({
35233
35281
  displayName: "ProgressBar__Container",
35234
35282
  componentId: "sc-qa6fzh-2"
35235
35283
  })(["display:flex;flex-direction:column;min-width:", "px;width:", "%;justify-content:start;align-items:flex-start;", ""], function (props) {
@@ -35240,7 +35288,7 @@ var Container$h = /*#__PURE__*/styled.div.withConfig({
35240
35288
  return props.style;
35241
35289
  });
35242
35290
 
35243
- var img$9 = '';
35291
+ var img$8 = '';
35244
35292
 
35245
35293
  var QuestInfo = function QuestInfo(_ref) {
35246
35294
  var quests = _ref.quests,
@@ -35281,8 +35329,8 @@ var QuestInfo = function QuestInfo(_ref) {
35281
35329
  onPointerDown: onRightClick
35282
35330
  }), React__default.createElement(QuestContainer, null, React__default.createElement(TitleContainer$1, {
35283
35331
  className: "drag-handler"
35284
- }, React__default.createElement(Title$3, null, React__default.createElement(Thumbnail, {
35285
- src: quests[currentIndex].thumbnail || img$9
35332
+ }, React__default.createElement(Title$4, null, React__default.createElement(Thumbnail, {
35333
+ src: quests[currentIndex].thumbnail || img$8
35286
35334
  }), quests[currentIndex].title), React__default.createElement(QuestSplitDiv, null, React__default.createElement("hr", {
35287
35335
  className: "golden"
35288
35336
  }))), React__default.createElement(Content, null, React__default.createElement("p", null, quests[currentIndex].description)), React__default.createElement(QuestColumn, {
@@ -35300,8 +35348,8 @@ var QuestInfo = function QuestInfo(_ref) {
35300
35348
  }, button.title);
35301
35349
  })))) : React__default.createElement(QuestsContainer, null, React__default.createElement(QuestContainer, null, React__default.createElement(TitleContainer$1, {
35302
35350
  className: "drag-handler"
35303
- }, React__default.createElement(Title$3, null, React__default.createElement(Thumbnail, {
35304
- src: quests[0].thumbnail || img$9
35351
+ }, React__default.createElement(Title$4, null, React__default.createElement(Thumbnail, {
35352
+ src: quests[0].thumbnail || img$8
35305
35353
  }), quests[0].title), React__default.createElement(QuestSplitDiv, null, React__default.createElement("hr", {
35306
35354
  className: "golden"
35307
35355
  }))), React__default.createElement(Content, null, React__default.createElement("p", null, quests[0].description)), React__default.createElement(QuestColumn, {
@@ -35347,7 +35395,7 @@ var TitleContainer$1 = /*#__PURE__*/styled.div.withConfig({
35347
35395
  displayName: "QuestInfo__TitleContainer",
35348
35396
  componentId: "sc-15s2boc-6"
35349
35397
  })(["width:100%;display:flex;flex-wrap:wrap;justify-content:flex-start;align-items:center;margin-top:1rem;"]);
35350
- var Title$3 = /*#__PURE__*/styled.h1.withConfig({
35398
+ var Title$4 = /*#__PURE__*/styled.h1.withConfig({
35351
35399
  displayName: "QuestInfo__Title",
35352
35400
  componentId: "sc-15s2boc-7"
35353
35401
  })(["color:white;z-index:22;font-size:", " !important;color:", " !important;"], uiFonts.size.medium, uiColors.yellow);
@@ -35369,7 +35417,7 @@ var QuestList = function QuestList(_ref) {
35369
35417
  style: {
35370
35418
  width: '100%'
35371
35419
  }
35372
- }, React__default.createElement(Title$4, null, "Quests"), React__default.createElement("hr", {
35420
+ }, React__default.createElement(Title$5, null, "Quests"), React__default.createElement("hr", {
35373
35421
  className: "golden"
35374
35422
  }), React__default.createElement(QuestListContainer, null, quests ? quests.map(function (quest, i) {
35375
35423
  return React__default.createElement("div", {
@@ -35390,7 +35438,7 @@ var QuestDraggableContainer$1 = /*#__PURE__*/styled(DraggableContainer).withConf
35390
35438
  displayName: "QuestList__QuestDraggableContainer",
35391
35439
  componentId: "sc-1a2vx6q-0"
35392
35440
  })([".container-close{top:10px;right:10px;}.quest-title{text-align:left;margin-left:44px;margin-top:20px;color:yellow;}.quest-desc{margin-top:12px;margin-left:44px;}.rpgui-progress{min-width:80%;margin:0 auto;}"]);
35393
- var Title$4 = /*#__PURE__*/styled.h1.withConfig({
35441
+ var Title$5 = /*#__PURE__*/styled.h1.withConfig({
35394
35442
  displayName: "QuestList__Title",
35395
35443
  componentId: "sc-1a2vx6q-1"
35396
35444
  })(["z-index:22;font-size:", " !important;color:yellow !important;"], uiFonts.size.medium);
@@ -35550,7 +35598,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
35550
35598
  bgColor = _ref$bgColor === void 0 ? 'red' : _ref$bgColor,
35551
35599
  _ref$margin = _ref.margin,
35552
35600
  margin = _ref$margin === void 0 ? 20 : _ref$margin;
35553
- return React__default.createElement(Container$i, {
35601
+ return React__default.createElement(Container$h, {
35554
35602
  className: "simple-progress-bar"
35555
35603
  }, React__default.createElement(ProgressBarContainer, {
35556
35604
  margin: margin
@@ -35559,7 +35607,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
35559
35607
  bgColor: bgColor
35560
35608
  }))));
35561
35609
  };
35562
- var Container$i = /*#__PURE__*/styled.div.withConfig({
35610
+ var Container$h = /*#__PURE__*/styled.div.withConfig({
35563
35611
  displayName: "SimpleProgressBar__Container",
35564
35612
  componentId: "sc-mbeil3-0"
35565
35613
  })(["display:flex;justify-content:center;align-items:center;width:100%;"]);
@@ -35786,20 +35834,20 @@ var Spell = function Spell(_ref) {
35786
35834
  isSettingShortcut = _ref.isSettingShortcut,
35787
35835
  minMagicLevelRequired = _ref.minMagicLevelRequired;
35788
35836
  var disabled = isSettingShortcut ? charMagicLevel < minMagicLevelRequired : manaCost > charMana || charMagicLevel < minMagicLevelRequired;
35789
- return React__default.createElement(Container$j, {
35837
+ return React__default.createElement(Container$i, {
35790
35838
  disabled: disabled,
35791
35839
  onPointerDown: onPointerDown == null ? void 0 : onPointerDown.bind(null, spellKey),
35792
35840
  isSettingShortcut: isSettingShortcut && !disabled,
35793
35841
  className: "spell"
35794
35842
  }, disabled && React__default.createElement(Overlay, null, charMagicLevel < minMagicLevelRequired ? 'Low magic level' : manaCost > charMana && 'No mana'), React__default.createElement(SpellImage, null, magicWords.split(' ').map(function (word) {
35795
35843
  return word[0];
35796
- })), React__default.createElement(Info, null, React__default.createElement(Title$5, null, React__default.createElement("span", null, name), React__default.createElement("span", {
35844
+ })), React__default.createElement(Info, null, React__default.createElement(Title$6, null, React__default.createElement("span", null, name), React__default.createElement("span", {
35797
35845
  className: "spell"
35798
- }, "(", magicWords, ")")), React__default.createElement(Description, null, description)), React__default.createElement(Divider, null), React__default.createElement(Cost, null, React__default.createElement("span", null, "Mana cost:"), React__default.createElement("span", {
35846
+ }, "(", magicWords, ")")), React__default.createElement(Description$1, null, description)), React__default.createElement(Divider, null), React__default.createElement(Cost, null, React__default.createElement("span", null, "Mana cost:"), React__default.createElement("span", {
35799
35847
  className: "mana"
35800
35848
  }, manaCost)));
35801
35849
  };
35802
- var Container$j = /*#__PURE__*/styled.button.withConfig({
35850
+ var Container$i = /*#__PURE__*/styled.button.withConfig({
35803
35851
  displayName: "Spell__Container",
35804
35852
  componentId: "sc-j96fa2-0"
35805
35853
  })(["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) {
@@ -35814,11 +35862,11 @@ var Info = /*#__PURE__*/styled.span.withConfig({
35814
35862
  displayName: "Spell__Info",
35815
35863
  componentId: "sc-j96fa2-2"
35816
35864
  })(["width:0;flex:1;"]);
35817
- var Title$5 = /*#__PURE__*/styled.p.withConfig({
35865
+ var Title$6 = /*#__PURE__*/styled.p.withConfig({
35818
35866
  displayName: "Spell__Title",
35819
35867
  componentId: "sc-j96fa2-3"
35820
35868
  })(["display:flex;flex-wrap:wrap;align-items:center;margin-bottom:5px;margin:0;span{font-size:", " !important;font-weight:bold !important;color:", " !important;margin-right:0.5rem;}.spell{font-size:", " !important;font-weight:normal !important;color:", " !important;}"], uiFonts.size.medium, uiColors.yellow, uiFonts.size.small, uiColors.lightGray);
35821
- var Description = /*#__PURE__*/styled.div.withConfig({
35869
+ var Description$1 = /*#__PURE__*/styled.div.withConfig({
35822
35870
  displayName: "Spell__Description",
35823
35871
  componentId: "sc-j96fa2-4"
35824
35872
  })(["font-size:", " !important;line-height:1.1 !important;"], uiFonts.size.small);
@@ -35884,7 +35932,7 @@ var Spellbook = function Spellbook(_ref) {
35884
35932
  width: "inherit",
35885
35933
  height: "inherit",
35886
35934
  cancelDrag: "#spellbook-search, #shortcuts_list, .spell"
35887
- }, React__default.createElement(Container$k, null, React__default.createElement(Title$6, null, "Learned Spells"), React__default.createElement(ShortcutsSetter, {
35935
+ }, React__default.createElement(Container$j, null, React__default.createElement(Title$7, null, "Learned Spells"), React__default.createElement(ShortcutsSetter, {
35888
35936
  setSettingShortcutIndex: setSettingShortcutIndex,
35889
35937
  settingShortcutIndex: settingShortcutIndex,
35890
35938
  shortcuts: shortcuts,
@@ -35912,11 +35960,11 @@ var Spellbook = function Spellbook(_ref) {
35912
35960
  }, spell)));
35913
35961
  }))));
35914
35962
  };
35915
- var Title$6 = /*#__PURE__*/styled.h1.withConfig({
35963
+ var Title$7 = /*#__PURE__*/styled.h1.withConfig({
35916
35964
  displayName: "Spellbook__Title",
35917
35965
  componentId: "sc-r02nfq-0"
35918
35966
  })(["font-size:", " !important;margin-bottom:0 !important;"], uiFonts.size.large);
35919
- var Container$k = /*#__PURE__*/styled.div.withConfig({
35967
+ var Container$j = /*#__PURE__*/styled.div.withConfig({
35920
35968
  displayName: "Spellbook__Container",
35921
35969
  componentId: "sc-r02nfq-1"
35922
35970
  })(["width:100%;height:100%;color:white;display:flex;flex-direction:column;"]);
@@ -35930,16 +35978,16 @@ var TextArea = function TextArea(_ref) {
35930
35978
  return React__default.createElement("textarea", Object.assign({}, props));
35931
35979
  };
35932
35980
 
35933
- var img$a = '';
35981
+ var img$9 = '';
35934
35982
 
35935
- var img$b = '';
35983
+ var img$a = '';
35936
35984
 
35937
- var img$c = '';
35985
+ var img$b = '';
35938
35986
 
35939
35987
  var DayNightPeriod = function DayNightPeriod(_ref) {
35940
35988
  var _periodOfDaySrcFiles;
35941
35989
  var periodOfDay = _ref.periodOfDay;
35942
- var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[shared.PeriodOfDay.Morning] = img$b, _periodOfDaySrcFiles[shared.PeriodOfDay.Afternoon] = img$a, _periodOfDaySrcFiles[shared.PeriodOfDay.Night] = img$c, _periodOfDaySrcFiles);
35990
+ var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[shared.PeriodOfDay.Morning] = img$a, _periodOfDaySrcFiles[shared.PeriodOfDay.Afternoon] = img$9, _periodOfDaySrcFiles[shared.PeriodOfDay.Night] = img$b, _periodOfDaySrcFiles);
35943
35991
  return React__default.createElement(GifContainer, null, React__default.createElement("img", {
35944
35992
  src: periodOfDaySrcFiles[periodOfDay]
35945
35993
  }));
@@ -35949,7 +35997,7 @@ var GifContainer = /*#__PURE__*/styled.div.withConfig({
35949
35997
  componentId: "sc-10t97fw-0"
35950
35998
  })(["width:100%;img{width:67%;}"]);
35951
35999
 
35952
- var img$d = '';
36000
+ var img$c = '';
35953
36001
 
35954
36002
  var TimeWidget = function TimeWidget(_ref) {
35955
36003
  var onClose = _ref.onClose,
@@ -35964,7 +36012,7 @@ var TimeWidget = function TimeWidget(_ref) {
35964
36012
  var WidgetContainer = /*#__PURE__*/styled.div.withConfig({
35965
36013
  displayName: "TimeWidget__WidgetContainer",
35966
36014
  componentId: "sc-1ja236h-0"
35967
- })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$d);
36015
+ })(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$c);
35968
36016
  var Time = /*#__PURE__*/styled.div.withConfig({
35969
36017
  displayName: "TimeWidget__Time",
35970
36018
  componentId: "sc-1ja236h-1"
@@ -35984,7 +36032,8 @@ var TradingItemRow = function TradingItemRow(_ref) {
35984
36032
  atlasJSON = _ref.atlasJSON,
35985
36033
  onQuantityChange = _ref.onQuantityChange,
35986
36034
  traderItem = _ref.traderItem,
35987
- selectedQty = _ref.selectedQty;
36035
+ selectedQty = _ref.selectedQty,
36036
+ equipmentSet = _ref.equipmentSet;
35988
36037
  var onLeftClick = function onLeftClick(qty) {
35989
36038
  if (qty === void 0) {
35990
36039
  qty = 1;
@@ -35992,22 +36041,27 @@ var TradingItemRow = function TradingItemRow(_ref) {
35992
36041
  onQuantityChange(traderItem, Math.max(0, selectedQty - qty));
35993
36042
  };
35994
36043
  var onRightClick = function onRightClick(qty) {
35995
- var _traderItem$qty;
36044
+ var _traderItem$stackQty;
35996
36045
  if (qty === void 0) {
35997
36046
  qty = 1;
35998
36047
  }
35999
- onQuantityChange(traderItem, Math.min((_traderItem$qty = traderItem.qty) != null ? _traderItem$qty : 999, selectedQty + qty));
36048
+ onQuantityChange(traderItem, Math.min((_traderItem$stackQty = traderItem.stackQty) != null ? _traderItem$stackQty : 999, selectedQty + qty));
36000
36049
  };
36001
- return React__default.createElement(ItemWrapper, null, React__default.createElement(ItemIconContainer, null, React__default.createElement(SpriteContainer$1, null, React__default.createElement(SpriteFromAtlas, {
36050
+ return React__default.createElement(ItemWrapper, null, React__default.createElement(ItemIconContainer, null, React__default.createElement(SpriteContainer$1, null, React__default.createElement(ItemInfoWrapper, {
36051
+ atlasIMG: atlasIMG,
36052
+ atlasJSON: atlasJSON,
36053
+ equipmentSet: equipmentSet,
36054
+ item: traderItem
36055
+ }, React__default.createElement(SpriteFromAtlas, {
36002
36056
  atlasIMG: atlasIMG,
36003
36057
  atlasJSON: atlasJSON,
36004
36058
  spriteKey: shared.getItemTextureKeyPath({
36005
36059
  key: traderItem.key,
36006
- stackQty: traderItem.qty || 1,
36060
+ stackQty: traderItem.stackQty || 1,
36007
36061
  texturePath: traderItem.texturePath
36008
36062
  }, atlasJSON),
36009
36063
  imgScale: 2.5
36010
- }))), React__default.createElement(ItemNameContainer, null, React__default.createElement(NameValue, null, React__default.createElement("p", null, React__default.createElement(Ellipsis, {
36064
+ })))), React__default.createElement(ItemNameContainer, null, React__default.createElement(NameValue, null, React__default.createElement("p", null, React__default.createElement(Ellipsis, {
36011
36065
  maxLines: 1,
36012
36066
  maxWidth: "250px"
36013
36067
  }, capitalize(traderItem.name))), React__default.createElement("p", null, "$", traderItem.price))), React__default.createElement(QuantityContainer, null, React__default.createElement(SelectArrow, {
@@ -36080,7 +36134,8 @@ var TradingMenu = function TradingMenu(_ref) {
36080
36134
  atlasJSON = _ref.atlasJSON,
36081
36135
  atlasIMG = _ref.atlasIMG,
36082
36136
  characterAvailableGold = _ref.characterAvailableGold,
36083
- onConfirm = _ref.onConfirm;
36137
+ onConfirm = _ref.onConfirm,
36138
+ equipmentSet = _ref.equipmentSet;
36084
36139
  var _useState = React.useState(0),
36085
36140
  sum = _useState[0],
36086
36141
  setSum = _useState[1];
@@ -36138,7 +36193,7 @@ var TradingMenu = function TradingMenu(_ref) {
36138
36193
  style: {
36139
36194
  width: '100%'
36140
36195
  }
36141
- }, React__default.createElement(Title$7, null, Capitalize(type), " Menu"), React__default.createElement("hr", {
36196
+ }, React__default.createElement(Title$8, null, Capitalize(type), " Menu"), React__default.createElement("hr", {
36142
36197
  className: "golden"
36143
36198
  })), React__default.createElement(TradingComponentScrollWrapper, {
36144
36199
  id: "TraderContainer"
@@ -36151,7 +36206,8 @@ var TradingMenu = function TradingMenu(_ref) {
36151
36206
  atlasJSON: atlasJSON,
36152
36207
  onQuantityChange: onQuantityChange,
36153
36208
  traderItem: tradeItem,
36154
- selectedQty: (_qtyMap$get = qtyMap.get(tradeItem.key)) != null ? _qtyMap$get : 0
36209
+ selectedQty: (_qtyMap$get = qtyMap.get(tradeItem.key)) != null ? _qtyMap$get : 0,
36210
+ equipmentSet: equipmentSet
36155
36211
  }));
36156
36212
  })), React__default.createElement(GoldWrapper, null, React__default.createElement("p", null, "Available Gold:"), React__default.createElement("p", null, "$", characterAvailableGold)), React__default.createElement(TotalWrapper, null, React__default.createElement("p", null, "Total:"), React__default.createElement("p", null, "$", sum)), !hasGoldForSale() ? React__default.createElement(AlertWrapper, null, React__default.createElement("p", null, " Sorry, not enough money.")) : React__default.createElement(GoldWrapper, null, React__default.createElement("p", null, "Final Gold:"), React__default.createElement("p", null, "$", getFinalGold())), React__default.createElement(ButtonWrapper$2, null, React__default.createElement(Button, {
36157
36213
  buttonType: exports.ButtonTypes.RPGUIButton,
@@ -36166,7 +36222,7 @@ var TradingMenu = function TradingMenu(_ref) {
36166
36222
  }
36167
36223
  }, "Cancel"))));
36168
36224
  };
36169
- var Title$7 = /*#__PURE__*/styled.h1.withConfig({
36225
+ var Title$8 = /*#__PURE__*/styled.h1.withConfig({
36170
36226
  displayName: "TradingMenu__Title",
36171
36227
  componentId: "sc-1wjsz1l-0"
36172
36228
  })(["z-index:22;font-size:0.6rem;color:yellow !important;"]);
@@ -36200,17 +36256,230 @@ var Truncate = function Truncate(_ref) {
36200
36256
  var _ref$maxLines = _ref.maxLines,
36201
36257
  maxLines = _ref$maxLines === void 0 ? 1 : _ref$maxLines,
36202
36258
  children = _ref.children;
36203
- return React__default.createElement(Container$l, {
36259
+ return React__default.createElement(Container$k, {
36204
36260
  maxLines: maxLines
36205
36261
  }, children);
36206
36262
  };
36207
- var Container$l = /*#__PURE__*/styled.div.withConfig({
36263
+ var Container$k = /*#__PURE__*/styled.div.withConfig({
36208
36264
  displayName: "Truncate__Container",
36209
36265
  componentId: "sc-6x00qb-0"
36210
36266
  })(["display:-webkit-box;max-width:100%;max-height:100%;-webkit-line-clamp:", ";-webkit-box-orient:vertical;overflow:hidden;"], function (props) {
36211
36267
  return props.maxLines;
36212
36268
  });
36213
36269
 
36270
+ var IS_MOBILE_OR_TABLET = /*#__PURE__*/shared.isMobileOrTablet();
36271
+
36272
+ var chunkString = function chunkString(str, length) {
36273
+ return str.match(new RegExp('.{1,' + length + '}', 'g'));
36274
+ };
36275
+
36276
+ var img$d = '';
36277
+
36278
+ var NPCDialogText = function NPCDialogText(_ref) {
36279
+ var text = _ref.text,
36280
+ onClose = _ref.onClose,
36281
+ onEndStep = _ref.onEndStep,
36282
+ onStartStep = _ref.onStartStep,
36283
+ type = _ref.type;
36284
+ var windowSize = React.useRef([window.innerWidth, window.innerHeight]);
36285
+ function maxCharacters(width) {
36286
+ // Set the font size to 16 pixels
36287
+ var fontSize = 11.2;
36288
+ // Calculate the number of characters that can fit in one line
36289
+ var charactersPerLine = Math.floor(width / 2 / fontSize);
36290
+ // Calculate the number of lines that can fit in the div
36291
+ var linesPerDiv = Math.floor(180 / fontSize);
36292
+ // Calculate the maximum number of characters that can fit in the div
36293
+ var maxCharacters = charactersPerLine * linesPerDiv;
36294
+ // Return the maximum number of characters
36295
+ return Math.round(maxCharacters / 5);
36296
+ }
36297
+ var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
36298
+ var _useState = React.useState(0),
36299
+ chunkIndex = _useState[0],
36300
+ setChunkIndex = _useState[1];
36301
+ var onHandleSpacePress = function onHandleSpacePress(event) {
36302
+ if (event.code === 'Space') {
36303
+ goToNextStep();
36304
+ }
36305
+ };
36306
+ var goToNextStep = function goToNextStep() {
36307
+ var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
36308
+ if (hasNextChunk) {
36309
+ setChunkIndex(function (prev) {
36310
+ return prev + 1;
36311
+ });
36312
+ } else {
36313
+ // if there's no more text chunks, close the dialog
36314
+ onClose();
36315
+ }
36316
+ };
36317
+ React.useEffect(function () {
36318
+ document.addEventListener('keydown', onHandleSpacePress);
36319
+ return function () {
36320
+ return document.removeEventListener('keydown', onHandleSpacePress);
36321
+ };
36322
+ }, [chunkIndex]);
36323
+ var _useState2 = React.useState(false),
36324
+ showGoNextIndicator = _useState2[0],
36325
+ setShowGoNextIndicator = _useState2[1];
36326
+ return React__default.createElement(Container$l, null, React__default.createElement(DynamicText, {
36327
+ text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
36328
+ onFinish: function onFinish() {
36329
+ setShowGoNextIndicator(true);
36330
+ onEndStep && onEndStep();
36331
+ },
36332
+ onStart: function onStart() {
36333
+ setShowGoNextIndicator(false);
36334
+ onStartStep && onStartStep();
36335
+ }
36336
+ }), showGoNextIndicator && React__default.createElement(PressSpaceIndicator$1, {
36337
+ right: type === exports.NPCDialogType.TextOnly ? '1rem' : '10.5rem',
36338
+ src: IS_MOBILE_OR_TABLET ? img$d : img$7,
36339
+ onPointerDown: function onPointerDown() {
36340
+ goToNextStep();
36341
+ }
36342
+ }));
36343
+ };
36344
+ var Container$l = /*#__PURE__*/styled.div.withConfig({
36345
+ displayName: "NPCDialogText__Container",
36346
+ componentId: "sc-1cxkdh9-0"
36347
+ })([""]);
36348
+ var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
36349
+ displayName: "NPCDialogText__PressSpaceIndicator",
36350
+ componentId: "sc-1cxkdh9-1"
36351
+ })(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
36352
+ var right = _ref2.right;
36353
+ return right;
36354
+ });
36355
+
36356
+ (function (NPCDialogType) {
36357
+ NPCDialogType["TextOnly"] = "TextOnly";
36358
+ NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
36359
+ })(exports.NPCDialogType || (exports.NPCDialogType = {}));
36360
+ var NPCDialog = function NPCDialog(_ref) {
36361
+ var text = _ref.text,
36362
+ type = _ref.type,
36363
+ _onClose = _ref.onClose,
36364
+ imagePath = _ref.imagePath,
36365
+ _ref$isQuestionDialog = _ref.isQuestionDialog,
36366
+ isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
36367
+ questions = _ref.questions,
36368
+ answers = _ref.answers;
36369
+ return React__default.createElement(RPGUIContainer, {
36370
+ type: exports.RPGUIContainerTypes.FramedGold,
36371
+ width: isQuestionDialog ? '600px' : '80%',
36372
+ height: '180px'
36373
+ }, isQuestionDialog && questions && answers ? React__default.createElement(React__default.Fragment, null, React__default.createElement(TextContainer$2, {
36374
+ flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
36375
+ }, React__default.createElement(QuestionDialog, {
36376
+ questions: questions,
36377
+ answers: answers,
36378
+ onClose: function onClose() {
36379
+ if (_onClose) {
36380
+ _onClose();
36381
+ }
36382
+ }
36383
+ })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
36384
+ src: imagePath || img$6
36385
+ }))) : React__default.createElement(React__default.Fragment, null, React__default.createElement(Container$m, null, React__default.createElement(TextContainer$2, {
36386
+ flex: type === exports.NPCDialogType.TextAndThumbnail ? '70%' : '100%'
36387
+ }, React__default.createElement(NPCDialogText, {
36388
+ type: type,
36389
+ text: text || 'No text provided.',
36390
+ onClose: function onClose() {
36391
+ if (_onClose) {
36392
+ _onClose();
36393
+ }
36394
+ }
36395
+ })), type === exports.NPCDialogType.TextAndThumbnail && React__default.createElement(ThumbnailContainer$1, null, React__default.createElement(NPCThumbnail$1, {
36396
+ src: imagePath || img$6
36397
+ })))));
36398
+ };
36399
+ var Container$m = /*#__PURE__*/styled.div.withConfig({
36400
+ displayName: "NPCDialog__Container",
36401
+ componentId: "sc-1b4aw74-0"
36402
+ })(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
36403
+ var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
36404
+ displayName: "NPCDialog__TextContainer",
36405
+ componentId: "sc-1b4aw74-1"
36406
+ })(["flex:", " 0 0;width:355px;"], function (_ref2) {
36407
+ var flex = _ref2.flex;
36408
+ return flex;
36409
+ });
36410
+ var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
36411
+ displayName: "NPCDialog__ThumbnailContainer",
36412
+ componentId: "sc-1b4aw74-2"
36413
+ })(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
36414
+ var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
36415
+ displayName: "NPCDialog__NPCThumbnail",
36416
+ componentId: "sc-1b4aw74-3"
36417
+ })(["image-rendering:pixelated;height:128px;width:128px;"]);
36418
+
36419
+ var HistoryDialog = function HistoryDialog(_ref) {
36420
+ var backgroundImgPath = _ref.backgroundImgPath,
36421
+ fullCoverBackground = _ref.fullCoverBackground,
36422
+ questions = _ref.questions,
36423
+ answers = _ref.answers,
36424
+ text = _ref.text,
36425
+ imagePath = _ref.imagePath,
36426
+ textAndTypeArray = _ref.textAndTypeArray,
36427
+ onClose = _ref.onClose;
36428
+ var _useState = React.useState(0),
36429
+ img = _useState[0],
36430
+ setImage = _useState[1];
36431
+ var onHandleSpacePress = function onHandleSpacePress(event) {
36432
+ if (event.code === 'Space') {
36433
+ if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
36434
+ setImage(function (prev) {
36435
+ return prev + 1;
36436
+ });
36437
+ } else {
36438
+ // if there's no more text chunks, close the dialog
36439
+ onClose();
36440
+ }
36441
+ }
36442
+ };
36443
+ React.useEffect(function () {
36444
+ document.addEventListener('keydown', onHandleSpacePress);
36445
+ return function () {
36446
+ return document.removeEventListener('keydown', onHandleSpacePress);
36447
+ };
36448
+ }, [backgroundImgPath]);
36449
+ return React__default.createElement(BackgroundContainer, {
36450
+ imgPath: backgroundImgPath[img],
36451
+ fullImg: fullCoverBackground
36452
+ }, React__default.createElement(DialogContainer, null, textAndTypeArray ? React__default.createElement(NPCMultiDialog, {
36453
+ textAndTypeArray: textAndTypeArray,
36454
+ onClose: onClose
36455
+ }) : questions && answers ? React__default.createElement(QuestionDialog, {
36456
+ questions: questions,
36457
+ answers: answers,
36458
+ onClose: onClose
36459
+ }) : text && imagePath ? React__default.createElement(NPCDialog, {
36460
+ text: text,
36461
+ imagePath: imagePath,
36462
+ onClose: onClose,
36463
+ type: exports.NPCDialogType.TextAndThumbnail
36464
+ }) : React__default.createElement(NPCDialog, {
36465
+ text: text,
36466
+ onClose: onClose,
36467
+ type: exports.NPCDialogType.TextOnly
36468
+ })));
36469
+ };
36470
+ var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
36471
+ displayName: "HistoryDialog__BackgroundContainer",
36472
+ componentId: "sc-u6oe75-0"
36473
+ })(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
36474
+ return props.imgPath;
36475
+ }, function (props) {
36476
+ return props.imgPath ? 'cover' : 'auto';
36477
+ });
36478
+ var DialogContainer = /*#__PURE__*/styled.div.withConfig({
36479
+ displayName: "HistoryDialog__DialogContainer",
36480
+ componentId: "sc-u6oe75-1"
36481
+ })(["display:flex;justify-content:center;padding-top:200px;"]);
36482
+
36214
36483
  exports.Button = Button;
36215
36484
  exports.CharacterSelection = CharacterSelection;
36216
36485
  exports.Chat = Chat;
@@ -36223,6 +36492,7 @@ exports.Dropdown = Dropdown;
36223
36492
  exports.DropdownSelectorContainer = DropdownSelectorContainer;
36224
36493
  exports.DynamicText = DynamicText;
36225
36494
  exports.EquipmentSet = EquipmentSet;
36495
+ exports.EquipmentSlotSpriteByType = EquipmentSlotSpriteByType;
36226
36496
  exports.ErrorBoundary = ErrorBoundary;
36227
36497
  exports.HistoryDialog = HistoryDialog;
36228
36498
  exports.Input = Input;
@@ -36251,5 +36521,6 @@ exports.TimeWidget = TimeWidget;
36251
36521
  exports.TradingMenu = TradingMenu;
36252
36522
  exports.Truncate = Truncate;
36253
36523
  exports._RPGUI = _RPGUI;
36524
+ exports.rarityColor = rarityColor;
36254
36525
  exports.useEventListener = useEventListener;
36255
36526
  //# sourceMappingURL=long-bow.cjs.development.js.map