@rpg-engine/long-bow 0.3.69 → 0.3.71

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (158) hide show
  1. package/LICENSE +20 -20
  2. package/README.md +181 -181
  3. package/dist/components/CraftBook/CraftBook.d.ts +2 -1
  4. package/dist/components/Item/Cards/ItemInfo.d.ts +10 -0
  5. package/dist/components/Item/Cards/ItemInfoDisplay.d.ts +9 -0
  6. package/dist/components/Item/Cards/ItemInfoWrapper.d.ts +11 -0
  7. package/dist/components/Item/Cards/ItemTooltip.d.ts +7 -4
  8. package/dist/components/Item/Inventory/ItemContainer.d.ts +2 -1
  9. package/dist/components/Item/Inventory/ItemSlot.d.ts +4 -1
  10. package/dist/components/TradingMenu/TradingItemRow.d.ts +2 -1
  11. package/dist/components/TradingMenu/TradingMenu.d.ts +4 -3
  12. package/dist/components/shared/SpriteFromAtlas.d.ts +1 -0
  13. package/dist/long-bow.cjs.development.js +1220 -949
  14. package/dist/long-bow.cjs.development.js.map +1 -1
  15. package/dist/long-bow.cjs.production.min.js +1 -1
  16. package/dist/long-bow.cjs.production.min.js.map +1 -1
  17. package/dist/long-bow.esm.js +1222 -953
  18. package/dist/long-bow.esm.js.map +1 -1
  19. package/dist/stories/ItemInfoDisplay.stories.d.ts +8 -0
  20. package/dist/stories/TradingMenu.stories.d.ts +2 -2
  21. package/package.json +100 -100
  22. package/src/components/Abstractions/SlotsContainer.tsx +45 -45
  23. package/src/components/Arrow/SelectArrow.tsx +69 -69
  24. package/src/components/Arrow/img/arrow01-left-clicked.png +0 -0
  25. package/src/components/Arrow/img/arrow01-left.png +0 -0
  26. package/src/components/Arrow/img/arrow01-right-clicked.png +0 -0
  27. package/src/components/Arrow/img/arrow01-right.png +0 -0
  28. package/src/components/Arrow/img/arrow02-left-clicked.png +0 -0
  29. package/src/components/Arrow/img/arrow02-left.png +0 -0
  30. package/src/components/Arrow/img/arrow02-right-clicked.png +0 -0
  31. package/src/components/Arrow/img/arrow02-right.png +0 -0
  32. package/src/components/Button.tsx +40 -40
  33. package/src/components/Character/CharacterSelection.tsx +96 -96
  34. package/src/components/CharacterStatus/CharacterStatus.tsx +120 -120
  35. package/src/components/Chat/Chat.tsx +195 -195
  36. package/src/components/Chatdeprecated/ChatDeprecated.tsx +198 -198
  37. package/src/components/CheckButton.tsx +65 -65
  38. package/src/components/CircularController/CircularController.tsx +248 -248
  39. package/src/components/CraftBook/CraftBook.tsx +237 -227
  40. package/src/components/CraftBook/MockItems.ts +41 -46
  41. package/src/components/DraggableContainer.tsx +153 -153
  42. package/src/components/Dropdown.tsx +90 -90
  43. package/src/components/DropdownSelectorContainer.tsx +42 -42
  44. package/src/components/Equipment/EquipmentSet.tsx +190 -190
  45. package/src/components/HistoryDialog.tsx +104 -104
  46. package/src/components/Input.tsx +15 -15
  47. package/src/components/Item/Cards/ItemInfo.tsx +248 -0
  48. package/src/components/Item/Cards/ItemInfoDisplay.tsx +120 -0
  49. package/src/components/Item/Cards/ItemInfoWrapper.tsx +39 -0
  50. package/src/components/Item/Cards/ItemTooltip.tsx +85 -33
  51. package/src/components/Item/Inventory/ErrorBoundary.tsx +42 -42
  52. package/src/components/Item/Inventory/ItemContainer.tsx +214 -210
  53. package/src/components/Item/Inventory/ItemContainerTypes.ts +6 -6
  54. package/src/components/Item/Inventory/ItemQuantitySelector.tsx +138 -138
  55. package/src/components/Item/Inventory/ItemSlot.tsx +512 -501
  56. package/src/components/Item/Inventory/itemContainerHelper.ts +156 -156
  57. package/src/components/ListMenu.tsx +63 -63
  58. package/src/components/Multitab/Tab.tsx +66 -66
  59. package/src/components/Multitab/TabBody.tsx +13 -13
  60. package/src/components/Multitab/TabsContainer.tsx +97 -97
  61. package/src/components/NPCDialog/NPCDialog.tsx +121 -121
  62. package/src/components/NPCDialog/NPCDialogText.tsx +113 -113
  63. package/src/components/NPCDialog/NPCMultiDialog.tsx +159 -159
  64. package/src/components/NPCDialog/QuestionDialog/QuestionDialog.tsx +237 -237
  65. package/src/components/ProgressBar.tsx +92 -92
  66. package/src/components/PropertySelect/PropertySelect.tsx +106 -106
  67. package/src/components/QuestInfo/QuestInfo.tsx +230 -230
  68. package/src/components/QuestList.tsx +129 -129
  69. package/src/components/RPGUIContainer.tsx +47 -47
  70. package/src/components/RPGUIForceRenderStart.tsx +45 -45
  71. package/src/components/RPGUIRoot.tsx +14 -14
  72. package/src/components/RadioButton.tsx +53 -53
  73. package/src/components/RadioInput/RadioButton.tsx +96 -96
  74. package/src/components/RadioInput/RadioInput.tsx +102 -102
  75. package/src/components/RadioInput/instruments.ts +15 -15
  76. package/src/components/RangeSlider.tsx +78 -78
  77. package/src/components/RelativeListMenu.tsx +83 -83
  78. package/src/components/ScrollList.tsx +79 -79
  79. package/src/components/Shortcuts/Shortcuts.tsx +151 -151
  80. package/src/components/Shortcuts/ShortcutsSetter.tsx +132 -132
  81. package/src/components/Shortcuts/SingleShortcut.ts +62 -62
  82. package/src/components/SimpleProgressBar.tsx +62 -62
  83. package/src/components/SkillProgressBar.tsx +133 -133
  84. package/src/components/SkillsContainer.tsx +198 -198
  85. package/src/components/Spellbook/Spell.tsx +201 -201
  86. package/src/components/Spellbook/Spellbook.tsx +150 -150
  87. package/src/components/Spellbook/constants.ts +8 -8
  88. package/src/components/Spellbook/mockSpells.ts +60 -60
  89. package/src/components/StaticBook/StaticBook.tsx +103 -103
  90. package/src/components/TextArea.tsx +11 -11
  91. package/src/components/TimeWidget/DayNightPeriod/DayNightPeriod.tsx +35 -35
  92. package/src/components/TimeWidget/TimeWidget.tsx +63 -63
  93. package/src/components/TradingMenu/TradingItemRow.tsx +195 -181
  94. package/src/components/TradingMenu/TradingMenu.tsx +211 -203
  95. package/src/components/TradingMenu/items.mock.ts +48 -96
  96. package/src/components/Truncate.tsx +25 -25
  97. package/src/components/itemSelector/ItemSelector.tsx +136 -136
  98. package/src/components/shared/Column.tsx +16 -16
  99. package/src/components/shared/Ellipsis.tsx +65 -65
  100. package/src/components/shared/SpriteFromAtlas.tsx +104 -102
  101. package/src/components/typography/DynamicText.tsx +49 -49
  102. package/src/constants/uiColors.ts +20 -20
  103. package/src/constants/uiDevices.ts +3 -3
  104. package/src/constants/uiFonts.ts +12 -12
  105. package/src/hooks/useEventListener.ts +21 -21
  106. package/src/hooks/useOutsideAlerter.ts +25 -25
  107. package/src/index.tsx +40 -40
  108. package/src/libs/StringHelpers.ts +3 -3
  109. package/src/mocks/atlas/entities/entities.json +20215 -20215
  110. package/src/mocks/atlas/icons/icons.json +735 -735
  111. package/src/mocks/atlas/items/items.json +12086 -12086
  112. package/src/mocks/equipmentSet.mocks.ts +391 -393
  113. package/src/mocks/itemContainer.mocks.ts +563 -562
  114. package/src/mocks/skills.mocks.ts +128 -128
  115. package/src/stories/Arrow.stories.tsx +26 -26
  116. package/src/stories/Button.stories.tsx +36 -36
  117. package/src/stories/CharacterSelection.stories.tsx +45 -45
  118. package/src/stories/CharacterStatus.stories.tsx +29 -29
  119. package/src/stories/Chat.stories.tsx +187 -187
  120. package/src/stories/ChatDeprecated.stories.tsx +170 -170
  121. package/src/stories/CheckButton.stories.tsx +48 -48
  122. package/src/stories/CircullarController.stories.tsx +37 -37
  123. package/src/stories/CraftBook.stories.tsx +42 -40
  124. package/src/stories/DayNightPeriod.stories.tsx +27 -27
  125. package/src/stories/DraggableContainer.stories.tsx +28 -28
  126. package/src/stories/Dropdown.stories.tsx +46 -46
  127. package/src/stories/DropdownSelectorContainer.stories.tsx +41 -41
  128. package/src/stories/EquipmentSet.stories.tsx +65 -65
  129. package/src/stories/HistoryDialog.stories.tsx +61 -61
  130. package/src/stories/ItemContainer.stories.tsx +200 -198
  131. package/src/stories/ItemInfoDisplay.stories.tsx +33 -0
  132. package/src/stories/ItemQuantitySelector.stories.tsx +26 -26
  133. package/src/stories/ItemSelector.stories.tsx +77 -77
  134. package/src/stories/ItemTradingComponent.stories.tsx +35 -35
  135. package/src/stories/ListMenu.stories.tsx +56 -56
  136. package/src/stories/Multitab.stories.tsx +51 -51
  137. package/src/stories/NPCDialog.stories.tsx +130 -130
  138. package/src/stories/NPCMultiDialog.stories.tsx +71 -71
  139. package/src/stories/ProgressBar.stories.tsx +23 -23
  140. package/src/stories/PropertySelect.stories.tsx +40 -40
  141. package/src/stories/QuestInfo.stories.tsx +107 -107
  142. package/src/stories/QuestList.stories.tsx +82 -82
  143. package/src/stories/RPGUIContainers.stories.tsx +42 -42
  144. package/src/stories/RadioButton.stories.tsx +49 -49
  145. package/src/stories/RadioInput.stories.tsx +34 -34
  146. package/src/stories/RangeSlider.stories.tsx +64 -64
  147. package/src/stories/ScrollList.stories.tsx +85 -85
  148. package/src/stories/Shortcuts.stories.tsx +39 -39
  149. package/src/stories/SimpleProgressBar.stories.tsx +22 -22
  150. package/src/stories/SkillProgressBar.stories.tsx +34 -34
  151. package/src/stories/SkillsContainer.stories.tsx +35 -35
  152. package/src/stories/Spellbook.stories.tsx +104 -104
  153. package/src/stories/StaticBook.stories.tsx +32 -32
  154. package/src/stories/Text.stories.tsx +42 -42
  155. package/src/stories/TimeWidget.stories.tsx +27 -27
  156. package/src/stories/TradingMenu.stories.tsx +47 -45
  157. package/src/types/eventTypes.ts +4 -4
  158. package/src/types/index.d.ts +2 -2
