@rpg-engine/long-bow 0.4.7 → 0.4.8

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 (177) hide show
  1. package/LICENSE +20 -20
  2. package/README.md +181 -181
  3. package/dist/components/ConfirmModal.d.ts +8 -0
  4. package/dist/components/DraggableContainer.d.ts +1 -0
  5. package/dist/components/Item/Inventory/ItemSlot.d.ts +7 -7
  6. package/dist/components/Marketplace/BuyPanel.d.ts +22 -0
  7. package/dist/components/Marketplace/ManagmentPanel.d.ts +18 -0
  8. package/dist/components/Marketplace/Marketplace.d.ts +22 -9
  9. package/dist/components/Marketplace/MarketplaceRows.d.ts +3 -1
  10. package/dist/components/Marketplace/{__mocks__ → filters}/index.d.ts +1 -3
  11. package/dist/components/Pager.d.ts +9 -0
  12. package/dist/long-bow.cjs.development.js +1540 -1163
  13. package/dist/long-bow.cjs.development.js.map +1 -1
  14. package/dist/long-bow.cjs.production.min.js +1 -1
  15. package/dist/long-bow.cjs.production.min.js.map +1 -1
  16. package/dist/long-bow.esm.js +1594 -1217
  17. package/dist/long-bow.esm.js.map +1 -1
  18. package/package.json +100 -100
  19. package/src/components/Abstractions/ModalPortal.tsx +22 -22
  20. package/src/components/Abstractions/SlotsContainer.tsx +62 -62
  21. package/src/components/Arrow/SelectArrow.tsx +69 -69
  22. package/src/components/Arrow/img/arrow01-left-clicked.png +0 -0
  23. package/src/components/Arrow/img/arrow01-left.png +0 -0
  24. package/src/components/Arrow/img/arrow01-right-clicked.png +0 -0
  25. package/src/components/Arrow/img/arrow01-right.png +0 -0
  26. package/src/components/Arrow/img/arrow02-left-clicked.png +0 -0
  27. package/src/components/Arrow/img/arrow02-left.png +0 -0
  28. package/src/components/Arrow/img/arrow02-right-clicked.png +0 -0
  29. package/src/components/Arrow/img/arrow02-right.png +0 -0
  30. package/src/components/Button.tsx +40 -40
  31. package/src/components/Character/CharacterSelection.tsx +98 -98
  32. package/src/components/CharacterStatus/CharacterStatus.tsx +120 -120
  33. package/src/components/Chat/Chat.tsx +196 -196
  34. package/src/components/Chatdeprecated/ChatDeprecated.tsx +198 -198
  35. package/src/components/CheckButton.tsx +65 -65
  36. package/src/components/CircularController/CircularController.tsx +282 -282
  37. package/src/components/ConfirmModal.tsx +87 -0
  38. package/src/components/CraftBook/CraftBook.tsx +286 -286
  39. package/src/components/CraftBook/CraftingRecipe.tsx +161 -161
  40. package/src/components/CraftBook/MockItems.ts +101 -101
  41. package/src/components/DraggableContainer.tsx +183 -180
  42. package/src/components/Dropdown.tsx +14 -6
  43. package/src/components/DropdownSelectorContainer.tsx +42 -42
  44. package/src/components/Equipment/EquipmentSet.tsx +199 -199
  45. package/src/components/HistoryDialog.tsx +104 -104
  46. package/src/components/Input.tsx +15 -15
  47. package/src/components/InputRadio.tsx +41 -41
  48. package/src/components/Item/Cards/ItemInfo.tsx +298 -298
  49. package/src/components/Item/Cards/ItemInfoDisplay.tsx +135 -135
  50. package/src/components/Item/Cards/ItemInfoWrapper.tsx +62 -62
  51. package/src/components/Item/Cards/ItemTooltip.tsx +83 -83
  52. package/src/components/Item/Cards/MobileItemTooltip.tsx +149 -149
  53. package/src/components/Item/Inventory/ErrorBoundary.tsx +42 -42
  54. package/src/components/Item/Inventory/ItemContainer.tsx +231 -231
  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 +595 -580
  58. package/src/components/Item/Inventory/itemContainerHelper.ts +175 -175
  59. package/src/components/ListMenu.tsx +63 -63
  60. package/src/components/Marketplace/BuyPanel.tsx +296 -0
  61. package/src/components/Marketplace/ManagmentPanel.tsx +247 -0
  62. package/src/components/Marketplace/Marketplace.tsx +106 -132
  63. package/src/components/Marketplace/MarketplaceRows.tsx +161 -171
  64. package/src/components/Marketplace/{__mocks__ → filters}/index.tsx +67 -65
  65. package/src/components/Multitab/Tab.tsx +66 -66
  66. package/src/components/Multitab/TabBody.tsx +13 -13
  67. package/src/components/Multitab/TabsContainer.tsx +97 -97
  68. package/src/components/NPCDialog/NPCDialog.tsx +121 -121
  69. package/src/components/NPCDialog/NPCDialogText.tsx +113 -113
  70. package/src/components/NPCDialog/NPCMultiDialog.tsx +159 -159
  71. package/src/components/NPCDialog/QuestionDialog/QuestionDialog.tsx +237 -237
  72. package/src/components/Pager.tsx +94 -0
  73. package/src/components/ProgressBar.tsx +95 -95
  74. package/src/components/PropertySelect/PropertySelect.tsx +106 -106
  75. package/src/components/QuestInfo/QuestInfo.tsx +233 -233
  76. package/src/components/QuestList.tsx +135 -135
  77. package/src/components/RPGUIContainer.tsx +47 -47
  78. package/src/components/RPGUIForceRenderStart.tsx +45 -45
  79. package/src/components/RPGUIRoot.tsx +14 -14
  80. package/src/components/RadioButton.tsx +53 -53
  81. package/src/components/RadioInput/RadioButton.tsx +96 -96
  82. package/src/components/RadioInput/RadioInput.tsx +102 -102
  83. package/src/components/RadioInput/instruments.ts +15 -15
  84. package/src/components/RangeSlider.tsx +78 -78
  85. package/src/components/RelativeListMenu.tsx +90 -90
  86. package/src/components/ScrollList.tsx +79 -79
  87. package/src/components/Shortcuts/Shortcuts.tsx +193 -193
  88. package/src/components/Shortcuts/ShortcutsSetter.tsx +139 -139
  89. package/src/components/Shortcuts/SingleShortcut.ts +82 -82
  90. package/src/components/Shortcuts/useShortcutCooldown.ts +23 -23
  91. package/src/components/SimpleProgressBar.tsx +62 -62
  92. package/src/components/SkillProgressBar.tsx +198 -198
  93. package/src/components/SkillsContainer.tsx +213 -213
  94. package/src/components/Spellbook/Spell.tsx +235 -236
  95. package/src/components/Spellbook/Spellbook.tsx +145 -161
  96. package/src/components/Spellbook/cards/MobileSpellTooltip.tsx +137 -137
  97. package/src/components/Spellbook/cards/SpellInfo.tsx +134 -134
  98. package/src/components/Spellbook/cards/SpellInfoDisplay.tsx +31 -31
  99. package/src/components/Spellbook/cards/SpellInfoWrapper.tsx +48 -48
  100. package/src/components/Spellbook/cards/SpellTooltip.tsx +70 -70
  101. package/src/components/Spellbook/constants.ts +7 -7
  102. package/src/components/Spellbook/mockSpells.ts +84 -84
  103. package/src/components/StaticBook/StaticBook.tsx +103 -103
  104. package/src/components/TextArea.tsx +11 -11
  105. package/src/components/TimeWidget/DayNightPeriod/DayNightPeriod.tsx +35 -35
  106. package/src/components/TimeWidget/TimeWidget.tsx +65 -65
  107. package/src/components/TradingMenu/TradingItemRow.tsx +199 -199
  108. package/src/components/TradingMenu/TradingMenu.tsx +219 -219
  109. package/src/components/TradingMenu/items.mock.ts +48 -48
  110. package/src/components/Truncate.tsx +25 -25
  111. package/src/components/itemSelector/ItemSelector.tsx +136 -136
  112. package/src/components/shared/Column.tsx +16 -16
  113. package/src/components/shared/Ellipsis.tsx +76 -68
  114. package/src/components/shared/SpriteFromAtlas.tsx +104 -104
  115. package/src/components/typography/DynamicText.tsx +49 -49
  116. package/src/constants/uiColors.ts +20 -20
  117. package/src/constants/uiDevices.ts +3 -3
  118. package/src/constants/uiFonts.ts +12 -12
  119. package/src/hooks/useEventListener.ts +21 -21
  120. package/src/hooks/useOutsideAlerter.ts +25 -25
  121. package/src/index.tsx +42 -42
  122. package/src/libs/CastingTypeHelper.ts +7 -7
  123. package/src/libs/StringHelpers.ts +3 -3
  124. package/src/libs/itemCounter.ts +21 -21
  125. package/src/mocks/atlas/entities/entities.json +20215 -20215
  126. package/src/mocks/atlas/icons/icons.json +735 -735
  127. package/src/mocks/atlas/items/items.json +12086 -12086
  128. package/src/mocks/equipmentSet.mocks.ts +391 -391
  129. package/src/mocks/itemContainer.mocks.ts +605 -605
  130. package/src/mocks/skills.mocks.ts +130 -130
  131. package/src/stories/Arrow.stories.tsx +26 -26
  132. package/src/stories/Button.stories.tsx +36 -36
  133. package/src/stories/CharacterSelection.stories.tsx +44 -44
  134. package/src/stories/CharacterStatus.stories.tsx +29 -29
  135. package/src/stories/Chat.stories.tsx +187 -187
  136. package/src/stories/ChatDeprecated.stories.tsx +170 -170
  137. package/src/stories/CheckButton.stories.tsx +48 -48
  138. package/src/stories/CircullarController.stories.tsx +37 -37
  139. package/src/stories/CraftBook.stories.tsx +42 -42
  140. package/src/stories/DayNightPeriod.stories.tsx +27 -27
  141. package/src/stories/DraggableContainer.stories.tsx +28 -28
  142. package/src/stories/Dropdown.stories.tsx +46 -46
  143. package/src/stories/DropdownSelectorContainer.stories.tsx +41 -41
  144. package/src/stories/EquipmentSet.stories.tsx +65 -65
  145. package/src/stories/HistoryDialog.stories.tsx +61 -61
  146. package/src/stories/ItemContainer.stories.tsx +201 -201
  147. package/src/stories/ItemInfoDisplay.stories.tsx +33 -33
  148. package/src/stories/ItemQuantitySelector.stories.tsx +26 -26
  149. package/src/stories/ItemSelector.stories.tsx +77 -77
  150. package/src/stories/ItemTradingComponent.stories.tsx +35 -35
  151. package/src/stories/ListMenu.stories.tsx +56 -56
  152. package/src/stories/Marketplace.stories.tsx +53 -42
  153. package/src/stories/MarketplaceRows.stories.tsx +28 -28
  154. package/src/stories/Multitab.stories.tsx +51 -51
  155. package/src/stories/NPCDialog.stories.tsx +130 -130
  156. package/src/stories/NPCMultiDialog.stories.tsx +71 -71
  157. package/src/stories/ProgressBar.stories.tsx +23 -23
  158. package/src/stories/PropertySelect.stories.tsx +40 -40
  159. package/src/stories/QuestInfo.stories.tsx +107 -107
  160. package/src/stories/QuestList.stories.tsx +82 -82
  161. package/src/stories/RPGUIContainers.stories.tsx +42 -42
  162. package/src/stories/RadioButton.stories.tsx +49 -49
  163. package/src/stories/RadioInput.stories.tsx +34 -34
  164. package/src/stories/RangeSlider.stories.tsx +64 -64
  165. package/src/stories/ScrollList.stories.tsx +85 -85
  166. package/src/stories/Shortcuts.stories.tsx +39 -39
  167. package/src/stories/SimpleProgressBar.stories.tsx +22 -22
  168. package/src/stories/SkillProgressBar.stories.tsx +34 -34
  169. package/src/stories/SkillsContainer.stories.tsx +35 -35
  170. package/src/stories/SpellInfoDisplay.stories.tsx +27 -27
  171. package/src/stories/Spellbook.stories.tsx +104 -104
  172. package/src/stories/StaticBook.stories.tsx +32 -32
  173. package/src/stories/Text.stories.tsx +42 -42
  174. package/src/stories/TimeWidget.stories.tsx +27 -27
  175. package/src/stories/TradingMenu.stories.tsx +47 -47
  176. package/src/types/eventTypes.ts +4 -4
  177. package/src/types/index.d.ts +2 -2
