@campxdev/shared 0.1.0

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 (253) hide show
  1. package/.eslintrc.js +34 -0
  2. package/.prettierrc +10 -0
  3. package/.storybook/main.js +16 -0
  4. package/.storybook/preview.js +9 -0
  5. package/antd.customize.less +73 -0
  6. package/exports.ts +20 -0
  7. package/package.json +78 -0
  8. package/public/dean.JPG +0 -0
  9. package/public/download.png +0 -0
  10. package/public/illustrations/bookmark.svg +19 -0
  11. package/public/illustrations/girl-writing.png +0 -0
  12. package/public/illustrations/whiteboard.svg +24 -0
  13. package/public/images/AnimatedUploadFile.gif +0 -0
  14. package/public/images/doc@2x.png +0 -0
  15. package/public/images/greenTick.png +0 -0
  16. package/public/images/jpg.png +0 -0
  17. package/public/images/paperclip@2x.png +0 -0
  18. package/public/images/pdf.png +0 -0
  19. package/public/images/ppt.png +0 -0
  20. package/public/images/profileImage.jpg +0 -0
  21. package/public/images/profileImage.png +0 -0
  22. package/public/index.html +50 -0
  23. package/public/logo.png +0 -0
  24. package/public/logo_campx_full.png +0 -0
  25. package/public/logo_square.svg +21 -0
  26. package/public/omr_sign.jpg +0 -0
  27. package/src/App.tsx +35 -0
  28. package/src/assets/fonts/avenir/Avenir.ttc +0 -0
  29. package/src/assets/fonts/avenir/index.ts +2 -0
  30. package/src/assets/fonts/poppins/Poppins-Bold.ttf +0 -0
  31. package/src/assets/fonts/poppins/Poppins-Italic.ttf +0 -0
  32. package/src/assets/fonts/poppins/Poppins-Light.ttf +0 -0
  33. package/src/assets/fonts/poppins/Poppins-LightItalic.ttf +0 -0
  34. package/src/assets/fonts/poppins/Poppins-Medium.ttf +0 -0
  35. package/src/assets/fonts/poppins/Poppins-MediumItalic.ttf +0 -0
  36. package/src/assets/fonts/poppins/Poppins-Regular.ttf +0 -0
  37. package/src/assets/fonts/poppins/Poppins-SemiBold.ttf +0 -0
  38. package/src/assets/fonts/poppins/Poppins-SemiBoldItalic.ttf +0 -0
  39. package/src/assets/fonts/poppins/index.ts +7 -0
  40. package/src/assets/images/File bundle-bro.svg +122 -0
  41. package/src/assets/images/Filebundle.png +0 -0
  42. package/src/assets/images/NoPart.png +0 -0
  43. package/src/assets/images/ResultProcess.png +0 -0
  44. package/src/assets/images/ResultProcess.svg +99 -0
  45. package/src/assets/images/attachment.svg +1 -0
  46. package/src/assets/images/avatar.png +0 -0
  47. package/src/assets/images/index.ts +19 -0
  48. package/src/assets/images/pdf.png +0 -0
  49. package/src/assets/images/taskAttachment.png +0 -0
  50. package/src/assets/images/welcomeimage.jpg +0 -0
  51. package/src/assets/static_files/External_Marks_Import .xlsx +0 -0
  52. package/src/assets/static_files/Leads_Sample.xlsx +0 -0
  53. package/src/assets/static_files/Subject_Topic_Import_Sheet.xlsx +0 -0
  54. package/src/assets/static_files/admissions_Sample.xlsx +0 -0
  55. package/src/assets/static_files/barcodes_template.xlsx +0 -0
  56. package/src/assets/static_files/hostel_rooms_import.xlsx +0 -0
  57. package/src/assets/static_files/index.ts +24 -0
  58. package/src/assets/static_files/sample_admissions.xlsx +0 -0
  59. package/src/assets/static_files/sample_admissions_report.xlsx +0 -0
  60. package/src/assets/static_files/sample_curriculum_subjects_template.xlsx +0 -0
  61. package/src/assets/static_files/sample_import_students_new.xlsx +0 -0
  62. package/src/assets/static_files/sample_internal_marks.xlsx +0 -0
  63. package/src/assets/static_files/sample_student_subjects_template.xlsx +0 -0
  64. package/src/components/ActionButton.tsx +28 -0
  65. package/src/components/Attachment.tsx +26 -0
  66. package/src/components/AutocompleteSearch/AutocompleteSearch.tsx +57 -0
  67. package/src/components/AutocompleteSearch/index.tsx +1 -0
  68. package/src/components/Breadcrumbs.tsx +73 -0
  69. package/src/components/Card.tsx +97 -0
  70. package/src/components/CardsGrid.tsx +28 -0
  71. package/src/components/Chips.tsx +77 -0
  72. package/src/components/Detail.tsx +15 -0
  73. package/src/components/DetailsGrid.tsx +52 -0
  74. package/src/components/DividerHeading.tsx +40 -0
  75. package/src/components/DrawerWrapper/DialogWrapper.tsx +63 -0
  76. package/src/components/DrawerWrapper/DrawerTemplate.tsx +53 -0
  77. package/src/components/DrawerWrapper/DrawerWrapper.tsx +53 -0
  78. package/src/components/DropDownButton.tsx +184 -0
  79. package/src/components/ErrorBoundary.js +45 -0
  80. package/src/components/ErrorBox.tsx +42 -0
  81. package/src/components/FloatingContainer.tsx +26 -0
  82. package/src/components/FullCalendar/Actions.tsx +162 -0
  83. package/src/components/FullCalendar/FullCalendarWrapper.tsx +54 -0
  84. package/src/components/HookForm/AutoCompleteSearch.tsx +143 -0
  85. package/src/components/HookForm/DatePicker.tsx +65 -0
  86. package/src/components/HookForm/DateTimePicker.tsx +70 -0
  87. package/src/components/HookForm/FormLabel.tsx +14 -0
  88. package/src/components/HookForm/MultiCheckbox.tsx +82 -0
  89. package/src/components/HookForm/MultiSelect.tsx +100 -0
  90. package/src/components/HookForm/RadioGroup.tsx +113 -0
  91. package/src/components/HookForm/SingleCheckbox.tsx +46 -0
  92. package/src/components/HookForm/SingleSelect.tsx +93 -0
  93. package/src/components/HookForm/TextField.tsx +74 -0
  94. package/src/components/HookForm/TimePicker.tsx +82 -0
  95. package/src/components/HookForm/index.ts +23 -0
  96. package/src/components/IconButtons/IconButtons.tsx +137 -0
  97. package/src/components/IconButtons/Icons.tsx +269 -0
  98. package/src/components/IconButtons/assets/edit.svg +4 -0
  99. package/src/components/IconButtons/assets/eye.svg +6 -0
  100. package/src/components/IconButtons/assets/trash.svg +7 -0
  101. package/src/components/IconButtons/index.tsx +8 -0
  102. package/src/components/IconLabel.tsx +37 -0
  103. package/src/components/Image/Image.tsx +43 -0
  104. package/src/components/Image/broken-image.png +0 -0
  105. package/src/components/Image/index.tsx +1 -0
  106. package/src/components/ImageUpload.tsx +98 -0
  107. package/src/components/Input/AutoCompleteSearch.tsx +143 -0
  108. package/src/components/Input/DatePicker.tsx +60 -0
  109. package/src/components/Input/DateRangePicker.tsx +131 -0
  110. package/src/components/Input/DateTimePicker.tsx +70 -0
  111. package/src/components/Input/FormLabel.tsx +14 -0
  112. package/src/components/Input/MultiCheckbox.tsx +79 -0
  113. package/src/components/Input/MultiSelect.tsx +52 -0
  114. package/src/components/Input/RadioGroup.tsx +55 -0
  115. package/src/components/Input/SingleCheckbox.tsx +23 -0
  116. package/src/components/Input/SingleSelect.tsx +139 -0
  117. package/src/components/Input/TextField.tsx +50 -0
  118. package/src/components/Input/TimePicker.tsx +82 -0
  119. package/src/components/Input/index.ts +26 -0
  120. package/src/components/JsonPreview/JsonPreview.tsx +7 -0
  121. package/src/components/JsonPreview/index.tsx +1 -0
  122. package/src/components/LabelValue/LabelValue.tsx +21 -0
  123. package/src/components/LabelValue/index.tsx +1 -0
  124. package/src/components/Layout/ChangePassword.tsx +49 -0
  125. package/src/components/Layout/Header/AppHeader.tsx +150 -0
  126. package/src/components/Layout/Header/CogWheelMenu.tsx +35 -0
  127. package/src/components/Layout/Header/FreshDeskHelpButton.tsx +19 -0
  128. package/src/components/Layout/Header/MainAppHeader.tsx +6 -0
  129. package/src/components/Layout/Header/Notification.tsx +13 -0
  130. package/src/components/Layout/Header/UserBox.tsx +51 -0
  131. package/src/components/Layout/Header/applications.tsx +39 -0
  132. package/src/components/Layout/Header/icons.tsx +57 -0
  133. package/src/components/Layout/Header/index.tsx +1 -0
  134. package/src/components/Layout/Header/styles.tsx +48 -0
  135. package/src/components/LinearProgress/LinearProgress.tsx +27 -0
  136. package/src/components/LinearProgress/index.tsx +1 -0
  137. package/src/components/MediaRow/MediaRow.tsx +69 -0
  138. package/src/components/MediaRow/index.tsx +1 -0
  139. package/src/components/MenuButton.tsx +105 -0
  140. package/src/components/ModalButtons/DialogButton.tsx +84 -0
  141. package/src/components/ModalButtons/DrawerButton.tsx +89 -0
  142. package/src/components/ModalButtons/index.tsx +4 -0
  143. package/src/components/NoDataIllustration/NoDataIllustration.tsx +32 -0
  144. package/src/components/NoDataIllustration/index.tsx +1 -0
  145. package/src/components/PageContent.tsx +14 -0
  146. package/src/components/PageHeader.tsx +52 -0
  147. package/src/components/PopupConfirm/ConfirmContextProvider.tsx +22 -0
  148. package/src/components/PopupConfirm/PopupConfirm.tsx +33 -0
  149. package/src/components/PopupConfirm/index.tsx +1 -0
  150. package/src/components/PopupConfirm/useConfirm.ts +47 -0
  151. package/src/components/Row/Row.tsx +24 -0
  152. package/src/components/Row/index.tsx +1 -0
  153. package/src/components/SearchBar/SearchBar.tsx +53 -0
  154. package/src/components/SearchBar/index.tsx +1 -0
  155. package/src/components/Spinner.tsx +18 -0
  156. package/src/components/StepsHeader/StepsHeader.tsx +115 -0
  157. package/src/components/StepsHeader/index.tsx +1 -0
  158. package/src/components/Styled/OutlinedIconButton.tsx +7 -0
  159. package/src/components/Styled/index.tsx +1 -0
  160. package/src/components/StyledTableContainer.tsx +33 -0
  161. package/src/components/Swiper/Swiper.tsx +39 -0
  162. package/src/components/Swiper/index.tsx +1 -0
  163. package/src/components/SwitchButton/SwitchButton.tsx +41 -0
  164. package/src/components/SwitchButton/index.tsx +1 -0
  165. package/src/components/TableComponent/BatchActionsHeader.tsx +58 -0
  166. package/src/components/TableComponent/Icons/index.tsx +50 -0
  167. package/src/components/TableComponent/ReactTable.tsx +293 -0
  168. package/src/components/TableComponent/RenderTableBody.tsx +65 -0
  169. package/src/components/TableComponent/TableFooter/TableFooter.tsx +102 -0
  170. package/src/components/TableComponent/TableFooter/index.tsx +1 -0
  171. package/src/components/TableComponent/TableFooter/styles.tsx +28 -0
  172. package/src/components/TableComponent/index.tsx +219 -0
  173. package/src/components/TableComponent/no-data-illu.svg +1 -0
  174. package/src/components/TableComponent/react-table-config.d.ts +129 -0
  175. package/src/components/TableComponent/styles.tsx +173 -0
  176. package/src/components/TableComponent/types.ts +57 -0
  177. package/src/components/Tabs/Tabs.tsx +52 -0
  178. package/src/components/Tabs/TabsContainer.tsx +50 -0
  179. package/src/components/Tabs/index.tsx +1 -0
  180. package/src/components/Tabs/styles.tsx +55 -0
  181. package/src/components/ToastContainer/ToastContainer.tsx +42 -0
  182. package/src/components/ToastContainer/index.tsx +1 -0
  183. package/src/components/UploadButton/UploadButton.tsx +98 -0
  184. package/src/components/UploadButton/index.tsx +1 -0
  185. package/src/components/UploadButton/types.ts +14 -0
  186. package/src/components/UploadDocument/UploadDocument.tsx +108 -0
  187. package/src/components/UploadDocument/index.tsx +1 -0
  188. package/src/components/UploadFileDialog/UploadFileDialog.tsx +240 -0
  189. package/src/components/UploadFileDialog/index.tsx +1 -0
  190. package/src/components/index.ts +59 -0
  191. package/src/config/axios.ts +138 -0
  192. package/src/constants/UIConstants.ts +97 -0
  193. package/src/constants/formValidations.ts +6 -0
  194. package/src/constants/index.ts +4 -0
  195. package/src/constants/permissions.ts +67 -0
  196. package/src/constants/validateMessages.ts +12 -0
  197. package/src/contexts/Providers.tsx +24 -0
  198. package/src/contexts/QueryClientProvider.tsx +22 -0
  199. package/src/hooks/index.ts +2 -0
  200. package/src/hooks/useFetch.ts +53 -0
  201. package/src/hooks/useRouter.ts +31 -0
  202. package/src/index.tsx +9 -0
  203. package/src/layouts/ComponentsLayout.tsx +3 -0
  204. package/src/pages/LoginPage/LoginPage.tsx +166 -0
  205. package/src/pages/LoginPage/index.ts +1 -0
  206. package/src/pages/LoginPage/styles.tsx +121 -0
  207. package/src/pages/index.ts +4 -0
  208. package/src/permissions/PageWithPermission.tsx +58 -0
  209. package/src/permissions/PermissionDeniedPage.tsx +23 -0
  210. package/src/permissions/PermissionsStore.ts +289 -0
  211. package/src/permissions/ValidateAccess.tsx +18 -0
  212. package/src/permissions/index.ts +3 -0
  213. package/src/react-app-env.d.ts +1 -0
  214. package/src/shared-state/AssetsStore.ts +15 -0
  215. package/src/shared-state/UserStore.ts +13 -0
  216. package/src/shared-state/index.ts +3 -0
  217. package/src/stories/Button.stories.tsx +41 -0
  218. package/src/stories/Button.tsx +48 -0
  219. package/src/stories/Header.stories.tsx +25 -0
  220. package/src/stories/Header.tsx +56 -0
  221. package/src/stories/Introduction.stories.mdx +211 -0
  222. package/src/stories/Page.stories.tsx +26 -0
  223. package/src/stories/Page.tsx +73 -0
  224. package/src/stories/TextField.stories.tsx +18 -0
  225. package/src/stories/TextField.tsx +49 -0
  226. package/src/stories/assets/code-brackets.svg +1 -0
  227. package/src/stories/assets/colors.svg +1 -0
  228. package/src/stories/assets/comments.svg +1 -0
  229. package/src/stories/assets/direction.svg +1 -0
  230. package/src/stories/assets/flow.svg +1 -0
  231. package/src/stories/assets/plugin.svg +1 -0
  232. package/src/stories/assets/repo.svg +1 -0
  233. package/src/stories/assets/stackalt.svg +1 -0
  234. package/src/stories/button.css +30 -0
  235. package/src/stories/header.css +32 -0
  236. package/src/stories/page.css +69 -0
  237. package/src/theme/App.less +3 -0
  238. package/src/theme/MuiThemeProvider.tsx +11 -0
  239. package/src/theme/customCssBaseline.ts +78 -0
  240. package/src/theme/index.css +75 -0
  241. package/src/theme/muiTheme.ts +516 -0
  242. package/src/theme/theme.d.ts +75 -0
  243. package/src/utils/alphabet.ts +23 -0
  244. package/src/utils/arrayPadEnd.ts +3 -0
  245. package/src/utils/formatCurrency.ts +9 -0
  246. package/src/utils/getUrlParams.ts +5 -0
  247. package/src/utils/index.ts +6 -0
  248. package/src/utils/ordinalSuffixOf.ts +14 -0
  249. package/src/utils/romanize.ts +40 -0
  250. package/src/utils/withRouteWrapper.tsx +25 -0
  251. package/src/utils/withSuspense.tsx +6 -0
  252. package/styled-components.tsx +60 -0
  253. package/tsconfig.json +21 -0
