@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,82 +1,82 @@
1
- import styled from 'styled-components';
2
- import { uiColors } from '../../constants/uiColors';
3
-
4
- export const SingleShortcut = styled.button`
5
- width: 3rem;
6
- height: 3rem;
7
- background-color: ${uiColors.lightGray};
8
- border: 2px solid ${uiColors.darkGray};
9
- border-radius: 50%;
10
- text-transform: uppercase;
11
- font-size: 0.7rem;
12
- font-weight: bold;
13
- display: flex;
14
- align-items: center;
15
- justify-content: center;
16
- position: relative;
17
-
18
- span {
19
- pointer-events: none;
20
- }
21
-
22
- .mana {
23
- position: absolute;
24
- top: -5px;
25
- right: 0;
26
- font-size: 0.65rem;
27
- color: ${uiColors.blue};
28
- }
29
-
30
- .qty {
31
- position: absolute;
32
- top: -5px;
33
- right: 0;
34
- font-size: 0.65rem;
35
- }
36
-
37
- .magicWords {
38
- margin-top: 4px;
39
- }
40
-
41
- .keyboard {
42
- position: absolute;
43
- bottom: -5px;
44
- left: 0;
45
- font-size: 0.65rem;
46
- color: ${uiColors.yellow};
47
- }
48
-
49
- .onCooldown {
50
- color: ${uiColors.gray};
51
- }
52
-
53
- .cooldown {
54
- position: absolute;
55
- z-index: 1;
56
- top: 0;
57
- left: 0;
58
- width: 100%;
59
- height: 100%;
60
- border-radius: inherit;
61
- background-color: rgba(0 0 0 / 60%);
62
- font-size: 0.7rem;
63
- display: flex;
64
- align-items: center;
65
- justify-content: center;
66
- color: ${uiColors.darkYellow};
67
- }
68
-
69
- &:hover,
70
- &:focus {
71
- background-color: ${uiColors.darkGray};
72
- }
73
-
74
- &:active {
75
- background-color: ${uiColors.gray};
76
- border-color: ${uiColors.yellow};
77
- }
78
-
79
- &:disabled {
80
- opacity: 0.5;
81
- }
82
- `;
1
+ import styled from 'styled-components';
2
+ import { uiColors } from '../../constants/uiColors';
3
+
4
+ export const SingleShortcut = styled.button`
5
+ width: 3rem;
6
+ height: 3rem;
7
+ background-color: ${uiColors.lightGray};
8
+ border: 2px solid ${uiColors.darkGray};
9
+ border-radius: 50%;
10
+ text-transform: uppercase;
11
+ font-size: 0.7rem;
12
+ font-weight: bold;
13
+ display: flex;
14
+ align-items: center;
15
+ justify-content: center;
16
+ position: relative;
17
+
18
+ span {
19
+ pointer-events: none;
20
+ }
21
+
22
+ .mana {
23
+ position: absolute;
24
+ top: -5px;
25
+ right: 0;
26
+ font-size: 0.65rem;
27
+ color: ${uiColors.blue};
28
+ }
29
+
30
+ .qty {
31
+ position: absolute;
32
+ top: -5px;
33
+ right: 0;
34
+ font-size: 0.65rem;
35
+ }
36
+
37
+ .magicWords {
38
+ margin-top: 4px;
39
+ }
40
+
41
+ .keyboard {
42
+ position: absolute;
43
+ bottom: -5px;
44
+ left: 0;
45
+ font-size: 0.65rem;
46
+ color: ${uiColors.yellow};
47
+ }
48
+
49
+ .onCooldown {
50
+ color: ${uiColors.gray};
51
+ }
52
+
53
+ .cooldown {
54
+ position: absolute;
55
+ z-index: 1;
56
+ top: 0;
57
+ left: 0;
58
+ width: 100%;
59
+ height: 100%;
60
+ border-radius: inherit;
61
+ background-color: rgba(0 0 0 / 60%);
62
+ font-size: 0.7rem;
63
+ display: flex;
64
+ align-items: center;
65
+ justify-content: center;
66
+ color: ${uiColors.darkYellow};
67
+ }
68
+
69
+ &:hover,
70
+ &:focus {
71
+ background-color: ${uiColors.darkGray};
72
+ }
73
+
74
+ &:active {
75
+ background-color: ${uiColors.gray};
76
+ border-color: ${uiColors.yellow};
77
+ }
78
+
79
+ &:disabled {
80
+ opacity: 0.5;
81
+ }
82
+ `;
@@ -1,24 +1,24 @@
1
- import { useEffect, useRef, useState } from "react";
2
-
3
- export const useShortcutCooldown = (onShortcutCast: (index: number) => void) => {
4
- const [shortcutCooldown, setShortcutCooldown] = useState(0);
5
- const cooldownTimeout = useRef<NodeJS.Timeout | null>(null);
6
-
7
- const handleShortcutCast = (index: number) => {
8
- console.log(shortcutCooldown);
9
- if (shortcutCooldown <= 0) setShortcutCooldown(1.5);
10
- onShortcutCast(index);
11
- };
12
-
13
- useEffect(() => {
14
- if (cooldownTimeout.current) clearTimeout(cooldownTimeout.current);
15
-
16
- if (shortcutCooldown > 0) {
17
- cooldownTimeout.current = setTimeout(() => {
18
- setShortcutCooldown(shortcutCooldown - 0.1);
19
- }, 100);
20
- }
21
- }, [shortcutCooldown]);
22
-
23
- return { shortcutCooldown, handleShortcutCast };
1
+ import { useEffect, useRef, useState } from "react";
2
+
3
+ export const useShortcutCooldown = (onShortcutCast: (index: number) => void) => {
4
+ const [shortcutCooldown, setShortcutCooldown] = useState(0);
5
+ const cooldownTimeout = useRef<NodeJS.Timeout | null>(null);
6
+
7
+ const handleShortcutCast = (index: number) => {
8
+ console.log(shortcutCooldown);
9
+ if (shortcutCooldown <= 0) setShortcutCooldown(1.5);
10
+ onShortcutCast(index);
11
+ };
12
+
13
+ useEffect(() => {
14
+ if (cooldownTimeout.current) clearTimeout(cooldownTimeout.current);
15
+
16
+ if (shortcutCooldown > 0) {
17
+ cooldownTimeout.current = setTimeout(() => {
18
+ setShortcutCooldown(shortcutCooldown - 0.1);
19
+ }, 100);
20
+ }
21
+ }, [shortcutCooldown]);
22
+
23
+ return { shortcutCooldown, handleShortcutCast };
24
24
  };
@@ -1,62 +1,62 @@
1
- import React from 'react';
2
- import styled from 'styled-components';
3
-
4
- export interface ISimpleProgressBarProps {
5
- value: number;
6
- bgColor?: string;
7
- margin?: number;
8
- }
9
-
10
- export const SimpleProgressBar: React.FC<ISimpleProgressBarProps> = ({
11
- value,
12
- bgColor = 'red',
13
- margin = 20,
14
- }) => {
15
- return (
16
- <Container className="simple-progress-bar">
17
- <ProgressBarContainer margin={margin}>
18
- <BackgroundBar>
19
- <Progress value={value} bgColor={bgColor} />
20
- </BackgroundBar>
21
- </ProgressBarContainer>
22
- </Container>
23
- );
24
- };
25
-
26
- const Container = styled.div`
27
- display: flex;
28
- justify-content: center;
29
- align-items: center;
30
- width: 100%;
31
- `;
32
-
33
- const BackgroundBar = styled.span`
34
- background-color: rgba(0, 0, 0, 0.075);
35
- `;
36
-
37
- interface ISimpleProgressBarThemeProps {
38
- value: number;
39
- bgColor: string;
40
- }
41
-
42
- const Progress = styled.span`
43
- background-color: ${(props: ISimpleProgressBarThemeProps) => props.bgColor};
44
- width: ${(props: ISimpleProgressBarThemeProps) => props.value}%;
45
- `;
46
-
47
- interface ISimpleProgressBarTheme2Props {
48
- margin: number;
49
- }
50
-
51
- const ProgressBarContainer = styled.div`
52
- border-radius: 60px;
53
- border: 1px solid #282424;
54
- overflow: hidden;
55
- width: 100%;
56
- span {
57
- display: block;
58
- height: 100%;
59
- }
60
- height: 8px;
61
- margin-left: ${(props: ISimpleProgressBarTheme2Props) => props.margin}px;
62
- `;
1
+ import React from 'react';
2
+ import styled from 'styled-components';
3
+
4
+ export interface ISimpleProgressBarProps {
5
+ value: number;
6
+ bgColor?: string;
7
+ margin?: number;
8
+ }
9
+
10
+ export const SimpleProgressBar: React.FC<ISimpleProgressBarProps> = ({
11
+ value,
12
+ bgColor = 'red',
13
+ margin = 20,
14
+ }) => {
15
+ return (
16
+ <Container className="simple-progress-bar">
17
+ <ProgressBarContainer margin={margin}>
18
+ <BackgroundBar>
19
+ <Progress value={value} bgColor={bgColor} />
20
+ </BackgroundBar>
21
+ </ProgressBarContainer>
22
+ </Container>
23
+ );
24
+ };
25
+
26
+ const Container = styled.div`
27
+ display: flex;
28
+ justify-content: center;
29
+ align-items: center;
30
+ width: 100%;
31
+ `;
32
+
33
+ const BackgroundBar = styled.span`
34
+ background-color: rgba(0, 0, 0, 0.075);
35
+ `;
36
+
37
+ interface ISimpleProgressBarThemeProps {
38
+ value: number;
39
+ bgColor: string;
40
+ }
41
+
42
+ const Progress = styled.span`
43
+ background-color: ${(props: ISimpleProgressBarThemeProps) => props.bgColor};
44
+ width: ${(props: ISimpleProgressBarThemeProps) => props.value}%;
45
+ `;
46
+
47
+ interface ISimpleProgressBarTheme2Props {
48
+ margin: number;
49
+ }
50
+
51
+ const ProgressBarContainer = styled.div`
52
+ border-radius: 60px;
53
+ border: 1px solid #282424;
54
+ overflow: hidden;
55
+ width: 100%;
56
+ span {
57
+ display: block;
58
+ height: 100%;
59
+ }
60
+ height: 8px;
61
+ margin-left: ${(props: ISimpleProgressBarTheme2Props) => props.margin}px;
62
+ `;