@rpg-engine/long-bow 0.3.54 → 0.3.57

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 (162) 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/Spellbook/QuickSpells.d.ts +10 -0
  10. package/dist/components/Spellbook/Spell.d.ts +1 -1
  11. package/dist/components/Spellbook/Spellbook.d.ts +3 -5
  12. package/dist/components/Spellbook/SpellbookShortcuts.d.ts +10 -0
  13. package/dist/components/Spellbook/constants.d.ts +3 -3
  14. package/dist/components/shared/SpriteFromAtlas.d.ts +1 -1
  15. package/dist/index.d.ts +1 -1
  16. package/dist/long-bow.cjs.development.js +732 -911
  17. package/dist/long-bow.cjs.development.js.map +1 -1
  18. package/dist/long-bow.cjs.production.min.js +1 -1
  19. package/dist/long-bow.cjs.production.min.js.map +1 -1
  20. package/dist/long-bow.esm.js +734 -914
  21. package/dist/long-bow.esm.js.map +1 -1
  22. package/dist/stories/{Shortcuts.stories.d.ts → QuickSpells.stories.d.ts} +2 -2
  23. package/package.json +100 -100
  24. package/src/components/Abstractions/SlotsContainer.tsx +45 -45
  25. package/src/components/Arrow/SelectArrow.tsx +69 -65
  26. package/src/components/Arrow/img/arrow01-left-clicked.png +0 -0
  27. package/src/components/Arrow/img/arrow01-left.png +0 -0
  28. package/src/components/Arrow/img/arrow01-right-clicked.png +0 -0
  29. package/src/components/Arrow/img/arrow01-right.png +0 -0
  30. package/src/components/Arrow/img/arrow02-left-clicked.png +0 -0
  31. package/src/components/Arrow/img/arrow02-left.png +0 -0
  32. package/src/components/Arrow/img/arrow02-right-clicked.png +0 -0
  33. package/src/components/Arrow/img/arrow02-right.png +0 -0
  34. package/src/components/Button.tsx +40 -41
  35. package/src/components/Character/CharacterSelection.tsx +96 -96
  36. package/src/components/CharacterStatus/CharacterStatus.tsx +120 -120
  37. package/src/components/Chat/Chat.tsx +195 -195
  38. package/src/components/Chatdeprecated/ChatDeprecated.tsx +198 -200
  39. package/src/components/CheckButton.tsx +65 -65
  40. package/src/components/CircularController/CircularController.tsx +162 -245
  41. package/src/components/CraftBook/CraftBook.tsx +224 -235
  42. package/src/components/CraftBook/MockItems.ts +46 -46
  43. package/src/components/DraggableContainer.tsx +153 -154
  44. package/src/components/Dropdown.tsx +90 -96
  45. package/src/components/DropdownSelectorContainer.tsx +42 -42
  46. package/src/components/Equipment/EquipmentSet.tsx +190 -190
  47. package/src/components/HistoryDialog.tsx +104 -104
  48. package/src/components/Input.tsx +15 -15
  49. package/src/components/Item/Cards/ItemTooltip.tsx +33 -33
  50. package/src/components/Item/Inventory/ErrorBoundary.tsx +42 -42
  51. package/src/components/Item/Inventory/ItemContainer.tsx +175 -210
  52. package/src/components/Item/Inventory/ItemContainerTypes.ts +6 -6
  53. package/src/components/Item/Inventory/ItemQuantitySelector.tsx +138 -142
  54. package/src/components/Item/Inventory/ItemSlot.tsx +467 -501
  55. package/src/components/Item/Inventory/itemContainerHelper.ts +156 -156
  56. package/src/components/ListMenu.tsx +63 -63
  57. package/src/components/Multitab/Tab.tsx +66 -57
  58. package/src/components/Multitab/TabBody.tsx +13 -13
  59. package/src/components/Multitab/TabsContainer.tsx +97 -97
  60. package/src/components/NPCDialog/NPCDialog.tsx +121 -121
  61. package/src/components/NPCDialog/NPCDialogText.tsx +113 -113
  62. package/src/components/NPCDialog/NPCMultiDialog.tsx +159 -159
  63. package/src/components/NPCDialog/QuestionDialog/QuestionDialog.tsx +237 -237
  64. package/src/components/ProgressBar.tsx +92 -92
  65. package/src/components/PropertySelect/PropertySelect.tsx +106 -114
  66. package/src/components/QuestInfo/QuestInfo.tsx +230 -232
  67. package/src/components/QuestList.tsx +129 -129
  68. package/src/components/RPGUIContainer.tsx +47 -47
  69. package/src/components/RPGUIForceRenderStart.tsx +45 -45
  70. package/src/components/RPGUIRoot.tsx +14 -14
  71. package/src/components/RadioButton.tsx +53 -53
  72. package/src/components/RadioInput/RadioButton.tsx +96 -98
  73. package/src/components/RadioInput/RadioInput.tsx +102 -99
  74. package/src/components/RadioInput/instruments.ts +15 -15
  75. package/src/components/RangeSlider.tsx +78 -78
  76. package/src/components/RelativeListMenu.tsx +83 -83
  77. package/src/components/ScrollList.tsx +79 -79
  78. package/src/components/SimpleProgressBar.tsx +62 -62
  79. package/src/components/SkillProgressBar.tsx +133 -133
  80. package/src/components/SkillsContainer.tsx +198 -200
  81. package/src/components/Spellbook/QuickSpells.tsx +120 -0
  82. package/src/components/Spellbook/Spell.tsx +201 -201
  83. package/src/components/Spellbook/Spellbook.tsx +144 -150
  84. package/src/components/Spellbook/SpellbookShortcuts.tsx +77 -0
  85. package/src/components/Spellbook/constants.ts +12 -8
  86. package/src/components/Spellbook/mockSpells.ts +60 -60
  87. package/src/components/StaticBook/StaticBook.tsx +103 -105
  88. package/src/components/TextArea.tsx +11 -11
  89. package/src/components/TimeWidget/DayNightPeriod/DayNightPeriod.tsx +35 -35
  90. package/src/components/TimeWidget/TimeWidget.tsx +63 -63
  91. package/src/components/TradingMenu/TradingItemRow.tsx +193 -197
  92. package/src/components/TradingMenu/TradingMenu.tsx +203 -203
  93. package/src/components/TradingMenu/items.mock.ts +96 -96
  94. package/src/components/Truncate.tsx +25 -25
  95. package/src/components/itemSelector/ItemSelector.tsx +136 -136
  96. package/src/components/shared/Column.tsx +16 -16
  97. package/src/components/shared/Ellipsis.tsx +65 -65
  98. package/src/components/shared/SpriteFromAtlas.tsx +102 -102
  99. package/src/components/typography/DynamicText.tsx +49 -49
  100. package/src/constants/uiColors.ts +20 -20
  101. package/src/constants/uiDevices.ts +3 -3
  102. package/src/constants/uiFonts.ts +12 -12
  103. package/src/hooks/useEventListener.ts +21 -21
  104. package/src/hooks/useOutsideAlerter.ts +25 -25
  105. package/src/index.tsx +40 -40
  106. package/src/libs/StringHelpers.ts +3 -3
  107. package/src/mocks/atlas/entities/entities.json +20215 -20215
  108. package/src/mocks/atlas/icons/icons.json +735 -735
  109. package/src/mocks/atlas/items/items.json +12086 -12086
  110. package/src/mocks/equipmentSet.mocks.ts +393 -393
  111. package/src/mocks/itemContainer.mocks.ts +560 -562
  112. package/src/mocks/skills.mocks.ts +128 -128
  113. package/src/stories/Arrow.stories.tsx +26 -26
  114. package/src/stories/Button.stories.tsx +36 -36
  115. package/src/stories/CharacterSelection.stories.tsx +45 -45
  116. package/src/stories/CharacterStatus.stories.tsx +29 -29
  117. package/src/stories/Chat.stories.tsx +187 -187
  118. package/src/stories/ChatDeprecated.stories.tsx +170 -170
  119. package/src/stories/CheckButton.stories.tsx +48 -48
  120. package/src/stories/CircullarController.stories.tsx +33 -37
  121. package/src/stories/CraftBook.stories.tsx +40 -40
  122. package/src/stories/DayNightPeriod.stories.tsx +27 -27
  123. package/src/stories/DraggableContainer.stories.tsx +28 -28
  124. package/src/stories/Dropdown.stories.tsx +46 -46
  125. package/src/stories/DropdownSelectorContainer.stories.tsx +41 -41
  126. package/src/stories/EquipmentSet.stories.tsx +65 -65
  127. package/src/stories/HistoryDialog.stories.tsx +61 -61
  128. package/src/stories/ItemContainer.stories.tsx +124 -198
  129. package/src/stories/ItemQuantitySelector.stories.tsx +26 -26
  130. package/src/stories/ItemSelector.stories.tsx +77 -77
  131. package/src/stories/ItemTradingComponent.stories.tsx +35 -35
  132. package/src/stories/ListMenu.stories.tsx +56 -56
  133. package/src/stories/Multitab.stories.tsx +51 -51
  134. package/src/stories/NPCDialog.stories.tsx +130 -130
  135. package/src/stories/NPCMultiDialog.stories.tsx +71 -71
  136. package/src/stories/ProgressBar.stories.tsx +23 -23
  137. package/src/stories/PropertySelect.stories.tsx +40 -40
  138. package/src/stories/QuestInfo.stories.tsx +107 -107
  139. package/src/stories/QuestList.stories.tsx +82 -82
  140. package/src/stories/QuickSpells.stories.tsx +38 -0
  141. package/src/stories/RPGUIContainers.stories.tsx +42 -42
  142. package/src/stories/RadioButton.stories.tsx +49 -49
  143. package/src/stories/RadioInput.stories.tsx +34 -34
  144. package/src/stories/RangeSlider.stories.tsx +64 -64
  145. package/src/stories/ScrollList.stories.tsx +85 -85
  146. package/src/stories/SimpleProgressBar.stories.tsx +22 -22
  147. package/src/stories/SkillProgressBar.stories.tsx +34 -34
  148. package/src/stories/SkillsContainer.stories.tsx +35 -35
  149. package/src/stories/Spellbook.stories.tsx +107 -104
  150. package/src/stories/StaticBook.stories.tsx +32 -32
  151. package/src/stories/Text.stories.tsx +42 -42
  152. package/src/stories/TimeWidget.stories.tsx +27 -27
  153. package/src/stories/TradingMenu.stories.tsx +45 -45
  154. package/src/types/eventTypes.ts +4 -4
  155. package/src/types/index.d.ts +2 -2
  156. package/dist/components/Shortcuts/Shortcuts.d.ts +0 -12
  157. package/dist/components/Shortcuts/ShortcutsSetter.d.ts +0 -12
  158. package/dist/components/Shortcuts/SingleShortcut.d.ts +0 -1
  159. package/src/components/Shortcuts/Shortcuts.tsx +0 -129
  160. package/src/components/Shortcuts/ShortcutsSetter.tsx +0 -132
  161. package/src/components/Shortcuts/SingleShortcut.ts +0 -61
  162. package/src/stories/Shortcuts.stories.tsx +0 -39
