@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.
- package/LICENSE +20 -20
- package/README.md +181 -181
- package/dist/components/CraftBook/CraftBook.d.ts +2 -1
- package/dist/components/Item/Cards/ItemInfo.d.ts +10 -0
- package/dist/components/Item/Cards/ItemInfoDisplay.d.ts +9 -0
- package/dist/components/Item/Cards/ItemInfoWrapper.d.ts +11 -0
- package/dist/components/Item/Cards/ItemTooltip.d.ts +7 -4
- package/dist/components/Item/Inventory/ItemContainer.d.ts +2 -1
- package/dist/components/Item/Inventory/ItemSlot.d.ts +4 -1
- package/dist/components/TradingMenu/TradingItemRow.d.ts +2 -1
- package/dist/components/TradingMenu/TradingMenu.d.ts +4 -3
- package/dist/components/shared/SpriteFromAtlas.d.ts +1 -0
- package/dist/long-bow.cjs.development.js +1220 -949
- package/dist/long-bow.cjs.development.js.map +1 -1
- package/dist/long-bow.cjs.production.min.js +1 -1
- package/dist/long-bow.cjs.production.min.js.map +1 -1
- package/dist/long-bow.esm.js +1222 -953
- package/dist/long-bow.esm.js.map +1 -1
- package/dist/stories/ItemInfoDisplay.stories.d.ts +8 -0
- package/dist/stories/TradingMenu.stories.d.ts +2 -2
- package/package.json +100 -100
- package/src/components/Abstractions/SlotsContainer.tsx +45 -45
- package/src/components/Arrow/SelectArrow.tsx +69 -69
- package/src/components/Arrow/img/arrow01-left-clicked.png +0 -0
- package/src/components/Arrow/img/arrow01-left.png +0 -0
- package/src/components/Arrow/img/arrow01-right-clicked.png +0 -0
- package/src/components/Arrow/img/arrow01-right.png +0 -0
- package/src/components/Arrow/img/arrow02-left-clicked.png +0 -0
- package/src/components/Arrow/img/arrow02-left.png +0 -0
- package/src/components/Arrow/img/arrow02-right-clicked.png +0 -0
- package/src/components/Arrow/img/arrow02-right.png +0 -0
- package/src/components/Button.tsx +40 -40
- package/src/components/Character/CharacterSelection.tsx +96 -96
- package/src/components/CharacterStatus/CharacterStatus.tsx +120 -120
- package/src/components/Chat/Chat.tsx +195 -195
- package/src/components/Chatdeprecated/ChatDeprecated.tsx +198 -198
- package/src/components/CheckButton.tsx +65 -65
- package/src/components/CircularController/CircularController.tsx +248 -248
- package/src/components/CraftBook/CraftBook.tsx +237 -227
- package/src/components/CraftBook/MockItems.ts +41 -46
- package/src/components/DraggableContainer.tsx +153 -153
- package/src/components/Dropdown.tsx +90 -90
- package/src/components/DropdownSelectorContainer.tsx +42 -42
- package/src/components/Equipment/EquipmentSet.tsx +190 -190
- package/src/components/HistoryDialog.tsx +104 -104
- package/src/components/Input.tsx +15 -15
- package/src/components/Item/Cards/ItemInfo.tsx +248 -0
- package/src/components/Item/Cards/ItemInfoDisplay.tsx +120 -0
- package/src/components/Item/Cards/ItemInfoWrapper.tsx +39 -0
- package/src/components/Item/Cards/ItemTooltip.tsx +85 -33
- package/src/components/Item/Inventory/ErrorBoundary.tsx +42 -42
- package/src/components/Item/Inventory/ItemContainer.tsx +214 -210
- package/src/components/Item/Inventory/ItemContainerTypes.ts +6 -6
- package/src/components/Item/Inventory/ItemQuantitySelector.tsx +138 -138
- package/src/components/Item/Inventory/ItemSlot.tsx +512 -501
- package/src/components/Item/Inventory/itemContainerHelper.ts +156 -156
- package/src/components/ListMenu.tsx +63 -63
- package/src/components/Multitab/Tab.tsx +66 -66
- package/src/components/Multitab/TabBody.tsx +13 -13
- package/src/components/Multitab/TabsContainer.tsx +97 -97
- package/src/components/NPCDialog/NPCDialog.tsx +121 -121
- package/src/components/NPCDialog/NPCDialogText.tsx +113 -113
- package/src/components/NPCDialog/NPCMultiDialog.tsx +159 -159
- package/src/components/NPCDialog/QuestionDialog/QuestionDialog.tsx +237 -237
- package/src/components/ProgressBar.tsx +92 -92
- package/src/components/PropertySelect/PropertySelect.tsx +106 -106
- package/src/components/QuestInfo/QuestInfo.tsx +230 -230
- package/src/components/QuestList.tsx +129 -129
- package/src/components/RPGUIContainer.tsx +47 -47
- package/src/components/RPGUIForceRenderStart.tsx +45 -45
- package/src/components/RPGUIRoot.tsx +14 -14
- package/src/components/RadioButton.tsx +53 -53
- package/src/components/RadioInput/RadioButton.tsx +96 -96
- package/src/components/RadioInput/RadioInput.tsx +102 -102
- package/src/components/RadioInput/instruments.ts +15 -15
- package/src/components/RangeSlider.tsx +78 -78
- package/src/components/RelativeListMenu.tsx +83 -83
- package/src/components/ScrollList.tsx +79 -79
- package/src/components/Shortcuts/Shortcuts.tsx +151 -151
- package/src/components/Shortcuts/ShortcutsSetter.tsx +132 -132
- package/src/components/Shortcuts/SingleShortcut.ts +62 -62
- package/src/components/SimpleProgressBar.tsx +62 -62
- package/src/components/SkillProgressBar.tsx +133 -133
- package/src/components/SkillsContainer.tsx +198 -198
- package/src/components/Spellbook/Spell.tsx +201 -201
- package/src/components/Spellbook/Spellbook.tsx +150 -150
- package/src/components/Spellbook/constants.ts +8 -8
- package/src/components/Spellbook/mockSpells.ts +60 -60
- package/src/components/StaticBook/StaticBook.tsx +103 -103
- package/src/components/TextArea.tsx +11 -11
- package/src/components/TimeWidget/DayNightPeriod/DayNightPeriod.tsx +35 -35
- package/src/components/TimeWidget/TimeWidget.tsx +63 -63
- package/src/components/TradingMenu/TradingItemRow.tsx +195 -181
- package/src/components/TradingMenu/TradingMenu.tsx +211 -203
- package/src/components/TradingMenu/items.mock.ts +48 -96
- package/src/components/Truncate.tsx +25 -25
- package/src/components/itemSelector/ItemSelector.tsx +136 -136
- package/src/components/shared/Column.tsx +16 -16
- package/src/components/shared/Ellipsis.tsx +65 -65
- package/src/components/shared/SpriteFromAtlas.tsx +104 -102
- package/src/components/typography/DynamicText.tsx +49 -49
- package/src/constants/uiColors.ts +20 -20
- package/src/constants/uiDevices.ts +3 -3
- package/src/constants/uiFonts.ts +12 -12
- package/src/hooks/useEventListener.ts +21 -21
- package/src/hooks/useOutsideAlerter.ts +25 -25
- package/src/index.tsx +40 -40
- package/src/libs/StringHelpers.ts +3 -3
- package/src/mocks/atlas/entities/entities.json +20215 -20215
- package/src/mocks/atlas/icons/icons.json +735 -735
- package/src/mocks/atlas/items/items.json +12086 -12086
- package/src/mocks/equipmentSet.mocks.ts +391 -393
- package/src/mocks/itemContainer.mocks.ts +563 -562
- package/src/mocks/skills.mocks.ts +128 -128
- package/src/stories/Arrow.stories.tsx +26 -26
- package/src/stories/Button.stories.tsx +36 -36
- package/src/stories/CharacterSelection.stories.tsx +45 -45
- package/src/stories/CharacterStatus.stories.tsx +29 -29
- package/src/stories/Chat.stories.tsx +187 -187
- package/src/stories/ChatDeprecated.stories.tsx +170 -170
- package/src/stories/CheckButton.stories.tsx +48 -48
- package/src/stories/CircullarController.stories.tsx +37 -37
- package/src/stories/CraftBook.stories.tsx +42 -40
- package/src/stories/DayNightPeriod.stories.tsx +27 -27
- package/src/stories/DraggableContainer.stories.tsx +28 -28
- package/src/stories/Dropdown.stories.tsx +46 -46
- package/src/stories/DropdownSelectorContainer.stories.tsx +41 -41
- package/src/stories/EquipmentSet.stories.tsx +65 -65
- package/src/stories/HistoryDialog.stories.tsx +61 -61
- package/src/stories/ItemContainer.stories.tsx +200 -198
- package/src/stories/ItemInfoDisplay.stories.tsx +33 -0
- package/src/stories/ItemQuantitySelector.stories.tsx +26 -26
- package/src/stories/ItemSelector.stories.tsx +77 -77
- package/src/stories/ItemTradingComponent.stories.tsx +35 -35
- package/src/stories/ListMenu.stories.tsx +56 -56
- package/src/stories/Multitab.stories.tsx +51 -51
- package/src/stories/NPCDialog.stories.tsx +130 -130
- package/src/stories/NPCMultiDialog.stories.tsx +71 -71
- package/src/stories/ProgressBar.stories.tsx +23 -23
- package/src/stories/PropertySelect.stories.tsx +40 -40
- package/src/stories/QuestInfo.stories.tsx +107 -107
- package/src/stories/QuestList.stories.tsx +82 -82
- package/src/stories/RPGUIContainers.stories.tsx +42 -42
- package/src/stories/RadioButton.stories.tsx +49 -49
- package/src/stories/RadioInput.stories.tsx +34 -34
- package/src/stories/RangeSlider.stories.tsx +64 -64
- package/src/stories/ScrollList.stories.tsx +85 -85
- package/src/stories/Shortcuts.stories.tsx +39 -39
- package/src/stories/SimpleProgressBar.stories.tsx +22 -22
- package/src/stories/SkillProgressBar.stories.tsx +34 -34
- package/src/stories/SkillsContainer.stories.tsx +35 -35
- package/src/stories/Spellbook.stories.tsx +104 -104
- package/src/stories/StaticBook.stories.tsx +32 -32
- package/src/stories/Text.stories.tsx +42 -42
- package/src/stories/TimeWidget.stories.tsx +27 -27
- package/src/stories/TradingMenu.stories.tsx +47 -45
- package/src/types/eventTypes.ts +4 -4
- package/src/types/index.d.ts +2 -2
package/dist/long-bow.esm.js
CHANGED
|
@@ -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,
|
|
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$
|
|
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
|
-
|
|
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
|
|
33821
|
+
return null;
|
|
34016
33822
|
}
|
|
34017
33823
|
};
|
|
34018
|
-
var Container$
|
|
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$
|
|
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$
|
|
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
|
-
|
|
35022
|
-
|
|
35023
|
-
|
|
35024
|
-
|
|
35025
|
-
|
|
35026
|
-
|
|
35027
|
-
|
|
35028
|
-
|
|
35029
|
-
|
|
35030
|
-
|
|
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
|
-
|
|
35078
|
-
|
|
35079
|
-
|
|
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
|
-
}
|
|
35082
|
-
|
|
35083
|
-
|
|
35084
|
-
|
|
35085
|
-
|
|
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
|
-
|
|
35092
|
-
|
|
35093
|
-
|
|
35169
|
+
var answers = onGetAnswers(answerIds);
|
|
35170
|
+
if (!answers) {
|
|
35171
|
+
return null;
|
|
35094
35172
|
}
|
|
35095
|
-
|
|
35096
|
-
|
|
35097
|
-
|
|
35098
|
-
|
|
35099
|
-
|
|
35100
|
-
|
|
35101
|
-
|
|
35102
|
-
|
|
35103
|
-
|
|
35104
|
-
|
|
35105
|
-
|
|
35106
|
-
|
|
35107
|
-
|
|
35108
|
-
|
|
35109
|
-
|
|
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
|
-
|
|
35117
|
-
|
|
35118
|
-
|
|
35119
|
-
|
|
35120
|
-
|
|
35121
|
-
|
|
35122
|
-
|
|
35123
|
-
}
|
|
35124
|
-
|
|
35125
|
-
|
|
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
|
-
},
|
|
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$
|
|
35172
|
-
displayName: "
|
|
35173
|
-
componentId: "sc-
|
|
35174
|
-
})(["display:flex;
|
|
35175
|
-
|
|
35176
|
-
|
|
35177
|
-
|
|
35178
|
-
}
|
|
35179
|
-
var
|
|
35180
|
-
displayName: "
|
|
35181
|
-
componentId: "sc-
|
|
35182
|
-
})(["
|
|
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$
|
|
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$
|
|
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$
|
|
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$
|
|
35283
|
-
src: quests[currentIndex].thumbnail || img$
|
|
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$
|
|
35302
|
-
src: quests[0].thumbnail || img$
|
|
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$
|
|
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$
|
|
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$
|
|
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$
|
|
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$
|
|
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$
|
|
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$
|
|
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$
|
|
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$
|
|
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$
|
|
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$
|
|
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$
|
|
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$
|
|
35978
|
+
var img$9 = '';
|
|
35932
35979
|
|
|
35933
|
-
var img$
|
|
35980
|
+
var img$a = '';
|
|
35934
35981
|
|
|
35935
|
-
var img$
|
|
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$
|
|
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$
|
|
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$
|
|
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$
|
|
36041
|
+
var _traderItem$stackQty;
|
|
35994
36042
|
if (qty === void 0) {
|
|
35995
36043
|
qty = 1;
|
|
35996
36044
|
}
|
|
35997
|
-
onQuantityChange(traderItem, Math.min((_traderItem$
|
|
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(
|
|
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.
|
|
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$
|
|
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$
|
|
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$
|
|
36256
|
+
return React.createElement(Container$k, {
|
|
36202
36257
|
maxLines: maxLines
|
|
36203
36258
|
}, children);
|
|
36204
36259
|
};
|
|
36205
|
-
var Container$
|
|
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
|
-
|
|
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
|