@campxdev/shared 0.5.19 → 0.5.21

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 (200) hide show
  1. package/antd.customize.less +73 -73
  2. package/exports.ts +15 -15
  3. package/package.json +52 -52
  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 +17 -17
  7. package/src/assets/images/unauth.svg +92 -92
  8. package/src/components/ActionButton.tsx +28 -28
  9. package/src/components/Attachment.tsx +26 -26
  10. package/src/components/AutocompleteSearch/AutocompleteSearch.tsx +57 -57
  11. package/src/components/AutocompleteSearch/index.tsx +1 -1
  12. package/src/components/Breadcrumbs.tsx +73 -73
  13. package/src/components/Card.tsx +97 -97
  14. package/src/components/CardsGrid.tsx +28 -28
  15. package/src/components/ChangePassword.tsx +164 -164
  16. package/src/components/Chips.tsx +77 -77
  17. package/src/components/Detail.tsx +15 -15
  18. package/src/components/DetailsGrid.tsx +52 -52
  19. package/src/components/DividerHeading.tsx +40 -40
  20. package/src/components/DrawerWrapper/DialogWrapper.tsx +63 -63
  21. package/src/components/DrawerWrapper/DrawerTemplate.tsx +53 -53
  22. package/src/components/DrawerWrapper/DrawerWrapper.tsx +53 -53
  23. package/src/components/DropDownButton.tsx +190 -190
  24. package/src/components/ErrorBoundary/ErrorBoundary.tsx +28 -28
  25. package/src/components/ErrorBoundary/ErrorFallback.tsx +236 -236
  26. package/src/components/ErrorBoundary/GlobalNetworkLoadingIndicator.tsx +13 -13
  27. package/src/components/ErrorBoundary/index.tsx +1 -1
  28. package/src/components/ErrorBox.tsx +42 -42
  29. package/src/components/FloatingContainer.tsx +26 -26
  30. package/src/components/FullCalendar/Actions.tsx +162 -162
  31. package/src/components/FullCalendar/FullCalendarWrapper.tsx +54 -54
  32. package/src/components/FullScreenLoader.tsx +19 -19
  33. package/src/components/HookForm/AutoCompleteSearch.tsx +143 -143
  34. package/src/components/HookForm/DatePicker.tsx +65 -65
  35. package/src/components/HookForm/DateTimePicker.tsx +70 -70
  36. package/src/components/HookForm/FormLabel.tsx +14 -14
  37. package/src/components/HookForm/MultiCheckbox.tsx +82 -82
  38. package/src/components/HookForm/MultiSelect.tsx +100 -100
  39. package/src/components/HookForm/RadioGroup.tsx +112 -112
  40. package/src/components/HookForm/SingleCheckbox.tsx +46 -46
  41. package/src/components/HookForm/SingleSelect.tsx +93 -93
  42. package/src/components/HookForm/TextField.tsx +74 -74
  43. package/src/components/HookForm/TimePicker.tsx +82 -82
  44. package/src/components/HookForm/index.ts +23 -23
  45. package/src/components/IconButtons/IconButtons.tsx +137 -137
  46. package/src/components/IconButtons/Icons.tsx +268 -268
  47. package/src/components/IconButtons/assets/edit.svg +4 -4
  48. package/src/components/IconButtons/assets/eye.svg +6 -6
  49. package/src/components/IconButtons/assets/trash.svg +7 -7
  50. package/src/components/IconButtons/index.tsx +8 -8
  51. package/src/components/IconLabel.tsx +37 -37
  52. package/src/components/Image/Image.tsx +43 -43
  53. package/src/components/Image/index.tsx +1 -1
  54. package/src/components/ImageUpload.tsx +98 -98
  55. package/src/components/Input/AutoCompleteSearch.tsx +143 -143
  56. package/src/components/Input/DatePicker.tsx +60 -60
  57. package/src/components/Input/DateRangePicker.tsx +131 -131
  58. package/src/components/Input/DateTimePicker.tsx +70 -70
  59. package/src/components/Input/FormLabel.tsx +14 -14
  60. package/src/components/Input/MultiCheckbox.tsx +79 -79
  61. package/src/components/Input/MultiSelect.tsx +52 -52
  62. package/src/components/Input/RadioGroup.tsx +55 -55
  63. package/src/components/Input/SingleCheckbox.tsx +23 -23
  64. package/src/components/Input/SingleSelect.tsx +139 -139
  65. package/src/components/Input/TextField.tsx +50 -50
  66. package/src/components/Input/TimePicker.tsx +82 -82
  67. package/src/components/Input/index.ts +26 -26
  68. package/src/components/JsonPreview/JsonPreview.tsx +7 -7
  69. package/src/components/JsonPreview/index.tsx +1 -1
  70. package/src/components/LabelValue/LabelValue.tsx +21 -21
  71. package/src/components/LabelValue/index.tsx +1 -1
  72. package/src/components/Layout/ChangePassword.tsx +49 -49
  73. package/src/components/Layout/Header/AppHeader.tsx +113 -113
  74. package/src/components/Layout/Header/AppsMenu.tsx +92 -92
  75. package/src/components/Layout/Header/CogWheelMenu.tsx +33 -33
  76. package/src/components/Layout/Header/FreshDeskHelpButton.tsx +19 -19
  77. package/src/components/Layout/Header/Notification.tsx +13 -13
  78. package/src/components/Layout/Header/UserBox.tsx +70 -70
  79. package/src/components/Layout/Header/applications.ts +87 -87
  80. package/src/components/Layout/Header/assets/campx.svg +29 -29
  81. package/src/components/Layout/Header/assets/campx_square_small.svg +9 -9
  82. package/src/components/Layout/Header/assets/exams_small.svg +12 -12
  83. package/src/components/Layout/Header/assets/hostel_small.svg +13 -13
  84. package/src/components/Layout/Header/assets/index.ts +23 -23
  85. package/src/components/Layout/Header/assets/pay_small.svg +16 -16
  86. package/src/components/Layout/Header/assets/payxHeader.svg +21 -21
  87. package/src/components/Layout/Header/assets/people_small.svg +9 -9
  88. package/src/components/Layout/Header/assets/peoplexHeader.svg +14 -14
  89. package/src/components/Layout/Header/icons.tsx +57 -57
  90. package/src/components/Layout/Header/index.tsx +1 -1
  91. package/src/components/Layout/Header/styles.tsx +98 -98
  92. package/src/components/LayoutWrapper.tsx +25 -25
  93. package/src/components/LinearProgress.tsx +19 -19
  94. package/src/components/ListItemButton.tsx +94 -94
  95. package/src/components/LoginForm.tsx +103 -103
  96. package/src/components/MediaRow/MediaRow.tsx +69 -69
  97. package/src/components/MediaRow/index.tsx +1 -1
  98. package/src/components/MenuButton.tsx +103 -103
  99. package/src/components/ModalButtons/DialogButton.tsx +85 -85
  100. package/src/components/ModalButtons/DrawerButton.tsx +89 -89
  101. package/src/components/ModalButtons/index.tsx +4 -4
  102. package/src/components/NoDataIllustration/NoDataIllustration.tsx +32 -32
  103. package/src/components/NoDataIllustration/index.tsx +1 -1
  104. package/src/components/PageContent.tsx +17 -17
  105. package/src/components/PageHeader.tsx +52 -52
  106. package/src/components/PageNotFound.tsx +26 -26
  107. package/src/components/PopupConfirm/ConfirmContextProvider.tsx +40 -40
  108. package/src/components/PopupConfirm/PopupConfirm.tsx +34 -34
  109. package/src/components/PopupConfirm/index.tsx +1 -1
  110. package/src/components/PopupConfirm/useConfirm.ts +47 -47
  111. package/src/components/Row/Row.tsx +24 -24
  112. package/src/components/Row/index.tsx +1 -1
  113. package/src/components/SearchBar/SearchBar.tsx +53 -53
  114. package/src/components/SearchBar/index.tsx +1 -1
  115. package/src/components/SideMenuHeader.tsx +29 -29
  116. package/src/components/SideNav.tsx +150 -150
  117. package/src/components/Spinner.tsx +18 -18
  118. package/src/components/StepsHeader/StepsHeader.tsx +115 -115
  119. package/src/components/StepsHeader/index.tsx +1 -1
  120. package/src/components/Styled/OutlinedIconButton.tsx +7 -7
  121. package/src/components/Styled/index.tsx +1 -1
  122. package/src/components/StyledTableContainer.tsx +33 -33
  123. package/src/components/Swiper/Swiper.tsx +39 -39
  124. package/src/components/Swiper/index.tsx +1 -1
  125. package/src/components/SwitchButton/SwitchButton.tsx +41 -41
  126. package/src/components/SwitchButton/index.tsx +1 -1
  127. package/src/components/Table.tsx +42 -42
  128. package/src/components/TableComponent/BatchActionsHeader.tsx +58 -58
  129. package/src/components/TableComponent/Icons/index.tsx +50 -50
  130. package/src/components/TableComponent/ReactTable.tsx +293 -293
  131. package/src/components/TableComponent/RenderTableBody.tsx +64 -64
  132. package/src/components/TableComponent/TableFooter/TableFooter.tsx +102 -102
  133. package/src/components/TableComponent/TableFooter/index.tsx +1 -1
  134. package/src/components/TableComponent/TableFooter/styles.tsx +28 -28
  135. package/src/components/TableComponent/index.tsx +221 -221
  136. package/src/components/TableComponent/react-table-config.d.ts +129 -129
  137. package/src/components/TableComponent/styles.tsx +173 -173
  138. package/src/components/TableComponent/types.ts +57 -57
  139. package/src/components/Tabs/Tabs.tsx +52 -52
  140. package/src/components/Tabs/TabsContainer.tsx +50 -50
  141. package/src/components/Tabs/index.tsx +1 -1
  142. package/src/components/Tabs/styles.tsx +55 -55
  143. package/src/components/ToastContainer/ToastContainer.tsx +42 -42
  144. package/src/components/ToastContainer/index.tsx +1 -1
  145. package/src/components/UploadButton/UploadButton.tsx +98 -98
  146. package/src/components/UploadButton/index.tsx +1 -1
  147. package/src/components/UploadButton/types.ts +14 -14
  148. package/src/components/UploadDocument/UploadDocument.tsx +108 -108
  149. package/src/components/UploadDocument/index.tsx +1 -1
  150. package/src/components/UploadFileDialog/UploadFileDialog.tsx +240 -240
  151. package/src/components/UploadFileDialog/index.tsx +1 -1
  152. package/src/components/index.ts +82 -82
  153. package/src/config/axios.ts +73 -73
  154. package/src/constants/UIConstants.ts +97 -97
  155. package/src/constants/formValidations.ts +6 -6
  156. package/src/constants/index.ts +5 -5
  157. package/src/constants/isDevelopment.ts +3 -3
  158. package/src/constants/permissions.ts +67 -67
  159. package/src/constants/validateMessages.ts +12 -12
  160. package/src/contexts/LoginFormProvider.tsx +39 -39
  161. package/src/contexts/Providers.tsx +57 -58
  162. package/src/contexts/QueryClientProvider.tsx +22 -22
  163. package/src/hooks/index.ts +3 -3
  164. package/src/hooks/useAppInit.ts +33 -27
  165. package/src/hooks/useAuth.ts +90 -90
  166. package/src/hooks/useFetch.ts +53 -53
  167. package/src/hooks/useRouter.ts +31 -31
  168. package/src/layouts/Components/DashBoardMenu.tsx +232 -232
  169. package/src/layouts/Components/icons/index.tsx +403 -403
  170. package/src/layouts/Components/styles.tsx +60 -60
  171. package/src/layouts/ComponentsLayout.tsx +3 -3
  172. package/src/permissions/PageWithPermission.tsx +18 -18
  173. package/src/permissions/PermissionDeniedPage.tsx +16 -16
  174. package/src/permissions/PermissionsStore.ts +352 -295
  175. package/src/permissions/ValidateAccess.tsx +18 -18
  176. package/src/permissions/index.ts +3 -3
  177. package/src/react-app-env.d.ts +1 -1
  178. package/src/shared-state/AssetsStore.ts +15 -15
  179. package/src/shared-state/UserStore.ts +13 -13
  180. package/src/shared-state/index.ts +3 -3
  181. package/src/theme/App.less +3 -3
  182. package/src/theme/MuiThemeProvider.tsx +13 -13
  183. package/src/theme/customCssBaseline.ts +78 -78
  184. package/src/theme/index.css +75 -75
  185. package/src/theme/muiTheme.ts +516 -516
  186. package/src/theme/theme.d.ts +75 -75
  187. package/src/utils/alphabet.ts +23 -23
  188. package/src/utils/arrayPadEnd.ts +3 -3
  189. package/src/utils/formatCurrency.ts +9 -9
  190. package/src/utils/getUrlParams.ts +5 -5
  191. package/src/utils/index.ts +8 -8
  192. package/src/utils/logout.ts +24 -24
  193. package/src/utils/ordinalSuffixOf.ts +14 -14
  194. package/src/utils/romanize.ts +40 -40
  195. package/src/utils/withLocalization.tsx +11 -11
  196. package/src/utils/withRouteWrapper.tsx +25 -25
  197. package/src/utils/withSuspense.tsx +6 -6
  198. package/styled-components.tsx +60 -60
  199. package/todo.md +8 -8
  200. package/tsconfig.json +21 -21
