@rpg-engine/long-bow 0.4.2 → 0.4.4

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/long-bow.cjs.development.js +1059 -1059
  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 +1065 -1065
  8. package/dist/long-bow.esm.js.map +1 -1
  9. package/package.json +100 -100
  10. package/src/components/Abstractions/ModalPortal.tsx +22 -22
  11. package/src/components/Abstractions/SlotsContainer.tsx +62 -62
  12. package/src/components/Arrow/SelectArrow.tsx +69 -69
  13. package/src/components/Arrow/img/arrow01-left-clicked.png +0 -0
  14. package/src/components/Arrow/img/arrow01-left.png +0 -0
  15. package/src/components/Arrow/img/arrow01-right-clicked.png +0 -0
  16. package/src/components/Arrow/img/arrow01-right.png +0 -0
  17. package/src/components/Arrow/img/arrow02-left-clicked.png +0 -0
  18. package/src/components/Arrow/img/arrow02-left.png +0 -0
  19. package/src/components/Arrow/img/arrow02-right-clicked.png +0 -0
  20. package/src/components/Arrow/img/arrow02-right.png +0 -0
  21. package/src/components/Button.tsx +40 -40
  22. package/src/components/Character/CharacterSelection.tsx +98 -98
  23. package/src/components/CharacterStatus/CharacterStatus.tsx +120 -120
  24. package/src/components/Chat/Chat.tsx +196 -196
  25. package/src/components/Chatdeprecated/ChatDeprecated.tsx +198 -198
  26. package/src/components/CheckButton.tsx +65 -65
  27. package/src/components/CircularController/CircularController.tsx +282 -282
  28. package/src/components/CraftBook/CraftBook.tsx +286 -286
  29. package/src/components/CraftBook/CraftingRecipe.tsx +161 -161
  30. package/src/components/CraftBook/MockItems.ts +101 -101
  31. package/src/components/DraggableContainer.tsx +181 -180
  32. package/src/components/DropdownSelectorContainer.tsx +42 -42
  33. package/src/components/Equipment/EquipmentSet.tsx +199 -199
  34. package/src/components/HistoryDialog.tsx +104 -104
  35. package/src/components/Input.tsx +15 -15
  36. package/src/components/InputRadio.tsx +41 -41
  37. package/src/components/Item/Cards/ItemInfo.tsx +298 -298
  38. package/src/components/Item/Cards/ItemInfoDisplay.tsx +135 -135
  39. package/src/components/Item/Cards/ItemInfoWrapper.tsx +62 -62
  40. package/src/components/Item/Cards/ItemTooltip.tsx +83 -83
  41. package/src/components/Item/Cards/MobileItemTooltip.tsx +149 -149
  42. package/src/components/Item/Inventory/ErrorBoundary.tsx +42 -42
  43. package/src/components/Item/Inventory/ItemContainer.tsx +231 -231
  44. package/src/components/Item/Inventory/ItemContainerTypes.ts +6 -6
  45. package/src/components/Item/Inventory/ItemQuantitySelector.tsx +138 -138
  46. package/src/components/Item/Inventory/ItemSlot.tsx +580 -580
  47. package/src/components/Item/Inventory/itemContainerHelper.ts +175 -175
  48. package/src/components/ListMenu.tsx +63 -63
  49. package/src/components/Marketplace/Marketplace.tsx +132 -132
  50. package/src/components/Marketplace/MarketplaceRows.tsx +171 -171
  51. package/src/components/Marketplace/__mocks__/index.tsx +65 -65
  52. package/src/components/Multitab/Tab.tsx +66 -66
  53. package/src/components/Multitab/TabBody.tsx +13 -13
  54. package/src/components/Multitab/TabsContainer.tsx +97 -97
  55. package/src/components/NPCDialog/NPCDialog.tsx +121 -121
  56. package/src/components/NPCDialog/NPCDialogText.tsx +113 -113
  57. package/src/components/NPCDialog/NPCMultiDialog.tsx +159 -159
  58. package/src/components/NPCDialog/QuestionDialog/QuestionDialog.tsx +237 -237
  59. package/src/components/ProgressBar.tsx +95 -95
  60. package/src/components/PropertySelect/PropertySelect.tsx +106 -106
  61. package/src/components/QuestInfo/QuestInfo.tsx +233 -233
  62. package/src/components/QuestList.tsx +135 -135
  63. package/src/components/RPGUIContainer.tsx +47 -47
  64. package/src/components/RPGUIForceRenderStart.tsx +45 -45
  65. package/src/components/RPGUIRoot.tsx +14 -14
  66. package/src/components/RadioButton.tsx +53 -53
  67. package/src/components/RadioInput/RadioButton.tsx +96 -96
  68. package/src/components/RadioInput/RadioInput.tsx +102 -102
  69. package/src/components/RadioInput/instruments.ts +15 -15
  70. package/src/components/RangeSlider.tsx +78 -78
  71. package/src/components/RelativeListMenu.tsx +90 -90
  72. package/src/components/ScrollList.tsx +79 -79
  73. package/src/components/Shortcuts/Shortcuts.tsx +193 -193
  74. package/src/components/Shortcuts/ShortcutsSetter.tsx +139 -139
  75. package/src/components/Shortcuts/SingleShortcut.ts +82 -82
  76. package/src/components/Shortcuts/useShortcutCooldown.ts +23 -23
  77. package/src/components/SimpleProgressBar.tsx +62 -62
  78. package/src/components/SkillProgressBar.tsx +133 -133
  79. package/src/components/SkillsContainer.tsx +211 -211
  80. package/src/components/Spellbook/Spell.tsx +236 -236
  81. package/src/components/Spellbook/Spellbook.tsx +161 -161
  82. package/src/components/Spellbook/cards/MobileSpellTooltip.tsx +137 -137
  83. package/src/components/Spellbook/cards/SpellInfo.tsx +134 -134
  84. package/src/components/Spellbook/cards/SpellInfoDisplay.tsx +31 -31
  85. package/src/components/Spellbook/cards/SpellInfoWrapper.tsx +48 -48
  86. package/src/components/Spellbook/cards/SpellTooltip.tsx +70 -70
  87. package/src/components/Spellbook/constants.ts +7 -7
  88. package/src/components/Spellbook/mockSpells.ts +84 -84
  89. package/src/components/StaticBook/StaticBook.tsx +103 -103
  90. package/src/components/TextArea.tsx +11 -11
  91. package/src/components/TimeWidget/DayNightPeriod/DayNightPeriod.tsx +35 -35
  92. package/src/components/TimeWidget/TimeWidget.tsx +65 -65
  93. package/src/components/TradingMenu/TradingItemRow.tsx +199 -199
  94. package/src/components/TradingMenu/TradingMenu.tsx +219 -219
  95. package/src/components/TradingMenu/items.mock.ts +48 -48
  96. package/src/components/Truncate.tsx +25 -25
  97. package/src/components/itemSelector/ItemSelector.tsx +136 -136
  98. package/src/components/shared/Column.tsx +16 -16
  99. package/src/components/shared/Ellipsis.tsx +68 -68
  100. package/src/components/shared/SpriteFromAtlas.tsx +104 -104
  101. package/src/components/typography/DynamicText.tsx +49 -49
  102. package/src/constants/uiColors.ts +20 -20
  103. package/src/constants/uiDevices.ts +3 -3
  104. package/src/constants/uiFonts.ts +12 -12
  105. package/src/hooks/useEventListener.ts +21 -21
  106. package/src/hooks/useOutsideAlerter.ts +25 -25
  107. package/src/index.tsx +42 -42
  108. package/src/libs/CastingTypeHelper.ts +7 -7
  109. package/src/libs/StringHelpers.ts +3 -3
  110. package/src/libs/itemCounter.ts +21 -21
  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 -391
  115. package/src/mocks/itemContainer.mocks.ts +605 -605
  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 +44 -44
  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 -42
  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 +201 -201
  133. package/src/stories/ItemInfoDisplay.stories.tsx +33 -33
  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/Marketplace.stories.tsx +42 -42
  139. package/src/stories/MarketplaceRows.stories.tsx +28 -28
  140. package/src/stories/Multitab.stories.tsx +51 -51
  141. package/src/stories/NPCDialog.stories.tsx +130 -130
  142. package/src/stories/NPCMultiDialog.stories.tsx +71 -71
  143. package/src/stories/ProgressBar.stories.tsx +23 -23
  144. package/src/stories/PropertySelect.stories.tsx +40 -40
  145. package/src/stories/QuestInfo.stories.tsx +107 -107
  146. package/src/stories/QuestList.stories.tsx +82 -82
  147. package/src/stories/RPGUIContainers.stories.tsx +42 -42
  148. package/src/stories/RadioButton.stories.tsx +49 -49
  149. package/src/stories/RadioInput.stories.tsx +34 -34
  150. package/src/stories/RangeSlider.stories.tsx +64 -64
  151. package/src/stories/ScrollList.stories.tsx +85 -85
  152. package/src/stories/Shortcuts.stories.tsx +39 -39
  153. package/src/stories/SimpleProgressBar.stories.tsx +22 -22
  154. package/src/stories/SkillProgressBar.stories.tsx +34 -34
  155. package/src/stories/SkillsContainer.stories.tsx +35 -35
  156. package/src/stories/SpellInfoDisplay.stories.tsx +27 -27
  157. package/src/stories/Spellbook.stories.tsx +104 -104
  158. package/src/stories/StaticBook.stories.tsx +32 -32
  159. package/src/stories/Text.stories.tsx +42 -42
  160. package/src/stories/TimeWidget.stories.tsx +27 -27
  161. package/src/stories/TradingMenu.stories.tsx +47 -47
  162. package/src/types/eventTypes.ts +4 -4
  163. package/src/types/index.d.ts +2 -2
