norma-library 0.6.65 → 0.6.66

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 (165) hide show
  1. package/.babelrc.json +18 -18
  2. package/.prettierignore +10 -10
  3. package/.prettierrc.json +20 -20
  4. package/.storybook/main.ts +20 -20
  5. package/.storybook/preview.ts +15 -15
  6. package/README.md +43 -43
  7. package/commitlint.config.js +1 -1
  8. package/dist/esm/components/Card.js +3 -3
  9. package/dist/esm/components/Card.js.map +1 -1
  10. package/docs/index.md +118 -118
  11. package/package.json +136 -136
  12. package/src/components/Accordion.tsx +39 -39
  13. package/src/components/Avatar.tsx +17 -17
  14. package/src/components/Badge.tsx +14 -14
  15. package/src/components/Box/index.tsx +12 -12
  16. package/src/components/Box/interfaces.ts +3 -3
  17. package/src/components/Box/styles.tsx +22 -22
  18. package/src/components/Breadcrumb/index.tsx +27 -27
  19. package/src/components/Breadcrumb/interface.ts +8 -8
  20. package/src/components/Breadcrumb/styles.tsx +32 -32
  21. package/src/components/Button.tsx +26 -26
  22. package/src/components/Card.tsx +38 -38
  23. package/src/components/ChatMessage.tsx +87 -87
  24. package/src/components/ChatMessageBalloon/ChatMessageBalloon.style.ts +56 -56
  25. package/src/components/ChatMessageBalloon/ChatMessageBalloon.tsx +55 -55
  26. package/src/components/CheckBox.tsx +21 -21
  27. package/src/components/DateInput/index.tsx +34 -34
  28. package/src/components/DateInput/interface.ts +13 -13
  29. package/src/components/DateInput/styles.tsx +27 -27
  30. package/src/components/DatePicker.tsx +67 -67
  31. package/src/components/DropDown.tsx +24 -24
  32. package/src/components/IconButton.tsx +37 -37
  33. package/src/components/Icons.tsx +82 -82
  34. package/src/components/Modal.tsx +103 -103
  35. package/src/components/MultiSelectInput/components/MultiValue/index.tsx +44 -44
  36. package/src/components/MultiSelectInput/components/Option/index.tsx +62 -62
  37. package/src/components/MultiSelectInput/components/Option/styles.tsx +8 -8
  38. package/src/components/MultiSelectInput/index.tsx +60 -60
  39. package/src/components/MultiSelectInput/interfaces.ts +15 -15
  40. package/src/components/MultiSelectInput/styles.tsx +43 -43
  41. package/src/components/Paper.tsx +12 -12
  42. package/src/components/ProgressBar.tsx +71 -71
  43. package/src/components/RadioGroup.tsx +43 -43
  44. package/src/components/RangerSlider.tsx +65 -65
  45. package/src/components/Select.tsx +74 -74
  46. package/src/components/SelectInput/components/Option/index.tsx +61 -61
  47. package/src/components/SelectInput/components/Option/styles.tsx +8 -8
  48. package/src/components/SelectInput/index.tsx +45 -45
  49. package/src/components/SelectInput/interfaces.ts +15 -15
  50. package/src/components/SelectInput/styles.tsx +31 -31
  51. package/src/components/StatusModal/StatusModal.style.tsx +75 -75
  52. package/src/components/StatusModal/StatusModal.tsx +58 -58
  53. package/src/components/Svgs.tsx +506 -506
  54. package/src/components/Table/components/header/index.tsx +86 -86
  55. package/src/components/Table/components/header/styles.tsx +59 -59
  56. package/src/components/Table/components/index.tsx +8 -8
  57. package/src/components/Table/components/pagination/index.tsx +39 -39
  58. package/src/components/Table/components/pagination/styles.tsx +28 -28
  59. package/src/components/Table/components/tbody/index.tsx +30 -30
  60. package/src/components/Table/components/tbody/styles.tsx +4 -4
  61. package/src/components/Table/index.tsx +317 -317
  62. package/src/components/Table/interface.ts +23 -23
  63. package/src/components/Table/styles.tsx +117 -117
  64. package/src/components/Tabs.tsx +105 -105
  65. package/src/components/Tag.tsx +33 -33
  66. package/src/components/TextField.tsx +19 -19
  67. package/src/components/TextInput/index.tsx +37 -37
  68. package/src/components/TextInput/interface.ts +9 -9
  69. package/src/components/TextInput/styles.tsx +23 -23
  70. package/src/components/TimeLine.tsx +89 -89
  71. package/src/components/TimePicker.tsx +78 -78
  72. package/src/components/Typography/Text/index.tsx +20 -20
  73. package/src/components/Typography/Text/interfaces.ts +5 -5
  74. package/src/components/Typography/Text/styles.tsx +40 -40
  75. package/src/components/Typography/Title/index.tsx +22 -22
  76. package/src/components/Typography/Title/interfaces.ts +6 -6
  77. package/src/components/Typography/Title/styles.tsx +40 -40
  78. package/src/components/Typography/index.tsx +6 -6
  79. package/src/components/UncontrolledTable/components/header/index.tsx +72 -72
  80. package/src/components/UncontrolledTable/components/header/styles.tsx +66 -66
  81. package/src/components/UncontrolledTable/components/index.tsx +8 -8
  82. package/src/components/UncontrolledTable/components/pagination/index.tsx +43 -43
  83. package/src/components/UncontrolledTable/components/pagination/styles.tsx +28 -28
  84. package/src/components/UncontrolledTable/components/tbody/index.tsx +33 -33
  85. package/src/components/UncontrolledTable/components/tbody/styles.tsx +32 -32
  86. package/src/components/UncontrolledTable/index.tsx +223 -223
  87. package/src/components/UncontrolledTable/interface.ts +46 -46
  88. package/src/components/UncontrolledTable/styles.tsx +123 -123
  89. package/src/components/UncontrolledTabs/UncontrolledTabs.style.tsx +58 -58
  90. package/src/components/UncontrolledTabs/UncontrolledTabs.tsx +71 -71
  91. package/src/components/UncontrolledTabs/UncontrolledTabsInfo.style.ts +8 -8
  92. package/src/components/index.ts +24 -24
  93. package/src/helpers/alignments.ts +14 -14
  94. package/src/helpers/borders.ts +18 -18
  95. package/src/helpers/colors.ts +264 -264
  96. package/src/helpers/index.ts +5 -5
  97. package/src/helpers/radios.ts +24 -24
  98. package/src/helpers/sizes.ts +72 -72
  99. package/src/hooks/useClickOutside.tsx +18 -18
  100. package/src/index.ts +70 -70
  101. package/src/interfaces/Accordion.ts +12 -12
  102. package/src/interfaces/Avatar.tsx +15 -15
  103. package/src/interfaces/Badge.ts +19 -19
  104. package/src/interfaces/Button.ts +19 -19
  105. package/src/interfaces/Card.ts +11 -11
  106. package/src/interfaces/ChatMessage.ts +12 -12
  107. package/src/interfaces/ChatMessageBalloon.ts +17 -17
  108. package/src/interfaces/CheckBox.ts +27 -27
  109. package/src/interfaces/DatePicker.ts +13 -13
  110. package/src/interfaces/DropDown.ts +14 -14
  111. package/src/interfaces/IconButton.ts +22 -22
  112. package/src/interfaces/Icons.ts +17 -17
  113. package/src/interfaces/Modal.ts +18 -18
  114. package/src/interfaces/Paper.ts +12 -12
  115. package/src/interfaces/ProgressBar.ts +29 -29
  116. package/src/interfaces/RadioGroup.ts +23 -23
  117. package/src/interfaces/RangerSlider.ts +21 -21
  118. package/src/interfaces/Select.ts +17 -17
  119. package/src/interfaces/Tabs.ts +19 -19
  120. package/src/interfaces/Tag.ts +17 -17
  121. package/src/interfaces/TextField.ts +44 -44
  122. package/src/interfaces/TimeLine.ts +11 -11
  123. package/src/interfaces/TimePicker.ts +13 -13
  124. package/src/interfaces/index.ts +23 -23
  125. package/src/providers/NormaProvider.tsx +13 -13
  126. package/src/sample-data-2.json +178 -178
  127. package/src/sample-data.json +177 -177
  128. package/src/stories/Accordion.stories.tsx +65 -65
  129. package/src/stories/Avatar.stories.tsx +123 -123
  130. package/src/stories/Badge.stories.tsx +39 -39
  131. package/src/stories/Box.stories.tsx +35 -35
  132. package/src/stories/Breadcrumb.stories.tsx +44 -44
  133. package/src/stories/Button.stories.tsx +93 -93
  134. package/src/stories/Card.stories.tsx +39 -39
  135. package/src/stories/ChatMessage.stories.tsx +84 -84
  136. package/src/stories/ChatMessageBalloon.stories.tsx +108 -108
  137. package/src/stories/CheckBox.stories.tsx +88 -88
  138. package/src/stories/DateInput.stories.tsx +51 -51
  139. package/src/stories/DatePicker.stories.tsx +50 -50
  140. package/src/stories/DropDown.stories.tsx +57 -57
  141. package/src/stories/IconButton.stories.tsx +78 -78
  142. package/src/stories/Modal.stories.tsx +246 -246
  143. package/src/stories/ModalStatus.stories.tsx +46 -46
  144. package/src/stories/MultiSelectInput.stories.tsx +90 -90
  145. package/src/stories/Paper.stories.tsx +53 -53
  146. package/src/stories/ProgressBar.stories.tsx +116 -116
  147. package/src/stories/RadioGroup.stories.tsx +87 -87
  148. package/src/stories/RangerSlider.stories.tsx +149 -149
  149. package/src/stories/Select.stories.tsx +100 -100
  150. package/src/stories/SelectInput.stories.tsx +78 -78
  151. package/src/stories/Table.stories.tsx +372 -372
  152. package/src/stories/Tabs.stories.tsx +61 -61
  153. package/src/stories/Tag.stories.tsx +56 -56
  154. package/src/stories/Text.stories.tsx +37 -37
  155. package/src/stories/TextField.stories.tsx +310 -310
  156. package/src/stories/TextInput.stories.tsx +52 -52
  157. package/src/stories/TimeLine.stories.tsx +35 -35
  158. package/src/stories/TimePicker.stories.tsx +87 -87
  159. package/src/stories/Title.stories.tsx +43 -43
  160. package/src/stories/UncontrolledTable.stories.tsx +315 -315
  161. package/src/stories/UncontrolledTabs.stories.tsx +74 -74
  162. package/src/styles/globals.scss +17 -17
  163. package/src/types/index.ts +207 -207
  164. package/src/utils/styledBreakpoints.ts +25 -25
  165. package/vite.config.ts +15 -15
