@rpg-engine/long-bow 0.3.46 → 0.3.47
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/long-bow.cjs.development.js +705 -709
- 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 +708 -712
- package/dist/long-bow.esm.js.map +1 -1
- package/package.json +100 -101
- package/src/components/Abstractions/SlotsContainer.tsx +45 -45
- package/src/components/Arrow/SelectArrow.tsx +65 -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 +41 -41
- package/src/components/Character/CharacterSelection.tsx +96 -96
- package/src/components/Chat/Chat.tsx +194 -194
- package/src/components/Chatdeprecated/ChatDeprecated.tsx +200 -200
- package/src/components/CheckButton.tsx +65 -65
- package/src/components/CircularController/CircularController.tsx +162 -162
- package/src/components/CraftBook/CraftBook.tsx +230 -230
- package/src/components/CraftBook/MockItems.ts +46 -46
- package/src/components/DraggableContainer.tsx +154 -154
- package/src/components/Dropdown.tsx +96 -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 -175
- package/src/components/Item/Inventory/ItemContainerTypes.ts +6 -6
- package/src/components/Item/Inventory/ItemQuantitySelector.tsx +142 -142
- package/src/components/Item/Inventory/ItemSlot.tsx +465 -466
- package/src/components/Item/Inventory/itemContainerHelper.ts +156 -156
- package/src/components/ListMenu.tsx +63 -63
- package/src/components/Multitab/Tab.tsx +57 -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 +114 -114
- package/src/components/QuestInfo/QuestInfo.tsx +232 -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 +98 -98
- package/src/components/RadioInput/RadioInput.tsx +98 -98
- 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 +167 -167
- package/src/components/Spellbook/QuickSpells.tsx +120 -120
- package/src/components/Spellbook/Spell.tsx +201 -201
- package/src/components/Spellbook/Spellbook.tsx +144 -144
- package/src/components/Spellbook/SpellbookShortcuts.tsx +77 -77
- package/src/components/Spellbook/constants.ts +12 -12
- package/src/components/Spellbook/mockSpells.ts +60 -60
- package/src/components/StaticBook/StaticBook.tsx +105 -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 +197 -197
- package/src/components/TradingMenu/TradingMenu.tsx +203 -203
- package/src/components/TradingMenu/items.mock.ts +36 -36
- 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 -5
- 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 -560
- 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/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 -33
- 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 -124
- package/src/stories/ItemQuantitySelector.stories.tsx +26 -26
- package/src/stories/ItemSelector.stories.tsx +77 -77
- package/src/stories/ItemTradingComponent.stories.tsx +35 -35
- package/src/stories/ListMenu.stories.tsx +56 -56
- package/src/stories/Multitab.stories.tsx +51 -51
- package/src/stories/NPCDialog.stories.tsx +130 -130
- package/src/stories/NPCMultiDialog.stories.tsx +71 -71
- package/src/stories/ProgressBar.stories.tsx +23 -23
- package/src/stories/PropertySelect.stories.tsx +40 -40
- package/src/stories/QuestInfo.stories.tsx +107 -107
- package/src/stories/QuestList.stories.tsx +82 -82
- package/src/stories/QuickSpells.stories.tsx +38 -38
- 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 -107
- 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/long-bow.esm.js
CHANGED
|
@@ -1,13 +1,12 @@
|
|
|
1
1
|
import React, { Component, useState, useEffect, useRef, useMemo, Fragment } from 'react';
|
|
2
2
|
import styled from 'styled-components';
|
|
3
|
-
import { GRID_WIDTH, GRID_HEIGHT, ItemSubType, ItemContainerType, ItemType, ItemSocketEventsDisplayLabels, ActionsForInventory, ActionsForEquipmentSet, ActionsForLoot, ActionsForMapContainer, ItemRarities, getItemTextureKeyPath, ItemSlotType, getSPForLevel, PeriodOfDay } from '@rpg-engine/shared';
|
|
3
|
+
import { GRID_WIDTH, GRID_HEIGHT, ItemSubType, ItemContainerType, ItemType, ItemSocketEventsDisplayLabels, ActionsForInventory, ActionsForEquipmentSet, ActionsForLoot, ActionsForMapContainer, ItemRarities, getItemTextureKeyPath, ItemSlotType, getSPForLevel, PeriodOfDay, isMobileOrTablet } from '@rpg-engine/shared';
|
|
4
4
|
import dayjs from 'dayjs';
|
|
5
5
|
import { ErrorBoundary as ErrorBoundary$1 } from 'react-error-boundary';
|
|
6
6
|
import { RxPaperPlane } from 'react-icons/rx';
|
|
7
7
|
import Draggable from 'react-draggable';
|
|
8
8
|
import { v4 } from 'uuid';
|
|
9
9
|
import { observer } from 'mobx-react-lite';
|
|
10
|
-
import isMobile from 'is-mobile';
|
|
11
10
|
import 'rpgui/rpgui.min.css';
|
|
12
11
|
import 'rpgui/rpgui.min.js';
|
|
13
12
|
import _ from 'lodash-es';
|
|
@@ -33884,6 +33883,7 @@ var ItemSlot = /*#__PURE__*/observer(function (_ref) {
|
|
|
33884
33883
|
var resetItem = function resetItem() {
|
|
33885
33884
|
setTooltipVisible(false);
|
|
33886
33885
|
setWasDragged(false);
|
|
33886
|
+
setIsFocused(false);
|
|
33887
33887
|
};
|
|
33888
33888
|
var onSuccesfulDrag = function onSuccesfulDrag(quantity) {
|
|
33889
33889
|
resetItem();
|
|
@@ -33892,7 +33892,6 @@ var ItemSlot = /*#__PURE__*/observer(function (_ref) {
|
|
|
33892
33892
|
y: 0
|
|
33893
33893
|
});else if (item) {
|
|
33894
33894
|
onDragEnd(quantity);
|
|
33895
|
-
resetItem();
|
|
33896
33895
|
}
|
|
33897
33896
|
};
|
|
33898
33897
|
return React.createElement(Container$a, {
|
|
@@ -33948,7 +33947,6 @@ var ItemSlot = /*#__PURE__*/observer(function (_ref) {
|
|
|
33948
33947
|
if (item.stackQty && item.stackQty !== 1 && openQuantitySelector) openQuantitySelector(item.stackQty, onSuccesfulDrag);else onSuccesfulDrag(item.stackQty);
|
|
33949
33948
|
} else {
|
|
33950
33949
|
resetItem();
|
|
33951
|
-
setIsFocused(false);
|
|
33952
33950
|
setDragPosition({
|
|
33953
33951
|
x: 0,
|
|
33954
33952
|
y: 0
|
|
@@ -34142,548 +34140,6 @@ var EquipmentColumn = /*#__PURE__*/styled.div.withConfig({
|
|
|
34142
34140
|
componentId: "sc-1wuddg2-1"
|
|
34143
34141
|
})(["display:flex;justify-content:center;flex-wrap:wrap;flex-direction:column;touch-action:none;"]);
|
|
34144
34142
|
|
|
34145
|
-
var IS_MOBILE_OR_TABLET = /*#__PURE__*/isMobile({
|
|
34146
|
-
tablet: true
|
|
34147
|
-
});
|
|
34148
|
-
|
|
34149
|
-
var chunkString = function chunkString(str, length) {
|
|
34150
|
-
return str.match(new RegExp('.{1,' + length + '}', 'g'));
|
|
34151
|
-
};
|
|
34152
|
-
|
|
34153
|
-
var DynamicText = function DynamicText(_ref) {
|
|
34154
|
-
var text = _ref.text,
|
|
34155
|
-
onFinish = _ref.onFinish,
|
|
34156
|
-
onStart = _ref.onStart;
|
|
34157
|
-
var _useState = useState(''),
|
|
34158
|
-
textState = _useState[0],
|
|
34159
|
-
setTextState = _useState[1];
|
|
34160
|
-
useEffect(function () {
|
|
34161
|
-
var i = 0;
|
|
34162
|
-
var interval = setInterval(function () {
|
|
34163
|
-
// on every interval, show one more character
|
|
34164
|
-
if (i === 0) {
|
|
34165
|
-
if (onStart) {
|
|
34166
|
-
onStart();
|
|
34167
|
-
}
|
|
34168
|
-
}
|
|
34169
|
-
if (i < text.length) {
|
|
34170
|
-
setTextState(text.substring(0, i + 1));
|
|
34171
|
-
i++;
|
|
34172
|
-
} else {
|
|
34173
|
-
clearInterval(interval);
|
|
34174
|
-
if (onFinish) {
|
|
34175
|
-
onFinish();
|
|
34176
|
-
}
|
|
34177
|
-
}
|
|
34178
|
-
}, 50);
|
|
34179
|
-
return function () {
|
|
34180
|
-
clearInterval(interval);
|
|
34181
|
-
};
|
|
34182
|
-
}, [text]);
|
|
34183
|
-
return React.createElement(TextContainer, null, textState);
|
|
34184
|
-
};
|
|
34185
|
-
var TextContainer = /*#__PURE__*/styled.p.withConfig({
|
|
34186
|
-
displayName: "DynamicText__TextContainer",
|
|
34187
|
-
componentId: "sc-1ggl9nd-0"
|
|
34188
|
-
})(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]);
|
|
34189
|
-
|
|
34190
|
-
var img$6 = '';
|
|
34191
|
-
|
|
34192
|
-
var img$7 = '';
|
|
34193
|
-
|
|
34194
|
-
var NPCDialogText = function NPCDialogText(_ref) {
|
|
34195
|
-
var text = _ref.text,
|
|
34196
|
-
onClose = _ref.onClose,
|
|
34197
|
-
onEndStep = _ref.onEndStep,
|
|
34198
|
-
onStartStep = _ref.onStartStep,
|
|
34199
|
-
type = _ref.type;
|
|
34200
|
-
var windowSize = useRef([window.innerWidth, window.innerHeight]);
|
|
34201
|
-
function maxCharacters(width) {
|
|
34202
|
-
// Set the font size to 16 pixels
|
|
34203
|
-
var fontSize = 11.2;
|
|
34204
|
-
// Calculate the number of characters that can fit in one line
|
|
34205
|
-
var charactersPerLine = Math.floor(width / 2 / fontSize);
|
|
34206
|
-
// Calculate the number of lines that can fit in the div
|
|
34207
|
-
var linesPerDiv = Math.floor(180 / fontSize);
|
|
34208
|
-
// Calculate the maximum number of characters that can fit in the div
|
|
34209
|
-
var maxCharacters = charactersPerLine * linesPerDiv;
|
|
34210
|
-
// Return the maximum number of characters
|
|
34211
|
-
return Math.round(maxCharacters / 5);
|
|
34212
|
-
}
|
|
34213
|
-
var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
|
|
34214
|
-
var _useState = useState(0),
|
|
34215
|
-
chunkIndex = _useState[0],
|
|
34216
|
-
setChunkIndex = _useState[1];
|
|
34217
|
-
var onHandleSpacePress = function onHandleSpacePress(event) {
|
|
34218
|
-
if (event.code === 'Space') {
|
|
34219
|
-
goToNextStep();
|
|
34220
|
-
}
|
|
34221
|
-
};
|
|
34222
|
-
var goToNextStep = function goToNextStep() {
|
|
34223
|
-
var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
|
|
34224
|
-
if (hasNextChunk) {
|
|
34225
|
-
setChunkIndex(function (prev) {
|
|
34226
|
-
return prev + 1;
|
|
34227
|
-
});
|
|
34228
|
-
} else {
|
|
34229
|
-
// if there's no more text chunks, close the dialog
|
|
34230
|
-
onClose();
|
|
34231
|
-
}
|
|
34232
|
-
};
|
|
34233
|
-
useEffect(function () {
|
|
34234
|
-
document.addEventListener('keydown', onHandleSpacePress);
|
|
34235
|
-
return function () {
|
|
34236
|
-
return document.removeEventListener('keydown', onHandleSpacePress);
|
|
34237
|
-
};
|
|
34238
|
-
}, [chunkIndex]);
|
|
34239
|
-
var _useState2 = useState(false),
|
|
34240
|
-
showGoNextIndicator = _useState2[0],
|
|
34241
|
-
setShowGoNextIndicator = _useState2[1];
|
|
34242
|
-
return React.createElement(Container$b, null, React.createElement(DynamicText, {
|
|
34243
|
-
text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
|
|
34244
|
-
onFinish: function onFinish() {
|
|
34245
|
-
setShowGoNextIndicator(true);
|
|
34246
|
-
onEndStep && onEndStep();
|
|
34247
|
-
},
|
|
34248
|
-
onStart: function onStart() {
|
|
34249
|
-
setShowGoNextIndicator(false);
|
|
34250
|
-
onStartStep && onStartStep();
|
|
34251
|
-
}
|
|
34252
|
-
}), showGoNextIndicator && React.createElement(PressSpaceIndicator, {
|
|
34253
|
-
right: type === NPCDialogType.TextOnly ? '1rem' : '10.5rem',
|
|
34254
|
-
src: IS_MOBILE_OR_TABLET ? img$6 : img$7,
|
|
34255
|
-
onClick: function onClick() {
|
|
34256
|
-
goToNextStep();
|
|
34257
|
-
}
|
|
34258
|
-
}));
|
|
34259
|
-
};
|
|
34260
|
-
var Container$b = /*#__PURE__*/styled.div.withConfig({
|
|
34261
|
-
displayName: "NPCDialogText__Container",
|
|
34262
|
-
componentId: "sc-1cxkdh9-0"
|
|
34263
|
-
})([""]);
|
|
34264
|
-
var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
|
|
34265
|
-
displayName: "NPCDialogText__PressSpaceIndicator",
|
|
34266
|
-
componentId: "sc-1cxkdh9-1"
|
|
34267
|
-
})(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
|
|
34268
|
-
var right = _ref2.right;
|
|
34269
|
-
return right;
|
|
34270
|
-
});
|
|
34271
|
-
|
|
34272
|
-
//@ts-ignore
|
|
34273
|
-
var useEventListener = function useEventListener(type, handler, el) {
|
|
34274
|
-
if (el === void 0) {
|
|
34275
|
-
el = window;
|
|
34276
|
-
}
|
|
34277
|
-
var savedHandler = React.useRef();
|
|
34278
|
-
React.useEffect(function () {
|
|
34279
|
-
savedHandler.current = handler;
|
|
34280
|
-
}, [handler]);
|
|
34281
|
-
React.useEffect(function () {
|
|
34282
|
-
//@ts-ignore
|
|
34283
|
-
var listener = function listener(e) {
|
|
34284
|
-
return savedHandler.current(e);
|
|
34285
|
-
};
|
|
34286
|
-
el.addEventListener(type, listener);
|
|
34287
|
-
return function () {
|
|
34288
|
-
el.removeEventListener(type, listener);
|
|
34289
|
-
};
|
|
34290
|
-
}, [type, el]);
|
|
34291
|
-
};
|
|
34292
|
-
|
|
34293
|
-
var QuestionDialog = function QuestionDialog(_ref) {
|
|
34294
|
-
var questions = _ref.questions,
|
|
34295
|
-
answers = _ref.answers,
|
|
34296
|
-
onClose = _ref.onClose;
|
|
34297
|
-
var _useState = useState(questions[0]),
|
|
34298
|
-
currentQuestion = _useState[0],
|
|
34299
|
-
setCurrentQuestion = _useState[1];
|
|
34300
|
-
var _useState2 = useState(false),
|
|
34301
|
-
canShowAnswers = _useState2[0],
|
|
34302
|
-
setCanShowAnswers = _useState2[1];
|
|
34303
|
-
var onGetFirstAnswer = function onGetFirstAnswer() {
|
|
34304
|
-
if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {
|
|
34305
|
-
return null;
|
|
34306
|
-
}
|
|
34307
|
-
var firstAnswerId = currentQuestion.answerIds[0];
|
|
34308
|
-
return answers.find(function (answer) {
|
|
34309
|
-
return answer.id === firstAnswerId;
|
|
34310
|
-
});
|
|
34311
|
-
};
|
|
34312
|
-
var _useState3 = useState(onGetFirstAnswer()),
|
|
34313
|
-
currentAnswer = _useState3[0],
|
|
34314
|
-
setCurrentAnswer = _useState3[1];
|
|
34315
|
-
useEffect(function () {
|
|
34316
|
-
setCurrentAnswer(onGetFirstAnswer());
|
|
34317
|
-
}, [currentQuestion]);
|
|
34318
|
-
var onGetAnswers = function onGetAnswers(answerIds) {
|
|
34319
|
-
return answerIds.map(function (answerId) {
|
|
34320
|
-
return answers.find(function (answer) {
|
|
34321
|
-
return answer.id === answerId;
|
|
34322
|
-
});
|
|
34323
|
-
});
|
|
34324
|
-
};
|
|
34325
|
-
var onKeyPress = function onKeyPress(e) {
|
|
34326
|
-
switch (e.key) {
|
|
34327
|
-
case 'ArrowDown':
|
|
34328
|
-
// select next answer, if any.
|
|
34329
|
-
// if no next answer, select first answer
|
|
34330
|
-
// const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(
|
|
34331
|
-
// (answer) => answer?.id === currentAnswer!.id + 1
|
|
34332
|
-
// );
|
|
34333
|
-
var nextAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
|
|
34334
|
-
return (answer == null ? void 0 : answer.id) === currentAnswer.id + 1;
|
|
34335
|
-
});
|
|
34336
|
-
var nextAnswerID = currentQuestion.answerIds[nextAnswerIndex];
|
|
34337
|
-
var nextAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
|
|
34338
|
-
return (answer == null ? void 0 : answer.id) === nextAnswerID;
|
|
34339
|
-
});
|
|
34340
|
-
setCurrentAnswer(nextAnswer || onGetFirstAnswer());
|
|
34341
|
-
break;
|
|
34342
|
-
case 'ArrowUp':
|
|
34343
|
-
// select previous answer, if any.
|
|
34344
|
-
// if no previous answer, select last answer
|
|
34345
|
-
var previousAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
|
|
34346
|
-
return (answer == null ? void 0 : answer.id) === currentAnswer.id - 1;
|
|
34347
|
-
});
|
|
34348
|
-
var previousAnswerID = currentQuestion.answerIds && currentQuestion.answerIds[previousAnswerIndex];
|
|
34349
|
-
var previousAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
|
|
34350
|
-
return (answer == null ? void 0 : answer.id) === previousAnswerID;
|
|
34351
|
-
});
|
|
34352
|
-
if (previousAnswer) {
|
|
34353
|
-
setCurrentAnswer(previousAnswer);
|
|
34354
|
-
} else {
|
|
34355
|
-
setCurrentAnswer(onGetAnswers(currentQuestion.answerIds).pop());
|
|
34356
|
-
}
|
|
34357
|
-
break;
|
|
34358
|
-
case 'Enter':
|
|
34359
|
-
setCanShowAnswers(false);
|
|
34360
|
-
if (!(currentAnswer != null && currentAnswer.nextQuestionId)) {
|
|
34361
|
-
onClose();
|
|
34362
|
-
return;
|
|
34363
|
-
} else {
|
|
34364
|
-
setCurrentQuestion(questions.find(function (question) {
|
|
34365
|
-
return question.id === currentAnswer.nextQuestionId;
|
|
34366
|
-
}));
|
|
34367
|
-
}
|
|
34368
|
-
break;
|
|
34369
|
-
}
|
|
34370
|
-
};
|
|
34371
|
-
useEventListener('keydown', onKeyPress);
|
|
34372
|
-
var onAnswerClick = function onAnswerClick(answer) {
|
|
34373
|
-
setCanShowAnswers(false);
|
|
34374
|
-
if (answer.nextQuestionId) {
|
|
34375
|
-
// if there is a next question, go to it
|
|
34376
|
-
setCurrentQuestion(questions.find(function (question) {
|
|
34377
|
-
return question.id === answer.nextQuestionId;
|
|
34378
|
-
}));
|
|
34379
|
-
} else {
|
|
34380
|
-
// else, finish dialog!
|
|
34381
|
-
onClose();
|
|
34382
|
-
}
|
|
34383
|
-
};
|
|
34384
|
-
var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
|
|
34385
|
-
var answerIds = currentQuestion.answerIds;
|
|
34386
|
-
if (!answerIds) {
|
|
34387
|
-
return null;
|
|
34388
|
-
}
|
|
34389
|
-
var answers = onGetAnswers(answerIds);
|
|
34390
|
-
if (!answers) {
|
|
34391
|
-
return null;
|
|
34392
|
-
}
|
|
34393
|
-
return answers.map(function (answer) {
|
|
34394
|
-
var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
|
|
34395
|
-
var selectedColor = isSelected ? 'yellow' : 'white';
|
|
34396
|
-
if (answer) {
|
|
34397
|
-
return React.createElement(AnswerRow, {
|
|
34398
|
-
key: "answer_" + answer.id
|
|
34399
|
-
}, React.createElement(AnswerSelectedIcon, {
|
|
34400
|
-
color: selectedColor
|
|
34401
|
-
}, isSelected ? 'X' : null), React.createElement(Answer, {
|
|
34402
|
-
key: answer.id,
|
|
34403
|
-
onClick: function onClick() {
|
|
34404
|
-
return onAnswerClick(answer);
|
|
34405
|
-
},
|
|
34406
|
-
color: selectedColor
|
|
34407
|
-
}, answer.text));
|
|
34408
|
-
}
|
|
34409
|
-
return null;
|
|
34410
|
-
});
|
|
34411
|
-
};
|
|
34412
|
-
return React.createElement(Container$c, null, React.createElement(QuestionContainer, null, React.createElement(DynamicText, {
|
|
34413
|
-
text: currentQuestion.text,
|
|
34414
|
-
onStart: function onStart() {
|
|
34415
|
-
return setCanShowAnswers(false);
|
|
34416
|
-
},
|
|
34417
|
-
onFinish: function onFinish() {
|
|
34418
|
-
return setCanShowAnswers(true);
|
|
34419
|
-
}
|
|
34420
|
-
})), canShowAnswers && React.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
|
|
34421
|
-
};
|
|
34422
|
-
var Container$c = /*#__PURE__*/styled.div.withConfig({
|
|
34423
|
-
displayName: "QuestionDialog__Container",
|
|
34424
|
-
componentId: "sc-bxc5u0-0"
|
|
34425
|
-
})(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
|
|
34426
|
-
var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
|
|
34427
|
-
displayName: "QuestionDialog__QuestionContainer",
|
|
34428
|
-
componentId: "sc-bxc5u0-1"
|
|
34429
|
-
})(["flex:100%;width:100%;"]);
|
|
34430
|
-
var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
|
|
34431
|
-
displayName: "QuestionDialog__AnswersContainer",
|
|
34432
|
-
componentId: "sc-bxc5u0-2"
|
|
34433
|
-
})(["flex:100%;"]);
|
|
34434
|
-
var Answer = /*#__PURE__*/styled.p.withConfig({
|
|
34435
|
-
displayName: "QuestionDialog__Answer",
|
|
34436
|
-
componentId: "sc-bxc5u0-3"
|
|
34437
|
-
})(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
|
|
34438
|
-
return props.color;
|
|
34439
|
-
});
|
|
34440
|
-
var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
|
|
34441
|
-
displayName: "QuestionDialog__AnswerSelectedIcon",
|
|
34442
|
-
componentId: "sc-bxc5u0-4"
|
|
34443
|
-
})(["flex:5% 0 0;color:", " !important;"], function (props) {
|
|
34444
|
-
return props.color;
|
|
34445
|
-
});
|
|
34446
|
-
var AnswerRow = /*#__PURE__*/styled.div.withConfig({
|
|
34447
|
-
displayName: "QuestionDialog__AnswerRow",
|
|
34448
|
-
componentId: "sc-bxc5u0-5"
|
|
34449
|
-
})(["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;}"]);
|
|
34450
|
-
|
|
34451
|
-
var img$8 = '';
|
|
34452
|
-
|
|
34453
|
-
var NPCDialogType;
|
|
34454
|
-
(function (NPCDialogType) {
|
|
34455
|
-
NPCDialogType["TextOnly"] = "TextOnly";
|
|
34456
|
-
NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
|
|
34457
|
-
})(NPCDialogType || (NPCDialogType = {}));
|
|
34458
|
-
var NPCDialog = function NPCDialog(_ref) {
|
|
34459
|
-
var text = _ref.text,
|
|
34460
|
-
type = _ref.type,
|
|
34461
|
-
_onClose = _ref.onClose,
|
|
34462
|
-
imagePath = _ref.imagePath,
|
|
34463
|
-
_ref$isQuestionDialog = _ref.isQuestionDialog,
|
|
34464
|
-
isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
|
|
34465
|
-
questions = _ref.questions,
|
|
34466
|
-
answers = _ref.answers;
|
|
34467
|
-
return React.createElement(RPGUIContainer, {
|
|
34468
|
-
type: RPGUIContainerTypes.FramedGold,
|
|
34469
|
-
width: isQuestionDialog ? '600px' : '80%',
|
|
34470
|
-
height: '180px'
|
|
34471
|
-
}, isQuestionDialog && questions && answers ? React.createElement(React.Fragment, null, React.createElement(TextContainer$1, {
|
|
34472
|
-
flex: type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'
|
|
34473
|
-
}, React.createElement(QuestionDialog, {
|
|
34474
|
-
questions: questions,
|
|
34475
|
-
answers: answers,
|
|
34476
|
-
onClose: function onClose() {
|
|
34477
|
-
if (_onClose) {
|
|
34478
|
-
_onClose();
|
|
34479
|
-
}
|
|
34480
|
-
}
|
|
34481
|
-
})), type === NPCDialogType.TextAndThumbnail && React.createElement(ThumbnailContainer, null, React.createElement(NPCThumbnail, {
|
|
34482
|
-
src: imagePath || img$8
|
|
34483
|
-
}))) : React.createElement(React.Fragment, null, React.createElement(Container$d, null, React.createElement(TextContainer$1, {
|
|
34484
|
-
flex: type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'
|
|
34485
|
-
}, React.createElement(NPCDialogText, {
|
|
34486
|
-
type: type,
|
|
34487
|
-
text: text || 'No text provided.',
|
|
34488
|
-
onClose: function onClose() {
|
|
34489
|
-
if (_onClose) {
|
|
34490
|
-
_onClose();
|
|
34491
|
-
}
|
|
34492
|
-
}
|
|
34493
|
-
})), type === NPCDialogType.TextAndThumbnail && React.createElement(ThumbnailContainer, null, React.createElement(NPCThumbnail, {
|
|
34494
|
-
src: imagePath || img$8
|
|
34495
|
-
})))));
|
|
34496
|
-
};
|
|
34497
|
-
var Container$d = /*#__PURE__*/styled.div.withConfig({
|
|
34498
|
-
displayName: "NPCDialog__Container",
|
|
34499
|
-
componentId: "sc-1b4aw74-0"
|
|
34500
|
-
})(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
|
|
34501
|
-
var TextContainer$1 = /*#__PURE__*/styled.div.withConfig({
|
|
34502
|
-
displayName: "NPCDialog__TextContainer",
|
|
34503
|
-
componentId: "sc-1b4aw74-1"
|
|
34504
|
-
})(["flex:", " 0 0;width:355px;"], function (_ref2) {
|
|
34505
|
-
var flex = _ref2.flex;
|
|
34506
|
-
return flex;
|
|
34507
|
-
});
|
|
34508
|
-
var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
|
|
34509
|
-
displayName: "NPCDialog__ThumbnailContainer",
|
|
34510
|
-
componentId: "sc-1b4aw74-2"
|
|
34511
|
-
})(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
|
|
34512
|
-
var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
|
|
34513
|
-
displayName: "NPCDialog__NPCThumbnail",
|
|
34514
|
-
componentId: "sc-1b4aw74-3"
|
|
34515
|
-
})(["image-rendering:pixelated;height:128px;width:128px;"]);
|
|
34516
|
-
|
|
34517
|
-
var ImgSide;
|
|
34518
|
-
(function (ImgSide) {
|
|
34519
|
-
ImgSide["right"] = "right";
|
|
34520
|
-
ImgSide["left"] = "left";
|
|
34521
|
-
})(ImgSide || (ImgSide = {}));
|
|
34522
|
-
var NPCMultiDialog = function NPCMultiDialog(_ref) {
|
|
34523
|
-
var _textAndTypeArray$sli;
|
|
34524
|
-
var _onClose = _ref.onClose,
|
|
34525
|
-
textAndTypeArray = _ref.textAndTypeArray;
|
|
34526
|
-
var _useState = useState(false),
|
|
34527
|
-
showGoNextIndicator = _useState[0],
|
|
34528
|
-
setShowGoNextIndicator = _useState[1];
|
|
34529
|
-
var _useState2 = useState(0),
|
|
34530
|
-
slide = _useState2[0],
|
|
34531
|
-
setSlide = _useState2[1];
|
|
34532
|
-
var onHandleSpacePress = function onHandleSpacePress(event) {
|
|
34533
|
-
if (event.code === 'Space') {
|
|
34534
|
-
if (slide < (textAndTypeArray == null ? void 0 : textAndTypeArray.length) - 1) {
|
|
34535
|
-
setSlide(function (prev) {
|
|
34536
|
-
return prev + 1;
|
|
34537
|
-
});
|
|
34538
|
-
} else {
|
|
34539
|
-
// if there's no more text chunks, close the dialog
|
|
34540
|
-
_onClose();
|
|
34541
|
-
}
|
|
34542
|
-
}
|
|
34543
|
-
};
|
|
34544
|
-
useEffect(function () {
|
|
34545
|
-
document.addEventListener('keydown', onHandleSpacePress);
|
|
34546
|
-
return function () {
|
|
34547
|
-
return document.removeEventListener('keydown', onHandleSpacePress);
|
|
34548
|
-
};
|
|
34549
|
-
}, [slide]);
|
|
34550
|
-
return React.createElement(RPGUIContainer, {
|
|
34551
|
-
type: RPGUIContainerTypes.FramedGold,
|
|
34552
|
-
width: '50%',
|
|
34553
|
-
height: '180px'
|
|
34554
|
-
}, 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, {
|
|
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
|
-
})), React.createElement(ThumbnailContainer$1, null, React.createElement(NPCThumbnail$1, {
|
|
34570
|
-
src: textAndTypeArray[slide].imagePath || img$8
|
|
34571
|
-
})), showGoNextIndicator && React.createElement(PressSpaceIndicator$1, {
|
|
34572
|
-
right: '10.5rem',
|
|
34573
|
-
src: img$7
|
|
34574
|
-
})), textAndTypeArray[slide].imageSide === 'left' && React.createElement(React.Fragment, null, React.createElement(ThumbnailContainer$1, null, React.createElement(NPCThumbnail$1, {
|
|
34575
|
-
src: textAndTypeArray[slide].imagePath || img$8
|
|
34576
|
-
})), React.createElement(TextContainer$2, {
|
|
34577
|
-
flex: '70%'
|
|
34578
|
-
}, React.createElement(NPCDialogText, {
|
|
34579
|
-
onStartStep: function onStartStep() {
|
|
34580
|
-
return setShowGoNextIndicator(false);
|
|
34581
|
-
},
|
|
34582
|
-
onEndStep: function onEndStep() {
|
|
34583
|
-
return setShowGoNextIndicator(true);
|
|
34584
|
-
},
|
|
34585
|
-
text: textAndTypeArray[slide].text || 'No text provided.',
|
|
34586
|
-
onClose: function onClose() {
|
|
34587
|
-
if (_onClose) {
|
|
34588
|
-
_onClose();
|
|
34589
|
-
}
|
|
34590
|
-
}
|
|
34591
|
-
})), showGoNextIndicator && React.createElement(PressSpaceIndicator$1, {
|
|
34592
|
-
right: '1rem',
|
|
34593
|
-
src: img$7
|
|
34594
|
-
}))), ")"));
|
|
34595
|
-
};
|
|
34596
|
-
var Container$e = /*#__PURE__*/styled.div.withConfig({
|
|
34597
|
-
displayName: "NPCMultiDialog__Container",
|
|
34598
|
-
componentId: "sc-rvu5wg-0"
|
|
34599
|
-
})(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
|
|
34600
|
-
var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
|
|
34601
|
-
displayName: "NPCMultiDialog__TextContainer",
|
|
34602
|
-
componentId: "sc-rvu5wg-1"
|
|
34603
|
-
})(["flex:", " 0 0;width:355px;"], function (_ref2) {
|
|
34604
|
-
var flex = _ref2.flex;
|
|
34605
|
-
return flex;
|
|
34606
|
-
});
|
|
34607
|
-
var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
|
|
34608
|
-
displayName: "NPCMultiDialog__ThumbnailContainer",
|
|
34609
|
-
componentId: "sc-rvu5wg-2"
|
|
34610
|
-
})(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
|
|
34611
|
-
var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
|
|
34612
|
-
displayName: "NPCMultiDialog__NPCThumbnail",
|
|
34613
|
-
componentId: "sc-rvu5wg-3"
|
|
34614
|
-
})(["image-rendering:pixelated;height:128px;width:128px;"]);
|
|
34615
|
-
var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
|
|
34616
|
-
displayName: "NPCMultiDialog__PressSpaceIndicator",
|
|
34617
|
-
componentId: "sc-rvu5wg-4"
|
|
34618
|
-
})(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref3) {
|
|
34619
|
-
var right = _ref3.right;
|
|
34620
|
-
return right;
|
|
34621
|
-
});
|
|
34622
|
-
|
|
34623
|
-
var HistoryDialog = function HistoryDialog(_ref) {
|
|
34624
|
-
var backgroundImgPath = _ref.backgroundImgPath,
|
|
34625
|
-
fullCoverBackground = _ref.fullCoverBackground,
|
|
34626
|
-
questions = _ref.questions,
|
|
34627
|
-
answers = _ref.answers,
|
|
34628
|
-
text = _ref.text,
|
|
34629
|
-
imagePath = _ref.imagePath,
|
|
34630
|
-
textAndTypeArray = _ref.textAndTypeArray,
|
|
34631
|
-
onClose = _ref.onClose;
|
|
34632
|
-
var _useState = useState(0),
|
|
34633
|
-
img = _useState[0],
|
|
34634
|
-
setImage = _useState[1];
|
|
34635
|
-
var onHandleSpacePress = function onHandleSpacePress(event) {
|
|
34636
|
-
if (event.code === 'Space') {
|
|
34637
|
-
if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
|
|
34638
|
-
setImage(function (prev) {
|
|
34639
|
-
return prev + 1;
|
|
34640
|
-
});
|
|
34641
|
-
} else {
|
|
34642
|
-
// if there's no more text chunks, close the dialog
|
|
34643
|
-
onClose();
|
|
34644
|
-
}
|
|
34645
|
-
}
|
|
34646
|
-
};
|
|
34647
|
-
useEffect(function () {
|
|
34648
|
-
document.addEventListener('keydown', onHandleSpacePress);
|
|
34649
|
-
return function () {
|
|
34650
|
-
return document.removeEventListener('keydown', onHandleSpacePress);
|
|
34651
|
-
};
|
|
34652
|
-
}, [backgroundImgPath]);
|
|
34653
|
-
return React.createElement(BackgroundContainer, {
|
|
34654
|
-
imgPath: backgroundImgPath[img],
|
|
34655
|
-
fullImg: fullCoverBackground
|
|
34656
|
-
}, React.createElement(DialogContainer, null, textAndTypeArray ? React.createElement(NPCMultiDialog, {
|
|
34657
|
-
textAndTypeArray: textAndTypeArray,
|
|
34658
|
-
onClose: onClose
|
|
34659
|
-
}) : questions && answers ? React.createElement(QuestionDialog, {
|
|
34660
|
-
questions: questions,
|
|
34661
|
-
answers: answers,
|
|
34662
|
-
onClose: onClose
|
|
34663
|
-
}) : text && imagePath ? React.createElement(NPCDialog, {
|
|
34664
|
-
text: text,
|
|
34665
|
-
imagePath: imagePath,
|
|
34666
|
-
onClose: onClose,
|
|
34667
|
-
type: NPCDialogType.TextAndThumbnail
|
|
34668
|
-
}) : React.createElement(NPCDialog, {
|
|
34669
|
-
text: text,
|
|
34670
|
-
onClose: onClose,
|
|
34671
|
-
type: NPCDialogType.TextOnly
|
|
34672
|
-
})));
|
|
34673
|
-
};
|
|
34674
|
-
var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
|
|
34675
|
-
displayName: "HistoryDialog__BackgroundContainer",
|
|
34676
|
-
componentId: "sc-u6oe75-0"
|
|
34677
|
-
})(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
|
|
34678
|
-
return props.imgPath;
|
|
34679
|
-
}, function (props) {
|
|
34680
|
-
return props.imgPath ? 'cover' : 'auto';
|
|
34681
|
-
});
|
|
34682
|
-
var DialogContainer = /*#__PURE__*/styled.div.withConfig({
|
|
34683
|
-
displayName: "HistoryDialog__DialogContainer",
|
|
34684
|
-
componentId: "sc-u6oe75-1"
|
|
34685
|
-
})(["display:flex;justify-content:center;padding-top:200px;"]);
|
|
34686
|
-
|
|
34687
34143
|
var SlotsContainer = function SlotsContainer(_ref) {
|
|
34688
34144
|
var children = _ref.children,
|
|
34689
34145
|
title = _ref.title,
|
|
@@ -34943,163 +34399,489 @@ var ItemContainer$1 = function ItemContainer(_ref) {
|
|
|
34943
34399
|
atlasJSON: atlasJSON
|
|
34944
34400
|
}));
|
|
34945
34401
|
}
|
|
34946
|
-
return slots;
|
|
34402
|
+
return slots;
|
|
34403
|
+
};
|
|
34404
|
+
return React.createElement(React.Fragment, null, React.createElement(SlotsContainer, {
|
|
34405
|
+
title: itemContainer.name || 'Container',
|
|
34406
|
+
onClose: onClose,
|
|
34407
|
+
initialPosition: initialPosition
|
|
34408
|
+
}, React.createElement(ItemsContainer, {
|
|
34409
|
+
className: "item-container-body"
|
|
34410
|
+
}, onRenderSlots())), quantitySelect.isOpen && React.createElement(QuantitySelectorContainer, null, React.createElement(ItemQuantitySelector, {
|
|
34411
|
+
quantity: quantitySelect.maxQuantity,
|
|
34412
|
+
onConfirm: function onConfirm(quantity) {
|
|
34413
|
+
quantitySelect.callback(quantity);
|
|
34414
|
+
setQuantitySelect({
|
|
34415
|
+
isOpen: false,
|
|
34416
|
+
maxQuantity: 1,
|
|
34417
|
+
callback: function callback() {}
|
|
34418
|
+
});
|
|
34419
|
+
},
|
|
34420
|
+
onClose: function onClose() {
|
|
34421
|
+
quantitySelect.callback(-1);
|
|
34422
|
+
setQuantitySelect({
|
|
34423
|
+
isOpen: false,
|
|
34424
|
+
maxQuantity: 1,
|
|
34425
|
+
callback: function callback() {}
|
|
34426
|
+
});
|
|
34427
|
+
}
|
|
34428
|
+
})));
|
|
34429
|
+
};
|
|
34430
|
+
var ItemsContainer = /*#__PURE__*/styled.div.withConfig({
|
|
34431
|
+
displayName: "ItemContainer__ItemsContainer",
|
|
34432
|
+
componentId: "sc-15y5p9l-0"
|
|
34433
|
+
})(["max-width:280px;display:flex;justify-content:center;flex-wrap:wrap;"]);
|
|
34434
|
+
var QuantitySelectorContainer = /*#__PURE__*/styled.div.withConfig({
|
|
34435
|
+
displayName: "ItemContainer__QuantitySelectorContainer",
|
|
34436
|
+
componentId: "sc-15y5p9l-1"
|
|
34437
|
+
})(["position:absolute;top:0;left:0;width:100vw;height:100vh;z-index:100;display:flex;justify-content:center;align-items:center;background-color:rgba(0,0,0,0.5);"]);
|
|
34438
|
+
|
|
34439
|
+
var ItemSelector = function ItemSelector(_ref) {
|
|
34440
|
+
var atlasIMG = _ref.atlasIMG,
|
|
34441
|
+
atlasJSON = _ref.atlasJSON,
|
|
34442
|
+
options = _ref.options,
|
|
34443
|
+
onClose = _ref.onClose,
|
|
34444
|
+
onSelect = _ref.onSelect;
|
|
34445
|
+
var _useState = useState(),
|
|
34446
|
+
selectedValue = _useState[0],
|
|
34447
|
+
setSelectedValue = _useState[1];
|
|
34448
|
+
var handleClick = function handleClick() {
|
|
34449
|
+
var element = document.querySelector("input[name='test']:checked");
|
|
34450
|
+
var elementValue = element.value;
|
|
34451
|
+
setSelectedValue(elementValue);
|
|
34452
|
+
};
|
|
34453
|
+
useEffect(function () {
|
|
34454
|
+
if (selectedValue) {
|
|
34455
|
+
onSelect(selectedValue);
|
|
34456
|
+
}
|
|
34457
|
+
}, [selectedValue]);
|
|
34458
|
+
return React.createElement(DraggableContainer, {
|
|
34459
|
+
type: RPGUIContainerTypes.Framed,
|
|
34460
|
+
width: "500px",
|
|
34461
|
+
cancelDrag: ".equipment-container-body .arrow-selector",
|
|
34462
|
+
onCloseButton: function onCloseButton() {
|
|
34463
|
+
if (onClose) {
|
|
34464
|
+
onClose();
|
|
34465
|
+
}
|
|
34466
|
+
}
|
|
34467
|
+
}, React.createElement("div", {
|
|
34468
|
+
style: {
|
|
34469
|
+
width: '100%'
|
|
34470
|
+
}
|
|
34471
|
+
}, React.createElement(Title$2, null, 'Harvesting instruments'), React.createElement(Subtitle$1, null, 'Use the tool, you need it'), React.createElement("hr", {
|
|
34472
|
+
className: "golden"
|
|
34473
|
+
})), React.createElement(RadioInputScroller$1, null, options == null ? void 0 : options.map(function (option, index) {
|
|
34474
|
+
return React.createElement(RadioOptionsWrapper$1, {
|
|
34475
|
+
key: index
|
|
34476
|
+
}, React.createElement(SpriteAtlasWrapper$1, null, React.createElement(SpriteFromAtlas, {
|
|
34477
|
+
atlasIMG: atlasIMG,
|
|
34478
|
+
atlasJSON: atlasJSON,
|
|
34479
|
+
spriteKey: option.imageKey,
|
|
34480
|
+
imgScale: 3
|
|
34481
|
+
})), React.createElement("div", null, React.createElement("input", {
|
|
34482
|
+
className: "rpgui-radio",
|
|
34483
|
+
type: "radio",
|
|
34484
|
+
value: option.name,
|
|
34485
|
+
name: "test"
|
|
34486
|
+
}), React.createElement("label", {
|
|
34487
|
+
onClick: handleClick,
|
|
34488
|
+
style: {
|
|
34489
|
+
display: 'flex',
|
|
34490
|
+
alignItems: 'center'
|
|
34491
|
+
}
|
|
34492
|
+
}, option.name, " ", React.createElement("br", null), option.description)));
|
|
34493
|
+
})), React.createElement(ButtonWrapper$1, null, React.createElement(Button, {
|
|
34494
|
+
buttonType: ButtonTypes.RPGUIButton,
|
|
34495
|
+
onClick: onClose
|
|
34496
|
+
}, "Cancel"), React.createElement(Button, {
|
|
34497
|
+
buttonType: ButtonTypes.RPGUIButton
|
|
34498
|
+
}, "Select")));
|
|
34499
|
+
};
|
|
34500
|
+
var Title$2 = /*#__PURE__*/styled.h1.withConfig({
|
|
34501
|
+
displayName: "ItemSelector__Title",
|
|
34502
|
+
componentId: "sc-gptoxp-0"
|
|
34503
|
+
})(["font-size:0.6rem;color:yellow !important;"]);
|
|
34504
|
+
var Subtitle$1 = /*#__PURE__*/styled.h1.withConfig({
|
|
34505
|
+
displayName: "ItemSelector__Subtitle",
|
|
34506
|
+
componentId: "sc-gptoxp-1"
|
|
34507
|
+
})(["font-size:0.4rem;color:yellow !important;"]);
|
|
34508
|
+
var RadioInputScroller$1 = /*#__PURE__*/styled.div.withConfig({
|
|
34509
|
+
displayName: "ItemSelector__RadioInputScroller",
|
|
34510
|
+
componentId: "sc-gptoxp-2"
|
|
34511
|
+
})(["padding-left:15px;padding-top:10px;width:100%;margin-top:1rem;align-items:center;margin-left:20px;align-items:flex-start;overflow-y:scroll;height:360px;"]);
|
|
34512
|
+
var SpriteAtlasWrapper$1 = /*#__PURE__*/styled.div.withConfig({
|
|
34513
|
+
displayName: "ItemSelector__SpriteAtlasWrapper",
|
|
34514
|
+
componentId: "sc-gptoxp-3"
|
|
34515
|
+
})(["margin-right:40px;"]);
|
|
34516
|
+
var RadioOptionsWrapper$1 = /*#__PURE__*/styled.div.withConfig({
|
|
34517
|
+
displayName: "ItemSelector__RadioOptionsWrapper",
|
|
34518
|
+
componentId: "sc-gptoxp-4"
|
|
34519
|
+
})(["display:flex;align-items:stretch;margin-bottom:40px;"]);
|
|
34520
|
+
var ButtonWrapper$1 = /*#__PURE__*/styled.div.withConfig({
|
|
34521
|
+
displayName: "ItemSelector__ButtonWrapper",
|
|
34522
|
+
componentId: "sc-gptoxp-5"
|
|
34523
|
+
})(["display:flex;justify-content:space-around;padding-top:20px;width:100%;"]);
|
|
34524
|
+
|
|
34525
|
+
var ListMenu = function ListMenu(_ref) {
|
|
34526
|
+
var options = _ref.options,
|
|
34527
|
+
onSelected = _ref.onSelected,
|
|
34528
|
+
x = _ref.x,
|
|
34529
|
+
y = _ref.y;
|
|
34530
|
+
return React.createElement(Container$b, {
|
|
34531
|
+
x: x,
|
|
34532
|
+
y: y
|
|
34533
|
+
}, React.createElement("ul", {
|
|
34534
|
+
className: "rpgui-list-imp",
|
|
34535
|
+
style: {
|
|
34536
|
+
overflow: 'hidden'
|
|
34537
|
+
}
|
|
34538
|
+
}, options.map(function (params, index) {
|
|
34539
|
+
return React.createElement(ListElement$1, {
|
|
34540
|
+
key: (params == null ? void 0 : params.id) || index,
|
|
34541
|
+
onClick: function onClick() {
|
|
34542
|
+
onSelected(params == null ? void 0 : params.id);
|
|
34543
|
+
}
|
|
34544
|
+
}, (params == null ? void 0 : params.text) || 'No text');
|
|
34545
|
+
})));
|
|
34546
|
+
};
|
|
34547
|
+
var Container$b = /*#__PURE__*/styled.div.withConfig({
|
|
34548
|
+
displayName: "ListMenu__Container",
|
|
34549
|
+
componentId: "sc-i9097t-0"
|
|
34550
|
+
})(["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) {
|
|
34551
|
+
return props.y || 0;
|
|
34552
|
+
}, function (props) {
|
|
34553
|
+
return props.x || 0;
|
|
34554
|
+
}, uiFonts.size.xsmall);
|
|
34555
|
+
var ListElement$1 = /*#__PURE__*/styled.li.withConfig({
|
|
34556
|
+
displayName: "ListMenu__ListElement",
|
|
34557
|
+
componentId: "sc-i9097t-1"
|
|
34558
|
+
})(["margin-right:0.5rem;"]);
|
|
34559
|
+
|
|
34560
|
+
var img$6 = '';
|
|
34561
|
+
|
|
34562
|
+
var img$7 = '';
|
|
34563
|
+
|
|
34564
|
+
var ImgSide;
|
|
34565
|
+
(function (ImgSide) {
|
|
34566
|
+
ImgSide["right"] = "right";
|
|
34567
|
+
ImgSide["left"] = "left";
|
|
34568
|
+
})(ImgSide || (ImgSide = {}));
|
|
34569
|
+
var NPCMultiDialog = function NPCMultiDialog(_ref) {
|
|
34570
|
+
var _textAndTypeArray$sli;
|
|
34571
|
+
var _onClose = _ref.onClose,
|
|
34572
|
+
textAndTypeArray = _ref.textAndTypeArray;
|
|
34573
|
+
var _useState = useState(false),
|
|
34574
|
+
showGoNextIndicator = _useState[0],
|
|
34575
|
+
setShowGoNextIndicator = _useState[1];
|
|
34576
|
+
var _useState2 = useState(0),
|
|
34577
|
+
slide = _useState2[0],
|
|
34578
|
+
setSlide = _useState2[1];
|
|
34579
|
+
var onHandleSpacePress = function onHandleSpacePress(event) {
|
|
34580
|
+
if (event.code === 'Space') {
|
|
34581
|
+
if (slide < (textAndTypeArray == null ? void 0 : textAndTypeArray.length) - 1) {
|
|
34582
|
+
setSlide(function (prev) {
|
|
34583
|
+
return prev + 1;
|
|
34584
|
+
});
|
|
34585
|
+
} else {
|
|
34586
|
+
// if there's no more text chunks, close the dialog
|
|
34587
|
+
_onClose();
|
|
34588
|
+
}
|
|
34589
|
+
}
|
|
34590
|
+
};
|
|
34591
|
+
useEffect(function () {
|
|
34592
|
+
document.addEventListener('keydown', onHandleSpacePress);
|
|
34593
|
+
return function () {
|
|
34594
|
+
return document.removeEventListener('keydown', onHandleSpacePress);
|
|
34595
|
+
};
|
|
34596
|
+
}, [slide]);
|
|
34597
|
+
return React.createElement(RPGUIContainer, {
|
|
34598
|
+
type: RPGUIContainerTypes.FramedGold,
|
|
34599
|
+
width: '50%',
|
|
34600
|
+
height: '180px'
|
|
34601
|
+
}, React.createElement(React.Fragment, null, React.createElement(Container$c, null, ((_textAndTypeArray$sli = textAndTypeArray[slide]) == null ? void 0 : _textAndTypeArray$sli.imageSide) === 'right' && React.createElement(React.Fragment, null, React.createElement(TextContainer, {
|
|
34602
|
+
flex: '70%'
|
|
34603
|
+
}, React.createElement(NPCDialogText, {
|
|
34604
|
+
onStartStep: function onStartStep() {
|
|
34605
|
+
return setShowGoNextIndicator(false);
|
|
34606
|
+
},
|
|
34607
|
+
onEndStep: function onEndStep() {
|
|
34608
|
+
return setShowGoNextIndicator(true);
|
|
34609
|
+
},
|
|
34610
|
+
text: textAndTypeArray[slide].text || 'No text provided.',
|
|
34611
|
+
onClose: function onClose() {
|
|
34612
|
+
if (_onClose) {
|
|
34613
|
+
_onClose();
|
|
34614
|
+
}
|
|
34615
|
+
}
|
|
34616
|
+
})), React.createElement(ThumbnailContainer, null, React.createElement(NPCThumbnail, {
|
|
34617
|
+
src: textAndTypeArray[slide].imagePath || img$6
|
|
34618
|
+
})), showGoNextIndicator && React.createElement(PressSpaceIndicator, {
|
|
34619
|
+
right: '10.5rem',
|
|
34620
|
+
src: img$7
|
|
34621
|
+
})), textAndTypeArray[slide].imageSide === 'left' && React.createElement(React.Fragment, null, React.createElement(ThumbnailContainer, null, React.createElement(NPCThumbnail, {
|
|
34622
|
+
src: textAndTypeArray[slide].imagePath || img$6
|
|
34623
|
+
})), React.createElement(TextContainer, {
|
|
34624
|
+
flex: '70%'
|
|
34625
|
+
}, React.createElement(NPCDialogText, {
|
|
34626
|
+
onStartStep: function onStartStep() {
|
|
34627
|
+
return setShowGoNextIndicator(false);
|
|
34628
|
+
},
|
|
34629
|
+
onEndStep: function onEndStep() {
|
|
34630
|
+
return setShowGoNextIndicator(true);
|
|
34631
|
+
},
|
|
34632
|
+
text: textAndTypeArray[slide].text || 'No text provided.',
|
|
34633
|
+
onClose: function onClose() {
|
|
34634
|
+
if (_onClose) {
|
|
34635
|
+
_onClose();
|
|
34636
|
+
}
|
|
34637
|
+
}
|
|
34638
|
+
})), showGoNextIndicator && React.createElement(PressSpaceIndicator, {
|
|
34639
|
+
right: '1rem',
|
|
34640
|
+
src: img$7
|
|
34641
|
+
}))), ")"));
|
|
34642
|
+
};
|
|
34643
|
+
var Container$c = /*#__PURE__*/styled.div.withConfig({
|
|
34644
|
+
displayName: "NPCMultiDialog__Container",
|
|
34645
|
+
componentId: "sc-rvu5wg-0"
|
|
34646
|
+
})(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
|
|
34647
|
+
var TextContainer = /*#__PURE__*/styled.div.withConfig({
|
|
34648
|
+
displayName: "NPCMultiDialog__TextContainer",
|
|
34649
|
+
componentId: "sc-rvu5wg-1"
|
|
34650
|
+
})(["flex:", " 0 0;width:355px;"], function (_ref2) {
|
|
34651
|
+
var flex = _ref2.flex;
|
|
34652
|
+
return flex;
|
|
34653
|
+
});
|
|
34654
|
+
var ThumbnailContainer = /*#__PURE__*/styled.div.withConfig({
|
|
34655
|
+
displayName: "NPCMultiDialog__ThumbnailContainer",
|
|
34656
|
+
componentId: "sc-rvu5wg-2"
|
|
34657
|
+
})(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
|
|
34658
|
+
var NPCThumbnail = /*#__PURE__*/styled.img.withConfig({
|
|
34659
|
+
displayName: "NPCMultiDialog__NPCThumbnail",
|
|
34660
|
+
componentId: "sc-rvu5wg-3"
|
|
34661
|
+
})(["image-rendering:pixelated;height:128px;width:128px;"]);
|
|
34662
|
+
var PressSpaceIndicator = /*#__PURE__*/styled.img.withConfig({
|
|
34663
|
+
displayName: "NPCMultiDialog__PressSpaceIndicator",
|
|
34664
|
+
componentId: "sc-rvu5wg-4"
|
|
34665
|
+
})(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref3) {
|
|
34666
|
+
var right = _ref3.right;
|
|
34667
|
+
return right;
|
|
34668
|
+
});
|
|
34669
|
+
|
|
34670
|
+
//@ts-ignore
|
|
34671
|
+
var useEventListener = function useEventListener(type, handler, el) {
|
|
34672
|
+
if (el === void 0) {
|
|
34673
|
+
el = window;
|
|
34674
|
+
}
|
|
34675
|
+
var savedHandler = React.useRef();
|
|
34676
|
+
React.useEffect(function () {
|
|
34677
|
+
savedHandler.current = handler;
|
|
34678
|
+
}, [handler]);
|
|
34679
|
+
React.useEffect(function () {
|
|
34680
|
+
//@ts-ignore
|
|
34681
|
+
var listener = function listener(e) {
|
|
34682
|
+
return savedHandler.current(e);
|
|
34683
|
+
};
|
|
34684
|
+
el.addEventListener(type, listener);
|
|
34685
|
+
return function () {
|
|
34686
|
+
el.removeEventListener(type, listener);
|
|
34687
|
+
};
|
|
34688
|
+
}, [type, el]);
|
|
34689
|
+
};
|
|
34690
|
+
|
|
34691
|
+
var DynamicText = function DynamicText(_ref) {
|
|
34692
|
+
var text = _ref.text,
|
|
34693
|
+
onFinish = _ref.onFinish,
|
|
34694
|
+
onStart = _ref.onStart;
|
|
34695
|
+
var _useState = useState(''),
|
|
34696
|
+
textState = _useState[0],
|
|
34697
|
+
setTextState = _useState[1];
|
|
34698
|
+
useEffect(function () {
|
|
34699
|
+
var i = 0;
|
|
34700
|
+
var interval = setInterval(function () {
|
|
34701
|
+
// on every interval, show one more character
|
|
34702
|
+
if (i === 0) {
|
|
34703
|
+
if (onStart) {
|
|
34704
|
+
onStart();
|
|
34705
|
+
}
|
|
34706
|
+
}
|
|
34707
|
+
if (i < text.length) {
|
|
34708
|
+
setTextState(text.substring(0, i + 1));
|
|
34709
|
+
i++;
|
|
34710
|
+
} else {
|
|
34711
|
+
clearInterval(interval);
|
|
34712
|
+
if (onFinish) {
|
|
34713
|
+
onFinish();
|
|
34714
|
+
}
|
|
34715
|
+
}
|
|
34716
|
+
}, 50);
|
|
34717
|
+
return function () {
|
|
34718
|
+
clearInterval(interval);
|
|
34719
|
+
};
|
|
34720
|
+
}, [text]);
|
|
34721
|
+
return React.createElement(TextContainer$1, null, textState);
|
|
34722
|
+
};
|
|
34723
|
+
var TextContainer$1 = /*#__PURE__*/styled.p.withConfig({
|
|
34724
|
+
displayName: "DynamicText__TextContainer",
|
|
34725
|
+
componentId: "sc-1ggl9nd-0"
|
|
34726
|
+
})(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]);
|
|
34727
|
+
|
|
34728
|
+
var QuestionDialog = function QuestionDialog(_ref) {
|
|
34729
|
+
var questions = _ref.questions,
|
|
34730
|
+
answers = _ref.answers,
|
|
34731
|
+
onClose = _ref.onClose;
|
|
34732
|
+
var _useState = useState(questions[0]),
|
|
34733
|
+
currentQuestion = _useState[0],
|
|
34734
|
+
setCurrentQuestion = _useState[1];
|
|
34735
|
+
var _useState2 = useState(false),
|
|
34736
|
+
canShowAnswers = _useState2[0],
|
|
34737
|
+
setCanShowAnswers = _useState2[1];
|
|
34738
|
+
var onGetFirstAnswer = function onGetFirstAnswer() {
|
|
34739
|
+
if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {
|
|
34740
|
+
return null;
|
|
34741
|
+
}
|
|
34742
|
+
var firstAnswerId = currentQuestion.answerIds[0];
|
|
34743
|
+
return answers.find(function (answer) {
|
|
34744
|
+
return answer.id === firstAnswerId;
|
|
34745
|
+
});
|
|
34947
34746
|
};
|
|
34948
|
-
|
|
34949
|
-
|
|
34950
|
-
|
|
34951
|
-
|
|
34952
|
-
|
|
34953
|
-
|
|
34954
|
-
|
|
34955
|
-
|
|
34956
|
-
|
|
34957
|
-
|
|
34958
|
-
setQuantitySelect({
|
|
34959
|
-
isOpen: false,
|
|
34960
|
-
maxQuantity: 1,
|
|
34961
|
-
callback: function callback() {}
|
|
34962
|
-
});
|
|
34963
|
-
},
|
|
34964
|
-
onClose: function onClose() {
|
|
34965
|
-
quantitySelect.callback(-1);
|
|
34966
|
-
setQuantitySelect({
|
|
34967
|
-
isOpen: false,
|
|
34968
|
-
maxQuantity: 1,
|
|
34969
|
-
callback: function callback() {}
|
|
34747
|
+
var _useState3 = useState(onGetFirstAnswer()),
|
|
34748
|
+
currentAnswer = _useState3[0],
|
|
34749
|
+
setCurrentAnswer = _useState3[1];
|
|
34750
|
+
useEffect(function () {
|
|
34751
|
+
setCurrentAnswer(onGetFirstAnswer());
|
|
34752
|
+
}, [currentQuestion]);
|
|
34753
|
+
var onGetAnswers = function onGetAnswers(answerIds) {
|
|
34754
|
+
return answerIds.map(function (answerId) {
|
|
34755
|
+
return answers.find(function (answer) {
|
|
34756
|
+
return answer.id === answerId;
|
|
34970
34757
|
});
|
|
34758
|
+
});
|
|
34759
|
+
};
|
|
34760
|
+
var onKeyPress = function onKeyPress(e) {
|
|
34761
|
+
switch (e.key) {
|
|
34762
|
+
case 'ArrowDown':
|
|
34763
|
+
// select next answer, if any.
|
|
34764
|
+
// if no next answer, select first answer
|
|
34765
|
+
// const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(
|
|
34766
|
+
// (answer) => answer?.id === currentAnswer!.id + 1
|
|
34767
|
+
// );
|
|
34768
|
+
var nextAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
|
|
34769
|
+
return (answer == null ? void 0 : answer.id) === currentAnswer.id + 1;
|
|
34770
|
+
});
|
|
34771
|
+
var nextAnswerID = currentQuestion.answerIds[nextAnswerIndex];
|
|
34772
|
+
var nextAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
|
|
34773
|
+
return (answer == null ? void 0 : answer.id) === nextAnswerID;
|
|
34774
|
+
});
|
|
34775
|
+
setCurrentAnswer(nextAnswer || onGetFirstAnswer());
|
|
34776
|
+
break;
|
|
34777
|
+
case 'ArrowUp':
|
|
34778
|
+
// select previous answer, if any.
|
|
34779
|
+
// if no previous answer, select last answer
|
|
34780
|
+
var previousAnswerIndex = onGetAnswers(currentQuestion.answerIds).findIndex(function (answer) {
|
|
34781
|
+
return (answer == null ? void 0 : answer.id) === currentAnswer.id - 1;
|
|
34782
|
+
});
|
|
34783
|
+
var previousAnswerID = currentQuestion.answerIds && currentQuestion.answerIds[previousAnswerIndex];
|
|
34784
|
+
var previousAnswer = onGetAnswers(currentQuestion.answerIds).find(function (answer) {
|
|
34785
|
+
return (answer == null ? void 0 : answer.id) === previousAnswerID;
|
|
34786
|
+
});
|
|
34787
|
+
if (previousAnswer) {
|
|
34788
|
+
setCurrentAnswer(previousAnswer);
|
|
34789
|
+
} else {
|
|
34790
|
+
setCurrentAnswer(onGetAnswers(currentQuestion.answerIds).pop());
|
|
34791
|
+
}
|
|
34792
|
+
break;
|
|
34793
|
+
case 'Enter':
|
|
34794
|
+
setCanShowAnswers(false);
|
|
34795
|
+
if (!(currentAnswer != null && currentAnswer.nextQuestionId)) {
|
|
34796
|
+
onClose();
|
|
34797
|
+
return;
|
|
34798
|
+
} else {
|
|
34799
|
+
setCurrentQuestion(questions.find(function (question) {
|
|
34800
|
+
return question.id === currentAnswer.nextQuestionId;
|
|
34801
|
+
}));
|
|
34802
|
+
}
|
|
34803
|
+
break;
|
|
34971
34804
|
}
|
|
34972
|
-
})));
|
|
34973
|
-
};
|
|
34974
|
-
var ItemsContainer = /*#__PURE__*/styled.div.withConfig({
|
|
34975
|
-
displayName: "ItemContainer__ItemsContainer",
|
|
34976
|
-
componentId: "sc-15y5p9l-0"
|
|
34977
|
-
})(["max-width:280px;display:flex;justify-content:center;flex-wrap:wrap;"]);
|
|
34978
|
-
var QuantitySelectorContainer = /*#__PURE__*/styled.div.withConfig({
|
|
34979
|
-
displayName: "ItemContainer__QuantitySelectorContainer",
|
|
34980
|
-
componentId: "sc-15y5p9l-1"
|
|
34981
|
-
})(["position:absolute;top:0;left:0;width:100vw;height:100vh;z-index:100;display:flex;justify-content:center;align-items:center;background-color:rgba(0,0,0,0.5);"]);
|
|
34982
|
-
|
|
34983
|
-
var ItemSelector = function ItemSelector(_ref) {
|
|
34984
|
-
var atlasIMG = _ref.atlasIMG,
|
|
34985
|
-
atlasJSON = _ref.atlasJSON,
|
|
34986
|
-
options = _ref.options,
|
|
34987
|
-
onClose = _ref.onClose,
|
|
34988
|
-
onSelect = _ref.onSelect;
|
|
34989
|
-
var _useState = useState(),
|
|
34990
|
-
selectedValue = _useState[0],
|
|
34991
|
-
setSelectedValue = _useState[1];
|
|
34992
|
-
var handleClick = function handleClick() {
|
|
34993
|
-
var element = document.querySelector("input[name='test']:checked");
|
|
34994
|
-
var elementValue = element.value;
|
|
34995
|
-
setSelectedValue(elementValue);
|
|
34996
34805
|
};
|
|
34997
|
-
|
|
34998
|
-
|
|
34999
|
-
|
|
34806
|
+
useEventListener('keydown', onKeyPress);
|
|
34807
|
+
var onAnswerClick = function onAnswerClick(answer) {
|
|
34808
|
+
setCanShowAnswers(false);
|
|
34809
|
+
if (answer.nextQuestionId) {
|
|
34810
|
+
// if there is a next question, go to it
|
|
34811
|
+
setCurrentQuestion(questions.find(function (question) {
|
|
34812
|
+
return question.id === answer.nextQuestionId;
|
|
34813
|
+
}));
|
|
34814
|
+
} else {
|
|
34815
|
+
// else, finish dialog!
|
|
34816
|
+
onClose();
|
|
35000
34817
|
}
|
|
35001
|
-
}
|
|
35002
|
-
|
|
35003
|
-
|
|
35004
|
-
|
|
35005
|
-
|
|
35006
|
-
onCloseButton: function onCloseButton() {
|
|
35007
|
-
if (onClose) {
|
|
35008
|
-
onClose();
|
|
35009
|
-
}
|
|
34818
|
+
};
|
|
34819
|
+
var onRenderCurrentAnswers = function onRenderCurrentAnswers() {
|
|
34820
|
+
var answerIds = currentQuestion.answerIds;
|
|
34821
|
+
if (!answerIds) {
|
|
34822
|
+
return null;
|
|
35010
34823
|
}
|
|
35011
|
-
|
|
35012
|
-
|
|
35013
|
-
|
|
34824
|
+
var answers = onGetAnswers(answerIds);
|
|
34825
|
+
if (!answers) {
|
|
34826
|
+
return null;
|
|
35014
34827
|
}
|
|
35015
|
-
|
|
35016
|
-
|
|
35017
|
-
|
|
35018
|
-
|
|
35019
|
-
|
|
35020
|
-
|
|
35021
|
-
|
|
35022
|
-
|
|
35023
|
-
|
|
35024
|
-
|
|
35025
|
-
|
|
35026
|
-
|
|
35027
|
-
|
|
35028
|
-
|
|
35029
|
-
|
|
35030
|
-
}), React.createElement("label", {
|
|
35031
|
-
onClick: handleClick,
|
|
35032
|
-
style: {
|
|
35033
|
-
display: 'flex',
|
|
35034
|
-
alignItems: 'center'
|
|
34828
|
+
return answers.map(function (answer) {
|
|
34829
|
+
var isSelected = (currentAnswer == null ? void 0 : currentAnswer.id) === (answer == null ? void 0 : answer.id);
|
|
34830
|
+
var selectedColor = isSelected ? 'yellow' : 'white';
|
|
34831
|
+
if (answer) {
|
|
34832
|
+
return React.createElement(AnswerRow, {
|
|
34833
|
+
key: "answer_" + answer.id
|
|
34834
|
+
}, React.createElement(AnswerSelectedIcon, {
|
|
34835
|
+
color: selectedColor
|
|
34836
|
+
}, isSelected ? 'X' : null), React.createElement(Answer, {
|
|
34837
|
+
key: answer.id,
|
|
34838
|
+
onClick: function onClick() {
|
|
34839
|
+
return onAnswerClick(answer);
|
|
34840
|
+
},
|
|
34841
|
+
color: selectedColor
|
|
34842
|
+
}, answer.text));
|
|
35035
34843
|
}
|
|
35036
|
-
|
|
35037
|
-
|
|
35038
|
-
|
|
35039
|
-
|
|
35040
|
-
|
|
35041
|
-
|
|
35042
|
-
|
|
35043
|
-
}
|
|
35044
|
-
|
|
35045
|
-
|
|
35046
|
-
componentId: "sc-gptoxp-0"
|
|
35047
|
-
})(["font-size:0.6rem;color:yellow !important;"]);
|
|
35048
|
-
var Subtitle$1 = /*#__PURE__*/styled.h1.withConfig({
|
|
35049
|
-
displayName: "ItemSelector__Subtitle",
|
|
35050
|
-
componentId: "sc-gptoxp-1"
|
|
35051
|
-
})(["font-size:0.4rem;color:yellow !important;"]);
|
|
35052
|
-
var RadioInputScroller$1 = /*#__PURE__*/styled.div.withConfig({
|
|
35053
|
-
displayName: "ItemSelector__RadioInputScroller",
|
|
35054
|
-
componentId: "sc-gptoxp-2"
|
|
35055
|
-
})(["padding-left:15px;padding-top:10px;width:100%;margin-top:1rem;align-items:center;margin-left:20px;align-items:flex-start;overflow-y:scroll;height:360px;"]);
|
|
35056
|
-
var SpriteAtlasWrapper$1 = /*#__PURE__*/styled.div.withConfig({
|
|
35057
|
-
displayName: "ItemSelector__SpriteAtlasWrapper",
|
|
35058
|
-
componentId: "sc-gptoxp-3"
|
|
35059
|
-
})(["margin-right:40px;"]);
|
|
35060
|
-
var RadioOptionsWrapper$1 = /*#__PURE__*/styled.div.withConfig({
|
|
35061
|
-
displayName: "ItemSelector__RadioOptionsWrapper",
|
|
35062
|
-
componentId: "sc-gptoxp-4"
|
|
35063
|
-
})(["display:flex;align-items:stretch;margin-bottom:40px;"]);
|
|
35064
|
-
var ButtonWrapper$1 = /*#__PURE__*/styled.div.withConfig({
|
|
35065
|
-
displayName: "ItemSelector__ButtonWrapper",
|
|
35066
|
-
componentId: "sc-gptoxp-5"
|
|
35067
|
-
})(["display:flex;justify-content:space-around;padding-top:20px;width:100%;"]);
|
|
35068
|
-
|
|
35069
|
-
var ListMenu = function ListMenu(_ref) {
|
|
35070
|
-
var options = _ref.options,
|
|
35071
|
-
onSelected = _ref.onSelected,
|
|
35072
|
-
x = _ref.x,
|
|
35073
|
-
y = _ref.y;
|
|
35074
|
-
return React.createElement(Container$f, {
|
|
35075
|
-
x: x,
|
|
35076
|
-
y: y
|
|
35077
|
-
}, React.createElement("ul", {
|
|
35078
|
-
className: "rpgui-list-imp",
|
|
35079
|
-
style: {
|
|
35080
|
-
overflow: 'hidden'
|
|
34844
|
+
return null;
|
|
34845
|
+
});
|
|
34846
|
+
};
|
|
34847
|
+
return React.createElement(Container$d, null, React.createElement(QuestionContainer, null, React.createElement(DynamicText, {
|
|
34848
|
+
text: currentQuestion.text,
|
|
34849
|
+
onStart: function onStart() {
|
|
34850
|
+
return setCanShowAnswers(false);
|
|
34851
|
+
},
|
|
34852
|
+
onFinish: function onFinish() {
|
|
34853
|
+
return setCanShowAnswers(true);
|
|
35081
34854
|
}
|
|
35082
|
-
},
|
|
35083
|
-
return React.createElement(ListElement$1, {
|
|
35084
|
-
key: (params == null ? void 0 : params.id) || index,
|
|
35085
|
-
onClick: function onClick() {
|
|
35086
|
-
onSelected(params == null ? void 0 : params.id);
|
|
35087
|
-
}
|
|
35088
|
-
}, (params == null ? void 0 : params.text) || 'No text');
|
|
35089
|
-
})));
|
|
34855
|
+
})), canShowAnswers && React.createElement(AnswersContainer, null, onRenderCurrentAnswers()));
|
|
35090
34856
|
};
|
|
35091
|
-
var Container$
|
|
35092
|
-
displayName: "
|
|
35093
|
-
componentId: "sc-
|
|
35094
|
-
})(["display:flex;
|
|
35095
|
-
|
|
35096
|
-
|
|
35097
|
-
|
|
35098
|
-
}
|
|
35099
|
-
var
|
|
35100
|
-
displayName: "
|
|
35101
|
-
componentId: "sc-
|
|
35102
|
-
})(["
|
|
34857
|
+
var Container$d = /*#__PURE__*/styled.div.withConfig({
|
|
34858
|
+
displayName: "QuestionDialog__Container",
|
|
34859
|
+
componentId: "sc-bxc5u0-0"
|
|
34860
|
+
})(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]);
|
|
34861
|
+
var QuestionContainer = /*#__PURE__*/styled.div.withConfig({
|
|
34862
|
+
displayName: "QuestionDialog__QuestionContainer",
|
|
34863
|
+
componentId: "sc-bxc5u0-1"
|
|
34864
|
+
})(["flex:100%;width:100%;"]);
|
|
34865
|
+
var AnswersContainer = /*#__PURE__*/styled.div.withConfig({
|
|
34866
|
+
displayName: "QuestionDialog__AnswersContainer",
|
|
34867
|
+
componentId: "sc-bxc5u0-2"
|
|
34868
|
+
})(["flex:100%;"]);
|
|
34869
|
+
var Answer = /*#__PURE__*/styled.p.withConfig({
|
|
34870
|
+
displayName: "QuestionDialog__Answer",
|
|
34871
|
+
componentId: "sc-bxc5u0-3"
|
|
34872
|
+
})(["flex:auto;color:", " !important;font-size:0.65rem !important;background:inherit;border:none;"], function (props) {
|
|
34873
|
+
return props.color;
|
|
34874
|
+
});
|
|
34875
|
+
var AnswerSelectedIcon = /*#__PURE__*/styled.span.withConfig({
|
|
34876
|
+
displayName: "QuestionDialog__AnswerSelectedIcon",
|
|
34877
|
+
componentId: "sc-bxc5u0-4"
|
|
34878
|
+
})(["flex:5% 0 0;color:", " !important;"], function (props) {
|
|
34879
|
+
return props.color;
|
|
34880
|
+
});
|
|
34881
|
+
var AnswerRow = /*#__PURE__*/styled.div.withConfig({
|
|
34882
|
+
displayName: "QuestionDialog__AnswerRow",
|
|
34883
|
+
componentId: "sc-bxc5u0-5"
|
|
34884
|
+
})(["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;}"]);
|
|
35103
34885
|
|
|
35104
34886
|
var ProgressBar = function ProgressBar(_ref) {
|
|
35105
34887
|
var max = _ref.max,
|
|
@@ -35118,7 +34900,7 @@ var ProgressBar = function ProgressBar(_ref) {
|
|
|
35118
34900
|
}
|
|
35119
34901
|
return value * 100 / max;
|
|
35120
34902
|
};
|
|
35121
|
-
return React.createElement(Container$
|
|
34903
|
+
return React.createElement(Container$e, {
|
|
35122
34904
|
className: "rpgui-progress",
|
|
35123
34905
|
"data-value": calculatePercentageValue(max, value) / 100,
|
|
35124
34906
|
"data-rpguitype": "progress",
|
|
@@ -35147,7 +34929,7 @@ var TextOverlay$1 = /*#__PURE__*/styled.div.withConfig({
|
|
|
35147
34929
|
displayName: "ProgressBar__TextOverlay",
|
|
35148
34930
|
componentId: "sc-qa6fzh-1"
|
|
35149
34931
|
})(["width:100%;position:relative;"]);
|
|
35150
|
-
var Container$
|
|
34932
|
+
var Container$e = /*#__PURE__*/styled.div.withConfig({
|
|
35151
34933
|
displayName: "ProgressBar__Container",
|
|
35152
34934
|
componentId: "sc-qa6fzh-2"
|
|
35153
34935
|
})(["display:flex;flex-direction:column;min-width:", "px;width:", "%;justify-content:start;align-items:flex-start;", ""], function (props) {
|
|
@@ -35158,7 +34940,7 @@ var Container$g = /*#__PURE__*/styled.div.withConfig({
|
|
|
35158
34940
|
return props.style;
|
|
35159
34941
|
});
|
|
35160
34942
|
|
|
35161
|
-
var img$
|
|
34943
|
+
var img$8 = '';
|
|
35162
34944
|
|
|
35163
34945
|
var QuestInfo = function QuestInfo(_ref) {
|
|
35164
34946
|
var quests = _ref.quests,
|
|
@@ -35202,7 +34984,7 @@ var QuestInfo = function QuestInfo(_ref) {
|
|
|
35202
34984
|
}), React.createElement(QuestContainer, null, React.createElement(TitleContainer$1, {
|
|
35203
34985
|
className: "drag-handler"
|
|
35204
34986
|
}, React.createElement(Title$3, null, React.createElement(Thumbnail, {
|
|
35205
|
-
src: quests[currentIndex].thumbnail || img$
|
|
34987
|
+
src: quests[currentIndex].thumbnail || img$8
|
|
35206
34988
|
}), quests[currentIndex].title), React.createElement(QuestSplitDiv, null, React.createElement("hr", {
|
|
35207
34989
|
className: "golden"
|
|
35208
34990
|
}))), React.createElement(Content, null, React.createElement("p", null, quests[currentIndex].description)), React.createElement(QuestColumn, {
|
|
@@ -35221,7 +35003,7 @@ var QuestInfo = function QuestInfo(_ref) {
|
|
|
35221
35003
|
})))) : React.createElement(QuestsContainer, null, React.createElement(QuestContainer, null, React.createElement(TitleContainer$1, {
|
|
35222
35004
|
className: "drag-handler"
|
|
35223
35005
|
}, React.createElement(Title$3, null, React.createElement(Thumbnail, {
|
|
35224
|
-
src: quests[0].thumbnail || img$
|
|
35006
|
+
src: quests[0].thumbnail || img$8
|
|
35225
35007
|
}), quests[0].title), React.createElement(QuestSplitDiv, null, React.createElement("hr", {
|
|
35226
35008
|
className: "golden"
|
|
35227
35009
|
}))), React.createElement(Content, null, React.createElement("p", null, quests[0].description)), React.createElement(QuestColumn, {
|
|
@@ -35370,7 +35152,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
|
|
|
35370
35152
|
bgColor = _ref$bgColor === void 0 ? 'red' : _ref$bgColor,
|
|
35371
35153
|
_ref$margin = _ref.margin,
|
|
35372
35154
|
margin = _ref$margin === void 0 ? 20 : _ref$margin;
|
|
35373
|
-
return React.createElement(Container$
|
|
35155
|
+
return React.createElement(Container$f, {
|
|
35374
35156
|
className: "simple-progress-bar"
|
|
35375
35157
|
}, React.createElement(ProgressBarContainer, {
|
|
35376
35158
|
margin: margin
|
|
@@ -35379,7 +35161,7 @@ var SimpleProgressBar = function SimpleProgressBar(_ref) {
|
|
|
35379
35161
|
bgColor: bgColor
|
|
35380
35162
|
}))));
|
|
35381
35163
|
};
|
|
35382
|
-
var Container$
|
|
35164
|
+
var Container$f = /*#__PURE__*/styled.div.withConfig({
|
|
35383
35165
|
displayName: "SimpleProgressBar__Container",
|
|
35384
35166
|
componentId: "sc-mbeil3-0"
|
|
35385
35167
|
})(["display:flex;justify-content:center;align-items:center;width:100%;"]);
|
|
@@ -35580,7 +35362,7 @@ var Spell = function Spell(_ref) {
|
|
|
35580
35362
|
isSettingShortcut = _ref.isSettingShortcut,
|
|
35581
35363
|
minMagicLevelRequired = _ref.minMagicLevelRequired;
|
|
35582
35364
|
var disabled = isSettingShortcut ? charMagicLevel < minMagicLevelRequired : manaCost > charMana || charMagicLevel < minMagicLevelRequired;
|
|
35583
|
-
return React.createElement(Container$
|
|
35365
|
+
return React.createElement(Container$g, {
|
|
35584
35366
|
disabled: disabled,
|
|
35585
35367
|
onClick: onClick == null ? void 0 : onClick.bind(null, spellKey),
|
|
35586
35368
|
isSettingShortcut: isSettingShortcut && !disabled,
|
|
@@ -35593,7 +35375,7 @@ var Spell = function Spell(_ref) {
|
|
|
35593
35375
|
className: "mana"
|
|
35594
35376
|
}, manaCost)));
|
|
35595
35377
|
};
|
|
35596
|
-
var Container$
|
|
35378
|
+
var Container$g = /*#__PURE__*/styled.button.withConfig({
|
|
35597
35379
|
displayName: "Spell__Container",
|
|
35598
35380
|
componentId: "sc-j96fa2-0"
|
|
35599
35381
|
})(["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) {
|
|
@@ -35713,7 +35495,7 @@ var Spellbook = function Spellbook(_ref) {
|
|
|
35713
35495
|
width: "inherit",
|
|
35714
35496
|
height: "inherit",
|
|
35715
35497
|
cancelDrag: "#spellbook-search, #shortcuts_list, .spell"
|
|
35716
|
-
}, React.createElement(Container$
|
|
35498
|
+
}, React.createElement(Container$h, null, React.createElement(Title$6, null, "Learned Spells"), React.createElement(SpellbookShortcuts, {
|
|
35717
35499
|
setSettingShortcutIndex: setSettingShortcutIndex,
|
|
35718
35500
|
settingShortcutIndex: settingShortcutIndex,
|
|
35719
35501
|
shortcuts: spellShortcuts,
|
|
@@ -35743,7 +35525,7 @@ var Title$6 = /*#__PURE__*/styled.h1.withConfig({
|
|
|
35743
35525
|
displayName: "Spellbook__Title",
|
|
35744
35526
|
componentId: "sc-r02nfq-0"
|
|
35745
35527
|
})(["font-size:", " !important;margin-bottom:0 !important;"], uiFonts.size.large);
|
|
35746
|
-
var Container$
|
|
35528
|
+
var Container$h = /*#__PURE__*/styled.div.withConfig({
|
|
35747
35529
|
displayName: "Spellbook__Container",
|
|
35748
35530
|
componentId: "sc-r02nfq-1"
|
|
35749
35531
|
})(["width:100%;height:100%;color:white;display:flex;flex-direction:column;"]);
|
|
@@ -35757,16 +35539,16 @@ var TextArea = function TextArea(_ref) {
|
|
|
35757
35539
|
return React.createElement("textarea", Object.assign({}, props));
|
|
35758
35540
|
};
|
|
35759
35541
|
|
|
35760
|
-
var img$
|
|
35542
|
+
var img$9 = '';
|
|
35761
35543
|
|
|
35762
|
-
var img$
|
|
35544
|
+
var img$a = '';
|
|
35763
35545
|
|
|
35764
|
-
var img$
|
|
35546
|
+
var img$b = '';
|
|
35765
35547
|
|
|
35766
35548
|
var DayNightPeriod = function DayNightPeriod(_ref) {
|
|
35767
35549
|
var _periodOfDaySrcFiles;
|
|
35768
35550
|
var periodOfDay = _ref.periodOfDay;
|
|
35769
|
-
var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[PeriodOfDay.Morning] = img$
|
|
35551
|
+
var periodOfDaySrcFiles = (_periodOfDaySrcFiles = {}, _periodOfDaySrcFiles[PeriodOfDay.Morning] = img$a, _periodOfDaySrcFiles[PeriodOfDay.Afternoon] = img$9, _periodOfDaySrcFiles[PeriodOfDay.Night] = img$b, _periodOfDaySrcFiles);
|
|
35770
35552
|
return React.createElement(GifContainer, null, React.createElement("img", {
|
|
35771
35553
|
src: periodOfDaySrcFiles[periodOfDay]
|
|
35772
35554
|
}));
|
|
@@ -35776,7 +35558,7 @@ var GifContainer = /*#__PURE__*/styled.div.withConfig({
|
|
|
35776
35558
|
componentId: "sc-10t97fw-0"
|
|
35777
35559
|
})(["width:100%;img{width:67%;}"]);
|
|
35778
35560
|
|
|
35779
|
-
var img$
|
|
35561
|
+
var img$c = '';
|
|
35780
35562
|
|
|
35781
35563
|
var TimeWidget = function TimeWidget(_ref) {
|
|
35782
35564
|
var onClose = _ref.onClose,
|
|
@@ -35791,7 +35573,7 @@ var TimeWidget = function TimeWidget(_ref) {
|
|
|
35791
35573
|
var WidgetContainer = /*#__PURE__*/styled.div.withConfig({
|
|
35792
35574
|
displayName: "TimeWidget__WidgetContainer",
|
|
35793
35575
|
componentId: "sc-1ja236h-0"
|
|
35794
|
-
})(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$
|
|
35576
|
+
})(["background-image:url(", ");background-size:10rem;background-repeat:no-repeat;width:10rem;position:absolute;height:100px;"], img$c);
|
|
35795
35577
|
var Time = /*#__PURE__*/styled.div.withConfig({
|
|
35796
35578
|
displayName: "TimeWidget__Time",
|
|
35797
35579
|
componentId: "sc-1ja236h-1"
|
|
@@ -36041,16 +35823,230 @@ var Truncate = function Truncate(_ref) {
|
|
|
36041
35823
|
var _ref$maxLines = _ref.maxLines,
|
|
36042
35824
|
maxLines = _ref$maxLines === void 0 ? 1 : _ref$maxLines,
|
|
36043
35825
|
children = _ref.children;
|
|
36044
|
-
return React.createElement(Container$
|
|
35826
|
+
return React.createElement(Container$i, {
|
|
36045
35827
|
maxLines: maxLines
|
|
36046
35828
|
}, children);
|
|
36047
35829
|
};
|
|
36048
|
-
var Container$
|
|
35830
|
+
var Container$i = /*#__PURE__*/styled.div.withConfig({
|
|
36049
35831
|
displayName: "Truncate__Container",
|
|
36050
35832
|
componentId: "sc-6x00qb-0"
|
|
36051
35833
|
})(["display:-webkit-box;max-width:100%;max-height:100%;-webkit-line-clamp:", ";-webkit-box-orient:vertical;overflow:hidden;"], function (props) {
|
|
36052
35834
|
return props.maxLines;
|
|
36053
35835
|
});
|
|
36054
35836
|
|
|
35837
|
+
var IS_MOBILE_OR_TABLET = /*#__PURE__*/isMobileOrTablet();
|
|
35838
|
+
|
|
35839
|
+
var chunkString = function chunkString(str, length) {
|
|
35840
|
+
return str.match(new RegExp('.{1,' + length + '}', 'g'));
|
|
35841
|
+
};
|
|
35842
|
+
|
|
35843
|
+
var img$d = '';
|
|
35844
|
+
|
|
35845
|
+
var NPCDialogText = function NPCDialogText(_ref) {
|
|
35846
|
+
var text = _ref.text,
|
|
35847
|
+
onClose = _ref.onClose,
|
|
35848
|
+
onEndStep = _ref.onEndStep,
|
|
35849
|
+
onStartStep = _ref.onStartStep,
|
|
35850
|
+
type = _ref.type;
|
|
35851
|
+
var windowSize = useRef([window.innerWidth, window.innerHeight]);
|
|
35852
|
+
function maxCharacters(width) {
|
|
35853
|
+
// Set the font size to 16 pixels
|
|
35854
|
+
var fontSize = 11.2;
|
|
35855
|
+
// Calculate the number of characters that can fit in one line
|
|
35856
|
+
var charactersPerLine = Math.floor(width / 2 / fontSize);
|
|
35857
|
+
// Calculate the number of lines that can fit in the div
|
|
35858
|
+
var linesPerDiv = Math.floor(180 / fontSize);
|
|
35859
|
+
// Calculate the maximum number of characters that can fit in the div
|
|
35860
|
+
var maxCharacters = charactersPerLine * linesPerDiv;
|
|
35861
|
+
// Return the maximum number of characters
|
|
35862
|
+
return Math.round(maxCharacters / 5);
|
|
35863
|
+
}
|
|
35864
|
+
var textChunks = chunkString(text, maxCharacters(windowSize.current[0]));
|
|
35865
|
+
var _useState = useState(0),
|
|
35866
|
+
chunkIndex = _useState[0],
|
|
35867
|
+
setChunkIndex = _useState[1];
|
|
35868
|
+
var onHandleSpacePress = function onHandleSpacePress(event) {
|
|
35869
|
+
if (event.code === 'Space') {
|
|
35870
|
+
goToNextStep();
|
|
35871
|
+
}
|
|
35872
|
+
};
|
|
35873
|
+
var goToNextStep = function goToNextStep() {
|
|
35874
|
+
var hasNextChunk = (textChunks == null ? void 0 : textChunks[chunkIndex + 1]) || false;
|
|
35875
|
+
if (hasNextChunk) {
|
|
35876
|
+
setChunkIndex(function (prev) {
|
|
35877
|
+
return prev + 1;
|
|
35878
|
+
});
|
|
35879
|
+
} else {
|
|
35880
|
+
// if there's no more text chunks, close the dialog
|
|
35881
|
+
onClose();
|
|
35882
|
+
}
|
|
35883
|
+
};
|
|
35884
|
+
useEffect(function () {
|
|
35885
|
+
document.addEventListener('keydown', onHandleSpacePress);
|
|
35886
|
+
return function () {
|
|
35887
|
+
return document.removeEventListener('keydown', onHandleSpacePress);
|
|
35888
|
+
};
|
|
35889
|
+
}, [chunkIndex]);
|
|
35890
|
+
var _useState2 = useState(false),
|
|
35891
|
+
showGoNextIndicator = _useState2[0],
|
|
35892
|
+
setShowGoNextIndicator = _useState2[1];
|
|
35893
|
+
return React.createElement(Container$j, null, React.createElement(DynamicText, {
|
|
35894
|
+
text: (textChunks == null ? void 0 : textChunks[chunkIndex]) || '',
|
|
35895
|
+
onFinish: function onFinish() {
|
|
35896
|
+
setShowGoNextIndicator(true);
|
|
35897
|
+
onEndStep && onEndStep();
|
|
35898
|
+
},
|
|
35899
|
+
onStart: function onStart() {
|
|
35900
|
+
setShowGoNextIndicator(false);
|
|
35901
|
+
onStartStep && onStartStep();
|
|
35902
|
+
}
|
|
35903
|
+
}), showGoNextIndicator && React.createElement(PressSpaceIndicator$1, {
|
|
35904
|
+
right: type === NPCDialogType.TextOnly ? '1rem' : '10.5rem',
|
|
35905
|
+
src: IS_MOBILE_OR_TABLET ? img$d : img$7,
|
|
35906
|
+
onClick: function onClick() {
|
|
35907
|
+
goToNextStep();
|
|
35908
|
+
}
|
|
35909
|
+
}));
|
|
35910
|
+
};
|
|
35911
|
+
var Container$j = /*#__PURE__*/styled.div.withConfig({
|
|
35912
|
+
displayName: "NPCDialogText__Container",
|
|
35913
|
+
componentId: "sc-1cxkdh9-0"
|
|
35914
|
+
})([""]);
|
|
35915
|
+
var PressSpaceIndicator$1 = /*#__PURE__*/styled.img.withConfig({
|
|
35916
|
+
displayName: "NPCDialogText__PressSpaceIndicator",
|
|
35917
|
+
componentId: "sc-1cxkdh9-1"
|
|
35918
|
+
})(["position:absolute;right:", ";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"], function (_ref2) {
|
|
35919
|
+
var right = _ref2.right;
|
|
35920
|
+
return right;
|
|
35921
|
+
});
|
|
35922
|
+
|
|
35923
|
+
var NPCDialogType;
|
|
35924
|
+
(function (NPCDialogType) {
|
|
35925
|
+
NPCDialogType["TextOnly"] = "TextOnly";
|
|
35926
|
+
NPCDialogType["TextAndThumbnail"] = "TextAndThumbnail";
|
|
35927
|
+
})(NPCDialogType || (NPCDialogType = {}));
|
|
35928
|
+
var NPCDialog = function NPCDialog(_ref) {
|
|
35929
|
+
var text = _ref.text,
|
|
35930
|
+
type = _ref.type,
|
|
35931
|
+
_onClose = _ref.onClose,
|
|
35932
|
+
imagePath = _ref.imagePath,
|
|
35933
|
+
_ref$isQuestionDialog = _ref.isQuestionDialog,
|
|
35934
|
+
isQuestionDialog = _ref$isQuestionDialog === void 0 ? false : _ref$isQuestionDialog,
|
|
35935
|
+
questions = _ref.questions,
|
|
35936
|
+
answers = _ref.answers;
|
|
35937
|
+
return React.createElement(RPGUIContainer, {
|
|
35938
|
+
type: RPGUIContainerTypes.FramedGold,
|
|
35939
|
+
width: isQuestionDialog ? '600px' : '80%',
|
|
35940
|
+
height: '180px'
|
|
35941
|
+
}, isQuestionDialog && questions && answers ? React.createElement(React.Fragment, null, React.createElement(TextContainer$2, {
|
|
35942
|
+
flex: type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'
|
|
35943
|
+
}, React.createElement(QuestionDialog, {
|
|
35944
|
+
questions: questions,
|
|
35945
|
+
answers: answers,
|
|
35946
|
+
onClose: function onClose() {
|
|
35947
|
+
if (_onClose) {
|
|
35948
|
+
_onClose();
|
|
35949
|
+
}
|
|
35950
|
+
}
|
|
35951
|
+
})), type === NPCDialogType.TextAndThumbnail && React.createElement(ThumbnailContainer$1, null, React.createElement(NPCThumbnail$1, {
|
|
35952
|
+
src: imagePath || img$6
|
|
35953
|
+
}))) : React.createElement(React.Fragment, null, React.createElement(Container$k, null, React.createElement(TextContainer$2, {
|
|
35954
|
+
flex: type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'
|
|
35955
|
+
}, React.createElement(NPCDialogText, {
|
|
35956
|
+
type: type,
|
|
35957
|
+
text: text || 'No text provided.',
|
|
35958
|
+
onClose: function onClose() {
|
|
35959
|
+
if (_onClose) {
|
|
35960
|
+
_onClose();
|
|
35961
|
+
}
|
|
35962
|
+
}
|
|
35963
|
+
})), type === NPCDialogType.TextAndThumbnail && React.createElement(ThumbnailContainer$1, null, React.createElement(NPCThumbnail$1, {
|
|
35964
|
+
src: imagePath || img$6
|
|
35965
|
+
})))));
|
|
35966
|
+
};
|
|
35967
|
+
var Container$k = /*#__PURE__*/styled.div.withConfig({
|
|
35968
|
+
displayName: "NPCDialog__Container",
|
|
35969
|
+
componentId: "sc-1b4aw74-0"
|
|
35970
|
+
})(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]);
|
|
35971
|
+
var TextContainer$2 = /*#__PURE__*/styled.div.withConfig({
|
|
35972
|
+
displayName: "NPCDialog__TextContainer",
|
|
35973
|
+
componentId: "sc-1b4aw74-1"
|
|
35974
|
+
})(["flex:", " 0 0;width:355px;"], function (_ref2) {
|
|
35975
|
+
var flex = _ref2.flex;
|
|
35976
|
+
return flex;
|
|
35977
|
+
});
|
|
35978
|
+
var ThumbnailContainer$1 = /*#__PURE__*/styled.div.withConfig({
|
|
35979
|
+
displayName: "NPCDialog__ThumbnailContainer",
|
|
35980
|
+
componentId: "sc-1b4aw74-2"
|
|
35981
|
+
})(["flex:30% 0 0;display:flex;justify-content:flex-end;"]);
|
|
35982
|
+
var NPCThumbnail$1 = /*#__PURE__*/styled.img.withConfig({
|
|
35983
|
+
displayName: "NPCDialog__NPCThumbnail",
|
|
35984
|
+
componentId: "sc-1b4aw74-3"
|
|
35985
|
+
})(["image-rendering:pixelated;height:128px;width:128px;"]);
|
|
35986
|
+
|
|
35987
|
+
var HistoryDialog = function HistoryDialog(_ref) {
|
|
35988
|
+
var backgroundImgPath = _ref.backgroundImgPath,
|
|
35989
|
+
fullCoverBackground = _ref.fullCoverBackground,
|
|
35990
|
+
questions = _ref.questions,
|
|
35991
|
+
answers = _ref.answers,
|
|
35992
|
+
text = _ref.text,
|
|
35993
|
+
imagePath = _ref.imagePath,
|
|
35994
|
+
textAndTypeArray = _ref.textAndTypeArray,
|
|
35995
|
+
onClose = _ref.onClose;
|
|
35996
|
+
var _useState = useState(0),
|
|
35997
|
+
img = _useState[0],
|
|
35998
|
+
setImage = _useState[1];
|
|
35999
|
+
var onHandleSpacePress = function onHandleSpacePress(event) {
|
|
36000
|
+
if (event.code === 'Space') {
|
|
36001
|
+
if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
|
|
36002
|
+
setImage(function (prev) {
|
|
36003
|
+
return prev + 1;
|
|
36004
|
+
});
|
|
36005
|
+
} else {
|
|
36006
|
+
// if there's no more text chunks, close the dialog
|
|
36007
|
+
onClose();
|
|
36008
|
+
}
|
|
36009
|
+
}
|
|
36010
|
+
};
|
|
36011
|
+
useEffect(function () {
|
|
36012
|
+
document.addEventListener('keydown', onHandleSpacePress);
|
|
36013
|
+
return function () {
|
|
36014
|
+
return document.removeEventListener('keydown', onHandleSpacePress);
|
|
36015
|
+
};
|
|
36016
|
+
}, [backgroundImgPath]);
|
|
36017
|
+
return React.createElement(BackgroundContainer, {
|
|
36018
|
+
imgPath: backgroundImgPath[img],
|
|
36019
|
+
fullImg: fullCoverBackground
|
|
36020
|
+
}, React.createElement(DialogContainer, null, textAndTypeArray ? React.createElement(NPCMultiDialog, {
|
|
36021
|
+
textAndTypeArray: textAndTypeArray,
|
|
36022
|
+
onClose: onClose
|
|
36023
|
+
}) : questions && answers ? React.createElement(QuestionDialog, {
|
|
36024
|
+
questions: questions,
|
|
36025
|
+
answers: answers,
|
|
36026
|
+
onClose: onClose
|
|
36027
|
+
}) : text && imagePath ? React.createElement(NPCDialog, {
|
|
36028
|
+
text: text,
|
|
36029
|
+
imagePath: imagePath,
|
|
36030
|
+
onClose: onClose,
|
|
36031
|
+
type: NPCDialogType.TextAndThumbnail
|
|
36032
|
+
}) : React.createElement(NPCDialog, {
|
|
36033
|
+
text: text,
|
|
36034
|
+
onClose: onClose,
|
|
36035
|
+
type: NPCDialogType.TextOnly
|
|
36036
|
+
})));
|
|
36037
|
+
};
|
|
36038
|
+
var BackgroundContainer = /*#__PURE__*/styled.div.withConfig({
|
|
36039
|
+
displayName: "HistoryDialog__BackgroundContainer",
|
|
36040
|
+
componentId: "sc-u6oe75-0"
|
|
36041
|
+
})(["width:100%;height:100%;background-image:url(", ");background-size:", ";display:flex;justify-content:space-evenly;align-items:center;"], function (props) {
|
|
36042
|
+
return props.imgPath;
|
|
36043
|
+
}, function (props) {
|
|
36044
|
+
return props.imgPath ? 'cover' : 'auto';
|
|
36045
|
+
});
|
|
36046
|
+
var DialogContainer = /*#__PURE__*/styled.div.withConfig({
|
|
36047
|
+
displayName: "HistoryDialog__DialogContainer",
|
|
36048
|
+
componentId: "sc-u6oe75-1"
|
|
36049
|
+
})(["display:flex;justify-content:center;padding-top:200px;"]);
|
|
36050
|
+
|
|
36055
36051
|
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 };
|
|
36056
36052
|
//# sourceMappingURL=long-bow.esm.js.map
|