@@ -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%;"]);
@@ -35784,20 +35831,20 @@ var Spell = function Spell(_ref) {
35784
35831
  isSettingShortcut = _ref.isSettingShortcut,
35785
35832
  minMagicLevelRequired = _ref.minMagicLevelRequired;
35786
35833
  var disabled = isSettingShortcut ? charMagicLevel < minMagicLevelRequired : manaCost > charMana || charMagicLevel < minMagicLevelRequired;
35787
- return React.createElement(Container$j, {
35834
+ return React.createElement(Container$i, {
35788
35835
  disabled: disabled,
35789
35836
  onPointerDown: onPointerDown == null ? void 0 : onPointerDown.bind(null, spellKey),
35790
35837
  isSettingShortcut: isSettingShortcut && !disabled,
35791
35838
  className: "spell"
35792
35839
  }, disabled && React.createElement(Overlay, null, charMagicLevel < minMagicLevelRequired ? 'Low magic level' : manaCost > charMana && 'No mana'), React.createElement(SpellImage, null, magicWords.split(' ').map(function (word) {
35793
35840
  return word[0];
35794
- })), 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", {
35795
35842
  className: "spell"
35796
- }, "(", 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", {
35797
35844
  className: "mana"
35798
35845
  }, manaCost)));
35799
35846
  };
