@rpg-engine/long-bow 0.4.7 → 0.4.8

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.
Files changed (177) hide show
  1. package/LICENSE +20 -20
  2. package/README.md +181 -181
  3. package/dist/components/ConfirmModal.d.ts +8 -0
  4. package/dist/components/DraggableContainer.d.ts +1 -0
  5. package/dist/components/Item/Inventory/ItemSlot.d.ts +7 -7
  6. package/dist/components/Marketplace/BuyPanel.d.ts +22 -0
  7. package/dist/components/Marketplace/ManagmentPanel.d.ts +18 -0
  8. package/dist/components/Marketplace/Marketplace.d.ts +22 -9
  9. package/dist/components/Marketplace/MarketplaceRows.d.ts +3 -1
  10. package/dist/components/Marketplace/{__mocks__ → filters}/index.d.ts +1 -3
  11. package/dist/components/Pager.d.ts +9 -0
  12. package/dist/long-bow.cjs.development.js +1540 -1163
  13. package/dist/long-bow.cjs.development.js.map +1 -1
  14. package/dist/long-bow.cjs.production.min.js +1 -1
  15. package/dist/long-bow.cjs.production.min.js.map +1 -1
  16. package/dist/long-bow.esm.js +1594 -1217
  17. package/dist/long-bow.esm.js.map +1 -1
  18. package/package.json +100 -100
  19. package/src/components/Abstractions/ModalPortal.tsx +22 -22
  20. package/src/components/Abstractions/SlotsContainer.tsx +62 -62
  21. package/src/components/Arrow/SelectArrow.tsx +69 -69
  22. package/src/components/Arrow/img/arrow01-left-clicked.png +0 -0
  23. package/src/components/Arrow/img/arrow01-left.png +0 -0
  24. package/src/components/Arrow/img/arrow01-right-clicked.png +0 -0
  25. package/src/components/Arrow/img/arrow01-right.png +0 -0
  26. package/src/components/Arrow/img/arrow02-left-clicked.png +0 -0
  27. package/src/components/Arrow/img/arrow02-left.png +0 -0
  28. package/src/components/Arrow/img/arrow02-right-clicked.png +0 -0
  29. package/src/components/Arrow/img/arrow02-right.png +0 -0
  30. package/src/components/Button.tsx +40 -40
  31. package/src/components/Character/CharacterSelection.tsx +98 -98
  32. package/src/components/CharacterStatus/CharacterStatus.tsx +120 -120
  33. package/src/components/Chat/Chat.tsx +196 -196
  34. package/src/components/Chatdeprecated/ChatDeprecated.tsx +198 -198
  35. package/src/components/CheckButton.tsx +65 -65
  36. package/src/components/CircularController/CircularController.tsx +282 -282
  37. package/src/components/ConfirmModal.tsx +87 -0
  38. package/src/components/CraftBook/CraftBook.tsx +286 -286
  39. package/src/components/CraftBook/CraftingRecipe.tsx +161 -161
  40. package/src/components/CraftBook/MockItems.ts +101 -101
  41. package/src/components/DraggableContainer.tsx +183 -180
  42. package/src/components/Dropdown.tsx +14 -6
  43. package/src/components/DropdownSelectorContainer.tsx +42 -42
  44. package/src/components/Equipment/EquipmentSet.tsx +199 -199
  45. package/src/components/HistoryDialog.tsx +104 -104
  46. package/src/components/Input.tsx +15 -15
  47. package/src/components/InputRadio.tsx +41 -41
  48. package/src/components/Item/Cards/ItemInfo.tsx +298 -298
  49. package/src/components/Item/Cards/ItemInfoDisplay.tsx +135 -135
  50. package/src/components/Item/Cards/ItemInfoWrapper.tsx +62 -62
  51. package/src/components/Item/Cards/ItemTooltip.tsx +83 -83
  52. package/src/components/Item/Cards/MobileItemTooltip.tsx +149 -149
  53. package/src/components/Item/Inventory/ErrorBoundary.tsx +42 -42
  54. package/src/components/Item/Inventory/ItemContainer.tsx +231 -231
  55. package/src/components/Item/Inventory/ItemContainerTypes.ts +6 -6
  56. package/src/components/Item/Inventory/ItemQuantitySelector.tsx +138 -138
  57. package/src/components/Item/Inventory/ItemSlot.tsx +595 -580
  58. package/src/components/Item/Inventory/itemContainerHelper.ts +175 -175
  59. package/src/components/ListMenu.tsx +63 -63
  60. package/src/components/Marketplace/BuyPanel.tsx +296 -0
  61. package/src/components/Marketplace/ManagmentPanel.tsx +247 -0
  62. package/src/components/Marketplace/Marketplace.tsx +106 -132
  63. package/src/components/Marketplace/MarketplaceRows.tsx +161 -171
  64. package/src/components/Marketplace/{__mocks__ → filters}/index.tsx +67 -65
  65. package/src/components/Multitab/Tab.tsx +66 -66
  66. package/src/components/Multitab/TabBody.tsx +13 -13
  67. package/src/components/Multitab/TabsContainer.tsx +97 -97
  68. package/src/components/NPCDialog/NPCDialog.tsx +121 -121
  69. package/src/components/NPCDialog/NPCDialogText.tsx +113 -113
  70. package/src/components/NPCDialog/NPCMultiDialog.tsx +159 -159
  71. package/src/components/NPCDialog/QuestionDialog/QuestionDialog.tsx +237 -237
  72. package/src/components/Pager.tsx +94 -0
  73. package/src/components/ProgressBar.tsx +95 -95
  74. package/src/components/PropertySelect/PropertySelect.tsx +106 -106
  75. package/src/components/QuestInfo/QuestInfo.tsx +233 -233
  76. package/src/components/QuestList.tsx +135 -135
  77. package/src/components/RPGUIContainer.tsx +47 -47
  78. package/src/components/RPGUIForceRenderStart.tsx +45 -45
  79. package/src/components/RPGUIRoot.tsx +14 -14
  80. package/src/components/RadioButton.tsx +53 -53
  81. package/src/components/RadioInput/RadioButton.tsx +96 -96
  82. package/src/components/RadioInput/RadioInput.tsx +102 -102
  83. package/src/components/RadioInput/instruments.ts +15 -15
  84. package/src/components/RangeSlider.tsx +78 -78
  85. package/src/components/RelativeListMenu.tsx +90 -90
  86. package/src/components/ScrollList.tsx +79 -79
  87. package/src/components/Shortcuts/Shortcuts.tsx +193 -193
  88. package/src/components/Shortcuts/ShortcutsSetter.tsx +139 -139
  89. package/src/components/Shortcuts/SingleShortcut.ts +82 -82
  90. package/src/components/Shortcuts/useShortcutCooldown.ts +23 -23
  91. package/src/components/SimpleProgressBar.tsx +62 -62
  92. package/src/components/SkillProgressBar.tsx +198 -198
  93. package/src/components/SkillsContainer.tsx +213 -213
  94. package/src/components/Spellbook/Spell.tsx +235 -236
  95. package/src/components/Spellbook/Spellbook.tsx +145 -161
  96. package/src/components/Spellbook/cards/MobileSpellTooltip.tsx +137 -137
  97. package/src/components/Spellbook/cards/SpellInfo.tsx +134 -134
  98. package/src/components/Spellbook/cards/SpellInfoDisplay.tsx +31 -31
  99. package/src/components/Spellbook/cards/SpellInfoWrapper.tsx +48 -48
  100. package/src/components/Spellbook/cards/SpellTooltip.tsx +70 -70
  101. package/src/components/Spellbook/constants.ts +7 -7
  102. package/src/components/Spellbook/mockSpells.ts +84 -84
  103. package/src/components/StaticBook/StaticBook.tsx +103 -103
  104. package/src/components/TextArea.tsx +11 -11
  105. package/src/components/TimeWidget/DayNightPeriod/DayNightPeriod.tsx +35 -35
  106. package/src/components/TimeWidget/TimeWidget.tsx +65 -65
  107. package/src/components/TradingMenu/TradingItemRow.tsx +199 -199
  108. package/src/components/TradingMenu/TradingMenu.tsx +219 -219
  109. package/src/components/TradingMenu/items.mock.ts +48 -48
  110. package/src/components/Truncate.tsx +25 -25
  111. package/src/components/itemSelector/ItemSelector.tsx +136 -136
  112. package/src/components/shared/Column.tsx +16 -16
  113. package/src/components/shared/Ellipsis.tsx +76 -68
  114. package/src/components/shared/SpriteFromAtlas.tsx +104 -104
  115. package/src/components/typography/DynamicText.tsx +49 -49
  116. package/src/constants/uiColors.ts +20 -20
  117. package/src/constants/uiDevices.ts +3 -3
  118. package/src/constants/uiFonts.ts +12 -12
  119. package/src/hooks/useEventListener.ts +21 -21
  120. package/src/hooks/useOutsideAlerter.ts +25 -25
  121. package/src/index.tsx +42 -42
  122. package/src/libs/CastingTypeHelper.ts +7 -7
  123. package/src/libs/StringHelpers.ts +3 -3
  124. package/src/libs/itemCounter.ts +21 -21
  125. package/src/mocks/atlas/entities/entities.json +20215 -20215
  126. package/src/mocks/atlas/icons/icons.json +735 -735
  127. package/src/mocks/atlas/items/items.json +12086 -12086
  128. package/src/mocks/equipmentSet.mocks.ts +391 -391
  129. package/src/mocks/itemContainer.mocks.ts +605 -605
  130. package/src/mocks/skills.mocks.ts +130 -130
  131. package/src/stories/Arrow.stories.tsx +26 -26
  132. package/src/stories/Button.stories.tsx +36 -36
  133. package/src/stories/CharacterSelection.stories.tsx +44 -44
  134. package/src/stories/CharacterStatus.stories.tsx +29 -29
  135. package/src/stories/Chat.stories.tsx +187 -187
  136. package/src/stories/ChatDeprecated.stories.tsx +170 -170
  137. package/src/stories/CheckButton.stories.tsx +48 -48
  138. package/src/stories/CircullarController.stories.tsx +37 -37
  139. package/src/stories/CraftBook.stories.tsx +42 -42
  140. package/src/stories/DayNightPeriod.stories.tsx +27 -27
  141. package/src/stories/DraggableContainer.stories.tsx +28 -28
  142. package/src/stories/Dropdown.stories.tsx +46 -46
  143. package/src/stories/DropdownSelectorContainer.stories.tsx +41 -41
  144. package/src/stories/EquipmentSet.stories.tsx +65 -65
  145. package/src/stories/HistoryDialog.stories.tsx +61 -61
  146. package/src/stories/ItemContainer.stories.tsx +201 -201
  147. package/src/stories/ItemInfoDisplay.stories.tsx +33 -33
  148. package/src/stories/ItemQuantitySelector.stories.tsx +26 -26
  149. package/src/stories/ItemSelector.stories.tsx +77 -77
  150. package/src/stories/ItemTradingComponent.stories.tsx +35 -35
  151. package/src/stories/ListMenu.stories.tsx +56 -56
  152. package/src/stories/Marketplace.stories.tsx +53 -42
  153. package/src/stories/MarketplaceRows.stories.tsx +28 -28
  154. package/src/stories/Multitab.stories.tsx +51 -51
  155. package/src/stories/NPCDialog.stories.tsx +130 -130
  156. package/src/stories/NPCMultiDialog.stories.tsx +71 -71
  157. package/src/stories/ProgressBar.stories.tsx +23 -23
  158. package/src/stories/PropertySelect.stories.tsx +40 -40
  159. package/src/stories/QuestInfo.stories.tsx +107 -107
  160. package/src/stories/QuestList.stories.tsx +82 -82
  161. package/src/stories/RPGUIContainers.stories.tsx +42 -42
  162. package/src/stories/RadioButton.stories.tsx +49 -49
  163. package/src/stories/RadioInput.stories.tsx +34 -34
  164. package/src/stories/RangeSlider.stories.tsx +64 -64
  165. package/src/stories/ScrollList.stories.tsx +85 -85
  166. package/src/stories/Shortcuts.stories.tsx +39 -39
  167. package/src/stories/SimpleProgressBar.stories.tsx +22 -22
  168. package/src/stories/SkillProgressBar.stories.tsx +34 -34
  169. package/src/stories/SkillsContainer.stories.tsx +35 -35
  170. package/src/stories/SpellInfoDisplay.stories.tsx +27 -27
  171. package/src/stories/Spellbook.stories.tsx +104 -104
  172. package/src/stories/StaticBook.stories.tsx +32 -32
  173. package/src/stories/Text.stories.tsx +42 -42
  174. package/src/stories/TimeWidget.stories.tsx +27 -27
  175. package/src/stories/TradingMenu.stories.tsx +47 -47
  176. package/src/types/eventTypes.ts +4 -4
  177. 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();
@@ -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
+ };
@@ -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
  };