@@ -1,28 +1,28 @@
1
- import { Button, ButtonProps, CircularProgress } from '@mui/material'
2
- import React from 'react'
3
-
4
- interface ActionButtonProps extends ButtonProps {
5
- loading?: boolean
6
- [key: string]: any
7
- variant?: any
8
- }
9
-
10
- export default function ActionButton({
11
- children,
12
- loading,
13
- ...props
14
- }: ActionButtonProps) {
15
- return (
16
- <React.Fragment>
17
- <Button
18
- variant={!props?.variant ? 'contained' : props?.variant}
19
- color="primary"
20
- endIcon={loading ? <CircularProgress size={20} /> : null}
21
- disabled={loading}
22
- {...props}
23
- >
24
- {children}
25
- </Button>
26
- </React.Fragment>
27
- )
28
- }
1
+ import { Button, ButtonProps, CircularProgress } from '@mui/material'
2
+ import React from 'react'
3
+
4
+ interface ActionButtonProps extends ButtonProps {
5
+ loading?: boolean
6
+ [key: string]: any
7
+ variant?: any
8
+ }
9
+
10
+ export default function ActionButton({
11
+ children,
12
+ loading,
13
+ ...props
14
+ }: ActionButtonProps) {
15
+ return (
16
+ <React.Fragment>
17
+ <Button
18
+ variant={!props?.variant ? 'contained' : props?.variant}
19
+ color="primary"
20
+ endIcon={loading ? <CircularProgress size={20} /> : null}
21
+ disabled={loading}
22
+ {...props}
23
+ >
24
+ {children}
25
+ </Button>
26
+ </React.Fragment>
27
+ )
28
+ }
@@ -1,26 +1,26 @@
1
- import React from 'react'
2
- import styled from 'styled-components'
3
-
4
- interface AttachemntProps {
5
- name: string
6
- onClick?: Function
7
- actions?: any
8
- }
9
-
10
- const AttachmentContainer = styled.div`
11
- background: rgba(0, 0, 0, 0.1);
12
- border-radius: 8px;
13
- padding: 8px;
14
- display: flex;
15
- justify-content: space-between;
16
- cursor: pointer;
17
- `
18
-
19
- export default function Attachment(props: AttachemntProps) {
20
- return (
21
- <AttachmentContainer onClick={() => props.onClick && props.onClick()}>
22
- <div>{props.name}</div>
23
- <div onClick={(e) => e.stopPropagation()}>{props.actions}</div>
24
- </AttachmentContainer>
25
- )
26
- }
1
+ import React from 'react'
2
+ import styled from 'styled-components'
3
+
4
+ interface AttachemntProps {
5
+ name: string
6
+ onClick?: Function
7
+ actions?: any
8
+ }
9
+
10
+ const AttachmentContainer = styled.div`
11
+ background: rgba(0, 0, 0, 0.1);
12
+ border-radius: 8px;
13
+ padding: 8px;
14
+ display: flex;
15
+ justify-content: space-between;
16
+ cursor: pointer;
17
+ `
18
+
19
+ export default function Attachment(props: AttachemntProps) {
20
+ return (
21
+ <AttachmentContainer onClick={() => props.onClick && props.onClick()}>
22
+ <div>{props.name}</div>
23
+ <div onClick={(e) => e.stopPropagation()}>{props.actions}</div>
24
+ </AttachmentContainer>
25
+ )
26
+ }
@@ -1,57 +1,57 @@
1
- import { Autocomplete as MuiAutocomplete, TextField } from '@mui/material'
2
- import _ from 'lodash'
3
- import { useEffect, useMemo, useState } from 'react'
4
-
5
- export default function AutocompleteSearch({
6
- name,
7
- value,
8
- onInputChange,
9
- onChange,
10
- label,
11
- options: _options,
12
- ...props
13
- }) {
14
- const [options, setOptions] = useState([])
15
-
16
- const debouncedChangeHandler = useMemo(
17
- () =>
18
- _.debounce((e, newInput) => {
19
- onInputChange(newInput)
20
- }, 300),
21
- [],
22
- )
23
-
24
- useEffect(() => {
25
- if (!_options) return
26
- setOptions((prev) => [..._options])
27
- }, [_options])
28
-
29
- return (
30
- <MuiAutocomplete
31
- id="autocomplete-search"
32
- fullWidth
33
- getOptionLabel={(option) =>
34
- typeof option === 'string' ? option : option?.label
35
- }
36
- filterOptions={(x) => x}
37
- options={options || []}
38
- autoComplete
39
- includeInputInList
40
- filterSelectedOptions
41
- value={value}
42
- onChange={(event: any, newValue: any) => {
43
- if (!newValue) return
44
- // onInputChange(newValue)
45
- onChange(newValue)
46
- }}
47
- onInputChange={debouncedChangeHandler}
48
- renderInput={(params) => (
49
- <TextField {...params} label={label} fullWidth />
50
- )}
51
- renderOption={(props, option) => {
52
- return <li {...props}>{option?.label}</li>
53
- }}
54
- {...props}
55
- />
56
- )
57
- }
1
+ import { Autocomplete as MuiAutocomplete, TextField } from '@mui/material'
2
+ import _ from 'lodash'
3
+ import { useEffect, useMemo, useState } from 'react'
4
+
5
+ export default function AutocompleteSearch({
6
+ name,
7
+ value,
8
+ onInputChange,
9
+ onChange,
10
+ label,
11
+ options: _options,
12
+ ...props
13
+ }) {
14
+ const [options, setOptions] = useState([])
15
+
16
+ const debouncedChangeHandler = useMemo(
17
+ () =>
18
+ _.debounce((e, newInput) => {
19
+ onInputChange(newInput)
20
+ }, 300),
21
+ [],
22
+ )
23
+
24
+ useEffect(() => {
25
+ if (!_options) return
26
+ setOptions((prev) => [..._options])
27
+ }, [_options])
28
+
29
+ return (
30
+ <MuiAutocomplete
31
+ id="autocomplete-search"
32
+ fullWidth
33
+ getOptionLabel={(option) =>
34
+ typeof option === 'string' ? option : option?.label
35
+ }
36
+ filterOptions={(x) => x}
37
+ options={options || []}
38
+ autoComplete
39
+ includeInputInList
40
+ filterSelectedOptions
41
+ value={value}
42
+ onChange={(event: any, newValue: any) => {
43
+ if (!newValue) return
44
+ // onInputChange(newValue)
45
+ onChange(newValue)
46
+ }}
47
+ onInputChange={debouncedChangeHandler}
48
+ renderInput={(params) => (
49
+ <TextField {...params} label={label} fullWidth />
50
+ )}
51
+ renderOption={(props, option) => {
52
+ return <li {...props}>{option?.label}</li>
53
+ }}
54
+ {...props}
55
+ />
56
+ )
57
+ }
@@ -1 +1 @@
1
- export { default } from './AutocompleteSearch'
1
+ export { default } from './AutocompleteSearch'
@@ -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
+ }