@rpg-engine/long-bow 0.3.46 โ†’ 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,124 +1,124 @@
1
- import { IItem, ItemContainerType, ItemType } from '@rpg-engine/shared';
2
- import { Meta, Story } from '@storybook/react';
3
- import React, { useState } from 'react';
4
- import {
5
- IItemContainerProps,
6
- ItemContainer,
7
- } from '../../src/components/Item/Inventory/ItemContainer';
8
- import { RPGUIRoot } from '../../src/components/RPGUIRoot';
9
- import { itemContainerMock } from '../../src/mocks/itemContainer.mocks';
10
- import atlasJSON from '../mocks/atlas/items/items.json';
11
- import atlasIMG from '../mocks/atlas/items/items.png';
12
-
13
- const meta: Meta = {
14
- title: 'Item Container',
15
- component: ItemContainer,
16
- };
17
-
18
- export default meta;
19
-
20
- const onMouseOver = (_event: any, slotIndex: number, item: IItem | null) => {
21
- if (!item) {
22
- // console.log(`Free at ${slotIndex}` )
23
- return;
24
- }
25
- console.log(`${item.name} at ${slotIndex}`);
26
- };
27
-
28
- const onSelected = (payload: string, item: IItem) => {
29
- console.log('onSelected', payload, item);
30
- };
31
-
32
- const onItemClick = (
33
- item: IItem,
34
- ItemType: ItemType,
35
- itemContainerType: ItemContainerType | null
36
- ) => {
37
- console.log(item, ItemType, itemContainerType, 'was clicked!');
38
- };
39
-
40
- // THIS IS ONLY LONG-BOW EXAMPLE FOR DRAG AND DROP
41
- let dragItem: IItem | null = null;
42
- let dropItem: IItem | null = null;
43
- let allowedToDrop = false;
44
- let dragSlot = -1;
45
- let dropSlot = -1;
46
-
47
- const Template: Story<IItemContainerProps> = () => {
48
- const [itemContainer, setItemContainer] = useState(itemContainerMock);
49
-
50
- return (
51
- <RPGUIRoot>
52
- <ItemContainer
53
- itemContainer={itemContainer}
54
- onClose={() => console.log('closing item container')}
55
- onMouseOver={onMouseOver}
56
- onSelected={onSelected}
57
- onItemClick={onItemClick}
58
- checkIfItemCanBeMoved={() => allowedToDrop}
59
- onItemDragEnd={quantity => {
60
- // THIS IS ONLY LONG-BOW EXAMPLE FOR DRAG AND DROP
61
-
62
- if (quantity === 0) {
63
- setItemContainer({ ...itemContainer });
64
- } else if (allowedToDrop && dropSlot !== -1) {
65
- const newContainer = { ...itemContainer };
66
-
67
- if (quantity && dragItem && dragItem.stackQty) {
68
- newContainer.slots[dropSlot] = {
69
- ...dragItem,
70
- stackQty: quantity + (dropItem?.stackQty || 0),
71
- };
72
-
73
- if (dragItem.stackQty - quantity === 0)
74
- newContainer.slots[dragSlot] = null;
75
- else
76
- newContainer.slots[dragSlot] = {
77
- ...dragItem,
78
- stackQty: dragItem.stackQty - quantity,
79
- };
80
- } else {
81
- newContainer.slots[dropSlot] = dragItem;
82
- newContainer.slots[dragSlot] = null;
83
- }
84
- setTimeout(() => {
85
- setItemContainer(newContainer);
86
- }, 100);
87
- }
88
-
89
- allowedToDrop = false;
90
- dropSlot = -1;
91
- dropItem = null;
92
- dragItem = null;
93
- }}
94
- onItemDragStart={(item, slotIndex) => {
95
- dragItem = item;
96
- dragSlot = slotIndex;
97
- }}
98
- onItemPlaceDrop={(item, slotIndex) => {
99
- // THIS IS ONLY LONG-BOW EXAMPLE FOR DRAG AND DROP
100
-
101
- if (
102
- !item ||
103
- (dragItem?.key === item?.key && dragSlot !== slotIndex)
104
- ) {
105
- console.log('allow');
106
- allowedToDrop = true;
107
- dropSlot = slotIndex;
108
- dropItem = item ? item : null;
109
- } else {
110
- allowedToDrop = false;
111
- dropSlot = -1;
112
- dropItem = null;
113
- }
114
- }}
115
- onOutsideDrop={(item, pos) => console.log('drop', item, pos)}
116
- type={ItemContainerType.Inventory}
117
- atlasIMG={atlasIMG}
118
- atlasJSON={atlasJSON}
119
- />
120
- </RPGUIRoot>
121
- );
122
- };
123
-
124
- export const Default = Template.bind({});
1
+ import { IItem, ItemContainerType, ItemType } from '@rpg-engine/shared';
2
+ import { Meta, Story } from '@storybook/react';
3
+ import React, { useState } from 'react';
4
+ import {
5
+ IItemContainerProps,
6
+ ItemContainer,
7
+ } from '../../src/components/Item/Inventory/ItemContainer';
8
+ import { RPGUIRoot } from '../../src/components/RPGUIRoot';
9
+ import { itemContainerMock } from '../../src/mocks/itemContainer.mocks';
10
+ import atlasJSON from '../mocks/atlas/items/items.json';
11
+ import atlasIMG from '../mocks/atlas/items/items.png';
12
+
13
+ const meta: Meta = {
14
+ title: 'Item Container',
15
+ component: ItemContainer,
16
+ };
17
+
18
+ export default meta;
19
+
20
+ const onMouseOver = (_event: any, slotIndex: number, item: IItem | null) => {
21
+ if (!item) {
22
+ // console.log(`Free at ${slotIndex}` )
23
+ return;
24
+ }
25
+ console.log(`${item.name} at ${slotIndex}`);
26
+ };
27
+
28
+ const onSelected = (payload: string, item: IItem) => {
29
+ console.log('onSelected', payload, item);
30
+ };
31
+
32
+ const onItemClick = (
33
+ item: IItem,
34
+ ItemType: ItemType,
35
+ itemContainerType: ItemContainerType | null
36
+ ) => {
37
+ console.log(item, ItemType, itemContainerType, 'was clicked!');
38
+ };
39
+
40
+ // THIS IS ONLY LONG-BOW EXAMPLE FOR DRAG AND DROP
41
+ let dragItem: IItem | null = null;
42
+ let dropItem: IItem | null = null;
43
+ let allowedToDrop = false;
44
+ let dragSlot = -1;
45
+ let dropSlot = -1;
46
+
47
+ const Template: Story<IItemContainerProps> = () => {
48
+ const [itemContainer, setItemContainer] = useState(itemContainerMock);
49
+
50
+ return (
51
+ <RPGUIRoot>
52
+ <ItemContainer
53
+ itemContainer={itemContainer}
54
+ onClose={() => console.log('closing item container')}
55
+ onMouseOver={onMouseOver}
56
+ onSelected={onSelected}
57
+ onItemClick={onItemClick}
58
+ checkIfItemCanBeMoved={() => allowedToDrop}
59
+ onItemDragEnd={quantity => {
60
+ // THIS IS ONLY LONG-BOW EXAMPLE FOR DRAG AND DROP
61
+
62
+ if (quantity === 0) {
63
+ setItemContainer({ ...itemContainer });
64
+ } else if (allowedToDrop && dropSlot !== -1) {
65
+ const newContainer = { ...itemContainer };
66
+
67
+ if (quantity && dragItem && dragItem.stackQty) {
68
+ newContainer.slots[dropSlot] = {
69
+ ...dragItem,
70
+ stackQty: quantity + (dropItem?.stackQty || 0),
71
+ };
72
+
73
+ if (dragItem.stackQty - quantity === 0)
74
+ newContainer.slots[dragSlot] = null;
75
+ else
76
+ newContainer.slots[dragSlot] = {
77
+ ...dragItem,
78
+ stackQty: dragItem.stackQty - quantity,
79
+ };
80
+ } else {
81
+ newContainer.slots[dropSlot] = dragItem;
82
+ newContainer.slots[dragSlot] = null;
83
+ }
84
+ setTimeout(() => {
85
+ setItemContainer(newContainer);
86
+ }, 100);
87
+ }
88
+
89
+ allowedToDrop = false;
90
+ dropSlot = -1;
91
+ dropItem = null;
92
+ dragItem = null;
93
+ }}
94
+ onItemDragStart={(item, slotIndex) => {
95
+ dragItem = item;
96
+ dragSlot = slotIndex;
97
+ }}
98
+ onItemPlaceDrop={(item, slotIndex) => {
99
+ // THIS IS ONLY LONG-BOW EXAMPLE FOR DRAG AND DROP
100
+
101
+ if (
102
+ !item ||
103
+ (dragItem?.key === item?.key && dragSlot !== slotIndex)
104
+ ) {
105
+ console.log('allow');
106
+ allowedToDrop = true;
107
+ dropSlot = slotIndex;
108
+ dropItem = item ? item : null;
109
+ } else {
110
+ allowedToDrop = false;
111
+ dropSlot = -1;
112
+ dropItem = null;
113
+ }
114
+ }}
115
+ onOutsideDrop={(item, pos) => console.log('drop', item, pos)}
116
+ type={ItemContainerType.Inventory}
117
+ atlasIMG={atlasIMG}
118
+ atlasJSON={atlasJSON}
119
+ />
120
+ </RPGUIRoot>
121
+ );
122
+ };
123
+
124
+ export const Default = Template.bind({});
@@ -1,26 +1,26 @@
1
- import { Meta, Story } from '@storybook/react';
2
- import React from 'react';
3
- import { RPGUIRoot } from '..';
4
- import {
5
- IItemQuantitySelectorProps,
6
- ItemQuantitySelector,
7
- } from '../components/Item/Inventory/ItemQuantitySelector';
8
-
9
- const meta: Meta = {
10
- title: 'Item Quantity Selector',
11
- component: ItemQuantitySelector,
12
- };
13
-
14
- export default meta;
15
-
16
- const Template: Story<IItemQuantitySelectorProps> = args => (
17
- <RPGUIRoot>
18
- <ItemQuantitySelector {...args} />
19
- </RPGUIRoot>
20
- );
21
-
22
- export const Default = Template.bind({});
23
-
24
- Default.args = {
25
- quantity: 10,
26
- };
1
+ import { Meta, Story } from '@storybook/react';
2
+ import React from 'react';
3
+ import { RPGUIRoot } from '..';
4
+ import {
5
+ IItemQuantitySelectorProps,
6
+ ItemQuantitySelector,
7
+ } from '../components/Item/Inventory/ItemQuantitySelector';
8
+
9
+ const meta: Meta = {
10
+ title: 'Item Quantity Selector',
11
+ component: ItemQuantitySelector,
12
+ };
13
+
14
+ export default meta;
15
+
16
+ const Template: Story<IItemQuantitySelectorProps> = args => (
17
+ <RPGUIRoot>
18
+ <ItemQuantitySelector {...args} />
19
+ </RPGUIRoot>
20
+ );
21
+
22
+ export const Default = Template.bind({});
23
+
24
+ Default.args = {
25
+ quantity: 10,
26
+ };
@@ -1,77 +1,77 @@
1
- import { Meta, Story } from '@storybook/react';
2
- import React from 'react';
3
- import { RPGUIRoot } from '..';
4
- import {
5
- IOptionsItemSelectorProps,
6
- ItemSelector,
7
- } from '../components/itemSelector/ItemSelector';
8
- import atlasJSON from '../mocks/atlas/items/items.json';
9
- import atlasIMG from '../mocks/atlas/items/items.png';
10
-
11
- const meta: Meta = {
12
- title: 'Item Selector',
13
- component: ItemSelector,
14
- };
15
-
16
- export default meta;
17
-
18
- const Template: Story = args => (
19
- <RPGUIRoot>
20
- <ItemSelector
21
- atlasIMG={atlasIMG}
22
- atlasJSON={atlasJSON}
23
- options={options}
24
- onSelect={onSelect}
25
- onClose={() => console.log('closing Equipment Set Container')}
26
- {...args}
27
- />
28
- </RPGUIRoot>
29
- );
30
-
31
- export const Default = Template.bind({});
32
-
33
- const onSelect = (value: string): void => {
34
- console.log('Story package', value);
35
- };
36
-
37
- const options: IOptionsItemSelectorProps[] = [
38
- {
39
- name: 'Human',
40
- description: 'Human',
41
- imageKey: 'axes/frost-double-axe.png',
42
- },
43
- {
44
- name: 'Human',
45
- description: 'Human',
46
- imageKey: 'maces/spiked-club.png',
47
- },
48
- {
49
- name: 'Human2',
50
- description: 'Human2',
51
- imageKey: 'axes/frost-double-axe.png',
52
- },
53
- {
54
- name: 'Human3',
55
- description: 'Human3',
56
- imageKey: 'maces/spiked-club.png',
57
- },
58
- {
59
- name: 'Human4',
60
- description: 'Human4',
61
- imageKey: 'axes/frost-double-axe.png',
62
- },
63
- {
64
- name: 'Human5',
65
- description: 'Human5',
66
- imageKey: 'maces/spiked-club.png',
67
- },
68
- {
69
- name: 'Human6',
70
- description: 'Human6',
71
- imageKey: 'axes/frost-double-axe.png',
72
- },
73
- ];
74
-
75
- Default.args = {
76
- options,
77
- };
1
+ import { Meta, Story } from '@storybook/react';
2
+ import React from 'react';
3
+ import { RPGUIRoot } from '..';
4
+ import {
5
+ IOptionsItemSelectorProps,
6
+ ItemSelector,
7
+ } from '../components/itemSelector/ItemSelector';
8
+ import atlasJSON from '../mocks/atlas/items/items.json';
9
+ import atlasIMG from '../mocks/atlas/items/items.png';
10
+
11
+ const meta: Meta = {
12
+ title: 'Item Selector',
13
+ component: ItemSelector,
14
+ };
15
+
16
+ export default meta;
17
+
18
+ const Template: Story = args => (
19
+ <RPGUIRoot>
20
+ <ItemSelector
21
+ atlasIMG={atlasIMG}
22
+ atlasJSON={atlasJSON}
23
+ options={options}
24
+ onSelect={onSelect}
25
+ onClose={() => console.log('closing Equipment Set Container')}
26
+ {...args}
27
+ />
28
+ </RPGUIRoot>
29
+ );
30
+
31
+ export const Default = Template.bind({});
32
+
33
+ const onSelect = (value: string): void => {
34
+ console.log('Story package', value);
35
+ };
36
+
37
+ const options: IOptionsItemSelectorProps[] = [
38
+ {
39
+ name: 'Human',
40
+ description: 'Human',
41
+ imageKey: 'axes/frost-double-axe.png',
42
+ },
43
+ {
44
+ name: 'Human',
45
+ description: 'Human',
46
+ imageKey: 'maces/spiked-club.png',
47
+ },
48
+ {
49
+ name: 'Human2',
50
+ description: 'Human2',
51
+ imageKey: 'axes/frost-double-axe.png',
52
+ },
53
+ {
54
+ name: 'Human3',
55
+ description: 'Human3',
56
+ imageKey: 'maces/spiked-club.png',
57
+ },
58
+ {
59
+ name: 'Human4',
60
+ description: 'Human4',
61
+ imageKey: 'axes/frost-double-axe.png',
62
+ },
63
+ {
64
+ name: 'Human5',
65
+ description: 'Human5',
66
+ imageKey: 'maces/spiked-club.png',
67
+ },
68
+ {
69
+ name: 'Human6',
70
+ description: 'Human6',
71
+ imageKey: 'axes/frost-double-axe.png',
72
+ },
73
+ ];
74
+
75
+ Default.args = {
76
+ options,
77
+ };
@@ -1,35 +1,35 @@
1
- import { ITradeResponseItem } from '@rpg-engine/shared';
2
- import { Meta } from '@storybook/react';
3
- import React, { useState } from 'react';
4
- import { RPGUIRoot } from '../components/RPGUIRoot';
5
- import { itemMock } from '../components/TradingMenu/items.mock';
6
- import { TradingItemRow } from '../components/TradingMenu/TradingItemRow';
7
- import atlasJSON from '../mocks/atlas/items/items.json';
8
- import atlasIMG from '../mocks/atlas/items/items.png';
9
-
10
- const meta: Meta = {
11
- title: 'Trading Item',
12
- component: TradingItemRow,
13
- };
14
- export default meta;
15
-
16
- export const Default = () => {
17
- const [selectedQty, setSelectedQty] = useState(0);
18
-
19
- const handleOnChange = (item: ITradeResponseItem, qty: number) => {
20
- console.log(item);
21
- setSelectedQty(qty);
22
- };
23
-
24
- return (
25
- <RPGUIRoot>
26
- <TradingItemRow
27
- atlasIMG={atlasIMG}
28
- atlasJSON={atlasJSON}
29
- onQuantityChange={handleOnChange}
30
- selectedQty={selectedQty}
31
- traderItem={itemMock[0]}
32
- />
33
- </RPGUIRoot>
34
- );
35
- };
1
+ import { ITradeResponseItem } from '@rpg-engine/shared';
2
+ import { Meta } from '@storybook/react';
3
+ import React, { useState } from 'react';
4
+ import { RPGUIRoot } from '../components/RPGUIRoot';
5
+ import { itemMock } from '../components/TradingMenu/items.mock';
6
+ import { TradingItemRow } from '../components/TradingMenu/TradingItemRow';
7
+ import atlasJSON from '../mocks/atlas/items/items.json';
8
+ import atlasIMG from '../mocks/atlas/items/items.png';
9
+
10
+ const meta: Meta = {
11
+ title: 'Trading Item',
12
+ component: TradingItemRow,
13
+ };
14
+ export default meta;
15
+
16
+ export const Default = () => {
17
+ const [selectedQty, setSelectedQty] = useState(0);
18
+
19
+ const handleOnChange = (item: ITradeResponseItem, qty: number) => {
20
+ console.log(item);
21
+ setSelectedQty(qty);
22
+ };
23
+
24
+ return (
25
+ <RPGUIRoot>
26
+ <TradingItemRow
27
+ atlasIMG={atlasIMG}
28
+ atlasJSON={atlasJSON}
29
+ onQuantityChange={handleOnChange}
30
+ selectedQty={selectedQty}
31
+ traderItem={itemMock[0]}
32
+ />
33
+ </RPGUIRoot>
34
+ );
35
+ };
@@ -1,56 +1,56 @@
1
- import { Meta, Story } from '@storybook/react';
2
- import React from 'react';
3
- import { IListMenuProps, ListMenu } from '../../src/components/ListMenu';
4
- import { RPGUIRoot } from '../../src/components/RPGUIRoot';
5
-
6
- const meta: Meta = {
7
- /* ๐Ÿ‘‡ The title prop is optional.
8
- * See https://storybook.js.org/docsreact/configure/overview#configure-story-loading
9
- * to learn how to generate automatic titles
10
- */
11
- title: 'List Menu',
12
- component: ListMenu,
13
- argTypes: {},
14
- };
15
-
16
- export default meta;
17
-
18
- //๐Ÿ‘‡ We create a โ€œtemplateโ€ of how args map to rendering "Blacksmith","Merchant","City Guard","Explorer"
19
- const Template: Story<IListMenuProps> = args => (
20
- <RPGUIRoot>
21
- <ListMenu {...args} />
22
- </RPGUIRoot>
23
- );
24
-
25
- export const Default = Template.bind({});
26
-
27
- Default.args = {
28
- // x: 100,
29
- // y: 100,
30
- options: [
31
- {
32
- id: 'blacksmith',
33
- text: 'Huge option added here',
34
- },
35
- {
36
- text: 'Merchant',
37
- id: 'merchant',
38
- },
39
- {
40
- text: 'City Guard',
41
- id: 'city-guard',
42
- },
43
- {
44
- text: 'Explorer',
45
- id: 'explorer',
46
- },
47
- {
48
- text: 'Royalty',
49
- id: 'royalty',
50
- },
51
- {
52
- text: 'Gladiator',
53
- id: 'gladiator',
54
- },
55
- ],
56
- };
1
+ import { Meta, Story } from '@storybook/react';
2
+ import React from 'react';
3
+ import { IListMenuProps, ListMenu } from '../../src/components/ListMenu';
4
+ import { RPGUIRoot } from '../../src/components/RPGUIRoot';
5
+
6
+ const meta: Meta = {
7
+ /* ๐Ÿ‘‡ The title prop is optional.
8
+ * See https://storybook.js.org/docsreact/configure/overview#configure-story-loading
9
+ * to learn how to generate automatic titles
10
+ */
11
+ title: 'List Menu',
12
+ component: ListMenu,
13
+ argTypes: {},
14
+ };
15
+
16
+ export default meta;
17
+
18
+ //๐Ÿ‘‡ We create a โ€œtemplateโ€ of how args map to rendering "Blacksmith","Merchant","City Guard","Explorer"
19
+ const Template: Story<IListMenuProps> = args => (
20
+ <RPGUIRoot>
21
+ <ListMenu {...args} />
22
+ </RPGUIRoot>
23
+ );
24
+
25
+ export const Default = Template.bind({});
26
+
27
+ Default.args = {
28
+ // x: 100,
29
+ // y: 100,
30
+ options: [
31
+ {
32
+ id: 'blacksmith',
33
+ text: 'Huge option added here',
34
+ },
35
+ {
36
+ text: 'Merchant',
37
+ id: 'merchant',
38
+ },
39
+ {
40
+ text: 'City Guard',
41
+ id: 'city-guard',
42
+ },
43
+ {
44
+ text: 'Explorer',
45
+ id: 'explorer',
46
+ },
47
+ {
48
+ text: 'Royalty',
49
+ id: 'royalty',
50
+ },
51
+ {
52
+ text: 'Gladiator',
53
+ id: 'gladiator',
54
+ },
55
+ ],
56
+ };