@@ -1,199 +1,199 @@
1
- import {
2
- IEquipmentSet,
3
- IItem,
4
- IItemContainer,
5
- ItemContainerType,
6
- ItemSlotType,
7
- ItemType,
8
- } from '@rpg-engine/shared';
9
- import React from 'react';
10
- import styled from 'styled-components';
11
- import { IPosition } from '../../types/eventTypes';
12
- import { DraggableContainer } from '../DraggableContainer';
13
- import { ItemSlot } from '../Item/Inventory/ItemSlot';
14
- import { RPGUIContainerTypes } from '../RPGUIContainer';
15
-
16
- export interface IEquipmentSetProps {
17
- equipmentSet: IEquipmentSet;
18
- onClose?: () => void;
19
- onItemClick?: (
20
- ItemType: ItemType,
21
- item: IItem,
22
- itemContainerType: ItemContainerType | null
23
- ) => void;
24
- onItemDragStart?: (
25
- item: IItem,
26
- slotIndex: number,
27
- itemContainerType: ItemContainerType | null
28
- ) => void;
29
- onItemDragEnd?: (quantity?: number) => void;
30
- onItemPlaceDrop?: (
31
- item: IItem | null,
32
- slotIndex: number,
33
- itemContainerType: ItemContainerType | null
34
- ) => void;
35
- onItemOutsideDrop?: (item: IItem, position: IPosition) => void;
36
- scale?: number;
37
- checkIfItemCanBeMoved: () => boolean;
38
- checkIfItemShouldDragEnd?: () => boolean;
39
- onMouseOver?: (e: any, slotIndex: number, item: IItem | null) => void;
40
- onSelected?: (optionId: string) => void;
41
- initialPosition?: { x: number; y: number };
42
- type: ItemContainerType | null;
43
- atlasIMG: any;
44
- atlasJSON: any;
45
- onPositionChangeEnd?: (position: IPosition) => void;
46
- onPositionChangeStart?: (position: IPosition) => void;
47
- }
48
-
49
- export const EquipmentSet: React.FC<IEquipmentSetProps> = ({
50
- equipmentSet,
51
- onClose,
52
- onMouseOver,
53
- onSelected,
54
- onItemClick,
55
- atlasIMG,
56
- atlasJSON,
57
- onItemDragEnd,
58
- onItemDragStart,
59
- onItemPlaceDrop,
60
- onItemOutsideDrop,
61
- checkIfItemCanBeMoved,
62
- checkIfItemShouldDragEnd,
63
- scale,
64
- initialPosition,
65
- onPositionChangeEnd,
66
- onPositionChangeStart,
67
- }) => {
68
- const {
69
- neck,
70
- leftHand,
71
- ring,
72
- head,
73
- armor,
74
- legs,
75
- boot,
76
- inventory,
77
- rightHand,
78
- accessory,
79
- } = equipmentSet;
80
-
81
- const equipmentData = [
82
- neck,
83
- leftHand,
84
- ring,
85
- head,
86
- armor,
87
- legs,
88
- boot,
89
- inventory,
90
- rightHand,
91
- accessory,
92
- ];
93
-
94
- const equipmentMaskSlots = [
95
- ItemSlotType.Neck,
96
- ItemSlotType.LeftHand,
97
- ItemSlotType.Ring,
98
- ItemSlotType.Head,
99
- ItemSlotType.Torso,
100
- ItemSlotType.Legs,
101
- ItemSlotType.Feet,
102
- ItemSlotType.Inventory,
103
- ItemSlotType.RightHand,
104
- ItemSlotType.Accessory,
105
- ];
106
-
107
- const onRenderEquipmentSlotRange = (start: number, end: number) => {
108
- const equipmentRange = equipmentData.slice(start, end);
109
- const slotMaksRange = equipmentMaskSlots.slice(start, end);
110
-
111
- return equipmentRange.map((data, i) => {
112
- const item = data as IItem;
113
- const itemContainer =
114
- (item && (item.itemContainer as IItemContainer)) ?? null;
115
-
116
- return (
117
- <ItemSlot
118
- key={i}
119
- slotIndex={i}
120
- item={item}
121
- itemContainer={itemContainer}
122
- itemContainerType={ItemContainerType.Equipment}
123
- slotSpriteMask={slotMaksRange[i]}
124
- onMouseOver={(event, slotIndex, item) => {
125
- if (onMouseOver) onMouseOver(event, slotIndex, item);
126
- }}
127
- onPointerDown={(itemType, ContainerType) => {
128
- if (onItemClick) onItemClick(itemType, item, ContainerType);
129
- }}
130
- onSelected={(optionId: string) => {
131
- if (onSelected) onSelected(optionId);
132
- }}
133
- onDragStart={(item, slotIndex, itemContainerType) => {
134
- if (!item) {
135
- return;
136
- }
137
-
138
- if (onItemDragStart)
139
- onItemDragStart(item, slotIndex, itemContainerType);
140
- }}
141
- onDragEnd={quantity => {
142
- if (onItemDragEnd) onItemDragEnd(quantity);
143
- }}
144
- dragScale={scale}
145
- checkIfItemCanBeMoved={checkIfItemCanBeMoved}
146
- checkIfItemShouldDragEnd={checkIfItemShouldDragEnd}
147
- onPlaceDrop={(item, slotIndex, itemContainerType) => {
148
- if (onItemPlaceDrop)
149
- onItemPlaceDrop(item, slotIndex, itemContainerType);
150
- }}
151
- onOutsideDrop={(item, position) => {
152
- if (onItemOutsideDrop) onItemOutsideDrop(item, position);
153
- }}
154
- atlasIMG={atlasIMG}
155
- atlasJSON={atlasJSON}
156
- />
157
- );
158
- });
159
- };
160
-
161
- return (
162
- <DraggableContainer
163
- title={'Equipments'}
164
- type={RPGUIContainerTypes.Framed}
165
- onCloseButton={() => {
166
- if (onClose) onClose();
167
- }}
168
- width="330px"
169
- cancelDrag=".equipment-container-body"
170
- scale={scale}
171
- initialPosition={initialPosition}
172
- onPositionChangeEnd={onPositionChangeEnd}
173
- onPositionChangeStart={onPositionChangeStart}
174
- >
175
- <EquipmentSetContainer className="equipment-container-body">
176
- <EquipmentColumn>{onRenderEquipmentSlotRange(0, 3)}</EquipmentColumn>
177
- <EquipmentColumn>{onRenderEquipmentSlotRange(3, 7)}</EquipmentColumn>
178
- <EquipmentColumn>{onRenderEquipmentSlotRange(7, 10)}</EquipmentColumn>
179
- </EquipmentSetContainer>
180
- </DraggableContainer>
181
- );
182
- };
183
-
184
- const EquipmentSetContainer = styled.div`
185
- width: inherit;
186
- display: flex;
187
- justify-content: center;
188
- flex-wrap: wrap;
189
- flex-direction: row;
190
- touch-action: none;
191
- `;
192
-
193
- const EquipmentColumn = styled.div`
194
- display: flex;
195
- justify-content: center;
196
- flex-wrap: wrap;
197
- flex-direction: column;
198
- touch-action: none;
199
- `;
1
+ import {
2
+ IEquipmentSet,
3
+ IItem,
4
+ IItemContainer,
5
+ ItemContainerType,
6
+ ItemSlotType,
7
+ ItemType,
8
+ } from '@rpg-engine/shared';
9
+ import React from 'react';
10
+ import styled from 'styled-components';
11
+ import { IPosition } from '../../types/eventTypes';
12
+ import { DraggableContainer } from '../DraggableContainer';
13
+ import { ItemSlot } from '../Item/Inventory/ItemSlot';
14
+ import { RPGUIContainerTypes } from '../RPGUIContainer';
15
+
16
+ export interface IEquipmentSetProps {
17
+ equipmentSet: IEquipmentSet;
18
+ onClose?: () => void;
19
+ onItemClick?: (
20
+ ItemType: ItemType,
21
+ item: IItem,
22
+ itemContainerType: ItemContainerType | null
23
+ ) => void;
24
+ onItemDragStart?: (
25
+ item: IItem,
26
+ slotIndex: number,
27
+ itemContainerType: ItemContainerType | null
28
+ ) => void;
29
+ onItemDragEnd?: (quantity?: number) => void;
30
+ onItemPlaceDrop?: (
31
+ item: IItem | null,
32
+ slotIndex: number,
33
+ itemContainerType: ItemContainerType | null
34
+ ) => void;
35
+ onItemOutsideDrop?: (item: IItem, position: IPosition) => void;
36
+ scale?: number;
37
+ checkIfItemCanBeMoved: () => boolean;
38
+ checkIfItemShouldDragEnd?: () => boolean;
39
+ onMouseOver?: (e: any, slotIndex: number, item: IItem | null) => void;
40
+ onSelected?: (optionId: string) => void;
41
+ initialPosition?: { x: number; y: number };
42
+ type: ItemContainerType | null;
43
+ atlasIMG: any;
44
+ atlasJSON: any;
45
+ onPositionChangeEnd?: (position: IPosition) => void;
46
+ onPositionChangeStart?: (position: IPosition) => void;
47
+ }
48
+
49
+ export const EquipmentSet: React.FC<IEquipmentSetProps> = ({
50
+ equipmentSet,
51
+ onClose,
52
+ onMouseOver,
53
+ onSelected,
54
+ onItemClick,
55
+ atlasIMG,
56
+ atlasJSON,
57
+ onItemDragEnd,
58
+ onItemDragStart,
59
+ onItemPlaceDrop,
60
+ onItemOutsideDrop,
61
+ checkIfItemCanBeMoved,
62
+ checkIfItemShouldDragEnd,
63
+ scale,
64
+ initialPosition,
65
+ onPositionChangeEnd,
66
+ onPositionChangeStart,
67
+ }) => {
68
+ const {
69
+ neck,
70
+ leftHand,
71
+ ring,
72
+ head,
73
+ armor,
74
+ legs,
75
+ boot,
76
+ inventory,
77
+ rightHand,
78
+ accessory,
79
+ } = equipmentSet;
80
+
81
+ const equipmentData = [
82
+ neck,
83
+ leftHand,
84
+ ring,
85
+ head,
86
+ armor,
87
+ legs,
88
+ boot,
89
+ inventory,
90
+ rightHand,
91
+ accessory,
92
+ ];
93
+
94
+ const equipmentMaskSlots = [
95
+ ItemSlotType.Neck,
96
+ ItemSlotType.LeftHand,
97
+ ItemSlotType.Ring,
98
+ ItemSlotType.Head,
99
+ ItemSlotType.Torso,
100
+ ItemSlotType.Legs,
101
+ ItemSlotType.Feet,
102
+ ItemSlotType.Inventory,
103
+ ItemSlotType.RightHand,
104
+ ItemSlotType.Accessory,
105
+ ];
106
+
107
+ const onRenderEquipmentSlotRange = (start: number, end: number) => {
108
+ const equipmentRange = equipmentData.slice(start, end);
109
+ const slotMaksRange = equipmentMaskSlots.slice(start, end);
110
+
111
+ return equipmentRange.map((data, i) => {
112
+ const item = data as IItem;
113
+ const itemContainer =
114
+ (item && (item.itemContainer as IItemContainer)) ?? null;
115
+
116
+ return (
117
+ <ItemSlot
118
+ key={i}
119
+ slotIndex={i}
120
+ item={item}
121
+ itemContainer={itemContainer}
122
+ itemContainerType={ItemContainerType.Equipment}
123
+ slotSpriteMask={slotMaksRange[i]}
124
+ onMouseOver={(event, slotIndex, item) => {
125
+ if (onMouseOver) onMouseOver(event, slotIndex, item);
126
+ }}
127
+ onPointerDown={(itemType, ContainerType) => {
128
+ if (onItemClick) onItemClick(itemType, item, ContainerType);
129
+ }}
130
+ onSelected={(optionId: string) => {
131
+ if (onSelected) onSelected(optionId);
132
+ }}
133
+ onDragStart={(item, slotIndex, itemContainerType) => {
134
+ if (!item) {
135
+ return;
136
+ }
137
+
138
+ if (onItemDragStart)
139
+ onItemDragStart(item, slotIndex, itemContainerType);
140
+ }}
141
+ onDragEnd={quantity => {
142
+ if (onItemDragEnd) onItemDragEnd(quantity);
143
+ }}
144
+ dragScale={scale}
145
+ checkIfItemCanBeMoved={checkIfItemCanBeMoved}
146
+ checkIfItemShouldDragEnd={checkIfItemShouldDragEnd}
147
+ onPlaceDrop={(item, slotIndex, itemContainerType) => {
148
+ if (onItemPlaceDrop)
149
+ onItemPlaceDrop(item, slotIndex, itemContainerType);
150
+ }}
151
+ onOutsideDrop={(item, position) => {
152
+ if (onItemOutsideDrop) onItemOutsideDrop(item, position);
153
+ }}
154
+ atlasIMG={atlasIMG}
155
+ atlasJSON={atlasJSON}
156
+ />
157
+ );
158
+ });
159
+ };
160
+
161
+ return (
162
+ <DraggableContainer
163
+ title={'Equipments'}
164
+ type={RPGUIContainerTypes.Framed}
165
+ onCloseButton={() => {
166
+ if (onClose) onClose();
167
+ }}
168
+ width="330px"
169
+ cancelDrag=".equipment-container-body"
170
+ scale={scale}
171
+ initialPosition={initialPosition}
172
+ onPositionChangeEnd={onPositionChangeEnd}
173
+ onPositionChangeStart={onPositionChangeStart}
174
+ >
175
+ <EquipmentSetContainer className="equipment-container-body">
176
+ <EquipmentColumn>{onRenderEquipmentSlotRange(0, 3)}</EquipmentColumn>
177
+ <EquipmentColumn>{onRenderEquipmentSlotRange(3, 7)}</EquipmentColumn>
178
+ <EquipmentColumn>{onRenderEquipmentSlotRange(7, 10)}</EquipmentColumn>
179
+ </EquipmentSetContainer>
180
+ </DraggableContainer>
181
+ );
182
+ };
183
+
184
+ const EquipmentSetContainer = styled.div`
185
+ width: inherit;
186
+ display: flex;
187
+ justify-content: center;
188
+ flex-wrap: wrap;
189
+ flex-direction: row;
190
+ touch-action: none;
191
+ `;
192
+
193
+ const EquipmentColumn = styled.div`
194
+ display: flex;
195
+ justify-content: center;
196
+ flex-wrap: wrap;
197
+ flex-direction: column;
198
+ touch-action: none;
199
+ `;
@@ -1,104 +1,104 @@
1
- import React, { useEffect, useState } from 'react';
2
- import styled from 'styled-components';
3
- import { NPCDialog, NPCDialogType } from './NPCDialog/NPCDialog';
4
- import { NPCMultiDialog, NPCMultiDialogType } from './NPCDialog/NPCMultiDialog';
5
- import {
6
- IQuestionDialog,
7
- IQuestionDialogAnswer,
8
- QuestionDialog,
9
- } from './NPCDialog/QuestionDialog/QuestionDialog';
10
-
11
- export interface IHistoryDialogProps {
12
- backgroundImgPath: string[];
13
- fullCoverBackground: boolean;
14
- questions?: IQuestionDialog[];
15
- answers?: IQuestionDialogAnswer[];
16
- text?: string;
17
- imagePath?: string;
18
- textAndTypeArray?: NPCMultiDialogType[];
19
- onClose: () => void;
20
- }
21
-
22
- export const HistoryDialog: React.FC<IHistoryDialogProps> = ({
23
- backgroundImgPath,
24
- fullCoverBackground,
25
- questions,
26
- answers,
27
- text,
28
- imagePath,
29
- textAndTypeArray,
30
- onClose,
31
- }) => {
32
- const [img, setImage] = useState<number>(0);
33
- const onHandleSpacePress = (event: KeyboardEvent) => {
34
- if (event.code === 'Space') {
35
- if (img < backgroundImgPath?.length - 1) {
36
- setImage(prev => prev + 1);
37
- } else {
38
- // if there's no more text chunks, close the dialog
39
- onClose();
40
- }
41
- }
42
- };
43
-
44
- useEffect(() => {
45
- document.addEventListener('keydown', onHandleSpacePress);
46
-
47
- return () => document.removeEventListener('keydown', onHandleSpacePress);
48
- }, [backgroundImgPath]);
49
- return (
50
- <BackgroundContainer
51
- imgPath={backgroundImgPath[img]}
52
- fullImg={fullCoverBackground}
53
- >
54
- <DialogContainer>
55
- {textAndTypeArray ? (
56
- <NPCMultiDialog
57
- textAndTypeArray={textAndTypeArray}
58
- onClose={onClose}
59
- />
60
- ) : questions && answers ? (
61
- <QuestionDialog
62
- questions={questions}
63
- answers={answers}
64
- onClose={onClose}
65
- />
66
- ) : text && imagePath ? (
67
- <NPCDialog
68
- text={text}
69
- imagePath={imagePath}
70
- onClose={onClose}
71
- type={NPCDialogType.TextAndThumbnail}
72
- />
73
- ) : (
74
- <NPCDialog
75
- text={text}
76
- onClose={onClose}
77
- type={NPCDialogType.TextOnly}
78
- />
79
- )}
80
- </DialogContainer>
81
- </BackgroundContainer>
82
- );
83
- };
84
-
85
- interface IImgContainerProps {
86
- imgPath: string;
87
- fullImg: boolean;
88
- }
89
-
90
- const BackgroundContainer = styled.div<IImgContainerProps>`
91
- width: 100%;
92
- height: 100%;
93
- background-image: url(${props => props.imgPath});
94
- background-size: ${props => (props.imgPath ? 'cover' : 'auto')};
95
- display: flex;
96
- justify-content: space-evenly;
97
- align-items: center;
98
- `;
99
-
100
- const DialogContainer = styled.div`
101
- display: flex;
102
- justify-content: center;
103
- padding-top: 200px;
104
- `;
1
+ import React, { useEffect, useState } from 'react';
2
+ import styled from 'styled-components';
3
+ import { NPCDialog, NPCDialogType } from './NPCDialog/NPCDialog';
4
+ import { NPCMultiDialog, NPCMultiDialogType } from './NPCDialog/NPCMultiDialog';
5
+ import {
6
+ IQuestionDialog,
7
+ IQuestionDialogAnswer,
8
+ QuestionDialog,
9
+ } from './NPCDialog/QuestionDialog/QuestionDialog';
10
+
11
+ export interface IHistoryDialogProps {
12
+ backgroundImgPath: string[];
13
+ fullCoverBackground: boolean;
14
+ questions?: IQuestionDialog[];
15
+ answers?: IQuestionDialogAnswer[];
16
+ text?: string;
17
+ imagePath?: string;
18
+ textAndTypeArray?: NPCMultiDialogType[];
19
+ onClose: () => void;
20
+ }
21
+
22
+ export const HistoryDialog: React.FC<IHistoryDialogProps> = ({
23
+ backgroundImgPath,
24
+ fullCoverBackground,
25
+ questions,
26
+ answers,
27
+ text,
28
+ imagePath,
29
+ textAndTypeArray,
30
+ onClose,
31
+ }) => {
32
+ const [img, setImage] = useState<number>(0);
33
+ const onHandleSpacePress = (event: KeyboardEvent) => {
34
+ if (event.code === 'Space') {
35
+ if (img < backgroundImgPath?.length - 1) {
36
+ setImage(prev => prev + 1);
37
+ } else {
38
+ // if there's no more text chunks, close the dialog
39
+ onClose();
40
+ }
41
+ }
42
+ };
43
+
44
+ useEffect(() => {
45
+ document.addEventListener('keydown', onHandleSpacePress);
46
+
47
+ return () => document.removeEventListener('keydown', onHandleSpacePress);
48
+ }, [backgroundImgPath]);
49
+ return (
50
+ <BackgroundContainer
51
+ imgPath={backgroundImgPath[img]}
52
+ fullImg={fullCoverBackground}
53
+ >
54
+ <DialogContainer>
55
+ {textAndTypeArray ? (
56
+ <NPCMultiDialog
57
+ textAndTypeArray={textAndTypeArray}
58
+ onClose={onClose}
59
+ />
60
+ ) : questions && answers ? (
61
+ <QuestionDialog
62
+ questions={questions}
63
+ answers={answers}
64
+ onClose={onClose}
65
+ />
66
+ ) : text && imagePath ? (
67
+ <NPCDialog
68
+ text={text}
69
+ imagePath={imagePath}
70
+ onClose={onClose}
71
+ type={NPCDialogType.TextAndThumbnail}
72
+ />
73
+ ) : (
74
+ <NPCDialog
75
+ text={text}
76
+ onClose={onClose}
77
+ type={NPCDialogType.TextOnly}
78
+ />
79
+ )}
80
+ </DialogContainer>
81
+ </BackgroundContainer>
82
+ );
83
+ };
84
+
85
+ interface IImgContainerProps {
86
+ imgPath: string;
87
+ fullImg: boolean;
88
+ }
89
+
90
+ const BackgroundContainer = styled.div<IImgContainerProps>`
91
+ width: 100%;
92
+ height: 100%;
93
+ background-image: url(${props => props.imgPath});
94
+ background-size: ${props => (props.imgPath ? 'cover' : 'auto')};
95
+ display: flex;
96
+ justify-content: space-evenly;
97
+ align-items: center;
98
+ `;
99
+
100
+ const DialogContainer = styled.div`
101
+ display: flex;
102
+ justify-content: center;
103
+ padding-top: 200px;
104
+ `;
@@ -1,15 +1,15 @@
1
- import React from 'react';
2
-
3
- export interface IInputProps
4
- extends React.DetailedHTMLProps<
5
- React.InputHTMLAttributes<HTMLInputElement>,
6
- HTMLInputElement
7
- > {
8
- innerRef?: React.Ref<HTMLInputElement>;
9
- }
10
-
11
- export const Input: React.FC<IInputProps> = ({ ...props }) => {
12
- const { innerRef, ...rest } = props;
13
-
14
- return <input {...rest} ref={props.innerRef} />;
15
- };
1
+ import React from 'react';
2
+
3
+ export interface IInputProps
4
+ extends React.DetailedHTMLProps<
5
+ React.InputHTMLAttributes<HTMLInputElement>,
6
+ HTMLInputElement
7
+ > {
8
+ innerRef?: React.Ref<HTMLInputElement>;
9
+ }
10
+
11
+ export const Input: React.FC<IInputProps> = ({ ...props }) => {
12
+ const { innerRef, ...rest } = props;
13
+
14
+ return <input {...rest} ref={props.innerRef} />;
15
+ };