@rpg-engine/long-bow 0.3.73 → 0.3.76

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 (160) hide show
  1. package/LICENSE +20 -20
  2. package/README.md +181 -181
  3. package/dist/components/CraftBook/CraftBook.d.ts +3 -1
  4. package/dist/components/Item/Cards/ItemInfo.d.ts +10 -0
  5. package/dist/components/Item/Cards/ItemInfoDisplay.d.ts +10 -0
  6. package/dist/components/Item/Cards/ItemInfoWrapper.d.ts +12 -0
  7. package/dist/components/Item/Cards/ItemTooltip.d.ts +7 -4
  8. package/dist/components/Item/Cards/MobileItemTooltip.d.ts +18 -0
  9. package/dist/components/Item/Inventory/ItemContainer.d.ts +2 -1
  10. package/dist/components/Item/Inventory/ItemSlot.d.ts +4 -1
  11. package/dist/components/TradingMenu/TradingItemRow.d.ts +3 -1
  12. package/dist/components/TradingMenu/TradingMenu.d.ts +6 -4
  13. package/dist/components/shared/SpriteFromAtlas.d.ts +1 -0
  14. package/dist/long-bow.cjs.development.js +1400 -1009
  15. package/dist/long-bow.cjs.development.js.map +1 -1
  16. package/dist/long-bow.cjs.production.min.js +1 -1
  17. package/dist/long-bow.cjs.production.min.js.map +1 -1
  18. package/dist/long-bow.esm.js +1402 -1013
  19. package/dist/long-bow.esm.js.map +1 -1
  20. package/dist/stories/ItemInfoDisplay.stories.d.ts +8 -0
  21. package/dist/stories/TradingMenu.stories.d.ts +2 -2
  22. package/package.json +100 -100
  23. package/src/components/Abstractions/SlotsContainer.tsx +45 -45
  24. package/src/components/Arrow/SelectArrow.tsx +69 -69
  25. package/src/components/Arrow/img/arrow01-left-clicked.png +0 -0
  26. package/src/components/Arrow/img/arrow01-left.png +0 -0
  27. package/src/components/Arrow/img/arrow01-right-clicked.png +0 -0
  28. package/src/components/Arrow/img/arrow01-right.png +0 -0
  29. package/src/components/Arrow/img/arrow02-left-clicked.png +0 -0
  30. package/src/components/Arrow/img/arrow02-left.png +0 -0
  31. package/src/components/Arrow/img/arrow02-right-clicked.png +0 -0
  32. package/src/components/Arrow/img/arrow02-right.png +0 -0
  33. package/src/components/Button.tsx +40 -40
  34. package/src/components/Character/CharacterSelection.tsx +96 -96
  35. package/src/components/CharacterStatus/CharacterStatus.tsx +120 -120
  36. package/src/components/Chat/Chat.tsx +195 -195
  37. package/src/components/Chatdeprecated/ChatDeprecated.tsx +198 -198
  38. package/src/components/CheckButton.tsx +65 -65
  39. package/src/components/CircularController/CircularController.tsx +248 -248
  40. package/src/components/CraftBook/CraftBook.tsx +240 -227
  41. package/src/components/CraftBook/MockItems.ts +246 -251
  42. package/src/components/DraggableContainer.tsx +153 -153
  43. package/src/components/Dropdown.tsx +90 -90
  44. package/src/components/DropdownSelectorContainer.tsx +42 -42
  45. package/src/components/Equipment/EquipmentSet.tsx +190 -190
  46. package/src/components/HistoryDialog.tsx +104 -104
  47. package/src/components/Input.tsx +15 -15
  48. package/src/components/Item/Cards/ItemInfo.tsx +248 -0
  49. package/src/components/Item/Cards/ItemInfoDisplay.tsx +123 -0
  50. package/src/components/Item/Cards/ItemInfoWrapper.tsx +62 -0
  51. package/src/components/Item/Cards/ItemTooltip.tsx +85 -33
  52. package/src/components/Item/Cards/MobileItemTooltip.tsx +105 -0
  53. package/src/components/Item/Inventory/ErrorBoundary.tsx +42 -42
  54. package/src/components/Item/Inventory/ItemContainer.tsx +214 -210
  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 +540 -501
  58. package/src/components/Item/Inventory/itemContainerHelper.ts +156 -156
  59. package/src/components/ListMenu.tsx +63 -63
  60. package/src/components/Multitab/Tab.tsx +66 -66
  61. package/src/components/Multitab/TabBody.tsx +13 -13
  62. package/src/components/Multitab/TabsContainer.tsx +97 -97
  63. package/src/components/NPCDialog/NPCDialog.tsx +121 -121
  64. package/src/components/NPCDialog/NPCDialogText.tsx +113 -113
  65. package/src/components/NPCDialog/NPCMultiDialog.tsx +159 -159
  66. package/src/components/NPCDialog/QuestionDialog/QuestionDialog.tsx +237 -237
  67. package/src/components/ProgressBar.tsx +92 -92
  68. package/src/components/PropertySelect/PropertySelect.tsx +106 -106
  69. package/src/components/QuestInfo/QuestInfo.tsx +230 -230
  70. package/src/components/QuestList.tsx +129 -129
  71. package/src/components/RPGUIContainer.tsx +47 -47
  72. package/src/components/RPGUIForceRenderStart.tsx +45 -45
  73. package/src/components/RPGUIRoot.tsx +14 -14
  74. package/src/components/RadioButton.tsx +53 -53
  75. package/src/components/RadioInput/RadioButton.tsx +96 -96
  76. package/src/components/RadioInput/RadioInput.tsx +102 -102
  77. package/src/components/RadioInput/instruments.ts +15 -15
  78. package/src/components/RangeSlider.tsx +78 -78
  79. package/src/components/RelativeListMenu.tsx +83 -83
  80. package/src/components/ScrollList.tsx +79 -79
  81. package/src/components/Shortcuts/Shortcuts.tsx +151 -151
  82. package/src/components/Shortcuts/ShortcutsSetter.tsx +132 -132
  83. package/src/components/Shortcuts/SingleShortcut.ts +62 -62
  84. package/src/components/SimpleProgressBar.tsx +62 -62
  85. package/src/components/SkillProgressBar.tsx +133 -133
  86. package/src/components/SkillsContainer.tsx +200 -200
  87. package/src/components/Spellbook/Spell.tsx +201 -201
  88. package/src/components/Spellbook/Spellbook.tsx +150 -150
  89. package/src/components/Spellbook/constants.ts +8 -8
  90. package/src/components/Spellbook/mockSpells.ts +60 -60
  91. package/src/components/StaticBook/StaticBook.tsx +103 -103
  92. package/src/components/TextArea.tsx +11 -11
  93. package/src/components/TimeWidget/DayNightPeriod/DayNightPeriod.tsx +35 -35
  94. package/src/components/TimeWidget/TimeWidget.tsx +63 -63
  95. package/src/components/TradingMenu/TradingItemRow.tsx +198 -181
  96. package/src/components/TradingMenu/TradingMenu.tsx +215 -203
  97. package/src/components/TradingMenu/items.mock.ts +48 -96
  98. package/src/components/Truncate.tsx +25 -25
  99. package/src/components/itemSelector/ItemSelector.tsx +136 -136
  100. package/src/components/shared/Column.tsx +16 -16
  101. package/src/components/shared/Ellipsis.tsx +65 -65
  102. package/src/components/shared/SpriteFromAtlas.tsx +104 -102
  103. package/src/components/typography/DynamicText.tsx +49 -49
  104. package/src/constants/uiColors.ts +20 -20
  105. package/src/constants/uiDevices.ts +3 -3
  106. package/src/constants/uiFonts.ts +12 -12
  107. package/src/hooks/useEventListener.ts +21 -21
  108. package/src/hooks/useOutsideAlerter.ts +25 -25
  109. package/src/index.tsx +40 -40
  110. package/src/libs/StringHelpers.ts +3 -3
  111. package/src/mocks/atlas/entities/entities.json +20215 -20215
  112. package/src/mocks/atlas/icons/icons.json +735 -735
  113. package/src/mocks/atlas/items/items.json +12086 -12086
  114. package/src/mocks/equipmentSet.mocks.ts +391 -393
  115. package/src/mocks/itemContainer.mocks.ts +563 -562
  116. package/src/mocks/skills.mocks.ts +128 -128
  117. package/src/stories/Arrow.stories.tsx +26 -26
  118. package/src/stories/Button.stories.tsx +36 -36
  119. package/src/stories/CharacterSelection.stories.tsx +45 -45
  120. package/src/stories/CharacterStatus.stories.tsx +29 -29
  121. package/src/stories/Chat.stories.tsx +187 -187
  122. package/src/stories/ChatDeprecated.stories.tsx +170 -170
  123. package/src/stories/CheckButton.stories.tsx +48 -48
  124. package/src/stories/CircullarController.stories.tsx +37 -37
  125. package/src/stories/CraftBook.stories.tsx +42 -40
  126. package/src/stories/DayNightPeriod.stories.tsx +27 -27
  127. package/src/stories/DraggableContainer.stories.tsx +28 -28
  128. package/src/stories/Dropdown.stories.tsx +46 -46
  129. package/src/stories/DropdownSelectorContainer.stories.tsx +41 -41
  130. package/src/stories/EquipmentSet.stories.tsx +65 -65
  131. package/src/stories/HistoryDialog.stories.tsx +61 -61
  132. package/src/stories/ItemContainer.stories.tsx +200 -198
  133. package/src/stories/ItemInfoDisplay.stories.tsx +33 -0
  134. package/src/stories/ItemQuantitySelector.stories.tsx +26 -26
  135. package/src/stories/ItemSelector.stories.tsx +77 -77
  136. package/src/stories/ItemTradingComponent.stories.tsx +35 -35
  137. package/src/stories/ListMenu.stories.tsx +56 -56
  138. package/src/stories/Multitab.stories.tsx +51 -51
  139. package/src/stories/NPCDialog.stories.tsx +130 -130
  140. package/src/stories/NPCMultiDialog.stories.tsx +71 -71
  141. package/src/stories/ProgressBar.stories.tsx +23 -23
  142. package/src/stories/PropertySelect.stories.tsx +40 -40
  143. package/src/stories/QuestInfo.stories.tsx +107 -107
  144. package/src/stories/QuestList.stories.tsx +82 -82
  145. package/src/stories/RPGUIContainers.stories.tsx +42 -42
  146. package/src/stories/RadioButton.stories.tsx +49 -49
  147. package/src/stories/RadioInput.stories.tsx +34 -34
  148. package/src/stories/RangeSlider.stories.tsx +64 -64
  149. package/src/stories/ScrollList.stories.tsx +85 -85
  150. package/src/stories/Shortcuts.stories.tsx +39 -39
  151. package/src/stories/SimpleProgressBar.stories.tsx +22 -22
  152. package/src/stories/SkillProgressBar.stories.tsx +34 -34
  153. package/src/stories/SkillsContainer.stories.tsx +35 -35
  154. package/src/stories/Spellbook.stories.tsx +104 -104
  155. package/src/stories/StaticBook.stories.tsx +32 -32
  156. package/src/stories/Text.stories.tsx +42 -42
  157. package/src/stories/TimeWidget.stories.tsx +27 -27
  158. package/src/stories/TradingMenu.stories.tsx +47 -45
  159. package/src/types/eventTypes.ts +4 -4
  160. package/src/types/index.d.ts +2 -2
