@rpg-engine/long-bow 0.3.53 → 0.3.55

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 (163) hide show
  1. package/LICENSE +20 -20
  2. package/README.md +181 -181
  3. package/dist/components/Arrow/SelectArrow.d.ts +1 -1
  4. package/dist/components/Button.d.ts +2 -2
  5. package/dist/components/CircularController/CircularController.d.ts +4 -7
  6. package/dist/components/Item/Inventory/ItemContainer.d.ts +1 -4
  7. package/dist/components/Item/Inventory/ItemSlot.d.ts +1 -2
  8. package/dist/components/Multitab/Tab.d.ts +1 -1
  9. package/dist/components/QuestInfo/QuestInfo.d.ts +1 -1
  10. package/dist/components/Spellbook/QuickSpells.d.ts +10 -0
  11. package/dist/components/Spellbook/Spell.d.ts +1 -1
  12. package/dist/components/Spellbook/Spellbook.d.ts +3 -5
  13. package/dist/components/Spellbook/SpellbookShortcuts.d.ts +10 -0
  14. package/dist/components/Spellbook/constants.d.ts +3 -3
  15. package/dist/components/shared/SpriteFromAtlas.d.ts +1 -1
  16. package/dist/index.d.ts +1 -1
  17. package/dist/long-bow.cjs.development.js +734 -914
  18. package/dist/long-bow.cjs.development.js.map +1 -1
  19. package/dist/long-bow.cjs.production.min.js +1 -1
  20. package/dist/long-bow.cjs.production.min.js.map +1 -1
  21. package/dist/long-bow.esm.js +736 -917
  22. package/dist/long-bow.esm.js.map +1 -1
  23. package/dist/stories/{Shortcuts.stories.d.ts → QuickSpells.stories.d.ts} +2 -2
  24. package/package.json +100 -100
  25. package/src/components/Abstractions/SlotsContainer.tsx +45 -45
  26. package/src/components/Arrow/SelectArrow.tsx +69 -65
  27. package/src/components/Arrow/img/arrow01-left-clicked.png +0 -0
  28. package/src/components/Arrow/img/arrow01-left.png +0 -0
  29. package/src/components/Arrow/img/arrow01-right-clicked.png +0 -0
  30. package/src/components/Arrow/img/arrow01-right.png +0 -0
  31. package/src/components/Arrow/img/arrow02-left-clicked.png +0 -0
  32. package/src/components/Arrow/img/arrow02-left.png +0 -0
  33. package/src/components/Arrow/img/arrow02-right-clicked.png +0 -0
  34. package/src/components/Arrow/img/arrow02-right.png +0 -0
  35. package/src/components/Button.tsx +40 -41
  36. package/src/components/Character/CharacterSelection.tsx +96 -96
  37. package/src/components/CharacterStatus/CharacterStatus.tsx +120 -120
  38. package/src/components/Chat/Chat.tsx +195 -195
  39. package/src/components/Chatdeprecated/ChatDeprecated.tsx +198 -200
  40. package/src/components/CheckButton.tsx +65 -65
  41. package/src/components/CircularController/CircularController.tsx +162 -245
  42. package/src/components/CraftBook/CraftBook.tsx +224 -235
  43. package/src/components/CraftBook/MockItems.ts +46 -46
  44. package/src/components/DraggableContainer.tsx +153 -154
  45. package/src/components/Dropdown.tsx +90 -96
  46. package/src/components/DropdownSelectorContainer.tsx +42 -42
  47. package/src/components/Equipment/EquipmentSet.tsx +190 -190
  48. package/src/components/HistoryDialog.tsx +104 -104
  49. package/src/components/Input.tsx +15 -15
  50. package/src/components/Item/Cards/ItemTooltip.tsx +33 -33
  51. package/src/components/Item/Inventory/ErrorBoundary.tsx +42 -42
  52. package/src/components/Item/Inventory/ItemContainer.tsx +175 -210
  53. package/src/components/Item/Inventory/ItemContainerTypes.ts +6 -6
  54. package/src/components/Item/Inventory/ItemQuantitySelector.tsx +138 -142
  55. package/src/components/Item/Inventory/ItemSlot.tsx +467 -502
  56. package/src/components/Item/Inventory/itemContainerHelper.ts +156 -156
  57. package/src/components/ListMenu.tsx +63 -63
  58. package/src/components/Multitab/Tab.tsx +66 -57
  59. package/src/components/Multitab/TabBody.tsx +13 -13
  60. package/src/components/Multitab/TabsContainer.tsx +97 -97
  61. package/src/components/NPCDialog/NPCDialog.tsx +121 -121
  62. package/src/components/NPCDialog/NPCDialogText.tsx +113 -113
  63. package/src/components/NPCDialog/NPCMultiDialog.tsx +159 -159
  64. package/src/components/NPCDialog/QuestionDialog/QuestionDialog.tsx +237 -237
  65. package/src/components/ProgressBar.tsx +92 -92
  66. package/src/components/PropertySelect/PropertySelect.tsx +106 -114
  67. package/src/components/QuestInfo/QuestInfo.tsx +230 -232
  68. package/src/components/QuestList.tsx +129 -129
  69. package/src/components/RPGUIContainer.tsx +47 -47
  70. package/src/components/RPGUIForceRenderStart.tsx +45 -45
  71. package/src/components/RPGUIRoot.tsx +14 -14
  72. package/src/components/RadioButton.tsx +53 -53
  73. package/src/components/RadioInput/RadioButton.tsx +96 -98
  74. package/src/components/RadioInput/RadioInput.tsx +102 -99
  75. package/src/components/RadioInput/instruments.ts +15 -15
  76. package/src/components/RangeSlider.tsx +78 -78
  77. package/src/components/RelativeListMenu.tsx +83 -83
  78. package/src/components/ScrollList.tsx +79 -79
  79. package/src/components/SimpleProgressBar.tsx +62 -62
  80. package/src/components/SkillProgressBar.tsx +133 -133
  81. package/src/components/SkillsContainer.tsx +198 -200
  82. package/src/components/Spellbook/QuickSpells.tsx +120 -0
  83. package/src/components/Spellbook/Spell.tsx +201 -201
  84. package/src/components/Spellbook/Spellbook.tsx +144 -150
  85. package/src/components/Spellbook/SpellbookShortcuts.tsx +77 -0
  86. package/src/components/Spellbook/constants.ts +12 -8
  87. package/src/components/Spellbook/mockSpells.ts +60 -60
  88. package/src/components/StaticBook/StaticBook.tsx +103 -105
  89. package/src/components/TextArea.tsx +11 -11
  90. package/src/components/TimeWidget/DayNightPeriod/DayNightPeriod.tsx +35 -35
  91. package/src/components/TimeWidget/TimeWidget.tsx +63 -63
  92. package/src/components/TradingMenu/TradingItemRow.tsx +193 -197
  93. package/src/components/TradingMenu/TradingMenu.tsx +203 -203
  94. package/src/components/TradingMenu/items.mock.ts +96 -96
  95. package/src/components/Truncate.tsx +25 -25
  96. package/src/components/itemSelector/ItemSelector.tsx +136 -136
  97. package/src/components/shared/Column.tsx +16 -16
  98. package/src/components/shared/Ellipsis.tsx +65 -65
  99. package/src/components/shared/SpriteFromAtlas.tsx +102 -102
  100. package/src/components/typography/DynamicText.tsx +49 -49
  101. package/src/constants/uiColors.ts +20 -20
  102. package/src/constants/uiDevices.ts +3 -3
  103. package/src/constants/uiFonts.ts +12 -12
  104. package/src/hooks/useEventListener.ts +21 -21
  105. package/src/hooks/useOutsideAlerter.ts +25 -25
  106. package/src/index.tsx +40 -40
  107. package/src/libs/StringHelpers.ts +3 -3
  108. package/src/mocks/atlas/entities/entities.json +20215 -20215
  109. package/src/mocks/atlas/icons/icons.json +735 -735
  110. package/src/mocks/atlas/items/items.json +12086 -12086
  111. package/src/mocks/equipmentSet.mocks.ts +393 -393
  112. package/src/mocks/itemContainer.mocks.ts +560 -562
  113. package/src/mocks/skills.mocks.ts +128 -128
  114. package/src/stories/Arrow.stories.tsx +26 -26
  115. package/src/stories/Button.stories.tsx +36 -36
  116. package/src/stories/CharacterSelection.stories.tsx +45 -45
  117. package/src/stories/CharacterStatus.stories.tsx +29 -29
  118. package/src/stories/Chat.stories.tsx +187 -187
  119. package/src/stories/ChatDeprecated.stories.tsx +170 -170
  120. package/src/stories/CheckButton.stories.tsx +48 -48
  121. package/src/stories/CircullarController.stories.tsx +33 -37
  122. package/src/stories/CraftBook.stories.tsx +40 -40
  123. package/src/stories/DayNightPeriod.stories.tsx +27 -27
  124. package/src/stories/DraggableContainer.stories.tsx +28 -28
  125. package/src/stories/Dropdown.stories.tsx +46 -46
  126. package/src/stories/DropdownSelectorContainer.stories.tsx +41 -41
  127. package/src/stories/EquipmentSet.stories.tsx +65 -65
  128. package/src/stories/HistoryDialog.stories.tsx +61 -61
  129. package/src/stories/ItemContainer.stories.tsx +124 -198
  130. package/src/stories/ItemQuantitySelector.stories.tsx +26 -26
  131. package/src/stories/ItemSelector.stories.tsx +77 -77
  132. package/src/stories/ItemTradingComponent.stories.tsx +35 -35
  133. package/src/stories/ListMenu.stories.tsx +56 -56
  134. package/src/stories/Multitab.stories.tsx +51 -51
  135. package/src/stories/NPCDialog.stories.tsx +130 -130
  136. package/src/stories/NPCMultiDialog.stories.tsx +71 -71
  137. package/src/stories/ProgressBar.stories.tsx +23 -23
  138. package/src/stories/PropertySelect.stories.tsx +40 -40
  139. package/src/stories/QuestInfo.stories.tsx +110 -107
  140. package/src/stories/QuestList.stories.tsx +82 -82
  141. package/src/stories/QuickSpells.stories.tsx +38 -0
  142. package/src/stories/RPGUIContainers.stories.tsx +42 -42
  143. package/src/stories/RadioButton.stories.tsx +49 -49
  144. package/src/stories/RadioInput.stories.tsx +34 -34
  145. package/src/stories/RangeSlider.stories.tsx +64 -64
  146. package/src/stories/ScrollList.stories.tsx +85 -85
  147. package/src/stories/SimpleProgressBar.stories.tsx +22 -22
  148. package/src/stories/SkillProgressBar.stories.tsx +34 -34
  149. package/src/stories/SkillsContainer.stories.tsx +35 -35
  150. package/src/stories/Spellbook.stories.tsx +107 -104
  151. package/src/stories/StaticBook.stories.tsx +32 -32
  152. package/src/stories/Text.stories.tsx +42 -42
  153. package/src/stories/TimeWidget.stories.tsx +27 -27
  154. package/src/stories/TradingMenu.stories.tsx +45 -45
  155. package/src/types/eventTypes.ts +4 -4
  156. package/src/types/index.d.ts +2 -2
  157. package/dist/components/Shortcuts/Shortcuts.d.ts +0 -12
  158. package/dist/components/Shortcuts/ShortcutsSetter.d.ts +0 -12
  159. package/dist/components/Shortcuts/SingleShortcut.d.ts +0 -1
  160. package/src/components/Shortcuts/Shortcuts.tsx +0 -129
  161. package/src/components/Shortcuts/ShortcutsSetter.tsx +0 -132
  162. package/src/components/Shortcuts/SingleShortcut.ts +0 -61
  163. package/src/stories/Shortcuts.stories.tsx +0 -39
