@rpg-engine/long-bow 0.3.53 → 0.3.55

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/components/Arrow/SelectArrow.d.ts +1 -1
  4. package/dist/components/Button.d.ts +2 -2
  5. package/dist/components/CircularController/CircularController.d.ts +4 -7
  6. package/dist/components/Item/Inventory/ItemContainer.d.ts +1 -4
  7. package/dist/components/Item/Inventory/ItemSlot.d.ts +1 -2
  8. package/dist/components/Multitab/Tab.d.ts +1 -1
  9. package/dist/components/QuestInfo/QuestInfo.d.ts +1 -1
  10. package/dist/components/Spellbook/QuickSpells.d.ts +10 -0
  11. package/dist/components/Spellbook/Spell.d.ts +1 -1
  12. package/dist/components/Spellbook/Spellbook.d.ts +3 -5
  13. package/dist/components/Spellbook/SpellbookShortcuts.d.ts +10 -0
  14. package/dist/components/Spellbook/constants.d.ts +3 -3
  15. package/dist/components/shared/SpriteFromAtlas.d.ts +1 -1
  16. package/dist/index.d.ts +1 -1
  17. package/dist/long-bow.cjs.development.js +734 -914
  18. package/dist/long-bow.cjs.development.js.map +1 -1
  19. package/dist/long-bow.cjs.production.min.js +1 -1
  20. package/dist/long-bow.cjs.production.min.js.map +1 -1
  21. package/dist/long-bow.esm.js +736 -917
  22. package/dist/long-bow.esm.js.map +1 -1
  23. package/dist/stories/{Shortcuts.stories.d.ts → QuickSpells.stories.d.ts} +2 -2
  24. package/package.json +100 -100
  25. package/src/components/Abstractions/SlotsContainer.tsx +45 -45
  26. package/src/components/Arrow/SelectArrow.tsx +69 -65
  27. package/src/components/Arrow/img/arrow01-left-clicked.png +0 -0
  28. package/src/components/Arrow/img/arrow01-left.png +0 -0
  29. package/src/components/Arrow/img/arrow01-right-clicked.png +0 -0
  30. package/src/components/Arrow/img/arrow01-right.png +0 -0
  31. package/src/components/Arrow/img/arrow02-left-clicked.png +0 -0
  32. package/src/components/Arrow/img/arrow02-left.png +0 -0
  33. package/src/components/Arrow/img/arrow02-right-clicked.png +0 -0
  34. package/src/components/Arrow/img/arrow02-right.png +0 -0
  35. package/src/components/Button.tsx +40 -41
  36. package/src/components/Character/CharacterSelection.tsx +96 -96
  37. package/src/components/CharacterStatus/CharacterStatus.tsx +120 -120
  38. package/src/components/Chat/Chat.tsx +195 -195
  39. package/src/components/Chatdeprecated/ChatDeprecated.tsx +198 -200
  40. package/src/components/CheckButton.tsx +65 -65
  41. package/src/components/CircularController/CircularController.tsx +162 -245
  42. package/src/components/CraftBook/CraftBook.tsx +224 -235
  43. package/src/components/CraftBook/MockItems.ts +46 -46
  44. package/src/components/DraggableContainer.tsx +153 -154
  45. package/src/components/Dropdown.tsx +90 -96
  46. package/src/components/DropdownSelectorContainer.tsx +42 -42
  47. package/src/components/Equipment/EquipmentSet.tsx +190 -190
  48. package/src/components/HistoryDialog.tsx +104 -104
  49. package/src/components/Input.tsx +15 -15
  50. package/src/components/Item/Cards/ItemTooltip.tsx +33 -33
  51. package/src/components/Item/Inventory/ErrorBoundary.tsx +42 -42
  52. package/src/components/Item/Inventory/ItemContainer.tsx +175 -210
  53. package/src/components/Item/Inventory/ItemContainerTypes.ts +6 -6
  54. package/src/components/Item/Inventory/ItemQuantitySelector.tsx +138 -142
  55. package/src/components/Item/Inventory/ItemSlot.tsx +467 -502
  56. package/src/components/Item/Inventory/itemContainerHelper.ts +156 -156
  57. package/src/components/ListMenu.tsx +63 -63
  58. package/src/components/Multitab/Tab.tsx +66 -57
  59. package/src/components/Multitab/TabBody.tsx +13 -13
  60. package/src/components/Multitab/TabsContainer.tsx +97 -97
  61. package/src/components/NPCDialog/NPCDialog.tsx +121 -121
  62. package/src/components/NPCDialog/NPCDialogText.tsx +113 -113
  63. package/src/components/NPCDialog/NPCMultiDialog.tsx +159 -159
  64. package/src/components/NPCDialog/QuestionDialog/QuestionDialog.tsx +237 -237
  65. package/src/components/ProgressBar.tsx +92 -92
  66. package/src/components/PropertySelect/PropertySelect.tsx +106 -114
  67. package/src/components/QuestInfo/QuestInfo.tsx +230 -232
  68. package/src/components/QuestList.tsx +129 -129
  69. package/src/components/RPGUIContainer.tsx +47 -47
  70. package/src/components/RPGUIForceRenderStart.tsx +45 -45
  71. package/src/components/RPGUIRoot.tsx +14 -14
  72. package/src/components/RadioButton.tsx +53 -53
  73. package/src/components/RadioInput/RadioButton.tsx +96 -98
  74. package/src/components/RadioInput/RadioInput.tsx +102 -99
  75. package/src/components/RadioInput/instruments.ts +15 -15
  76. package/src/components/RangeSlider.tsx +78 -78
  77. package/src/components/RelativeListMenu.tsx +83 -83
  78. package/src/components/ScrollList.tsx +79 -79
  79. package/src/components/SimpleProgressBar.tsx +62 -62
  80. package/src/components/SkillProgressBar.tsx +133 -133
  81. package/src/components/SkillsContainer.tsx +198 -200
  82. package/src/components/Spellbook/QuickSpells.tsx +120 -0
  83. package/src/components/Spellbook/Spell.tsx +201 -201
  84. package/src/components/Spellbook/Spellbook.tsx +144 -150
  85. package/src/components/Spellbook/SpellbookShortcuts.tsx +77 -0
  86. package/src/components/Spellbook/constants.ts +12 -8
  87. package/src/components/Spellbook/mockSpells.ts +60 -60
  88. package/src/components/StaticBook/StaticBook.tsx +103 -105
  89. package/src/components/TextArea.tsx +11 -11
  90. package/src/components/TimeWidget/DayNightPeriod/DayNightPeriod.tsx +35 -35
  91. package/src/components/TimeWidget/TimeWidget.tsx +63 -63
  92. package/src/components/TradingMenu/TradingItemRow.tsx +193 -197
  93. package/src/components/TradingMenu/TradingMenu.tsx +203 -203
  94. package/src/components/TradingMenu/items.mock.ts +96 -96
  95. package/src/components/Truncate.tsx +25 -25
  96. package/src/components/itemSelector/ItemSelector.tsx +136 -136
  97. package/src/components/shared/Column.tsx +16 -16
  98. package/src/components/shared/Ellipsis.tsx +65 -65
  99. package/src/components/shared/SpriteFromAtlas.tsx +102 -102
  100. package/src/components/typography/DynamicText.tsx +49 -49
  101. package/src/constants/uiColors.ts +20 -20
  102. package/src/constants/uiDevices.ts +3 -3
  103. package/src/constants/uiFonts.ts +12 -12
  104. package/src/hooks/useEventListener.ts +21 -21
  105. package/src/hooks/useOutsideAlerter.ts +25 -25
  106. package/src/index.tsx +40 -40
  107. package/src/libs/StringHelpers.ts +3 -3
  108. package/src/mocks/atlas/entities/entities.json +20215 -20215
  109. package/src/mocks/atlas/icons/icons.json +735 -735
  110. package/src/mocks/atlas/items/items.json +12086 -12086
  111. package/src/mocks/equipmentSet.mocks.ts +393 -393
  112. package/src/mocks/itemContainer.mocks.ts +560 -562
  113. package/src/mocks/skills.mocks.ts +128 -128
  114. package/src/stories/Arrow.stories.tsx +26 -26
  115. package/src/stories/Button.stories.tsx +36 -36
  116. package/src/stories/CharacterSelection.stories.tsx +45 -45
  117. package/src/stories/CharacterStatus.stories.tsx +29 -29
  118. package/src/stories/Chat.stories.tsx +187 -187
  119. package/src/stories/ChatDeprecated.stories.tsx +170 -170
  120. package/src/stories/CheckButton.stories.tsx +48 -48
  121. package/src/stories/CircullarController.stories.tsx +33 -37
  122. package/src/stories/CraftBook.stories.tsx +40 -40
  123. package/src/stories/DayNightPeriod.stories.tsx +27 -27
  124. package/src/stories/DraggableContainer.stories.tsx +28 -28
  125. package/src/stories/Dropdown.stories.tsx +46 -46
  126. package/src/stories/DropdownSelectorContainer.stories.tsx +41 -41
  127. package/src/stories/EquipmentSet.stories.tsx +65 -65
  128. package/src/stories/HistoryDialog.stories.tsx +61 -61
  129. package/src/stories/ItemContainer.stories.tsx +124 -198
  130. package/src/stories/ItemQuantitySelector.stories.tsx +26 -26
  131. package/src/stories/ItemSelector.stories.tsx +77 -77
  132. package/src/stories/ItemTradingComponent.stories.tsx +35 -35
  133. package/src/stories/ListMenu.stories.tsx +56 -56
  134. package/src/stories/Multitab.stories.tsx +51 -51
  135. package/src/stories/NPCDialog.stories.tsx +130 -130
  136. package/src/stories/NPCMultiDialog.stories.tsx +71 -71
  137. package/src/stories/ProgressBar.stories.tsx +23 -23
  138. package/src/stories/PropertySelect.stories.tsx +40 -40
  139. package/src/stories/QuestInfo.stories.tsx +110 -107
  140. package/src/stories/QuestList.stories.tsx +82 -82
  141. package/src/stories/QuickSpells.stories.tsx +38 -0
  142. package/src/stories/RPGUIContainers.stories.tsx +42 -42
  143. package/src/stories/RadioButton.stories.tsx +49 -49
  144. package/src/stories/RadioInput.stories.tsx +34 -34
  145. package/src/stories/RangeSlider.stories.tsx +64 -64
  146. package/src/stories/ScrollList.stories.tsx +85 -85
  147. package/src/stories/SimpleProgressBar.stories.tsx +22 -22
  148. package/src/stories/SkillProgressBar.stories.tsx +34 -34
  149. package/src/stories/SkillsContainer.stories.tsx +35 -35
  150. package/src/stories/Spellbook.stories.tsx +107 -104
  151. package/src/stories/StaticBook.stories.tsx +32 -32
  152. package/src/stories/Text.stories.tsx +42 -42
  153. package/src/stories/TimeWidget.stories.tsx +27 -27
  154. package/src/stories/TradingMenu.stories.tsx +45 -45
  155. package/src/types/eventTypes.ts +4 -4
  156. package/src/types/index.d.ts +2 -2
  157. package/dist/components/Shortcuts/Shortcuts.d.ts +0 -12
  158. package/dist/components/Shortcuts/ShortcutsSetter.d.ts +0 -12
  159. package/dist/components/Shortcuts/SingleShortcut.d.ts +0 -1
  160. package/src/components/Shortcuts/Shortcuts.tsx +0 -129
  161. package/src/components/Shortcuts/ShortcutsSetter.tsx +0 -132
  162. package/src/components/Shortcuts/SingleShortcut.ts +0 -61
  163. package/src/stories/Shortcuts.stories.tsx +0 -39