@@ -1,98 +1,96 @@
1
- import { capitalize } from 'lodash';
2
- import React from 'react';
3
- import styled from 'styled-components';
4
- import { uiColors } from '../../constants/uiColors';
5
- import { Ellipsis } from '../shared/Ellipsis';
6
-
7
- export interface IRadioProps {
8
- title:string,
9
- subtitle:string,
10
- instrument:string|null
11
- setInstrument: (value: string) => void;
12
- }
13
-
14
- export const RadioButton: React.FC<IRadioProps> = ({
15
- title,
16
- subtitle,
17
- instrument,
18
- setInstrument,
19
- }) => {
20
- const isRadioSelected=(value:string):boolean=>instrument===value;
21
-
22
- const handleClick = (e:string):void => {
23
- setInstrument(e)
24
- };
25
-
26
- return (
27
- <ItemWrapper onClick={() => handleClick(title)} >
28
- <ItemIconContainer>
29
- <SpriteContainer id='elemento-radio'>
30
- <input
31
- type='radio'
32
- name='react-radio-btn'
33
- className='rpgui-radio'
34
- value={title}
35
- checked={isRadioSelected(title)}
36
- onChange={(e)=>(e)}
37
- />
38
- </SpriteContainer>
39
- </ItemIconContainer>
40
- <ItemNameContainer>
41
- <NameValue onClick={() => handleClick(title)}>
42
- <p>{title}</p>
43
- <p>
44
- <Ellipsis maxLines={1} maxWidth="250px">
45
- {capitalize(subtitle)}
46
- </Ellipsis>
47
- </p>
48
-
49
- </NameValue>
50
- </ItemNameContainer>
51
- </ItemWrapper>
52
- );
53
- };
54
-
55
- const ItemWrapper = styled.div`
56
- width: 100%;
57
- margin: auto;
58
- display: flex;
59
- justify-content: space-between;
60
- margin-bottom: 1rem;
61
-
62
- &:hover {
63
- background-color: ${uiColors.darkGray};
64
- }
65
- padding: 0.5rem;
66
- `;
67
-
68
-
69
- const ItemNameContainer = styled.div`
70
- flex: 80%;
71
- `;
72
-
73
- const ItemIconContainer = styled.div`
74
- display: flex;
75
- justify-content: flex-start;
76
- align-items: center;
77
-
78
- flex: 0 0 58px;
79
- `;
80
-
81
- const SpriteContainer = styled.div`
82
- input {
83
- display:block !important;
84
- &:hover {
85
- cursor: pointer;
86
- }
87
- };
88
- position: relative;
89
- top: -0.5rem;
90
- left: 0.5rem;
91
- `;
92
-
93
- const NameValue = styled.div`
94
- p {
95
- font-size: 0.75rem;
96
- margin: 0;
97
- }
98
- `;
1
+ import { capitalize } from 'lodash';
2
+ import React from 'react';
3
+ import styled from 'styled-components';
4
+ import { uiColors } from '../../constants/uiColors';
5
+ import { Ellipsis } from '../shared/Ellipsis';
6
+
7
+ export interface IRadioProps {
8
+ title: string;
9
+ subtitle: string;
10
+ instrument: string | null;
11
+ setInstrument: (value: string) => void;
12
+ }
13
+
14
+ export const RadioButton: React.FC<IRadioProps> = ({
15
+ title,
16
+ subtitle,
17
+ instrument,
18
+ setInstrument,
19
+ }) => {
20
+ const isRadioSelected = (value: string): boolean => instrument === value;
21
+
22
+ const handleClick = (e: string): void => {
23
+ setInstrument(e);
24
+ };
25
+
26
+ return (
27
+ <ItemWrapper onPointerDown={() => handleClick(title)}>
28
+ <ItemIconContainer>
29
+ <SpriteContainer id="elemento-radio">
30
+ <input
31
+ type="radio"
32
+ name="react-radio-btn"
33
+ className="rpgui-radio"
34
+ value={title}
35
+ checked={isRadioSelected(title)}
36
+ onChange={e => e}
37
+ />
38
+ </SpriteContainer>
39
+ </ItemIconContainer>
40
+ <ItemNameContainer>
41
+ <NameValue onPointerDown={() => handleClick(title)}>
42
+ <p>{title}</p>
43
+ <p>
44
+ <Ellipsis maxLines={1} maxWidth="250px">
45
+ {capitalize(subtitle)}
46
+ </Ellipsis>
47
+ </p>
48
+ </NameValue>
49
+ </ItemNameContainer>
50
+ </ItemWrapper>
51
+ );
52
+ };
53
+
54
+ const ItemWrapper = styled.div`
55
+ width: 100%;
56
+ margin: auto;
57
+ display: flex;
58
+ justify-content: space-between;
59
+ margin-bottom: 1rem;
60
+
61
+ &:hover {
62
+ background-color: ${uiColors.darkGray};
63
+ }
64
+ padding: 0.5rem;
65
+ `;
66
+
67
+ const ItemNameContainer = styled.div`
68
+ flex: 80%;
69
+ `;
70
+
71
+ const ItemIconContainer = styled.div`
72
+ display: flex;
73
+ justify-content: flex-start;
74
+ align-items: center;
75
+
76
+ flex: 0 0 58px;
77
+ `;
78
+
79
+ const SpriteContainer = styled.div`
80
+ input {
81
+ display: block !important;
82
+ &:hover {
83
+ cursor: pointer;
84
+ }
85
+ }
86
+ position: relative;
87
+ top: -0.5rem;
88
+ left: 0.5rem;
89
+ `;
90
+
91
+ const NameValue = styled.div`
92
+ p {
93
+ font-size: 0.75rem;
94
+ margin: 0;
95
+ }
96
+ `;
@@ -1,99 +1,102 @@
1
- import React, { useState } from 'react';
2
- import styled from 'styled-components';
3
- import { DraggableContainer } from '../DraggableContainer';
4
- import { RPGUIContainerTypes } from '../RPGUIContainer';
5
- import { Button, ButtonTypes } from '../Button';
6
- import { RadioButton } from './RadioButton';
7
-
8
- export interface IRadioItems {
9
- title: string;
10
- subtitle: string;
11
- }
12
- export interface IRadioInput {
13
- title:string,
14
- subtitle:string,
15
- onSelect:(a:string)=>void,
16
- onCancel:()=>void,
17
- items:IRadioItems[]
18
- }
19
-
20
- export const RadioInput: React.FC<IRadioInput>=({title,subtitle,onSelect,onCancel,items})=>{
21
- const [instrument, setInstrument] = useState('')
22
-
23
- const confirHandler=()=>{
24
- if(instrument){
25
- onSelect(instrument)
26
- }
27
- }
28
-
29
- return (
30
- <DraggableContainer
31
- type={RPGUIContainerTypes.Framed}
32
- onCloseButton={() => {
33
- if (onCancel) onCancel();
34
- }}
35
- width="500px"
36
- cancelDrag=".equipment-container-body .arrow-selector"
37
- >
38
- <>
39
- <div style={{ width: '100%' }}>
40
- <Title>{title}</Title>
41
- <Subtitle>{subtitle}</Subtitle>
42
- <hr className="golden" />
43
- </div>
44
- <RadioInputScroller>{
45
- items.map((item,index)=>(
46
- <RadioButton
47
- key={`${item.title}_${index}`}
48
- title={item.title}
49
- subtitle={item.subtitle}
50
- setInstrument={setInstrument}
51
- instrument={instrument}
52
- />
53
- ))
54
- }
55
- </RadioInputScroller>
56
- <ButtonWrapper>
57
- <Button
58
- buttonType={ButtonTypes.RPGUIButton}
59
- onClick={() => onCancel()}
60
- >
61
- Cancel
62
- </Button>
63
- <Button
64
- buttonType={ButtonTypes.RPGUIButton}
65
- onClick={ confirHandler}
66
- >
67
- Select
68
- </Button>
69
-
70
- </ButtonWrapper>
71
-
72
- </>
73
- </DraggableContainer>
74
- )
75
- }
76
- const RadioInputScroller = styled.div`
77
- overflow-y: scroll;
78
- height: 390px;
79
- width: 100%;
80
- margin-top: 1rem;
81
- `;
82
-
83
- const Title = styled.h1`
84
- z-index: 22;
85
- font-size: 0.6rem;
86
- color: yellow !important;
87
- `;
88
- const Subtitle = styled.h1`
89
- z-index: 22;
90
- font-size: 0.4rem;
91
- color: yellow !important;
92
- `;
93
- const ButtonWrapper = styled.div`
94
- display: flex;
95
- justify-content: flex-end;
96
- padding-top: 20px;
97
- width: 100%;
98
- margin-top: 1rem;
99
- `;
1
+ import React, { useState } from 'react';
2
+ import styled from 'styled-components';
3
+ import { Button, ButtonTypes } from '../Button';
4
+ import { DraggableContainer } from '../DraggableContainer';
5
+ import { RPGUIContainerTypes } from '../RPGUIContainer';
6
+ import { RadioButton } from './RadioButton';
7
+
8
+ export interface IRadioItems {
9
+ title: string;
10
+ subtitle: string;
11
+ }
12
+ export interface IRadioInput {
13
+ title: string;
14
+ subtitle: string;
15
+ onSelect: (a: string) => void;
16
+ onCancel: () => void;
17
+ items: IRadioItems[];
18
+ }
19
+
20
+ export const RadioInput: React.FC<IRadioInput> = ({
21
+ title,
22
+ subtitle,
23
+ onSelect,
24
+ onCancel,
25
+ items,
26
+ }) => {
27
+ const [instrument, setInstrument] = useState('');
28
+
29
+ const confirHandler = () => {
30
+ if (instrument) {
31
+ onSelect(instrument);
32
+ }
33
+ };
34
+
35
+ return (
36
+ <DraggableContainer
37
+ type={RPGUIContainerTypes.Framed}
38
+ onCloseButton={() => {
39
+ if (onCancel) onCancel();
40
+ }}
41
+ width="500px"
42
+ cancelDrag=".equipment-container-body .arrow-selector"
43
+ >
44
+ <>
45
+ <div style={{ width: '100%' }}>
46
+ <Title>{title}</Title>
47
+ <Subtitle>{subtitle}</Subtitle>
48
+ <hr className="golden" />
49
+ </div>
50
+ <RadioInputScroller>
51
+ {items.map((item, index) => (
52
+ <RadioButton
53
+ key={`${item.title}_${index}`}
54
+ title={item.title}
55
+ subtitle={item.subtitle}
56
+ setInstrument={setInstrument}
57
+ instrument={instrument}
58
+ />
59
+ ))}
60
+ </RadioInputScroller>
61
+ <ButtonWrapper>
62
+ <Button
63
+ buttonType={ButtonTypes.RPGUIButton}
64
+ onPointerDown={() => onCancel()}
65
+ >
66
+ Cancel
67
+ </Button>
68
+ <Button
69
+ buttonType={ButtonTypes.RPGUIButton}
70
+ onPointerDown={confirHandler}
71
+ >
72
+ Select
73
+ </Button>
74
+ </ButtonWrapper>
75
+ </>
76
+ </DraggableContainer>
77
+ );
78
+ };
79
+ const RadioInputScroller = styled.div`
80
+ overflow-y: scroll;
81
+ height: 390px;
82
+ width: 100%;
83
+ margin-top: 1rem;
84
+ `;
85
+
86
+ const Title = styled.h1`
87
+ z-index: 22;
88
+ font-size: 0.6rem;
89
+ color: yellow !important;
90
+ `;
91
+ const Subtitle = styled.h1`
92
+ z-index: 22;
93
+ font-size: 0.4rem;
94
+ color: yellow !important;
95
+ `;
96
+ const ButtonWrapper = styled.div`
97
+ display: flex;
98
+ justify-content: flex-end;
99
+ padding-top: 20px;
100
+ width: 100%;
101
+ margin-top: 1rem;
102
+ `;
@@ -1,16 +1,16 @@
1
-
2
- export const Itools:{title:string,subtitle:string}[] = [
3
- {
4
- title : 'Ax',
5
- subtitle:'Cut down trees',
6
- }, {
7
- title : 'Sawing',
8
- subtitle:'cut the wood into small pieces',
9
- }, {
10
- title : 'Sickle',
11
- subtitle:'harvesting cereal plants',
12
- }, {
13
- title : 'Bow',
14
- subtitle:'Hunting monsters',
15
- },
1
+
2
+ export const Itools:{title:string,subtitle:string}[] = [
3
+ {
4
+ title : 'Ax',
5
+ subtitle:'Cut down trees',
6
+ }, {
7
+ title : 'Sawing',
8
+ subtitle:'cut the wood into small pieces',
9
+ }, {
10
+ title : 'Sickle',
11
+ subtitle:'harvesting cereal plants',
12
+ }, {
13
+ title : 'Bow',
14
+ subtitle:'Hunting monsters',
15
+ },
16
16
  ];
@@ -1,78 +1,78 @@
1
- import React, { useEffect, useRef, useState } from 'react';
2
- import styled from 'styled-components';
3
- import { v4 as uuidv4 } from 'uuid';
4
-
5
- export enum RangeSliderType {
6
- Slider = 'rpgui-slider',
7
- GoldSlider = 'rpgui-slider golden',
8
- }
9
-
10
- export interface IRangeSliderProps {
11
- type: RangeSliderType;
12
- valueMin: number;
13
- valueMax: number;
14
- width: string;
15
- onChange: (value: number) => void;
16
- value: number;
17
- }
18
-
19
- export const RangeSlider: React.FC<IRangeSliderProps> = ({
20
- type,
21
- valueMin,
22
- valueMax,
23
- width,
24
- onChange,
25
- value,
26
- }) => {
27
- const sliderId = uuidv4();
28
-
29
- const containerRef = useRef<HTMLDivElement>(null);
30
- const [left, setLeft] = useState(0);
31
-
32
- useEffect(() => {
33
- const calculatedWidth = containerRef.current?.clientWidth || 0;
34
- setLeft(
35
- Math.max(
36
- ((value - valueMin) / (valueMax - valueMin)) * (calculatedWidth - 35) +
37
- 10
38
- )
39
- );
40
- }, [value, valueMin, valueMax]);
41
-
42
- const typeClass = type === RangeSliderType.GoldSlider ? 'golden' : '';
43
-
44
- return (
45
- <div
46
- style={{ width: width, position: 'relative' }}
47
- className={`rpgui-slider-container ${typeClass}`}
48
- id={`rpgui-slider-${sliderId}`}
49
- ref={containerRef}
50
- >
51
- <div style={{ pointerEvents: 'none' }}>
52
- <div className={`rpgui-slider-track ${typeClass}`} />
53
- <div className={`rpgui-slider-left-edge ${typeClass}`} />
54
- <div className={`rpgui-slider-right-edge ${typeClass}`} />
55
- <div className={`rpgui-slider-thumb ${typeClass}`} style={{ left }} />
56
- </div>
57
- <Input
58
- type="range"
59
- style={{ width: width }}
60
- min={valueMin}
61
- max={valueMax}
62
- onChange={e => onChange(Number(e.target.value))}
63
- value={value}
64
- className="rpgui-cursor-point"
65
- />
66
- </div>
67
- );
68
- };
69
-
70
- const Input = styled.input`
71
- opacity: 0;
72
- position: absolute;
73
- width: 100%;
74
- height: 100%;
75
- top: 0;
76
- left: 0;
77
- margin-top: -5px;
78
- `;
1
+ import React, { useEffect, useRef, useState } from 'react';
2
+ import styled from 'styled-components';
3
+ import { v4 as uuidv4 } from 'uuid';
4
+
5
+ export enum RangeSliderType {
6
+ Slider = 'rpgui-slider',
7
+ GoldSlider = 'rpgui-slider golden',
8
+ }
9
+
10
+ export interface IRangeSliderProps {
11
+ type: RangeSliderType;
12
+ valueMin: number;
13
+ valueMax: number;
14
+ width: string;
15
+ onChange: (value: number) => void;
16
+ value: number;
17
+ }
18
+
19
+ export const RangeSlider: React.FC<IRangeSliderProps> = ({
20
+ type,
21
+ valueMin,
22
+ valueMax,
23
+ width,
24
+ onChange,
25
+ value,
26
+ }) => {
27
+ const sliderId = uuidv4();
28
+
29
+ const containerRef = useRef<HTMLDivElement>(null);
30
+ const [left, setLeft] = useState(0);
31
+
32
+ useEffect(() => {
33
+ const calculatedWidth = containerRef.current?.clientWidth || 0;
34
+ setLeft(
35
+ Math.max(
36
+ ((value - valueMin) / (valueMax - valueMin)) * (calculatedWidth - 35) +
37
+ 10
38
+ )
39
+ );
40
+ }, [value, valueMin, valueMax]);
41
+
42
+ const typeClass = type === RangeSliderType.GoldSlider ? 'golden' : '';
43
+
44
+ return (
45
+ <div
46
+ style={{ width: width, position: 'relative' }}
47
+ className={`rpgui-slider-container ${typeClass}`}
48
+ id={`rpgui-slider-${sliderId}`}
49
+ ref={containerRef}
50
+ >
51
+ <div style={{ pointerEvents: 'none' }}>
52
+ <div className={`rpgui-slider-track ${typeClass}`} />
53
+ <div className={`rpgui-slider-left-edge ${typeClass}`} />
54
+ <div className={`rpgui-slider-right-edge ${typeClass}`} />
55
+ <div className={`rpgui-slider-thumb ${typeClass}`} style={{ left }} />
56
+ </div>
57
+ <Input
58
+ type="range"
59
+ style={{ width: width }}
60
+ min={valueMin}
61
+ max={valueMax}
62
+ onChange={e => onChange(Number(e.target.value))}
63
+ value={value}
64
+ className="rpgui-cursor-point"
65
+ />
66
+ </div>
67
+ );
68
+ };
69
+
70
+ const Input = styled.input`
71
+ opacity: 0;
72
+ position: absolute;
73
+ width: 100%;
74
+ height: 100%;
75
+ top: 0;
76
+ left: 0;
77
+ margin-top: -5px;
78
+ `;