@@ -1,180 +1,183 @@
1
- import React, { useEffect, useRef } from 'react';
2
- import Draggable from 'react-draggable';
3
- import styled from 'styled-components';
4
- import { uiFonts } from '../constants/uiFonts';
5
- import { useOutsideClick } from '../hooks/useOutsideAlerter';
6
- import { IPosition } from '../types/eventTypes';
7
- import { RPGUIContainerTypes } from './RPGUIContainer';
8
-
9
- export interface IDraggableContainerProps {
10
- children: React.ReactNode;
11
- width?: string;
12
- height?: string;
13
- className?: string;
14
- type?: RPGUIContainerTypes;
15
- title?: string;
16
- imgSrc?: string;
17
- imgWidth?: string;
18
- onCloseButton?: () => void;
19
- cancelDrag?: string;
20
- onPositionChange?: (position: IPosition) => void;
21
- onPositionChangeEnd?: (position: IPosition) => void;
22
- onPositionChangeStart?: (position: IPosition) => void;
23
- onOutsideClick?: () => void;
24
- initialPosition?: IPosition;
25
- scale?: number;
26
- }
27
-
28
- export const DraggableContainer: React.FC<IDraggableContainerProps> = ({
29
- children,
30
- width = '50%',
31
- height,
32
- className,
33
- type = RPGUIContainerTypes.FramedGold,
34
- onCloseButton,
35
- title,
36
- imgSrc,
37
- imgWidth = '20px',
38
- cancelDrag,
39
- onPositionChange,
40
- onPositionChangeEnd,
41
- onPositionChangeStart,
42
- onOutsideClick,
43
- initialPosition = { x: 0, y: 0 },
44
- scale,
45
- }) => {
46
- const draggableRef = useRef(null);
47
-
48
- useOutsideClick(draggableRef, 'item-container');
49
-
50
- useEffect(() => {
51
- document.addEventListener('clickOutside', event => {
52
- const e = event as CustomEvent;
53
-
54
- if (e.detail.id === 'item-container') {
55
- if (onOutsideClick) {
56
- onOutsideClick();
57
- }
58
- }
59
- });
60
-
61
- return () => {
62
- document.removeEventListener('clickOutside', _e => {});
63
- };
64
- }, []);
65
-
66
- return (
67
- <Draggable
68
- cancel={`.container-close,${cancelDrag}`}
69
- onDrag={(_e, data) => {
70
- if (onPositionChange) {
71
- onPositionChange({
72
- x: data.x,
73
- y: data.y,
74
- });
75
- }
76
- }}
77
- onStop={(_e, data) => {
78
- if (onPositionChangeEnd) {
79
- onPositionChangeEnd({
80
- x: data.x,
81
- y: data.y,
82
- });
83
- }
84
- }}
85
- onStart={(_e, data) => {
86
- if (onPositionChangeStart) {
87
- onPositionChangeStart({
88
- x: data.x,
89
- y: data.y,
90
- });
91
- }
92
- }}
93
- defaultPosition={initialPosition}
94
- scale={scale}
95
- >
96
- <Container
97
- ref={draggableRef}
98
- width={width}
99
- height={height || 'auto'}
100
- className={`rpgui-container ${type} ${className}`}
101
- >
102
- {title && (
103
- <TitleContainer className="drag-handler">
104
- <Title>
105
- {imgSrc && <Icon src={imgSrc} width={imgWidth} />}
106
- {title}
107
- </Title>
108
- </TitleContainer>
109
- )}
110
- {onCloseButton && (
111
- <CloseButton
112
- className="container-close"
113
- onPointerDown={onCloseButton}
114
- >
115
- X
116
- </CloseButton>
117
- )}
118
-
119
- {children}
120
- </Container>
121
- </Draggable>
122
- );
123
- };
124
-
125
- interface IContainerProps {
126
- width: string;
127
- height: string;
128
- }
129
-
130
- const Container = styled.div<IContainerProps>`
131
- height: ${props => props.height};
132
- width: ${({ width }) => width};
133
- display: flex;
134
- flex-wrap: wrap;
135
- image-rendering: pixelated;
136
-
137
- &.rpgui-container {
138
- padding-top: 1.5rem;
139
- }
140
- `;
141
-
142
- const CloseButton = styled.div`
143
- position: absolute;
144
- top: 3px;
145
- right: 0px;
146
- color: white;
147
- z-index: 22;
148
- font-size: 1.1rem;
149
- @media (max-width: 950px) {
150
- font-size: 1.7rem;
151
- padding: 12px;
152
- }
153
- `;
154
-
155
- const TitleContainer = styled.div`
156
- width: 100%;
157
- height: 100%;
158
- display: flex;
159
- flex-wrap: wrap;
160
- justify-content: flex-start;
161
- align-items: center;
162
- `;
163
-
164
- const Title = styled.h1`
165
- color: white;
166
- z-index: 22;
167
- font-size: ${uiFonts.size.large};
168
- `;
169
-
170
- interface ICustomIconProps {
171
- width: string;
172
- }
173
-
174
- const Icon = styled.img`
175
- color: white;
176
- z-index: 22;
177
- font-size: ${uiFonts.size.xsmall};
178
- width: ${(props: ICustomIconProps) => props.width};
179
- margin-right: 0.5rem;
180
- `;
1
+ import React, { useEffect, useRef } from 'react';
2
+ import Draggable from 'react-draggable';
3
+ import styled from 'styled-components';
4
+ import { uiFonts } from '../constants/uiFonts';
5
+ import { useOutsideClick } from '../hooks/useOutsideAlerter';
6
+ import { IPosition } from '../types/eventTypes';
7
+ import { RPGUIContainerTypes } from './RPGUIContainer';
8
+
9
+ export interface IDraggableContainerProps {
10
+ children: React.ReactNode;
11
+ width?: string;
12
+ height?: string;
13
+ className?: string;
14
+ type?: RPGUIContainerTypes;
15
+ title?: string;
16
+ imgSrc?: string;
17
+ imgWidth?: string;
18
+ onCloseButton?: () => void;
19
+ cancelDrag?: string;
20
+ onPositionChange?: (position: IPosition) => void;
21
+ onPositionChangeEnd?: (position: IPosition) => void;
22
+ onPositionChangeStart?: (position: IPosition) => void;
23
+ onOutsideClick?: () => void;
24
+ initialPosition?: IPosition;
25
+ scale?: number;
26
+ dragDisabled?: boolean;
27
+ }
28
+
29
+ export const DraggableContainer: React.FC<IDraggableContainerProps> = ({
30
+ children,
31
+ width = '50%',
32
+ height,
33
+ className,
34
+ type = RPGUIContainerTypes.FramedGold,
35
+ onCloseButton,
36
+ title,
37
+ imgSrc,
38
+ imgWidth = '20px',
39
+ cancelDrag,
40
+ onPositionChange,
41
+ onPositionChangeEnd,
42
+ onPositionChangeStart,
43
+ onOutsideClick,
44
+ initialPosition = { x: 0, y: 0 },
45
+ scale,
46
+ dragDisabled = false,
47
+ }) => {
48
+ const draggableRef = useRef(null);
49
+
50
+ useOutsideClick(draggableRef, 'item-container');
51
+
52
+ useEffect(() => {
53
+ document.addEventListener('clickOutside', event => {
54
+ const e = event as CustomEvent;
55
+
56
+ if (e.detail.id === 'item-container') {
57
+ if (onOutsideClick) {
58
+ onOutsideClick();
59
+ }
60
+ }
61
+ });
62
+
63
+ return () => {
64
+ document.removeEventListener('clickOutside', _e => {});
65
+ };
66
+ }, []);
67
+
68
+ return (
69
+ <Draggable
70
+ cancel={`.container-close,${cancelDrag}`}
71
+ disabled={dragDisabled}
72
+ onDrag={(_e, data) => {
73
+ if (onPositionChange) {
74
+ onPositionChange({
75
+ x: data.x,
76
+ y: data.y,
77
+ });
78
+ }
79
+ }}
80
+ onStop={(_e, data) => {
81
+ if (onPositionChangeEnd) {
82
+ onPositionChangeEnd({
83
+ x: data.x,
84
+ y: data.y,
85
+ });
86
+ }
87
+ }}
88
+ onStart={(_e, data) => {
89
+ if (onPositionChangeStart) {
90
+ onPositionChangeStart({
91
+ x: data.x,
92
+ y: data.y,
93
+ });
94
+ }
95
+ }}
96
+ defaultPosition={initialPosition}
97
+ scale={scale}
98
+ >
99
+ <Container
100
+ ref={draggableRef}
101
+ width={width}
102
+ height={height || 'auto'}
103
+ className={`rpgui-container ${type} ${className}`}
104
+ >
105
+ {title && (
106
+ <TitleContainer className="drag-handler">
107
+ <Title>
108
+ {imgSrc && <Icon src={imgSrc} width={imgWidth} />}
109
+ {title}
110
+ </Title>
111
+ </TitleContainer>
112
+ )}
113
+ {onCloseButton && (
114
+ <CloseButton
115
+ className="container-close"
116
+ onPointerDown={onCloseButton}
117
+ >
118
+ X
119
+ </CloseButton>
120
+ )}
121
+
122
+ {children}
123
+ </Container>
124
+ </Draggable>
125
+ );
126
+ };
127
+
128
+ interface IContainerProps {
129
+ width: string;
130
+ height: string;
131
+ }
132
+
133
+ const Container = styled.div<IContainerProps>`
134
+ height: ${props => props.height};
135
+ width: ${({ width }) => width};
136
+ display: flex;
137
+ flex-wrap: wrap;
138
+ image-rendering: pixelated;
139
+
140
+ &.rpgui-container {
141
+ padding-top: 1.5rem;
142
+ }
143
+ `;
144
+
145
+ const CloseButton = styled.div`
146
+ position: absolute;
147
+ top: 3px;
148
+ right: 0px;
149
+ color: white;
150
+ z-index: 22;
151
+ font-size: 1.1rem;
152
+ @media (max-width: 950px) {
153
+ font-size: 1.7rem;
154
+ padding: 12px;
155
+ }
156
+ `;
157
+
158
+ const TitleContainer = styled.div`
159
+ width: 100%;
160
+ height: 100%;
161
+ display: flex;
162
+ flex-wrap: wrap;
163
+ justify-content: flex-start;
164
+ align-items: center;
165
+ `;
166
+
167
+ const Title = styled.h1`
168
+ color: white;
169
+ z-index: 22;
170
+ font-size: ${uiFonts.size.large};
171
+ `;
172
+
173
+ interface ICustomIconProps {
174
+ width: string;
175
+ }
176
+
177
+ const Icon = styled.img`
178
+ color: white;
179
+ z-index: 22;
180
+ font-size: ${uiFonts.size.xsmall};
181
+ width: ${(props: ICustomIconProps) => props.width};
182
+ margin-right: 0.5rem;
183
+ `;
@@ -33,7 +33,7 @@ export const Dropdown: React.FC<IDropdownProps> = ({
33
33
  if (firstOption) {
34
34
  let change = !selectedValue;
35
35
  if (!change) {
36
- change = options.filter((o) => o.value === selectedValue).length < 1;
36
+ change = options.filter(o => o.value === selectedValue).length < 1;
37
37
  }
38
38
 
39
39
  /**
@@ -58,17 +58,17 @@ export const Dropdown: React.FC<IDropdownProps> = ({
58
58
  <DropdownSelect
59
59
  id={`dropdown-${dropdownId}`}
60
60
  className="rpgui-dropdown-imp rpgui-dropdown-imp-header"
61
- onPointerDown={() => setOpened((prev) => !prev)}
61
+ onPointerUp={() => setOpened(prev => !prev)}
62
62
  >
63
63
  <label>▼</label> {selectedOption}
64
64
  </DropdownSelect>
65
65
 
66
66
  <DropdownOptions className="rpgui-dropdown-imp" opened={opened}>
67
- {options.map((option) => {
67
+ {options.map(option => {
68
68
  return (
69
69
  <li
70
70
  key={option.id}
71
- onPointerDown={() => {
71
+ onPointerUp={() => {
72
72
  setSelectedValue(option.value);
73
73
  setSelectedOption(option.option);
74
74
  setOpened(false);
@@ -85,12 +85,17 @@ export const Dropdown: React.FC<IDropdownProps> = ({
85
85
 
86
86
  const Container = styled.div<{ width: string | undefined }>`
87
87
  position: relative;
88
- width: ${(props) => props.width || '100%'};
88
+ width: ${props => props.width || '100%'};
89
89
  `;
90
90
 
91
91
  const DropdownSelect = styled.p`
92
92
  width: 100%;
93
93
  box-sizing: border-box;
94
+
95
+ label {
96
+ display: inline-block;
97
+ transform: translateY(-2px);
98
+ }
94
99
  `;
95
100
 
96
101
  const DropdownOptions = styled.ul<{
@@ -98,8 +103,11 @@ const DropdownOptions = styled.ul<{
98
103
  }>`
99
104
  position: absolute;
100
105
  width: 100%;
101
- display: ${(props) => (props.opened ? 'block' : 'none')};
106
+ max-height: 300px;
107
+ overflow-y: auto;
108
+ display: ${props => (props.opened ? 'block' : 'none')};
102
109
  box-sizing: border-box;
110
+
103
111
  @media (max-width: 768px) {
104
112
  padding: 8px 0;
105
113
  }
@@ -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
+ `;