@rpg-engine/long-bow 0.4.2 → 0.4.3

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 +1060 -1065
  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 +1066 -1071
  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 +92 -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 +217 -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,231 +1,231 @@
1
- import {
2
- IEquipmentSet,
3
- IItem,
4
- IItemContainer,
5
- IShortcut,
6
- ItemContainerType,
7
- ItemType,
8
- } from '@rpg-engine/shared';
9
- import React, { useState } from 'react';
10
- import styled from 'styled-components';
11
- import { SlotsContainer } from '../../Abstractions/SlotsContainer';
12
- import { ItemQuantitySelector } from './ItemQuantitySelector';
13
-
14
- import { IPosition } from '../../../types/eventTypes';
15
- import ModalPortal from '../../Abstractions/ModalPortal';
16
- import { ShortcutsSetter } from '../../Shortcuts/ShortcutsSetter';
17
- import { ItemSlot } from './ItemSlot';
18
-
19
- export interface IItemContainerProps {
20
- itemContainer: IItemContainer;
21
- onClose?: () => void;
22
- onItemClick?: (
23
- item: IItem,
24
- ItemType: IItem['type'],
25
- itemContainerType: ItemContainerType | null
26
- ) => void;
27
- onItemDragStart?: (
28
- item: IItem,
29
- slotIndex: number,
30
- itemContainerType: ItemContainerType | null
31
- ) => void;
32
- onItemDragEnd?: (quantity?: number) => void;
33
- onOutsideDrop?: (item: IItem, position: IPosition) => void;
34
- onItemPlaceDrop?: (
35
- item: IItem | null,
36
- slotIndex: number,
37
- itemContainerType: ItemContainerType | null
38
- ) => void;
39
- scale?: number;
40
- checkIfItemCanBeMoved: () => boolean;
41
- checkIfItemShouldDragEnd?: () => boolean;
42
- onMouseOver?: (e: any, slotIndex: number, item: IItem | null) => void;
43
- onSelected?: (optionId: string, item: IItem) => void;
44
- type: ItemContainerType;
45
- atlasJSON: any;
46
- atlasIMG: any;
47
- disableContextMenu?: boolean;
48
- initialPosition?: { x: number; y: number };
49
- shortcuts?: IShortcut[];
50
- setItemShortcut?: (key: string, index: number) => void;
51
- removeShortcut?: (index: number) => void;
52
- equipmentSet?: IEquipmentSet | null;
53
- isDepotSystem?: boolean;
54
- onPositionChangeEnd?: (position: IPosition) => void;
55
- onPositionChangeStart?: (position: IPosition) => void;
56
- }
57
-
58
- export const ItemContainer: React.FC<IItemContainerProps> = ({
59
- itemContainer,
60
- onClose,
61
- onMouseOver,
62
- onSelected,
63
- onItemClick,
64
- type,
65
- atlasJSON,
66
- atlasIMG,
67
- disableContextMenu = false,
68
- onItemDragEnd,
69
- onItemDragStart,
70
- onItemPlaceDrop,
71
- onOutsideDrop,
72
- checkIfItemCanBeMoved,
73
- initialPosition,
74
- checkIfItemShouldDragEnd,
75
- scale,
76
- shortcuts,
77
- setItemShortcut,
78
- removeShortcut,
79
- equipmentSet,
80
- isDepotSystem,
81
- onPositionChangeEnd,
82
- onPositionChangeStart,
83
- }) => {
84
- const [quantitySelect, setQuantitySelect] = useState({
85
- isOpen: false,
86
- maxQuantity: 1,
87
- callback: (_quantity: number) => {},
88
- });
89
- const [settingShortcutIndex, setSettingShortcutIndex] = useState(-1);
90
-
91
- const handleSetShortcut = (item: IItem, index: number) => {
92
- if (item.type === ItemType.Consumable || item.type === ItemType.Tool) {
93
- setItemShortcut?.(item.key, index);
94
- }
95
- };
96
-
97
- const onRenderSlots = () => {
98
- const slots = [];
99
-
100
- for (let i = 0; i < itemContainer.slotQty; i++) {
101
- slots.push(
102
- <ItemSlot
103
- isContextMenuDisabled={disableContextMenu}
104
- key={i}
105
- slotIndex={i}
106
- item={itemContainer.slots?.[i] || null}
107
- itemContainerType={type}
108
- onMouseOver={(event, slotIndex, item) => {
109
- if (onMouseOver) onMouseOver(event, slotIndex, item);
110
- }}
111
- onPointerDown={(itemType, containerType, item) => {
112
- if (settingShortcutIndex !== -1) {
113
- setSettingShortcutIndex(-1);
114
-
115
- handleSetShortcut(item, settingShortcutIndex);
116
- } else if (onItemClick) onItemClick(item, itemType, containerType);
117
- }}
118
- onSelected={(optionId: string, item: IItem) => {
119
- if (onSelected) onSelected(optionId, item);
120
- }}
121
- onDragStart={(item, slotIndex, itemContainerType) => {
122
- if (onItemDragStart)
123
- onItemDragStart(item, slotIndex, itemContainerType);
124
- }}
125
- onDragEnd={quantity => {
126
- if (onItemDragEnd) onItemDragEnd(quantity);
127
- }}
128
- dragScale={scale}
129
- checkIfItemCanBeMoved={checkIfItemCanBeMoved}
130
- checkIfItemShouldDragEnd={checkIfItemShouldDragEnd}
131
- openQuantitySelector={(maxQuantity, callback) => {
132
- setQuantitySelect({
133
- isOpen: true,
134
- maxQuantity,
135
- callback,
136
- });
137
- }}
138
- onPlaceDrop={(item, slotIndex, itemContainerType) => {
139
- if (onItemPlaceDrop)
140
- onItemPlaceDrop(item, slotIndex, itemContainerType);
141
- }}
142
- onOutsideDrop={(item, position) => {
143
- if (onOutsideDrop) onOutsideDrop(item, position);
144
- }}
145
- atlasIMG={atlasIMG}
146
- atlasJSON={atlasJSON}
147
- isSelectingShortcut={settingShortcutIndex !== -1}
148
- equipmentSet={equipmentSet}
149
- setItemShortcut={
150
- type === ItemContainerType.Inventory ? handleSetShortcut : undefined
151
- }
152
- isDepotSystem={isDepotSystem}
153
- />
154
- );
155
- }
156
- return slots;
157
- };
158
-
159
- return (
160
- <>
161
- <SlotsContainer
162
- title={itemContainer.name || 'Container'}
163
- onClose={onClose}
164
- initialPosition={initialPosition}
165
- scale={scale}
166
- onPositionChangeEnd={onPositionChangeEnd}
167
- onPositionChangeStart={onPositionChangeStart}
168
- >
169
- {type === ItemContainerType.Inventory &&
170
- shortcuts &&
171
- removeShortcut && (
172
- <ShortcutsSetter
173
- setSettingShortcutIndex={setSettingShortcutIndex}
174
- settingShortcutIndex={settingShortcutIndex}
175
- shortcuts={shortcuts}
176
- removeShortcut={removeShortcut}
177
- atlasIMG={atlasIMG}
178
- atlasJSON={atlasJSON}
179
- />
180
- )}
181
- <ItemsContainer className="item-container-body">
182
- {onRenderSlots()}
183
- </ItemsContainer>
184
- </SlotsContainer>
185
- {quantitySelect.isOpen && (
186
- <ModalPortal>
187
- <QuantitySelectorContainer>
188
- <ItemQuantitySelector
189
- quantity={quantitySelect.maxQuantity}
190
- onConfirm={quantity => {
191
- quantitySelect.callback(quantity);
192
- setQuantitySelect({
193
- isOpen: false,
194
- maxQuantity: 1,
195
- callback: () => {},
196
- });
197
- }}
198
- onClose={() => {
199
- quantitySelect.callback(-1);
200
- setQuantitySelect({
201
- isOpen: false,
202
- maxQuantity: 1,
203
- callback: () => {},
204
- });
205
- }}
206
- />
207
- </QuantitySelectorContainer>
208
- </ModalPortal>
209
- )}
210
- </>
211
- );
212
- };
213
-
214
- const ItemsContainer = styled.div`
215
- display: flex;
216
- justify-content: center;
217
- flex-wrap: wrap;
218
- `;
219
-
220
- const QuantitySelectorContainer = styled.div`
221
- position: absolute;
222
- top: 0;
223
- left: 0;
224
- width: 100vw;
225
- height: 100vh;
226
- z-index: 100;
227
- display: flex;
228
- justify-content: center;
229
- align-items: center;
230
- background-color: rgba(0, 0, 0, 0.5);
231
- `;
1
+ import {
2
+ IEquipmentSet,
3
+ IItem,
4
+ IItemContainer,
5
+ IShortcut,
6
+ ItemContainerType,
7
+ ItemType,
8
+ } from '@rpg-engine/shared';
9
+ import React, { useState } from 'react';
10
+ import styled from 'styled-components';
11
+ import { SlotsContainer } from '../../Abstractions/SlotsContainer';
12
+ import { ItemQuantitySelector } from './ItemQuantitySelector';
13
+
14
+ import { IPosition } from '../../../types/eventTypes';
15
+ import ModalPortal from '../../Abstractions/ModalPortal';
16
+ import { ShortcutsSetter } from '../../Shortcuts/ShortcutsSetter';
17
+ import { ItemSlot } from './ItemSlot';
18
+
19
+ export interface IItemContainerProps {
20
+ itemContainer: IItemContainer;
21
+ onClose?: () => void;
22
+ onItemClick?: (
23
+ item: IItem,
24
+ ItemType: IItem['type'],
25
+ itemContainerType: ItemContainerType | null
26
+ ) => void;
27
+ onItemDragStart?: (
28
+ item: IItem,
29
+ slotIndex: number,
30
+ itemContainerType: ItemContainerType | null
31
+ ) => void;
32
+ onItemDragEnd?: (quantity?: number) => void;
33
+ onOutsideDrop?: (item: IItem, position: IPosition) => void;
34
+ onItemPlaceDrop?: (
35
+ item: IItem | null,
36
+ slotIndex: number,
37
+ itemContainerType: ItemContainerType | null
38
+ ) => void;
39
+ scale?: number;
40
+ checkIfItemCanBeMoved: () => boolean;
41
+ checkIfItemShouldDragEnd?: () => boolean;
42
+ onMouseOver?: (e: any, slotIndex: number, item: IItem | null) => void;
43
+ onSelected?: (optionId: string, item: IItem) => void;
44
+ type: ItemContainerType;
45
+ atlasJSON: any;
46
+ atlasIMG: any;
47
+ disableContextMenu?: boolean;
48
+ initialPosition?: { x: number; y: number };
49
+ shortcuts?: IShortcut[];
50
+ setItemShortcut?: (key: string, index: number) => void;
51
+ removeShortcut?: (index: number) => void;
52
+ equipmentSet?: IEquipmentSet | null;
53
+ isDepotSystem?: boolean;
54
+ onPositionChangeEnd?: (position: IPosition) => void;
55
+ onPositionChangeStart?: (position: IPosition) => void;
56
+ }
57
+
58
+ export const ItemContainer: React.FC<IItemContainerProps> = ({
59
+ itemContainer,
60
+ onClose,
61
+ onMouseOver,
62
+ onSelected,
63
+ onItemClick,
64
+ type,
65
+ atlasJSON,
66
+ atlasIMG,
67
+ disableContextMenu = false,
68
+ onItemDragEnd,
69
+ onItemDragStart,
70
+ onItemPlaceDrop,
71
+ onOutsideDrop,
72
+ checkIfItemCanBeMoved,
73
+ initialPosition,
74
+ checkIfItemShouldDragEnd,
75
+ scale,
76
+ shortcuts,
77
+ setItemShortcut,
78
+ removeShortcut,
79
+ equipmentSet,
80
+ isDepotSystem,
81
+ onPositionChangeEnd,
82
+ onPositionChangeStart,
83
+ }) => {
84
+ const [quantitySelect, setQuantitySelect] = useState({
85
+ isOpen: false,
86
+ maxQuantity: 1,
87
+ callback: (_quantity: number) => {},
88
+ });
89
+ const [settingShortcutIndex, setSettingShortcutIndex] = useState(-1);
90
+
91
+ const handleSetShortcut = (item: IItem, index: number) => {
92
+ if (item.type === ItemType.Consumable || item.type === ItemType.Tool) {
93
+ setItemShortcut?.(item.key, index);
94
+ }
95
+ };
96
+
97
+ const onRenderSlots = () => {
98
+ const slots = [];
99
+
100
+ for (let i = 0; i < itemContainer.slotQty; i++) {
101
+ slots.push(
102
+ <ItemSlot
103
+ isContextMenuDisabled={disableContextMenu}
104
+ key={i}
105
+ slotIndex={i}
106
+ item={itemContainer.slots?.[i] || null}
107
+ itemContainerType={type}
108
+ onMouseOver={(event, slotIndex, item) => {
109
+ if (onMouseOver) onMouseOver(event, slotIndex, item);
110
+ }}
111
+ onPointerDown={(itemType, containerType, item) => {
112
+ if (settingShortcutIndex !== -1) {
113
+ setSettingShortcutIndex(-1);
114
+
115
+ handleSetShortcut(item, settingShortcutIndex);
116
+ } else if (onItemClick) onItemClick(item, itemType, containerType);
117
+ }}
118
+ onSelected={(optionId: string, item: IItem) => {
119
+ if (onSelected) onSelected(optionId, item);
120
+ }}
121
+ onDragStart={(item, slotIndex, itemContainerType) => {
122
+ if (onItemDragStart)
123
+ onItemDragStart(item, slotIndex, itemContainerType);
124
+ }}
125
+ onDragEnd={quantity => {
126
+ if (onItemDragEnd) onItemDragEnd(quantity);
127
+ }}
128
+ dragScale={scale}
129
+ checkIfItemCanBeMoved={checkIfItemCanBeMoved}
130
+ checkIfItemShouldDragEnd={checkIfItemShouldDragEnd}
131
+ openQuantitySelector={(maxQuantity, callback) => {
132
+ setQuantitySelect({
133
+ isOpen: true,
134
+ maxQuantity,
135
+ callback,
136
+ });
137
+ }}
138
+ onPlaceDrop={(item, slotIndex, itemContainerType) => {
139
+ if (onItemPlaceDrop)
140
+ onItemPlaceDrop(item, slotIndex, itemContainerType);
141
+ }}
142
+ onOutsideDrop={(item, position) => {
143
+ if (onOutsideDrop) onOutsideDrop(item, position);
144
+ }}
145
+ atlasIMG={atlasIMG}
146
+ atlasJSON={atlasJSON}
147
+ isSelectingShortcut={settingShortcutIndex !== -1}
148
+ equipmentSet={equipmentSet}
149
+ setItemShortcut={
150
+ type === ItemContainerType.Inventory ? handleSetShortcut : undefined
151
+ }
152
+ isDepotSystem={isDepotSystem}
153
+ />
154
+ );
155
+ }
156
+ return slots;
157
+ };
158
+
159
+ return (
160
+ <>
161
+ <SlotsContainer
162
+ title={itemContainer.name || 'Container'}
163
+ onClose={onClose}
164
+ initialPosition={initialPosition}
165
+ scale={scale}
166
+ onPositionChangeEnd={onPositionChangeEnd}
167
+ onPositionChangeStart={onPositionChangeStart}
168
+ >
169
+ {type === ItemContainerType.Inventory &&
170
+ shortcuts &&
171
+ removeShortcut && (
172
+ <ShortcutsSetter
173
+ setSettingShortcutIndex={setSettingShortcutIndex}
174
+ settingShortcutIndex={settingShortcutIndex}
175
+ shortcuts={shortcuts}
176
+ removeShortcut={removeShortcut}
177
+ atlasIMG={atlasIMG}
178
+ atlasJSON={atlasJSON}
179
+ />
180
+ )}
181
+ <ItemsContainer className="item-container-body">
182
+ {onRenderSlots()}
183
+ </ItemsContainer>
184
+ </SlotsContainer>
185
+ {quantitySelect.isOpen && (
186
+ <ModalPortal>
187
+ <QuantitySelectorContainer>
188
+ <ItemQuantitySelector
189
+ quantity={quantitySelect.maxQuantity}
190
+ onConfirm={quantity => {
191
+ quantitySelect.callback(quantity);
192
+ setQuantitySelect({
193
+ isOpen: false,
194
+ maxQuantity: 1,
195
+ callback: () => {},
196
+ });
197
+ }}
198
+ onClose={() => {
199
+ quantitySelect.callback(-1);
200
+ setQuantitySelect({
201
+ isOpen: false,
202
+ maxQuantity: 1,
203
+ callback: () => {},
204
+ });
205
+ }}
206
+ />
207
+ </QuantitySelectorContainer>
208
+ </ModalPortal>
209
+ )}
210
+ </>
211
+ );
212
+ };
213
+
214
+ const ItemsContainer = styled.div`
215
+ display: flex;
216
+ justify-content: center;
217
+ flex-wrap: wrap;
218
+ `;
219
+
220
+ const QuantitySelectorContainer = styled.div`
221
+ position: absolute;
222
+ top: 0;
223
+ left: 0;
224
+ width: 100vw;
225
+ height: 100vh;
226
+ z-index: 100;
227
+ display: flex;
228
+ justify-content: center;
229
+ align-items: center;
230
+ background-color: rgba(0, 0, 0, 0.5);
231
+ `;
@@ -1,6 +1,6 @@
1
- export enum SlotContainerType {
2
- INVENTORY = 'Inventory',
3
- EQUIPMENT_SET = 'EquipmentSet',
4
- LOOT = 'Loot',
5
- MAP_CONTAINER = 'Map-Container',
6
- }
1
+ export enum SlotContainerType {
2
+ INVENTORY = 'Inventory',
3
+ EQUIPMENT_SET = 'EquipmentSet',
4
+ LOOT = 'Loot',
5
+ MAP_CONTAINER = 'Map-Container',
6
+ }