@rpg-engine/long-bow 0.3.77 → 0.3.78

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (160) hide show
  1. package/LICENSE +20 -20
  2. package/README.md +181 -181
  3. package/dist/components/CraftBook/CraftBook.d.ts +3 -1
  4. package/dist/components/Item/Cards/ItemInfo.d.ts +10 -0
  5. package/dist/components/Item/Cards/ItemInfoDisplay.d.ts +10 -0
  6. package/dist/components/Item/Cards/ItemInfoWrapper.d.ts +12 -0
  7. package/dist/components/Item/Cards/ItemTooltip.d.ts +7 -4
  8. package/dist/components/Item/Cards/MobileItemTooltip.d.ts +18 -0
  9. package/dist/components/Item/Inventory/ItemContainer.d.ts +2 -1
  10. package/dist/components/Item/Inventory/ItemSlot.d.ts +4 -1
  11. package/dist/components/TradingMenu/TradingItemRow.d.ts +3 -1
  12. package/dist/components/TradingMenu/TradingMenu.d.ts +6 -4
  13. package/dist/components/shared/SpriteFromAtlas.d.ts +1 -0
  14. package/dist/long-bow.cjs.development.js +1404 -1009
  15. package/dist/long-bow.cjs.development.js.map +1 -1
  16. package/dist/long-bow.cjs.production.min.js +1 -1
  17. package/dist/long-bow.cjs.production.min.js.map +1 -1
  18. package/dist/long-bow.esm.js +1406 -1013
  19. package/dist/long-bow.esm.js.map +1 -1
  20. package/dist/stories/ItemInfoDisplay.stories.d.ts +8 -0
  21. package/dist/stories/TradingMenu.stories.d.ts +2 -2
  22. package/package.json +100 -100
  23. package/src/components/Abstractions/SlotsContainer.tsx +45 -45
  24. package/src/components/Arrow/SelectArrow.tsx +69 -69
  25. package/src/components/Arrow/img/arrow01-left-clicked.png +0 -0
  26. package/src/components/Arrow/img/arrow01-left.png +0 -0
  27. package/src/components/Arrow/img/arrow01-right-clicked.png +0 -0
  28. package/src/components/Arrow/img/arrow01-right.png +0 -0
  29. package/src/components/Arrow/img/arrow02-left-clicked.png +0 -0
  30. package/src/components/Arrow/img/arrow02-left.png +0 -0
  31. package/src/components/Arrow/img/arrow02-right-clicked.png +0 -0
  32. package/src/components/Arrow/img/arrow02-right.png +0 -0
  33. package/src/components/Button.tsx +40 -40
  34. package/src/components/Character/CharacterSelection.tsx +96 -96
  35. package/src/components/CharacterStatus/CharacterStatus.tsx +120 -120
  36. package/src/components/Chat/Chat.tsx +195 -195
  37. package/src/components/Chatdeprecated/ChatDeprecated.tsx +198 -198
  38. package/src/components/CheckButton.tsx +65 -65
  39. package/src/components/CircularController/CircularController.tsx +248 -248
  40. package/src/components/CraftBook/CraftBook.tsx +240 -227
  41. package/src/components/CraftBook/MockItems.ts +77 -251
  42. package/src/components/DraggableContainer.tsx +153 -153
  43. package/src/components/Dropdown.tsx +90 -90
  44. package/src/components/DropdownSelectorContainer.tsx +42 -42
  45. package/src/components/Equipment/EquipmentSet.tsx +190 -190
  46. package/src/components/HistoryDialog.tsx +104 -104
  47. package/src/components/Input.tsx +15 -15
  48. package/src/components/Item/Cards/ItemInfo.tsx +252 -0
  49. package/src/components/Item/Cards/ItemInfoDisplay.tsx +128 -0
  50. package/src/components/Item/Cards/ItemInfoWrapper.tsx +62 -0
  51. package/src/components/Item/Cards/ItemTooltip.tsx +85 -33
  52. package/src/components/Item/Cards/MobileItemTooltip.tsx +134 -0
  53. package/src/components/Item/Inventory/ErrorBoundary.tsx +42 -42
  54. package/src/components/Item/Inventory/ItemContainer.tsx +214 -210
  55. package/src/components/Item/Inventory/ItemContainerTypes.ts +6 -6
  56. package/src/components/Item/Inventory/ItemQuantitySelector.tsx +138 -138
  57. package/src/components/Item/Inventory/ItemSlot.tsx +540 -501
  58. package/src/components/Item/Inventory/itemContainerHelper.ts +156 -156
  59. package/src/components/ListMenu.tsx +63 -63
  60. package/src/components/Multitab/Tab.tsx +66 -66
  61. package/src/components/Multitab/TabBody.tsx +13 -13
  62. package/src/components/Multitab/TabsContainer.tsx +97 -97
  63. package/src/components/NPCDialog/NPCDialog.tsx +121 -121
  64. package/src/components/NPCDialog/NPCDialogText.tsx +113 -113
  65. package/src/components/NPCDialog/NPCMultiDialog.tsx +159 -159
  66. package/src/components/NPCDialog/QuestionDialog/QuestionDialog.tsx +237 -237
  67. package/src/components/ProgressBar.tsx +92 -92
  68. package/src/components/PropertySelect/PropertySelect.tsx +106 -106
  69. package/src/components/QuestInfo/QuestInfo.tsx +230 -230
  70. package/src/components/QuestList.tsx +129 -129
  71. package/src/components/RPGUIContainer.tsx +47 -47
  72. package/src/components/RPGUIForceRenderStart.tsx +45 -45
  73. package/src/components/RPGUIRoot.tsx +14 -14
  74. package/src/components/RadioButton.tsx +53 -53
  75. package/src/components/RadioInput/RadioButton.tsx +96 -96
  76. package/src/components/RadioInput/RadioInput.tsx +102 -102
  77. package/src/components/RadioInput/instruments.ts +15 -15
  78. package/src/components/RangeSlider.tsx +78 -78
  79. package/src/components/RelativeListMenu.tsx +83 -83
  80. package/src/components/ScrollList.tsx +79 -79
  81. package/src/components/Shortcuts/Shortcuts.tsx +151 -151
  82. package/src/components/Shortcuts/ShortcutsSetter.tsx +132 -132
  83. package/src/components/Shortcuts/SingleShortcut.ts +62 -62
  84. package/src/components/SimpleProgressBar.tsx +62 -62
  85. package/src/components/SkillProgressBar.tsx +133 -133
  86. package/src/components/SkillsContainer.tsx +200 -200
  87. package/src/components/Spellbook/Spell.tsx +201 -201
  88. package/src/components/Spellbook/Spellbook.tsx +150 -150
  89. package/src/components/Spellbook/constants.ts +8 -8
  90. package/src/components/Spellbook/mockSpells.ts +60 -60
  91. package/src/components/StaticBook/StaticBook.tsx +103 -103
  92. package/src/components/TextArea.tsx +11 -11
  93. package/src/components/TimeWidget/DayNightPeriod/DayNightPeriod.tsx +35 -35
  94. package/src/components/TimeWidget/TimeWidget.tsx +63 -63
  95. package/src/components/TradingMenu/TradingItemRow.tsx +198 -181
  96. package/src/components/TradingMenu/TradingMenu.tsx +215 -203
  97. package/src/components/TradingMenu/items.mock.ts +48 -96
  98. package/src/components/Truncate.tsx +25 -25
  99. package/src/components/itemSelector/ItemSelector.tsx +136 -136
  100. package/src/components/shared/Column.tsx +16 -16
  101. package/src/components/shared/Ellipsis.tsx +65 -65
  102. package/src/components/shared/SpriteFromAtlas.tsx +104 -102
  103. package/src/components/typography/DynamicText.tsx +49 -49
  104. package/src/constants/uiColors.ts +20 -20
  105. package/src/constants/uiDevices.ts +3 -3
  106. package/src/constants/uiFonts.ts +12 -12
  107. package/src/hooks/useEventListener.ts +21 -21
  108. package/src/hooks/useOutsideAlerter.ts +25 -25
  109. package/src/index.tsx +40 -40
  110. package/src/libs/StringHelpers.ts +3 -3
  111. package/src/mocks/atlas/entities/entities.json +20215 -20215
  112. package/src/mocks/atlas/icons/icons.json +735 -735
  113. package/src/mocks/atlas/items/items.json +12086 -12086
  114. package/src/mocks/equipmentSet.mocks.ts +391 -393
  115. package/src/mocks/itemContainer.mocks.ts +563 -562
  116. package/src/mocks/skills.mocks.ts +128 -128
  117. package/src/stories/Arrow.stories.tsx +26 -26
  118. package/src/stories/Button.stories.tsx +36 -36
  119. package/src/stories/CharacterSelection.stories.tsx +45 -45
  120. package/src/stories/CharacterStatus.stories.tsx +29 -29
  121. package/src/stories/Chat.stories.tsx +187 -187
  122. package/src/stories/ChatDeprecated.stories.tsx +170 -170
  123. package/src/stories/CheckButton.stories.tsx +48 -48
  124. package/src/stories/CircullarController.stories.tsx +37 -37
  125. package/src/stories/CraftBook.stories.tsx +42 -40
  126. package/src/stories/DayNightPeriod.stories.tsx +27 -27
  127. package/src/stories/DraggableContainer.stories.tsx +28 -28
  128. package/src/stories/Dropdown.stories.tsx +46 -46
  129. package/src/stories/DropdownSelectorContainer.stories.tsx +41 -41
  130. package/src/stories/EquipmentSet.stories.tsx +65 -65
  131. package/src/stories/HistoryDialog.stories.tsx +61 -61
  132. package/src/stories/ItemContainer.stories.tsx +200 -198
  133. package/src/stories/ItemInfoDisplay.stories.tsx +33 -0
  134. package/src/stories/ItemQuantitySelector.stories.tsx +26 -26
  135. package/src/stories/ItemSelector.stories.tsx +77 -77
  136. package/src/stories/ItemTradingComponent.stories.tsx +35 -35
  137. package/src/stories/ListMenu.stories.tsx +56 -56
  138. package/src/stories/Multitab.stories.tsx +51 -51
  139. package/src/stories/NPCDialog.stories.tsx +130 -130
  140. package/src/stories/NPCMultiDialog.stories.tsx +71 -71
  141. package/src/stories/ProgressBar.stories.tsx +23 -23
  142. package/src/stories/PropertySelect.stories.tsx +40 -40
  143. package/src/stories/QuestInfo.stories.tsx +107 -107
  144. package/src/stories/QuestList.stories.tsx +82 -82
  145. package/src/stories/RPGUIContainers.stories.tsx +42 -42
  146. package/src/stories/RadioButton.stories.tsx +49 -49
  147. package/src/stories/RadioInput.stories.tsx +34 -34
  148. package/src/stories/RangeSlider.stories.tsx +64 -64
  149. package/src/stories/ScrollList.stories.tsx +85 -85
  150. package/src/stories/Shortcuts.stories.tsx +39 -39
  151. package/src/stories/SimpleProgressBar.stories.tsx +22 -22
  152. package/src/stories/SkillProgressBar.stories.tsx +34 -34
  153. package/src/stories/SkillsContainer.stories.tsx +35 -35
  154. package/src/stories/Spellbook.stories.tsx +104 -104
  155. package/src/stories/StaticBook.stories.tsx +32 -32
  156. package/src/stories/Text.stories.tsx +42 -42
  157. package/src/stories/TimeWidget.stories.tsx +27 -27
  158. package/src/stories/TradingMenu.stories.tsx +47 -45
  159. package/src/types/eventTypes.ts +4 -4
  160. package/src/types/index.d.ts +2 -2