@@ -1,201 +1,201 @@
1
- import { IRawSpell } from '@rpg-engine/shared';
2
- import React from 'react';
3
- import styled from 'styled-components';
4
- import { uiColors } from '../../constants/uiColors';
5
- import { uiFonts } from '../../constants/uiFonts';
6
-
7
- interface Props extends IRawSpell {
8
- charMana: number;
9
- charMagicLevel: number;
10
- onPointerDown?: (spellKey: string) => void;
11
- isSettingShortcut?: boolean;
12
- spellKey: string;
13
- }
14
-
15
- export const Spell: React.FC<Props> = ({
16
- spellKey,
17
- name,
18
- description,
19
- magicWords,
20
- manaCost,
21
- charMana,
22
- charMagicLevel,
23
- onPointerDown,
24
- isSettingShortcut,
25
- minMagicLevelRequired,
26
- }) => {
27
- const disabled = isSettingShortcut
28
- ? charMagicLevel < minMagicLevelRequired
29
- : manaCost > charMana || charMagicLevel < minMagicLevelRequired;
30
-
31
- return (
32
- <Container
33
- disabled={disabled}
34
- onPointerDown={onPointerDown?.bind(null, spellKey)}
35
- isSettingShortcut={isSettingShortcut && !disabled}
36
- className="spell"
37
- >
38
- {disabled && (
39
- <Overlay>
40
- {charMagicLevel < minMagicLevelRequired
41
- ? 'Low magic level'
42
- : manaCost > charMana && 'No mana'}
43
- </Overlay>
44
- )}
45
- <SpellImage>{magicWords.split(' ').map(word => word[0])}</SpellImage>
46
- <Info>
47
- <Title>
48
- <span>{name}</span>
49
- <span className="spell">({magicWords})</span>
50
- </Title>
51
- <Description>{description}</Description>
52
- </Info>
53
-
54
- <Divider />
55
- <Cost>
56
- <span>Mana cost:</span>
57
- <span className="mana">{manaCost}</span>
58
- </Cost>
59
- </Container>
60
- );
61
- };
62
-
63
- const Container = styled.button<{ isSettingShortcut?: boolean }>`
64
- display: block;
65
- background: none;
66
- border: 2px solid transparent;
67
- border-radius: 1rem;
68
- width: 100%;
69
- display: flex;
70
- height: 5rem;
71
- gap: 1rem;
72
- align-items: center;
73
- padding: 0 1rem;
74
- text-align: left;
75
- position: relative;
76
-
77
- animation: ${({ isSettingShortcut }) =>
78
- isSettingShortcut ? 'border-color-change 1s infinite' : 'none'};
79
-
80
- @keyframes border-color-change {
81
- 0% {
82
- border-color: ${uiColors.yellow};
83
- }
84
- 50% {
85
- border-color: transparent;
86
- }
87
- 100% {
88
- border-color: ${uiColors.yellow};
89
- }
90
- }
91
-
92
- &:hover,
93
- &:focus {
94
- background-color: ${uiColors.darkGray};
95
- }
96
-
97
- &:active {
98
- background: none;
99
- }
100
- `;
101
-
102
- const SpellImage = styled.div`
103
- width: 4rem;
104
- height: 4rem;
105
- font-size: ${uiFonts.size.xLarge};
106
- font-weight: bold;
107
- background-color: ${uiColors.darkGray};
108
- color: ${uiColors.lightGray};
109
- display: flex;
110
- justify-content: center;
111
- align-items: center;
112
- text-transform: uppercase;
113
- `;
114
-
115
- const Info = styled.span`
116
- width: 0;
117
- flex: 1;
118
- `;
119
-
120
- const Title = styled.p`
121
- display: flex;
122
- flex-wrap: wrap;
123
- align-items: center;
124
- margin-bottom: 5px;
125
- margin: 0;
126
-
127
- span {
128
- font-size: ${uiFonts.size.medium} !important;
129
- font-weight: bold !important;
130
- color: ${uiColors.yellow} !important;
131
- margin-right: 0.5rem;
132
- }
133
-
134
- .spell {
135
- font-size: ${uiFonts.size.small} !important;
136
- font-weight: normal !important;
137
- color: ${uiColors.lightGray} !important;
138
- }
139
- `;
140
-
141
- const Description = styled.div`
142
- font-size: ${uiFonts.size.small} !important;
143
- line-height: 1.1 !important;
144
- `;
145
-
146
- const Divider = styled.div`
147
- width: 1px;
148
- height: 100%;
149
- margin: 0 1rem;
150
- background-color: ${uiColors.lightGray};
151
- `;
152
-
153
- const Cost = styled.p`
154
- display: flex;
155
- align-items: center;
156
- flex-direction: column;
157
- gap: 0.5rem;
158
-
159
- div {
160
- z-index: 1;
161
- }
162
-
163
- .mana {
164
- position: relative;
165
- font-size: ${uiFonts.size.medium};
166
- font-weight: bold;
167
- z-index: 1;
168
-
169
- &::after {
170
- position: absolute;
171
- content: '';
172
- top: 0;
173
- left: 0;
174
- background-color: ${uiColors.blue};
175
- width: 100%;
176
- height: 100%;
177
- border-radius: 50%;
178
- transform: scale(1.8);
179
- filter: blur(10px);
180
- z-index: -1;
181
- }
182
- }
183
- `;
184
-
185
- const Overlay = styled.p`
186
- margin: 0 !important;
187
- position: absolute;
188
- top: 0;
189
- left: 0;
190
- width: 100%;
191
- height: 100%;
192
- border-radius: 1rem;
193
- display: flex;
194
- justify-content: center;
195
- align-items: center;
196
- color: ${uiColors.yellow};
197
- font-size: ${uiFonts.size.large} !important;
198
- font-weight: bold;
199
- z-index: 10;
200
- background-color: rgba(0 0 0 / 0.2);
201
- `;
1
+ import { IRawSpell } from '@rpg-engine/shared';
2
+ import React from 'react';
3
+ import styled from 'styled-components';
4
+ import { uiColors } from '../../constants/uiColors';
5
+ import { uiFonts } from '../../constants/uiFonts';
6
+
7
+ interface Props extends IRawSpell {
8
+ charMana: number;
9
+ charMagicLevel: number;
10
+ onPointerDown?: (spellKey: string) => void;
11
+ isSettingShortcut?: boolean;
12
+ spellKey: string;
13
+ }
14
+
15
+ export const Spell: React.FC<Props> = ({
16
+ spellKey,
17
+ name,
18
+ description,
19
+ magicWords,
20
+ manaCost,
21
+ charMana,
22
+ charMagicLevel,
23
+ onPointerDown,
24
+ isSettingShortcut,
25
+ minMagicLevelRequired,
26
+ }) => {
27
+ const disabled = isSettingShortcut
28
+ ? charMagicLevel < minMagicLevelRequired
29
+ : manaCost > charMana || charMagicLevel < minMagicLevelRequired;
30
+
31
+ return (
32
+ <Container
33
+ disabled={disabled}
34
+ onPointerDown={onPointerDown?.bind(null, spellKey)}
35
+ isSettingShortcut={isSettingShortcut && !disabled}
36
+ className="spell"
37
+ >
38
+ {disabled && (
39
+ <Overlay>
40
+ {charMagicLevel < minMagicLevelRequired
41
+ ? 'Low magic level'
42
+ : manaCost > charMana && 'No mana'}
43
+ </Overlay>
44
+ )}
45
+ <SpellImage>{magicWords.split(' ').map(word => word[0])}</SpellImage>
46
+ <Info>
47
+ <Title>
48
+ <span>{name}</span>
49
+ <span className="spell">({magicWords})</span>
50
+ </Title>
51
+ <Description>{description}</Description>
52
+ </Info>
53
+
54
+ <Divider />
55
+ <Cost>
56
+ <span>Mana cost:</span>
57
+ <span className="mana">{manaCost}</span>
58
+ </Cost>
59
+ </Container>
60
+ );
61
+ };
62
+
63
+ const Container = styled.button<{ isSettingShortcut?: boolean }>`
64
+ display: block;
65
+ background: none;
66
+ border: 2px solid transparent;
67
+ border-radius: 1rem;
68
+ width: 100%;
69
+ display: flex;
70
+ height: 5rem;
71
+ gap: 1rem;
72
+ align-items: center;
73
+ padding: 0 1rem;
74
+ text-align: left;
75
+ position: relative;
76
+
77
+ animation: ${({ isSettingShortcut }) =>
78
+ isSettingShortcut ? 'border-color-change 1s infinite' : 'none'};
79
+
80
+ @keyframes border-color-change {
81
+ 0% {
82
+ border-color: ${uiColors.yellow};
83
+ }
84
+ 50% {
85
+ border-color: transparent;
86
+ }
87
+ 100% {
88
+ border-color: ${uiColors.yellow};
89
+ }
90
+ }
91
+
92
+ &:hover,
93
+ &:focus {
94
+ background-color: ${uiColors.darkGray};
95
+ }
96
+
97
+ &:active {
98
+ background: none;
99
+ }
100
+ `;
101
+
102
+ const SpellImage = styled.div`
103
+ width: 4rem;
104
+ height: 4rem;
105
+ font-size: ${uiFonts.size.xLarge};
106
+ font-weight: bold;
107
+ background-color: ${uiColors.darkGray};
108
+ color: ${uiColors.lightGray};
109
+ display: flex;
110
+ justify-content: center;
111
+ align-items: center;
112
+ text-transform: uppercase;
113
+ `;
114
+
115
+ const Info = styled.span`
116
+ width: 0;
117
+ flex: 1;
118
+ `;
119
+
120
+ const Title = styled.p`
121
+ display: flex;
122
+ flex-wrap: wrap;
123
+ align-items: center;
124
+ margin-bottom: 5px;
125
+ margin: 0;
126
+
127
+ span {
128
+ font-size: ${uiFonts.size.medium} !important;
129
+ font-weight: bold !important;
130
+ color: ${uiColors.yellow} !important;
131
+ margin-right: 0.5rem;
132
+ }
133
+
134
+ .spell {
135
+ font-size: ${uiFonts.size.small} !important;
136
+ font-weight: normal !important;
137
+ color: ${uiColors.lightGray} !important;
138
+ }
139
+ `;
140
+
141
+ const Description = styled.div`
142
+ font-size: ${uiFonts.size.small} !important;
143
+ line-height: 1.1 !important;
144
+ `;
145
+
146
+ const Divider = styled.div`
147
+ width: 1px;
148
+ height: 100%;
149
+ margin: 0 1rem;
150
+ background-color: ${uiColors.lightGray};
151
+ `;
152
+
153
+ const Cost = styled.p`
154
+ display: flex;
155
+ align-items: center;
156
+ flex-direction: column;
157
+ gap: 0.5rem;
158
+
159
+ div {
160
+ z-index: 1;
161
+ }
162
+
163
+ .mana {
164
+ position: relative;
165
+ font-size: ${uiFonts.size.medium};
166
+ font-weight: bold;
167
+ z-index: 1;
168
+
169
+ &::after {
170
+ position: absolute;
171
+ content: '';
172
+ top: 0;
173
+ left: 0;
174
+ background-color: ${uiColors.blue};
175
+ width: 100%;
176
+ height: 100%;
177
+ border-radius: 50%;
178
+ transform: scale(1.8);
179
+ filter: blur(10px);
180
+ z-index: -1;
181
+ }
182
+ }
183
+ `;
184
+
185
+ const Overlay = styled.p`
186
+ margin: 0 !important;
187
+ position: absolute;
188
+ top: 0;
189
+ left: 0;
190
+ width: 100%;
191
+ height: 100%;
192
+ border-radius: 1rem;
193
+ display: flex;
194
+ justify-content: center;
195
+ align-items: center;
196
+ color: ${uiColors.yellow};
197
+ font-size: ${uiFonts.size.large} !important;
198
+ font-weight: bold;
199
+ z-index: 10;
200
+ background-color: rgba(0 0 0 / 0.2);
201
+ `;