@rpg-engine/long-bow 0.3.45 → 0.3.47

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 (139) hide show
  1. package/LICENSE +20 -20
  2. package/README.md +181 -181
  3. package/dist/long-bow.cjs.development.js +705 -709
  4. package/dist/long-bow.cjs.development.js.map +1 -1
  5. package/dist/long-bow.cjs.production.min.js +1 -1
  6. package/dist/long-bow.cjs.production.min.js.map +1 -1
  7. package/dist/long-bow.esm.js +708 -712
  8. package/dist/long-bow.esm.js.map +1 -1
  9. package/package.json +100 -101
  10. package/src/components/Abstractions/SlotsContainer.tsx +45 -45
  11. package/src/components/Arrow/SelectArrow.tsx +65 -65
  12. package/src/components/Arrow/img/arrow01-left-clicked.png +0 -0
  13. package/src/components/Arrow/img/arrow01-left.png +0 -0
  14. package/src/components/Arrow/img/arrow01-right-clicked.png +0 -0
  15. package/src/components/Arrow/img/arrow01-right.png +0 -0
  16. package/src/components/Arrow/img/arrow02-left-clicked.png +0 -0
  17. package/src/components/Arrow/img/arrow02-left.png +0 -0
  18. package/src/components/Arrow/img/arrow02-right-clicked.png +0 -0
  19. package/src/components/Arrow/img/arrow02-right.png +0 -0
  20. package/src/components/Button.tsx +41 -41
  21. package/src/components/Character/CharacterSelection.tsx +96 -96
  22. package/src/components/Chat/Chat.tsx +194 -194
  23. package/src/components/Chatdeprecated/ChatDeprecated.tsx +200 -200
  24. package/src/components/CheckButton.tsx +65 -65
  25. package/src/components/CircularController/CircularController.tsx +162 -162
  26. package/src/components/CraftBook/CraftBook.tsx +230 -230
  27. package/src/components/CraftBook/MockItems.ts +46 -46
  28. package/src/components/DraggableContainer.tsx +154 -154
  29. package/src/components/Dropdown.tsx +96 -96
  30. package/src/components/DropdownSelectorContainer.tsx +42 -42
  31. package/src/components/Equipment/EquipmentSet.tsx +190 -190
  32. package/src/components/HistoryDialog.tsx +104 -104
  33. package/src/components/Input.tsx +15 -15
  34. package/src/components/Item/Cards/ItemTooltip.tsx +33 -33
  35. package/src/components/Item/Inventory/ErrorBoundary.tsx +42 -42
  36. package/src/components/Item/Inventory/ItemContainer.tsx +175 -175
  37. package/src/components/Item/Inventory/ItemContainerTypes.ts +6 -6
  38. package/src/components/Item/Inventory/ItemQuantitySelector.tsx +142 -142
  39. package/src/components/Item/Inventory/ItemSlot.tsx +465 -466
  40. package/src/components/Item/Inventory/itemContainerHelper.ts +156 -156
  41. package/src/components/ListMenu.tsx +63 -63
  42. package/src/components/Multitab/Tab.tsx +57 -57
  43. package/src/components/Multitab/TabBody.tsx +13 -13
  44. package/src/components/Multitab/TabsContainer.tsx +97 -97
  45. package/src/components/NPCDialog/NPCDialog.tsx +121 -121
  46. package/src/components/NPCDialog/NPCDialogText.tsx +113 -113
  47. package/src/components/NPCDialog/NPCMultiDialog.tsx +159 -159
  48. package/src/components/NPCDialog/QuestionDialog/QuestionDialog.tsx +237 -237
  49. package/src/components/ProgressBar.tsx +92 -92
  50. package/src/components/PropertySelect/PropertySelect.tsx +114 -114
  51. package/src/components/QuestInfo/QuestInfo.tsx +232 -232
  52. package/src/components/QuestList.tsx +129 -129
  53. package/src/components/RPGUIContainer.tsx +47 -47
  54. package/src/components/RPGUIForceRenderStart.tsx +45 -45
  55. package/src/components/RPGUIRoot.tsx +14 -14
  56. package/src/components/RadioButton.tsx +53 -53
  57. package/src/components/RadioInput/RadioButton.tsx +98 -98
  58. package/src/components/RadioInput/RadioInput.tsx +98 -98
  59. package/src/components/RadioInput/instruments.ts +15 -15
  60. package/src/components/RangeSlider.tsx +78 -78
  61. package/src/components/RelativeListMenu.tsx +83 -83
  62. package/src/components/ScrollList.tsx +79 -79
  63. package/src/components/SimpleProgressBar.tsx +62 -62
  64. package/src/components/SkillProgressBar.tsx +133 -133
  65. package/src/components/SkillsContainer.tsx +167 -167
  66. package/src/components/Spellbook/QuickSpells.tsx +120 -120
  67. package/src/components/Spellbook/Spell.tsx +201 -201
  68. package/src/components/Spellbook/Spellbook.tsx +144 -144
  69. package/src/components/Spellbook/SpellbookShortcuts.tsx +77 -77
  70. package/src/components/Spellbook/constants.ts +12 -12
  71. package/src/components/Spellbook/mockSpells.ts +60 -60
  72. package/src/components/StaticBook/StaticBook.tsx +105 -105
  73. package/src/components/TextArea.tsx +11 -11
  74. package/src/components/TimeWidget/DayNightPeriod/DayNightPeriod.tsx +35 -35
  75. package/src/components/TimeWidget/TimeWidget.tsx +63 -63
  76. package/src/components/TradingMenu/TradingItemRow.tsx +197 -197
  77. package/src/components/TradingMenu/TradingMenu.tsx +203 -203
  78. package/src/components/TradingMenu/items.mock.ts +36 -36
  79. package/src/components/Truncate.tsx +25 -25
  80. package/src/components/itemSelector/ItemSelector.tsx +136 -136
  81. package/src/components/shared/Column.tsx +16 -16
  82. package/src/components/shared/Ellipsis.tsx +65 -65
  83. package/src/components/shared/SpriteFromAtlas.tsx +102 -102
  84. package/src/components/typography/DynamicText.tsx +49 -49
  85. package/src/constants/uiColors.ts +20 -20
  86. package/src/constants/uiDevices.ts +3 -5
  87. package/src/constants/uiFonts.ts +12 -12
  88. package/src/hooks/useEventListener.ts +21 -21
  89. package/src/hooks/useOutsideAlerter.ts +25 -25
  90. package/src/index.tsx +40 -40
  91. package/src/libs/StringHelpers.ts +3 -3
  92. package/src/mocks/atlas/entities/entities.json +20215 -20215
  93. package/src/mocks/atlas/icons/icons.json +735 -735
  94. package/src/mocks/atlas/items/items.json +12086 -12086
  95. package/src/mocks/equipmentSet.mocks.ts +393 -393
  96. package/src/mocks/itemContainer.mocks.ts +560 -560
  97. package/src/mocks/skills.mocks.ts +128 -128
  98. package/src/stories/Arrow.stories.tsx +26 -26
  99. package/src/stories/Button.stories.tsx +36 -36
  100. package/src/stories/CharacterSelection.stories.tsx +45 -45
  101. package/src/stories/Chat.stories.tsx +187 -187
  102. package/src/stories/ChatDeprecated.stories.tsx +170 -170
  103. package/src/stories/CheckButton.stories.tsx +48 -48
  104. package/src/stories/CircullarController.stories.tsx +33 -33
  105. package/src/stories/CraftBook.stories.tsx +40 -40
  106. package/src/stories/DayNightPeriod.stories.tsx +27 -27
  107. package/src/stories/DraggableContainer.stories.tsx +28 -28
  108. package/src/stories/Dropdown.stories.tsx +46 -46
  109. package/src/stories/DropdownSelectorContainer.stories.tsx +41 -41
  110. package/src/stories/EquipmentSet.stories.tsx +65 -65
  111. package/src/stories/HistoryDialog.stories.tsx +61 -61
  112. package/src/stories/ItemContainer.stories.tsx +124 -124
  113. package/src/stories/ItemQuantitySelector.stories.tsx +26 -26
  114. package/src/stories/ItemSelector.stories.tsx +77 -77
  115. package/src/stories/ItemTradingComponent.stories.tsx +35 -35
  116. package/src/stories/ListMenu.stories.tsx +56 -56
  117. package/src/stories/Multitab.stories.tsx +51 -51
  118. package/src/stories/NPCDialog.stories.tsx +130 -130
  119. package/src/stories/NPCMultiDialog.stories.tsx +71 -71
  120. package/src/stories/ProgressBar.stories.tsx +23 -23
  121. package/src/stories/PropertySelect.stories.tsx +40 -40
  122. package/src/stories/QuestInfo.stories.tsx +107 -107
  123. package/src/stories/QuestList.stories.tsx +82 -82
  124. package/src/stories/QuickSpells.stories.tsx +38 -38
  125. package/src/stories/RPGUIContainers.stories.tsx +42 -42
  126. package/src/stories/RadioButton.stories.tsx +49 -49
  127. package/src/stories/RadioInput.stories.tsx +34 -34
  128. package/src/stories/RangeSlider.stories.tsx +64 -64
  129. package/src/stories/ScrollList.stories.tsx +85 -85
  130. package/src/stories/SimpleProgressBar.stories.tsx +22 -22
  131. package/src/stories/SkillProgressBar.stories.tsx +34 -34
  132. package/src/stories/SkillsContainer.stories.tsx +35 -35
  133. package/src/stories/Spellbook.stories.tsx +107 -107
  134. package/src/stories/StaticBook.stories.tsx +32 -32
  135. package/src/stories/Text.stories.tsx +42 -42
  136. package/src/stories/TimeWidget.stories.tsx +27 -27
  137. package/src/stories/TradingMenu.stories.tsx +45 -45
  138. package/src/types/eventTypes.ts +4 -4
  139. package/src/types/index.d.ts +2 -2