@@ -1,90 +1,90 @@
1
- import React, { useEffect, useState } from 'react';
2
- import styled from 'styled-components';
3
- import { v4 as uuidv4 } from 'uuid';
4
-
5
- export interface IOptionsProps {
6
- id: number;
7
- value: string;
8
- option: string;
9
- }
10
-
11
- export interface IDropdownProps {
12
- options: IOptionsProps[];
13
- width?: string;
14
- onChange: (value: string) => void;
15
- }
16
-
17
- export const Dropdown: React.FC<IDropdownProps> = ({
18
- options,
19
- width,
20
- onChange,
21
- }) => {
22
- const dropdownId = uuidv4();
23
-
24
- const [selectedValue, setSelectedValue] = useState<string>('');
25
- const [selectedOption, setSelectedOption] = useState<string>('');
26
- const [opened, setOpened] = useState<boolean>(false);
27
-
28
- useEffect(() => {
29
- const firstOption = options[0];
30
-
31
- if (firstOption && !selectedValue) {
32
- setSelectedValue(firstOption.value);
33
- setSelectedOption(firstOption.option);
34
- }
35
- }, [options]);
36
-
37
- useEffect(() => {
38
- if (selectedValue) {
39
- onChange(selectedValue);
40
- }
41
- }, [selectedValue]);
42
-
43
- return (
44
- <Container onMouseLeave={() => setOpened(false)} width={width}>
45
- <DropdownSelect
46
- id={`dropdown-${dropdownId}`}
47
- className="rpgui-dropdown-imp rpgui-dropdown-imp-header"
48
- onPointerDown={() => setOpened(prev => !prev)}
49
- >
50
- <label>▼</label> {selectedOption}
51
- </DropdownSelect>
52
-
53
- <DropdownOptions className="rpgui-dropdown-imp" opened={opened}>
54
- {options.map(option => {
55
- return (
56
- <li
57
- key={option.id}
58
- onPointerDown={() => {
59
- setSelectedValue(option.value);
60
- setSelectedOption(option.option);
61
- setOpened(false);
62
- }}
63
- >
64
- {option.option}
65
- </li>
66
- );
67
- })}
68
- </DropdownOptions>
69
- </Container>
70
- );
71
- };
72
-
73
- const Container = styled.div<{ width: string | undefined }>`
74
- position: relative;
75
- width: ${props => props.width || '100%'};
76
- `;
77
-
78
- const DropdownSelect = styled.p`
79
- width: 100%;
80
- box-sizing: border-box;
81
- `;
82
-
83
- const DropdownOptions = styled.ul<{
84
- opened: boolean;
85
- }>`
86
- position: absolute;
87
- width: 100%;
88
- display: ${props => (props.opened ? 'block' : 'none')};
89
- box-sizing: border-box;
90
- `;
1
+ import React, { useEffect, useState } from 'react';
2
+ import styled from 'styled-components';
3
+ import { v4 as uuidv4 } from 'uuid';
4
+
5
+ export interface IOptionsProps {
6
+ id: number;
7
+ value: string;
8
+ option: string;
9
+ }
10
+
11
+ export interface IDropdownProps {
12
+ options: IOptionsProps[];
13
+ width?: string;
14
+ onChange: (value: string) => void;
15
+ }
16
+
17
+ export const Dropdown: React.FC<IDropdownProps> = ({
18
+ options,
19
+ width,
20
+ onChange,
21
+ }) => {
22
+ const dropdownId = uuidv4();
23
+
24
+ const [selectedValue, setSelectedValue] = useState<string>('');
25
+ const [selectedOption, setSelectedOption] = useState<string>('');
26
+ const [opened, setOpened] = useState<boolean>(false);
27
+
28
+ useEffect(() => {
29
+ const firstOption = options[0];
30
+
31
+ if (firstOption && !selectedValue) {
32
+ setSelectedValue(firstOption.value);
33
+ setSelectedOption(firstOption.option);
34
+ }
35
+ }, [options]);
36
+
37
+ useEffect(() => {
38
+ if (selectedValue) {
39
+ onChange(selectedValue);
40
+ }
41
+ }, [selectedValue]);
42
+
43
+ return (
44
+ <Container onMouseLeave={() => setOpened(false)} width={width}>
45
+ <DropdownSelect
46
+ id={`dropdown-${dropdownId}`}
47
+ className="rpgui-dropdown-imp rpgui-dropdown-imp-header"
48
+ onPointerDown={() => setOpened(prev => !prev)}
49
+ >
50
+ <label>▼</label> {selectedOption}
51
+ </DropdownSelect>
52
+
53
+ <DropdownOptions className="rpgui-dropdown-imp" opened={opened}>
54
+ {options.map(option => {
55
+ return (
56
+ <li
57
+ key={option.id}
58
+ onPointerDown={() => {
59
+ setSelectedValue(option.value);
60
+ setSelectedOption(option.option);
61
+ setOpened(false);
62
+ }}
63
+ >
64
+ {option.option}
65
+ </li>
66
+ );
67
+ })}
68
+ </DropdownOptions>
69
+ </Container>
70
+ );
71
+ };
72
+
73
+ const Container = styled.div<{ width: string | undefined }>`
74
+ position: relative;
75
+ width: ${props => props.width || '100%'};
76
+ `;
77
+
78
+ const DropdownSelect = styled.p`
79
+ width: 100%;
80
+ box-sizing: border-box;
81
+ `;
82
+
83
+ const DropdownOptions = styled.ul<{
84
+ opened: boolean;
85
+ }>`
86
+ position: absolute;
87
+ width: 100%;
88
+ display: ${props => (props.opened ? 'block' : 'none')};
89
+ box-sizing: border-box;
90
+ `;
@@ -1,42 +1,42 @@
1
- import React from 'react';
2
- import styled from 'styled-components';
3
- import { uiFonts } from '../constants/uiFonts';
4
- import { Dropdown } from './Dropdown';
5
-
6
- interface IDropdownSelectorOption {
7
- id: string;
8
- name: string;
9
- }
10
-
11
- export interface IDropdownSelectorContainer {
12
- onChange: (id: string) => void;
13
- options: IDropdownSelectorOption[];
14
- details?: string;
15
- title: string;
16
- }
17
-
18
- export const DropdownSelectorContainer: React.FC<IDropdownSelectorContainer> = ({
19
- title,
20
- onChange,
21
- options,
22
- details,
23
- }) => {
24
- return (
25
- <div>
26
- <p>{title}</p>
27
- <Dropdown
28
- options={options.map((option, index) => ({
29
- option: option.name,
30
- value: option.id,
31
- id: index,
32
- }))}
33
- onChange={onChange}
34
- />
35
- <Details>{details}</Details>
36
- </div>
37
- );
38
- };
39
-
40
- const Details = styled.p`
41
- font-size: ${uiFonts.size.xsmall} !important;
42
- `;
1
+ import React from 'react';
2
+ import styled from 'styled-components';
3
+ import { uiFonts } from '../constants/uiFonts';
4
+ import { Dropdown } from './Dropdown';
5
+
6
+ interface IDropdownSelectorOption {
7
+ id: string;
8
+ name: string;
9
+ }
10
+
11
+ export interface IDropdownSelectorContainer {
12
+ onChange: (id: string) => void;
13
+ options: IDropdownSelectorOption[];
14
+ details?: string;
15
+ title: string;
16
+ }
17
+
18
+ export const DropdownSelectorContainer: React.FC<IDropdownSelectorContainer> = ({
19
+ title,
20
+ onChange,
21
+ options,
22
+ details,
23
+ }) => {
24
+ return (
25
+ <div>
26
+ <p>{title}</p>
27
+ <Dropdown
28
+ options={options.map((option, index) => ({
29
+ option: option.name,
30
+ value: option.id,
31
+ id: index,
32
+ }))}
33
+ onChange={onChange}
34
+ />
35
+ <Details>{details}</Details>
36
+ </div>
37
+ );
38
+ };
39
+
40
+ const Details = styled.p`
41
+ font-size: ${uiFonts.size.xsmall} !important;
42
+ `;
@@ -1,190 +1,190 @@
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
- dragScale?: 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
- }
46
-
47
- export const EquipmentSet: React.FC<IEquipmentSetProps> = ({
48
- equipmentSet,
49
- onClose,
50
- onMouseOver,
51
- onSelected,
52
- onItemClick,
53
- atlasIMG,
54
- atlasJSON,
55
- onItemDragEnd,
56
- onItemDragStart,
57
- onItemPlaceDrop,
58
- onItemOutsideDrop,
59
- checkIfItemCanBeMoved,
60
- checkIfItemShouldDragEnd,
61
- dragScale,
62
- }) => {
63
- const {
64
- neck,
65
- leftHand,
66
- ring,
67
- head,
68
- armor,
69
- legs,
70
- boot,
71
- inventory,
72
- rightHand,
73
- accessory,
74
- } = equipmentSet;
75
-
76
- const equipmentData = [
77
- neck,
78
- leftHand,
79
- ring,
80
- head,
81
- armor,
82
- legs,
83
- boot,
84
- inventory,
85
- rightHand,
86
- accessory,
87
- ];
88
-
89
- const equipmentMaskSlots = [
90
- ItemSlotType.Neck,
91
- ItemSlotType.LeftHand,
92
- ItemSlotType.Ring,
93
- ItemSlotType.Head,
94
- ItemSlotType.Torso,
95
- ItemSlotType.Legs,
96
- ItemSlotType.Feet,
97
- ItemSlotType.Inventory,
98
- ItemSlotType.RightHand,
99
- ItemSlotType.Accessory,
100
- ];
101
-
102
- const onRenderEquipmentSlotRange = (start: number, end: number) => {
103
- const equipmentRange = equipmentData.slice(start, end);
104
- const slotMaksRange = equipmentMaskSlots.slice(start, end);
105
-
106
- return equipmentRange.map((data, i) => {
107
- const item = data as IItem;
108
- const itemContainer =
109
- (item && (item.itemContainer as IItemContainer)) ?? null;
110
-
111
- return (
112
- <ItemSlot
113
- key={i}
114
- slotIndex={i}
115
- item={item}
116
- itemContainer={itemContainer}
117
- itemContainerType={ItemContainerType.Equipment}
118
- slotSpriteMask={slotMaksRange[i]}
119
- onMouseOver={(event, slotIndex, item) => {
120
- if (onMouseOver) onMouseOver(event, slotIndex, item);
121
- }}
122
- onPointerDown={(itemType, ContainerType) => {
123
- if (onItemClick) onItemClick(itemType, item, ContainerType);
124
- }}
125
- onSelected={(optionId: string) => {
126
- if (onSelected) onSelected(optionId);
127
- }}
128
- onDragStart={(item, slotIndex, itemContainerType) => {
129
- if (!item) {
130
- return;
131
- }
132
-
133
- if (onItemDragStart)
134
- onItemDragStart(item, slotIndex, itemContainerType);
135
- }}
136
- onDragEnd={quantity => {
137
- if (onItemDragEnd) onItemDragEnd(quantity);
138
- }}
139
- dragScale={dragScale}
140
- checkIfItemCanBeMoved={checkIfItemCanBeMoved}
141
- checkIfItemShouldDragEnd={checkIfItemShouldDragEnd}
142
- onPlaceDrop={(item, slotIndex, itemContainerType) => {
143
- if (onItemPlaceDrop)
144
- onItemPlaceDrop(item, slotIndex, itemContainerType);
145
- }}
146
- onOutsideDrop={(item, position) => {
147
- if (onItemOutsideDrop) onItemOutsideDrop(item, position);
148
- }}
149
- atlasIMG={atlasIMG}
150
- atlasJSON={atlasJSON}
151
- />
152
- );
153
- });
154
- };
155
-
156
- return (
157
- <DraggableContainer
158
- title={'Equipments'}
159
- type={RPGUIContainerTypes.Framed}
160
- onCloseButton={() => {
161
- if (onClose) onClose();
162
- }}
163
- width="330px"
164
- cancelDrag=".equipment-container-body"
165
- >
166
- <EquipmentSetContainer className="equipment-container-body">
167
- <EquipmentColumn>{onRenderEquipmentSlotRange(0, 3)}</EquipmentColumn>
168
- <EquipmentColumn>{onRenderEquipmentSlotRange(3, 7)}</EquipmentColumn>
169
- <EquipmentColumn>{onRenderEquipmentSlotRange(7, 10)}</EquipmentColumn>
170
- </EquipmentSetContainer>
171
- </DraggableContainer>
172
- );
173
- };
174
-
175
- const EquipmentSetContainer = styled.div`
176
- width: inherit;
177
- display: flex;
178
- justify-content: center;
179
- flex-wrap: wrap;
180
- flex-direction: row;
181
- touch-action: none;
182
- `;
183
-
184
- const EquipmentColumn = styled.div`
185
- display: flex;
186
- justify-content: center;
187
- flex-wrap: wrap;
188
- flex-direction: column;
189
- touch-action: none;
190
- `;
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
+ dragScale?: 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
+ }
46
+
47
+ export const EquipmentSet: React.FC<IEquipmentSetProps> = ({
48
+ equipmentSet,
49
+ onClose,
50
+ onMouseOver,
51
+ onSelected,
52
+ onItemClick,
53
+ atlasIMG,
54
+ atlasJSON,
55
+ onItemDragEnd,
56
+ onItemDragStart,
57
+ onItemPlaceDrop,
58
+ onItemOutsideDrop,
59
+ checkIfItemCanBeMoved,
60
+ checkIfItemShouldDragEnd,
61
+ dragScale,
62
+ }) => {
63
+ const {
64
+ neck,
65
+ leftHand,
66
+ ring,
67
+ head,
68
+ armor,
69
+ legs,
70
+ boot,
71
+ inventory,
72
+ rightHand,
73
+ accessory,
74
+ } = equipmentSet;
75
+
76
+ const equipmentData = [
77
+ neck,
78
+ leftHand,
79
+ ring,
80
+ head,
81
+ armor,
82
+ legs,
83
+ boot,
84
+ inventory,
85
+ rightHand,
86
+ accessory,
87
+ ];
88
+
89
+ const equipmentMaskSlots = [
90
+ ItemSlotType.Neck,
91
+ ItemSlotType.LeftHand,
92
+ ItemSlotType.Ring,
93
+ ItemSlotType.Head,
94
+ ItemSlotType.Torso,
95
+ ItemSlotType.Legs,
96
+ ItemSlotType.Feet,
97
+ ItemSlotType.Inventory,
98
+ ItemSlotType.RightHand,
99
+ ItemSlotType.Accessory,
100
+ ];
101
+
102
+ const onRenderEquipmentSlotRange = (start: number, end: number) => {
103
+ const equipmentRange = equipmentData.slice(start, end);
104
+ const slotMaksRange = equipmentMaskSlots.slice(start, end);
105
+
106
+ return equipmentRange.map((data, i) => {
107
+ const item = data as IItem;
108
+ const itemContainer =
109
+ (item && (item.itemContainer as IItemContainer)) ?? null;
110
+
111
+ return (
112
+ <ItemSlot
113
+ key={i}
114
+ slotIndex={i}
115
+ item={item}
116
+ itemContainer={itemContainer}
117
+ itemContainerType={ItemContainerType.Equipment}
118
+ slotSpriteMask={slotMaksRange[i]}
119
+ onMouseOver={(event, slotIndex, item) => {
120
+ if (onMouseOver) onMouseOver(event, slotIndex, item);
121
+ }}
122
+ onPointerDown={(itemType, ContainerType) => {
123
+ if (onItemClick) onItemClick(itemType, item, ContainerType);
124
+ }}
125
+ onSelected={(optionId: string) => {
126
+ if (onSelected) onSelected(optionId);
127
+ }}
128
+ onDragStart={(item, slotIndex, itemContainerType) => {
129
+ if (!item) {
130
+ return;
131
+ }
132
+
133
+ if (onItemDragStart)
134
+ onItemDragStart(item, slotIndex, itemContainerType);
135
+ }}
136
+ onDragEnd={quantity => {
137
+ if (onItemDragEnd) onItemDragEnd(quantity);
138
+ }}
139
+ dragScale={dragScale}
140
+ checkIfItemCanBeMoved={checkIfItemCanBeMoved}
141
+ checkIfItemShouldDragEnd={checkIfItemShouldDragEnd}
142
+ onPlaceDrop={(item, slotIndex, itemContainerType) => {
143
+ if (onItemPlaceDrop)
144
+ onItemPlaceDrop(item, slotIndex, itemContainerType);
145
+ }}
146
+ onOutsideDrop={(item, position) => {
147
+ if (onItemOutsideDrop) onItemOutsideDrop(item, position);
148
+ }}
149
+ atlasIMG={atlasIMG}
150
+ atlasJSON={atlasJSON}
151
+ />
152
+ );
153
+ });
154
+ };
155
+
156
+ return (
157
+ <DraggableContainer
158
+ title={'Equipments'}
159
+ type={RPGUIContainerTypes.Framed}
160
+ onCloseButton={() => {
161
+ if (onClose) onClose();
162
+ }}
163
+ width="330px"
164
+ cancelDrag=".equipment-container-body"
165
+ >
166
+ <EquipmentSetContainer className="equipment-container-body">
167
+ <EquipmentColumn>{onRenderEquipmentSlotRange(0, 3)}</EquipmentColumn>
168
+ <EquipmentColumn>{onRenderEquipmentSlotRange(3, 7)}</EquipmentColumn>
169
+ <EquipmentColumn>{onRenderEquipmentSlotRange(7, 10)}</EquipmentColumn>
170
+ </EquipmentSetContainer>
171
+ </DraggableContainer>
172
+ );
173
+ };
174
+
175
+ const EquipmentSetContainer = styled.div`
176
+ width: inherit;
177
+ display: flex;
178
+ justify-content: center;
179
+ flex-wrap: wrap;
180
+ flex-direction: row;
181
+ touch-action: none;
182
+ `;
183
+
184
+ const EquipmentColumn = styled.div`
185
+ display: flex;
186
+ justify-content: center;
187
+ flex-wrap: wrap;
188
+ flex-direction: column;
189
+ touch-action: none;
190
+ `;