@rpg-engine/long-bow 0.3.45 → 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,159 +1,159 @@
1
- import React, { useEffect, useState } from 'react';
2
- import styled from 'styled-components';
3
- import { RPGUIContainer, RPGUIContainerTypes } from '../RPGUIContainer';
4
- import aliceDefaultThumbnail from './img/npcDialog/npcThumbnails/alice.png';
5
- import pressSpaceGif from './img/space.gif';
6
- import { NPCDialogText } from './NPCDialogText';
7
-
8
- export enum ImgSide {
9
- right = 'right',
10
- left = 'left',
11
- }
12
-
13
- export interface NPCMultiDialogType {
14
- text: string;
15
- imagePath?: string;
16
- imageSide: ImgSide;
17
- }
18
-
19
- export interface INPCMultiDialogProps {
20
- onClose: () => void;
21
- textAndTypeArray: NPCMultiDialogType[];
22
- }
23
-
24
- export const NPCMultiDialog: React.FC<INPCMultiDialogProps> = ({
25
- onClose,
26
- textAndTypeArray,
27
- }) => {
28
- const [showGoNextIndicator, setShowGoNextIndicator] = useState<boolean>(
29
- false
30
- );
31
- const [slide, setSlide] = useState<number>(0);
32
-
33
- const onHandleSpacePress = (event: KeyboardEvent) => {
34
- if (event.code === 'Space') {
35
- if (slide < textAndTypeArray?.length - 1) {
36
- setSlide(prev => prev + 1);
37
- } else {
38
- // if there's no more text chunks, close the dialog
39
- onClose();
40
- }
41
- }
42
- };
43
-
44
- useEffect(() => {
45
- document.addEventListener('keydown', onHandleSpacePress);
46
-
47
- return () => document.removeEventListener('keydown', onHandleSpacePress);
48
- }, [slide]);
49
-
50
- return (
51
- <RPGUIContainer
52
- type={RPGUIContainerTypes.FramedGold}
53
- width={'50%'}
54
- height={'180px'}
55
- >
56
- <>
57
- <Container>
58
- {textAndTypeArray[slide]?.imageSide === 'right' && (
59
- <>
60
- <TextContainer flex={'70%'}>
61
- <NPCDialogText
62
- onStartStep={() => setShowGoNextIndicator(false)}
63
- onEndStep={() => setShowGoNextIndicator(true)}
64
- text={textAndTypeArray[slide].text || 'No text provided.'}
65
- onClose={() => {
66
- if (onClose) {
67
- onClose();
68
- }
69
- }}
70
- />
71
- </TextContainer>
72
- <ThumbnailContainer>
73
- <NPCThumbnail
74
- src={
75
- textAndTypeArray[slide].imagePath || aliceDefaultThumbnail
76
- }
77
- />
78
- </ThumbnailContainer>
79
- {showGoNextIndicator && (
80
- <PressSpaceIndicator right={'10.5rem'} src={pressSpaceGif} />
81
- )}
82
- </>
83
- )}
84
- {textAndTypeArray[slide].imageSide === 'left' && (
85
- <>
86
- <ThumbnailContainer>
87
- <NPCThumbnail
88
- src={
89
- textAndTypeArray[slide].imagePath || aliceDefaultThumbnail
90
- }
91
- />
92
- </ThumbnailContainer>
93
- <TextContainer flex={'70%'}>
94
- <NPCDialogText
95
- onStartStep={() => setShowGoNextIndicator(false)}
96
- onEndStep={() => setShowGoNextIndicator(true)}
97
- text={textAndTypeArray[slide].text || 'No text provided.'}
98
- onClose={() => {
99
- if (onClose) {
100
- onClose();
101
- }
102
- }}
103
- />
104
- </TextContainer>
105
- {showGoNextIndicator && (
106
- <PressSpaceIndicator right={'1rem'} src={pressSpaceGif} />
107
- )}
108
- </>
109
- )}
110
- </Container>
111
- )
112
- </>
113
- </RPGUIContainer>
114
- );
115
- };
116
-
117
- const Container = styled.div`
118
- display: flex;
119
- width: 100%;
120
- height: 100%;
121
-
122
- box-sizing: border-box;
123
- justify-content: center;
124
- align-items: flex-start;
125
- position: relative;
126
- `;
127
-
128
- interface ITextContainerProps {
129
- flex: string;
130
- }
131
-
132
- const TextContainer = styled.div<ITextContainerProps>`
133
- flex: ${({ flex }) => flex} 0 0;
134
- width: 355px;
135
- `;
136
-
137
- const ThumbnailContainer = styled.div`
138
- flex: 30% 0 0;
139
- display: flex;
140
- justify-content: flex-end;
141
- `;
142
-
143
- const NPCThumbnail = styled.img`
144
- image-rendering: pixelated;
145
- height: 128px;
146
- width: 128px;
147
- `;
148
-
149
- interface IPressSpaceIndicatorProps {
150
- right: string;
151
- }
152
-
153
- const PressSpaceIndicator = styled.img<IPressSpaceIndicatorProps>`
154
- position: absolute;
155
- right: ${({ right }) => right};
156
- bottom: 1rem;
157
- height: 20.7px;
158
- image-rendering: -webkit-optimize-contrast;
159
- `;
1
+ import React, { useEffect, useState } from 'react';
2
+ import styled from 'styled-components';
3
+ import { RPGUIContainer, RPGUIContainerTypes } from '../RPGUIContainer';
4
+ import aliceDefaultThumbnail from './img/npcDialog/npcThumbnails/alice.png';
5
+ import pressSpaceGif from './img/space.gif';
6
+ import { NPCDialogText } from './NPCDialogText';
7
+
8
+ export enum ImgSide {
9
+ right = 'right',
10
+ left = 'left',
11
+ }
12
+
13
+ export interface NPCMultiDialogType {
14
+ text: string;
15
+ imagePath?: string;
16
+ imageSide: ImgSide;
17
+ }
18
+
19
+ export interface INPCMultiDialogProps {
20
+ onClose: () => void;
21
+ textAndTypeArray: NPCMultiDialogType[];
22
+ }
23
+
24
+ export const NPCMultiDialog: React.FC<INPCMultiDialogProps> = ({
25
+ onClose,
26
+ textAndTypeArray,
27
+ }) => {
28
+ const [showGoNextIndicator, setShowGoNextIndicator] = useState<boolean>(
29
+ false
30
+ );
31
+ const [slide, setSlide] = useState<number>(0);
32
+
33
+ const onHandleSpacePress = (event: KeyboardEvent) => {
34
+ if (event.code === 'Space') {
35
+ if (slide < textAndTypeArray?.length - 1) {
36
+ setSlide(prev => prev + 1);
37
+ } else {
38
+ // if there's no more text chunks, close the dialog
39
+ onClose();
40
+ }
41
+ }
42
+ };
43
+
44
+ useEffect(() => {
45
+ document.addEventListener('keydown', onHandleSpacePress);
46
+
47
+ return () => document.removeEventListener('keydown', onHandleSpacePress);
48
+ }, [slide]);
49
+
50
+ return (
51
+ <RPGUIContainer
52
+ type={RPGUIContainerTypes.FramedGold}
53
+ width={'50%'}
54
+ height={'180px'}
55
+ >
56
+ <>
57
+ <Container>
58
+ {textAndTypeArray[slide]?.imageSide === 'right' && (
59
+ <>
60
+ <TextContainer flex={'70%'}>
61
+ <NPCDialogText
62
+ onStartStep={() => setShowGoNextIndicator(false)}
63
+ onEndStep={() => setShowGoNextIndicator(true)}
64
+ text={textAndTypeArray[slide].text || 'No text provided.'}
65
+ onClose={() => {
66
+ if (onClose) {
67
+ onClose();
68
+ }
69
+ }}
70
+ />
71
+ </TextContainer>
72
+ <ThumbnailContainer>
73
+ <NPCThumbnail
74
+ src={
75
+ textAndTypeArray[slide].imagePath || aliceDefaultThumbnail
76
+ }
77
+ />
78
+ </ThumbnailContainer>
79
+ {showGoNextIndicator && (
80
+ <PressSpaceIndicator right={'10.5rem'} src={pressSpaceGif} />
81
+ )}
82
+ </>
83
+ )}
84
+ {textAndTypeArray[slide].imageSide === 'left' && (
85
+ <>
86
+ <ThumbnailContainer>
87
+ <NPCThumbnail
88
+ src={
89
+ textAndTypeArray[slide].imagePath || aliceDefaultThumbnail
90
+ }
91
+ />
92
+ </ThumbnailContainer>
93
+ <TextContainer flex={'70%'}>
94
+ <NPCDialogText
95
+ onStartStep={() => setShowGoNextIndicator(false)}
96
+ onEndStep={() => setShowGoNextIndicator(true)}
97
+ text={textAndTypeArray[slide].text || 'No text provided.'}
98
+ onClose={() => {
99
+ if (onClose) {
100
+ onClose();
101
+ }
102
+ }}
103
+ />
104
+ </TextContainer>
105
+ {showGoNextIndicator && (
106
+ <PressSpaceIndicator right={'1rem'} src={pressSpaceGif} />
107
+ )}
108
+ </>
109
+ )}
110
+ </Container>
111
+ )
112
+ </>
113
+ </RPGUIContainer>
114
+ );
115
+ };
116
+
117
+ const Container = styled.div`
118
+ display: flex;
119
+ width: 100%;
120
+ height: 100%;
121
+
122
+ box-sizing: border-box;
123
+ justify-content: center;
124
+ align-items: flex-start;
125
+ position: relative;
126
+ `;
127
+
128
+ interface ITextContainerProps {
129
+ flex: string;
130
+ }
131
+
132
+ const TextContainer = styled.div<ITextContainerProps>`
133
+ flex: ${({ flex }) => flex} 0 0;
134
+ width: 355px;
135
+ `;
136
+
137
+ const ThumbnailContainer = styled.div`
138
+ flex: 30% 0 0;
139
+ display: flex;
140
+ justify-content: flex-end;
141
+ `;
142
+
143
+ const NPCThumbnail = styled.img`
144
+ image-rendering: pixelated;
145
+ height: 128px;
146
+ width: 128px;
147
+ `;
148
+
149
+ interface IPressSpaceIndicatorProps {
150
+ right: string;
151
+ }
152
+
153
+ const PressSpaceIndicator = styled.img<IPressSpaceIndicatorProps>`
154
+ position: absolute;
155
+ right: ${({ right }) => right};
156
+ bottom: 1rem;
157
+ height: 20.7px;
158
+ image-rendering: -webkit-optimize-contrast;
159
+ `;