@rpg-engine/long-bow 0.3.53 → 0.3.55
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/Arrow/SelectArrow.d.ts +1 -1
- package/dist/components/Button.d.ts +2 -2
- package/dist/components/CircularController/CircularController.d.ts +4 -7
- package/dist/components/Item/Inventory/ItemContainer.d.ts +1 -4
- package/dist/components/Item/Inventory/ItemSlot.d.ts +1 -2
- package/dist/components/Multitab/Tab.d.ts +1 -1
- package/dist/components/QuestInfo/QuestInfo.d.ts +1 -1
- package/dist/components/Spellbook/QuickSpells.d.ts +10 -0
- package/dist/components/Spellbook/Spell.d.ts +1 -1
- package/dist/components/Spellbook/Spellbook.d.ts +3 -5
- package/dist/components/Spellbook/SpellbookShortcuts.d.ts +10 -0
- package/dist/components/Spellbook/constants.d.ts +3 -3
- package/dist/components/shared/SpriteFromAtlas.d.ts +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/long-bow.cjs.development.js +734 -914
- 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 +736 -917
- package/dist/long-bow.esm.js.map +1 -1
- package/dist/stories/{Shortcuts.stories.d.ts → QuickSpells.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 -65
- 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 -41
- 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 -200
- package/src/components/CheckButton.tsx +65 -65
- package/src/components/CircularController/CircularController.tsx +162 -245
- package/src/components/CraftBook/CraftBook.tsx +224 -235
- package/src/components/CraftBook/MockItems.ts +46 -46
- package/src/components/DraggableContainer.tsx +153 -154
- package/src/components/Dropdown.tsx +90 -96
- 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/ItemTooltip.tsx +33 -33
- package/src/components/Item/Inventory/ErrorBoundary.tsx +42 -42
- package/src/components/Item/Inventory/ItemContainer.tsx +175 -210
- package/src/components/Item/Inventory/ItemContainerTypes.ts +6 -6
- package/src/components/Item/Inventory/ItemQuantitySelector.tsx +138 -142
- package/src/components/Item/Inventory/ItemSlot.tsx +467 -502
- package/src/components/Item/Inventory/itemContainerHelper.ts +156 -156
- package/src/components/ListMenu.tsx +63 -63
- package/src/components/Multitab/Tab.tsx +66 -57
- 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 -114
- package/src/components/QuestInfo/QuestInfo.tsx +230 -232
- 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 -98
- package/src/components/RadioInput/RadioInput.tsx +102 -99
- 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/SimpleProgressBar.tsx +62 -62
- package/src/components/SkillProgressBar.tsx +133 -133
- package/src/components/SkillsContainer.tsx +198 -200
- package/src/components/Spellbook/QuickSpells.tsx +120 -0
- package/src/components/Spellbook/Spell.tsx +201 -201
- package/src/components/Spellbook/Spellbook.tsx +144 -150
- package/src/components/Spellbook/SpellbookShortcuts.tsx +77 -0
- package/src/components/Spellbook/constants.ts +12 -8
- package/src/components/Spellbook/mockSpells.ts +60 -60
- package/src/components/StaticBook/StaticBook.tsx +103 -105
- 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 +193 -197
- package/src/components/TradingMenu/TradingMenu.tsx +203 -203
- package/src/components/TradingMenu/items.mock.ts +96 -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 +102 -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 +393 -393
- package/src/mocks/itemContainer.mocks.ts +560 -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 +33 -37
- package/src/stories/CraftBook.stories.tsx +40 -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 +124 -198
- 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 +110 -107
- package/src/stories/QuestList.stories.tsx +82 -82
- package/src/stories/QuickSpells.stories.tsx +38 -0
- 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/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 +107 -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 +45 -45
- package/src/types/eventTypes.ts +4 -4
- package/src/types/index.d.ts +2 -2
- package/dist/components/Shortcuts/Shortcuts.d.ts +0 -12
- package/dist/components/Shortcuts/ShortcutsSetter.d.ts +0 -12
- package/dist/components/Shortcuts/SingleShortcut.d.ts +0 -1
- package/src/components/Shortcuts/Shortcuts.tsx +0 -129
- package/src/components/Shortcuts/ShortcutsSetter.tsx +0 -132
- package/src/components/Shortcuts/SingleShortcut.ts +0 -61
- package/src/stories/Shortcuts.stories.tsx +0 -39
package/dist/long-bow.esm.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
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,
|
|
3
|
+
import { GRID_WIDTH, GRID_HEIGHT, ItemSubType, ItemContainerType, ItemType, ItemSocketEventsDisplayLabels, ActionsForInventory, ActionsForEquipmentSet, ActionsForLoot, ActionsForMapContainer, ItemRarities, getItemTextureKeyPath, ItemSlotType, isMobileOrTablet, getSPForLevel, PeriodOfDay } from '@rpg-engine/shared';
|
|
4
4
|
import dayjs from 'dayjs';
|
|
5
5
|
import { ErrorBoundary as ErrorBoundary$1 } from 'react-error-boundary';
|
|
6
6
|
import { RxPaperPlane } from 'react-icons/rx';
|
|
@@ -66,7 +66,7 @@ var uiFonts = {
|
|
|
66
66
|
}
|
|
67
67
|
};
|
|
68
68
|
|
|
69
|
-
var _excluded = ["disabled", "children", "buttonType", "
|
|
69
|
+
var _excluded = ["disabled", "children", "buttonType", "onPointerDown"];
|
|
70
70
|
var ButtonTypes;
|
|
71
71
|
(function (ButtonTypes) {
|
|
72
72
|
ButtonTypes["RPGUIButton"] = "rpgui-button";
|
|
@@ -77,14 +77,13 @@ var Button = function Button(_ref) {
|
|
|
77
77
|
disabled = _ref$disabled === void 0 ? false : _ref$disabled,
|
|
78
78
|
children = _ref.children,
|
|
79
79
|
buttonType = _ref.buttonType,
|
|
80
|
-
|
|
80
|
+
onPointerDown = _ref.onPointerDown,
|
|
81
81
|
props = _objectWithoutPropertiesLoose(_ref, _excluded);
|
|
82
82
|
return React.createElement(ButtonContainer, Object.assign({
|
|
83
83
|
className: "" + buttonType,
|
|
84
84
|
disabled: disabled
|
|
85
85
|
}, props, {
|
|
86
|
-
|
|
87
|
-
onClick: onClick
|
|
86
|
+
onPointerDown: onPointerDown
|
|
88
87
|
}), React.createElement("p", null, children));
|
|
89
88
|
};
|
|
90
89
|
var ButtonContainer = /*#__PURE__*/styled.button.withConfig({
|
|
@@ -103,7 +102,7 @@ var SpriteFromAtlas = function SpriteFromAtlas(_ref) {
|
|
|
103
102
|
_ref$imgScale = _ref.imgScale,
|
|
104
103
|
imgScale = _ref$imgScale === void 0 ? 2 : _ref$imgScale,
|
|
105
104
|
imgStyle = _ref.imgStyle,
|
|
106
|
-
|
|
105
|
+
onPointerDown = _ref.onPointerDown,
|
|
107
106
|
containerStyle = _ref.containerStyle,
|
|
108
107
|
_ref$grayScale = _ref.grayScale,
|
|
109
108
|
grayScale = _ref$grayScale === void 0 ? false : _ref$grayScale,
|
|
@@ -117,7 +116,7 @@ var SpriteFromAtlas = function SpriteFromAtlas(_ref) {
|
|
|
117
116
|
width: width,
|
|
118
117
|
height: height,
|
|
119
118
|
hasHover: grayScale,
|
|
120
|
-
|
|
119
|
+
onPointerDown: onPointerDown,
|
|
121
120
|
style: containerStyle
|
|
122
121
|
}, React.createElement(ImgSprite, {
|
|
123
122
|
className: "sprite-from-atlas-img",
|
|
@@ -32517,22 +32516,22 @@ var img$4 = '
|
|
|
32517
32516
|
|
|
32518
32517
|
var img$5 = '';
|
|
32519
32518
|
|
|
32520
|
-
var _excluded$1 = ["direction", "size", "
|
|
32519
|
+
var _excluded$1 = ["direction", "size", "onPointerDown"];
|
|
32521
32520
|
var SelectArrow = function SelectArrow(_ref) {
|
|
32522
32521
|
var _ref$direction = _ref.direction,
|
|
32523
32522
|
direction = _ref$direction === void 0 ? 'left' : _ref$direction,
|
|
32524
32523
|
size = _ref.size,
|
|
32525
|
-
|
|
32524
|
+
_onPointerDown = _ref.onPointerDown,
|
|
32526
32525
|
props = _objectWithoutPropertiesLoose(_ref, _excluded$1);
|
|
32527
32526
|
return React.createElement(React.Fragment, null, direction === 'left' ? React.createElement(LeftArrow, Object.assign({
|
|
32528
32527
|
size: size,
|
|
32529
|
-
|
|
32530
|
-
return
|
|
32528
|
+
onPointerDown: function onPointerDown() {
|
|
32529
|
+
return _onPointerDown();
|
|
32531
32530
|
}
|
|
32532
32531
|
}, props)) : React.createElement(RightArrow, Object.assign({
|
|
32533
32532
|
size: size,
|
|
32534
|
-
|
|
32535
|
-
return
|
|
32533
|
+
onPointerDown: function onPointerDown() {
|
|
32534
|
+
return _onPointerDown();
|
|
32536
32535
|
}
|
|
32537
32536
|
}, props)));
|
|
32538
32537
|
};
|
|
@@ -32618,12 +32617,10 @@ var PropertySelect = function PropertySelect(_ref) {
|
|
|
32618
32617
|
className: "rpgui-progress-track"
|
|
32619
32618
|
}), React.createElement(SelectArrow, {
|
|
32620
32619
|
direction: "left",
|
|
32621
|
-
|
|
32622
|
-
onTouchStart: onLeftClick
|
|
32620
|
+
onPointerDown: onLeftClick
|
|
32623
32621
|
}), React.createElement(SelectArrow, {
|
|
32624
32622
|
direction: "right",
|
|
32625
|
-
|
|
32626
|
-
onTouchStart: onRightClick
|
|
32623
|
+
onPointerDown: onRightClick
|
|
32627
32624
|
}));
|
|
32628
32625
|
};
|
|
32629
32626
|
var Item = /*#__PURE__*/styled.span.withConfig({
|
|
@@ -32784,7 +32781,7 @@ var Chat = function Chat(_ref) {
|
|
|
32784
32781
|
autoComplete: "off",
|
|
32785
32782
|
onFocus: onFocus,
|
|
32786
32783
|
onBlur: onBlur,
|
|
32787
|
-
|
|
32784
|
+
onPointerDown: onFocus,
|
|
32788
32785
|
autoFocus: true
|
|
32789
32786
|
})), React.createElement(Column, {
|
|
32790
32787
|
justifyContent: "flex-end"
|
|
@@ -32956,8 +32953,7 @@ var ChatDeprecated = function ChatDeprecated(_ref) {
|
|
|
32956
32953
|
}, React.createElement(ErrorBoundary$1, {
|
|
32957
32954
|
fallback: React.createElement("p", null, "Oops! Your chat has crashed.")
|
|
32958
32955
|
}, onCloseButton && React.createElement(CloseButton, {
|
|
32959
|
-
|
|
32960
|
-
onTouchStart: onCloseButton
|
|
32956
|
+
onPointerDown: onCloseButton
|
|
32961
32957
|
}, "X"), React.createElement(RPGUIContainer, {
|
|
32962
32958
|
type: RPGUIContainerTypes.FramedGrey,
|
|
32963
32959
|
width: '100%',
|
|
@@ -33046,27 +33042,69 @@ var CheckButton = function CheckButton(_ref) {
|
|
|
33046
33042
|
checked: selectedValues[element.label],
|
|
33047
33043
|
onChange: function onChange() {}
|
|
33048
33044
|
}), React.createElement("label", {
|
|
33049
|
-
|
|
33045
|
+
onPointerDown: function onPointerDown() {
|
|
33050
33046
|
return handleClick(element.label);
|
|
33051
33047
|
}
|
|
33052
33048
|
}, element.label), React.createElement("br", null));
|
|
33053
33049
|
}));
|
|
33054
33050
|
};
|
|
33055
33051
|
|
|
33056
|
-
var
|
|
33057
|
-
|
|
33058
|
-
|
|
33059
|
-
|
|
33052
|
+
var QuickSpells = function QuickSpells(_ref) {
|
|
33053
|
+
var quickSpells = _ref.quickSpells,
|
|
33054
|
+
onSpellCast = _ref.onSpellCast,
|
|
33055
|
+
mana = _ref.mana,
|
|
33056
|
+
_ref$isBlockedCasting = _ref.isBlockedCastingByKeyboard,
|
|
33057
|
+
isBlockedCastingByKeyboard = _ref$isBlockedCasting === void 0 ? false : _ref$isBlockedCasting;
|
|
33058
|
+
useEffect(function () {
|
|
33059
|
+
var handleKeyDown = function handleKeyDown(e) {
|
|
33060
|
+
if (isBlockedCastingByKeyboard) return;
|
|
33061
|
+
var shortcutIndex = Number(e.key) - 1;
|
|
33062
|
+
if (shortcutIndex >= 0 && shortcutIndex <= 3) {
|
|
33063
|
+
var shortcut = quickSpells[shortcutIndex];
|
|
33064
|
+
if (shortcut != null && shortcut.key && mana >= (shortcut == null ? void 0 : shortcut.manaCost)) {
|
|
33065
|
+
onSpellCast(shortcut.key);
|
|
33066
|
+
}
|
|
33067
|
+
}
|
|
33068
|
+
};
|
|
33069
|
+
window.addEventListener('keydown', handleKeyDown);
|
|
33070
|
+
return function () {
|
|
33071
|
+
window.removeEventListener('keydown', handleKeyDown);
|
|
33072
|
+
};
|
|
33073
|
+
}, [quickSpells, isBlockedCastingByKeyboard]);
|
|
33074
|
+
return React.createElement(List, null, Array.from({
|
|
33075
|
+
length: 4
|
|
33076
|
+
}).map(function (_, i) {
|
|
33077
|
+
var _quickSpells$i, _quickSpells$i2, _quickSpells$i3, _quickSpells$i4, _quickSpells$i5;
|
|
33078
|
+
return React.createElement(SpellShortcut, {
|
|
33079
|
+
key: i,
|
|
33080
|
+
onPointerDown: onSpellCast.bind(null, (_quickSpells$i = quickSpells[i]) == null ? void 0 : _quickSpells$i.key),
|
|
33081
|
+
disabled: mana < ((_quickSpells$i2 = quickSpells[i]) == null ? void 0 : _quickSpells$i2.manaCost)
|
|
33082
|
+
}, React.createElement("span", {
|
|
33083
|
+
className: "mana"
|
|
33084
|
+
}, ((_quickSpells$i3 = quickSpells[i]) == null ? void 0 : _quickSpells$i3.key) && ((_quickSpells$i4 = quickSpells[i]) == null ? void 0 : _quickSpells$i4.manaCost)), React.createElement("span", {
|
|
33085
|
+
className: "magicWords"
|
|
33086
|
+
}, (_quickSpells$i5 = quickSpells[i]) == null ? void 0 : _quickSpells$i5.magicWords.split(' ').map(function (word) {
|
|
33087
|
+
return word[0];
|
|
33088
|
+
})), React.createElement("span", {
|
|
33089
|
+
className: "keyboard"
|
|
33090
|
+
}, i + 1));
|
|
33091
|
+
}));
|
|
33092
|
+
};
|
|
33093
|
+
var SpellShortcut = /*#__PURE__*/styled.button.withConfig({
|
|
33094
|
+
displayName: "QuickSpells__SpellShortcut",
|
|
33095
|
+
componentId: "sc-41yq7s-0"
|
|
33096
|
+
})(["width:3rem;height:3rem;background-color:", ";border:2px solid ", ";border-radius:50%;text-transform:uppercase;font-size:0.7rem;font-weight:bold;display:flex;align-items:center;justify-content:center;position:relative;span{pointer-events:none;}.mana{position:absolute;top:-5px;right:0;font-size:0.65rem;color:", ";}.magicWords{margin-top:4px;}.keyboard{position:absolute;bottom:-5px;left:0;font-size:0.65rem;color:", ";}&:hover,&:focus{background-color:", ";}&:active{background-color:", ";}&:disabled{opacity:0.5;}"], uiColors.lightGray, uiColors.darkGray, uiColors.blue, uiColors.yellow, uiColors.darkGray, uiColors.gray);
|
|
33097
|
+
var List = /*#__PURE__*/styled.p.withConfig({
|
|
33098
|
+
displayName: "QuickSpells__List",
|
|
33099
|
+
componentId: "sc-41yq7s-1"
|
|
33100
|
+
})(["width:100%;display:flex;align-items:center;justify-content:center;gap:0.5rem;box-sizing:border-box;margin:0 !important;"]);
|
|
33060
33101
|
|
|
33061
33102
|
var CircularController = function CircularController(_ref) {
|
|
33062
|
-
var
|
|
33103
|
+
var onActionPointerDown = _ref.onActionPointerDown,
|
|
33063
33104
|
onCancelClick = _ref.onCancelClick,
|
|
33064
|
-
|
|
33105
|
+
onSpellClick = _ref.onSpellClick,
|
|
33065
33106
|
mana = _ref.mana,
|
|
33066
|
-
|
|
33067
|
-
inventory = _ref.inventory,
|
|
33068
|
-
atlasIMG = _ref.atlasIMG,
|
|
33069
|
-
atlasJSON = _ref.atlasJSON;
|
|
33107
|
+
spells = _ref.spells;
|
|
33070
33108
|
var onTouchStart = function onTouchStart(e) {
|
|
33071
33109
|
var target = e.target;
|
|
33072
33110
|
target == null ? void 0 : target.classList.add('active');
|
|
@@ -33078,73 +33116,28 @@ var CircularController = function CircularController(_ref) {
|
|
|
33078
33116
|
}, 100);
|
|
33079
33117
|
action();
|
|
33080
33118
|
};
|
|
33081
|
-
|
|
33082
|
-
|
|
33083
|
-
|
|
33084
|
-
|
|
33085
|
-
var
|
|
33086
|
-
|
|
33087
|
-
var _shortcuts$i3;
|
|
33088
|
-
var _payload = (_shortcuts$i3 = shortcuts[i]) == null ? void 0 : _shortcuts$i3.payload;
|
|
33089
|
-
var itemsFromEquipment = [];
|
|
33090
|
-
if (inventory) {
|
|
33091
|
-
Object.keys(inventory.slots).forEach(function (i) {
|
|
33092
|
-
var _inventory$slots$inde;
|
|
33093
|
-
var index = parseInt(i);
|
|
33094
|
-
if (((_inventory$slots$inde = inventory.slots[index]) == null ? void 0 : _inventory$slots$inde.key) === (_payload == null ? void 0 : _payload.key)) {
|
|
33095
|
-
itemsFromEquipment.push(inventory.slots[index]);
|
|
33096
|
-
}
|
|
33097
|
-
});
|
|
33098
|
-
}
|
|
33099
|
-
var totalQty = itemsFromEquipment.reduce(function (acc, item) {
|
|
33100
|
-
return acc + ((item == null ? void 0 : item.stackQty) || 1);
|
|
33101
|
-
}, 0);
|
|
33102
|
-
return React.createElement(StyledShortcut, {
|
|
33103
|
-
key: i,
|
|
33104
|
-
onTouchStart: onTouchStart,
|
|
33105
|
-
onTouchEnd: onTouchEnd.bind(null, onShortcutClickBinded),
|
|
33106
|
-
disabled: false,
|
|
33107
|
-
className: variant
|
|
33108
|
-
}, _payload && React.createElement(SpriteFromAtlas, {
|
|
33109
|
-
atlasIMG: atlasIMG,
|
|
33110
|
-
atlasJSON: atlasJSON,
|
|
33111
|
-
spriteKey: getItemTextureKeyPath({
|
|
33112
|
-
key: _payload.texturePath,
|
|
33113
|
-
texturePath: _payload.texturePath,
|
|
33114
|
-
stackQty: _payload.stackQty || 1
|
|
33115
|
-
}, atlasJSON),
|
|
33116
|
-
width: 32,
|
|
33117
|
-
height: 32,
|
|
33118
|
-
imgScale: 1.4,
|
|
33119
|
-
imgStyle: {
|
|
33120
|
-
left: '4px'
|
|
33121
|
-
}
|
|
33122
|
-
}), React.createElement("span", {
|
|
33123
|
-
className: "qty"
|
|
33124
|
-
}, totalQty));
|
|
33125
|
-
}
|
|
33126
|
-
var payload = (_shortcuts$i4 = shortcuts[i]) == null ? void 0 : _shortcuts$i4.payload;
|
|
33119
|
+
return React.createElement(ButtonsContainer, null, React.createElement(SpellsContainer, null, Array.from({
|
|
33120
|
+
length: 4
|
|
33121
|
+
}).map(function (_, i) {
|
|
33122
|
+
var variant = i === 0 ? 'top' : i === 3 ? 'bottom' : '';
|
|
33123
|
+
var spell = spells[i];
|
|
33124
|
+
var onSpellClickBinded = spell ? onSpellClick.bind(null, spell.key) : function () {};
|
|
33127
33125
|
return React.createElement(StyledShortcut, {
|
|
33128
33126
|
key: i,
|
|
33127
|
+
disabled: mana < (spell == null ? void 0 : spell.manaCost),
|
|
33129
33128
|
onTouchStart: onTouchStart,
|
|
33130
|
-
onTouchEnd: onTouchEnd.bind(null,
|
|
33131
|
-
disabled: mana < ((_payload$manaCost = payload == null ? void 0 : payload.manaCost) != null ? _payload$manaCost : 0),
|
|
33129
|
+
onTouchEnd: onTouchEnd.bind(null, onSpellClickBinded),
|
|
33132
33130
|
className: variant
|
|
33133
33131
|
}, React.createElement("span", {
|
|
33134
33132
|
className: "mana"
|
|
33135
|
-
},
|
|
33133
|
+
}, (spell == null ? void 0 : spell.key) && (spell == null ? void 0 : spell.manaCost)), React.createElement("span", {
|
|
33136
33134
|
className: "magicWords"
|
|
33137
|
-
},
|
|
33135
|
+
}, spell == null ? void 0 : spell.magicWords.split(' ').map(function (word) {
|
|
33138
33136
|
return word[0];
|
|
33139
33137
|
})));
|
|
33140
|
-
};
|
|
33141
|
-
return React.createElement(ButtonsContainer, null, React.createElement(ShortcutsContainer, null, Array.from({
|
|
33142
|
-
length: 6
|
|
33143
|
-
}).map(function (_, i) {
|
|
33144
|
-
return renderShortcut(i);
|
|
33145
33138
|
})), React.createElement(Button$2, {
|
|
33146
33139
|
onTouchStart: onTouchStart,
|
|
33147
|
-
onTouchEnd: onTouchEnd.bind(null,
|
|
33140
|
+
onTouchEnd: onTouchEnd.bind(null, onActionPointerDown)
|
|
33148
33141
|
}, React.createElement("div", {
|
|
33149
33142
|
className: "rpgui-icon sword"
|
|
33150
33143
|
})), React.createElement(CancelButton, {
|
|
@@ -33155,7 +33148,7 @@ var CircularController = function CircularController(_ref) {
|
|
|
33155
33148
|
var Button$2 = /*#__PURE__*/styled.button.withConfig({
|
|
33156
33149
|
displayName: "CircularController__Button",
|
|
33157
33150
|
componentId: "sc-1fewf3h-0"
|
|
33158
|
-
})(["width:4.3rem;height:4.3rem;background-color:", ";border:2px solid ", ";border-radius:50%;text-transform:uppercase;font-size:0.7rem;font-weight:bold;display:flex;align-items:center;justify-content:center;position:relative;transition:background-color 0.1s
|
|
33151
|
+
})(["width:4.3rem;height:4.3rem;background-color:", ";border:2px solid ", ";border-radius:50%;text-transform:uppercase;font-size:0.7rem;font-weight:bold;display:flex;align-items:center;justify-content:center;position:relative;transition:background-color 0.1s;&.active{background-color:", ";}.sword{transform:rotate(-45deg);height:2.5rem;width:1.9rem;pointer-events:none;}"], uiColors.lightGray, uiColors.darkGray, uiColors.gray);
|
|
33159
33152
|
var CancelButton = /*#__PURE__*/styled(Button$2).withConfig({
|
|
33160
33153
|
displayName: "CircularController__CancelButton",
|
|
33161
33154
|
componentId: "sc-1fewf3h-1"
|
|
@@ -33164,14 +33157,14 @@ var ButtonsContainer = /*#__PURE__*/styled.div.withConfig({
|
|
|
33164
33157
|
displayName: "CircularController__ButtonsContainer",
|
|
33165
33158
|
componentId: "sc-1fewf3h-2"
|
|
33166
33159
|
})(["display:flex;align-items:center;justify-content:center;gap:0.5rem;"]);
|
|
33167
|
-
var
|
|
33168
|
-
displayName: "
|
|
33160
|
+
var SpellsContainer = /*#__PURE__*/styled.div.withConfig({
|
|
33161
|
+
displayName: "CircularController__SpellsContainer",
|
|
33169
33162
|
componentId: "sc-1fewf3h-3"
|
|
33170
|
-
})(["display:flex;align-items:center;justify-content:center;gap:0.
|
|
33171
|
-
var StyledShortcut = /*#__PURE__*/styled(
|
|
33163
|
+
})(["display:flex;align-items:center;justify-content:center;gap:0.4rem;flex-direction:column;.top{transform:translate(93%,25%);}.bottom{transform:translate(93%,-25%);}"]);
|
|
33164
|
+
var StyledShortcut = /*#__PURE__*/styled(SpellShortcut).withConfig({
|
|
33172
33165
|
displayName: "CircularController__StyledShortcut",
|
|
33173
33166
|
componentId: "sc-1fewf3h-4"
|
|
33174
|
-
})(["width:2.5rem;height:2.5rem;transition:background-color 0.1s;.mana
|
|
33167
|
+
})(["width:2.5rem;height:2.5rem;transition:background-color 0.1s;.mana{font-size:0.5rem;}&:hover,&:focus,&:active{background-color:", ";}&.active{background-color:", ";}"], uiColors.lightGray, uiColors.gray);
|
|
33175
33168
|
|
|
33176
33169
|
function useOutsideClick(ref, id) {
|
|
33177
33170
|
useEffect(function () {
|
|
@@ -33256,8 +33249,7 @@ var DraggableContainer = function DraggableContainer(_ref) {
|
|
|
33256
33249
|
width: imgWidth
|
|
33257
33250
|
}), title)), onCloseButton && React.createElement(CloseButton$1, {
|
|
33258
33251
|
className: "container-close",
|
|
33259
|
-
|
|
33260
|
-
onTouchStart: onCloseButton
|
|
33252
|
+
onPointerDown: onCloseButton
|
|
33261
33253
|
}, "X"), children));
|
|
33262
33254
|
};
|
|
33263
33255
|
var Container$6 = /*#__PURE__*/styled.div.withConfig({
|
|
@@ -33322,12 +33314,7 @@ var Dropdown = function Dropdown(_ref) {
|
|
|
33322
33314
|
}, React.createElement(DropdownSelect, {
|
|
33323
33315
|
id: "dropdown-" + dropdownId,
|
|
33324
33316
|
className: "rpgui-dropdown-imp rpgui-dropdown-imp-header",
|
|
33325
|
-
|
|
33326
|
-
return setOpened(function (prev) {
|
|
33327
|
-
return !prev;
|
|
33328
|
-
});
|
|
33329
|
-
},
|
|
33330
|
-
onTouchStart: function onTouchStart() {
|
|
33317
|
+
onPointerDown: function onPointerDown() {
|
|
33331
33318
|
return setOpened(function (prev) {
|
|
33332
33319
|
return !prev;
|
|
33333
33320
|
});
|
|
@@ -33338,12 +33325,7 @@ var Dropdown = function Dropdown(_ref) {
|
|
|
33338
33325
|
}, options.map(function (option) {
|
|
33339
33326
|
return React.createElement("li", {
|
|
33340
33327
|
key: option.id,
|
|
33341
|
-
|
|
33342
|
-
setSelectedValue(option.value);
|
|
33343
|
-
setSelectedOption(option.option);
|
|
33344
|
-
setOpened(false);
|
|
33345
|
-
},
|
|
33346
|
-
onTouchStart: function onTouchStart() {
|
|
33328
|
+
onPointerDown: function onPointerDown() {
|
|
33347
33329
|
setSelectedValue(option.value);
|
|
33348
33330
|
setSelectedOption(option.option);
|
|
33349
33331
|
setOpened(false);
|
|
@@ -33449,10 +33431,7 @@ var CraftBook = function CraftBook(_ref) {
|
|
|
33449
33431
|
imgScale: 3,
|
|
33450
33432
|
grayScale: !option.canCraft
|
|
33451
33433
|
})), React.createElement("div", null, React.createElement("div", {
|
|
33452
|
-
|
|
33453
|
-
return handleClick(option.key);
|
|
33454
|
-
},
|
|
33455
|
-
onTouchStart: function onTouchStart() {
|
|
33434
|
+
onPointerDown: function onPointerDown() {
|
|
33456
33435
|
return handleClick(option.key);
|
|
33457
33436
|
}
|
|
33458
33437
|
}, React.createElement("input", {
|
|
@@ -33466,15 +33445,9 @@ var CraftBook = function CraftBook(_ref) {
|
|
|
33466
33445
|
return handleClick(option.key);
|
|
33467
33446
|
}
|
|
33468
33447
|
}), React.createElement("label", {
|
|
33469
|
-
|
|
33448
|
+
onPointerDown: function onPointerDown() {
|
|
33470
33449
|
handleClick(option.key);
|
|
33471
33450
|
},
|
|
33472
|
-
onTouchStart: function onTouchStart() {
|
|
33473
|
-
setIsShown({
|
|
33474
|
-
show: true,
|
|
33475
|
-
index: index
|
|
33476
|
-
});
|
|
33477
|
-
},
|
|
33478
33451
|
style: {
|
|
33479
33452
|
display: 'flex',
|
|
33480
33453
|
alignItems: 'center'
|
|
@@ -33503,14 +33476,10 @@ var CraftBook = function CraftBook(_ref) {
|
|
|
33503
33476
|
})));
|
|
33504
33477
|
})), React.createElement(ButtonWrapper, null, React.createElement(Button, {
|
|
33505
33478
|
buttonType: ButtonTypes.RPGUIButton,
|
|
33506
|
-
|
|
33507
|
-
onTouchStart: onClose
|
|
33479
|
+
onPointerDown: onClose
|
|
33508
33480
|
}, "Cancel"), React.createElement(Button, {
|
|
33509
33481
|
buttonType: ButtonTypes.RPGUIButton,
|
|
33510
|
-
|
|
33511
|
-
return onCraftItem(craftItem);
|
|
33512
|
-
},
|
|
33513
|
-
onTouchStart: function onTouchStart() {
|
|
33482
|
+
onPointerDown: function onPointerDown() {
|
|
33514
33483
|
return onCraftItem(craftItem);
|
|
33515
33484
|
}
|
|
33516
33485
|
}, "Craft")));
|
|
@@ -33601,7 +33570,7 @@ var RelativeListMenu = function RelativeListMenu(_ref) {
|
|
|
33601
33570
|
}, options.map(function (params, index) {
|
|
33602
33571
|
return React.createElement(ListElement, {
|
|
33603
33572
|
key: (params == null ? void 0 : params.id) || index,
|
|
33604
|
-
|
|
33573
|
+
onPointerDown: function onPointerDown() {
|
|
33605
33574
|
onSelected(params == null ? void 0 : params.id);
|
|
33606
33575
|
}
|
|
33607
33576
|
}, (params == null ? void 0 : params.text) || 'No text');
|
|
@@ -33747,7 +33716,7 @@ var ItemSlot = /*#__PURE__*/observer(function (_ref) {
|
|
|
33747
33716
|
slotSpriteMask = _ref.slotSpriteMask,
|
|
33748
33717
|
_onMouseOver = _ref.onMouseOver,
|
|
33749
33718
|
_onMouseOut = _ref.onMouseOut,
|
|
33750
|
-
|
|
33719
|
+
onPointerDown = _ref.onPointerDown,
|
|
33751
33720
|
_onSelected = _ref.onSelected,
|
|
33752
33721
|
atlasJSON = _ref.atlasJSON,
|
|
33753
33722
|
atlasIMG = _ref.atlasIMG,
|
|
@@ -33760,8 +33729,7 @@ var ItemSlot = /*#__PURE__*/observer(function (_ref) {
|
|
|
33760
33729
|
checkIfItemCanBeMoved = _ref.checkIfItemCanBeMoved,
|
|
33761
33730
|
openQuantitySelector = _ref.openQuantitySelector,
|
|
33762
33731
|
checkIfItemShouldDragEnd = _ref.checkIfItemShouldDragEnd,
|
|
33763
|
-
dragScale = _ref.dragScale
|
|
33764
|
-
isSelectingShortcut = _ref.isSelectingShortcut;
|
|
33732
|
+
dragScale = _ref.dragScale;
|
|
33765
33733
|
var _useState = useState(false),
|
|
33766
33734
|
isTooltipVisible = _useState[0],
|
|
33767
33735
|
setTooltipVisible = _useState[1];
|
|
@@ -33794,7 +33762,6 @@ var ItemSlot = /*#__PURE__*/observer(function (_ref) {
|
|
|
33794
33762
|
});
|
|
33795
33763
|
setIsFocused(false);
|
|
33796
33764
|
if (item) {
|
|
33797
|
-
console.log(item);
|
|
33798
33765
|
setContextActions(generateContextMenu(item, containerType));
|
|
33799
33766
|
}
|
|
33800
33767
|
}, [item]);
|
|
@@ -33926,14 +33893,12 @@ var ItemSlot = /*#__PURE__*/observer(function (_ref) {
|
|
|
33926
33893
|
bubbles: true
|
|
33927
33894
|
});
|
|
33928
33895
|
(_document$elementFrom = document.elementFromPoint(clientX, clientY)) == null ? void 0 : _document$elementFrom.dispatchEvent(simulatedEvent);
|
|
33929
|
-
}
|
|
33930
|
-
isSelectingShortcut: isSelectingShortcut && ((item == null ? void 0 : item.type) === ItemType.Consumable || (item == null ? void 0 : item.type) === ItemType.Tool)
|
|
33896
|
+
}
|
|
33931
33897
|
}, React.createElement(Draggable, {
|
|
33932
|
-
axis: isSelectingShortcut ? 'none' : 'both',
|
|
33933
33898
|
defaultClassName: item ? 'draggable' : 'empty-slot',
|
|
33934
33899
|
scale: dragScale,
|
|
33935
33900
|
onStop: function onStop(e, data) {
|
|
33936
|
-
if (wasDragged && item
|
|
33901
|
+
if (wasDragged && item) {
|
|
33937
33902
|
var _e$target;
|
|
33938
33903
|
//@ts-ignore
|
|
33939
33904
|
var classes = Array.from((_e$target = e.target) == null ? void 0 : _e$target.classList);
|
|
@@ -33971,12 +33936,12 @@ var ItemSlot = /*#__PURE__*/observer(function (_ref) {
|
|
|
33971
33936
|
}
|
|
33972
33937
|
}, 100);
|
|
33973
33938
|
} else if (item) {
|
|
33974
|
-
if (!isContextMenuDisabled
|
|
33975
|
-
|
|
33939
|
+
if (!isContextMenuDisabled) setIsContextMenuVisible(!isContextMenuVisible);
|
|
33940
|
+
onPointerDown(item.type, containerType, item);
|
|
33976
33941
|
}
|
|
33977
33942
|
},
|
|
33978
33943
|
onStart: function onStart() {
|
|
33979
|
-
if (!item
|
|
33944
|
+
if (!item) {
|
|
33980
33945
|
return;
|
|
33981
33946
|
}
|
|
33982
33947
|
if (onDragStart) {
|
|
@@ -34038,7 +34003,7 @@ var rarityColor = function rarityColor(item) {
|
|
|
34038
34003
|
var Container$a = /*#__PURE__*/styled.div.withConfig({
|
|
34039
34004
|
displayName: "ItemSlot__Container",
|
|
34040
34005
|
componentId: "sc-l2j5ef-0"
|
|
34041
|
-
})(["margin:0.1rem;.sprite-from-atlas-img{position:relative;top:1.5rem;left:1.5rem;border-color:", ";box-shadow:", " inset,", ";}position:relative
|
|
34006
|
+
})(["margin:0.1rem;.sprite-from-atlas-img{position:relative;top:1.5rem;left:1.5rem;border-color:", ";box-shadow:", " inset,", ";}position:relative;"], function (_ref2) {
|
|
34042
34007
|
var item = _ref2.item;
|
|
34043
34008
|
return rarityColor(item);
|
|
34044
34009
|
}, function (_ref3) {
|
|
@@ -34047,9 +34012,6 @@ var Container$a = /*#__PURE__*/styled.div.withConfig({
|
|
|
34047
34012
|
}, function (_ref4) {
|
|
34048
34013
|
var item = _ref4.item;
|
|
34049
34014
|
return "0 0 4px 3px " + rarityColor(item);
|
|
34050
|
-
}, function (_ref5) {
|
|
34051
|
-
var isSelectingShortcut = _ref5.isSelectingShortcut;
|
|
34052
|
-
return isSelectingShortcut ? 'bg-color-change 1s infinite' : 'none';
|
|
34053
34015
|
});
|
|
34054
34016
|
var ItemContainer = /*#__PURE__*/styled.div.withConfig({
|
|
34055
34017
|
displayName: "ItemSlot__ItemContainer",
|
|
@@ -34110,7 +34072,7 @@ var EquipmentSet = function EquipmentSet(_ref) {
|
|
|
34110
34072
|
onMouseOver: function onMouseOver(event, slotIndex, item) {
|
|
34111
34073
|
if (_onMouseOver) _onMouseOver(event, slotIndex, item);
|
|
34112
34074
|
},
|
|
34113
|
-
|
|
34075
|
+
onPointerDown: function onPointerDown(itemType, ContainerType) {
|
|
34114
34076
|
if (onItemClick) onItemClick(itemType, item, ContainerType);
|
|
34115
34077
|
},
|
|
34116
34078
|
onSelected: function onSelected(optionId) {
|
|
@@ -34160,6 +34122,546 @@ var EquipmentColumn = /*#__PURE__*/styled.div.withConfig({
|
|
|
34160
34122
|
componentId: "sc-1wuddg2-1"
|
|
34161
34123
|
})(["display:flex;justify-content:center;flex-wrap:wrap;flex-direction:column;touch-action:none;"]);
|
|
34162
34124
|
|
|
34125
|
+
var IS_MOBILE_OR_TABLET = /*#__PURE__*/isMobileOrTablet();
|
|
34126
|
+
|
|
34127
|
+
var chunkString = function chunkString(str, length) {
|
|
34128
|
+
return str.match(new RegExp('.{1,' + length + '}', 'g'));
|
|
34129
|
+
};
|
|
34130
|
+
|
|
34131
|
+
var DynamicText = function DynamicText(_ref) {
|
|
34132
|
+
var text = _ref.text,
|
|
34133
|
+
onFinish = _ref.onFinish,
|
|
34134
|
+
onStart = _ref.onStart;
|
|
34135
|
+
var _useState = useState(''),
|
|
34136
|
+
textState = _useState[0],
|
|
34137
|
+
setTextState = _useState[1];
|
|
34138
|
+
useEffect(function () {
|
|
34139
|
+
var i = 0;
|
|
34140
|
+
var interval = setInterval(function () {
|
|
34141
|
+
// on every interval, show one more character
|
|
34142
|
+
if (i === 0) {
|
|
34143
|
+
if (onStart) {
|
|
34144
|
+
onStart();
|
|
34145
|
+
}
|
|
34146
|
+
}
|
|
34147
|
+
if (i < text.length) {
|
|
34148
|
+
setTextState(text.substring(0, i + 1));
|
|
34149
|
+
i++;
|
|
34150
|
+
} else {
|
|
34151
|
+
clearInterval(interval);
|
|
34152
|
+
if (onFinish) {
|
|
34153
|
+
onFinish();
|
|
34154
|
+
}
|
|
34155
|
+
}
|
|
34156
|
+
}, 50);
|
|
34157
|
+
return function () {
|
|
34158
|
+
clearInterval(interval);
|
|
34159
|
+
};
|
|
34160
|
+
}, [text]);
|
|
34161
|
+
return React.createElement(TextContainer, null, textState);
|
|
34162
|
+
};
|
|
34163
|
+
var TextContainer = /*#__PURE__*/styled.p.withConfig({
|
|
34164
|
+
displayName: "DynamicText__TextContainer",
|
|
34165
|
+
componentId: "sc-1ggl9nd-0"
|
|
34166
|
+
})(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]);
|
|
34167
|
+
|
|
34168
|
+
var img$6 = '';
|
|
34169
|
+
|
|
34170
|
+
var img$7 = '';
|
|
34171
|
+
|
|
34172
|
+
var NPCDialogText = function NPCDialogText(_ref) {
|
|
34173
|
+
var text = _ref.text,
|
|
34174
|
+
onClose = _ref.onClose,
|
|
34175
|
+
onEndStep = _ref.onEndStep,
|
|
34176
|
+
onStartStep = _ref.onStartStep,
|
|
34177
|
+
type = _ref.type;
|
|
34178
|
+
var windowSize = useRef([window.innerWidth, window.innerHeight]);
|
|
34179
|
+
function maxCharacters(width) {
|
|
34180
|
+
// Set the font size to 16 pixels
|
|
34181
|
+
var fontSize = 11.2;
|
|
34182
|
+
// Calculate the number of characters that can fit in one line
|
|
34183
|
+
var charactersPerLine = Math.floor(width / 2 / fontSize);
|
|
34184
|
+
// Calculate the number of lines that can fit in the div
|
|
34185
|
+
var linesPerDiv = Math.floor(180 / fontSize);
|
|
34186
|
+
// Calculate the maximum number of characters that can fit in the div
|
|
34187
|
+
var maxCharacters = charactersPerLine * linesPerDiv;
|
|
34188
|
+
// Return the maximum number of characters
|
|
34189
|
+
return Math.round(maxCharacters / 5);
|
|
34190
|
+
}
|
|
34191
|
+
var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
|
|
34192
|
+
var _useState = useState(0),
|
|
34193
|
+
chunkIndex = _useState[0],
|
|
34194
|
+
setChunkIndex = _useState[1];
|
|
34195
|
+
var onHandleSpacePress = function onHandleSpacePress(event) {
|
|
34196
|
+
if (event.code === 'Space') {
|
|
34197
|
+
goToNextStep();
|
|
34198
|
+
}
|
|
34199
|
+
};
|
|
34200
|
+
var goToNextStep = function goToNextStep() {
|
|
34201
|
+
var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
|
|
34202
|
+
if (hasNextChunk) {
|
|
34203
|
+
setChunkIndex(function (prev) {
|
|
34204
|
+
return prev + 1;
|
|
34205
|
+
});
|
|
34206
|
+
} else {
|
|
34207
|
+
// if there's no more text chunks, close the dialog
|
|
34208
|
+
onClose();
|
|
34209
|
+
}
|
|
34210
|
+
};
|
|
34211
|
+
useEffect(function () {
|
|
34212
|
+
document.addEventListener('keydown', onHandleSpacePress);
|
|
34213
|
+
return function () {
|
|
34214
|
+
return document.removeEventListener('keydown', onHandleSpacePress);
|
|
34215
|
+
};
|
|
34216
|
+
}, [chunkIndex]);
|
|
34217
|
+
var _useState2 = useState(false),
|
|
34218
|
+
showGoNextIndicator = _useState2[0],
|
|
34219
|
+
setShowGoNextIndicator = _useState2[1];
|
|
34220
|
+
return React.createElement(Container$b, null, React.createElement(DynamicText, {
|
|
34221
|
+
text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
|
|
34222
|
+
onFinish: function onFinish() {
|
|
34223
|
+
setShowGoNextIndicator(true);
|
|
34224
|
+
onEndStep && onEndStep();
|
|
34225
|
+
},
|
|
34226
|
+
onStart: function onStart() {
|
|
34227
|
+
setShowGoNextIndicator(false);
|
|
34228
|
+
onStartStep && onStartStep();
|
|
34229
|
+
}
|
|
34230
|
+
}), showGoNextIndicator && React.createElement(PressSpaceIndicator, {
|
|
34231
|
+
right: type === NPCDialogType.TextOnly ? '1rem' : '10.5rem',
|
|
34232
|
+
src: IS_MOBILE_OR_TABLET ? img$6 : img$7,
|
|
34233
|
+
onPointerDown: function onPointerDown() {
|
|
34234
|
+
goToNextStep();
|
|
34235
|
+
}
|
|
34236
|
+
}));
|
|
34237
|
+
};
|
|
34238
|
+
var Container$b = /*#__PURE__*/styled.div.withConfig({
|
|
34239
|
+
displayName: "NPCDialogText__Container",
|
|
34240
|
+
componentId: "sc-1cxkdh9-0"
|
|
34241
|
+
})([""]);
|
|
34242
|
+
var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
|
|
34243
|
+
displayName: "NPCDialogText__PressSpaceIndicator",
|
|
34244
|
+
componentId: "sc-1cxkdh9-1"
|
|
34245
|
+
})(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
|
|
34246
|
+
var right = _ref2.right;
|
|
34247
|
+
return right;
|
|
34248
|
+
});
|
|
34249
|
+
|
|
34250
|
+
//@ts-ignore
|
|
34251
|
+
var useEventListener = function useEventListener(type, handler, el) {
|
|
34252
|
+
if (el === void 0) {
|
|
34253
|
+
el = window;
|
|
34254
|
+
}
|
|
34255
|
+
var savedHandler = React.useRef();
|
|
34256
|
+
React.useEffect(function () {
|
|
34257
|
+
savedHandler.current = handler;
|
|
34258
|
+
}, [handler]);
|
|
34259
|
+
React.useEffect(function () {
|
|
34260
|
+
//@ts-ignore
|
|
34261
|
+
var listener = function listener(e) {
|
|
34262
|
+
return savedHandler.current(e);
|
|
34263
|
+
};
|
|
34264
|
+
el.addEventListener(type, listener);
|
|
34265
|
+
return function () {
|
|
34266
|
+
el.removeEventListener(type, listener);
|
|
34267
|
+
};
|
|
34268
|
+
}, [type, el]);
|
|
34269
|
+
};
|
|
34270
|
+
|
|
34271
|
+
var QuestionDialog = function QuestionDialog(_ref) {
|
|
34272
|
+
var questions = _ref.questions,
|
|
34273
|
+
answers = _ref.answers,
|
|
34274
|
+
onClose = _ref.onClose;
|
|
34275
|
+
var _useState = useState(questions[0]),
|
|
34276
|
+
currentQuestion = _useState[0],
|
|
34277
|
+
setCurrentQuestion = _useState[1];
|
|
34278
|
+
var _useState2 = useState(false),
|
|
34279
|
+
canShowAnswers = _useState2[0],
|
|
34280
|
+
setCanShowAnswers = _useState2[1];
|
|
34281
|
+
var onGetFirstAnswer = function onGetFirstAnswer() {
|
|
34282
|
+
if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {
|
|
34283
|
+
return null;
|
|
34284
|
+
}
|
|
34285
|
+
var firstAnswerId = currentQuestion.answerIds[0];
|
|
34286
|
+
return answers.find(function (answer) {
|
|
34287
|
+
return answer.id === firstAnswerId;
|
|
34288
|
+
});
|
|
34289
|
+
};
|
|
34290
|
+
var _useState3 = useState(onGetFirstAnswer()),
|
|
34291
|
+
currentAnswer = _useState3[0],
|
|
34292
|
+
setCurrentAnswer = _useState3[1];
|
|
34293
|
+
useEffect(function () {
|
|
34294
|
+
setCurrentAnswer(onGetFirstAnswer());
|
|
34295
|
+
}, [currentQuestion]);
|
|
34296
|
+
var onGetAnswers = function onGetAnswers(answerIds) {
|
|
34297
|
+
return answerIds.map(function (answerId) {
|
|
34298
|
+
return answers.find(function (answer) {
|
|
34299
|
+
return answer.id === answerId;
|
|
34300
|
+
});
|
|
34301
|
+
});
|
|
34302
|
+
};
|
|
34303
|
+
var onKeyPress = function onKeyPress(e) {
|
|
34304
|
+
switch (e.key) {
|
|
34305
|
+
case 'ArrowDown':
|
|
34306
|
+
// select next answer, if any.
|
|
34307
|
+
// if no next answer, select first answer
|
|
34308
|
+
// const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(
|
|
34309
|
+
// (answer) => answer?.id === currentAnswer!.id + 1
|
|
34310
|
+
// );
|
|
34311
|
+
var nextAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
|
|
34312
|
+
return (answer == null ? void 0 : answer.id) === currentAnswer.id + 1;
|
|
34313
|
+
});
|
|
34314
|
+
var nextAnswerID = currentQuestion.answerIds[nextAnswerIndex];
|
|
34315
|
+
var nextAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
|
|
34316
|
+
return (answer == null ? void 0 : answer.id) === nextAnswerID;
|
|
34317
|
+
});
|
|
34318
|
+
setCurrentAnswer(nextAnswer || onGetFirstAnswer());
|
|
34319
|
+
break;
|
|
34320
|
+
case 'ArrowUp':
|
|
34321
|
+
// select previous answer, if any.
|
|
34322
|
+
// if no previous answer, select last answer
|
|
34323
|
+
var previousAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
|
|
34324
|
+
return (answer == null ? void 0 : answer.id) === currentAnswer.id - 1;
|
|
34325
|
+
});
|
|
34326
|
+
var previousAnswerID = currentQuestion.answerIds && currentQuestion.answerIds[previousAnswerIndex];
|
|
34327
|
+
var previousAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
|
|
34328
|
+
return (answer == null ? void 0 : answer.id) === previousAnswerID;
|
|
34329
|
+
});
|
|
34330
|
+
if (previousAnswer) {
|
|
34331
|
+
setCurrentAnswer(previousAnswer);
|
|
34332
|
+
} else {
|
|
34333
|
+
setCurrentAnswer(onGetAnswers(currentQuestion.answerIds).pop());
|
|
34334
|
+
}
|
|
34335
|
+
break;
|
|
34336
|
+
case 'Enter':
|
|
34337
|
+
setCanShowAnswers(false);
|
|
34338
|
+
if (!(currentAnswer != null && currentAnswer.nextQuestionId)) {
|
|
34339
|
+
onClose();
|
|
34340
|
+
return;
|
|
34341
|
+
} else {
|
|
34342
|
+
setCurrentQuestion(questions.find(function (question) {
|
|
34343
|
+
return question.id === currentAnswer.nextQuestionId;
|
|
34344
|
+
}));
|
|
34345
|
+
}
|
|
34346
|
+
break;
|
|
34347
|
+
}
|
|
34348
|
+
};
|
|
34349
|
+
useEventListener('keydown', onKeyPress);
|
|
34350
|
+
var onAnswerClick = function onAnswerClick(answer) {
|
|
34351
|
+
setCanShowAnswers(false);
|
|
34352
|
+
if (answer.nextQuestionId) {
|
|
34353
|
+
// if there is a next question, go to it
|
|
34354
|
+
setCurrentQuestion(questions.find(function (question) {
|
|
34355
|
+
return question.id === answer.nextQuestionId;
|
|
34356
|
+
}));
|
|
34357
|
+
} else {
|
|
34358
|
+
// else, finish dialog!
|
|
34359
|
+
onClose();
|
|
34360
|
+
}
|
|
34361
|
+
};
|
|
34362
|
+
var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
|
|
34363
|
+
var answerIds = currentQuestion.answerIds;
|
|
34364
|
+
if (!answerIds) {
|
|
34365
|
+
return null;
|
|
34366
|
+
}
|
|
34367
|
+
var answers = onGetAnswers(answerIds);
|
|
34368
|
+
if (!answers) {
|
|
34369
|
+
return null;
|
|
34370
|
+
}
|
|
34371
|
+
return answers.map(function (answer) {
|
|
34372
|
+
var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
|
|
34373
|
+
var selectedColor = isSelected ? 'yellow' : 'white';
|
|
34374
|
+
if (answer) {
|
|
34375
|
+
return React.createElement(AnswerRow, {
|
|
34376
|
+
key: "answer_" + answer.id
|
|
34377
|
+
}, React.createElement(AnswerSelectedIcon, {
|
|
34378
|
+
color: selectedColor
|
|
34379
|
+
}, isSelected ? 'X' : null), React.createElement(Answer, {
|
|
34380
|
+
key: answer.id,
|
|
34381
|
+
onPointerDown: function onPointerDown() {
|
|
34382
|
+
return onAnswerClick(answer);
|
|
34383
|
+
},
|
|
34384
|
+
color: selectedColor
|
|
34385
|
+
}, answer.text));
|
|
34386
|
+
}
|
|
34387
|
+
return null;
|
|
34388
|
+
});
|
|
34389
|
+
};
|
|
34390
|
+
return React.createElement(Container$c, null, React.createElement(QuestionContainer, null, React.createElement(DynamicText, {
|
|
34391
|
+
text: currentQuestion.text,
|
|
34392
|
+
onStart: function onStart() {
|
|
34393
|
+
return setCanShowAnswers(false);
|
|
34394
|
+
},
|
|
34395
|
+
onFinish: function onFinish() {
|
|
34396
|
+
return setCanShowAnswers(true);
|
|
34397
|
+
}
|
|
34398
|
+
})), canShowAnswers && React.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
|
|
34399
|
+
};
|
|
34400
|
+
var Container$c = /*#__PURE__*/styled.div.withConfig({
|
|
34401
|
+
displayName: "QuestionDialog__Container",
|
|
34402
|
+
componentId: "sc-bxc5u0-0"
|
|
34403
|
+
})(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
|
|
34404
|
+
var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
|
|
34405
|
+
displayName: "QuestionDialog__QuestionContainer",
|
|
34406
|
+
componentId: "sc-bxc5u0-1"
|
|
34407
|
+
})(["flex:100%;width:100%;"]);
|
|
34408
|
+
var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
|
|
34409
|
+
displayName: "QuestionDialog__AnswersContainer",
|
|
34410
|
+
componentId: "sc-bxc5u0-2"
|
|
34411
|
+
})(["flex:100%;"]);
|
|
34412
|
+
var Answer = /*#__PURE__*/styled.p.withConfig({
|
|
34413
|
+
displayName: "QuestionDialog__Answer",
|
|
34414
|
+
componentId: "sc-bxc5u0-3"
|
|
34415
|
+
})(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
|
|
34416
|
+
return props.color;
|
|
34417
|
+
});
|
|
34418
|
+
var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
|
|
34419
|
+
displayName: "QuestionDialog__AnswerSelectedIcon",
|
|
34420
|
+
componentId: "sc-bxc5u0-4"
|
|
34421
|
+
})(["flex:5% 0 0;color:", " !important;"], function (props) {
|
|
34422
|
+
return props.color;
|
|
34423
|
+
});
|
|
34424
|
+
var AnswerRow = /*#__PURE__*/styled.div.withConfig({
|
|
34425
|
+
displayName: "QuestionDialog__AnswerRow",
|
|
34426
|
+
componentId: "sc-bxc5u0-5"
|
|
34427
|
+
})(["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;}"]);
|
|
34428
|
+
|
|
34429
|
+
var img$8 = '';
|
|
34430
|
+
|
|
34431
|
+
var NPCDialogType;
|
|
34432
|
+
(function (NPCDialogType) {
|
|
34433
|
+
NPCDialogType["TextOnly"] = "TextOnly";
|
|
34434
|
+
NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
|
|
34435
|
+
})(NPCDialogType || (NPCDialogType = {}));
|
|
34436
|
+
var NPCDialog = function NPCDialog(_ref) {
|
|
34437
|
+
var text = _ref.text,
|
|
34438
|
+
type = _ref.type,
|
|
34439
|
+
_onClose = _ref.onClose,
|
|
34440
|
+
imagePath = _ref.imagePath,
|
|
34441
|
+
_ref$isQuestionDialog = _ref.isQuestionDialog,
|
|
34442
|
+
isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
|
|
34443
|
+
questions = _ref.questions,
|
|
34444
|
+
answers = _ref.answers;
|
|
34445
|
+
return React.createElement(RPGUIContainer, {
|
|
34446
|
+
type: RPGUIContainerTypes.FramedGold,
|
|
34447
|
+
width: isQuestionDialog ? '600px' : '80%',
|
|
34448
|
+
height: '180px'
|
|
34449
|
+
}, isQuestionDialog && questions && answers ? React.createElement(React.Fragment, null, React.createElement(TextContainer$1, {
|
|
34450
|
+
flex: type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'
|
|
34451
|
+
}, React.createElement(QuestionDialog, {
|
|
34452
|
+
questions: questions,
|
|
34453
|
+
answers: answers,
|
|
34454
|
+
onClose: function onClose() {
|
|
34455
|
+
if (_onClose) {
|
|
34456
|
+
_onClose();
|
|
34457
|
+
}
|
|
34458
|
+
}
|
|
34459
|
+
})), type === NPCDialogType.TextAndThumbnail && React.createElement(ThumbnailContainer, null, React.createElement(NPCThumbnail, {
|
|
34460
|
+
src: imagePath || img$8
|
|
34461
|
+
}))) : React.createElement(React.Fragment, null, React.createElement(Container$d, null, React.createElement(TextContainer$1, {
|
|
34462
|
+
flex: type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'
|
|
34463
|
+
}, React.createElement(NPCDialogText, {
|
|
34464
|
+
type: type,
|
|
34465
|
+
text: text || 'No text provided.',
|
|
34466
|
+
onClose: function onClose() {
|
|
34467
|
+
if (_onClose) {
|
|
34468
|
+
_onClose();
|
|
34469
|
+
}
|
|
34470
|
+
}
|
|
34471
|
+
})), type === NPCDialogType.TextAndThumbnail && React.createElement(ThumbnailContainer, null, React.createElement(NPCThumbnail, {
|
|
34472
|
+
src: imagePath || img$8
|
|
34473
|
+
})))));
|
|
34474
|
+
};
|
|
34475
|
+
var Container$d = /*#__PURE__*/styled.div.withConfig({
|
|
34476
|
+
displayName: "NPCDialog__Container",
|
|
34477
|
+
componentId: "sc-1b4aw74-0"
|
|
34478
|
+
})(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
|
|
34479
|
+
var TextContainer$1 = /*#__PURE__*/styled.div.withConfig({
|
|
34480
|
+
displayName: "NPCDialog__TextContainer",
|
|
34481
|
+
componentId: "sc-1b4aw74-1"
|
|
34482
|
+
})(["flex:", " 0 0;width:355px;"], function (_ref2) {
|
|
34483
|
+
var flex = _ref2.flex;
|
|
34484
|
+
return flex;
|
|
34485
|
+
});
|
|
34486
|
+
var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
|
|
34487
|
+
displayName: "NPCDialog__ThumbnailContainer",
|
|
34488
|
+
componentId: "sc-1b4aw74-2"
|
|
34489
|
+
})(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
|
|
34490
|
+
var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
|
|
34491
|
+
displayName: "NPCDialog__NPCThumbnail",
|
|
34492
|
+
componentId: "sc-1b4aw74-3"
|
|
34493
|
+
})(["image-rendering:pixelated;height:128px;width:128px;"]);
|
|
34494
|
+
|
|
34495
|
+
var ImgSide;
|
|
34496
|
+
(function (ImgSide) {
|
|
34497
|
+
ImgSide["right"] = "right";
|
|
34498
|
+
ImgSide["left"] = "left";
|
|
34499
|
+
})(ImgSide || (ImgSide = {}));
|
|
34500
|
+
var NPCMultiDialog = function NPCMultiDialog(_ref) {
|
|
34501
|
+
var _textAndTypeArray$sli;
|
|
34502
|
+
var _onClose = _ref.onClose,
|
|
34503
|
+
textAndTypeArray = _ref.textAndTypeArray;
|
|
34504
|
+
var _useState = useState(false),
|
|
34505
|
+
showGoNextIndicator = _useState[0],
|
|
34506
|
+
setShowGoNextIndicator = _useState[1];
|
|
34507
|
+
var _useState2 = useState(0),
|
|
34508
|
+
slide = _useState2[0],
|
|
34509
|
+
setSlide = _useState2[1];
|
|
34510
|
+
var onHandleSpacePress = function onHandleSpacePress(event) {
|
|
34511
|
+
if (event.code === 'Space') {
|
|
34512
|
+
if (slide < (textAndTypeArray == null ? void 0 : textAndTypeArray.length) - 1) {
|
|
34513
|
+
setSlide(function (prev) {
|
|
34514
|
+
return prev + 1;
|
|
34515
|
+
});
|
|
34516
|
+
} else {
|
|
34517
|
+
// if there's no more text chunks, close the dialog
|
|
34518
|
+
_onClose();
|
|
34519
|
+
}
|
|
34520
|
+
}
|
|
34521
|
+
};
|
|
34522
|
+
useEffect(function () {
|
|
34523
|
+
document.addEventListener('keydown', onHandleSpacePress);
|
|
34524
|
+
return function () {
|
|
34525
|
+
return document.removeEventListener('keydown', onHandleSpacePress);
|
|
34526
|
+
};
|
|
34527
|
+
}, [slide]);
|
|
34528
|
+
return React.createElement(RPGUIContainer, {
|
|
34529
|
+
type: RPGUIContainerTypes.FramedGold,
|
|
34530
|
+
width: '50%',
|
|
34531
|
+
height: '180px'
|
|
34532
|
+
}, 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, {
|
|
34533
|
+
flex: '70%'
|
|
34534
|
+
}, React.createElement(NPCDialogText, {
|
|
34535
|
+
onStartStep: function onStartStep() {
|
|
34536
|
+
return setShowGoNextIndicator(false);
|
|
34537
|
+
},
|
|
34538
|
+
onEndStep: function onEndStep() {
|
|
34539
|
+
return setShowGoNextIndicator(true);
|
|
34540
|
+
},
|
|
34541
|
+
text: textAndTypeArray[slide].text || 'No text provided.',
|
|
34542
|
+
onClose: function onClose() {
|
|
34543
|
+
if (_onClose) {
|
|
34544
|
+
_onClose();
|
|
34545
|
+
}
|
|
34546
|
+
}
|
|
34547
|
+
})), React.createElement(ThumbnailContainer$1, null, React.createElement(NPCThumbnail$1, {
|
|
34548
|
+
src: textAndTypeArray[slide].imagePath || img$8
|
|
34549
|
+
})), showGoNextIndicator && React.createElement(PressSpaceIndicator$1, {
|
|
34550
|
+
right: '10.5rem',
|
|
34551
|
+
src: img$7
|
|
34552
|
+
})), textAndTypeArray[slide].imageSide === 'left' && React.createElement(React.Fragment, null, React.createElement(ThumbnailContainer$1, null, React.createElement(NPCThumbnail$1, {
|
|
34553
|
+
src: textAndTypeArray[slide].imagePath || img$8
|
|
34554
|
+
})), React.createElement(TextContainer$2, {
|
|
34555
|
+
flex: '70%'
|
|
34556
|
+
}, React.createElement(NPCDialogText, {
|
|
34557
|
+
onStartStep: function onStartStep() {
|
|
34558
|
+
return setShowGoNextIndicator(false);
|
|
34559
|
+
},
|
|
34560
|
+
onEndStep: function onEndStep() {
|
|
34561
|
+
return setShowGoNextIndicator(true);
|
|
34562
|
+
},
|
|
34563
|
+
text: textAndTypeArray[slide].text || 'No text provided.',
|
|
34564
|
+
onClose: function onClose() {
|
|
34565
|
+
if (_onClose) {
|
|
34566
|
+
_onClose();
|
|
34567
|
+
}
|
|
34568
|
+
}
|
|
34569
|
+
})), showGoNextIndicator && React.createElement(PressSpaceIndicator$1, {
|
|
34570
|
+
right: '1rem',
|
|
34571
|
+
src: img$7
|
|
34572
|
+
}))), ")"));
|
|
34573
|
+
};
|
|
34574
|
+
var Container$e = /*#__PURE__*/styled.div.withConfig({
|
|
34575
|
+
displayName: "NPCMultiDialog__Container",
|
|
34576
|
+
componentId: "sc-rvu5wg-0"
|
|
34577
|
+
})(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
|
|
34578
|
+
var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
|
|
34579
|
+
displayName: "NPCMultiDialog__TextContainer",
|
|
34580
|
+
componentId: "sc-rvu5wg-1"
|
|
34581
|
+
})(["flex:", " 0 0;width:355px;"], function (_ref2) {
|
|
34582
|
+
var flex = _ref2.flex;
|
|
34583
|
+
return flex;
|
|
34584
|
+
});
|
|
34585
|
+
var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
|
|
34586
|
+
displayName: "NPCMultiDialog__ThumbnailContainer",
|
|
34587
|
+
componentId: "sc-rvu5wg-2"
|
|
34588
|
+
})(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
|
|
34589
|
+
var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
|
|
34590
|
+
displayName: "NPCMultiDialog__NPCThumbnail",
|
|
34591
|
+
componentId: "sc-rvu5wg-3"
|
|
34592
|
+
})(["image-rendering:pixelated;height:128px;width:128px;"]);
|
|
34593
|
+
var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
|
|
34594
|
+
displayName: "NPCMultiDialog__PressSpaceIndicator",
|
|
34595
|
+
componentId: "sc-rvu5wg-4"
|
|
34596
|
+
})(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref3) {
|
|
34597
|
+
var right = _ref3.right;
|
|
34598
|
+
return right;
|
|
34599
|
+
});
|
|
34600
|
+
|
|
34601
|
+
var HistoryDialog = function HistoryDialog(_ref) {
|
|
34602
|
+
var backgroundImgPath = _ref.backgroundImgPath,
|
|
34603
|
+
fullCoverBackground = _ref.fullCoverBackground,
|
|
34604
|
+
questions = _ref.questions,
|
|
34605
|
+
answers = _ref.answers,
|
|
34606
|
+
text = _ref.text,
|
|
34607
|
+
imagePath = _ref.imagePath,
|
|
34608
|
+
textAndTypeArray = _ref.textAndTypeArray,
|
|
34609
|
+
onClose = _ref.onClose;
|
|
34610
|
+
var _useState = useState(0),
|
|
34611
|
+
img = _useState[0],
|
|
34612
|
+
setImage = _useState[1];
|
|
34613
|
+
var onHandleSpacePress = function onHandleSpacePress(event) {
|
|
34614
|
+
if (event.code === 'Space') {
|
|
34615
|
+
if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
|
|
34616
|
+
setImage(function (prev) {
|
|
34617
|
+
return prev + 1;
|
|
34618
|
+
});
|
|
34619
|
+
} else {
|
|
34620
|
+
// if there's no more text chunks, close the dialog
|
|
34621
|
+
onClose();
|
|
34622
|
+
}
|
|
34623
|
+
}
|
|
34624
|
+
};
|
|
34625
|
+
useEffect(function () {
|
|
34626
|
+
document.addEventListener('keydown', onHandleSpacePress);
|
|
34627
|
+
return function () {
|
|
34628
|
+
return document.removeEventListener('keydown', onHandleSpacePress);
|
|
34629
|
+
};
|
|
34630
|
+
}, [backgroundImgPath]);
|
|
34631
|
+
return React.createElement(BackgroundContainer, {
|
|
34632
|
+
imgPath: backgroundImgPath[img],
|
|
34633
|
+
fullImg: fullCoverBackground
|
|
34634
|
+
}, React.createElement(DialogContainer, null, textAndTypeArray ? React.createElement(NPCMultiDialog, {
|
|
34635
|
+
textAndTypeArray: textAndTypeArray,
|
|
34636
|
+
onClose: onClose
|
|
34637
|
+
}) : questions && answers ? React.createElement(QuestionDialog, {
|
|
34638
|
+
questions: questions,
|
|
34639
|
+
answers: answers,
|
|
34640
|
+
onClose: onClose
|
|
34641
|
+
}) : text && imagePath ? React.createElement(NPCDialog, {
|
|
34642
|
+
text: text,
|
|
34643
|
+
imagePath: imagePath,
|
|
34644
|
+
onClose: onClose,
|
|
34645
|
+
type: NPCDialogType.TextAndThumbnail
|
|
34646
|
+
}) : React.createElement(NPCDialog, {
|
|
34647
|
+
text: text,
|
|
34648
|
+
onClose: onClose,
|
|
34649
|
+
type: NPCDialogType.TextOnly
|
|
34650
|
+
})));
|
|
34651
|
+
};
|
|
34652
|
+
var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
|
|
34653
|
+
displayName: "HistoryDialog__BackgroundContainer",
|
|
34654
|
+
componentId: "sc-u6oe75-0"
|
|
34655
|
+
})(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
|
|
34656
|
+
return props.imgPath;
|
|
34657
|
+
}, function (props) {
|
|
34658
|
+
return props.imgPath ? 'cover' : 'auto';
|
|
34659
|
+
});
|
|
34660
|
+
var DialogContainer = /*#__PURE__*/styled.div.withConfig({
|
|
34661
|
+
displayName: "HistoryDialog__DialogContainer",
|
|
34662
|
+
componentId: "sc-u6oe75-1"
|
|
34663
|
+
})(["display:flex;justify-content:center;padding-top:200px;"]);
|
|
34664
|
+
|
|
34163
34665
|
var SlotsContainer = function SlotsContainer(_ref) {
|
|
34164
34666
|
var children = _ref.children,
|
|
34165
34667
|
title = _ref.title,
|
|
@@ -34175,8 +34677,8 @@ var SlotsContainer = function SlotsContainer(_ref) {
|
|
|
34175
34677
|
onClose();
|
|
34176
34678
|
}
|
|
34177
34679
|
},
|
|
34178
|
-
width: "
|
|
34179
|
-
cancelDrag: ".item-container-body
|
|
34680
|
+
width: "330px",
|
|
34681
|
+
cancelDrag: ".item-container-body",
|
|
34180
34682
|
onPositionChange: function onPositionChange(_ref2) {
|
|
34181
34683
|
var x = _ref2.x,
|
|
34182
34684
|
y = _ref2.y;
|
|
@@ -34286,8 +34788,7 @@ var ItemQuantitySelector = function ItemQuantitySelector(_ref) {
|
|
|
34286
34788
|
width: "25rem"
|
|
34287
34789
|
}, React.createElement(CloseButton$2, {
|
|
34288
34790
|
className: "container-close",
|
|
34289
|
-
|
|
34290
|
-
onTouchStart: onClose
|
|
34791
|
+
onPointerDown: onClose
|
|
34291
34792
|
}, "X"), React.createElement("h2", null, "Select quantity to move"), React.createElement(StyledForm, {
|
|
34292
34793
|
style: {
|
|
34293
34794
|
width: '100%'
|
|
@@ -34348,72 +34849,6 @@ var CloseButton$2 = /*#__PURE__*/styled.div.withConfig({
|
|
|
34348
34849
|
componentId: "sc-yfdtpn-3"
|
|
34349
34850
|
})(["position:absolute;top:3px;right:0px;color:white;z-index:22;font-size:0.8rem;"]);
|
|
34350
34851
|
|
|
34351
|
-
var ShortcutsSetter = function ShortcutsSetter(_ref) {
|
|
34352
|
-
var setSettingShortcutIndex = _ref.setSettingShortcutIndex,
|
|
34353
|
-
settingShortcutIndex = _ref.settingShortcutIndex,
|
|
34354
|
-
shortcuts = _ref.shortcuts,
|
|
34355
|
-
removeShortcut = _ref.removeShortcut,
|
|
34356
|
-
atlasJSON = _ref.atlasJSON,
|
|
34357
|
-
atlasIMG = _ref.atlasIMG;
|
|
34358
|
-
var getContent = function getContent(index) {
|
|
34359
|
-
var _shortcuts$index, _shortcuts$index3;
|
|
34360
|
-
if (((_shortcuts$index = shortcuts[index]) == null ? void 0 : _shortcuts$index.type) === ShortcutType.Item) {
|
|
34361
|
-
var _shortcuts$index2;
|
|
34362
|
-
var _payload = (_shortcuts$index2 = shortcuts[index]) == null ? void 0 : _shortcuts$index2.payload;
|
|
34363
|
-
if (!_payload) return null;
|
|
34364
|
-
return React.createElement(SpriteFromAtlas, {
|
|
34365
|
-
atlasIMG: atlasIMG,
|
|
34366
|
-
atlasJSON: atlasJSON,
|
|
34367
|
-
spriteKey: getItemTextureKeyPath({
|
|
34368
|
-
key: _payload.texturePath,
|
|
34369
|
-
texturePath: _payload.texturePath,
|
|
34370
|
-
stackQty: _payload.stackQty || 1
|
|
34371
|
-
}, atlasJSON),
|
|
34372
|
-
width: 32,
|
|
34373
|
-
height: 32,
|
|
34374
|
-
imgScale: 1.6,
|
|
34375
|
-
imgStyle: {
|
|
34376
|
-
left: '5px'
|
|
34377
|
-
}
|
|
34378
|
-
});
|
|
34379
|
-
}
|
|
34380
|
-
var payload = (_shortcuts$index3 = shortcuts[index]) == null ? void 0 : _shortcuts$index3.payload;
|
|
34381
|
-
return React.createElement("span", null, payload == null ? void 0 : payload.magicWords.split(' ').map(function (word) {
|
|
34382
|
-
return word[0];
|
|
34383
|
-
}));
|
|
34384
|
-
};
|
|
34385
|
-
return React.createElement(Container$b, null, React.createElement("p", null, "Shortcuts:"), React.createElement(List, {
|
|
34386
|
-
id: "shortcuts_list"
|
|
34387
|
-
}, Array.from({
|
|
34388
|
-
length: 6
|
|
34389
|
-
}).map(function (_, i) {
|
|
34390
|
-
return React.createElement(Shortcut, {
|
|
34391
|
-
key: i,
|
|
34392
|
-
onClick: function onClick() {
|
|
34393
|
-
removeShortcut(i);
|
|
34394
|
-
if (!shortcuts[i] || shortcuts[i].type === ShortcutType.None) setSettingShortcutIndex(i);
|
|
34395
|
-
},
|
|
34396
|
-
disabled: settingShortcutIndex !== -1 && settingShortcutIndex !== i,
|
|
34397
|
-
isBeingSet: settingShortcutIndex === i
|
|
34398
|
-
}, getContent(i));
|
|
34399
|
-
})));
|
|
34400
|
-
};
|
|
34401
|
-
var Container$b = /*#__PURE__*/styled.div.withConfig({
|
|
34402
|
-
displayName: "ShortcutsSetter__Container",
|
|
34403
|
-
componentId: "sc-xuouuf-0"
|
|
34404
|
-
})(["p{margin:0;margin-left:0.5rem;}"]);
|
|
34405
|
-
var Shortcut = /*#__PURE__*/styled.button.withConfig({
|
|
34406
|
-
displayName: "ShortcutsSetter__Shortcut",
|
|
34407
|
-
componentId: "sc-xuouuf-1"
|
|
34408
|
-
})(["width:2.6rem;height:2.6rem;background-color:", ";border:2px solid ", ";border-radius:50%;text-transform:uppercase;font-size:0.7rem;font-weight:bold;display:flex;align-items:center;justify-content:center;span{margin-top:4px;}&:hover,&:focus{background-color:", ";}&:active{background-color:", ";}&:disabled{opacity:0.5;}"], uiColors.lightGray, function (_ref2) {
|
|
34409
|
-
var isBeingSet = _ref2.isBeingSet;
|
|
34410
|
-
return isBeingSet ? uiColors.yellow : uiColors.darkGray;
|
|
34411
|
-
}, uiColors.darkGray, uiColors.gray);
|
|
34412
|
-
var List = /*#__PURE__*/styled.div.withConfig({
|
|
34413
|
-
displayName: "ShortcutsSetter__List",
|
|
34414
|
-
componentId: "sc-xuouuf-2"
|
|
34415
|
-
})(["width:100%;display:flex;align-items:center;gap:0.5rem;padding-bottom:0.5rem;padding-left:0.5rem;box-sizing:border-box;margin:0 !important;"]);
|
|
34416
|
-
|
|
34417
34852
|
var ItemContainer$1 = function ItemContainer(_ref) {
|
|
34418
34853
|
var itemContainer = _ref.itemContainer,
|
|
34419
34854
|
onClose = _ref.onClose,
|
|
@@ -34432,10 +34867,7 @@ var ItemContainer$1 = function ItemContainer(_ref) {
|
|
|
34432
34867
|
checkIfItemCanBeMoved = _ref.checkIfItemCanBeMoved,
|
|
34433
34868
|
initialPosition = _ref.initialPosition,
|
|
34434
34869
|
checkIfItemShouldDragEnd = _ref.checkIfItemShouldDragEnd,
|
|
34435
|
-
dragScale = _ref.dragScale
|
|
34436
|
-
shortcuts = _ref.shortcuts,
|
|
34437
|
-
setItemShortcut = _ref.setItemShortcut,
|
|
34438
|
-
removeShortcut = _ref.removeShortcut;
|
|
34870
|
+
dragScale = _ref.dragScale;
|
|
34439
34871
|
var _useState = useState({
|
|
34440
34872
|
isOpen: false,
|
|
34441
34873
|
maxQuantity: 1,
|
|
@@ -34443,9 +34875,6 @@ var ItemContainer$1 = function ItemContainer(_ref) {
|
|
|
34443
34875
|
}),
|
|
34444
34876
|
quantitySelect = _useState[0],
|
|
34445
34877
|
setQuantitySelect = _useState[1];
|
|
34446
|
-
var _useState2 = useState(-1),
|
|
34447
|
-
settingShortcutIndex = _useState2[0],
|
|
34448
|
-
setSettingShortcutIndex = _useState2[1];
|
|
34449
34878
|
var onRenderSlots = function onRenderSlots() {
|
|
34450
34879
|
var slots = [];
|
|
34451
34880
|
for (var i = 0; i < itemContainer.slotQty; i++) {
|
|
@@ -34459,13 +34888,8 @@ var ItemContainer$1 = function ItemContainer(_ref) {
|
|
|
34459
34888
|
onMouseOver: function onMouseOver(event, slotIndex, item) {
|
|
34460
34889
|
if (_onMouseOver) _onMouseOver(event, slotIndex, item);
|
|
34461
34890
|
},
|
|
34462
|
-
|
|
34463
|
-
if (
|
|
34464
|
-
setSettingShortcutIndex(-1);
|
|
34465
|
-
if (itemType === ItemType.Consumable || itemType === ItemType.Tool) {
|
|
34466
|
-
setItemShortcut == null ? void 0 : setItemShortcut(item.key, settingShortcutIndex);
|
|
34467
|
-
}
|
|
34468
|
-
} else if (onItemClick) onItemClick(item, itemType, containerType);
|
|
34891
|
+
onPointerDown: function onPointerDown(ItemType, ContainerType, item) {
|
|
34892
|
+
if (onItemClick) onItemClick(item, ItemType, ContainerType);
|
|
34469
34893
|
},
|
|
34470
34894
|
onSelected: function onSelected(optionId, item) {
|
|
34471
34895
|
if (_onSelected) _onSelected(optionId, item);
|
|
@@ -34493,8 +34917,7 @@ var ItemContainer$1 = function ItemContainer(_ref) {
|
|
|
34493
34917
|
if (_onOutsideDrop) _onOutsideDrop(item, position);
|
|
34494
34918
|
},
|
|
34495
34919
|
atlasIMG: atlasIMG,
|
|
34496
|
-
atlasJSON: atlasJSON
|
|
34497
|
-
isSelectingShortcut: settingShortcutIndex !== -1
|
|
34920
|
+
atlasJSON: atlasJSON
|
|
34498
34921
|
}));
|
|
34499
34922
|
}
|
|
34500
34923
|
return slots;
|
|
@@ -34503,14 +34926,7 @@ var ItemContainer$1 = function ItemContainer(_ref) {
|
|
|
34503
34926
|
title: itemContainer.name || 'Container',
|
|
34504
34927
|
onClose: onClose,
|
|
34505
34928
|
initialPosition: initialPosition
|
|
34506
|
-
},
|
|
34507
|
-
setSettingShortcutIndex: setSettingShortcutIndex,
|
|
34508
|
-
settingShortcutIndex: settingShortcutIndex,
|
|
34509
|
-
shortcuts: shortcuts,
|
|
34510
|
-
removeShortcut: removeShortcut,
|
|
34511
|
-
atlasIMG: atlasIMG,
|
|
34512
|
-
atlasJSON: atlasJSON
|
|
34513
|
-
}), React.createElement(ItemsContainer, {
|
|
34929
|
+
}, React.createElement(ItemsContainer, {
|
|
34514
34930
|
className: "item-container-body"
|
|
34515
34931
|
}, onRenderSlots())), quantitySelect.isOpen && React.createElement(QuantitySelectorContainer, null, React.createElement(ItemQuantitySelector, {
|
|
34516
34932
|
quantity: quantitySelect.maxQuantity,
|
|
@@ -34535,7 +34951,7 @@ var ItemContainer$1 = function ItemContainer(_ref) {
|
|
|
34535
34951
|
var ItemsContainer = /*#__PURE__*/styled.div.withConfig({
|
|
34536
34952
|
displayName: "ItemContainer__ItemsContainer",
|
|
34537
34953
|
componentId: "sc-15y5p9l-0"
|
|
34538
|
-
})(["display:flex;justify-content:center;flex-wrap:wrap;"]);
|
|
34954
|
+
})(["max-width:280px;display:flex;justify-content:center;flex-wrap:wrap;"]);
|
|
34539
34955
|
var QuantitySelectorContainer = /*#__PURE__*/styled.div.withConfig({
|
|
34540
34956
|
displayName: "ItemContainer__QuantitySelectorContainer",
|
|
34541
34957
|
componentId: "sc-15y5p9l-1"
|
|
@@ -34589,7 +35005,7 @@ var ItemSelector = function ItemSelector(_ref) {
|
|
|
34589
35005
|
value: option.name,
|
|
34590
35006
|
name: "test"
|
|
34591
35007
|
}), React.createElement("label", {
|
|
34592
|
-
|
|
35008
|
+
onPointerDown: handleClick,
|
|
34593
35009
|
style: {
|
|
34594
35010
|
display: 'flex',
|
|
34595
35011
|
alignItems: 'center'
|
|
@@ -34597,7 +35013,7 @@ var ItemSelector = function ItemSelector(_ref) {
|
|
|
34597
35013
|
}, option.name, " ", React.createElement("br", null), option.description)));
|
|
34598
35014
|
})), React.createElement(ButtonWrapper$1, null, React.createElement(Button, {
|
|
34599
35015
|
buttonType: ButtonTypes.RPGUIButton,
|
|
34600
|
-
|
|
35016
|
+
onPointerDown: onClose
|
|
34601
35017
|
}, "Cancel"), React.createElement(Button, {
|
|
34602
35018
|
buttonType: ButtonTypes.RPGUIButton
|
|
34603
35019
|
}, "Select")));
|
|
@@ -34632,7 +35048,7 @@ var ListMenu = function ListMenu(_ref) {
|
|
|
34632
35048
|
onSelected = _ref.onSelected,
|
|
34633
35049
|
x = _ref.x,
|
|
34634
35050
|
y = _ref.y;
|
|
34635
|
-
return React.createElement(Container$
|
|
35051
|
+
return React.createElement(Container$f, {
|
|
34636
35052
|
x: x,
|
|
34637
35053
|
y: y
|
|
34638
35054
|
}, React.createElement("ul", {
|
|
@@ -34643,13 +35059,13 @@ var ListMenu = function ListMenu(_ref) {
|
|
|
34643
35059
|
}, options.map(function (params, index) {
|
|
34644
35060
|
return React.createElement(ListElement$1, {
|
|
34645
35061
|
key: (params == null ? void 0 : params.id) || index,
|
|
34646
|
-
|
|
35062
|
+
onPointerDown: function onPointerDown() {
|
|
34647
35063
|
onSelected(params == null ? void 0 : params.id);
|
|
34648
35064
|
}
|
|
34649
35065
|
}, (params == null ? void 0 : params.text) || 'No text');
|
|
34650
35066
|
})));
|
|
34651
35067
|
};
|
|
34652
|
-
var Container$
|
|
35068
|
+
var Container$f = /*#__PURE__*/styled.div.withConfig({
|
|
34653
35069
|
displayName: "ListMenu__Container",
|
|
34654
35070
|
componentId: "sc-i9097t-0"
|
|
34655
35071
|
})(["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) {
|
|
@@ -34662,332 +35078,6 @@ var ListElement$1 = /*#__PURE__*/styled.li.withConfig({
|
|
|
34662
35078
|
componentId: "sc-i9097t-1"
|
|
34663
35079
|
})(["margin-right:0.5rem;"]);
|
|
34664
35080
|
|
|
34665
|
-
var img$6 = '';
|
|
34666
|
-
|
|
34667
|
-
var img$7 = '';
|
|
34668
|
-
|
|
34669
|
-
var ImgSide;
|
|
34670
|
-
(function (ImgSide) {
|
|
34671
|
-
ImgSide["right"] = "right";
|
|
34672
|
-
ImgSide["left"] = "left";
|
|
34673
|
-
})(ImgSide || (ImgSide = {}));
|
|
34674
|
-
var NPCMultiDialog = function NPCMultiDialog(_ref) {
|
|
34675
|
-
var _textAndTypeArray$sli;
|
|
34676
|
-
var _onClose = _ref.onClose,
|
|
34677
|
-
textAndTypeArray = _ref.textAndTypeArray;
|
|
34678
|
-
var _useState = useState(false),
|
|
34679
|
-
showGoNextIndicator = _useState[0],
|
|
34680
|
-
setShowGoNextIndicator = _useState[1];
|
|
34681
|
-
var _useState2 = useState(0),
|
|
34682
|
-
slide = _useState2[0],
|
|
34683
|
-
setSlide = _useState2[1];
|
|
34684
|
-
var onHandleSpacePress = function onHandleSpacePress(event) {
|
|
34685
|
-
if (event.code === 'Space') {
|
|
34686
|
-
if (slide < (textAndTypeArray == null ? void 0 : textAndTypeArray.length) - 1) {
|
|
34687
|
-
setSlide(function (prev) {
|
|
34688
|
-
return prev + 1;
|
|
34689
|
-
});
|
|
34690
|
-
} else {
|
|
34691
|
-
// if there's no more text chunks, close the dialog
|
|
34692
|
-
_onClose();
|
|
34693
|
-
}
|
|
34694
|
-
}
|
|
34695
|
-
};
|
|
34696
|
-
useEffect(function () {
|
|
34697
|
-
document.addEventListener('keydown', onHandleSpacePress);
|
|
34698
|
-
return function () {
|
|
34699
|
-
return document.removeEventListener('keydown', onHandleSpacePress);
|
|
34700
|
-
};
|
|
34701
|
-
}, [slide]);
|
|
34702
|
-
return React.createElement(RPGUIContainer, {
|
|
34703
|
-
type: RPGUIContainerTypes.FramedGold,
|
|
34704
|
-
width: '50%',
|
|
34705
|
-
height: '180px'
|
|
34706
|
-
}, React.createElement(React.Fragment, null, React.createElement(Container$d, null, ((_textAndTypeArray$sli = textAndTypeArray[slide]) == null ? void 0 : _textAndTypeArray$sli.imageSide) === 'right' && React.createElement(React.Fragment, null, React.createElement(TextContainer, {
|
|
34707
|
-
flex: '70%'
|
|
34708
|
-
}, React.createElement(NPCDialogText, {
|
|
34709
|
-
onStartStep: function onStartStep() {
|
|
34710
|
-
return setShowGoNextIndicator(false);
|
|
34711
|
-
},
|
|
34712
|
-
onEndStep: function onEndStep() {
|
|
34713
|
-
return setShowGoNextIndicator(true);
|
|
34714
|
-
},
|
|
34715
|
-
text: textAndTypeArray[slide].text || 'No text provided.',
|
|
34716
|
-
onClose: function onClose() {
|
|
34717
|
-
if (_onClose) {
|
|
34718
|
-
_onClose();
|
|
34719
|
-
}
|
|
34720
|
-
}
|
|
34721
|
-
})), React.createElement(ThumbnailContainer, null, React.createElement(NPCThumbnail, {
|
|
34722
|
-
src: textAndTypeArray[slide].imagePath || img$6
|
|
34723
|
-
})), showGoNextIndicator && React.createElement(PressSpaceIndicator, {
|
|
34724
|
-
right: '10.5rem',
|
|
34725
|
-
src: img$7
|
|
34726
|
-
})), textAndTypeArray[slide].imageSide === 'left' && React.createElement(React.Fragment, null, React.createElement(ThumbnailContainer, null, React.createElement(NPCThumbnail, {
|
|
34727
|
-
src: textAndTypeArray[slide].imagePath || img$6
|
|
34728
|
-
})), React.createElement(TextContainer, {
|
|
34729
|
-
flex: '70%'
|
|
34730
|
-
}, React.createElement(NPCDialogText, {
|
|
34731
|
-
onStartStep: function onStartStep() {
|
|
34732
|
-
return setShowGoNextIndicator(false);
|
|
34733
|
-
},
|
|
34734
|
-
onEndStep: function onEndStep() {
|
|
34735
|
-
return setShowGoNextIndicator(true);
|
|
34736
|
-
},
|
|
34737
|
-
text: textAndTypeArray[slide].text || 'No text provided.',
|
|
34738
|
-
onClose: function onClose() {
|
|
34739
|
-
if (_onClose) {
|
|
34740
|
-
_onClose();
|
|
34741
|
-
}
|
|
34742
|
-
}
|
|
34743
|
-
})), showGoNextIndicator && React.createElement(PressSpaceIndicator, {
|
|
34744
|
-
right: '1rem',
|
|
34745
|
-
src: img$7
|
|
34746
|
-
}))), ")"));
|
|
34747
|
-
};
|
|
34748
|
-
var Container$d = /*#__PURE__*/styled.div.withConfig({
|
|
34749
|
-
displayName: "NPCMultiDialog__Container",
|
|
34750
|
-
componentId: "sc-rvu5wg-0"
|
|
34751
|
-
})(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
|
|
34752
|
-
var TextContainer = /*#__PURE__*/styled.div.withConfig({
|
|
34753
|
-
displayName: "NPCMultiDialog__TextContainer",
|
|
34754
|
-
componentId: "sc-rvu5wg-1"
|
|
34755
|
-
})(["flex:", " 0 0;width:355px;"], function (_ref2) {
|
|
34756
|
-
var flex = _ref2.flex;
|
|
34757
|
-
return flex;
|
|
34758
|
-
});
|
|
34759
|
-
var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
|
|
34760
|
-
displayName: "NPCMultiDialog__ThumbnailContainer",
|
|
34761
|
-
componentId: "sc-rvu5wg-2"
|
|
34762
|
-
})(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
|
|
34763
|
-
var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
|
|
34764
|
-
displayName: "NPCMultiDialog__NPCThumbnail",
|
|
34765
|
-
componentId: "sc-rvu5wg-3"
|
|
34766
|
-
})(["image-rendering:pixelated;height:128px;width:128px;"]);
|
|
34767
|
-
var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
|
|
34768
|
-
displayName: "NPCMultiDialog__PressSpaceIndicator",
|
|
34769
|
-
componentId: "sc-rvu5wg-4"
|
|
34770
|
-
})(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref3) {
|
|
34771
|
-
var right = _ref3.right;
|
|
34772
|
-
return right;
|
|
34773
|
-
});
|
|
34774
|
-
|
|
34775
|
-
//@ts-ignore
|
|
34776
|
-
var useEventListener = function useEventListener(type, handler, el) {
|
|
34777
|
-
if (el === void 0) {
|
|
34778
|
-
el = window;
|
|
34779
|
-
}
|
|
34780
|
-
var savedHandler = React.useRef();
|
|
34781
|
-
React.useEffect(function () {
|
|
34782
|
-
savedHandler.current = handler;
|
|
34783
|
-
}, [handler]);
|
|
34784
|
-
React.useEffect(function () {
|
|
34785
|
-
//@ts-ignore
|
|
34786
|
-
var listener = function listener(e) {
|
|
34787
|
-
return savedHandler.current(e);
|
|
34788
|
-
};
|
|
34789
|
-
el.addEventListener(type, listener);
|
|
34790
|
-
return function () {
|
|
34791
|
-
el.removeEventListener(type, listener);
|
|
34792
|
-
};
|
|
34793
|
-
}, [type, el]);
|
|
34794
|
-
};
|
|
34795
|
-
|
|
34796
|
-
var DynamicText = function DynamicText(_ref) {
|
|
34797
|
-
var text = _ref.text,
|
|
34798
|
-
onFinish = _ref.onFinish,
|
|
34799
|
-
onStart = _ref.onStart;
|
|
34800
|
-
var _useState = useState(''),
|
|
34801
|
-
textState = _useState[0],
|
|
34802
|
-
setTextState = _useState[1];
|
|
34803
|
-
useEffect(function () {
|
|
34804
|
-
var i = 0;
|
|
34805
|
-
var interval = setInterval(function () {
|
|
34806
|
-
// on every interval, show one more character
|
|
34807
|
-
if (i === 0) {
|
|
34808
|
-
if (onStart) {
|
|
34809
|
-
onStart();
|
|
34810
|
-
}
|
|
34811
|
-
}
|
|
34812
|
-
if (i < text.length) {
|
|
34813
|
-
setTextState(text.substring(0, i + 1));
|
|
34814
|
-
i++;
|
|
34815
|
-
} else {
|
|
34816
|
-
clearInterval(interval);
|
|
34817
|
-
if (onFinish) {
|
|
34818
|
-
onFinish();
|
|
34819
|
-
}
|
|
34820
|
-
}
|
|
34821
|
-
}, 50);
|
|
34822
|
-
return function () {
|
|
34823
|
-
clearInterval(interval);
|
|
34824
|
-
};
|
|
34825
|
-
}, [text]);
|
|
34826
|
-
return React.createElement(TextContainer$1, null, textState);
|
|
34827
|
-
};
|
|
34828
|
-
var TextContainer$1 = /*#__PURE__*/styled.p.withConfig({
|
|
34829
|
-
displayName: "DynamicText__TextContainer",
|
|
34830
|
-
componentId: "sc-1ggl9nd-0"
|
|
34831
|
-
})(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]);
|
|
34832
|
-
|
|
34833
|
-
var QuestionDialog = function QuestionDialog(_ref) {
|
|
34834
|
-
var questions = _ref.questions,
|
|
34835
|
-
answers = _ref.answers,
|
|
34836
|
-
onClose = _ref.onClose;
|
|
34837
|
-
var _useState = useState(questions[0]),
|
|
34838
|
-
currentQuestion = _useState[0],
|
|
34839
|
-
setCurrentQuestion = _useState[1];
|
|
34840
|
-
var _useState2 = useState(false),
|
|
34841
|
-
canShowAnswers = _useState2[0],
|
|
34842
|
-
setCanShowAnswers = _useState2[1];
|
|
34843
|
-
var onGetFirstAnswer = function onGetFirstAnswer() {
|
|
34844
|
-
if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {
|
|
34845
|
-
return null;
|
|
34846
|
-
}
|
|
34847
|
-
var firstAnswerId = currentQuestion.answerIds[0];
|
|
34848
|
-
return answers.find(function (answer) {
|
|
34849
|
-
return answer.id === firstAnswerId;
|
|
34850
|
-
});
|
|
34851
|
-
};
|
|
34852
|
-
var _useState3 = useState(onGetFirstAnswer()),
|
|
34853
|
-
currentAnswer = _useState3[0],
|
|
34854
|
-
setCurrentAnswer = _useState3[1];
|
|
34855
|
-
useEffect(function () {
|
|
34856
|
-
setCurrentAnswer(onGetFirstAnswer());
|
|
34857
|
-
}, [currentQuestion]);
|
|
34858
|
-
var onGetAnswers = function onGetAnswers(answerIds) {
|
|
34859
|
-
return answerIds.map(function (answerId) {
|
|
34860
|
-
return answers.find(function (answer) {
|
|
34861
|
-
return answer.id === answerId;
|
|
34862
|
-
});
|
|
34863
|
-
});
|
|
34864
|
-
};
|
|
34865
|
-
var onKeyPress = function onKeyPress(e) {
|
|
34866
|
-
switch (e.key) {
|
|
34867
|
-
case 'ArrowDown':
|
|
34868
|
-
// select next answer, if any.
|
|
34869
|
-
// if no next answer, select first answer
|
|
34870
|
-
// const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(
|
|
34871
|
-
// (answer) => answer?.id === currentAnswer!.id + 1
|
|
34872
|
-
// );
|
|
34873
|
-
var nextAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
|
|
34874
|
-
return (answer == null ? void 0 : answer.id) === currentAnswer.id + 1;
|
|
34875
|
-
});
|
|
34876
|
-
var nextAnswerID = currentQuestion.answerIds[nextAnswerIndex];
|
|
34877
|
-
var nextAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
|
|
34878
|
-
return (answer == null ? void 0 : answer.id) === nextAnswerID;
|
|
34879
|
-
});
|
|
34880
|
-
setCurrentAnswer(nextAnswer || onGetFirstAnswer());
|
|
34881
|
-
break;
|
|
34882
|
-
case 'ArrowUp':
|
|
34883
|
-
// select previous answer, if any.
|
|
34884
|
-
// if no previous answer, select last answer
|
|
34885
|
-
var previousAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
|
|
34886
|
-
return (answer == null ? void 0 : answer.id) === currentAnswer.id - 1;
|
|
34887
|
-
});
|
|
34888
|
-
var previousAnswerID = currentQuestion.answerIds && currentQuestion.answerIds[previousAnswerIndex];
|
|
34889
|
-
var previousAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
|
|
34890
|
-
return (answer == null ? void 0 : answer.id) === previousAnswerID;
|
|
34891
|
-
});
|
|
34892
|
-
if (previousAnswer) {
|
|
34893
|
-
setCurrentAnswer(previousAnswer);
|
|
34894
|
-
} else {
|
|
34895
|
-
setCurrentAnswer(onGetAnswers(currentQuestion.answerIds).pop());
|
|
34896
|
-
}
|
|
34897
|
-
break;
|
|
34898
|
-
case 'Enter':
|
|
34899
|
-
setCanShowAnswers(false);
|
|
34900
|
-
if (!(currentAnswer != null && currentAnswer.nextQuestionId)) {
|
|
34901
|
-
onClose();
|
|
34902
|
-
return;
|
|
34903
|
-
} else {
|
|
34904
|
-
setCurrentQuestion(questions.find(function (question) {
|
|
34905
|
-
return question.id === currentAnswer.nextQuestionId;
|
|
34906
|
-
}));
|
|
34907
|
-
}
|
|
34908
|
-
break;
|
|
34909
|
-
}
|
|
34910
|
-
};
|
|
34911
|
-
useEventListener('keydown', onKeyPress);
|
|
34912
|
-
var onAnswerClick = function onAnswerClick(answer) {
|
|
34913
|
-
setCanShowAnswers(false);
|
|
34914
|
-
if (answer.nextQuestionId) {
|
|
34915
|
-
// if there is a next question, go to it
|
|
34916
|
-
setCurrentQuestion(questions.find(function (question) {
|
|
34917
|
-
return question.id === answer.nextQuestionId;
|
|
34918
|
-
}));
|
|
34919
|
-
} else {
|
|
34920
|
-
// else, finish dialog!
|
|
34921
|
-
onClose();
|
|
34922
|
-
}
|
|
34923
|
-
};
|
|
34924
|
-
var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
|
|
34925
|
-
var answerIds = currentQuestion.answerIds;
|
|
34926
|
-
if (!answerIds) {
|
|
34927
|
-
return null;
|
|
34928
|
-
}
|
|
34929
|
-
var answers = onGetAnswers(answerIds);
|
|
34930
|
-
if (!answers) {
|
|
34931
|
-
return null;
|
|
34932
|
-
}
|
|
34933
|
-
return answers.map(function (answer) {
|
|
34934
|
-
var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
|
|
34935
|
-
var selectedColor = isSelected ? 'yellow' : 'white';
|
|
34936
|
-
if (answer) {
|
|
34937
|
-
return React.createElement(AnswerRow, {
|
|
34938
|
-
key: "answer_" + answer.id
|
|
34939
|
-
}, React.createElement(AnswerSelectedIcon, {
|
|
34940
|
-
color: selectedColor
|
|
34941
|
-
}, isSelected ? 'X' : null), React.createElement(Answer, {
|
|
34942
|
-
key: answer.id,
|
|
34943
|
-
onClick: function onClick() {
|
|
34944
|
-
return onAnswerClick(answer);
|
|
34945
|
-
},
|
|
34946
|
-
color: selectedColor
|
|
34947
|
-
}, answer.text));
|
|
34948
|
-
}
|
|
34949
|
-
return null;
|
|
34950
|
-
});
|
|
34951
|
-
};
|
|
34952
|
-
return React.createElement(Container$e, null, React.createElement(QuestionContainer, null, React.createElement(DynamicText, {
|
|
34953
|
-
text: currentQuestion.text,
|
|
34954
|
-
onStart: function onStart() {
|
|
34955
|
-
return setCanShowAnswers(false);
|
|
34956
|
-
},
|
|
34957
|
-
onFinish: function onFinish() {
|
|
34958
|
-
return setCanShowAnswers(true);
|
|
34959
|
-
}
|
|
34960
|
-
})), canShowAnswers && React.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
|
|
34961
|
-
};
|
|
34962
|
-
var Container$e = /*#__PURE__*/styled.div.withConfig({
|
|
34963
|
-
displayName: "QuestionDialog__Container",
|
|
34964
|
-
componentId: "sc-bxc5u0-0"
|
|
34965
|
-
})(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
|
|
34966
|
-
var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
|
|
34967
|
-
displayName: "QuestionDialog__QuestionContainer",
|
|
34968
|
-
componentId: "sc-bxc5u0-1"
|
|
34969
|
-
})(["flex:100%;width:100%;"]);
|
|
34970
|
-
var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
|
|
34971
|
-
displayName: "QuestionDialog__AnswersContainer",
|
|
34972
|
-
componentId: "sc-bxc5u0-2"
|
|
34973
|
-
})(["flex:100%;"]);
|
|
34974
|
-
var Answer = /*#__PURE__*/styled.p.withConfig({
|
|
34975
|
-
displayName: "QuestionDialog__Answer",
|
|
34976
|
-
componentId: "sc-bxc5u0-3"
|
|
34977
|
-
})(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
|
|
34978
|
-
return props.color;
|
|
34979
|
-
});
|
|
34980
|
-
var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
|
|
34981
|
-
displayName: "QuestionDialog__AnswerSelectedIcon",
|
|
34982
|
-
componentId: "sc-bxc5u0-4"
|
|
34983
|
-
})(["flex:5% 0 0;color:", " !important;"], function (props) {
|
|
34984
|
-
return props.color;
|
|
34985
|
-
});
|
|
34986
|
-
var AnswerRow = /*#__PURE__*/styled.div.withConfig({
|
|
34987
|
-
displayName: "QuestionDialog__AnswerRow",
|
|
34988
|
-
componentId: "sc-bxc5u0-5"
|
|
34989
|
-
})(["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;}"]);
|
|
34990
|
-
|
|
34991
35081
|
var ProgressBar = function ProgressBar(_ref) {
|
|
34992
35082
|
var max = _ref.max,
|
|
34993
35083
|
value = _ref.value,
|
|
@@ -35005,7 +35095,7 @@ var ProgressBar = function ProgressBar(_ref) {
|
|
|
35005
35095
|
}
|
|
35006
35096
|
return value * 100 / max;
|
|
35007
35097
|
};
|
|
35008
|
-
return React.createElement(Container$
|
|
35098
|
+
return React.createElement(Container$g, {
|
|
35009
35099
|
className: "rpgui-progress",
|
|
35010
35100
|
"data-value": calculatePercentageValue(max, value) / 100,
|
|
35011
35101
|
"data-rpguitype": "progress",
|
|
@@ -35034,7 +35124,7 @@ var TextOverlay$1 = /*#__PURE__*/styled.div.withConfig({
|
|
|
35034
35124
|
displayName: "ProgressBar__TextOverlay",
|
|
35035
35125
|
componentId: "sc-qa6fzh-1"
|
|
35036
35126
|
})(["width:100%;position:relative;"]);
|
|
35037
|
-
var Container$
|
|
35127
|
+
var Container$g = /*#__PURE__*/styled.div.withConfig({
|
|
35038
35128
|
displayName: "ProgressBar__Container",
|
|
35039
35129
|
componentId: "sc-qa6fzh-2"
|
|
35040
35130
|
})(["display:flex;flex-direction:column;min-width:", "px;width:", "%;justify-content:start;align-items:flex-start;", ""], function (props) {
|
|
@@ -35045,7 +35135,7 @@ var Container$f = /*#__PURE__*/styled.div.withConfig({
|
|
|
35045
35135
|
return props.style;
|
|
35046
35136
|
});
|
|
35047
35137
|
|
|
35048
|
-
var img$
|
|
35138
|
+
var img$9 = '';
|
|
35049
35139
|
|
|
35050
35140
|
var QuestInfo = function QuestInfo(_ref) {
|
|
35051
35141
|
var quests = _ref.quests,
|
|
@@ -35080,16 +35170,14 @@ var QuestInfo = function QuestInfo(_ref) {
|
|
|
35080
35170
|
cancelDrag: ".equipment-container-body .arrow-selector"
|
|
35081
35171
|
}, quests.length >= 2 ? React.createElement(QuestsContainer, null, currentIndex !== 0 && React.createElement(SelectArrow, {
|
|
35082
35172
|
direction: "left",
|
|
35083
|
-
|
|
35084
|
-
onTouchStart: onLeftClick
|
|
35173
|
+
onPointerDown: onLeftClick
|
|
35085
35174
|
}), currentIndex !== quests.length - 1 && React.createElement(SelectArrow, {
|
|
35086
35175
|
direction: "right",
|
|
35087
|
-
|
|
35088
|
-
onTouchStart: onRightClick
|
|
35176
|
+
onPointerDown: onRightClick
|
|
35089
35177
|
}), React.createElement(QuestContainer, null, React.createElement(TitleContainer$1, {
|
|
35090
35178
|
className: "drag-handler"
|
|
35091
35179
|
}, React.createElement(Title$3, null, React.createElement(Thumbnail, {
|
|
35092
|
-
src: quests[currentIndex].thumbnail || img$
|
|
35180
|
+
src: quests[currentIndex].thumbnail || img$9
|
|
35093
35181
|
}), quests[currentIndex].title), React.createElement(QuestSplitDiv, null, React.createElement("hr", {
|
|
35094
35182
|
className: "golden"
|
|
35095
35183
|
}))), React.createElement(Content, null, React.createElement("p", null, quests[currentIndex].description)), React.createElement(QuestColumn, {
|
|
@@ -35098,8 +35186,8 @@ var QuestInfo = function QuestInfo(_ref) {
|
|
|
35098
35186
|
}, buttons && buttons.map(function (button, index) {
|
|
35099
35187
|
return React.createElement(Button, {
|
|
35100
35188
|
key: index,
|
|
35101
|
-
|
|
35102
|
-
return button.
|
|
35189
|
+
onPointerDown: function onPointerDown() {
|
|
35190
|
+
return button.onPointerDown(quests[currentIndex]._id, quests[currentIndex].npcId);
|
|
35103
35191
|
},
|
|
35104
35192
|
disabled: button.disabled,
|
|
35105
35193
|
buttonType: ButtonTypes.RPGUIButton,
|
|
@@ -35108,7 +35196,7 @@ var QuestInfo = function QuestInfo(_ref) {
|
|
|
35108
35196
|
})))) : React.createElement(QuestsContainer, null, React.createElement(QuestContainer, null, React.createElement(TitleContainer$1, {
|
|
35109
35197
|
className: "drag-handler"
|
|
35110
35198
|
}, React.createElement(Title$3, null, React.createElement(Thumbnail, {
|
|
35111
|
-
src: quests[0].thumbnail || img$
|
|
35199
|
+
src: quests[0].thumbnail || img$9
|
|
35112
35200
|
}), quests[0].title), React.createElement(QuestSplitDiv, null, React.createElement("hr", {
|
|
35113
35201
|
className: "golden"
|
|
35114
35202
|
}))), React.createElement(Content, null, React.createElement("p", null, quests[0].description)), React.createElement(QuestColumn, {
|
|
@@ -35117,8 +35205,8 @@ var QuestInfo = function QuestInfo(_ref) {
|
|
|
35117
35205
|
}, buttons && buttons.map(function (button, index) {
|
|
35118
35206
|
return React.createElement(Button, {
|
|
35119
35207
|
key: index,
|
|
35120
|
-
|
|
35121
|
-
return button.
|
|
35208
|
+
onPointerDown: function onPointerDown() {
|
|
35209
|
+
return button.onPointerDown(quests[0]._id, quests[0].npcId);
|
|
35122
35210
|
},
|
|
35123
35211
|
disabled: button.disabled,
|
|
35124
35212
|
buttonType: ButtonTypes.RPGUIButton,
|
|
@@ -35237,7 +35325,7 @@ var InputRadio = function InputRadio(_ref) {
|
|
|
35237
35325
|
name: name,
|
|
35238
35326
|
type: "radio"
|
|
35239
35327
|
}), React.createElement("label", {
|
|
35240
|
-
|
|
35328
|
+
onPointerDown: handleClick
|
|
35241
35329
|
}, element.label), React.createElement("br", null));
|
|
35242
35330
|
}));
|
|
35243
35331
|
};
|
|
@@ -35251,96 +35339,13 @@ var RPGUIRoot = function RPGUIRoot(_ref) {
|
|
|
35251
35339
|
}, children);
|
|
35252
35340
|
};
|
|
35253
35341
|
|
|
35254
|
-
var Shortcuts = function Shortcuts(_ref) {
|
|
35255
|
-
var shortcuts = _ref.shortcuts,
|
|
35256
|
-
onShortcutCast = _ref.onShortcutCast,
|
|
35257
|
-
mana = _ref.mana,
|
|
35258
|
-
_ref$isBlockedCasting = _ref.isBlockedCastingByKeyboard,
|
|
35259
|
-
isBlockedCastingByKeyboard = _ref$isBlockedCasting === void 0 ? false : _ref$isBlockedCasting,
|
|
35260
|
-
atlasJSON = _ref.atlasJSON,
|
|
35261
|
-
atlasIMG = _ref.atlasIMG,
|
|
35262
|
-
inventory = _ref.inventory;
|
|
35263
|
-
useEffect(function () {
|
|
35264
|
-
var handleKeyDown = function handleKeyDown(e) {
|
|
35265
|
-
if (isBlockedCastingByKeyboard) return;
|
|
35266
|
-
var shortcutIndex = Number(e.key) - 1;
|
|
35267
|
-
if (shortcutIndex >= 0 && shortcutIndex <= 5) {
|
|
35268
|
-
onShortcutCast(shortcutIndex);
|
|
35269
|
-
}
|
|
35270
|
-
};
|
|
35271
|
-
window.addEventListener('keydown', handleKeyDown);
|
|
35272
|
-
return function () {
|
|
35273
|
-
window.removeEventListener('keydown', handleKeyDown);
|
|
35274
|
-
};
|
|
35275
|
-
}, [shortcuts, isBlockedCastingByKeyboard]);
|
|
35276
|
-
return React.createElement(List$1, null, Array.from({
|
|
35277
|
-
length: 6
|
|
35278
|
-
}).map(function (_, i) {
|
|
35279
|
-
var _shortcuts$i, _shortcuts$i3, _payload$manaCost;
|
|
35280
|
-
if (((_shortcuts$i = shortcuts[i]) == null ? void 0 : _shortcuts$i.type) === ShortcutType.Item) {
|
|
35281
|
-
var _shortcuts$i2;
|
|
35282
|
-
var _payload = (_shortcuts$i2 = shortcuts[i]) == null ? void 0 : _shortcuts$i2.payload;
|
|
35283
|
-
var itemsFromEquipment = [];
|
|
35284
|
-
if (inventory) {
|
|
35285
|
-
Object.keys(inventory.slots).forEach(function (i) {
|
|
35286
|
-
var _inventory$slots$inde;
|
|
35287
|
-
var index = parseInt(i);
|
|
35288
|
-
if (((_inventory$slots$inde = inventory.slots[index]) == null ? void 0 : _inventory$slots$inde.key) === (_payload == null ? void 0 : _payload.key)) {
|
|
35289
|
-
itemsFromEquipment.push(inventory.slots[index]);
|
|
35290
|
-
}
|
|
35291
|
-
});
|
|
35292
|
-
}
|
|
35293
|
-
var totalQty = itemsFromEquipment.reduce(function (acc, item) {
|
|
35294
|
-
return acc + ((item == null ? void 0 : item.stackQty) || 1);
|
|
35295
|
-
}, 0);
|
|
35296
|
-
return React.createElement(SingleShortcut, {
|
|
35297
|
-
key: i,
|
|
35298
|
-
onClick: onShortcutCast.bind(null, i),
|
|
35299
|
-
disabled: false
|
|
35300
|
-
}, _payload && React.createElement(SpriteFromAtlas, {
|
|
35301
|
-
atlasIMG: atlasIMG,
|
|
35302
|
-
atlasJSON: atlasJSON,
|
|
35303
|
-
spriteKey: getItemTextureKeyPath({
|
|
35304
|
-
key: _payload.texturePath,
|
|
35305
|
-
texturePath: _payload.texturePath,
|
|
35306
|
-
stackQty: _payload.stackQty || 1
|
|
35307
|
-
}, atlasJSON),
|
|
35308
|
-
width: 32,
|
|
35309
|
-
height: 32
|
|
35310
|
-
}), React.createElement("span", {
|
|
35311
|
-
className: "qty"
|
|
35312
|
-
}, totalQty), React.createElement("span", {
|
|
35313
|
-
className: "keyboard"
|
|
35314
|
-
}, i + 1));
|
|
35315
|
-
}
|
|
35316
|
-
var payload = (_shortcuts$i3 = shortcuts[i]) == null ? void 0 : _shortcuts$i3.payload;
|
|
35317
|
-
return React.createElement(SingleShortcut, {
|
|
35318
|
-
key: i,
|
|
35319
|
-
onClick: onShortcutCast.bind(null, i),
|
|
35320
|
-
disabled: mana < ((_payload$manaCost = payload == null ? void 0 : payload.manaCost) != null ? _payload$manaCost : 0)
|
|
35321
|
-
}, React.createElement("span", {
|
|
35322
|
-
className: "mana"
|
|
35323
|
-
}, payload && payload.manaCost), React.createElement("span", {
|
|
35324
|
-
className: "magicWords"
|
|
35325
|
-
}, payload == null ? void 0 : payload.magicWords.split(' ').map(function (word) {
|
|
35326
|
-
return word[0];
|
|
35327
|
-
})), React.createElement("span", {
|
|
35328
|
-
className: "keyboard"
|
|
35329
|
-
}, i + 1));
|
|
35330
|
-
}));
|
|
35331
|
-
};
|
|
35332
|
-
var List$1 = /*#__PURE__*/styled.p.withConfig({
|
|
35333
|
-
displayName: "Shortcuts__List",
|
|
35334
|
-
componentId: "sc-kgtsi7-0"
|
|
35335
|
-
})(["width:100%;display:flex;align-items:center;justify-content:center;gap:0.5rem;box-sizing:border-box;margin:0 !important;"]);
|
|
35336
|
-
|
|
35337
35342
|
var SimpleProgressBar = function SimpleProgressBar(_ref) {
|
|
35338
35343
|
var value = _ref.value,
|
|
35339
35344
|
_ref$bgColor = _ref.bgColor,
|
|
35340
35345
|
bgColor = _ref$bgColor === void 0 ? 'red' : _ref$bgColor,
|
|
35341
35346
|
_ref$margin = _ref.margin,
|
|
35342
35347
|
margin = _ref$margin === void 0 ? 20 : _ref$margin;
|
|
35343
|
-
return React.createElement(Container$
|
|
35348
|
+
return React.createElement(Container$h, {
|
|
35344
35349
|
className: "simple-progress-bar"
|
|
35345
35350
|
}, React.createElement(ProgressBarContainer, {
|
|
35346
35351
|
margin: margin
|
|
@@ -35349,7 +35354,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
|
|
|
35349
35354
|
bgColor: bgColor
|
|
35350
35355
|
}))));
|
|
35351
35356
|
};
|
|
35352
|
-
var Container$
|
|
35357
|
+
var Container$h = /*#__PURE__*/styled.div.withConfig({
|
|
35353
35358
|
displayName: "SimpleProgressBar__Container",
|
|
35354
35359
|
componentId: "sc-mbeil3-0"
|
|
35355
35360
|
})(["display:flex;justify-content:center;align-items:center;width:100%;"]);
|
|
@@ -35525,8 +35530,7 @@ var SkillsContainer = function SkillsContainer(_ref) {
|
|
|
35525
35530
|
title: "Skills",
|
|
35526
35531
|
cancelDrag: "#skillsDiv"
|
|
35527
35532
|
}, onCloseButton && React.createElement(CloseButton$3, {
|
|
35528
|
-
|
|
35529
|
-
onTouchStart: onCloseButton
|
|
35533
|
+
onPointerDown: onCloseButton
|
|
35530
35534
|
}, "X"), React.createElement(SkillsContainerDiv, {
|
|
35531
35535
|
id: "skillsDiv"
|
|
35532
35536
|
}, React.createElement(SkillSplitDiv, null, React.createElement("p", null, "General"), React.createElement("hr", {
|
|
@@ -35573,13 +35577,13 @@ var Spell = function Spell(_ref) {
|
|
|
35573
35577
|
manaCost = _ref.manaCost,
|
|
35574
35578
|
charMana = _ref.charMana,
|
|
35575
35579
|
charMagicLevel = _ref.charMagicLevel,
|
|
35576
|
-
|
|
35580
|
+
onPointerDown = _ref.onPointerDown,
|
|
35577
35581
|
isSettingShortcut = _ref.isSettingShortcut,
|
|
35578
35582
|
minMagicLevelRequired = _ref.minMagicLevelRequired;
|
|
35579
35583
|
var disabled = isSettingShortcut ? charMagicLevel < minMagicLevelRequired : manaCost > charMana || charMagicLevel < minMagicLevelRequired;
|
|
35580
|
-
return React.createElement(Container$
|
|
35584
|
+
return React.createElement(Container$i, {
|
|
35581
35585
|
disabled: disabled,
|
|
35582
|
-
|
|
35586
|
+
onPointerDown: onPointerDown == null ? void 0 : onPointerDown.bind(null, spellKey),
|
|
35583
35587
|
isSettingShortcut: isSettingShortcut && !disabled,
|
|
35584
35588
|
className: "spell"
|
|
35585
35589
|
}, disabled && React.createElement(Overlay, null, charMagicLevel < minMagicLevelRequired ? 'Low magic level' : manaCost > charMana && 'No mana'), React.createElement(SpellImage, null, magicWords.split(' ').map(function (word) {
|
|
@@ -35590,7 +35594,7 @@ var Spell = function Spell(_ref) {
|
|
|
35590
35594
|
className: "mana"
|
|
35591
35595
|
}, manaCost)));
|
|
35592
35596
|
};
|
|
35593
|
-
var Container$
|
|
35597
|
+
var Container$i = /*#__PURE__*/styled.button.withConfig({
|
|
35594
35598
|
displayName: "Spell__Container",
|
|
35595
35599
|
componentId: "sc-j96fa2-0"
|
|
35596
35600
|
})(["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) {
|
|
@@ -35626,6 +35630,43 @@ var Overlay = /*#__PURE__*/styled.p.withConfig({
|
|
|
35626
35630
|
componentId: "sc-j96fa2-7"
|
|
35627
35631
|
})(["margin:0 !important;position:absolute;top:0;left:0;width:100%;height:100%;border-radius:1rem;display:flex;justify-content:center;align-items:center;color:", ";font-size:", " !important;font-weight:bold;z-index:10;background-color:rgba(0 0 0 / 0.2);"], uiColors.yellow, uiFonts.size.large);
|
|
35628
35632
|
|
|
35633
|
+
var SpellbookShortcuts = function SpellbookShortcuts(_ref) {
|
|
35634
|
+
var setSettingShortcutIndex = _ref.setSettingShortcutIndex,
|
|
35635
|
+
settingShortcutIndex = _ref.settingShortcutIndex,
|
|
35636
|
+
shortcuts = _ref.shortcuts,
|
|
35637
|
+
removeShortcut = _ref.removeShortcut;
|
|
35638
|
+
return React.createElement(List$1, {
|
|
35639
|
+
id: "shortcuts_list"
|
|
35640
|
+
}, "Spells shortcuts:", Array.from({
|
|
35641
|
+
length: 4
|
|
35642
|
+
}).map(function (_, i) {
|
|
35643
|
+
var _shortcuts$i2;
|
|
35644
|
+
return React.createElement(SpellShortcut$1, {
|
|
35645
|
+
key: i,
|
|
35646
|
+
onPointerDown: function onPointerDown() {
|
|
35647
|
+
var _shortcuts$i;
|
|
35648
|
+
removeShortcut(i);
|
|
35649
|
+
if (!((_shortcuts$i = shortcuts[i]) != null && _shortcuts$i.key)) setSettingShortcutIndex(i);
|
|
35650
|
+
},
|
|
35651
|
+
disabled: settingShortcutIndex !== -1 && settingShortcutIndex !== i,
|
|
35652
|
+
isBeingSet: settingShortcutIndex === i
|
|
35653
|
+
}, React.createElement("span", null, (_shortcuts$i2 = shortcuts[i]) == null ? void 0 : _shortcuts$i2.magicWords.split(' ').map(function (word) {
|
|
35654
|
+
return word[0];
|
|
35655
|
+
})));
|
|
35656
|
+
}));
|
|
35657
|
+
};
|
|
35658
|
+
var SpellShortcut$1 = /*#__PURE__*/styled.button.withConfig({
|
|
35659
|
+
displayName: "SpellbookShortcuts__SpellShortcut",
|
|
35660
|
+
componentId: "sc-fr4a0d-0"
|
|
35661
|
+
})(["width:2.6rem;height:2.6rem;background-color:", ";border:2px solid ", ";border-radius:50%;text-transform:uppercase;font-size:0.7rem;font-weight:bold;display:flex;align-items:center;justify-content:center;span{margin-top:4px;}&:hover,&:focus{background-color:", ";}&:active{background-color:", ";}&:disabled{opacity:0.5;}"], uiColors.lightGray, function (_ref2) {
|
|
35662
|
+
var isBeingSet = _ref2.isBeingSet;
|
|
35663
|
+
return isBeingSet ? uiColors.yellow : uiColors.darkGray;
|
|
35664
|
+
}, uiColors.darkGray, uiColors.gray);
|
|
35665
|
+
var List$1 = /*#__PURE__*/styled.p.withConfig({
|
|
35666
|
+
displayName: "SpellbookShortcuts__List",
|
|
35667
|
+
componentId: "sc-fr4a0d-1"
|
|
35668
|
+
})(["width:100%;display:flex;align-items:center;justify-content:flex-end;gap:0.5rem;padding:0.5rem;box-sizing:border-box;margin:0 !important;"]);
|
|
35669
|
+
|
|
35629
35670
|
var Spellbook = function Spellbook(_ref) {
|
|
35630
35671
|
var onClose = _ref.onClose,
|
|
35631
35672
|
onInputFocus = _ref.onInputFocus,
|
|
@@ -35635,10 +35676,8 @@ var Spellbook = function Spellbook(_ref) {
|
|
|
35635
35676
|
mana = _ref.mana,
|
|
35636
35677
|
onSpellClick = _ref.onSpellClick,
|
|
35637
35678
|
setSpellShortcut = _ref.setSpellShortcut,
|
|
35638
|
-
|
|
35639
|
-
|
|
35640
|
-
atlasIMG = _ref.atlasIMG,
|
|
35641
|
-
atlasJSON = _ref.atlasJSON;
|
|
35679
|
+
spellShortcuts = _ref.spellShortcuts,
|
|
35680
|
+
removeSpellShortcut = _ref.removeSpellShortcut;
|
|
35642
35681
|
var _useState = useState(''),
|
|
35643
35682
|
search = _useState[0],
|
|
35644
35683
|
setSearch = _useState[1];
|
|
@@ -35675,13 +35714,11 @@ var Spellbook = function Spellbook(_ref) {
|
|
|
35675
35714
|
width: "inherit",
|
|
35676
35715
|
height: "inherit",
|
|
35677
35716
|
cancelDrag: "#spellbook-search, #shortcuts_list, .spell"
|
|
35678
|
-
}, React.createElement(Container$
|
|
35717
|
+
}, React.createElement(Container$j, null, React.createElement(Title$6, null, "Learned Spells"), React.createElement(SpellbookShortcuts, {
|
|
35679
35718
|
setSettingShortcutIndex: setSettingShortcutIndex,
|
|
35680
35719
|
settingShortcutIndex: settingShortcutIndex,
|
|
35681
|
-
shortcuts:
|
|
35682
|
-
removeShortcut:
|
|
35683
|
-
atlasIMG: atlasIMG,
|
|
35684
|
-
atlasJSON: atlasJSON
|
|
35720
|
+
shortcuts: spellShortcuts,
|
|
35721
|
+
removeShortcut: removeSpellShortcut
|
|
35685
35722
|
}), React.createElement(Input, {
|
|
35686
35723
|
placeholder: "Search for spell",
|
|
35687
35724
|
value: search,
|
|
@@ -35697,7 +35734,7 @@ var Spellbook = function Spellbook(_ref) {
|
|
|
35697
35734
|
}, React.createElement(Spell, Object.assign({
|
|
35698
35735
|
charMana: mana,
|
|
35699
35736
|
charMagicLevel: magicLevel,
|
|
35700
|
-
|
|
35737
|
+
onPointerDown: settingShortcutIndex !== -1 ? setShortcut : onSpellClick,
|
|
35701
35738
|
spellKey: spell.key,
|
|
35702
35739
|
isSettingShortcut: settingShortcutIndex !== -1
|
|
35703
35740
|
}, spell)));
|
|
@@ -35707,7 +35744,7 @@ var Title$6 = /*#__PURE__*/styled.h1.withConfig({
|
|
|
35707
35744
|
displayName: "Spellbook__Title",
|
|
35708
35745
|
componentId: "sc-r02nfq-0"
|
|
35709
35746
|
})(["font-size:", " !important;margin-bottom:0 !important;"], uiFonts.size.large);
|
|
35710
|
-
var Container$
|
|
35747
|
+
var Container$j = /*#__PURE__*/styled.div.withConfig({
|
|
35711
35748
|
displayName: "Spellbook__Container",
|
|
35712
35749
|
componentId: "sc-r02nfq-1"
|
|
35713
35750
|
})(["width:100%;height:100%;color:white;display:flex;flex-direction:column;"]);
|
|
@@ -35721,16 +35758,16 @@ var TextArea = function TextArea(_ref) {
|
|
|
35721
35758
|
return React.createElement("textarea", Object.assign({}, props));
|
|
35722
35759
|
};
|
|
35723
35760
|
|
|
35724
|
-
var img$
|
|
35761
|
+
var img$a = '';
|
|
35725
35762
|
|
|
35726
|
-
var img$
|
|
35763
|
+
var img$b = '';
|
|
35727
35764
|
|
|
35728
|
-
var img$
|
|
35765
|
+
var img$c = '';
|
|
35729
35766
|
|
|
35730
35767
|
var DayNightPeriod = function DayNightPeriod(_ref) {
|
|
35731
35768
|
var _periodOfDaySrcFiles;
|
|
35732
35769
|
var periodOfDay = _ref.periodOfDay;
|
|
35733
|
-
var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[PeriodOfDay.Morning] = img$
|
|
35770
|
+
var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[PeriodOfDay.Morning] = img$b, _periodOfDaySrcFiles[PeriodOfDay.Afternoon] = img$a, _periodOfDaySrcFiles[PeriodOfDay.Night] = img$c, _periodOfDaySrcFiles);
|
|
35734
35771
|
return React.createElement(GifContainer, null, React.createElement("img", {
|
|
35735
35772
|
src: periodOfDaySrcFiles[periodOfDay]
|
|
35736
35773
|
}));
|
|
@@ -35740,14 +35777,14 @@ var GifContainer = /*#__PURE__*/styled.div.withConfig({
|
|
|
35740
35777
|
componentId: "sc-10t97fw-0"
|
|
35741
35778
|
})(["width:100%;img{width:67%;}"]);
|
|
35742
35779
|
|
|
35743
|
-
var img$
|
|
35780
|
+
var img$d = '';
|
|
35744
35781
|
|
|
35745
35782
|
var TimeWidget = function TimeWidget(_ref) {
|
|
35746
35783
|
var onClose = _ref.onClose,
|
|
35747
35784
|
TimeClock = _ref.TimeClock,
|
|
35748
35785
|
periodOfDay = _ref.periodOfDay;
|
|
35749
35786
|
return React.createElement(Draggable, null, React.createElement(WidgetContainer, null, React.createElement(CloseButton$4, {
|
|
35750
|
-
|
|
35787
|
+
onPointerDown: onClose
|
|
35751
35788
|
}, "X"), React.createElement(DayNightContainer, null, React.createElement(DayNightPeriod, {
|
|
35752
35789
|
periodOfDay: periodOfDay
|
|
35753
35790
|
})), React.createElement(Time, null, TimeClock)));
|
|
@@ -35755,7 +35792,7 @@ var TimeWidget = function TimeWidget(_ref) {
|
|
|
35755
35792
|
var WidgetContainer = /*#__PURE__*/styled.div.withConfig({
|
|
35756
35793
|
displayName: "TimeWidget__WidgetContainer",
|
|
35757
35794
|
componentId: "sc-1ja236h-0"
|
|
35758
|
-
})(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$
|
|
35795
|
+
})(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$d);
|
|
35759
35796
|
var Time = /*#__PURE__*/styled.div.withConfig({
|
|
35760
35797
|
displayName: "TimeWidget__Time",
|
|
35761
35798
|
componentId: "sc-1ja236h-1"
|
|
@@ -35817,26 +35854,22 @@ var TradingItemRow = function TradingItemRow(_ref) {
|
|
|
35817
35854
|
size: 32,
|
|
35818
35855
|
className: "arrow-selector",
|
|
35819
35856
|
direction: "left",
|
|
35820
|
-
|
|
35821
|
-
onTouchStart: onLeftOutClick
|
|
35857
|
+
onPointerDown: onLeftOutClick
|
|
35822
35858
|
}), React.createElement(StyledArrow, {
|
|
35823
35859
|
size: 32,
|
|
35824
35860
|
className: "arrow-selector",
|
|
35825
35861
|
direction: "left",
|
|
35826
|
-
|
|
35827
|
-
onTouchStart: onLeftClick
|
|
35862
|
+
onPointerDown: onLeftClick
|
|
35828
35863
|
}), React.createElement(QuantityDisplay, null, React.createElement(TextOverlay$2, null, React.createElement(Item$1, null, selectedQty))), React.createElement(StyledArrow, {
|
|
35829
35864
|
size: 32,
|
|
35830
35865
|
className: "arrow-selector",
|
|
35831
35866
|
direction: "right",
|
|
35832
|
-
|
|
35833
|
-
onTouchStart: onRightClick
|
|
35867
|
+
onPointerDown: onRightClick
|
|
35834
35868
|
}), React.createElement(SelectArrow, {
|
|
35835
35869
|
size: 32,
|
|
35836
35870
|
className: "arrow-selector",
|
|
35837
35871
|
direction: "right",
|
|
35838
|
-
|
|
35839
|
-
onTouchStart: onRightOutClick
|
|
35872
|
+
onPointerDown: onRightOutClick
|
|
35840
35873
|
})));
|
|
35841
35874
|
};
|
|
35842
35875
|
var StyledArrow = /*#__PURE__*/styled(SelectArrow).withConfig({
|
|
@@ -35963,12 +35996,12 @@ var TradingMenu = function TradingMenu(_ref) {
|
|
|
35963
35996
|
})), 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, {
|
|
35964
35997
|
buttonType: ButtonTypes.RPGUIButton,
|
|
35965
35998
|
disabled: !hasGoldForSale(),
|
|
35966
|
-
|
|
35999
|
+
onPointerDown: function onPointerDown() {
|
|
35967
36000
|
return onConfirmClick();
|
|
35968
36001
|
}
|
|
35969
36002
|
}, "Confirm"), React.createElement(Button, {
|
|
35970
36003
|
buttonType: ButtonTypes.RPGUIButton,
|
|
35971
|
-
|
|
36004
|
+
onPointerDown: function onPointerDown() {
|
|
35972
36005
|
return onClose();
|
|
35973
36006
|
}
|
|
35974
36007
|
}, "Cancel"))));
|
|
@@ -36007,230 +36040,16 @@ var Truncate = function Truncate(_ref) {
|
|
|
36007
36040
|
var _ref$maxLines = _ref.maxLines,
|
|
36008
36041
|
maxLines = _ref$maxLines === void 0 ? 1 : _ref$maxLines,
|
|
36009
36042
|
children = _ref.children;
|
|
36010
|
-
return React.createElement(Container$
|
|
36043
|
+
return React.createElement(Container$k, {
|
|
36011
36044
|
maxLines: maxLines
|
|
36012
36045
|
}, children);
|
|
36013
36046
|
};
|
|
36014
|
-
var Container$
|
|
36047
|
+
var Container$k = /*#__PURE__*/styled.div.withConfig({
|
|
36015
36048
|
displayName: "Truncate__Container",
|
|
36016
36049
|
componentId: "sc-6x00qb-0"
|
|
36017
36050
|
})(["display:-webkit-box;max-width:100%;max-height:100%;-webkit-line-clamp:", ";-webkit-box-orient:vertical;overflow:hidden;"], function (props) {
|
|
36018
36051
|
return props.maxLines;
|
|
36019
36052
|
});
|
|
36020
36053
|
|
|
36021
|
-
|
|
36022
|
-
|
|
36023
|
-
var chunkString = function chunkString(str, length) {
|
|
36024
|
-
return str.match(new RegExp('.{1,' + length + '}', 'g'));
|
|
36025
|
-
};
|
|
36026
|
-
|
|
36027
|
-
var img$d = '';
|
|
36028
|
-
|
|
36029
|
-
var NPCDialogText = function NPCDialogText(_ref) {
|
|
36030
|
-
var text = _ref.text,
|
|
36031
|
-
onClose = _ref.onClose,
|
|
36032
|
-
onEndStep = _ref.onEndStep,
|
|
36033
|
-
onStartStep = _ref.onStartStep,
|
|
36034
|
-
type = _ref.type;
|
|
36035
|
-
var windowSize = useRef([window.innerWidth, window.innerHeight]);
|
|
36036
|
-
function maxCharacters(width) {
|
|
36037
|
-
// Set the font size to 16 pixels
|
|
36038
|
-
var fontSize = 11.2;
|
|
36039
|
-
// Calculate the number of characters that can fit in one line
|
|
36040
|
-
var charactersPerLine = Math.floor(width / 2 / fontSize);
|
|
36041
|
-
// Calculate the number of lines that can fit in the div
|
|
36042
|
-
var linesPerDiv = Math.floor(180 / fontSize);
|
|
36043
|
-
// Calculate the maximum number of characters that can fit in the div
|
|
36044
|
-
var maxCharacters = charactersPerLine * linesPerDiv;
|
|
36045
|
-
// Return the maximum number of characters
|
|
36046
|
-
return Math.round(maxCharacters / 5);
|
|
36047
|
-
}
|
|
36048
|
-
var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
|
|
36049
|
-
var _useState = useState(0),
|
|
36050
|
-
chunkIndex = _useState[0],
|
|
36051
|
-
setChunkIndex = _useState[1];
|
|
36052
|
-
var onHandleSpacePress = function onHandleSpacePress(event) {
|
|
36053
|
-
if (event.code === 'Space') {
|
|
36054
|
-
goToNextStep();
|
|
36055
|
-
}
|
|
36056
|
-
};
|
|
36057
|
-
var goToNextStep = function goToNextStep() {
|
|
36058
|
-
var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
|
|
36059
|
-
if (hasNextChunk) {
|
|
36060
|
-
setChunkIndex(function (prev) {
|
|
36061
|
-
return prev + 1;
|
|
36062
|
-
});
|
|
36063
|
-
} else {
|
|
36064
|
-
// if there's no more text chunks, close the dialog
|
|
36065
|
-
onClose();
|
|
36066
|
-
}
|
|
36067
|
-
};
|
|
36068
|
-
useEffect(function () {
|
|
36069
|
-
document.addEventListener('keydown', onHandleSpacePress);
|
|
36070
|
-
return function () {
|
|
36071
|
-
return document.removeEventListener('keydown', onHandleSpacePress);
|
|
36072
|
-
};
|
|
36073
|
-
}, [chunkIndex]);
|
|
36074
|
-
var _useState2 = useState(false),
|
|
36075
|
-
showGoNextIndicator = _useState2[0],
|
|
36076
|
-
setShowGoNextIndicator = _useState2[1];
|
|
36077
|
-
return React.createElement(Container$k, null, React.createElement(DynamicText, {
|
|
36078
|
-
text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
|
|
36079
|
-
onFinish: function onFinish() {
|
|
36080
|
-
setShowGoNextIndicator(true);
|
|
36081
|
-
onEndStep && onEndStep();
|
|
36082
|
-
},
|
|
36083
|
-
onStart: function onStart() {
|
|
36084
|
-
setShowGoNextIndicator(false);
|
|
36085
|
-
onStartStep && onStartStep();
|
|
36086
|
-
}
|
|
36087
|
-
}), showGoNextIndicator && React.createElement(PressSpaceIndicator$1, {
|
|
36088
|
-
right: type === NPCDialogType.TextOnly ? '1rem' : '10.5rem',
|
|
36089
|
-
src: IS_MOBILE_OR_TABLET ? img$d : img$7,
|
|
36090
|
-
onClick: function onClick() {
|
|
36091
|
-
goToNextStep();
|
|
36092
|
-
}
|
|
36093
|
-
}));
|
|
36094
|
-
};
|
|
36095
|
-
var Container$k = /*#__PURE__*/styled.div.withConfig({
|
|
36096
|
-
displayName: "NPCDialogText__Container",
|
|
36097
|
-
componentId: "sc-1cxkdh9-0"
|
|
36098
|
-
})([""]);
|
|
36099
|
-
var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
|
|
36100
|
-
displayName: "NPCDialogText__PressSpaceIndicator",
|
|
36101
|
-
componentId: "sc-1cxkdh9-1"
|
|
36102
|
-
})(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
|
|
36103
|
-
var right = _ref2.right;
|
|
36104
|
-
return right;
|
|
36105
|
-
});
|
|
36106
|
-
|
|
36107
|
-
var NPCDialogType;
|
|
36108
|
-
(function (NPCDialogType) {
|
|
36109
|
-
NPCDialogType["TextOnly"] = "TextOnly";
|
|
36110
|
-
NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
|
|
36111
|
-
})(NPCDialogType || (NPCDialogType = {}));
|
|
36112
|
-
var NPCDialog = function NPCDialog(_ref) {
|
|
36113
|
-
var text = _ref.text,
|
|
36114
|
-
type = _ref.type,
|
|
36115
|
-
_onClose = _ref.onClose,
|
|
36116
|
-
imagePath = _ref.imagePath,
|
|
36117
|
-
_ref$isQuestionDialog = _ref.isQuestionDialog,
|
|
36118
|
-
isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
|
|
36119
|
-
questions = _ref.questions,
|
|
36120
|
-
answers = _ref.answers;
|
|
36121
|
-
return React.createElement(RPGUIContainer, {
|
|
36122
|
-
type: RPGUIContainerTypes.FramedGold,
|
|
36123
|
-
width: isQuestionDialog ? '600px' : '80%',
|
|
36124
|
-
height: '180px'
|
|
36125
|
-
}, isQuestionDialog && questions && answers ? React.createElement(React.Fragment, null, React.createElement(TextContainer$2, {
|
|
36126
|
-
flex: type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'
|
|
36127
|
-
}, React.createElement(QuestionDialog, {
|
|
36128
|
-
questions: questions,
|
|
36129
|
-
answers: answers,
|
|
36130
|
-
onClose: function onClose() {
|
|
36131
|
-
if (_onClose) {
|
|
36132
|
-
_onClose();
|
|
36133
|
-
}
|
|
36134
|
-
}
|
|
36135
|
-
})), type === NPCDialogType.TextAndThumbnail && React.createElement(ThumbnailContainer$1, null, React.createElement(NPCThumbnail$1, {
|
|
36136
|
-
src: imagePath || img$6
|
|
36137
|
-
}))) : React.createElement(React.Fragment, null, React.createElement(Container$l, null, React.createElement(TextContainer$2, {
|
|
36138
|
-
flex: type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'
|
|
36139
|
-
}, React.createElement(NPCDialogText, {
|
|
36140
|
-
type: type,
|
|
36141
|
-
text: text || 'No text provided.',
|
|
36142
|
-
onClose: function onClose() {
|
|
36143
|
-
if (_onClose) {
|
|
36144
|
-
_onClose();
|
|
36145
|
-
}
|
|
36146
|
-
}
|
|
36147
|
-
})), type === NPCDialogType.TextAndThumbnail && React.createElement(ThumbnailContainer$1, null, React.createElement(NPCThumbnail$1, {
|
|
36148
|
-
src: imagePath || img$6
|
|
36149
|
-
})))));
|
|
36150
|
-
};
|
|
36151
|
-
var Container$l = /*#__PURE__*/styled.div.withConfig({
|
|
36152
|
-
displayName: "NPCDialog__Container",
|
|
36153
|
-
componentId: "sc-1b4aw74-0"
|
|
36154
|
-
})(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
|
|
36155
|
-
var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
|
|
36156
|
-
displayName: "NPCDialog__TextContainer",
|
|
36157
|
-
componentId: "sc-1b4aw74-1"
|
|
36158
|
-
})(["flex:", " 0 0;width:355px;"], function (_ref2) {
|
|
36159
|
-
var flex = _ref2.flex;
|
|
36160
|
-
return flex;
|
|
36161
|
-
});
|
|
36162
|
-
var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
|
|
36163
|
-
displayName: "NPCDialog__ThumbnailContainer",
|
|
36164
|
-
componentId: "sc-1b4aw74-2"
|
|
36165
|
-
})(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
|
|
36166
|
-
var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
|
|
36167
|
-
displayName: "NPCDialog__NPCThumbnail",
|
|
36168
|
-
componentId: "sc-1b4aw74-3"
|
|
36169
|
-
})(["image-rendering:pixelated;height:128px;width:128px;"]);
|
|
36170
|
-
|
|
36171
|
-
var HistoryDialog = function HistoryDialog(_ref) {
|
|
36172
|
-
var backgroundImgPath = _ref.backgroundImgPath,
|
|
36173
|
-
fullCoverBackground = _ref.fullCoverBackground,
|
|
36174
|
-
questions = _ref.questions,
|
|
36175
|
-
answers = _ref.answers,
|
|
36176
|
-
text = _ref.text,
|
|
36177
|
-
imagePath = _ref.imagePath,
|
|
36178
|
-
textAndTypeArray = _ref.textAndTypeArray,
|
|
36179
|
-
onClose = _ref.onClose;
|
|
36180
|
-
var _useState = useState(0),
|
|
36181
|
-
img = _useState[0],
|
|
36182
|
-
setImage = _useState[1];
|
|
36183
|
-
var onHandleSpacePress = function onHandleSpacePress(event) {
|
|
36184
|
-
if (event.code === 'Space') {
|
|
36185
|
-
if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
|
|
36186
|
-
setImage(function (prev) {
|
|
36187
|
-
return prev + 1;
|
|
36188
|
-
});
|
|
36189
|
-
} else {
|
|
36190
|
-
// if there's no more text chunks, close the dialog
|
|
36191
|
-
onClose();
|
|
36192
|
-
}
|
|
36193
|
-
}
|
|
36194
|
-
};
|
|
36195
|
-
useEffect(function () {
|
|
36196
|
-
document.addEventListener('keydown', onHandleSpacePress);
|
|
36197
|
-
return function () {
|
|
36198
|
-
return document.removeEventListener('keydown', onHandleSpacePress);
|
|
36199
|
-
};
|
|
36200
|
-
}, [backgroundImgPath]);
|
|
36201
|
-
return React.createElement(BackgroundContainer, {
|
|
36202
|
-
imgPath: backgroundImgPath[img],
|
|
36203
|
-
fullImg: fullCoverBackground
|
|
36204
|
-
}, React.createElement(DialogContainer, null, textAndTypeArray ? React.createElement(NPCMultiDialog, {
|
|
36205
|
-
textAndTypeArray: textAndTypeArray,
|
|
36206
|
-
onClose: onClose
|
|
36207
|
-
}) : questions && answers ? React.createElement(QuestionDialog, {
|
|
36208
|
-
questions: questions,
|
|
36209
|
-
answers: answers,
|
|
36210
|
-
onClose: onClose
|
|
36211
|
-
}) : text && imagePath ? React.createElement(NPCDialog, {
|
|
36212
|
-
text: text,
|
|
36213
|
-
imagePath: imagePath,
|
|
36214
|
-
onClose: onClose,
|
|
36215
|
-
type: NPCDialogType.TextAndThumbnail
|
|
36216
|
-
}) : React.createElement(NPCDialog, {
|
|
36217
|
-
text: text,
|
|
36218
|
-
onClose: onClose,
|
|
36219
|
-
type: NPCDialogType.TextOnly
|
|
36220
|
-
})));
|
|
36221
|
-
};
|
|
36222
|
-
var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
|
|
36223
|
-
displayName: "HistoryDialog__BackgroundContainer",
|
|
36224
|
-
componentId: "sc-u6oe75-0"
|
|
36225
|
-
})(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
|
|
36226
|
-
return props.imgPath;
|
|
36227
|
-
}, function (props) {
|
|
36228
|
-
return props.imgPath ? 'cover' : 'auto';
|
|
36229
|
-
});
|
|
36230
|
-
var DialogContainer = /*#__PURE__*/styled.div.withConfig({
|
|
36231
|
-
displayName: "HistoryDialog__DialogContainer",
|
|
36232
|
-
componentId: "sc-u6oe75-1"
|
|
36233
|
-
})(["display:flex;justify-content:center;padding-top:200px;"]);
|
|
36234
|
-
|
|
36235
|
-
export { Button, ButtonTypes, CharacterSelection, Chat, ChatDeprecated, CheckButton, CircularController, CraftBook, DraggableContainer, Dropdown, DropdownSelectorContainer, DynamicText, EquipmentSet, ErrorBoundary, HistoryDialog, ImgSide, Input, InputRadio, ItemContainer$1 as ItemContainer, ItemSelector, ItemSlot, ListMenu, NPCDialog, NPCDialogType, NPCMultiDialog, ProgressBar, PropertySelect, QuestInfo, QuestList, QuestionDialog, RPGUIContainer, RPGUIContainerTypes, RPGUIRoot, RangeSlider, RangeSliderType, Shortcuts, SkillProgressBar, SkillsContainer, Spellbook, SpriteFromAtlas, TextArea, TimeWidget, TradingMenu, Truncate, _RPGUI, useEventListener };
|
|
36054
|
+
export { Button, ButtonTypes, CharacterSelection, Chat, ChatDeprecated, CheckButton, CircularController, CraftBook, DraggableContainer, Dropdown, DropdownSelectorContainer, DynamicText, EquipmentSet, ErrorBoundary, HistoryDialog, ImgSide, Input, InputRadio, ItemContainer$1 as ItemContainer, ItemSelector, ItemSlot, ListMenu, NPCDialog, NPCDialogType, NPCMultiDialog, ProgressBar, PropertySelect, QuestInfo, QuestList, QuestionDialog, QuickSpells, RPGUIContainer, RPGUIContainerTypes, RPGUIRoot, RangeSlider, RangeSliderType, SkillProgressBar, SkillsContainer, SpellShortcut, Spellbook, SpriteFromAtlas, TextArea, TimeWidget, TradingMenu, Truncate, _RPGUI, useEventListener };
|
|
36236
36055
|
//# sourceMappingURL=long-bow.esm.js.map
|