@campxdev/shared 0.3.11 → 0.3.13

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 (181) hide show
  1. package/antd.customize.less +73 -73
  2. package/exports.ts +15 -15
  3. package/package.json +51 -51
  4. package/src/assets/fonts/avenir/index.ts +2 -2
  5. package/src/assets/fonts/poppins/index.ts +7 -7
  6. package/src/assets/images/index.ts +16 -16
  7. package/src/components/ActionButton.tsx +28 -28
  8. package/src/components/Attachment.tsx +26 -26
  9. package/src/components/AutocompleteSearch/AutocompleteSearch.tsx +57 -57
  10. package/src/components/AutocompleteSearch/index.tsx +1 -1
  11. package/src/components/Breadcrumbs.tsx +73 -73
  12. package/src/components/Card.tsx +97 -97
  13. package/src/components/CardsGrid.tsx +28 -28
  14. package/src/components/Chips.tsx +77 -77
  15. package/src/components/Detail.tsx +15 -15
  16. package/src/components/DetailsGrid.tsx +52 -52
  17. package/src/components/DividerHeading.tsx +40 -40
  18. package/src/components/DrawerWrapper/DialogWrapper.tsx +63 -63
  19. package/src/components/DrawerWrapper/DrawerTemplate.tsx +53 -53
  20. package/src/components/DrawerWrapper/DrawerWrapper.tsx +53 -53
  21. package/src/components/DropDownButton.tsx +184 -184
  22. package/src/components/ErrorBoundary/ErrorBoundary.tsx +28 -28
  23. package/src/components/ErrorBoundary/ErrorFallback.tsx +180 -180
  24. package/src/components/ErrorBoundary/GlobalNetworkLoadingIndicator.tsx +13 -13
  25. package/src/components/ErrorBoundary/index.tsx +1 -1
  26. package/src/components/ErrorBox.tsx +42 -42
  27. package/src/components/FloatingContainer.tsx +26 -26
  28. package/src/components/FullCalendar/Actions.tsx +162 -162
  29. package/src/components/FullCalendar/FullCalendarWrapper.tsx +54 -54
  30. package/src/components/FullScreenLoader.tsx +19 -19
  31. package/src/components/HookForm/AutoCompleteSearch.tsx +143 -143
  32. package/src/components/HookForm/DatePicker.tsx +65 -65
  33. package/src/components/HookForm/DateTimePicker.tsx +70 -70
  34. package/src/components/HookForm/FormLabel.tsx +14 -14
  35. package/src/components/HookForm/MultiCheckbox.tsx +82 -82
  36. package/src/components/HookForm/MultiSelect.tsx +100 -100
  37. package/src/components/HookForm/RadioGroup.tsx +112 -112
  38. package/src/components/HookForm/SingleCheckbox.tsx +46 -46
  39. package/src/components/HookForm/SingleSelect.tsx +93 -93
  40. package/src/components/HookForm/TextField.tsx +74 -74
  41. package/src/components/HookForm/TimePicker.tsx +82 -82
  42. package/src/components/HookForm/index.ts +23 -23
  43. package/src/components/IconButtons/IconButtons.tsx +137 -137
  44. package/src/components/IconButtons/Icons.tsx +268 -268
  45. package/src/components/IconButtons/assets/edit.svg +4 -4
  46. package/src/components/IconButtons/assets/eye.svg +6 -6
  47. package/src/components/IconButtons/assets/trash.svg +7 -7
  48. package/src/components/IconButtons/index.tsx +8 -8
  49. package/src/components/IconLabel.tsx +37 -37
  50. package/src/components/Image/Image.tsx +43 -43
  51. package/src/components/Image/index.tsx +1 -1
  52. package/src/components/ImageUpload.tsx +98 -98
  53. package/src/components/Input/AutoCompleteSearch.tsx +143 -143
  54. package/src/components/Input/DatePicker.tsx +60 -60
  55. package/src/components/Input/DateRangePicker.tsx +131 -131
  56. package/src/components/Input/DateTimePicker.tsx +70 -70
  57. package/src/components/Input/FormLabel.tsx +14 -14
  58. package/src/components/Input/MultiCheckbox.tsx +79 -79
  59. package/src/components/Input/MultiSelect.tsx +52 -52
  60. package/src/components/Input/RadioGroup.tsx +55 -55
  61. package/src/components/Input/SingleCheckbox.tsx +23 -23
  62. package/src/components/Input/SingleSelect.tsx +139 -139
  63. package/src/components/Input/TextField.tsx +50 -50
  64. package/src/components/Input/TimePicker.tsx +82 -82
  65. package/src/components/Input/index.ts +26 -26
  66. package/src/components/JsonPreview/JsonPreview.tsx +7 -7
  67. package/src/components/JsonPreview/index.tsx +1 -1
  68. package/src/components/LabelValue/LabelValue.tsx +21 -21
  69. package/src/components/LabelValue/index.tsx +1 -1
  70. package/src/components/Layout/ChangePassword.tsx +49 -49
  71. package/src/components/Layout/Header/AppHeader.tsx +120 -120
  72. package/src/components/Layout/Header/AppsMenu.tsx +85 -85
  73. package/src/components/Layout/Header/CogWheelMenu.tsx +33 -33
  74. package/src/components/Layout/Header/FreshDeskHelpButton.tsx +19 -19
  75. package/src/components/Layout/Header/Notification.tsx +13 -13
  76. package/src/components/Layout/Header/UserBox.tsx +42 -42
  77. package/src/components/Layout/Header/applications.tsx +60 -60
  78. package/src/components/Layout/Header/assets/index.ts +7 -7
  79. package/src/components/Layout/Header/icons.tsx +57 -57
  80. package/src/components/Layout/Header/index.tsx +1 -1
  81. package/src/components/Layout/Header/styles.tsx +91 -91
  82. package/src/components/LinearProgress.tsx +19 -19
  83. package/src/components/LoginForm.tsx +103 -103
  84. package/src/components/MediaRow/MediaRow.tsx +69 -69
  85. package/src/components/MediaRow/index.tsx +1 -1
  86. package/src/components/MenuButton.tsx +103 -103
  87. package/src/components/ModalButtons/DialogButton.tsx +85 -85
  88. package/src/components/ModalButtons/DrawerButton.tsx +89 -89
  89. package/src/components/ModalButtons/index.tsx +4 -4
  90. package/src/components/NoDataIllustration/NoDataIllustration.tsx +32 -32
  91. package/src/components/NoDataIllustration/index.tsx +1 -1
  92. package/src/components/PageContent.tsx +17 -17
  93. package/src/components/PageHeader.tsx +52 -52
  94. package/src/components/PageNotFound.tsx +25 -25
  95. package/src/components/PopupConfirm/ConfirmContextProvider.tsx +40 -40
  96. package/src/components/PopupConfirm/PopupConfirm.tsx +34 -34
  97. package/src/components/PopupConfirm/index.tsx +1 -1
  98. package/src/components/PopupConfirm/useConfirm.ts +47 -47
  99. package/src/components/Row/Row.tsx +24 -24
  100. package/src/components/Row/index.tsx +1 -1
  101. package/src/components/SearchBar/SearchBar.tsx +53 -53
  102. package/src/components/SearchBar/index.tsx +1 -1
  103. package/src/components/Spinner.tsx +18 -18
  104. package/src/components/StepsHeader/StepsHeader.tsx +115 -115
  105. package/src/components/StepsHeader/index.tsx +1 -1
  106. package/src/components/Styled/OutlinedIconButton.tsx +7 -7
  107. package/src/components/Styled/index.tsx +1 -1
  108. package/src/components/StyledTableContainer.tsx +33 -33
  109. package/src/components/Swiper/Swiper.tsx +39 -39
  110. package/src/components/Swiper/index.tsx +1 -1
  111. package/src/components/SwitchButton/SwitchButton.tsx +41 -41
  112. package/src/components/SwitchButton/index.tsx +1 -1
  113. package/src/components/Table.tsx +42 -42
  114. package/src/components/TableComponent/BatchActionsHeader.tsx +58 -58
  115. package/src/components/TableComponent/Icons/index.tsx +50 -50
  116. package/src/components/TableComponent/ReactTable.tsx +293 -293
  117. package/src/components/TableComponent/RenderTableBody.tsx +64 -64
  118. package/src/components/TableComponent/TableFooter/TableFooter.tsx +102 -102
  119. package/src/components/TableComponent/TableFooter/index.tsx +1 -1
  120. package/src/components/TableComponent/TableFooter/styles.tsx +28 -28
  121. package/src/components/TableComponent/index.tsx +221 -221
  122. package/src/components/TableComponent/react-table-config.d.ts +129 -129
  123. package/src/components/TableComponent/styles.tsx +173 -173
  124. package/src/components/TableComponent/types.ts +57 -57
  125. package/src/components/Tabs/Tabs.tsx +52 -52
  126. package/src/components/Tabs/TabsContainer.tsx +50 -50
  127. package/src/components/Tabs/index.tsx +1 -1
  128. package/src/components/Tabs/styles.tsx +55 -55
  129. package/src/components/ToastContainer/ToastContainer.tsx +42 -42
  130. package/src/components/ToastContainer/index.tsx +1 -1
  131. package/src/components/UploadButton/UploadButton.tsx +98 -98
  132. package/src/components/UploadButton/index.tsx +1 -1
  133. package/src/components/UploadButton/types.ts +14 -14
  134. package/src/components/UploadDocument/UploadDocument.tsx +108 -108
  135. package/src/components/UploadDocument/index.tsx +1 -1
  136. package/src/components/UploadFileDialog/UploadFileDialog.tsx +240 -240
  137. package/src/components/UploadFileDialog/index.tsx +1 -1
  138. package/src/components/index.ts +67 -67
  139. package/src/config/axios.ts +73 -72
  140. package/src/constants/UIConstants.ts +97 -97
  141. package/src/constants/formValidations.ts +6 -6
  142. package/src/constants/index.ts +5 -5
  143. package/src/constants/isDevelopment.ts +3 -3
  144. package/src/constants/permissions.ts +67 -67
  145. package/src/constants/validateMessages.ts +12 -12
  146. package/src/contexts/LoginFormProvider.tsx +39 -39
  147. package/src/contexts/Providers.tsx +27 -27
  148. package/src/contexts/QueryClientProvider.tsx +22 -22
  149. package/src/hooks/index.ts +3 -3
  150. package/src/hooks/useAuth.ts +77 -77
  151. package/src/hooks/useFetch.ts +53 -53
  152. package/src/hooks/useRouter.ts +31 -31
  153. package/src/layouts/ComponentsLayout.tsx +3 -3
  154. package/src/permissions/PageWithPermission.tsx +18 -18
  155. package/src/permissions/PermissionDeniedPage.tsx +16 -16
  156. package/src/permissions/PermissionsStore.ts +291 -291
  157. package/src/permissions/ValidateAccess.tsx +18 -18
  158. package/src/permissions/index.ts +3 -3
  159. package/src/react-app-env.d.ts +1 -1
  160. package/src/shared-state/AssetsStore.ts +15 -15
  161. package/src/shared-state/UserStore.ts +13 -13
  162. package/src/shared-state/index.ts +3 -3
  163. package/src/theme/App.less +3 -3
  164. package/src/theme/MuiThemeProvider.tsx +13 -13
  165. package/src/theme/customCssBaseline.ts +78 -78
  166. package/src/theme/index.css +75 -75
  167. package/src/theme/muiTheme.ts +516 -516
  168. package/src/theme/theme.d.ts +75 -75
  169. package/src/utils/alphabet.ts +23 -23
  170. package/src/utils/arrayPadEnd.ts +3 -3
  171. package/src/utils/formatCurrency.ts +9 -9
  172. package/src/utils/getUrlParams.ts +5 -5
  173. package/src/utils/index.ts +8 -8
  174. package/src/utils/logout.ts +23 -23
  175. package/src/utils/ordinalSuffixOf.ts +14 -14
  176. package/src/utils/romanize.ts +40 -40
  177. package/src/utils/withLocalization.tsx +11 -11
  178. package/src/utils/withRouteWrapper.tsx +26 -26
  179. package/src/utils/withSuspense.tsx +6 -6
  180. package/styled-components.tsx +60 -60
  181. package/tsconfig.json +21 -21
