@rpg-engine/long-bow 0.4.2 → 0.4.4
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 +1059 -1059
- 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 +1065 -1065
- package/dist/long-bow.esm.js.map +1 -1
- package/package.json +100 -100
- package/src/components/Abstractions/ModalPortal.tsx +22 -22
- package/src/components/Abstractions/SlotsContainer.tsx +62 -62
- package/src/components/Arrow/SelectArrow.tsx +69 -69
- package/src/components/Arrow/img/arrow01-left-clicked.png +0 -0
- package/src/components/Arrow/img/arrow01-left.png +0 -0
- package/src/components/Arrow/img/arrow01-right-clicked.png +0 -0
- package/src/components/Arrow/img/arrow01-right.png +0 -0
- package/src/components/Arrow/img/arrow02-left-clicked.png +0 -0
- package/src/components/Arrow/img/arrow02-left.png +0 -0
- package/src/components/Arrow/img/arrow02-right-clicked.png +0 -0
- package/src/components/Arrow/img/arrow02-right.png +0 -0
- package/src/components/Button.tsx +40 -40
- package/src/components/Character/CharacterSelection.tsx +98 -98
- package/src/components/CharacterStatus/CharacterStatus.tsx +120 -120
- package/src/components/Chat/Chat.tsx +196 -196
- package/src/components/Chatdeprecated/ChatDeprecated.tsx +198 -198
- package/src/components/CheckButton.tsx +65 -65
- package/src/components/CircularController/CircularController.tsx +282 -282
- package/src/components/CraftBook/CraftBook.tsx +286 -286
- package/src/components/CraftBook/CraftingRecipe.tsx +161 -161
- package/src/components/CraftBook/MockItems.ts +101 -101
- package/src/components/DraggableContainer.tsx +181 -180
- package/src/components/DropdownSelectorContainer.tsx +42 -42
- package/src/components/Equipment/EquipmentSet.tsx +199 -199
- package/src/components/HistoryDialog.tsx +104 -104
- package/src/components/Input.tsx +15 -15
- package/src/components/InputRadio.tsx +41 -41
- package/src/components/Item/Cards/ItemInfo.tsx +298 -298
- package/src/components/Item/Cards/ItemInfoDisplay.tsx +135 -135
- package/src/components/Item/Cards/ItemInfoWrapper.tsx +62 -62
- package/src/components/Item/Cards/ItemTooltip.tsx +83 -83
- package/src/components/Item/Cards/MobileItemTooltip.tsx +149 -149
- package/src/components/Item/Inventory/ErrorBoundary.tsx +42 -42
- package/src/components/Item/Inventory/ItemContainer.tsx +231 -231
- package/src/components/Item/Inventory/ItemContainerTypes.ts +6 -6
- package/src/components/Item/Inventory/ItemQuantitySelector.tsx +138 -138
- package/src/components/Item/Inventory/ItemSlot.tsx +580 -580
- package/src/components/Item/Inventory/itemContainerHelper.ts +175 -175
- package/src/components/ListMenu.tsx +63 -63
- package/src/components/Marketplace/Marketplace.tsx +132 -132
- package/src/components/Marketplace/MarketplaceRows.tsx +171 -171
- package/src/components/Marketplace/__mocks__/index.tsx +65 -65
- package/src/components/Multitab/Tab.tsx +66 -66
- package/src/components/Multitab/TabBody.tsx +13 -13
- package/src/components/Multitab/TabsContainer.tsx +97 -97
- package/src/components/NPCDialog/NPCDialog.tsx +121 -121
- package/src/components/NPCDialog/NPCDialogText.tsx +113 -113
- package/src/components/NPCDialog/NPCMultiDialog.tsx +159 -159
- package/src/components/NPCDialog/QuestionDialog/QuestionDialog.tsx +237 -237
- package/src/components/ProgressBar.tsx +95 -95
- package/src/components/PropertySelect/PropertySelect.tsx +106 -106
- package/src/components/QuestInfo/QuestInfo.tsx +233 -233
- package/src/components/QuestList.tsx +135 -135
- package/src/components/RPGUIContainer.tsx +47 -47
- package/src/components/RPGUIForceRenderStart.tsx +45 -45
- package/src/components/RPGUIRoot.tsx +14 -14
- package/src/components/RadioButton.tsx +53 -53
- package/src/components/RadioInput/RadioButton.tsx +96 -96
- package/src/components/RadioInput/RadioInput.tsx +102 -102
- package/src/components/RadioInput/instruments.ts +15 -15
- package/src/components/RangeSlider.tsx +78 -78
- package/src/components/RelativeListMenu.tsx +90 -90
- package/src/components/ScrollList.tsx +79 -79
- package/src/components/Shortcuts/Shortcuts.tsx +193 -193
- package/src/components/Shortcuts/ShortcutsSetter.tsx +139 -139
- package/src/components/Shortcuts/SingleShortcut.ts +82 -82
- package/src/components/Shortcuts/useShortcutCooldown.ts +23 -23
- package/src/components/SimpleProgressBar.tsx +62 -62
- package/src/components/SkillProgressBar.tsx +133 -133
- package/src/components/SkillsContainer.tsx +211 -211
- package/src/components/Spellbook/Spell.tsx +236 -236
- package/src/components/Spellbook/Spellbook.tsx +161 -161
- package/src/components/Spellbook/cards/MobileSpellTooltip.tsx +137 -137
- package/src/components/Spellbook/cards/SpellInfo.tsx +134 -134
- package/src/components/Spellbook/cards/SpellInfoDisplay.tsx +31 -31
- package/src/components/Spellbook/cards/SpellInfoWrapper.tsx +48 -48
- package/src/components/Spellbook/cards/SpellTooltip.tsx +70 -70
- package/src/components/Spellbook/constants.ts +7 -7
- package/src/components/Spellbook/mockSpells.ts +84 -84
- package/src/components/StaticBook/StaticBook.tsx +103 -103
- package/src/components/TextArea.tsx +11 -11
- package/src/components/TimeWidget/DayNightPeriod/DayNightPeriod.tsx +35 -35
- package/src/components/TimeWidget/TimeWidget.tsx +65 -65
- package/src/components/TradingMenu/TradingItemRow.tsx +199 -199
- package/src/components/TradingMenu/TradingMenu.tsx +219 -219
- package/src/components/TradingMenu/items.mock.ts +48 -48
- 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 +68 -68
- package/src/components/shared/SpriteFromAtlas.tsx +104 -104
- package/src/components/typography/DynamicText.tsx +49 -49
- package/src/constants/uiColors.ts +20 -20
- package/src/constants/uiDevices.ts +3 -3
- package/src/constants/uiFonts.ts +12 -12
- package/src/hooks/useEventListener.ts +21 -21
- package/src/hooks/useOutsideAlerter.ts +25 -25
- package/src/index.tsx +42 -42
- package/src/libs/CastingTypeHelper.ts +7 -7
- package/src/libs/StringHelpers.ts +3 -3
- package/src/libs/itemCounter.ts +21 -21
- package/src/mocks/atlas/entities/entities.json +20215 -20215
- package/src/mocks/atlas/icons/icons.json +735 -735
- package/src/mocks/atlas/items/items.json +12086 -12086
- package/src/mocks/equipmentSet.mocks.ts +391 -391
- package/src/mocks/itemContainer.mocks.ts +605 -605
- 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 +44 -44
- package/src/stories/CharacterStatus.stories.tsx +29 -29
- package/src/stories/Chat.stories.tsx +187 -187
- package/src/stories/ChatDeprecated.stories.tsx +170 -170
- package/src/stories/CheckButton.stories.tsx +48 -48
- package/src/stories/CircullarController.stories.tsx +37 -37
- package/src/stories/CraftBook.stories.tsx +42 -42
- 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 +201 -201
- package/src/stories/ItemInfoDisplay.stories.tsx +33 -33
- 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/Marketplace.stories.tsx +42 -42
- package/src/stories/MarketplaceRows.stories.tsx +28 -28
- package/src/stories/Multitab.stories.tsx +51 -51
- package/src/stories/NPCDialog.stories.tsx +130 -130
- package/src/stories/NPCMultiDialog.stories.tsx +71 -71
- package/src/stories/ProgressBar.stories.tsx +23 -23
- package/src/stories/PropertySelect.stories.tsx +40 -40
- package/src/stories/QuestInfo.stories.tsx +107 -107
- package/src/stories/QuestList.stories.tsx +82 -82
- package/src/stories/RPGUIContainers.stories.tsx +42 -42
- package/src/stories/RadioButton.stories.tsx +49 -49
- package/src/stories/RadioInput.stories.tsx +34 -34
- package/src/stories/RangeSlider.stories.tsx +64 -64
- package/src/stories/ScrollList.stories.tsx +85 -85
- package/src/stories/Shortcuts.stories.tsx +39 -39
- package/src/stories/SimpleProgressBar.stories.tsx +22 -22
- package/src/stories/SkillProgressBar.stories.tsx +34 -34
- package/src/stories/SkillsContainer.stories.tsx +35 -35
- package/src/stories/SpellInfoDisplay.stories.tsx +27 -27
- package/src/stories/Spellbook.stories.tsx +104 -104
- package/src/stories/StaticBook.stories.tsx +32 -32
- package/src/stories/Text.stories.tsx +42 -42
- package/src/stories/TimeWidget.stories.tsx +27 -27
- package/src/stories/TradingMenu.stories.tsx +47 -47
- package/src/types/eventTypes.ts +4 -4
- package/src/types/index.d.ts +2 -2
|
@@ -1,49 +1,49 @@
|
|
|
1
|
-
import React, { useEffect, useState } from 'react';
|
|
2
|
-
import styled from 'styled-components';
|
|
3
|
-
|
|
4
|
-
interface IProps {
|
|
5
|
-
text: string;
|
|
6
|
-
onFinish?: () => void;
|
|
7
|
-
onStart?: () => void;
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
export const DynamicText: React.FC<IProps> = ({ text, onFinish, onStart }) => {
|
|
11
|
-
const [textState, setTextState] = useState<string>('');
|
|
12
|
-
|
|
13
|
-
useEffect(() => {
|
|
14
|
-
let i = 0;
|
|
15
|
-
const interval = setInterval(() => {
|
|
16
|
-
// on every interval, show one more character
|
|
17
|
-
|
|
18
|
-
if (i === 0) {
|
|
19
|
-
if (onStart) {
|
|
20
|
-
onStart();
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
if (i < text.length) {
|
|
25
|
-
setTextState(text.substring(0, i + 1));
|
|
26
|
-
i++;
|
|
27
|
-
} else {
|
|
28
|
-
clearInterval(interval);
|
|
29
|
-
if (onFinish) {
|
|
30
|
-
onFinish();
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
}, 50);
|
|
34
|
-
|
|
35
|
-
return () => {
|
|
36
|
-
clearInterval(interval);
|
|
37
|
-
};
|
|
38
|
-
}, [text]);
|
|
39
|
-
|
|
40
|
-
return <TextContainer>{textState}</TextContainer>;
|
|
41
|
-
};
|
|
42
|
-
|
|
43
|
-
const TextContainer = styled.p`
|
|
44
|
-
font-size: 0.7rem !important;
|
|
45
|
-
color: white;
|
|
46
|
-
text-shadow: 1px 1px 0px #000000;
|
|
47
|
-
letter-spacing: 1.2px;
|
|
48
|
-
word-break: normal;
|
|
49
|
-
`;
|
|
1
|
+
import React, { useEffect, useState } from 'react';
|
|
2
|
+
import styled from 'styled-components';
|
|
3
|
+
|
|
4
|
+
interface IProps {
|
|
5
|
+
text: string;
|
|
6
|
+
onFinish?: () => void;
|
|
7
|
+
onStart?: () => void;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export const DynamicText: React.FC<IProps> = ({ text, onFinish, onStart }) => {
|
|
11
|
+
const [textState, setTextState] = useState<string>('');
|
|
12
|
+
|
|
13
|
+
useEffect(() => {
|
|
14
|
+
let i = 0;
|
|
15
|
+
const interval = setInterval(() => {
|
|
16
|
+
// on every interval, show one more character
|
|
17
|
+
|
|
18
|
+
if (i === 0) {
|
|
19
|
+
if (onStart) {
|
|
20
|
+
onStart();
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
if (i < text.length) {
|
|
25
|
+
setTextState(text.substring(0, i + 1));
|
|
26
|
+
i++;
|
|
27
|
+
} else {
|
|
28
|
+
clearInterval(interval);
|
|
29
|
+
if (onFinish) {
|
|
30
|
+
onFinish();
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
}, 50);
|
|
34
|
+
|
|
35
|
+
return () => {
|
|
36
|
+
clearInterval(interval);
|
|
37
|
+
};
|
|
38
|
+
}, [text]);
|
|
39
|
+
|
|
40
|
+
return <TextContainer>{textState}</TextContainer>;
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
const TextContainer = styled.p`
|
|
44
|
+
font-size: 0.7rem !important;
|
|
45
|
+
color: white;
|
|
46
|
+
text-shadow: 1px 1px 0px #000000;
|
|
47
|
+
letter-spacing: 1.2px;
|
|
48
|
+
word-break: normal;
|
|
49
|
+
`;
|
|
@@ -1,20 +1,20 @@
|
|
|
1
|
-
export const uiColors = {
|
|
2
|
-
lightGray: '#888',
|
|
3
|
-
gray: '#4E4A4E',
|
|
4
|
-
darkGray: '#3e3e3e',
|
|
5
|
-
darkYellow: '#FFC857',
|
|
6
|
-
yellow: '#FFFF00',
|
|
7
|
-
orange: '#D27D2C',
|
|
8
|
-
cardinal: '#C5283D',
|
|
9
|
-
red: '#D04648',
|
|
10
|
-
darkRed: '#442434',
|
|
11
|
-
raisinBlack: '#191923',
|
|
12
|
-
navyBlue: '#0E79B2',
|
|
13
|
-
purple: '#6833A3',
|
|
14
|
-
darkPurple: '#522761',
|
|
15
|
-
blue: '#597DCE',
|
|
16
|
-
darkBlue: '#30346D',
|
|
17
|
-
brown: '#854C30',
|
|
18
|
-
lightGreen: '#66cd1c',
|
|
19
|
-
brownGreen: '#346524',
|
|
20
|
-
};
|
|
1
|
+
export const uiColors = {
|
|
2
|
+
lightGray: '#888',
|
|
3
|
+
gray: '#4E4A4E',
|
|
4
|
+
darkGray: '#3e3e3e',
|
|
5
|
+
darkYellow: '#FFC857',
|
|
6
|
+
yellow: '#FFFF00',
|
|
7
|
+
orange: '#D27D2C',
|
|
8
|
+
cardinal: '#C5283D',
|
|
9
|
+
red: '#D04648',
|
|
10
|
+
darkRed: '#442434',
|
|
11
|
+
raisinBlack: '#191923',
|
|
12
|
+
navyBlue: '#0E79B2',
|
|
13
|
+
purple: '#6833A3',
|
|
14
|
+
darkPurple: '#522761',
|
|
15
|
+
blue: '#597DCE',
|
|
16
|
+
darkBlue: '#30346D',
|
|
17
|
+
brown: '#854C30',
|
|
18
|
+
lightGreen: '#66cd1c',
|
|
19
|
+
brownGreen: '#346524',
|
|
20
|
+
};
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import { isMobileOrTablet } from '@rpg-engine/shared';
|
|
2
|
-
|
|
3
|
-
export const IS_MOBILE_OR_TABLET = isMobileOrTablet();
|
|
1
|
+
import { isMobileOrTablet } from '@rpg-engine/shared';
|
|
2
|
+
|
|
3
|
+
export const IS_MOBILE_OR_TABLET = isMobileOrTablet();
|
package/src/constants/uiFonts.ts
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
export const uiFonts = {
|
|
2
|
-
size: {
|
|
3
|
-
xxsmall: '8px',
|
|
4
|
-
xsmall: '9px',
|
|
5
|
-
small: '12px',
|
|
6
|
-
medium: '14px',
|
|
7
|
-
large: '16px',
|
|
8
|
-
xLarge: '18px',
|
|
9
|
-
xxLarge: '20px',
|
|
10
|
-
xxxLarge: '24px',
|
|
11
|
-
},
|
|
12
|
-
};
|
|
1
|
+
export const uiFonts = {
|
|
2
|
+
size: {
|
|
3
|
+
xxsmall: '8px',
|
|
4
|
+
xsmall: '9px',
|
|
5
|
+
small: '12px',
|
|
6
|
+
medium: '14px',
|
|
7
|
+
large: '16px',
|
|
8
|
+
xLarge: '18px',
|
|
9
|
+
xxLarge: '20px',
|
|
10
|
+
xxxLarge: '24px',
|
|
11
|
+
},
|
|
12
|
+
};
|
|
@@ -1,21 +1,21 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
|
|
3
|
-
//@ts-ignore
|
|
4
|
-
export const useEventListener = (type, handler, el = window) => {
|
|
5
|
-
const savedHandler = React.useRef();
|
|
6
|
-
|
|
7
|
-
React.useEffect(() => {
|
|
8
|
-
savedHandler.current = handler;
|
|
9
|
-
}, [handler]);
|
|
10
|
-
|
|
11
|
-
React.useEffect(() => {
|
|
12
|
-
//@ts-ignore
|
|
13
|
-
const listener = e => savedHandler.current(e);
|
|
14
|
-
|
|
15
|
-
el.addEventListener(type, listener);
|
|
16
|
-
|
|
17
|
-
return () => {
|
|
18
|
-
el.removeEventListener(type, listener);
|
|
19
|
-
};
|
|
20
|
-
}, [type, el]);
|
|
21
|
-
};
|
|
1
|
+
import React from 'react';
|
|
2
|
+
|
|
3
|
+
//@ts-ignore
|
|
4
|
+
export const useEventListener = (type, handler, el = window) => {
|
|
5
|
+
const savedHandler = React.useRef();
|
|
6
|
+
|
|
7
|
+
React.useEffect(() => {
|
|
8
|
+
savedHandler.current = handler;
|
|
9
|
+
}, [handler]);
|
|
10
|
+
|
|
11
|
+
React.useEffect(() => {
|
|
12
|
+
//@ts-ignore
|
|
13
|
+
const listener = e => savedHandler.current(e);
|
|
14
|
+
|
|
15
|
+
el.addEventListener(type, listener);
|
|
16
|
+
|
|
17
|
+
return () => {
|
|
18
|
+
el.removeEventListener(type, listener);
|
|
19
|
+
};
|
|
20
|
+
}, [type, el]);
|
|
21
|
+
};
|
|
@@ -1,25 +1,25 @@
|
|
|
1
|
-
import { useEffect } from 'react';
|
|
2
|
-
|
|
3
|
-
export function useOutsideClick(ref: any, id: string) {
|
|
4
|
-
useEffect(() => {
|
|
5
|
-
/**
|
|
6
|
-
* Alert if clicked on outside of element
|
|
7
|
-
*/
|
|
8
|
-
function handleClickOutside(event: any) {
|
|
9
|
-
if (ref.current && !ref.current.contains(event.target)) {
|
|
10
|
-
const event = new CustomEvent('clickOutside', {
|
|
11
|
-
detail: {
|
|
12
|
-
id,
|
|
13
|
-
},
|
|
14
|
-
});
|
|
15
|
-
document.dispatchEvent(event);
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
// Bind the event listener
|
|
19
|
-
document.addEventListener('pointerdown', handleClickOutside);
|
|
20
|
-
return () => {
|
|
21
|
-
// Unbind the event listener on clean up
|
|
22
|
-
document.removeEventListener('pointerdown', handleClickOutside);
|
|
23
|
-
};
|
|
24
|
-
}, [ref]);
|
|
25
|
-
}
|
|
1
|
+
import { useEffect } from 'react';
|
|
2
|
+
|
|
3
|
+
export function useOutsideClick(ref: any, id: string) {
|
|
4
|
+
useEffect(() => {
|
|
5
|
+
/**
|
|
6
|
+
* Alert if clicked on outside of element
|
|
7
|
+
*/
|
|
8
|
+
function handleClickOutside(event: any) {
|
|
9
|
+
if (ref.current && !ref.current.contains(event.target)) {
|
|
10
|
+
const event = new CustomEvent('clickOutside', {
|
|
11
|
+
detail: {
|
|
12
|
+
id,
|
|
13
|
+
},
|
|
14
|
+
});
|
|
15
|
+
document.dispatchEvent(event);
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
// Bind the event listener
|
|
19
|
+
document.addEventListener('pointerdown', handleClickOutside);
|
|
20
|
+
return () => {
|
|
21
|
+
// Unbind the event listener on clean up
|
|
22
|
+
document.removeEventListener('pointerdown', handleClickOutside);
|
|
23
|
+
};
|
|
24
|
+
}, [ref]);
|
|
25
|
+
}
|
package/src/index.tsx
CHANGED
|
@@ -1,42 +1,42 @@
|
|
|
1
|
-
export * from './components/Button';
|
|
2
|
-
export * from './components/Character/CharacterSelection';
|
|
3
|
-
export * from './components/Chat/Chat';
|
|
4
|
-
export * from './components/Chatdeprecated/ChatDeprecated';
|
|
5
|
-
export * from './components/CheckButton';
|
|
6
|
-
export * from './components/CircularController/CircularController';
|
|
7
|
-
export * from './components/CraftBook/CraftBook';
|
|
8
|
-
export * from './components/DraggableContainer';
|
|
9
|
-
export * from './components/Dropdown';
|
|
10
|
-
export * from './components/DropdownSelectorContainer';
|
|
11
|
-
export * from './components/Equipment/EquipmentSet';
|
|
12
|
-
export * from './components/HistoryDialog';
|
|
13
|
-
export * from './components/Input';
|
|
14
|
-
export { ErrorBoundary } from './components/Item/Inventory/ErrorBoundary';
|
|
15
|
-
export * from './components/Item/Inventory/ItemContainer';
|
|
16
|
-
export * from './components/Item/Inventory/ItemSlot';
|
|
17
|
-
export * from './components/itemSelector/ItemSelector';
|
|
18
|
-
export * from './components/ListMenu';
|
|
19
|
-
export * from './components/Marketplace/Marketplace';
|
|
20
|
-
export * from './components/Marketplace/MarketplaceRows';
|
|
21
|
-
export * from './components/NPCDialog/NPCDialog';
|
|
22
|
-
export * from './components/NPCDialog/NPCMultiDialog';
|
|
23
|
-
export * from './components/NPCDialog/QuestionDialog/QuestionDialog';
|
|
24
|
-
export * from './components/ProgressBar';
|
|
25
|
-
export * from './components/PropertySelect/PropertySelect';
|
|
26
|
-
export * from './components/QuestInfo/QuestInfo';
|
|
27
|
-
export * from './components/QuestList';
|
|
28
|
-
export * from './components/RadioButton';
|
|
29
|
-
export * from './components/RangeSlider';
|
|
30
|
-
export * from './components/RPGUIContainer';
|
|
31
|
-
export * from './components/RPGUIRoot';
|
|
32
|
-
export * from './components/shared/SpriteFromAtlas';
|
|
33
|
-
export * from './components/Shortcuts/Shortcuts';
|
|
34
|
-
export * from './components/SkillProgressBar';
|
|
35
|
-
export * from './components/SkillsContainer';
|
|
36
|
-
export * from './components/Spellbook/Spellbook';
|
|
37
|
-
export * from './components/TextArea';
|
|
38
|
-
export * from './components/TimeWidget/TimeWidget';
|
|
39
|
-
export * from './components/TradingMenu/TradingMenu';
|
|
40
|
-
export * from './components/Truncate';
|
|
41
|
-
export * from './components/typography/DynamicText';
|
|
42
|
-
export { useEventListener } from './hooks/useEventListener';
|
|
1
|
+
export * from './components/Button';
|
|
2
|
+
export * from './components/Character/CharacterSelection';
|
|
3
|
+
export * from './components/Chat/Chat';
|
|
4
|
+
export * from './components/Chatdeprecated/ChatDeprecated';
|
|
5
|
+
export * from './components/CheckButton';
|
|
6
|
+
export * from './components/CircularController/CircularController';
|
|
7
|
+
export * from './components/CraftBook/CraftBook';
|
|
8
|
+
export * from './components/DraggableContainer';
|
|
9
|
+
export * from './components/Dropdown';
|
|
10
|
+
export * from './components/DropdownSelectorContainer';
|
|
11
|
+
export * from './components/Equipment/EquipmentSet';
|
|
12
|
+
export * from './components/HistoryDialog';
|
|
13
|
+
export * from './components/Input';
|
|
14
|
+
export { ErrorBoundary } from './components/Item/Inventory/ErrorBoundary';
|
|
15
|
+
export * from './components/Item/Inventory/ItemContainer';
|
|
16
|
+
export * from './components/Item/Inventory/ItemSlot';
|
|
17
|
+
export * from './components/itemSelector/ItemSelector';
|
|
18
|
+
export * from './components/ListMenu';
|
|
19
|
+
export * from './components/Marketplace/Marketplace';
|
|
20
|
+
export * from './components/Marketplace/MarketplaceRows';
|
|
21
|
+
export * from './components/NPCDialog/NPCDialog';
|
|
22
|
+
export * from './components/NPCDialog/NPCMultiDialog';
|
|
23
|
+
export * from './components/NPCDialog/QuestionDialog/QuestionDialog';
|
|
24
|
+
export * from './components/ProgressBar';
|
|
25
|
+
export * from './components/PropertySelect/PropertySelect';
|
|
26
|
+
export * from './components/QuestInfo/QuestInfo';
|
|
27
|
+
export * from './components/QuestList';
|
|
28
|
+
export * from './components/RadioButton';
|
|
29
|
+
export * from './components/RangeSlider';
|
|
30
|
+
export * from './components/RPGUIContainer';
|
|
31
|
+
export * from './components/RPGUIRoot';
|
|
32
|
+
export * from './components/shared/SpriteFromAtlas';
|
|
33
|
+
export * from './components/Shortcuts/Shortcuts';
|
|
34
|
+
export * from './components/SkillProgressBar';
|
|
35
|
+
export * from './components/SkillsContainer';
|
|
36
|
+
export * from './components/Spellbook/Spellbook';
|
|
37
|
+
export * from './components/TextArea';
|
|
38
|
+
export * from './components/TimeWidget/TimeWidget';
|
|
39
|
+
export * from './components/TradingMenu/TradingMenu';
|
|
40
|
+
export * from './components/Truncate';
|
|
41
|
+
export * from './components/typography/DynamicText';
|
|
42
|
+
export { useEventListener } from './hooks/useEventListener';
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
export const formatSpellCastingType = (castingType: string): string => {
|
|
2
|
-
const formattedCastingType = castingType
|
|
3
|
-
.split("-")
|
|
4
|
-
.map(word => word.charAt(0).toUpperCase() + word.slice(1))
|
|
5
|
-
.join(" ");
|
|
6
|
-
|
|
7
|
-
return formattedCastingType;
|
|
1
|
+
export const formatSpellCastingType = (castingType: string): string => {
|
|
2
|
+
const formattedCastingType = castingType
|
|
3
|
+
.split("-")
|
|
4
|
+
.map(word => word.charAt(0).toUpperCase() + word.slice(1))
|
|
5
|
+
.join(" ");
|
|
6
|
+
|
|
7
|
+
return formattedCastingType;
|
|
8
8
|
};
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export const chunkString = (str: string, length: number) => {
|
|
2
|
-
return str.match(new RegExp('.{1,' + length + '}', 'g'));
|
|
3
|
-
};
|
|
1
|
+
export const chunkString = (str: string, length: number) => {
|
|
2
|
+
return str.match(new RegExp('.{1,' + length + '}', 'g'));
|
|
3
|
+
};
|
package/src/libs/itemCounter.ts
CHANGED
|
@@ -1,22 +1,22 @@
|
|
|
1
|
-
import { IItem, IItemContainer } from "@rpg-engine/shared";
|
|
2
|
-
|
|
3
|
-
export const countItemFromInventory = (itemKey: string, inventory: IItemContainer) => {
|
|
4
|
-
let itemsFromInventory: (IItem | undefined | null)[] = [];
|
|
5
|
-
|
|
6
|
-
if (inventory) {
|
|
7
|
-
Object.keys(inventory.slots).forEach(i => {
|
|
8
|
-
const index = parseInt(i);
|
|
9
|
-
|
|
10
|
-
if (inventory.slots[index]?.key === itemKey) {
|
|
11
|
-
itemsFromInventory.push(inventory.slots[index]);
|
|
12
|
-
}
|
|
13
|
-
});
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
const totalQty = itemsFromInventory.reduce(
|
|
17
|
-
(acc, item) => acc + (item?.stackQty || 1),
|
|
18
|
-
0
|
|
19
|
-
);
|
|
20
|
-
|
|
21
|
-
return totalQty;
|
|
1
|
+
import { IItem, IItemContainer } from "@rpg-engine/shared";
|
|
2
|
+
|
|
3
|
+
export const countItemFromInventory = (itemKey: string, inventory: IItemContainer) => {
|
|
4
|
+
let itemsFromInventory: (IItem | undefined | null)[] = [];
|
|
5
|
+
|
|
6
|
+
if (inventory) {
|
|
7
|
+
Object.keys(inventory.slots).forEach(i => {
|
|
8
|
+
const index = parseInt(i);
|
|
9
|
+
|
|
10
|
+
if (inventory.slots[index]?.key === itemKey) {
|
|
11
|
+
itemsFromInventory.push(inventory.slots[index]);
|
|
12
|
+
}
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
const totalQty = itemsFromInventory.reduce(
|
|
17
|
+
(acc, item) => acc + (item?.stackQty || 1),
|
|
18
|
+
0
|
|
19
|
+
);
|
|
20
|
+
|
|
21
|
+
return totalQty;
|
|
22
22
|
};
|