@@ -0,0 +1,65 @@
1
+ import { Box, TableBody, TableCell, Typography } from '@mui/material'
2
+ import Spinner from '../Spinner'
3
+ import noDataImage from './no-data-illu.svg'
4
+ import { StyledTableRow } from './styles'
5
+
6
+ export const RenderTableBody = ({
7
+ getTableBodyProps,
8
+ prepareRow,
9
+ rows,
10
+ loading,
11
+ currentRows,
12
+ colLength,
13
+ }) => {
14
+ if (loading)
15
+ return (
16
+ <TableCell colSpan={colLength}>
17
+ <Spinner />
18
+ </TableCell>
19
+ )
20
+
21
+ if (!loading && currentRows === 0)
22
+ return (
23
+ <TableCell colSpan={colLength}>
24
+ <Box
25
+ sx={{
26
+ display: 'flex',
27
+ flexDirection: 'column',
28
+ alignItems: 'center',
29
+ justifyContent: 'center',
30
+ }}
31
+ >
32
+ <img
33
+ style={{ width: '200px', height: 'auto', textAlign: 'center' }}
34
+ src={noDataImage}
35
+ />
36
+ <Typography variant="h6" align="center">
37
+ No Records Found
38
+ </Typography>
39
+ </Box>
40
+ </TableCell>
41
+ )
42
+
43
+ return (
44
+ <TableBody {...getTableBodyProps()}>
45
+ {rows?.map((row, index) => {
46
+ prepareRow(row)
47
+ return (
48
+ <StyledTableRow
49
+ key={index}
50
+ {...row.getRowProps()}
51
+ isSelected={row?.isSelected}
52
+ >
53
+ {row.cells?.map((cell, index) => {
54
+ return (
55
+ <TableCell key={index} {...cell.getCellProps()}>
56
+ {cell?.render('Cell')}
57
+ </TableCell>
58
+ )
59
+ })}
60
+ </StyledTableRow>
61
+ )
62
+ })}
63
+ </TableBody>
64
+ )
65
+ }
@@ -0,0 +1,102 @@
1
+ import { Box, Typography } from '@mui/material'
2
+ import DropDownButton from '../../DropDownButton'
3
+ import { StyledPagination, StyledTableFooter } from '../styles'
4
+
5
+ interface TableFooterProps {
6
+ totalCount: number
7
+ limit: number
8
+ handlePagination: (v: number) => void
9
+ page: number
10
+ handlePageLimit?: (v: number) => void
11
+ }
12
+
13
+ export default function TableFooter({
14
+ totalCount,
15
+ limit,
16
+ handlePagination,
17
+ page,
18
+ handlePageLimit,
19
+ }: TableFooterProps) {
20
+ const onChange = (v: number) => {
21
+ handlePagination(v)
22
+ }
23
+ return (
24
+ <StyledTableFooter>
25
+ <TableStats limit={limit} totalCount={totalCount} page={page} />
26
+ <StyledPagination
27
+ page={page}
28
+ count={Math.ceil(totalCount / limit)}
29
+ onChange={(e, v) => onChange(v)}
30
+ variant="outlined"
31
+ shape="rounded"
32
+ />
33
+ {handlePageLimit ? (
34
+ <LimitField handlePageLimit={handlePageLimit} limit={limit} />
35
+ ) : (
36
+ <Box></Box>
37
+ )}
38
+ </StyledTableFooter>
39
+ )
40
+ }
41
+
42
+ export const TableStats = ({
43
+ limit,
44
+ totalCount,
45
+ page,
46
+ }: {
47
+ limit: number
48
+ page: number
49
+ totalCount: number
50
+ }) => {
51
+ const pageStart = (page - 1) * limit + 1
52
+ const pageEnd = page * limit <= totalCount ? page * limit : totalCount
53
+
54
+ return (
55
+ <Box>
56
+ <Typography variant="subtitle1">{`${pageStart} - ${pageEnd} of ${totalCount}`}</Typography>
57
+ </Box>
58
+ )
59
+ }
60
+
61
+ const LimitField = ({ handlePageLimit, limit }) => {
62
+ return (
63
+ <Box>
64
+ <DropDownButton
65
+ buttonProps={{
66
+ variant: 'outlined',
67
+ color: 'secondary',
68
+ sx: {
69
+ padding: '0px 10px',
70
+ color: '#121212',
71
+ fontSize: '13px',
72
+ border: '1px solid #1212121A',
73
+ },
74
+ }}
75
+ label={`${limit} / page`}
76
+ menu={[
77
+ {
78
+ label: 10,
79
+ onClick: () => handlePageLimit(10),
80
+ },
81
+
82
+ {
83
+ label: 20,
84
+ onClick: () => handlePageLimit(20),
85
+ },
86
+ {
87
+ label: 30,
88
+ onClick: () => handlePageLimit(30),
89
+ },
90
+ {
91
+ label: 50,
92
+ onClick: () => handlePageLimit(50),
93
+ },
94
+ {
95
+ label: 100,
96
+ onClick: () => handlePageLimit(100),
97
+ },
98
+ ]}
99
+ />
100
+ </Box>
101
+ )
102
+ }
@@ -0,0 +1 @@
1
+ export { default } from './TableFooter'
@@ -0,0 +1,28 @@
1
+ import { Box, Pagination, styled } from '@mui/material'
2
+
3
+ export const StyledTableStats = styled(Box)(({}) => ({}))
4
+
5
+ export const StyledTableFooter = styled(Box)(({ theme }) => ({
6
+ paddingTop: '1rem',
7
+ width: '100%',
8
+ display: 'flex',
9
+ justifyContent: 'space-between',
10
+ alignItems: 'center',
11
+ }))
12
+
13
+ export const StyledPagination = styled(Pagination)(({ theme }) => ({
14
+ '& .MuiPaginationItem-root': {
15
+ border: 'none',
16
+ background: theme.palette.secondary.dark,
17
+ },
18
+ '& .MuiPaginationItem-previousNext': {
19
+ border: theme.borders.grayLight,
20
+ background: theme.palette.common.white,
21
+ },
22
+ '& .Mui-selected': {
23
+ border: `2px solid ${theme.palette.common.yellow}`,
24
+ },
25
+ '& .MuiPaginationItem-ellipsis': {
26
+ background: theme.palette.common.white,
27
+ },
28
+ }))
@@ -0,0 +1,219 @@
1
+ import {
2
+ alpha,
3
+ Box,
4
+ IconButton,
5
+ ListItemIcon,
6
+ styled,
7
+ Table as MuiTable,
8
+ TableBody,
9
+ TableCell,
10
+ TableContainer,
11
+ TableHead,
12
+ TableRow,
13
+ Typography,
14
+ } from '@mui/material'
15
+ import _ from 'lodash'
16
+ import { useEffect, useState } from 'react'
17
+ import Spinner from '../Spinner'
18
+ import { SortAscIcon, SortDescIcon, SortIcon } from './Icons'
19
+ import TableFooter from './TableFooter'
20
+
21
+ export interface ColumnProps {
22
+ dataIndex: string
23
+ key: string
24
+ title: any
25
+ render?: (cellData: any, row: any, index: number) => any
26
+ textColor?: string
27
+ sort?: boolean
28
+ width?: string //pixels
29
+ }
30
+
31
+ interface TableProps {
32
+ columns: Array<ColumnProps>
33
+ rowKey?: string
34
+ dataSource?: any[]
35
+ loading?: boolean
36
+ onRowClick?: (row: any) => void
37
+ pagination?: {
38
+ page: number
39
+ limit: number
40
+ totalCount: number
41
+ onChange: (v: number) => void
42
+ onChangeLimit?: (v: number) => void
43
+ }
44
+ onSort?: (sort: any) => void
45
+ dense?: boolean
46
+ }
47
+
48
+ type Order = 'asc' | 'desc' | ''
49
+ type Sort = {}
50
+
51
+ export default function Table({
52
+ columns,
53
+ dataSource,
54
+ onRowClick,
55
+ pagination,
56
+ loading,
57
+ onSort,
58
+ dense = false,
59
+ }: TableProps) {
60
+ const [sort, setSort] = useState<Sort>({})
61
+
62
+ const handleSortClick = (sortBykey) => {
63
+ setSort((prev) => {
64
+ if (prev[sortBykey]) {
65
+ if (prev[sortBykey] === 'desc') return { ...prev, [sortBykey]: 'asc' }
66
+ if (prev[sortBykey] === 'asc') {
67
+ delete prev[sortBykey]
68
+ return { ...prev }
69
+ }
70
+ } else {
71
+ return {
72
+ ...prev,
73
+ [sortBykey]: 'desc',
74
+ }
75
+ }
76
+ })
77
+ }
78
+
79
+ useEffect(() => {
80
+ if (!onSort) return
81
+
82
+ onSort({
83
+ sortBy: Object.keys(sort).join(','),
84
+ sortOrder: Object.keys(sort)
85
+ .map((item) => sort[item])
86
+ .join(','),
87
+ })
88
+ }, [sort])
89
+
90
+ return (
91
+ <TableContainer>
92
+ <>
93
+ <MuiTable>
94
+ <TableHead>
95
+ <TableRow>
96
+ {columns.map((col, index) => (
97
+ <TableCell
98
+ key={index}
99
+ sx={{
100
+ ...(col?.width && {
101
+ width: col?.width,
102
+ }),
103
+ }}
104
+ >
105
+ <>
106
+ <Box>{col.title}</Box>
107
+ </>
108
+ {col.sort && (
109
+ <IconButton onClick={() => handleSortClick(col.dataIndex)}>
110
+ <ListItemIcon>
111
+ {sort[col.dataIndex] === 'asc' ? (
112
+ <SortAscIcon />
113
+ ) : sort[col.dataIndex] === 'desc' ? (
114
+ <SortDescIcon />
115
+ ) : (
116
+ <SortIcon />
117
+ )}
118
+ </ListItemIcon>
119
+ </IconButton>
120
+ )}
121
+ </TableCell>
122
+ ))}
123
+ </TableRow>
124
+ </TableHead>
125
+ {!loading ? (
126
+ <>
127
+ {dataSource?.length ? (
128
+ <TableBody>
129
+ {dataSource?.map((row, index) => (
130
+ <StyledTableRow
131
+ canRowClick={!!onRowClick}
132
+ hover={!!onRowClick}
133
+ key={index}
134
+ onClick={() => {
135
+ return onRowClick && onRowClick(row)
136
+ }}
137
+ >
138
+ {columns.map((col, colIndex) => (
139
+ <TableCell
140
+ sx={{
141
+ color: col.textColor,
142
+ padding: dense ? '10px' : '15px',
143
+ }}
144
+ key={colIndex}
145
+ >
146
+ <>
147
+ {col?.render
148
+ ? col.render(row[col.dataIndex], row, index)
149
+ : _.get(row, col.dataIndex)}
150
+ </>
151
+ </TableCell>
152
+ ))}
153
+ </StyledTableRow>
154
+ ))}
155
+ </TableBody>
156
+ ) : (
157
+ <Box>
158
+ <Typography sx={{ padding: '10px' }}>
159
+ No Records Found !..
160
+ </Typography>
161
+ </Box>
162
+ )}
163
+ </>
164
+ ) : (
165
+ <Spinner />
166
+ )}
167
+ </MuiTable>
168
+ </>
169
+ <>
170
+ {pagination && (
171
+ <TableFooter
172
+ page={pagination.page}
173
+ limit={pagination.limit}
174
+ totalCount={pagination.totalCount}
175
+ handlePagination={pagination.onChange}
176
+ handlePageLimit={pagination.onChangeLimit}
177
+ />
178
+ )}
179
+ </>
180
+ </TableContainer>
181
+ )
182
+ }
183
+
184
+ // const StyledSortButton = styled(IconButton)<{
185
+ // sortOrder: Order
186
+ // dataIndex: string
187
+ // }>(({ theme, sortOrder, dataIndex }) => ({
188
+ // marginLeft: '10px',
189
+ // ...(sortOrder === '' && {
190
+ // '& .MuiSvgIcon-root': {
191
+ // // visibility: 'hidden',
192
+ // },
193
+ // // '&:hover .MuiSvgIcon-root': {
194
+ // // visibility: 'visible',
195
+ // // opacity: 0.4,
196
+ // // },
197
+ // transition: 'transform 1s ease-in-out',
198
+ // }),
199
+ // ...(sortOrder === 'asc' && {
200
+ // transition: 'transform 1s ease-in-out',
201
+ // }),
202
+ // ...(sortOrder === 'desc' && {
203
+ // '& .MuiSvgIcon-root': {
204
+ // transform: 'rotate(180deg)',
205
+ // },
206
+ // transition: 'transform 1s ease-in-out',
207
+ // }),
208
+ // }))
209
+
210
+ const StyledTableRow = styled(TableRow)<{ canRowClick: boolean }>(
211
+ ({ theme, canRowClick }) => ({
212
+ ...(canRowClick && {
213
+ cursor: 'pointer',
214
+ '&.MuiTableRow-hover:hover': {
215
+ backgroundColor: alpha('#f2f2f2', 0.4),
216
+ },
217
+ }),
218
+ }),
219
+ )