@@ -1,144 +1,144 @@
1
- import { IRawSpell } from '@rpg-engine/shared';
2
- import React, { Fragment, useEffect, useMemo, useState } from 'react';
3
- import styled from 'styled-components';
4
- import { uiFonts } from '../../constants/uiFonts';
5
- import { DraggableContainer } from '../DraggableContainer';
6
- import { Input } from '../Input';
7
- import { RPGUIContainerTypes } from '../RPGUIContainer';
8
- import { Spell } from './Spell';
9
- import { SpellbookShortcuts } from './SpellbookShortcuts';
10
-
11
- export interface ISpellbookProps {
12
- onClose?: () => void;
13
- onInputFocus?: () => void;
14
- onInputBlur?: () => void;
15
- spells: IRawSpell[];
16
- magicLevel: number;
17
- mana: number;
18
- onSpellClick: (spellKey: string) => void;
19
- setSpellShortcut: (key: string, index: number) => void;
20
- spellShortcuts: IRawSpell[];
21
- removeSpellShortcut: (index: number) => void;
22
- }
23
-
24
- export const Spellbook: React.FC<ISpellbookProps> = ({
25
- onClose,
26
- onInputFocus,
27
- onInputBlur,
28
- spells,
29
- magicLevel,
30
- mana,
31
- onSpellClick,
32
- setSpellShortcut,
33
- spellShortcuts,
34
- removeSpellShortcut,
35
- }) => {
36
- const [search, setSearch] = useState('');
37
- const [settingShortcutIndex, setSettingShortcutIndex] = useState(-1);
38
-
39
- useEffect(() => {
40
- const handleEscapeClose = (e: KeyboardEvent) => {
41
- if (e.key === 'Escape') {
42
- onClose?.();
43
- }
44
- };
45
-
46
- document.addEventListener('keydown', handleEscapeClose);
47
-
48
- return () => {
49
- document.removeEventListener('keydown', handleEscapeClose);
50
- };
51
- }, [onClose]);
52
-
53
- const spellsToDisplay = useMemo(() => {
54
- return spells
55
- .sort((a, b) => {
56
- if (a.minMagicLevelRequired > b.minMagicLevelRequired) return 1;
57
- if (a.minMagicLevelRequired < b.minMagicLevelRequired) return -1;
58
- return 0;
59
- })
60
- .filter(
61
- spell =>
62
- spell.name.toLocaleLowerCase().includes(search.toLocaleLowerCase()) ||
63
- spell.magicWords
64
- .toLocaleLowerCase()
65
- .includes(search.toLocaleLowerCase())
66
- );
67
- }, [search, spells]);
68
-
69
- const setShortcut = (spellKey: string) => {
70
- setSpellShortcut?.(spellKey, settingShortcutIndex);
71
- setSettingShortcutIndex(-1);
72
- };
73
-
74
- return (
75
- <DraggableContainer
76
- type={RPGUIContainerTypes.Framed}
77
- onCloseButton={onClose}
78
- width="inherit"
79
- height="inherit"
80
- cancelDrag="#spellbook-search, #shortcuts_list, .spell"
81
- >
82
- <Container>
83
- <Title>Learned Spells</Title>
84
-
85
- <SpellbookShortcuts
86
- setSettingShortcutIndex={setSettingShortcutIndex}
87
- settingShortcutIndex={settingShortcutIndex}
88
- shortcuts={spellShortcuts}
89
- removeShortcut={removeSpellShortcut}
90
- />
91
-
92
- <Input
93
- placeholder="Search for spell"
94
- value={search}
95
- onChange={e => setSearch(e.target.value)}
96
- onFocus={onInputFocus}
97
- onBlur={onInputBlur}
98
- id="spellbook-search"
99
- />
100
-
101
- <SpellList>
102
- {spellsToDisplay.map(spell => (
103
- <Fragment key={spell.key}>
104
- <Spell
105
- charMana={mana}
106
- charMagicLevel={magicLevel}
107
- onClick={
108
- settingShortcutIndex !== -1 ? setShortcut : onSpellClick
109
- }
110
- spellKey={spell.key}
111
- isSettingShortcut={settingShortcutIndex !== -1}
112
- {...spell}
113
- />
114
- </Fragment>
115
- ))}
116
- </SpellList>
117
- </Container>
118
- </DraggableContainer>
119
- );
120
- };
121
-
122
- const Title = styled.h1`
123
- font-size: ${uiFonts.size.large} !important;
124
- margin-bottom: 0 !important;
125
- `;
126
-
127
- const Container = styled.div`
128
- width: 100%;
129
- height: 100%;
130
- color: white;
131
- display: flex;
132
- flex-direction: column;
133
- `;
134
-
135
- const SpellList = styled.div`
136
- width: 100%;
137
- min-height: 0;
138
- flex: 1;
139
- overflow-y: auto;
140
- display: flex;
141
- flex-direction: column;
142
- gap: 1.5rem;
143
- margin-top: 1rem;
144
- `;
1
+ import { IRawSpell } from '@rpg-engine/shared';
2
+ import React, { Fragment, useEffect, useMemo, useState } from 'react';
3
+ import styled from 'styled-components';
4
+ import { uiFonts } from '../../constants/uiFonts';
5
+ import { DraggableContainer } from '../DraggableContainer';
6
+ import { Input } from '../Input';
7
+ import { RPGUIContainerTypes } from '../RPGUIContainer';
8
+ import { Spell } from './Spell';
9
+ import { SpellbookShortcuts } from './SpellbookShortcuts';
10
+
11
+ export interface ISpellbookProps {
12
+ onClose?: () => void;
13
+ onInputFocus?: () => void;
14
+ onInputBlur?: () => void;
15
+ spells: IRawSpell[];
16
+ magicLevel: number;
17
+ mana: number;
18
+ onSpellClick: (spellKey: string) => void;
19
+ setSpellShortcut: (key: string, index: number) => void;
20
+ spellShortcuts: IRawSpell[];
21
+ removeSpellShortcut: (index: number) => void;
22
+ }
23
+
24
+ export const Spellbook: React.FC<ISpellbookProps> = ({
25
+ onClose,
26
+ onInputFocus,
27
+ onInputBlur,
28
+ spells,
29
+ magicLevel,
30
+ mana,
31
+ onSpellClick,
32
+ setSpellShortcut,
33
+ spellShortcuts,
34
+ removeSpellShortcut,
35
+ }) => {
36
+ const [search, setSearch] = useState('');
37
+ const [settingShortcutIndex, setSettingShortcutIndex] = useState(-1);
38
+
39
+ useEffect(() => {
40
+ const handleEscapeClose = (e: KeyboardEvent) => {
41
+ if (e.key === 'Escape') {
42
+ onClose?.();
43
+ }
44
+ };
45
+
46
+ document.addEventListener('keydown', handleEscapeClose);
47
+
48
+ return () => {
49
+ document.removeEventListener('keydown', handleEscapeClose);
50
+ };
51
+ }, [onClose]);
52
+
53
+ const spellsToDisplay = useMemo(() => {
54
+ return spells
55
+ .sort((a, b) => {
56
+ if (a.minMagicLevelRequired > b.minMagicLevelRequired) return 1;
57
+ if (a.minMagicLevelRequired < b.minMagicLevelRequired) return -1;
58
+ return 0;
59
+ })
60
+ .filter(
61
+ spell =>
62
+ spell.name.toLocaleLowerCase().includes(search.toLocaleLowerCase()) ||
63
+ spell.magicWords
64
+ .toLocaleLowerCase()
65
+ .includes(search.toLocaleLowerCase())
66
+ );
67
+ }, [search, spells]);
68
+
69
+ const setShortcut = (spellKey: string) => {
70
+ setSpellShortcut?.(spellKey, settingShortcutIndex);
71
+ setSettingShortcutIndex(-1);
72
+ };
73
+
74
+ return (
75
+ <DraggableContainer
76
+ type={RPGUIContainerTypes.Framed}
77
+ onCloseButton={onClose}
78
+ width="inherit"
79
+ height="inherit"
80
+ cancelDrag="#spellbook-search, #shortcuts_list, .spell"
81
+ >
82
+ <Container>
83
+ <Title>Learned Spells</Title>
84
+
85
+ <SpellbookShortcuts
86
+ setSettingShortcutIndex={setSettingShortcutIndex}
87
+ settingShortcutIndex={settingShortcutIndex}
88
+ shortcuts={spellShortcuts}
89
+ removeShortcut={removeSpellShortcut}
90
+ />
91
+
92
+ <Input
93
+ placeholder="Search for spell"
94
+ value={search}
95
+ onChange={e => setSearch(e.target.value)}
96
+ onFocus={onInputFocus}
97
+ onBlur={onInputBlur}
98
+ id="spellbook-search"
99
+ />
100
+
101
+ <SpellList>
102
+ {spellsToDisplay.map(spell => (
103
+ <Fragment key={spell.key}>
104
+ <Spell
105
+ charMana={mana}
106
+ charMagicLevel={magicLevel}
107
+ onClick={
108
+ settingShortcutIndex !== -1 ? setShortcut : onSpellClick
109
+ }
110
+ spellKey={spell.key}
111
+ isSettingShortcut={settingShortcutIndex !== -1}
112
+ {...spell}
113
+ />
114
+ </Fragment>
115
+ ))}
116
+ </SpellList>
117
+ </Container>
118
+ </DraggableContainer>
119
+ );
120
+ };
121
+
122
+ const Title = styled.h1`
123
+ font-size: ${uiFonts.size.large} !important;
124
+ margin-bottom: 0 !important;
125
+ `;
126
+
127
+ const Container = styled.div`
128
+ width: 100%;
129
+ height: 100%;
130
+ color: white;
131
+ display: flex;
132
+ flex-direction: column;
133
+ `;
134
+
135
+ const SpellList = styled.div`
136
+ width: 100%;
137
+ min-height: 0;
138
+ flex: 1;
139
+ overflow-y: auto;
140
+ display: flex;
141
+ flex-direction: column;
142
+ gap: 1.5rem;
143
+ margin-top: 1rem;
144
+ `;
@@ -1,77 +1,77 @@
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
-
6
- type Props = {
7
- setSettingShortcutIndex: (index: number) => void;
8
- settingShortcutIndex: number;
9
- shortcuts: IRawSpell[];
10
- removeShortcut: (index: number) => void;
11
- };
12
-
13
- export const SpellbookShortcuts: React.FC<Props> = ({
14
- setSettingShortcutIndex,
15
- settingShortcutIndex,
16
- shortcuts,
17
- removeShortcut,
18
- }) => (
19
- <List id="shortcuts_list">
20
- Spells shortcuts:
21
- {Array.from({ length: 4 }).map((_, i) => (
22
- <SpellShortcut
23
- key={i}
24
- onClick={() => {
25
- removeShortcut(i);
26
- if (!shortcuts[i]?.key) setSettingShortcutIndex(i);
27
- }}
28
- disabled={settingShortcutIndex !== -1 && settingShortcutIndex !== i}
29
- isBeingSet={settingShortcutIndex === i}
30
- >
31
- <span>{shortcuts[i]?.magicWords.split(' ').map(word => word[0])}</span>
32
- </SpellShortcut>
33
- ))}
34
- </List>
35
- );
36
- const SpellShortcut = styled.button<{ isBeingSet?: boolean }>`
37
- width: 2.6rem;
38
- height: 2.6rem;
39
- background-color: ${uiColors.lightGray};
40
- border: 2px solid
41
- ${({ isBeingSet }) => (isBeingSet ? uiColors.yellow : uiColors.darkGray)};
42
- border-radius: 50%;
43
- text-transform: uppercase;
44
- font-size: 0.7rem;
45
- font-weight: bold;
46
- display: flex;
47
- align-items: center;
48
- justify-content: center;
49
-
50
- span {
51
- margin-top: 4px;
52
- }
53
-
54
- &:hover,
55
- &:focus {
56
- background-color: ${uiColors.darkGray};
57
- }
58
-
59
- &:active {
60
- background-color: ${uiColors.gray};
61
- }
62
-
63
- &:disabled {
64
- opacity: 0.5;
65
- }
66
- `;
67
-
68
- const List = styled.p`
69
- width: 100%;
70
- display: flex;
71
- align-items: center;
72
- justify-content: flex-end;
73
- gap: 0.5rem;
74
- padding: 0.5rem;
75
- box-sizing: border-box;
76
- margin: 0 !important;
77
- `;
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
+
6
+ type Props = {
7
+ setSettingShortcutIndex: (index: number) => void;
8
+ settingShortcutIndex: number;
9
+ shortcuts: IRawSpell[];
10
+ removeShortcut: (index: number) => void;
11
+ };
12
+
13
+ export const SpellbookShortcuts: React.FC<Props> = ({
14
+ setSettingShortcutIndex,
15
+ settingShortcutIndex,
16
+ shortcuts,
17
+ removeShortcut,
18
+ }) => (
19
+ <List id="shortcuts_list">
20
+ Spells shortcuts:
21
+ {Array.from({ length: 4 }).map((_, i) => (
22
+ <SpellShortcut
23
+ key={i}
24
+ onClick={() => {
25
+ removeShortcut(i);
26
+ if (!shortcuts[i]?.key) setSettingShortcutIndex(i);
27
+ }}
28
+ disabled={settingShortcutIndex !== -1 && settingShortcutIndex !== i}
29
+ isBeingSet={settingShortcutIndex === i}
30
+ >
31
+ <span>{shortcuts[i]?.magicWords.split(' ').map(word => word[0])}</span>
32
+ </SpellShortcut>
33
+ ))}
34
+ </List>
35
+ );
36
+ const SpellShortcut = styled.button<{ isBeingSet?: boolean }>`
37
+ width: 2.6rem;
38
+ height: 2.6rem;
39
+ background-color: ${uiColors.lightGray};
40
+ border: 2px solid
41
+ ${({ isBeingSet }) => (isBeingSet ? uiColors.yellow : uiColors.darkGray)};
42
+ border-radius: 50%;
43
+ text-transform: uppercase;
44
+ font-size: 0.7rem;
45
+ font-weight: bold;
46
+ display: flex;
47
+ align-items: center;
48
+ justify-content: center;
49
+
50
+ span {
51
+ margin-top: 4px;
52
+ }
53
+
54
+ &:hover,
55
+ &:focus {
56
+ background-color: ${uiColors.darkGray};
57
+ }
58
+
59
+ &:active {
60
+ background-color: ${uiColors.gray};
61
+ }
62
+
63
+ &:disabled {
64
+ opacity: 0.5;
65
+ }
66
+ `;
67
+
68
+ const List = styled.p`
69
+ width: 100%;
70
+ display: flex;
71
+ align-items: center;
72
+ justify-content: flex-end;
73
+ gap: 0.5rem;
74
+ padding: 0.5rem;
75
+ box-sizing: border-box;
76
+ margin: 0 !important;
77
+ `;
@@ -1,12 +1,12 @@
1
- import { IRawSpell } from '@rpg-engine/shared';
2
-
3
- export const SPELL_SHORTCUTS_STORAGE_KEY = 'spellShortcuts';
4
-
5
- export const defaultSpellShortcut: IRawSpell = {
6
- key: '',
7
- manaCost: 0,
8
- magicWords: '',
9
- name: '',
10
- description: '',
11
- minMagicLevelRequired: 0,
12
- };
1
+ import { IRawSpell } from '@rpg-engine/shared';
2
+
3
+ export const SPELL_SHORTCUTS_STORAGE_KEY = 'spellShortcuts';
4
+
5
+ export const defaultSpellShortcut: IRawSpell = {
6
+ key: '',
7
+ manaCost: 0,
8
+ magicWords: '',
9
+ name: '',
10
+ description: '',
11
+ minMagicLevelRequired: 0,
12
+ };
@@ -1,60 +1,60 @@
1
- import { IRawSpell } from '@rpg-engine/shared';
2
-
3
- enum SpellsBlueprint {
4
- SelfHealingSpell = 'self-healing-spell',
5
- FoodCreationSpell = 'food-creation-spell',
6
- ArrowCreationSpell = 'arrow-creation-spell',
7
- BoltCreationSpell = 'bolt-creation-spell',
8
- BlankRuneCreationSpell = 'blank-rune-creation-spell',
9
- SelfHasteSpell = 'self-haste-spell',
10
- FireRuneCreationSpell = 'fire-rune-creation-spell',
11
- HealRuneCreationSpell = 'healing-rune-creation-spell',
12
- PoisonRuneCreationSpell = 'poison-rune-creation-spell',
13
- DarkRuneCreationSpell = 'dark-rune-creation-spell',
14
- GreaterHealingSpell = 'greater-healing-spell',
15
- EnergyBoltCreationSpell = 'energy-bolt-creation-spell',
16
- FireBoltCreationSpell = 'fire-bolt-creation-spell',
17
- }
18
-
19
- export const mockSpells: IRawSpell[] = [
20
- {
21
- key: SpellsBlueprint.ArrowCreationSpell,
22
- name: 'Arrow Creation Spell',
23
- description: 'A spell that creates arrow in your inventory.',
24
- magicWords: 'iquar elandi',
25
- manaCost: 10,
26
- minMagicLevelRequired: 3,
27
- },
28
- {
29
- key: SpellsBlueprint.BlankRuneCreationSpell,
30
- name: 'Blank Rune Creation Spell',
31
- description: 'A spell that creates a blank rune in your inventory.',
32
- magicWords: 'iquar ansr ki',
33
- manaCost: 5,
34
- minMagicLevelRequired: 3,
35
- },
36
- {
37
- key: SpellsBlueprint.BoltCreationSpell,
38
- name: 'Bolt Creation Spell',
39
- description: 'A spell that creates bolt in your inventory.',
40
- magicWords: 'iquar lyn',
41
- manaCost: 15,
42
- minMagicLevelRequired: 3,
43
- },
44
- {
45
- key: SpellsBlueprint.SelfHasteSpell,
46
- name: 'Self Haste Spell',
47
- description: 'A self haste spell.',
48
- magicWords: 'talas hiz',
49
- manaCost: 40,
50
- minMagicLevelRequired: 5,
51
- },
52
- {
53
- key: SpellsBlueprint.SelfHealingSpell,
54
- name: 'Self Healing Spell',
55
- description: 'A self healing spell.',
56
- magicWords: 'talas faenya',
57
- manaCost: 10,
58
- minMagicLevelRequired: 1,
59
- },
60
- ];
1
+ import { IRawSpell } from '@rpg-engine/shared';
2
+
3
+ enum SpellsBlueprint {
4
+ SelfHealingSpell = 'self-healing-spell',
5
+ FoodCreationSpell = 'food-creation-spell',
6
+ ArrowCreationSpell = 'arrow-creation-spell',
7
+ BoltCreationSpell = 'bolt-creation-spell',
8
+ BlankRuneCreationSpell = 'blank-rune-creation-spell',
9
+ SelfHasteSpell = 'self-haste-spell',
10
+ FireRuneCreationSpell = 'fire-rune-creation-spell',
11
+ HealRuneCreationSpell = 'healing-rune-creation-spell',
12
+ PoisonRuneCreationSpell = 'poison-rune-creation-spell',
13
+ DarkRuneCreationSpell = 'dark-rune-creation-spell',
14
+ GreaterHealingSpell = 'greater-healing-spell',
15
+ EnergyBoltCreationSpell = 'energy-bolt-creation-spell',
16
+ FireBoltCreationSpell = 'fire-bolt-creation-spell',
17
+ }
18
+
19
+ export const mockSpells: IRawSpell[] = [
20
+ {
21
+ key: SpellsBlueprint.ArrowCreationSpell,
22
+ name: 'Arrow Creation Spell',
23
+ description: 'A spell that creates arrow in your inventory.',
24
+ magicWords: 'iquar elandi',
25
+ manaCost: 10,
26
+ minMagicLevelRequired: 3,
27
+ },
28
+ {
29
+ key: SpellsBlueprint.BlankRuneCreationSpell,
30
+ name: 'Blank Rune Creation Spell',
31
+ description: 'A spell that creates a blank rune in your inventory.',
32
+ magicWords: 'iquar ansr ki',
33
+ manaCost: 5,
34
+ minMagicLevelRequired: 3,
35
+ },
36
+ {
37
+ key: SpellsBlueprint.BoltCreationSpell,
38
+ name: 'Bolt Creation Spell',
39
+ description: 'A spell that creates bolt in your inventory.',
40
+ magicWords: 'iquar lyn',
41
+ manaCost: 15,
42
+ minMagicLevelRequired: 3,
43
+ },
44
+ {
45
+ key: SpellsBlueprint.SelfHasteSpell,
46
+ name: 'Self Haste Spell',
47
+ description: 'A self haste spell.',
48
+ magicWords: 'talas hiz',
49
+ manaCost: 40,
50
+ minMagicLevelRequired: 5,
51
+ },
52
+ {
53
+ key: SpellsBlueprint.SelfHealingSpell,
54
+ name: 'Self Healing Spell',
55
+ description: 'A self healing spell.',
56
+ magicWords: 'talas faenya',
57
+ manaCost: 10,
58
+ minMagicLevelRequired: 1,
59
+ },
60
+ ];