@rpg-engine/long-bow 0.2.7 → 0.2.9
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/dist/components/QuestInfo/QuestInfo.d.ts +9 -9
- package/dist/components/QuestList.d.ts +11 -0
- package/dist/long-bow.cjs.development.js +150 -48
- 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 +150 -48
- package/dist/long-bow.esm.js.map +1 -1
- package/dist/stories/QuestList.stories.d.ts +8 -0
- package/package.json +6 -6
- package/src/components/Character/CharacterSelection.tsx +20 -18
- package/src/components/Item/Inventory/ItemSlot.tsx +31 -11
- package/src/components/PropertySelect/PropertySelect.tsx +9 -1
- package/src/components/QuestInfo/QuestInfo.tsx +149 -46
- package/src/components/QuestList.tsx +124 -0
- package/src/mocks/equipmentSet.mocks.ts +4 -6
- package/src/mocks/itemContainer.mocks.ts +10 -33
- package/src/stories/QuestInfo.stories.tsx +67 -36
- package/src/stories/QuestList.stories.tsx +54 -0
|
@@ -1,14 +1,14 @@
|
|
|
1
|
+
import { IQuest } from '@rpg-engine/shared';
|
|
1
2
|
import React from 'react';
|
|
2
|
-
export interface
|
|
3
|
-
title: string;
|
|
4
|
-
children: React.ReactNode;
|
|
5
|
-
onClose?: () => void;
|
|
6
|
-
button?: Array<IQuestButtonProps>;
|
|
7
|
-
thumbnail?: string;
|
|
8
|
-
}
|
|
9
|
-
export interface IQuestButtonProps {
|
|
3
|
+
export interface IQuestsButtonProps {
|
|
10
4
|
disabled: boolean;
|
|
11
5
|
title: string;
|
|
12
|
-
onClick: () => void;
|
|
6
|
+
onClick: (questId: string, npcId: string) => void;
|
|
7
|
+
}
|
|
8
|
+
export interface IQuestInfoProps {
|
|
9
|
+
onClose?: () => void;
|
|
10
|
+
buttons?: IQuestsButtonProps[];
|
|
11
|
+
quests: IQuest[];
|
|
12
|
+
onChangeQuest: (currentQuestIndex: number, currentQuestId: string) => void;
|
|
13
13
|
}
|
|
14
14
|
export declare const QuestInfo: React.FC<IQuestInfoProps>;
|
|
@@ -20393,7 +20393,18 @@ var PropertySelect = function PropertySelect(_ref) {
|
|
|
20393
20393
|
React.useEffect(function () {
|
|
20394
20394
|
onChange(availableProperties[currentIndex]);
|
|
20395
20395
|
}, [currentIndex]);
|
|
20396
|
-
|
|
20396
|
+
|
|
20397
|
+
var getCurrentSelectionName = function getCurrentSelectionName() {
|
|
20398
|
+
var item = availableProperties[currentIndex];
|
|
20399
|
+
|
|
20400
|
+
if (item) {
|
|
20401
|
+
return item.name;
|
|
20402
|
+
}
|
|
20403
|
+
|
|
20404
|
+
return '';
|
|
20405
|
+
};
|
|
20406
|
+
|
|
20407
|
+
return React__default.createElement(Container$1, null, React__default.createElement(TextOverlay, null, React__default.createElement(Item, null, getCurrentSelectionName())), React__default.createElement("div", {
|
|
20397
20408
|
className: "rpgui-progress-track"
|
|
20398
20409
|
}), React__default.createElement(LeftArrow, {
|
|
20399
20410
|
onClick: onLeftClick
|
|
@@ -20425,36 +20436,39 @@ var RightArrow = /*#__PURE__*/styled.div.withConfig({
|
|
|
20425
20436
|
var CharacterSelection = function CharacterSelection(_ref) {
|
|
20426
20437
|
var availableCharacters = _ref.availableCharacters,
|
|
20427
20438
|
onChange = _ref.onChange;
|
|
20439
|
+
var propertySelectValues = availableCharacters.map(function (item) {
|
|
20440
|
+
return {
|
|
20441
|
+
id: item.textureKey,
|
|
20442
|
+
name: item.name
|
|
20443
|
+
};
|
|
20444
|
+
});
|
|
20428
20445
|
|
|
20429
|
-
var
|
|
20430
|
-
|
|
20431
|
-
|
|
20432
|
-
id: item.textureKey,
|
|
20433
|
-
name: item.name
|
|
20434
|
-
};
|
|
20435
|
-
});
|
|
20436
|
-
};
|
|
20437
|
-
|
|
20438
|
-
var _useState = React.useState(getPropertySelectValues()),
|
|
20439
|
-
propertySelectValues = _useState[0];
|
|
20446
|
+
var _useState = React.useState(),
|
|
20447
|
+
selectedValue = _useState[0],
|
|
20448
|
+
setSelectedValue = _useState[1];
|
|
20440
20449
|
|
|
20441
20450
|
var _useState2 = React.useState(''),
|
|
20442
20451
|
selectedSpriteKey = _useState2[0],
|
|
20443
20452
|
setSelectedSpriteKey = _useState2[1];
|
|
20444
20453
|
|
|
20445
|
-
var _useState3 = React.useState(propertySelectValues[0]),
|
|
20446
|
-
selectedValue = _useState3[0],
|
|
20447
|
-
setSelectedValue = _useState3[1];
|
|
20448
|
-
|
|
20449
20454
|
var onSelectedValueChange = function onSelectedValueChange() {
|
|
20450
|
-
var textureKey = selectedValue.id;
|
|
20451
|
-
|
|
20455
|
+
var textureKey = selectedValue ? selectedValue.id : '';
|
|
20456
|
+
var spriteKey = textureKey ? textureKey + '/down/standing/0.png' : '';
|
|
20457
|
+
|
|
20458
|
+
if (spriteKey == selectedSpriteKey) {
|
|
20459
|
+
return;
|
|
20460
|
+
}
|
|
20461
|
+
|
|
20462
|
+
setSelectedSpriteKey(spriteKey);
|
|
20452
20463
|
onChange(textureKey);
|
|
20453
20464
|
};
|
|
20454
20465
|
|
|
20455
20466
|
React.useEffect(function () {
|
|
20456
20467
|
onSelectedValueChange();
|
|
20457
20468
|
}, [selectedValue]);
|
|
20469
|
+
React.useEffect(function () {
|
|
20470
|
+
setSelectedValue(propertySelectValues[0]);
|
|
20471
|
+
}, [availableCharacters]);
|
|
20458
20472
|
return React__default.createElement(Container$2, null, selectedSpriteKey && React__default.createElement(SpriteFromAtlas, {
|
|
20459
20473
|
spriteKey: selectedSpriteKey,
|
|
20460
20474
|
atlasIMG: img,
|
|
@@ -20463,7 +20477,7 @@ var CharacterSelection = function CharacterSelection(_ref) {
|
|
|
20463
20477
|
height: 50,
|
|
20464
20478
|
width: 50,
|
|
20465
20479
|
containerStyle: {
|
|
20466
|
-
padding: '25px 10px 5px
|
|
20480
|
+
padding: '25px 10px 5px 27px'
|
|
20467
20481
|
}
|
|
20468
20482
|
}), React__default.createElement(PropertySelect, {
|
|
20469
20483
|
availableProperties: propertySelectValues,
|
|
@@ -26297,10 +26311,25 @@ var ItemSlot = /*#__PURE__*/mobxReactLite.observer(function (_ref) {
|
|
|
26297
26311
|
return '2.5rem';
|
|
26298
26312
|
};
|
|
26299
26313
|
|
|
26314
|
+
var getStackInfo = function getStackInfo(itemId, stackQty) {
|
|
26315
|
+
// if (itemToRender?.isStackable && itemToRender?.stackQty) {
|
|
26316
|
+
if (stackQty > 1) {
|
|
26317
|
+
return React__default.createElement(ItemQty, {
|
|
26318
|
+
left: getLeftPositionValue(stackQty),
|
|
26319
|
+
key: "qty-" + itemId
|
|
26320
|
+
}, ' ', stackQty, ' ');
|
|
26321
|
+
}
|
|
26322
|
+
|
|
26323
|
+
return undefined;
|
|
26324
|
+
};
|
|
26325
|
+
|
|
26300
26326
|
var renderItem = function renderItem(itemToRender) {
|
|
26327
|
+
var _itemToRender$_id, _itemToRender$stackQt;
|
|
26328
|
+
|
|
26301
26329
|
var element = [];
|
|
26302
26330
|
|
|
26303
26331
|
if (itemToRender != null && itemToRender.texturePath) {
|
|
26332
|
+
console.table(itemToRender);
|
|
26304
26333
|
element.push(React__default.createElement(SpriteFromAtlas, {
|
|
26305
26334
|
key: itemToRender._id,
|
|
26306
26335
|
atlasIMG: img$5,
|
|
@@ -26310,11 +26339,10 @@ var ItemSlot = /*#__PURE__*/mobxReactLite.observer(function (_ref) {
|
|
|
26310
26339
|
}));
|
|
26311
26340
|
}
|
|
26312
26341
|
|
|
26313
|
-
|
|
26314
|
-
|
|
26315
|
-
|
|
26316
|
-
|
|
26317
|
-
}, ' ', itemToRender.stackQty, ' '));
|
|
26342
|
+
var stackInfo = getStackInfo((_itemToRender$_id = itemToRender == null ? void 0 : itemToRender._id) != null ? _itemToRender$_id : '', (_itemToRender$stackQt = itemToRender == null ? void 0 : itemToRender.stackQty) != null ? _itemToRender$stackQt : 0);
|
|
26343
|
+
|
|
26344
|
+
if (stackInfo) {
|
|
26345
|
+
element.push(stackInfo);
|
|
26318
26346
|
}
|
|
26319
26347
|
|
|
26320
26348
|
return element;
|
|
@@ -26324,13 +26352,23 @@ var ItemSlot = /*#__PURE__*/mobxReactLite.observer(function (_ref) {
|
|
|
26324
26352
|
var _itemToRender$allowed;
|
|
26325
26353
|
|
|
26326
26354
|
if (itemToRender != null && itemToRender.texturePath && (_itemToRender$allowed = itemToRender.allowedEquipSlotType) != null && _itemToRender$allowed.includes(slotSpriteMask)) {
|
|
26327
|
-
|
|
26355
|
+
var _itemToRender$_id2, _itemToRender$stackQt2;
|
|
26356
|
+
|
|
26357
|
+
var element = [];
|
|
26358
|
+
element.push(React__default.createElement(SpriteFromAtlas, {
|
|
26328
26359
|
key: itemToRender._id,
|
|
26329
26360
|
atlasIMG: img$5,
|
|
26330
26361
|
atlasJSON: atlasJSON,
|
|
26331
26362
|
spriteKey: itemToRender.texturePath,
|
|
26332
26363
|
imgScale: 3
|
|
26333
|
-
});
|
|
26364
|
+
}));
|
|
26365
|
+
var stackInfo = getStackInfo((_itemToRender$_id2 = itemToRender == null ? void 0 : itemToRender._id) != null ? _itemToRender$_id2 : '', (_itemToRender$stackQt2 = itemToRender == null ? void 0 : itemToRender.stackQty) != null ? _itemToRender$stackQt2 : 0);
|
|
26366
|
+
|
|
26367
|
+
if (stackInfo) {
|
|
26368
|
+
element.push(stackInfo);
|
|
26369
|
+
}
|
|
26370
|
+
|
|
26371
|
+
return element;
|
|
26334
26372
|
} else {
|
|
26335
26373
|
return React__default.createElement(SpriteFromAtlas, {
|
|
26336
26374
|
atlasIMG: img$5,
|
|
@@ -27035,11 +27073,34 @@ var Container$d = /*#__PURE__*/styled.div.withConfig({
|
|
|
27035
27073
|
var img$8 = '';
|
|
27036
27074
|
|
|
27037
27075
|
var QuestInfo = function QuestInfo(_ref) {
|
|
27038
|
-
var
|
|
27076
|
+
var quests = _ref.quests,
|
|
27039
27077
|
onClose = _ref.onClose,
|
|
27040
|
-
|
|
27041
|
-
|
|
27042
|
-
|
|
27078
|
+
buttons = _ref.buttons,
|
|
27079
|
+
onChangeQuest = _ref.onChangeQuest;
|
|
27080
|
+
|
|
27081
|
+
var _useState = React.useState(0),
|
|
27082
|
+
currentIndex = _useState[0],
|
|
27083
|
+
setCurrentIndex = _useState[1];
|
|
27084
|
+
|
|
27085
|
+
var questsLength = quests.length - 1;
|
|
27086
|
+
React.useEffect(function () {
|
|
27087
|
+
if (onChangeQuest) {
|
|
27088
|
+
onChangeQuest(currentIndex, quests[currentIndex]._id);
|
|
27089
|
+
}
|
|
27090
|
+
}, [currentIndex]);
|
|
27091
|
+
|
|
27092
|
+
var onLeftClick = function onLeftClick() {
|
|
27093
|
+
if (currentIndex === 0) setCurrentIndex(questsLength);else setCurrentIndex(function (index) {
|
|
27094
|
+
return index - 1;
|
|
27095
|
+
});
|
|
27096
|
+
};
|
|
27097
|
+
|
|
27098
|
+
var onRightClick = function onRightClick() {
|
|
27099
|
+
if (currentIndex === questsLength) setCurrentIndex(0);else setCurrentIndex(function (index) {
|
|
27100
|
+
return index + 1;
|
|
27101
|
+
});
|
|
27102
|
+
};
|
|
27103
|
+
|
|
27043
27104
|
return React__default.createElement(QuestDraggableContainer, {
|
|
27044
27105
|
type: exports.RPGUIContainerTypes.Framed,
|
|
27045
27106
|
onCloseButton: function onCloseButton() {
|
|
@@ -27047,53 +27108,94 @@ var QuestInfo = function QuestInfo(_ref) {
|
|
|
27047
27108
|
},
|
|
27048
27109
|
width: "730px",
|
|
27049
27110
|
cancelDrag: ".equipment-container-body"
|
|
27050
|
-
},
|
|
27111
|
+
}, quests.length >= 2 ? React__default.createElement(QuestsContainer, null, currentIndex !== 0 && React__default.createElement(LeftArrow$1, {
|
|
27112
|
+
onClick: onLeftClick
|
|
27113
|
+
}), currentIndex !== quests.length - 1 && React__default.createElement(RightArrow$1, {
|
|
27114
|
+
onClick: onRightClick
|
|
27115
|
+
}), React__default.createElement(QuestContainer, null, React__default.createElement(TitleContainer$1, {
|
|
27051
27116
|
className: "drag-handler"
|
|
27052
27117
|
}, React__default.createElement(Title$1, null, React__default.createElement(Thumbnail, {
|
|
27053
|
-
src: thumbnail || img$8
|
|
27054
|
-
}), title), React__default.createElement(QuestSplitDiv, null, React__default.createElement("hr", {
|
|
27118
|
+
src: quests[currentIndex].thumbnail || img$8
|
|
27119
|
+
}), quests[currentIndex].title), React__default.createElement(QuestSplitDiv, null, React__default.createElement("hr", {
|
|
27055
27120
|
className: "golden"
|
|
27056
|
-
}))), React__default.createElement(Content, null,
|
|
27121
|
+
}))), React__default.createElement(Content, null, React__default.createElement("p", null, quests[currentIndex].description)), React__default.createElement(QuestColumn, {
|
|
27057
27122
|
className: "dark-background",
|
|
27058
27123
|
justifyContent: "flex-end"
|
|
27059
|
-
},
|
|
27124
|
+
}, buttons && buttons.map(function (button, index) {
|
|
27060
27125
|
return React__default.createElement(Button, {
|
|
27061
27126
|
key: index,
|
|
27062
|
-
onClick:
|
|
27063
|
-
|
|
27127
|
+
onClick: function onClick() {
|
|
27128
|
+
return button.onClick(quests[currentIndex]._id, quests[currentIndex].npcId);
|
|
27129
|
+
},
|
|
27130
|
+
disabled: button.disabled,
|
|
27064
27131
|
buttonType: exports.ButtonTypes.RPGUIButton,
|
|
27065
27132
|
id: "button-" + index
|
|
27066
|
-
},
|
|
27067
|
-
})))
|
|
27133
|
+
}, button.title);
|
|
27134
|
+
})))) : React__default.createElement(QuestsContainer, null, React__default.createElement(QuestContainer, null, React__default.createElement(TitleContainer$1, {
|
|
27135
|
+
className: "drag-handler"
|
|
27136
|
+
}, React__default.createElement(Title$1, null, React__default.createElement(Thumbnail, {
|
|
27137
|
+
src: quests[0].thumbnail || img$8
|
|
27138
|
+
}), quests[0].title), React__default.createElement(QuestSplitDiv, null, React__default.createElement("hr", {
|
|
27139
|
+
className: "golden"
|
|
27140
|
+
}))), React__default.createElement(Content, null, React__default.createElement("p", null, quests[0].description)), React__default.createElement(QuestColumn, {
|
|
27141
|
+
className: "dark-background",
|
|
27142
|
+
justifyContent: "flex-end"
|
|
27143
|
+
}, buttons && buttons.map(function (button, index) {
|
|
27144
|
+
return React__default.createElement(Button, {
|
|
27145
|
+
key: index,
|
|
27146
|
+
onClick: function onClick() {
|
|
27147
|
+
return button.onClick(quests[0]._id, quests[0].npcId);
|
|
27148
|
+
},
|
|
27149
|
+
disabled: button.disabled,
|
|
27150
|
+
buttonType: exports.ButtonTypes.RPGUIButton,
|
|
27151
|
+
id: "button-" + index
|
|
27152
|
+
}, button.title);
|
|
27153
|
+
})))));
|
|
27068
27154
|
};
|
|
27069
27155
|
var QuestDraggableContainer = /*#__PURE__*/styled(DraggableContainer).withConfig({
|
|
27070
27156
|
displayName: "QuestInfo__QuestDraggableContainer",
|
|
27071
27157
|
componentId: "sc-15s2boc-0"
|
|
27072
|
-
})(["border:1px solid black;width:600px;height:500px;
|
|
27158
|
+
})(["border:1px solid black;width:600px;height:500px;padding:0 0 0 0 !important;.DraggableContainer__TitleContainer-sc-184mpyl-2{height:auto;}.container-close{position:sticky;margin-left:auto;top:20px;padding-right:5px;}img{display:inline-block;vertical-align:middle;line-height:normal;}"]);
|
|
27159
|
+
var QuestContainer = /*#__PURE__*/styled.div.withConfig({
|
|
27160
|
+
displayName: "QuestInfo__QuestContainer",
|
|
27161
|
+
componentId: "sc-15s2boc-1"
|
|
27162
|
+
})(["margin-right:40px;margin-left:40px;"]);
|
|
27163
|
+
var QuestsContainer = /*#__PURE__*/styled.div.withConfig({
|
|
27164
|
+
displayName: "QuestInfo__QuestsContainer",
|
|
27165
|
+
componentId: "sc-15s2boc-2"
|
|
27166
|
+
})(["display:flex;align-items:center;"]);
|
|
27073
27167
|
var Content = /*#__PURE__*/styled.div.withConfig({
|
|
27074
27168
|
displayName: "QuestInfo__Content",
|
|
27075
|
-
componentId: "sc-15s2boc-
|
|
27169
|
+
componentId: "sc-15s2boc-3"
|
|
27076
27170
|
})(["padding:18px;h1{text-align:left;margin:14px 0px;}"]);
|
|
27077
27171
|
var QuestSplitDiv = /*#__PURE__*/styled.div.withConfig({
|
|
27078
27172
|
displayName: "QuestInfo__QuestSplitDiv",
|
|
27079
|
-
componentId: "sc-15s2boc-
|
|
27173
|
+
componentId: "sc-15s2boc-4"
|
|
27080
27174
|
})(["width:100%;font-size:11px;margin-bottom:10px;hr{margin:0px;padding:0px;}p{margin-bottom:0px;}"]);
|
|
27081
27175
|
var QuestColumn = /*#__PURE__*/styled(Column).withConfig({
|
|
27082
27176
|
displayName: "QuestInfo__QuestColumn",
|
|
27083
|
-
componentId: "sc-15s2boc-
|
|
27084
|
-
})(["background:#4e4a4e;padding-top:5px;
|
|
27177
|
+
componentId: "sc-15s2boc-5"
|
|
27178
|
+
})(["background:#4e4a4e;padding-top:5px;margin-bottom:20px;display:flex;justify-content:space-evenly;"]);
|
|
27085
27179
|
var TitleContainer$1 = /*#__PURE__*/styled.div.withConfig({
|
|
27086
27180
|
displayName: "QuestInfo__TitleContainer",
|
|
27087
|
-
componentId: "sc-15s2boc-
|
|
27088
|
-
})(["background:#4e4a4e;
|
|
27181
|
+
componentId: "sc-15s2boc-6"
|
|
27182
|
+
})(["background:#4e4a4e;width:100%;display:flex;flex-wrap:wrap;justify-content:flex-start;align-items:center;"]);
|
|
27089
27183
|
var Title$1 = /*#__PURE__*/styled.h1.withConfig({
|
|
27090
27184
|
displayName: "QuestInfo__Title",
|
|
27091
|
-
componentId: "sc-15s2boc-
|
|
27185
|
+
componentId: "sc-15s2boc-7"
|
|
27092
27186
|
})(["color:white;z-index:22;font-size:0.6rem;"]);
|
|
27093
27187
|
var Thumbnail = /*#__PURE__*/styled.img.withConfig({
|
|
27094
27188
|
displayName: "QuestInfo__Thumbnail",
|
|
27095
|
-
componentId: "sc-15s2boc-
|
|
27189
|
+
componentId: "sc-15s2boc-8"
|
|
27096
27190
|
})(["color:white;z-index:22;font-size:10px;width:64px;margin-right:0.5rem;"]);
|
|
27191
|
+
var LeftArrow$1 = /*#__PURE__*/styled.div.withConfig({
|
|
27192
|
+
displayName: "QuestInfo__LeftArrow",
|
|
27193
|
+
componentId: "sc-15s2boc-9"
|
|
27194
|
+
})(["background-image:url(", ");background-size:100% 100%;left:0;position:absolute;width:40px;height:42px;:active{background-image:url(", ");}"], img$2, img$1);
|
|
27195
|
+
var RightArrow$1 = /*#__PURE__*/styled.div.withConfig({
|
|
27196
|
+
displayName: "QuestInfo__RightArrow",
|
|
27197
|
+
componentId: "sc-15s2boc-10"
|
|
27198
|
+
})(["background-image:url(", ");right:0;position:absolute;width:40px;background-size:100% 100%;height:42px;:active{background-image:url(", ");}"], img$4, img$3);
|
|
27097
27199
|
|
|
27098
27200
|
var InputRadio = function InputRadio(_ref) {
|
|
27099
27201
|
var name = _ref.name,
|