@@ -1,129 +0,0 @@
1
- import {
2
- getItemTextureKeyPath,
3
- IItem,
4
- IItemContainer,
5
- IRawSpell,
6
- IShortcut,
7
- ShortcutType,
8
- } from '@rpg-engine/shared';
9
- import React, { useEffect } from 'react';
10
- import styled from 'styled-components';
11
- import { SpriteFromAtlas } from '../shared/SpriteFromAtlas';
12
- import { SingleShortcut } from './SingleShortcut';
13
-
14
- export type ShortcutsProps = {
15
- shortcuts: IShortcut[];
16
- onShortcutCast: (index: number) => void;
17
- mana: number;
18
- isBlockedCastingByKeyboard?: boolean;
19
- inventory?: IItemContainer | null;
20
- atlasJSON: any;
21
- atlasIMG: any;
22
- };
23
-
24
- export const Shortcuts: React.FC<ShortcutsProps> = ({
25
- shortcuts,
26
- onShortcutCast,
27
- mana,
28
- isBlockedCastingByKeyboard = false,
29
- atlasJSON,
30
- atlasIMG,
31
- inventory,
32
- }) => {
33
- useEffect(() => {
34
- const handleKeyDown = (e: KeyboardEvent) => {
35
- if (isBlockedCastingByKeyboard) return;
36
-
37
- const shortcutIndex = Number(e.key) - 1;
38
- if (shortcutIndex >= 0 && shortcutIndex <= 5) {
39
- onShortcutCast(shortcutIndex);
40
- }
41
- };
42
-
43
- window.addEventListener('keydown', handleKeyDown);
44
-
45
- return () => {
46
- window.removeEventListener('keydown', handleKeyDown);
47
- };
48
- }, [shortcuts, isBlockedCastingByKeyboard]);
49
-
50
- return (
51
- <List>
52
- {Array.from({ length: 6 }).map((_, i) => {
53
- if (shortcuts[i]?.type === ShortcutType.Item) {
54
- const payload = shortcuts[i]?.payload as IItem | undefined;
55
-
56
- let itemsFromEquipment: (IItem | undefined | null)[] = [];
57
-
58
- if (inventory) {
59
- Object.keys(inventory.slots).forEach(i => {
60
- const index = parseInt(i);
61
-
62
- if (inventory.slots[index]?.key === payload?.key) {
63
- itemsFromEquipment.push(inventory.slots[index]);
64
- }
65
- });
66
- }
67
-
68
- const totalQty = itemsFromEquipment.reduce(
69
- (acc, item) => acc + (item?.stackQty || 1),
70
- 0
71
- );
72
-
73
- return (
74
- <SingleShortcut
75
- key={i}
76
- onClick={onShortcutCast.bind(null, i)}
77
- disabled={false}
78
- >
79
- {payload && (
80
- <SpriteFromAtlas
81
- atlasIMG={atlasIMG}
82
- atlasJSON={atlasJSON}
83
- spriteKey={getItemTextureKeyPath(
84
- {
85
- key: payload.texturePath,
86
- texturePath: payload.texturePath,
87
- stackQty: payload.stackQty || 1,
88
- },
89
- atlasJSON
90
- )}
91
- width={32}
92
- height={32}
93
- />
94
- )}
95
- <span className="qty">{totalQty}</span>
96
- <span className="keyboard">{i + 1}</span>
97
- </SingleShortcut>
98
- );
99
- }
100
-
101
- const payload = shortcuts[i]?.payload as IRawSpell | undefined;
102
-
103
- return (
104
- <SingleShortcut
105
- key={i}
106
- onClick={onShortcutCast.bind(null, i)}
107
- disabled={mana < (payload?.manaCost ?? 0)}
108
- >
109
- <span className="mana">{payload && payload.manaCost}</span>
110
- <span className="magicWords">
111
- {payload?.magicWords.split(' ').map(word => word[0])}
112
- </span>
113
- <span className="keyboard">{i + 1}</span>
114
- </SingleShortcut>
115
- );
116
- })}
117
- </List>
118
- );
119
- };
120
-
121
- const List = styled.p`
122
- width: 100%;
123
- display: flex;
124
- align-items: center;
125
- justify-content: center;
126
- gap: 0.5rem;
127
- box-sizing: border-box;
128
- margin: 0 !important;
129
- `;
@@ -1,132 +0,0 @@
1
- import {
2
- getItemTextureKeyPath,
3
- IItem,
4
- IRawSpell,
5
- IShortcut,
6
- ShortcutType,
7
- } from '@rpg-engine/shared';
8
- import React from 'react';
9
- import styled from 'styled-components';
10
- import { uiColors } from '../../constants/uiColors';
11
- import { SpriteFromAtlas } from '../shared/SpriteFromAtlas';
12
-
13
- type ShortcutsSetterProps = {
14
- setSettingShortcutIndex: (index: number) => void;
15
- settingShortcutIndex: number;
16
- shortcuts: IShortcut[];
17
- removeShortcut: (index: number) => void;
18
- atlasJSON: any;
19
- atlasIMG: any;
20
- };
21
-
22
- export const ShortcutsSetter: React.FC<ShortcutsSetterProps> = ({
23
- setSettingShortcutIndex,
24
- settingShortcutIndex,
25
- shortcuts,
26
- removeShortcut,
27
- atlasJSON,
28
- atlasIMG,
29
- }) => {
30
- const getContent = (index: number) => {
31
- if (shortcuts[index]?.type === ShortcutType.Item) {
32
- const payload = shortcuts[index]?.payload as IItem | undefined;
33
-
34
- if (!payload) return null;
35
-
36
- return (
37
- <SpriteFromAtlas
38
- atlasIMG={atlasIMG}
39
- atlasJSON={atlasJSON}
40
- spriteKey={getItemTextureKeyPath(
41
- {
42
- key: payload.texturePath,
43
- texturePath: payload.texturePath,
44
- stackQty: payload.stackQty || 1,
45
- },
46
- atlasJSON
47
- )}
48
- width={32}
49
- height={32}
50
- imgScale={1.6}
51
- imgStyle={{ left: '5px' }}
52
- />
53
- );
54
- }
55
-
56
- const payload = shortcuts[index]?.payload as IRawSpell | undefined;
57
-
58
- return <span>{payload?.magicWords.split(' ').map(word => word[0])}</span>;
59
- };
60
-
61
- return (
62
- <Container>
63
- <p>Shortcuts:</p>
64
- <List id="shortcuts_list">
65
- {Array.from({ length: 6 }).map((_, i) => (
66
- <Shortcut
67
- key={i}
68
- onClick={() => {
69
- removeShortcut(i);
70
- if (!shortcuts[i] || shortcuts[i].type === ShortcutType.None)
71
- setSettingShortcutIndex(i);
72
- }}
73
- disabled={settingShortcutIndex !== -1 && settingShortcutIndex !== i}
74
- isBeingSet={settingShortcutIndex === i}
75
- >
76
- {getContent(i)}
77
- </Shortcut>
78
- ))}
79
- </List>
80
- </Container>
81
- );
82
- };
83
-
84
- const Container = styled.div`
85
- p {
86
- margin: 0;
87
- margin-left: 0.5rem;
88
- }
89
- `;
90
-
91
- const Shortcut = styled.button<{ isBeingSet?: boolean }>`
92
- width: 2.6rem;
93
- height: 2.6rem;
94
- background-color: ${uiColors.lightGray};
95
- border: 2px solid
96
- ${({ isBeingSet }) => (isBeingSet ? uiColors.yellow : uiColors.darkGray)};
97
- border-radius: 50%;
98
- text-transform: uppercase;
99
- font-size: 0.7rem;
100
- font-weight: bold;
101
- display: flex;
102
- align-items: center;
103
- justify-content: center;
104
-
105
- span {
106
- margin-top: 4px;
107
- }
108
-
109
- &:hover,
110
- &:focus {
111
- background-color: ${uiColors.darkGray};
112
- }
113
-
114
- &:active {
115
- background-color: ${uiColors.gray};
116
- }
117
-
118
- &:disabled {
119
- opacity: 0.5;
120
- }
121
- `;
122
-
123
- const List = styled.div`
124
- width: 100%;
125
- display: flex;
126
- align-items: center;
127
- gap: 0.5rem;
128
- padding-bottom: 0.5rem;
129
- padding-left: 0.5rem;
130
- box-sizing: border-box;
131
- margin: 0 !important;
132
- `;
@@ -1,61 +0,0 @@
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
- &:hover,
50
- &:focus {
51
- background-color: ${uiColors.darkGray};
52
- }
53
-
54
- &:active {
55
- background-color: ${uiColors.gray};
56
- }
57
-
58
- &:disabled {
59
- opacity: 0.5;
60
- }
61
- `;
@@ -1,39 +0,0 @@
1
- import { Meta, Story } from '@storybook/react';
2
- import React from 'react';
3
- import { RPGUIRoot } from '../components/RPGUIRoot';
4
- import { Shortcuts, ShortcutsProps } from '../components/Shortcuts/Shortcuts';
5
- import { SHORTCUTS_STORAGE_KEY } from '../components/Spellbook/constants';
6
- import atlasJSON from '../mocks/atlas/items/items.json';
7
- import atlasIMG from '../mocks/atlas/items/items.png';
8
- import { itemContainerMock } from '../mocks/itemContainer.mocks';
9
-
10
- const meta: Meta = {
11
- title: 'Shortcuts',
12
- component: Shortcuts,
13
- };
14
-
15
- export default meta;
16
-
17
- const Template: Story<ShortcutsProps> = args => {
18
- return (
19
- <RPGUIRoot>
20
- <div
21
- style={{
22
- width: '100%',
23
- }}
24
- >
25
- <Shortcuts {...args} />
26
- </div>
27
- </RPGUIRoot>
28
- );
29
- };
30
-
31
- export const Default = Template.bind({});
32
- Default.args = {
33
- onShortcutCast: spellKey => console.log(spellKey),
34
- shortcuts: JSON.parse(localStorage.getItem(SHORTCUTS_STORAGE_KEY) as string),
35
- mana: 100,
36
- atlasIMG,
37
- atlasJSON,
38
- inventory: itemContainerMock,
39
- };