@@ -1,142 +1,138 @@
1
- import React, { useEffect, useRef, useState } from 'react';
2
- import styled from 'styled-components';
3
- import { Button, ButtonTypes } from '../../Button';
4
- import { Input } from '../../Input';
5
- import { RPGUIContainer, RPGUIContainerTypes } from '../../RPGUIContainer';
6
- import { RangeSlider, RangeSliderType } from '../../RangeSlider';
7
-
8
- export interface IItemQuantitySelectorProps {
9
- quantity: number;
10
- onConfirm: (quantity: number) => void;
11
- onClose: () => void;
12
- }
13
-
14
- export const ItemQuantitySelector: React.FC<IItemQuantitySelectorProps> = ({
15
- quantity,
16
- onConfirm,
17
- onClose,
18
- }) => {
19
- const [value, setValue] = useState(quantity);
20
-
21
- const inputRef = useRef<HTMLInputElement>(null);
22
-
23
- useEffect(() => {
24
- if (inputRef.current) {
25
- inputRef.current.focus();
26
- inputRef.current.select();
27
-
28
- const closeSelector = (e: KeyboardEvent) => {
29
- if (e.key === 'Escape') {
30
- onClose();
31
- }
32
- };
33
-
34
- document.addEventListener('keydown', closeSelector);
35
-
36
- return () => {
37
- document.removeEventListener('keydown', closeSelector);
38
- };
39
- }
40
-
41
- return () => {};
42
- }, []);
43
-
44
- return (
45
- <StyledContainer type={RPGUIContainerTypes.Framed} width="25rem">
46
- <CloseButton
47
- className="container-close"
48
- onClick={onClose}
49
- onTouchStart={onClose}
50
- >
51
- X
52
- </CloseButton>
53
- <h2>Select quantity to move</h2>
54
- <StyledForm
55
- style={{ width: '100%' }}
56
- onSubmit={e => {
57
- e.preventDefault();
58
-
59
- const numberValue = Number(value);
60
-
61
- if (Number.isNaN(numberValue)) {
62
- return;
63
- }
64
-
65
- onConfirm(Math.max(1, Math.min(quantity, numberValue)));
66
- }}
67
- noValidate
68
- >
69
- <StyledInput
70
- innerRef={inputRef}
71
- placeholder="Enter quantity"
72
- type="number"
73
- min={1}
74
- max={quantity}
75
- value={value}
76
- onChange={e => {
77
- if (Number(e.target.value) >= quantity) {
78
- setValue(quantity);
79
- return;
80
- }
81
-
82
- setValue((e.target.value as unknown) as number);
83
- }}
84
- onBlur={e => {
85
- const newValue = Math.max(
86
- 1,
87
- Math.min(quantity, Number(e.target.value))
88
- );
89
-
90
- setValue(newValue);
91
- }}
92
- />
93
- <RangeSlider
94
- type={RangeSliderType.Slider}
95
- valueMin={1}
96
- valueMax={quantity}
97
- width="100%"
98
- onChange={setValue}
99
- value={value}
100
- />
101
- <Button buttonType={ButtonTypes.RPGUIButton} type="submit">
102
- Confirm
103
- </Button>
104
- </StyledForm>
105
- </StyledContainer>
106
- );
107
- };
108
-
109
- const StyledContainer = styled(RPGUIContainer)`
110
- display: flex;
111
- flex-direction: column;
112
- align-items: center;
113
- `;
114
-
115
- const StyledForm = styled.form`
116
- display: flex;
117
- flex-direction: column;
118
- align-items: center;
119
- width: 100%;
120
- `;
121
- const StyledInput = styled(Input)`
122
- text-align: center;
123
-
124
- &::-webkit-outer-spin-button,
125
- &::-webkit-inner-spin-button {
126
- -webkit-appearance: none;
127
- margin: 0;
128
- }
129
-
130
- &[type='number'] {
131
- -moz-appearance: textfield;
132
- }
133
- `;
134
-
135
- const CloseButton = styled.div`
136
- position: absolute;
137
- top: 3px;
138
- right: 0px;
139
- color: white;
140
- z-index: 22;
141
- font-size: 0.8rem;
142
- `;
1
+ import React, { useEffect, useRef, useState } from 'react';
2
+ import styled from 'styled-components';
3
+ import { Button, ButtonTypes } from '../../Button';
4
+ import { Input } from '../../Input';
5
+ import { RPGUIContainer, RPGUIContainerTypes } from '../../RPGUIContainer';
6
+ import { RangeSlider, RangeSliderType } from '../../RangeSlider';
7
+
8
+ export interface IItemQuantitySelectorProps {
9
+ quantity: number;
10
+ onConfirm: (quantity: number) => void;
11
+ onClose: () => void;
12
+ }
13
+
14
+ export const ItemQuantitySelector: React.FC<IItemQuantitySelectorProps> = ({
15
+ quantity,
16
+ onConfirm,
17
+ onClose,
18
+ }) => {
19
+ const [value, setValue] = useState(quantity);
20
+
21
+ const inputRef = useRef<HTMLInputElement>(null);
22
+
23
+ useEffect(() => {
24
+ if (inputRef.current) {
25
+ inputRef.current.focus();
26
+ inputRef.current.select();
27
+
28
+ const closeSelector = (e: KeyboardEvent) => {
29
+ if (e.key === 'Escape') {
30
+ onClose();
31
+ }
32
+ };
33
+
34
+ document.addEventListener('keydown', closeSelector);
35
+
36
+ return () => {
37
+ document.removeEventListener('keydown', closeSelector);
38
+ };
39
+ }
40
+
41
+ return () => {};
42
+ }, []);
43
+
44
+ return (
45
+ <StyledContainer type={RPGUIContainerTypes.Framed} width="25rem">
46
+ <CloseButton className="container-close" onPointerDown={onClose}>
47
+ X
48
+ </CloseButton>
49
+ <h2>Select quantity to move</h2>
50
+ <StyledForm
51
+ style={{ width: '100%' }}
52
+ onSubmit={e => {
53
+ e.preventDefault();
54
+
55
+ const numberValue = Number(value);
56
+
57
+ if (Number.isNaN(numberValue)) {
58
+ return;
59
+ }
60
+
61
+ onConfirm(Math.max(1, Math.min(quantity, numberValue)));
62
+ }}
63
+ noValidate
64
+ >
65
+ <StyledInput
66
+ innerRef={inputRef}
67
+ placeholder="Enter quantity"
68
+ type="number"
69
+ min={1}
70
+ max={quantity}
71
+ value={value}
72
+ onChange={e => {
73
+ if (Number(e.target.value) >= quantity) {
74
+ setValue(quantity);
75
+ return;
76
+ }
77
+
78
+ setValue((e.target.value as unknown) as number);
79
+ }}
80
+ onBlur={e => {
81
+ const newValue = Math.max(
82
+ 1,
83
+ Math.min(quantity, Number(e.target.value))
84
+ );
85
+
86
+ setValue(newValue);
87
+ }}
88
+ />
89
+ <RangeSlider
90
+ type={RangeSliderType.Slider}
91
+ valueMin={1}
92
+ valueMax={quantity}
93
+ width="100%"
94
+ onChange={setValue}
95
+ value={value}
96
+ />
97
+ <Button buttonType={ButtonTypes.RPGUIButton} type="submit">
98
+ Confirm
99
+ </Button>
100
+ </StyledForm>
101
+ </StyledContainer>
102
+ );
103
+ };
104
+
105
+ const StyledContainer = styled(RPGUIContainer)`
106
+ display: flex;
107
+ flex-direction: column;
108
+ align-items: center;
109
+ `;
110
+
111
+ const StyledForm = styled.form`
112
+ display: flex;
113
+ flex-direction: column;
114
+ align-items: center;
115
+ width: 100%;
116
+ `;
117
+ const StyledInput = styled(Input)`
118
+ text-align: center;
119
+
120
+ &::-webkit-outer-spin-button,
121
+ &::-webkit-inner-spin-button {
122
+ -webkit-appearance: none;
123
+ margin: 0;
124
+ }
125
+
126
+ &[type='number'] {
127
+ -moz-appearance: textfield;
128
+ }
129
+ `;
130
+
131
+ const CloseButton = styled.div`
132
+ position: absolute;
133
+ top: 3px;
134
+ right: 0px;
135
+ color: white;
136
+ z-index: 22;
137
+ font-size: 0.8rem;
138
+ `;