@@ -1,26 +1,26 @@
1
- import React from 'react';
2
- import { Button as MuiButton } from '@mui/material';
3
- import { ButtonBaseProps } from '../interfaces';
4
- import { styled } from '@mui/material/styles';
5
-
6
- const ButtonStyled = styled(MuiButton)({
7
- textTransform: 'none',
8
- '& .MuiButton-sizeLarge': {
9
- height: '75px',
10
- backgroundColor: 'red',
11
- },
12
- });
13
-
14
- export const Button = ({ label, children, ...props }: ButtonBaseProps) => {
15
-
16
- return (
17
- <ButtonStyled
18
- {...props}
19
- sx={{
20
- color: props.variant === 'contained' ? '#FFFF' : props.color,
21
- }}
22
- >
23
- {label ? label : children}
24
- </ButtonStyled>
25
- );
26
- };
1
+ import React from 'react';
2
+ import { Button as MuiButton } from '@mui/material';
3
+ import { ButtonBaseProps } from '../interfaces';
4
+ import { styled } from '@mui/material/styles';
5
+
6
+ const ButtonStyled = styled(MuiButton)({
7
+ textTransform: 'none',
8
+ '& .MuiButton-sizeLarge': {
9
+ height: '75px',
10
+ backgroundColor: 'red',
11
+ },
12
+ });
13
+
14
+ export const Button = ({ label, children, ...props }: ButtonBaseProps) => {
15
+
16
+ return (
17
+ <ButtonStyled
18
+ {...props}
19
+ sx={{
20
+ color: props.variant === 'contained' ? '#FFFF' : props.color,
21
+ }}
22
+ >
23
+ {label ? label : children}
24
+ </ButtonStyled>
25
+ );
26
+ };
@@ -1,38 +1,38 @@
1
- import React from 'react';
2
- import { Card as MuiCard } from '@mui/material';
3
- import { CardBaseProps } from '../interfaces';
4
- import { palette } from '../helpers';
5
- import { styled } from '@mui/material/styles';
6
- import { ColorVariant } from '@/types';
7
-
8
- const colorMap: Record<ColorVariant, string> = {
9
- inherit: palette.inherit,
10
- primary: palette.primary,
11
- secondary: palette.secondary,
12
- error: palette.error,
13
- warning: palette.warning,
14
- info: palette.info,
15
- success: palette.success,
16
- };
17
-
18
- const CardStyled = styled(MuiCard)<{
19
- borderColor?: ColorVariant;
20
- }>(({ borderColor }) => ({
21
- padding: 16,
22
- borderRadius: 5,
23
- boxShadow: '0px 2px 8px #00000053',
24
- borderLeft: borderColor ? `7px solid ${colorMap[borderColor]}` : 'none',
25
- }));
26
-
27
- export const Card = ({
28
- children,
29
- border,
30
- color = 'inherit',
31
- ...props
32
- }: CardBaseProps & { border?: boolean; color?: ColorVariant }) => {
33
- return (
34
- <CardStyled borderColor={border ? color : undefined} {...props}>
35
- {children}
36
- </CardStyled>
37
- );
38
- };
1
+ import React from 'react';
2
+ import { Card as MuiCard } from '@mui/material';
3
+ import { CardBaseProps } from '../interfaces';
4
+ import { palette } from '../helpers';
5
+ import { styled } from '@mui/material/styles';
6
+ import { ColorVariant } from '@/types';
7
+
8
+ const colorMap: Record<ColorVariant, string> = {
9
+ inherit: palette.inherit,
10
+ primary: palette.primary,
11
+ secondary: palette.secondary,
12
+ error: palette.error,
13
+ warning: palette.warning,
14
+ info: palette.info,
15
+ success: palette.success,
16
+ };
17
+
18
+ const CardStyled = styled(MuiCard)<{
19
+ $borderColor?: ColorVariant;
20
+ }>(({ $borderColor }) => ({
21
+ padding: 16,
22
+ borderRadius: 5,
23
+ boxShadow: '0px 2px 8px #00000053',
24
+ borderLeft: $borderColor ? `7px solid ${colorMap[$borderColor]}` : 'none',
25
+ }));
26
+
27
+ export const Card = ({
28
+ children,
29
+ border,
30
+ color = 'inherit',
31
+ ...props
32
+ }: CardBaseProps & { border?: boolean; color?: ColorVariant }) => {
33
+ return (
34
+ <CardStyled $borderColor={border ? color : undefined} {...props}>
35
+ {children}
36
+ </CardStyled>
37
+ );
38
+ };
@@ -1,87 +1,87 @@
1
- import React from 'react';
2
- import { Box, Typography } from '@mui/material';
3
- import { styled } from '@mui/material/styles';
4
- import { ChatMessageProps } from '@/interfaces';
5
-
6
- const Item = styled(Box)<{
7
- orient?: string;
8
- }>(({ orient }) => ({
9
- borderColor: '#ccc',
10
- display: 'flex',
11
- position: 'relative',
12
- width: '100%',
13
- justifyContent: orient === 'replay' ? 'flex-end' : 'flex-start',
14
- marginBottom: '10px',
15
- alignItems: 'center',
16
- }));
17
-
18
- const ContainerStyled = styled(Box)({
19
- display: 'flex',
20
- flexDirection: 'column',
21
- alignItems: 'center',
22
- minWidth: '640px',
23
- backgroundColor: '#F0F0F0',
24
- padding: '10px',
25
- });
26
-
27
- const BoxStyled = styled(Box)<{
28
- orient?: string;
29
- }>(({ orient }) => ({
30
- width: '70%',
31
- backgroundColor: orient === 'replay' ? '#E18B50' : '#FFF',
32
- color: orient === 'replay' ? '#FFF' : '#4D4F5C',
33
- borderTopLeftRadius: 30,
34
- borderTopRightRadius: 30,
35
- borderBottomLeftRadius: orient === 'me' ? 2 : 30,
36
- borderBottomRightRadius: orient === 'me' ? 30 : 2,
37
- marginLeft: orient === 'replay' ? '10px' : 0,
38
- marginRight: orient === 'me' ? '10px' : 0,
39
- padding: 20,
40
- }));
41
-
42
- export const ChatMessage: React.FC<ChatMessageProps> = ({ data }) => {
43
- return (
44
- <ContainerStyled>
45
- {data.map((item, key) => (
46
- <Item key={key} orient={item.send}>
47
- {item.emotion && item.send === 'replay' && <>{item.emotion}</>}
48
- <BoxStyled orient={item.send}>
49
- <Typography
50
- variant="subtitle2"
51
- style={{
52
- marginBottom: '5px',
53
- font: 'normal normal 600 16px/20px Source Sans Pro',
54
- }}
55
- >
56
- {item.name}
57
- </Typography>
58
- <Typography
59
- variant="body1"
60
- style={{
61
- font: 'normal normal normal 16px/20px Source Sans Pro',
62
- }}
63
- >
64
- {item.message}
65
- </Typography>
66
- <Typography
67
- variant="caption"
68
- style={{
69
- position: 'absolute',
70
- bottom: '-18px',
71
- left: item.send === 'me' ? 0 : 'auto',
72
- right: item.send === 'me' ? 'auto' : 0,
73
- font: 'normal normal normal 11px/13px Source Sans Pro',
74
- opacity: 0.5,
75
- color: '#4D4F5C',
76
- }}
77
- >
78
- {item.time}
79
- </Typography>
80
- </BoxStyled>
81
- {item.emotion && item.send === 'me' && <>{item.emotion}</>}
82
- {item.emotionReplay && item.send === 'me' && <>{item.emotionReplay}</>}
83
- </Item>
84
- ))}
85
- </ContainerStyled>
86
- );
87
- };
1
+ import React from 'react';
2
+ import { Box, Typography } from '@mui/material';
3
+ import { styled } from '@mui/material/styles';
4
+ import { ChatMessageProps } from '@/interfaces';
5
+
6
+ const Item = styled(Box)<{
7
+ orient?: string;
8
+ }>(({ orient }) => ({
9
+ borderColor: '#ccc',
10
+ display: 'flex',
11
+ position: 'relative',
12
+ width: '100%',
13
+ justifyContent: orient === 'replay' ? 'flex-end' : 'flex-start',
14
+ marginBottom: '10px',
15
+ alignItems: 'center',
16
+ }));
17
+
18
+ const ContainerStyled = styled(Box)({
19
+ display: 'flex',
20
+ flexDirection: 'column',
21
+ alignItems: 'center',
22
+ minWidth: '640px',
23
+ backgroundColor: '#F0F0F0',
24
+ padding: '10px',
25
+ });
26
+
27
+ const BoxStyled = styled(Box)<{
28
+ orient?: string;
29
+ }>(({ orient }) => ({
30
+ width: '70%',
31
+ backgroundColor: orient === 'replay' ? '#E18B50' : '#FFF',
32
+ color: orient === 'replay' ? '#FFF' : '#4D4F5C',
33
+ borderTopLeftRadius: 30,
34
+ borderTopRightRadius: 30,
35
+ borderBottomLeftRadius: orient === 'me' ? 2 : 30,
36
+ borderBottomRightRadius: orient === 'me' ? 30 : 2,
37
+ marginLeft: orient === 'replay' ? '10px' : 0,
38
+ marginRight: orient === 'me' ? '10px' : 0,
39
+ padding: 20,
40
+ }));
41
+
42
+ export const ChatMessage: React.FC<ChatMessageProps> = ({ data }) => {
43
+ return (
44
+ <ContainerStyled>
45
+ {data.map((item, key) => (
46
+ <Item key={key} orient={item.send}>
47
+ {item.emotion && item.send === 'replay' && <>{item.emotion}</>}
48
+ <BoxStyled orient={item.send}>
49
+ <Typography
50
+ variant="subtitle2"
51
+ style={{
52
+ marginBottom: '5px',
53
+ font: 'normal normal 600 16px/20px Source Sans Pro',
54
+ }}
55
+ >
56
+ {item.name}
57
+ </Typography>
58
+ <Typography
59
+ variant="body1"
60
+ style={{
61
+ font: 'normal normal normal 16px/20px Source Sans Pro',
62
+ }}
63
+ >
64
+ {item.message}
65
+ </Typography>
66
+ <Typography
67
+ variant="caption"
68
+ style={{
69
+ position: 'absolute',
70
+ bottom: '-18px',
71
+ left: item.send === 'me' ? 0 : 'auto',
72
+ right: item.send === 'me' ? 'auto' : 0,
73
+ font: 'normal normal normal 11px/13px Source Sans Pro',
74
+ opacity: 0.5,
75
+ color: '#4D4F5C',
76
+ }}
77
+ >
78
+ {item.time}
79
+ </Typography>
80
+ </BoxStyled>
81
+ {item.emotion && item.send === 'me' && <>{item.emotion}</>}
82
+ {item.emotionReplay && item.send === 'me' && <>{item.emotionReplay}</>}
83
+ </Item>
84
+ ))}
85
+ </ContainerStyled>
86
+ );
87
+ };
@@ -1,56 +1,56 @@
1
- import { Box, Typography } from '@mui/material';
2
- import { styled } from '@mui/material/styles';
3
-
4
- export const ChatMessageBalloonContainerStyle: any = styled(Box)({
5
- display: 'flex',
6
- flexDirection: 'column',
7
- });
8
-
9
- export const ChatMessageBalloonRowStyle: any = styled('div')<{ direction: string }>`
10
- display: flex;
11
- margin-bottom: 8px;
12
- flex-direction: ${props => (props.direction === 'I' ? 'row-reverse' : 'row')};
13
-
14
- &:last-child {
15
- margin-bottom: 0px;
16
- }
17
- `;
18
-
19
- export const ChatMessageBalloonStyle: any = styled('div')<{ direction: string }>`
20
- background-color: ${props => (props.direction === 'I' ? '#FFF' : '#E18B50')};
21
- border: 2px solid transparent;
22
- border-radius: ${props => (props.direction === 'I' ? '20px 20px 0px 20px' : '20px 20px 20px 0px')};
23
- box-sizing: border-box;
24
- color: ${props => (props.direction === 'I' ? '#4D4F5B' : '#FFF')};
25
- display: flex;
26
- flex-direction: column;
27
- padding: 12px 24px;
28
- width: 60%;
29
- transition: border 0.6s cubic-bezier(0.16, 1, 0.3, 1);
30
-
31
- &.is-highlight {
32
- border: 2px solid #8a8888;
33
- }
34
-
35
- &.is-interactive {
36
- cursor: pointer;
37
-
38
- &:hover {
39
- border: 2px solid #8a8888;
40
- }
41
- }
42
- `;
43
-
44
- export const ChatMessageDateStyle: any = styled(Typography)`
45
- color: #43425d;
46
- opacity: 0.5;
47
- `;
48
-
49
- export const ChatMessageChildrenStyle: any = styled('div')<{ direction: string }>`
50
- align-items: center;
51
- box-sizing: border-box;
52
- display: flex;
53
- flex: 1;
54
- justify-content: ${props => (props.direction === 'I' ? 'end' : 'start')};
55
- padding: 8px;
56
- `;
1
+ import { Box, Typography } from '@mui/material';
2
+ import { styled } from '@mui/material/styles';
3
+
4
+ export const ChatMessageBalloonContainerStyle: any = styled(Box)({
5
+ display: 'flex',
6
+ flexDirection: 'column',
7
+ });
8
+
9
+ export const ChatMessageBalloonRowStyle: any = styled('div')<{ direction: string }>`
10
+ display: flex;
11
+ margin-bottom: 8px;
12
+ flex-direction: ${props => (props.direction === 'I' ? 'row-reverse' : 'row')};
13
+
14
+ &:last-child {
15
+ margin-bottom: 0px;
16
+ }
17
+ `;
18
+
19
+ export const ChatMessageBalloonStyle: any = styled('div')<{ direction: string }>`
20
+ background-color: ${props => (props.direction === 'I' ? '#FFF' : '#E18B50')};
21
+ border: 2px solid transparent;
22
+ border-radius: ${props => (props.direction === 'I' ? '20px 20px 0px 20px' : '20px 20px 20px 0px')};
23
+ box-sizing: border-box;
24
+ color: ${props => (props.direction === 'I' ? '#4D4F5B' : '#FFF')};
25
+ display: flex;
26
+ flex-direction: column;
27
+ padding: 12px 24px;
28
+ width: 60%;
29
+ transition: border 0.6s cubic-bezier(0.16, 1, 0.3, 1);
30
+
31
+ &.is-highlight {
32
+ border: 2px solid #8a8888;
33
+ }
34
+
35
+ &.is-interactive {
36
+ cursor: pointer;
37
+
38
+ &:hover {
39
+ border: 2px solid #8a8888;
40
+ }
41
+ }
42
+ `;
43
+
44
+ export const ChatMessageDateStyle: any = styled(Typography)`
45
+ color: #43425d;
46
+ opacity: 0.5;
47
+ `;
48
+
49
+ export const ChatMessageChildrenStyle: any = styled('div')<{ direction: string }>`
50
+ align-items: center;
51
+ box-sizing: border-box;
52
+ display: flex;
53
+ flex: 1;
54
+ justify-content: ${props => (props.direction === 'I' ? 'end' : 'start')};
55
+ padding: 8px;
56
+ `;
@@ -1,55 +1,55 @@
1
- import React, { useMemo } from 'react';
2
- import { Typography } from '@mui/material';
3
- import { ChatMessageBalloonProps } from '../../interfaces';
4
- import * as S from './ChatMessageBalloon.style'
5
-
6
- export const ChatMessageBalloon: React.FC<ChatMessageBalloonProps> = ({
7
- label,
8
- description,
9
- date,
10
- direction,
11
- children,
12
- className,
13
- bottomChildren,
14
- onMouseEnter,
15
- onMouseLeave,
16
- onRowMouseEnter,
17
- onRowMouseLeave,
18
- highlight,
19
- ...rest
20
- }) => {
21
-
22
- const ballonClassNames = useMemo(() => {
23
- const classNames = []
24
- if(!!onMouseEnter) classNames.push('is-interactive')
25
- if(!!highlight) classNames.push('is-highlight')
26
- return classNames.join(" ")
27
- }, [highlight, onMouseEnter])
28
-
29
- return (
30
- <S.ChatMessageBalloonContainerStyle className={className} {...rest}>
31
- <S.ChatMessageBalloonRowStyle direction={direction} onMouseLeave={onRowMouseLeave} onMouseEnter={onRowMouseEnter}>
32
- <S.ChatMessageBalloonStyle onMouseLeave={onMouseLeave} onMouseEnter={onMouseEnter} direction={direction} className={ballonClassNames}>
33
- <Typography
34
- variant="subtitle2"
35
- style={{
36
- fontSize: "1rem",
37
- fontWeight: "600",
38
- marginBottom: '5px'
39
- }}
40
- >
41
- {label}
42
- </Typography>
43
- {description}
44
- </S.ChatMessageBalloonStyle>
45
- <S.ChatMessageChildrenStyle direction={direction}>
46
- {children}
47
- </S.ChatMessageChildrenStyle>
48
- </S.ChatMessageBalloonRowStyle>
49
- <S.ChatMessageBalloonRowStyle direction={direction} sx={{gap: "10px"}}>
50
- <S.ChatMessageDateStyle fontSize={"0.7rem"}>{date}</S.ChatMessageDateStyle>
51
- {bottomChildren}
52
- </S.ChatMessageBalloonRowStyle>
53
- </S.ChatMessageBalloonContainerStyle>
54
- );
55
- };
1
+ import React, { useMemo } from 'react';
2
+ import { Typography } from '@mui/material';
3
+ import { ChatMessageBalloonProps } from '../../interfaces';
4
+ import * as S from './ChatMessageBalloon.style'
5
+
6
+ export const ChatMessageBalloon: React.FC<ChatMessageBalloonProps> = ({
7
+ label,
8
+ description,
9
+ date,
10
+ direction,
11
+ children,
12
+ className,
13
+ bottomChildren,
14
+ onMouseEnter,
15
+ onMouseLeave,
16
+ onRowMouseEnter,
17
+ onRowMouseLeave,
18
+ highlight,
19
+ ...rest
20
+ }) => {
21
+
22
+ const ballonClassNames = useMemo(() => {
23
+ const classNames = []
24
+ if(!!onMouseEnter) classNames.push('is-interactive')
25
+ if(!!highlight) classNames.push('is-highlight')
26
+ return classNames.join(" ")
27
+ }, [highlight, onMouseEnter])
28
+
29
+ return (
30
+ <S.ChatMessageBalloonContainerStyle className={className} {...rest}>
31
+ <S.ChatMessageBalloonRowStyle direction={direction} onMouseLeave={onRowMouseLeave} onMouseEnter={onRowMouseEnter}>
32
+ <S.ChatMessageBalloonStyle onMouseLeave={onMouseLeave} onMouseEnter={onMouseEnter} direction={direction} className={ballonClassNames}>
33
+ <Typography
34
+ variant="subtitle2"
35
+ style={{
36
+ fontSize: "1rem",
37
+ fontWeight: "600",
38
+ marginBottom: '5px'
39
+ }}
40
+ >
41
+ {label}
42
+ </Typography>
43
+ {description}
44
+ </S.ChatMessageBalloonStyle>
45
+ <S.ChatMessageChildrenStyle direction={direction}>
46
+ {children}
47
+ </S.ChatMessageChildrenStyle>
48
+ </S.ChatMessageBalloonRowStyle>
49
+ <S.ChatMessageBalloonRowStyle direction={direction} sx={{gap: "10px"}}>
50
+ <S.ChatMessageDateStyle fontSize={"0.7rem"}>{date}</S.ChatMessageDateStyle>
51
+ {bottomChildren}
52
+ </S.ChatMessageBalloonRowStyle>
53
+ </S.ChatMessageBalloonContainerStyle>
54
+ );
55
+ };
@@ -1,21 +1,21 @@
1
- import React from 'react';
2
- import { FormControlLabel, Checkbox as MuiCheckbox } from '@mui/material';
3
-
4
- import { CheckBoxBaseProps } from '../interfaces';
5
-
6
- import { styled } from '@mui/material/styles';
7
-
8
- const CheckBoxStyled = styled(MuiCheckbox)({});
9
-
10
- export const CheckBox = ({ ...props }: CheckBoxBaseProps) => {
11
-
12
- return (
13
- <>
14
- {props.label ? (
15
- <FormControlLabel control={<CheckBoxStyled {...props} />} label={props.label} />
16
- ) : (
17
- <CheckBoxStyled {...props} />
18
- )}
19
- </>
20
- );
21
- };
1
+ import React from 'react';
2
+ import { FormControlLabel, Checkbox as MuiCheckbox } from '@mui/material';
3
+
4
+ import { CheckBoxBaseProps } from '../interfaces';
5
+
6
+ import { styled } from '@mui/material/styles';
7
+
8
+ const CheckBoxStyled = styled(MuiCheckbox)({});
9
+
10
+ export const CheckBox = ({ ...props }: CheckBoxBaseProps) => {
11
+
12
+ return (
13
+ <>
14
+ {props.label ? (
15
+ <FormControlLabel control={<CheckBoxStyled {...props} />} label={props.label} />
16
+ ) : (
17
+ <CheckBoxStyled {...props} />
18
+ )}
19
+ </>
20
+ );
21
+ };
@@ -1,35 +1,35 @@
1
- import React, { useState } from "react"
2
- import DatePicker from "react-datepicker";
3
- import * as S from "./styles"
4
- import { DateInputProps } from './interface';
5
-
6
- const DateInput:React.FC<DateInputProps> = ({
7
- label,
8
- dateFormat,
9
- dateSelected,
10
- className,
11
- showTimeSelect,
12
- timeFormat,
13
- disabled,
14
- onChange
15
- }) => {
16
- const [date, setDate] = useState<Date | null>(dateSelected)
17
- return (
18
- <S.Container className={className}>
19
- <S.Label>{label}</S.Label>
20
- <DatePicker
21
- dateFormat={dateFormat}
22
- selected={date}
23
- showTimeSelect={showTimeSelect}
24
- timeFormat={timeFormat}
25
- disabled={disabled}
26
- onChange={(date) => {
27
- setDate(date)
28
- onChange(date)
29
- }}
30
- />
31
- </S.Container>
32
- )
33
- }
34
-
1
+ import React, { useState } from "react"
2
+ import DatePicker from "react-datepicker";
3
+ import * as S from "./styles"
4
+ import { DateInputProps } from './interface';
5
+
6
+ const DateInput:React.FC<DateInputProps> = ({
7
+ label,
8
+ dateFormat,
9
+ dateSelected,
10
+ className,
11
+ showTimeSelect,
12
+ timeFormat,
13
+ disabled,
14
+ onChange
15
+ }) => {
16
+ const [date, setDate] = useState<Date | null>(dateSelected)
17
+ return (
18
+ <S.Container className={className}>
19
+ <S.Label>{label}</S.Label>
20
+ <DatePicker
21
+ dateFormat={dateFormat}
22
+ selected={date}
23
+ showTimeSelect={showTimeSelect}
24
+ timeFormat={timeFormat}
25
+ disabled={disabled}
26
+ onChange={(date) => {
27
+ setDate(date)
28
+ onChange(date)
29
+ }}
30
+ />
31
+ </S.Container>
32
+ )
33
+ }
34
+
35
35
  export default DateInput
@@ -1,14 +1,14 @@
1
- export interface DateInputProps {
2
- className?: string
3
- label: string
4
- dateSelected: Date
5
- onChange: Function
6
- dateFormat: string
7
- showTimeSelect?: boolean
8
- timeFormat?: string
9
- disabled?: boolean
10
- }
11
-
12
- export interface ContainerStyles {
13
-
1
+ export interface DateInputProps {
2
+ className?: string
3
+ label: string
4
+ dateSelected: Date
5
+ onChange: Function
6
+ dateFormat: string
7
+ showTimeSelect?: boolean
8
+ timeFormat?: string
9
+ disabled?: boolean
10
+ }
11
+
12
+ export interface ContainerStyles {
13
+
14
14
  }