@@ -1,73 +1,73 @@
1
- import ChevronLeft from '@mui/icons-material/ChevronLeft'
2
- import {
3
- Breadcrumbs as MuiBreadcrumbs,
4
- IconButton,
5
- Stack,
6
- styled,
7
- Typography,
8
- } from '@mui/material'
9
- import React, { ReactNode } from 'react'
10
- import { Link, useNavigate } from 'react-router-dom'
11
- import { useHistory } from '../hooks/useRouter'
12
-
13
- interface BreadcrumbsProps {
14
- links: { to: string | null; name: string | ReactNode }[]
15
- icon?: ReactNode
16
- }
17
-
18
- const StyledStack = styled(Stack)(({ theme }) => ({
19
- flexDirection: 'row',
20
- alignItems: 'center',
21
- '& .MuiSvgIcon-root': {
22
- fontSize: '28px',
23
- },
24
- '& .MuiTypography-root': {
25
- fontSize: '18px',
26
- fontWeight: 600,
27
- },
28
- }))
29
-
30
- const StyledLink = styled(Link)(({ theme }) => ({
31
- textDecoration: 'none',
32
- color: theme.palette.text.primary,
33
- transition: 'color 0.2s ease-in-out',
34
- fontFamily: 'Poppins',
35
- '&:hover': {
36
- color: theme.palette.common.yellow,
37
- },
38
- }))
39
-
40
- const StyledIconButton = styled(IconButton)(({ theme }) => ({
41
- color: theme.palette.text.primary,
42
- padding: 0,
43
- marginRight: '5px',
44
- }))
45
-
46
- export default function Breadcrumbs({ links, icon }: BreadcrumbsProps) {
47
- const navigate = useNavigate()
48
- let linksArray = links.slice(0, -1)
49
- let currentPage = links.slice(-1)[0]
50
- const backLink = links.slice(-2)[0]
51
-
52
- return (
53
- <StyledStack direction={'row'} alignItems='center'>
54
- {linksArray?.length ? (
55
- <StyledIconButton
56
- onClick={() => {
57
- navigate(backLink.to)
58
- }}
59
- >
60
- {icon ? icon : <ChevronLeft />}
61
- </StyledIconButton>
62
- ) : null}
63
- <MuiBreadcrumbs separator={<Typography variant='h3'>/</Typography>}>
64
- {linksArray.map((link, index) => (
65
- <StyledLink to={link.to} key={index}>
66
- {link?.name}
67
- </StyledLink>
68
- ))}
69
- <Typography variant='h3'>{currentPage?.name}</Typography>
70
- </MuiBreadcrumbs>
71
- </StyledStack>
72
- )
73
- }
1
+ import ChevronLeft from '@mui/icons-material/ChevronLeft'
2
+ import {
3
+ Breadcrumbs as MuiBreadcrumbs,
4
+ IconButton,
5
+ Stack,
6
+ styled,
7
+ Typography,
8
+ } from '@mui/material'
9
+ import React, { ReactNode } from 'react'
10
+ import { Link, useNavigate } from 'react-router-dom'
11
+ import { useHistory } from '../hooks/useRouter'
12
+
13
+ interface BreadcrumbsProps {
14
+ links: { to: string | null; name: string | ReactNode }[]
15
+ icon?: ReactNode
16
+ }
17
+
18
+ const StyledStack = styled(Stack)(({ theme }) => ({
19
+ flexDirection: 'row',
20
+ alignItems: 'center',
21
+ '& .MuiSvgIcon-root': {
22
+ fontSize: '28px',
23
+ },
24
+ '& .MuiTypography-root': {
25
+ fontSize: '18px',
26
+ fontWeight: 600,
27
+ },
28
+ }))
29
+
30
+ const StyledLink = styled(Link)(({ theme }) => ({
31
+ textDecoration: 'none',
32
+ color: theme.palette.text.primary,
33
+ transition: 'color 0.2s ease-in-out',
34
+ fontFamily: 'Poppins',
35
+ '&:hover': {
36
+ color: theme.palette.common.yellow,
37
+ },
38
+ }))
39
+
40
+ const StyledIconButton = styled(IconButton)(({ theme }) => ({
41
+ color: theme.palette.text.primary,
42
+ padding: 0,
43
+ marginRight: '5px',
44
+ }))
45
+
46
+ export default function Breadcrumbs({ links, icon }: BreadcrumbsProps) {
47
+ const navigate = useNavigate()
48
+ let linksArray = links.slice(0, -1)
49
+ let currentPage = links.slice(-1)[0]
50
+ const backLink = links.slice(-2)[0]
51
+
52
+ return (
53
+ <StyledStack direction={'row'} alignItems='center'>
54
+ {linksArray?.length ? (
55
+ <StyledIconButton
56
+ onClick={() => {
57
+ navigate(backLink.to)
58
+ }}
59
+ >
60
+ {icon ? icon : <ChevronLeft />}
61
+ </StyledIconButton>
62
+ ) : null}
63
+ <MuiBreadcrumbs separator={<Typography variant='h3'>/</Typography>}>
64
+ {linksArray.map((link, index) => (
65
+ <StyledLink to={link.to} key={index}>
66
+ {link?.name}
67
+ </StyledLink>
68
+ ))}
69
+ <Typography variant='h3'>{currentPage?.name}</Typography>
70
+ </MuiBreadcrumbs>
71
+ </StyledStack>
72
+ )
73
+ }
@@ -1,97 +1,97 @@
1
- import ChevronRight from '@mui/icons-material/ChevronRight'
2
- import {
3
- Box,
4
- Button,
5
- Card as MuiCard,
6
- CardActions,
7
- CardContent,
8
- CardHeader,
9
- CardMedia,
10
- styled,
11
- } from '@mui/material'
12
- import { ReactNode } from 'react'
13
-
14
- interface CardProps {
15
- title: string | ReactNode
16
- subheader?: string | ReactNode
17
- children?: ReactNode
18
- footer?: {
19
- buttonText?: string | ReactNode
20
- onClick: () => void
21
- endIcon?: ReactNode
22
- buttonProps?: any
23
- }
24
- image?: {
25
- url: string
26
- height: number
27
- }
28
- moreActions?: ReactNode
29
- }
30
-
31
- export default function Card({
32
- title,
33
- subheader,
34
- children,
35
- footer,
36
- image,
37
- moreActions,
38
- }: CardProps) {
39
- const handleClick = (e) => {
40
- e.preventDefault()
41
- e.stopPropagation()
42
- footer?.onClick()
43
- }
44
-
45
- return (
46
- <StyledCard>
47
- <CardMedia component="img" height={image?.height} image={image?.url} />
48
- <Box sx={{ position: 'relative', width: '100%' }}>
49
- <StyledMoreActions>{moreActions}</StyledMoreActions>
50
- <CardHeader title={title} subheader={subheader} />
51
- </Box>
52
- <CardContent sx={{ height: 'fit-content' }}>{children}</CardContent>
53
- {footer && (
54
- <StyledCardActions>
55
- <Button
56
- variant="text"
57
- fullWidth
58
- onClick={handleClick}
59
- endIcon={footer?.endIcon ?? <ChevronRight />}
60
- {...footer?.buttonProps}
61
- >
62
- {footer?.buttonText ?? 'View'}
63
- </Button>
64
- </StyledCardActions>
65
- )}
66
- </StyledCard>
67
- )
68
- }
69
-
70
- const StyledMoreActions = styled(Box)(({ theme }) => ({
71
- position: 'absolute',
72
- right: '10px',
73
- top: '15px',
74
- }))
75
-
76
- const StyledCard = styled(MuiCard)(({ theme }) => ({
77
- display: 'flex',
78
- flexDirection: 'column',
79
- width: '100%',
80
- height: '100%',
81
- '& .MuiCardContent-root': {
82
- flexGrow: 1,
83
- },
84
- '& .MuiCardHeader-root': {
85
- alignItems: 'baseline',
86
- gap: '6px',
87
- },
88
- }))
89
-
90
- const StyledCardActions = styled(CardActions)(({ theme }) => ({
91
- borderTop: theme.borders.grayLight,
92
- '& .MuiButton-root': {
93
- justifyContent: 'space-between',
94
- height: '40px',
95
- padding: '20px',
96
- },
97
- }))
1
+ import ChevronRight from '@mui/icons-material/ChevronRight'
2
+ import {
3
+ Box,
4
+ Button,
5
+ Card as MuiCard,
6
+ CardActions,
7
+ CardContent,
8
+ CardHeader,
9
+ CardMedia,
10
+ styled,
11
+ } from '@mui/material'
12
+ import { ReactNode } from 'react'
13
+
14
+ interface CardProps {
15
+ title: string | ReactNode
16
+ subheader?: string | ReactNode
17
+ children?: ReactNode
18
+ footer?: {
19
+ buttonText?: string | ReactNode
20
+ onClick: () => void
21
+ endIcon?: ReactNode
22
+ buttonProps?: any
23
+ }
24
+ image?: {
25
+ url: string
26
+ height: number
27
+ }
28
+ moreActions?: ReactNode
29
+ }
30
+
31
+ export default function Card({
32
+ title,
33
+ subheader,
34
+ children,
35
+ footer,
36
+ image,
37
+ moreActions,
38
+ }: CardProps) {
39
+ const handleClick = (e) => {
40
+ e.preventDefault()
41
+ e.stopPropagation()
42
+ footer?.onClick()
43
+ }
44
+
45
+ return (
46
+ <StyledCard>
47
+ <CardMedia component="img" height={image?.height} image={image?.url} />
48
+ <Box sx={{ position: 'relative', width: '100%' }}>
49
+ <StyledMoreActions>{moreActions}</StyledMoreActions>
50
+ <CardHeader title={title} subheader={subheader} />
51
+ </Box>
52
+ <CardContent sx={{ height: 'fit-content' }}>{children}</CardContent>
53
+ {footer && (
54
+ <StyledCardActions>
55
+ <Button
56
+ variant="text"
57
+ fullWidth
58
+ onClick={handleClick}
59
+ endIcon={footer?.endIcon ?? <ChevronRight />}
60
+ {...footer?.buttonProps}
61
+ >
62
+ {footer?.buttonText ?? 'View'}
63
+ </Button>
64
+ </StyledCardActions>
65
+ )}
66
+ </StyledCard>
67
+ )
68
+ }
69
+
70
+ const StyledMoreActions = styled(Box)(({ theme }) => ({
71
+ position: 'absolute',
72
+ right: '10px',
73
+ top: '15px',
74
+ }))
75
+
76
+ const StyledCard = styled(MuiCard)(({ theme }) => ({
77
+ display: 'flex',
78
+ flexDirection: 'column',
79
+ width: '100%',
80
+ height: '100%',
81
+ '& .MuiCardContent-root': {
82
+ flexGrow: 1,
83
+ },
84
+ '& .MuiCardHeader-root': {
85
+ alignItems: 'baseline',
86
+ gap: '6px',
87
+ },
88
+ }))
89
+
90
+ const StyledCardActions = styled(CardActions)(({ theme }) => ({
91
+ borderTop: theme.borders.grayLight,
92
+ '& .MuiButton-root': {
93
+ justifyContent: 'space-between',
94
+ height: '40px',
95
+ padding: '20px',
96
+ },
97
+ }))
@@ -1,28 +1,28 @@
1
- import { Box, SxProps } from '@mui/material'
2
- import React from 'react'
3
- export default function CardsGrid({
4
- cardWidth,
5
- gap,
6
- children,
7
- sx,
8
- }: {
9
- cardWidth: number
10
- gap: number
11
- children: React.ReactNode
12
- sx?: SxProps
13
- }) {
14
- return (
15
- <Box
16
- sx={{
17
- width: '100%',
18
- display: 'grid',
19
- gridTemplateColumns: `repeat(auto-fill, minmax(${cardWidth}px, 1fr))`,
20
- alignItems: 'start',
21
- gap: `${gap}px`,
22
- ...sx,
23
- }}
24
- >
25
- {children}
26
- </Box>
27
- )
28
- }
1
+ import { Box, SxProps } from '@mui/material'
2
+ import React from 'react'
3
+ export default function CardsGrid({
4
+ cardWidth,
5
+ gap,
6
+ children,
7
+ sx,
8
+ }: {
9
+ cardWidth: number
10
+ gap: number
11
+ children: React.ReactNode
12
+ sx?: SxProps
13
+ }) {
14
+ return (
15
+ <Box
16
+ sx={{
17
+ width: '100%',
18
+ display: 'grid',
19
+ gridTemplateColumns: `repeat(auto-fill, minmax(${cardWidth}px, 1fr))`,
20
+ alignItems: 'start',
21
+ gap: `${gap}px`,
22
+ ...sx,
23
+ }}
24
+ >
25
+ {children}
26
+ </Box>
27
+ )
28
+ }
@@ -1,77 +1,77 @@
1
- import { Chip, Stack, styled } from '@mui/material'
2
- import { ReactNode, useEffect, useState } from 'react'
3
-
4
- type IChip = {
5
- label: string
6
- value: string
7
- }
8
-
9
- interface ChipsProps {
10
- list: { label: string | ReactNode; value: string | number }[]
11
- selected: string[] | string | number
12
- onSelected: (selected: IChip[] | any) => void
13
- direction?: 'row' | 'column'
14
- singleSelection?: boolean
15
- toggle?: boolean
16
- }
17
-
18
- export default function Chips({
19
- list = [],
20
- selected: _selected,
21
- onSelected,
22
- direction = 'row',
23
- singleSelection = true,
24
- toggle = false,
25
- }: ChipsProps) {
26
- const [selected, setSelected] = useState<any[] | any>([])
27
-
28
- useEffect(() => {
29
- setSelected(_selected)
30
- }, [_selected])
31
-
32
- const handleChange = (value) => {
33
- if (singleSelection) {
34
- if (selected === value && !toggle) {
35
- setSelected('')
36
- onSelected('')
37
- } else {
38
- setSelected(value)
39
- onSelected(value)
40
- }
41
- } else {
42
- if (selected.includes(value)) {
43
- setSelected((prev) => prev.filter((item) => item !== value))
44
- onSelected(selected.filter((item) => item !== value))
45
- } else {
46
- setSelected([...selected, value])
47
- onSelected([...selected, value])
48
- }
49
- }
50
- }
51
-
52
- const isSelected = (value) =>
53
- singleSelection ? selected === value : selected.includes(value)
54
-
55
- return (
56
- <Stack gap={'8px'} direction={direction} flexWrap={'wrap'}>
57
- {list.map((item, index) => (
58
- <StyledChip
59
- key={index}
60
- color={'primary'}
61
- label={item.label}
62
- clickable
63
- variant={isSelected(item?.value) ? 'outlined' : 'filled'}
64
- onClick={() => handleChange(item?.value)}
65
- />
66
- ))}
67
- </Stack>
68
- )
69
- }
70
-
71
- const StyledChip = styled(Chip)(({ theme }) => ({
72
- minWidth: '100px',
73
- '&.MuiButtonBase-root.MuiChip-filled': {
74
- background: theme.palette.secondary.light,
75
- color: theme.palette.text.primary,
76
- },
77
- }))
1
+ import { Chip, Stack, styled } from '@mui/material'
2
+ import { ReactNode, useEffect, useState } from 'react'
3
+
4
+ type IChip = {
5
+ label: string
6
+ value: string
7
+ }
8
+
9
+ interface ChipsProps {
10
+ list: { label: string | ReactNode; value: string | number }[]
11
+ selected: string[] | string | number
12
+ onSelected: (selected: IChip[] | any) => void
13
+ direction?: 'row' | 'column'
14
+ singleSelection?: boolean
15
+ toggle?: boolean
16
+ }
17
+
18
+ export default function Chips({
19
+ list = [],
20
+ selected: _selected,
21
+ onSelected,
22
+ direction = 'row',
23
+ singleSelection = true,
24
+ toggle = false,
25
+ }: ChipsProps) {
26
+ const [selected, setSelected] = useState<any[] | any>([])
27
+
28
+ useEffect(() => {
29
+ setSelected(_selected)
30
+ }, [_selected])
31
+
32
+ const handleChange = (value) => {
33
+ if (singleSelection) {
34
+ if (selected === value && !toggle) {
35
+ setSelected('')
36
+ onSelected('')
37
+ } else {
38
+ setSelected(value)
39
+ onSelected(value)
40
+ }
41
+ } else {
42
+ if (selected.includes(value)) {
43
+ setSelected((prev) => prev.filter((item) => item !== value))
44
+ onSelected(selected.filter((item) => item !== value))
45
+ } else {
46
+ setSelected([...selected, value])
47
+ onSelected([...selected, value])
48
+ }
49
+ }
50
+ }
51
+
52
+ const isSelected = (value) =>
53
+ singleSelection ? selected === value : selected.includes(value)
54
+
55
+ return (
56
+ <Stack gap={'8px'} direction={direction} flexWrap={'wrap'}>
57
+ {list.map((item, index) => (
58
+ <StyledChip
59
+ key={index}
60
+ color={'primary'}
61
+ label={item.label}
62
+ clickable
63
+ variant={isSelected(item?.value) ? 'outlined' : 'filled'}
64
+ onClick={() => handleChange(item?.value)}
65
+ />
66
+ ))}
67
+ </Stack>
68
+ )
69
+ }
70
+
71
+ const StyledChip = styled(Chip)(({ theme }) => ({
72
+ minWidth: '100px',
73
+ '&.MuiButtonBase-root.MuiChip-filled': {
74
+ background: theme.palette.secondary.light,
75
+ color: theme.palette.text.primary,
76
+ },
77
+ }))
@@ -1,15 +1,15 @@
1
- import React from 'react'
2
-
3
- interface DetailProps {
4
- label: string
5
- value: string | number
6
- }
7
-
8
- export default function Detail(props: DetailProps) {
9
- return (
10
- <div>
11
- <div>{props.label}</div>
12
- <h3>{props.value}</h3>
13
- </div>
14
- )
15
- }
1
+ import React from 'react'
2
+
3
+ interface DetailProps {
4
+ label: string
5
+ value: string | number
6
+ }
7
+
8
+ export default function Detail(props: DetailProps) {
9
+ return (
10
+ <div>
11
+ <div>{props.label}</div>
12
+ <h3>{props.value}</h3>
13
+ </div>
14
+ )
15
+ }