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