@rpg-engine/long-bow 0.3.97 → 0.3.99

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