35800
- var Container$j = /*#__PURE__*/styled.button.withConfig({
35847
+ var Container$i = /*#__PURE__*/styled.button.withConfig({
35801
35848
  displayName: "Spell__Container",
35802
35849
  componentId: "sc-j96fa2-0"
35803
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) {
@@ -35812,11 +35859,11 @@ var Info = /*#__PURE__*/styled.span.withConfig({
35812
35859
  displayName: "Spell__Info",
35813
35860
  componentId: "sc-j96fa2-2"
35814
35861
  })(["width:0;flex:1;"]);
35815
- var Title$5 = /*#__PURE__*/styled.p.withConfig({
35862
+ var Title$6 = /*#__PURE__*/styled.p.withConfig({
35816
35863
  displayName: "Spell__Title",
35817
35864
  componentId: "sc-j96fa2-3"
35818
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);
35819
- var Description = /*#__PURE__*/styled.div.withConfig({
35866
+ var Description$1 = /*#__PURE__*/styled.div.withConfig({
35820
35867
  displayName: "Spell__Description",
35821
35868
  componentId: "sc-j96fa2-4"
35822
35869
  })(["font-size:", " !important;line-height:1.1 !important;"], uiFonts.size.small);
@@ -35882,7 +35929,7 @@ var Spellbook = function Spellbook(_ref) {
35882
35929
  width: "inherit",
35883
35930
  height: "inherit",
35884
35931
  cancelDrag: "#spellbook-search, #shortcuts_list, .spell"
35885
- }, 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, {
35886
35933
  setSettingShortcutIndex: setSettingShortcutIndex,
35887
35934
  settingShortcutIndex: settingShortcutIndex,
35888
35935
  shortcuts: shortcuts,
@@ -35910,11 +35957,11 @@ var Spellbook = function Spellbook(_ref) {
35910
35957
  }, spell)));
35911
35958
  }))));
35912
35959
  };
35913
- var Title$6 = /*#__PURE__*/styled.h1.withConfig({
35960
+ var Title$7 = /*#__PURE__*/styled.h1.withConfig({
35914
35961
  displayName: "Spellbook__Title",
35915
35962
  componentId: "sc-r02nfq-0"
35916
35963
  })(["font-size:", " !important;margin-bottom:0 !important;"], uiFonts.size.large);
35917
- var Container$k = /*#__PURE__*/styled.div.withConfig({
35964
+ var Container$j = /*#__PURE__*/styled.div.withConfig({
35918
35965
  displayName: "Spellbook__Container",
35919
35966
  componentId: "sc-r02nfq-1"
35920
35967
  })(["width:100%;height:100%;color:white;display:flex;flex-direction:column;"]);
@@ -35928,16 +35975,16 @@ var TextArea = function TextArea(_ref) {
35928
35975
  return React.createElement("textarea", Object.assign({}, props));
35929
35976
  };
35930
35977
 
35931
- var img$a = '';
35978
+ var img$9 = '';
35932
35979
 
35933
- var img$b = '';
35980
+ var img$a = '';
35934
35981
 
35935
- var img$c = '';
35982
+ var img$b = '';
35936
35983
 
35937
35984
  var DayNightPeriod = function DayNightPeriod(_ref) {
35938
35985
  var _periodOfDaySrcFiles;
35939
35986
  var periodOfDay = _ref.periodOfDay;
35940
- 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);
35941
35988
  return React.createElement(GifContainer, null, React.createElement("img", {
35942
35989
  src: periodOfDaySrcFiles[periodOfDay]
35943
35990
  }));
@@ -35947,7 +35994,7 @@ var GifContainer = /*#__PURE__*/styled.div.withConfig({
35947
35994
  componentId: "sc-10t97fw-0"
35948
35995
  })(["width:100%;img{width:67%;}"]);
35949
35996
 
35950
- var img$d = '';
35997
+ var img$c = '';
35951
35998
 
35952
35999
  var TimeWidget = function TimeWidget(_ref) {
35953
36000
  var onClose = _ref.onClose,
@@ -35962,7 +36009,7 @@ var TimeWidget = function TimeWidget(_ref) {
35962
36009
  var WidgetContainer = /*#__PURE__*/styled.div.withConfig({
35963
36010
  displayName: "TimeWidget__WidgetContainer",
35964
36011
  componentId: "sc-1ja236h-0"
35965
- })(["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);
35966
36013
  var Time = /*#__PURE__*/styled.div.withConfig({
35967
36014
  displayName: "TimeWidget__Time",
35968
36015
  componentId: "sc-1ja236h-1"
@@ -35982,7 +36029,8 @@ var TradingItemRow = function TradingItemRow(_ref) {
35982
36029
  atlasJSON = _ref.atlasJSON,
35983
36030
  onQuantityChange = _ref.onQuantityChange,
35984
36031
  traderItem = _ref.traderItem,
35985
- selectedQty = _ref.selectedQty;
36032
+ selectedQty = _ref.selectedQty,
36033
+ equipmentSet = _ref.equipmentSet;
35986
36034
  var onLeftClick = function onLeftClick(qty) {
35987
36035
  if (qty === void 0) {
35988
36036
  qty = 1;
@@ -35990,22 +36038,27 @@ var TradingItemRow = function TradingItemRow(_ref) {
35990
36038
  onQuantityChange(traderItem, Math.max(0, selectedQty - qty));
35991
36039
  };
35992
36040
  var onRightClick = function onRightClick(qty) {
35993
- var _traderItem$qty;
36041
+ var _traderItem$stackQty;
35994
36042
  if (qty === void 0) {
35995
36043
  qty = 1;
35996
36044
  }
35997
- 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));
35998
36046
  };
35999
- 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, {
36000
36053
  atlasIMG: atlasIMG,
36001
36054
  atlasJSON: atlasJSON,
36002
36055
  spriteKey: getItemTextureKeyPath({
36003
36056
  key: traderItem.key,
36004
- stackQty: traderItem.qty || 1,
36057
+ stackQty: traderItem.stackQty || 1,
36005
36058
  texturePath: traderItem.texturePath
36006
36059
  }, atlasJSON),
36007
36060
  imgScale: 2.5
36008
- }))), 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, {
36009
36062
  maxLines: 1,
36010
36063
  maxWidth: "250px"
36011
36064
  }, capitalize(traderItem.name))), React.createElement("p", null, "$", traderItem.price))), React.createElement(QuantityContainer, null, React.createElement(SelectArrow, {
@@ -36078,7 +36131,8 @@ var TradingMenu = function TradingMenu(_ref) {
36078
36131
  atlasJSON = _ref.atlasJSON,
36079
36132
  atlasIMG = _ref.atlasIMG,
36080
36133
  characterAvailableGold = _ref.characterAvailableGold,
36081
- onConfirm = _ref.onConfirm;
36134
+ onConfirm = _ref.onConfirm,
36135
+ equipmentSet = _ref.equipmentSet;
36082
36136
  var _useState = useState(0),
36083
36137
  sum = _useState[0],
36084
36138
  setSum = _useState[1];
@@ -36136,7 +36190,7 @@ var TradingMenu = function TradingMenu(_ref) {
36136
36190
  style: {
36137
36191
  width: '100%'
36138
36192
  }
36139
- }, React.createElement(Title$7, null, Capitalize(type), " Menu"), React.createElement("hr", {
36193
+ }, React.createElement(Title$8, null, Capitalize(type), " Menu"), React.createElement("hr", {
36140
36194
  className: "golden"
36141
36195
  })), React.createElement(TradingComponentScrollWrapper, {
36142
36196
  id: "TraderContainer"
@@ -36149,7 +36203,8 @@ var TradingMenu = function TradingMenu(_ref) {
36149
36203
  atlasJSON: atlasJSON,
36150
36204
  onQuantityChange: onQuantityChange,
36151
36205
  traderItem: tradeItem,
36152
- 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
36153
36208
  }));
36154
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, {
36155
36210
  buttonType: ButtonTypes.RPGUIButton,
@@ -36164,7 +36219,7 @@ var TradingMenu = function TradingMenu(_ref) {
36164
36219
  }
36165
36220
  }, "Cancel"))));
36166
36221
  };
36167
- var Title$7 = /*#__PURE__*/styled.h1.withConfig({
36222
+ var Title$8 = /*#__PURE__*/styled.h1.withConfig({
36168
36223
  displayName: "TradingMenu__Title",
36169
36224
  componentId: "sc-1wjsz1l-0"
36170
36225
  })(["z-index:22;font-size:0.6rem;color:yellow !important;"]);
@@ -36198,16 +36253,230 @@ var Truncate = function Truncate(_ref) {
36198
36253
  var _ref$maxLines = _ref.maxLines,
36199
36254
  maxLines = _ref$maxLines === void 0 ? 1 : _ref$maxLines,
36200
36255
  children = _ref.children;
36201
- return React.createElement(Container$l, {
36256
+ return React.createElement(Container$k, {
36202
36257
  maxLines: maxLines
36203
36258
  }, children);
36204
36259
  };
36205
- var Container$l = /*#__PURE__*/styled.div.withConfig({
36260
+ var Container$k = /*#__PURE__*/styled.div.withConfig({
36206
36261
  displayName: "Truncate__Container",
36207
36262
  componentId: "sc-6x00qb-0"
36208
36263
  })(["display:-webkit-box;max-width:100%;max-height:100%;-webkit-line-clamp:", ";-webkit-box-orient:vertical;overflow:hidden;"], function (props) {
36209
36264
  return props.maxLines;
36210
36265
  });
36211
36266
 
36212
- 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 };
36213
36482
  //# sourceMappingURL=long-bow.esm.js.map