@campxdev/shared 1.8.14 → 1.8.16

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 (267) hide show
  1. package/antd.customize.less +73 -0
  2. package/exports.ts +19 -0
  3. package/package.json +4 -20
  4. package/src/assets/fonts/avenir/Avenir-Book.ttf +0 -0
  5. package/src/assets/fonts/avenir/Avenir-Heavy.ttf +0 -0
  6. package/src/assets/fonts/avenir/Avenir-HeavyOblique.ttf +0 -0
  7. package/src/assets/fonts/avenir/Avenir-Medium.ttf +0 -0
  8. package/src/assets/fonts/avenir/Avenir-MediumOblique.ttf +0 -0
  9. package/src/assets/fonts/avenir/index.ts +13 -0
  10. package/src/assets/fonts/poppins/Poppins-Bold.ttf +0 -0
  11. package/src/assets/fonts/poppins/Poppins-Italic.ttf +0 -0
  12. package/src/assets/fonts/poppins/Poppins-Light.ttf +0 -0
  13. package/src/assets/fonts/poppins/Poppins-LightItalic.ttf +0 -0
  14. package/src/assets/fonts/poppins/Poppins-Medium.ttf +0 -0
  15. package/src/assets/fonts/poppins/Poppins-MediumItalic.ttf +0 -0
  16. package/src/assets/fonts/poppins/Poppins-Regular.ttf +0 -0
  17. package/src/assets/fonts/poppins/Poppins-SemiBold.ttf +0 -0
  18. package/src/assets/fonts/poppins/Poppins-SemiBoldItalic.ttf +0 -0
  19. package/src/assets/fonts/poppins/index.ts +18 -0
  20. package/src/assets/images/401.png +0 -0
  21. package/src/assets/images/403.png +0 -0
  22. package/src/assets/images/404.png +0 -0
  23. package/src/assets/images/404notfound.svg +1 -0
  24. package/src/assets/images/500.png +0 -0
  25. package/src/assets/images/avatar.png +0 -0
  26. package/src/assets/images/campx_logo__full_primary.png +0 -0
  27. package/src/assets/images/index.ts +17 -0
  28. package/src/assets/images/internalservererror.svg +1 -0
  29. package/src/assets/images/noInternet.svg +1 -0
  30. package/src/assets/images/nointernet.png +0 -0
  31. package/src/assets/images/notfound.png +0 -0
  32. package/src/assets/images/pagenotfound.svg +1 -0
  33. package/src/assets/images/permissiondenied.svg +1 -0
  34. package/src/assets/images/unauth.svg +92 -0
  35. package/src/components/ActionButton.tsx +20 -0
  36. package/src/components/Attachment.tsx +26 -0
  37. package/src/components/AutocompleteSearch/AutocompleteSearch.tsx +57 -0
  38. package/src/components/AutocompleteSearch/index.tsx +1 -0
  39. package/src/components/Breadcrumbs.tsx +72 -0
  40. package/src/components/Card.tsx +98 -0
  41. package/src/components/CardsGrid.tsx +28 -0
  42. package/src/components/ChangePassword.tsx +123 -0
  43. package/src/components/Chips.tsx +81 -0
  44. package/src/components/Detail.tsx +15 -0
  45. package/src/components/DetailsGrid.tsx +52 -0
  46. package/src/components/DividerHeading.tsx +41 -0
  47. package/src/components/DrawerWrapper/DialogWrapper.tsx +67 -0
  48. package/src/components/DrawerWrapper/DrawerTemplate.tsx +53 -0
  49. package/src/components/DrawerWrapper/DrawerWrapper.tsx +53 -0
  50. package/src/components/DropDownButton/AnchorElement.tsx +44 -0
  51. package/src/components/DropDownButton/DropDownButton.tsx +184 -0
  52. package/src/components/DropDownButton/DropdownMenuItem.tsx +110 -0
  53. package/src/components/DropDownButton/index.tsx +1 -0
  54. package/src/components/DropDownButton/styles.tsx +59 -0
  55. package/src/components/ErrorBoundary/ErrorBoundary.tsx +33 -0
  56. package/src/components/ErrorBoundary/ErrorFallback.tsx +241 -0
  57. package/src/components/ErrorBoundary/GlobalNetworkLoadingIndicator.tsx +13 -0
  58. package/src/components/ErrorBoundary/index.tsx +1 -0
  59. package/src/components/ErrorBox.tsx +42 -0
  60. package/src/components/ExcelToJsonInput/ExcelJsonUpload.tsx +50 -0
  61. package/src/components/ExcelToJsonInput/ExcelToJsonInput.tsx +57 -0
  62. package/src/components/ExcelToJsonInput/index.tsx +1 -0
  63. package/src/components/FilterComponents/FilterButton.tsx +56 -0
  64. package/src/components/FilterComponents/SearchBar.tsx +45 -0
  65. package/src/components/FloatingContainer.tsx +33 -0
  66. package/src/components/Form/Form.tsx +147 -0
  67. package/src/components/Form/RenderForm.tsx +189 -0
  68. package/src/components/FullScreenLoader.tsx +19 -0
  69. package/src/components/HookForm/AutoCompleteSearch.tsx +113 -0
  70. package/src/components/HookForm/DatePicker.tsx +40 -0
  71. package/src/components/HookForm/DateTimePicker.tsx +47 -0
  72. package/src/components/HookForm/FormLabel.tsx +14 -0
  73. package/src/components/HookForm/MultiCheckbox.tsx +69 -0
  74. package/src/components/HookForm/MultiSelect.tsx +53 -0
  75. package/src/components/HookForm/RadioGroup.tsx +47 -0
  76. package/src/components/HookForm/SingleCheckbox.tsx +34 -0
  77. package/src/components/HookForm/SingleSelect.tsx +46 -0
  78. package/src/components/HookForm/TextField.tsx +40 -0
  79. package/src/components/HookForm/TimePicker.tsx +40 -0
  80. package/src/components/HookForm/index.ts +23 -0
  81. package/src/components/IconButtons/IconButtons.tsx +137 -0
  82. package/src/components/IconButtons/Icons.tsx +268 -0
  83. package/src/components/IconButtons/assets/edit.svg +4 -0
  84. package/src/components/IconButtons/assets/eye.svg +6 -0
  85. package/src/components/IconButtons/assets/trash.svg +7 -0
  86. package/src/components/IconButtons/index.tsx +8 -0
  87. package/src/components/IconLabel.tsx +37 -0
  88. package/src/components/Image/Image.tsx +45 -0
  89. package/src/components/Image/broken-image.png +0 -0
  90. package/src/components/Image/index.tsx +1 -0
  91. package/src/components/ImageUpload.tsx +98 -0
  92. package/src/components/Input/AsyncSearchSelect/AsyncSearchSelect.tsx +216 -0
  93. package/src/components/Input/AsyncSearchSelect/index.tsx +1 -0
  94. package/src/components/Input/AsyncSearchSelect/styles.tsx +105 -0
  95. package/src/components/Input/AutoCompleteSearch.tsx +121 -0
  96. package/src/components/Input/DatePicker.tsx +87 -0
  97. package/src/components/Input/DateRangePicker.tsx +105 -0
  98. package/src/components/Input/DateTimePicker.tsx +84 -0
  99. package/src/components/Input/FormLabel.tsx +21 -0
  100. package/src/components/Input/MultiCheckbox.tsx +64 -0
  101. package/src/components/Input/MultiSelect.tsx +150 -0
  102. package/src/components/Input/RadioGroup.tsx +104 -0
  103. package/src/components/Input/SingleCheckbox.tsx +78 -0
  104. package/src/components/Input/SingleSelect.tsx +104 -0
  105. package/src/components/Input/TextField.tsx +46 -0
  106. package/src/components/Input/TimePicker.tsx +77 -0
  107. package/src/components/Input/index.ts +26 -0
  108. package/src/components/Input/types.ts +3 -0
  109. package/src/components/JsonPreview.tsx +7 -0
  110. package/src/components/LabelValue.tsx +21 -0
  111. package/src/components/Layout/ChangePassword.tsx +49 -0
  112. package/src/components/Layout/Header/AppHeader.tsx +112 -0
  113. package/src/components/Layout/Header/AppsMenu.tsx +105 -0
  114. package/src/components/Layout/Header/HeaderActions/CogWheelMenu.tsx +33 -0
  115. package/src/components/Layout/Header/HeaderActions/FreshDeskHelpButton.tsx +24 -0
  116. package/src/components/Layout/Header/HeaderActions/HeaderActions.tsx +18 -0
  117. package/src/components/Layout/Header/HeaderActions/UserBox.tsx +56 -0
  118. package/src/components/Layout/Header/Notification.tsx +13 -0
  119. package/src/components/Layout/Header/applications.ts +103 -0
  120. package/src/components/Layout/Header/assets/background.png +0 -0
  121. package/src/components/Layout/Header/assets/campx.png +0 -0
  122. package/src/components/Layout/Header/assets/campx_square_small.svg +9 -0
  123. package/src/components/Layout/Header/assets/commuteX.png +0 -0
  124. package/src/components/Layout/Header/assets/commutex.png +0 -0
  125. package/src/components/Layout/Header/assets/commutex.svg +14 -0
  126. package/src/components/Layout/Header/assets/commutexSmall.svg +11 -0
  127. package/src/components/Layout/Header/assets/contactBg.png +0 -0
  128. package/src/components/Layout/Header/assets/enroll.svg +14 -0
  129. package/src/components/Layout/Header/assets/enroll_logo.svg +9 -0
  130. package/src/components/Layout/Header/assets/enrollx.svg +14 -0
  131. package/src/components/Layout/Header/assets/entrollx.png +0 -0
  132. package/src/components/Layout/Header/assets/exams_small.svg +12 -0
  133. package/src/components/Layout/Header/assets/examsx.svg +14 -0
  134. package/src/components/Layout/Header/assets/examx.png +0 -0
  135. package/src/components/Layout/Header/assets/hostel_small.svg +13 -0
  136. package/src/components/Layout/Header/assets/hostelx.png +0 -0
  137. package/src/components/Layout/Header/assets/hostelx.svg +13 -0
  138. package/src/components/Layout/Header/assets/index.ts +35 -0
  139. package/src/components/Layout/Header/assets/libraryx.svg +12 -0
  140. package/src/components/Layout/Header/assets/libreryx.png +0 -0
  141. package/src/components/Layout/Header/assets/pay_small.svg +16 -0
  142. package/src/components/Layout/Header/assets/payx.png +0 -0
  143. package/src/components/Layout/Header/assets/payx.svg +19 -0
  144. package/src/components/Layout/Header/assets/people_small.svg +9 -0
  145. package/src/components/Layout/Header/assets/peoplex.svg +12 -0
  146. package/src/components/Layout/Header/assets/pepolex.png +0 -0
  147. package/src/components/Layout/Header/assets/squarex.svg +12 -0
  148. package/src/components/Layout/Header/icons.tsx +57 -0
  149. package/src/components/Layout/Header/index.tsx +1 -0
  150. package/src/components/Layout/Header/styles.tsx +133 -0
  151. package/src/components/Layout/Helmet.tsx +49 -0
  152. package/src/components/Layout/LayoutWrapper.tsx +28 -0
  153. package/src/components/Layout/SideMenuHeader.tsx +29 -0
  154. package/src/components/Layout/SideNav.tsx +168 -0
  155. package/src/components/Layout/Tickets/HelpWidget/HelpWidget.tsx +273 -0
  156. package/src/components/Layout/Tickets/HelpWidget/styles.tsx +94 -0
  157. package/src/components/Layout/Tickets/MyTickets.tsx +72 -0
  158. package/src/components/Layout/Tickets/TicketDetails.tsx +65 -0
  159. package/src/components/Layout/Tickets/TimeLine.tsx +64 -0
  160. package/src/components/Layout/Tickets/index.tsx +1 -0
  161. package/src/components/Layout/Tickets/services.ts +11 -0
  162. package/src/components/Layout/Tickets/styles.tsx +136 -0
  163. package/src/components/LinearProgress.tsx +19 -0
  164. package/src/components/ListItemButton.tsx +95 -0
  165. package/src/components/LoginForm.tsx +279 -0
  166. package/src/components/MediaRow/MediaRow.tsx +67 -0
  167. package/src/components/MediaRow/index.tsx +1 -0
  168. package/src/components/ModalButtons/DialogButton.tsx +126 -0
  169. package/src/components/ModalButtons/DrawerButton.tsx +115 -0
  170. package/src/components/ModalButtons/index.tsx +4 -0
  171. package/src/components/NoDataIllustration.tsx +32 -0
  172. package/src/components/PageContent.tsx +12 -0
  173. package/src/components/PageHeader.tsx +55 -0
  174. package/src/components/PageNotFound.tsx +26 -0
  175. package/src/components/PopupConfirm/ConfirmContextProvider.tsx +40 -0
  176. package/src/components/PopupConfirm/PopupConfirm.tsx +67 -0
  177. package/src/components/PopupConfirm/animation.gif +0 -0
  178. package/src/components/PopupConfirm/index.tsx +1 -0
  179. package/src/components/PopupConfirm/useConfirm.ts +47 -0
  180. package/src/components/ResetPassword.tsx +107 -0
  181. package/src/components/Row.tsx +24 -0
  182. package/src/components/Spinner.tsx +18 -0
  183. package/src/components/StepsHeader/StepsHeader.tsx +115 -0
  184. package/src/components/StepsHeader/index.tsx +1 -0
  185. package/src/components/StyledTableContainer.tsx +33 -0
  186. package/src/components/SwitchButton.tsx +41 -0
  187. package/src/components/Table.tsx +42 -0
  188. package/src/components/Tables/BasicTable/Table.tsx +198 -0
  189. package/src/components/Tables/BasicTable/TableFooter.tsx +86 -0
  190. package/src/components/Tables/BasicTable/index.tsx +1 -0
  191. package/src/components/Tables/ReactTable/BatchActionsHeader.tsx +58 -0
  192. package/src/components/Tables/ReactTable/ReactTable.tsx +295 -0
  193. package/src/components/Tables/ReactTable/RenderTableBody.tsx +49 -0
  194. package/src/components/Tables/ReactTable/index.tsx +1 -0
  195. package/src/components/Tables/ReactTable/react-table-config.d.ts +128 -0
  196. package/src/components/Tables/common/NoRecordsFound.tsx +27 -0
  197. package/src/components/Tables/common/TableStats.tsx +22 -0
  198. package/src/components/Tables/common/icons.tsx +50 -0
  199. package/src/components/Tables/common/no-data-illu.svg +1 -0
  200. package/src/components/Tables/common/styles.tsx +170 -0
  201. package/src/components/Tables/common/types.ts +57 -0
  202. package/src/components/Tabs/NavigationTabs.tsx +80 -0
  203. package/src/components/Tabs/Tabs.tsx +53 -0
  204. package/src/components/Tabs/TabsContainer.tsx +53 -0
  205. package/src/components/Tabs/index.tsx +1 -0
  206. package/src/components/Tabs/styles.tsx +55 -0
  207. package/src/components/ToastContainer/ToastContainer.tsx +57 -0
  208. package/src/components/ToastContainer/index.tsx +1 -0
  209. package/src/components/UploadButton/UploadButton.tsx +126 -0
  210. package/src/components/UploadButton/index.tsx +1 -0
  211. package/src/components/UploadButton/types.ts +19 -0
  212. package/src/components/UploadDocument.tsx +108 -0
  213. package/src/components/UploadFileDialog/AnimatedUploadFile.gif +0 -0
  214. package/src/components/UploadFileDialog/UploadFileDialog.tsx +238 -0
  215. package/src/components/UploadFileDialog/index.tsx +1 -0
  216. package/src/components/index.ts +106 -0
  217. package/src/config/axios.ts +73 -0
  218. package/src/config/axiosEvaluator.ts +53 -0
  219. package/src/config/axiosXTenant.ts +57 -0
  220. package/src/constants/UIConstants.ts +97 -0
  221. package/src/constants/formValidations.ts +6 -0
  222. package/src/constants/index.ts +5 -0
  223. package/src/constants/isDevelopment.ts +4 -0
  224. package/src/constants/permissions.ts +67 -0
  225. package/src/constants/validateMessages.ts +12 -0
  226. package/src/contexts/LoginFormProvider.tsx +44 -0
  227. package/src/contexts/Providers.tsx +50 -0
  228. package/src/contexts/PublicProviders.tsx +30 -0
  229. package/src/contexts/QueryClientProvider.tsx +22 -0
  230. package/src/hooks/index.ts +5 -0
  231. package/src/hooks/useAuth.ts +96 -0
  232. package/src/hooks/useExternalScript.ts +37 -0
  233. package/src/hooks/useFetch.ts +53 -0
  234. package/src/hooks/useFilters.ts +83 -0
  235. package/src/hooks/useRouter.ts +31 -0
  236. package/src/layouts/Components/DashBoardMenu.tsx +232 -0
  237. package/src/layouts/Components/icons/index.tsx +403 -0
  238. package/src/layouts/Components/styles.tsx +74 -0
  239. package/src/layouts/ComponentsLayout.tsx +3 -0
  240. package/src/permissions/PageWithPermission.tsx +18 -0
  241. package/src/permissions/PermissionDeniedPage.tsx +16 -0
  242. package/src/permissions/ValidateAccess.tsx +18 -0
  243. package/src/permissions/index.ts +2 -0
  244. package/src/react-app-env.d.ts +1 -0
  245. package/src/shared-state/AssetsStore.ts +15 -0
  246. package/src/shared-state/PermissionsStore.ts +392 -0
  247. package/src/shared-state/UserStore.ts +13 -0
  248. package/src/shared-state/index.ts +4 -0
  249. package/src/theme/App.less +3 -0
  250. package/src/theme/MuiThemeProvider.tsx +18 -0
  251. package/src/theme/customCssBaseline.ts +135 -0
  252. package/src/theme/index.css +28 -0
  253. package/src/theme/muiTheme.ts +597 -0
  254. package/src/theme/theme.d.ts +77 -0
  255. package/src/utils/adminAxios.ts +15 -0
  256. package/src/utils/alphabet.ts +23 -0
  257. package/src/utils/arrayPadEnd.ts +3 -0
  258. package/src/utils/formatCurrency.ts +9 -0
  259. package/src/utils/getUrlParams.ts +5 -0
  260. package/src/utils/index.ts +7 -0
  261. package/src/utils/logout.ts +25 -0
  262. package/src/utils/ordinalSuffixOf.ts +14 -0
  263. package/src/utils/romanize.ts +40 -0
  264. package/src/utils/withRouteWrapper.tsx +25 -0
  265. package/src/utils/withSuspense.tsx +6 -0
  266. package/styled-components.tsx +60 -0
  267. package/tsconfig.json +21 -0
@@ -0,0 +1 @@
1
+ export { default } from './TabsContainer'
@@ -0,0 +1,55 @@
1
+ import { Box, Stack, styled, Tabs } from '@mui/material'
2
+
3
+ export const StyledTabs = styled(Tabs)<{
4
+ size: 'small' | 'medium'
5
+ containerVariant?: 'page' | 'box'
6
+ }>(({ theme, size, containerVariant }) => ({
7
+ borderTopRightRadius: '10px',
8
+ borderTopLeftRadius: '10px',
9
+ background: theme.palette.secondary.light,
10
+ minHeight: '60px',
11
+ paddingLeft: '15px',
12
+ '& .MuiTabs-indicator': {
13
+ backgroundColor: theme.palette.common.yellow,
14
+ },
15
+ '& .MuiTabs-flexContainer': {
16
+ height: '100%',
17
+ alignItems: 'end',
18
+ },
19
+ '& .MuiTab-root': {
20
+ textTransform: 'none',
21
+ transition: 'color 0.2s ease-in-out',
22
+ padding: '5px 15px',
23
+ paddingBottom: '8px',
24
+ minHeight: 0,
25
+ fontSize: size === 'medium' ? '16px' : '14px',
26
+ fontWeight: '600',
27
+ },
28
+ '& .MuiTab-root.Mui-selected': {
29
+ color: theme.palette.secondary.main,
30
+ },
31
+ ...(containerVariant === 'page' && {
32
+ background: 'none',
33
+ paddingLeft: 0,
34
+ borderBottom: theme.borders.grayLight,
35
+ }),
36
+ }))
37
+
38
+ export const StyledContainer = styled(Stack)(({ theme }) => ({
39
+ borderRadius: '10px',
40
+ // border: theme.borders.grayLight,
41
+ }))
42
+
43
+ export const StyledComponentWrapper = styled(Box)<{
44
+ containerVariant: 'page' | 'box'
45
+ }>(({ theme, containerVariant }) => ({
46
+ padding: '15px',
47
+ height: '100%',
48
+ ...(containerVariant === 'page' && {
49
+ padding: '15px 0',
50
+ }),
51
+ }))
52
+
53
+ export const StyledTabsWrapper = styled(Box)(({ theme }) => ({
54
+ borderBottom: theme.borders.grayLight,
55
+ }))
@@ -0,0 +1,57 @@
1
+ import { Done, Close, WarningAmberRounded } from '@mui/icons-material'
2
+ import { Box } from '@mui/material'
3
+ import { Slide, ToastContainer as ReactToastContainer } from 'react-toastify'
4
+ import 'react-toastify/dist/ReactToastify.css'
5
+ import WarningAmberRoundedIcon from '@mui/icons-material/WarningAmberRounded'
6
+
7
+ export default function ToastContainer() {
8
+ return (
9
+ <ReactToastContainer
10
+ containerId={'toast-container'}
11
+ position="bottom-center"
12
+ autoClose={4000}
13
+ hideProgressBar={true}
14
+ newestOnTop={false}
15
+ transition={Slide}
16
+ closeOnClick
17
+ rtl={false}
18
+ pauseOnFocusLoss={false}
19
+ draggable
20
+ pauseOnHover
21
+ theme="colored"
22
+ icon={({ type }) => <Icon type={type} />}
23
+ />
24
+ )
25
+ }
26
+
27
+ const Icon = ({ type }) => {
28
+ const renderIcon = () => {
29
+ switch (type) {
30
+ case 'error':
31
+ return <Close />
32
+ case 'success':
33
+ return <Done />
34
+ case 'warning':
35
+ return <WarningAmberRounded />
36
+
37
+ default:
38
+ return <Done />
39
+ }
40
+ }
41
+
42
+ return (
43
+ <Box
44
+ sx={{
45
+ background: 'rgba(0, 0, 0, 0.1)',
46
+ minWidth: '50px',
47
+ height: '100%',
48
+ alignSelf: 'stretch',
49
+ display: 'flex',
50
+ alignItems: 'center',
51
+ justifyContent: 'center',
52
+ }}
53
+ >
54
+ {renderIcon()}
55
+ </Box>
56
+ )
57
+ }
@@ -0,0 +1 @@
1
+ export { default } from './ToastContainer'
@@ -0,0 +1,126 @@
1
+ import { Button, CircularProgress, styled } from '@mui/material'
2
+ import { useRef, useState } from 'react'
3
+ import { toast } from 'react-toastify'
4
+ import axios from '../../config/axios'
5
+ import { UploadButtonProps } from './types'
6
+
7
+ const getAccept = (type: UploadButtonProps['type']) => {
8
+ switch (type) {
9
+ case 'file':
10
+ return '.xlsx,.xls,.doc, .docx,.ppt, .pptx,.txt,.pdf'
11
+ case 'image':
12
+ return 'image/*'
13
+ case 'video':
14
+ return 'video/*'
15
+ case 'audio':
16
+ return 'audio/*'
17
+ }
18
+ }
19
+
20
+ export default function UploadButton({
21
+ type,
22
+ onChange,
23
+ uploadUrl,
24
+ onSuccess,
25
+ styledUpload,
26
+ loadingState,
27
+ refetchFn,
28
+ }: UploadButtonProps) {
29
+ const [loading, setLoading] = useState<boolean>(false)
30
+
31
+ const formRef: any = useRef()
32
+ const fileInputRef: any = useRef()
33
+ const ref: any = useRef()
34
+ const handleChange = (e: any) => {
35
+ if (e.target.files[0]) {
36
+ const formData = new FormData()
37
+ formData.append('file', e.target.files[0])
38
+ setLoading(true)
39
+ loadingState && loadingState(true)
40
+ axios
41
+ .post(uploadUrl, formData)
42
+ .then((res) => {
43
+ onChange({
44
+ url: res.data.url,
45
+ key: res.data.key,
46
+ type: type,
47
+ fileName: res.data?.mediaObject?.originalFileName ?? '',
48
+ id: res.data?.mediaObject?.id ?? '',
49
+ })
50
+ refetchFn()
51
+ setLoading(false)
52
+ loadingState && loadingState(false)
53
+ if (onSuccess) onSuccess()
54
+ formRef?.current.reset()
55
+ })
56
+ .catch((err) => {
57
+ setLoading(false)
58
+ loadingState && loadingState(false)
59
+ toast.error(
60
+ err?.response?.data?.message ?? 'Server Error While Uploading File',
61
+ )
62
+ !styledUpload && formRef?.current.reset()
63
+ })
64
+ }
65
+ }
66
+
67
+ return (
68
+ <>
69
+ {styledUpload ? (
70
+ <>
71
+ <div
72
+ onClick={() => {
73
+ ref.current.click()
74
+ }}
75
+ >
76
+ {styledUpload}
77
+ </div>
78
+ <input
79
+ accept={getAccept(type)}
80
+ type="file"
81
+ hidden
82
+ ref={ref}
83
+ onChange={handleChange}
84
+ />
85
+ </>
86
+ ) : (
87
+ <>
88
+ <form ref={formRef}>
89
+ <input
90
+ ref={fileInputRef}
91
+ type="file"
92
+ style={{ display: 'none' }}
93
+ accept={getAccept(type)}
94
+ onChange={handleChange}
95
+ />
96
+ <StyledButton
97
+ fullWidth
98
+ endIcon={loading ? <CircularProgress size={16} /> : null}
99
+ variant="outlined"
100
+ disabled={loading}
101
+ size={'large'}
102
+ onClick={() => fileInputRef.current.click()}
103
+ >
104
+ {getLabel(type)}
105
+ </StyledButton>
106
+ </form>
107
+ </>
108
+ )}
109
+ </>
110
+ )
111
+ }
112
+
113
+ const getLabel = (type) => {
114
+ switch (type) {
115
+ case 'file':
116
+ return 'File'
117
+ case 'image':
118
+ return 'Image'
119
+ case 'video':
120
+ return 'Video'
121
+ case 'audio':
122
+ return 'Audio'
123
+ }
124
+ }
125
+
126
+ const StyledButton = styled(Button)(({ theme }) => ({}))
@@ -0,0 +1 @@
1
+ export { default } from './UploadButton'
@@ -0,0 +1,19 @@
1
+ import { ReactNode } from "react"
2
+
3
+ interface Media {
4
+ type: 'image' | 'video' | 'audio' | 'file'
5
+ url: string
6
+ key: string
7
+ fileName?: string
8
+ id?: any
9
+ }
10
+ interface UploadButtonProps {
11
+ type: 'file' | 'image' | 'video' | 'audio'
12
+ onChange: (res: Media) => void
13
+ uploadUrl: string
14
+ onSuccess?: () => void
15
+ styledUpload?: ReactNode
16
+ loadingState?: (v) => void
17
+ refetchFn?: () => void
18
+ }
19
+ export type { Media, UploadButtonProps }
@@ -0,0 +1,108 @@
1
+ import { Box, CircularProgress, Stack, styled, Typography } from '@mui/material'
2
+ import { ReactNode, useRef, useState } from 'react'
3
+ import AttachFileIcon from '@mui/icons-material/AttachFile'
4
+ import { toast } from 'react-toastify'
5
+ import axios from '../config/axios'
6
+
7
+ export default function UploadDocument({
8
+ accept = '.doc,.docx,.pdf',
9
+ styledUpload,
10
+ postUrl,
11
+ postBody,
12
+ styleProps,
13
+ refetchFn,
14
+ width,
15
+ height,
16
+ }: {
17
+ accept?: string
18
+ styledUpload?: ReactNode
19
+ postUrl: string
20
+ postBody?: object
21
+ refetchFn?: () => void
22
+ styleProps?: any
23
+ width?: string
24
+ height?: string
25
+ }) {
26
+ const [loading, setLoading] = useState(false)
27
+ const fileRef = useRef<any>()
28
+
29
+ const handleChange = (e) => {
30
+ if (e.target.files[0]) {
31
+ const formData = new FormData()
32
+ formData.append('file', e.target.files[0])
33
+ if (postBody) {
34
+ Object?.keys(postBody)?.forEach((key) => {
35
+ formData?.append(key, postBody[key])
36
+ })
37
+ }
38
+
39
+ setLoading(true)
40
+ axios
41
+ .post(postUrl, formData)
42
+ .then((res) => {
43
+ setLoading(false)
44
+ refetchFn()
45
+ })
46
+ .catch((err) => {
47
+ setLoading(false)
48
+ toast.error('Server Error While Uploading File')
49
+ })
50
+ }
51
+ }
52
+
53
+ return (
54
+ <>
55
+ {styledUpload ? (
56
+ <div
57
+ onClick={() => {
58
+ fileRef.current.click()
59
+ }}
60
+ style={{
61
+ display: 'flex',
62
+ justifyContent: 'center',
63
+ alignItems: 'center',
64
+ ...styleProps,
65
+ }}
66
+ >
67
+ {loading ? <CircularProgress size={30} /> : styledUpload}
68
+ </div>
69
+ ) : (
70
+ <StyledImageLabel
71
+ onClick={() => {
72
+ fileRef.current.click()
73
+ }}
74
+ >
75
+ <AttachFileIcon />
76
+ <Typography sx={{ opacity: '0.6' }}>
77
+ {loading ? 'Uploading...' : `Upload File`}
78
+ </Typography>
79
+ </StyledImageLabel>
80
+ )}
81
+ <input
82
+ type="file"
83
+ ref={fileRef}
84
+ style={{ display: 'none' }}
85
+ accept={accept}
86
+ onChange={handleChange}
87
+ />
88
+ </>
89
+ )
90
+ }
91
+
92
+ export const StyledImageLabel = styled('div')(({ theme }) => ({
93
+ cursor: 'pointer',
94
+ borderRadius: '10px',
95
+ width: '100%',
96
+ height: '150px',
97
+ border: '1px dashed #0000001A',
98
+ display: 'flex',
99
+ flexDirection: 'column',
100
+ justifyContent: 'center',
101
+ alignItems: 'center',
102
+ '&:hover': {
103
+ backgroundColor: '#EFEFEF',
104
+ },
105
+ '& > *': {
106
+ color: theme.palette.text.disabled,
107
+ },
108
+ }))
@@ -0,0 +1,238 @@
1
+ import { Add, Close } from '@mui/icons-material'
2
+ import {
3
+ alpha,
4
+ Box,
5
+ Button,
6
+ ButtonProps,
7
+ CircularProgress,
8
+ Dialog,
9
+ DialogContent,
10
+ DialogProps,
11
+ IconButton,
12
+ styled,
13
+ Typography,
14
+ } from '@mui/material'
15
+ import { DeleteButton, EditButton } from '../IconButtons'
16
+ import { ReactNode, useEffect, useRef, useState } from 'react'
17
+ import { toast } from 'react-toastify'
18
+ import axios, { axiosErrorToast } from '../../config/axios'
19
+ const animatedImage = require('./AnimatedUploadFile.gif')
20
+
21
+ const StyledDialogHeader = styled(Box)(({ theme }) => ({
22
+ height: '64px',
23
+ backgroundColor: alpha(theme.palette.text.secondary, 0.1),
24
+ display: 'flex',
25
+ justifyContent: 'space-between',
26
+ alignItems: 'center',
27
+ padding: '0.6rem 1rem',
28
+ }))
29
+ const StyledDialogContent = styled(DialogContent)(({ theme }) => ({
30
+ display: 'flex',
31
+ flexDirection: 'column',
32
+ gap: '1rem',
33
+ alignItems: 'center',
34
+ padding: '40px',
35
+ }))
36
+
37
+ const StyledImage = styled((props: any) => (
38
+ <Box>
39
+ <img {...props} />
40
+ </Box>
41
+ ))(({ theme }) => ({
42
+ height: '90px',
43
+ width: '90px',
44
+ '> img': {
45
+ width: '100%',
46
+ height: '100%',
47
+ objectFit: 'contain',
48
+ },
49
+ }))
50
+
51
+ const StyledChooseFileButton = styled(Button)(({ theme }) => ({
52
+ padding: '15px 20px',
53
+ height: '50px',
54
+ '> .MuiBox-root': {
55
+ display: 'flex',
56
+ width: '100%',
57
+ alignItems: 'center',
58
+ justifyContent: 'space-between',
59
+ },
60
+ }))
61
+
62
+ const StyledFileLabel = styled(Box)(({ theme }) => ({
63
+ background: theme.palette.secondary.light,
64
+ borderRadius: '5px',
65
+ padding: '16px',
66
+ display: 'flex',
67
+ justifyContent: 'space-between',
68
+ alignItems: 'center',
69
+ }))
70
+
71
+ interface UploadFileDialogProps {
72
+ buttonProps?: ButtonProps
73
+ dialogProps?: DialogProps
74
+ buttonText: string | ReactNode
75
+ children?: ReactNode
76
+ dialogTitle: ReactNode | string
77
+ sampleFileUrl?: string
78
+ uploadUrl: string
79
+ successMessage?: string
80
+ refetchFn: () => void
81
+ postBody?: { [key: string]: string }
82
+ }
83
+
84
+ export default function UploadFileDialog({
85
+ buttonProps,
86
+ dialogProps,
87
+ buttonText,
88
+ dialogTitle,
89
+ uploadUrl,
90
+ sampleFileUrl,
91
+ successMessage,
92
+ refetchFn,
93
+ postBody = {},
94
+ }: UploadFileDialogProps) {
95
+ const inputRef: any = useRef(null)
96
+ const [loading, setLoading] = useState(false)
97
+
98
+ const [file, setFile] = useState(null)
99
+ const [open, setOpen] = useState(false)
100
+ const onClose = () => {
101
+ setOpen(false)
102
+ }
103
+
104
+ const triggerUpload = () => {
105
+ if (!inputRef.current) return
106
+ inputRef?.current?.click()
107
+ }
108
+
109
+ const handleImageChange = (e) => {
110
+ setFile(e.target.files[0])
111
+ }
112
+
113
+ const handleOnUpload = () => {
114
+ if (!file) return ``
115
+ const formData = new FormData()
116
+ formData.append('file', file)
117
+ if (postBody) {
118
+ Object.keys(postBody).forEach((key) => {
119
+ formData.append(key, postBody[key])
120
+ })
121
+ }
122
+ setLoading(true)
123
+
124
+ axios
125
+ .post(uploadUrl, formData)
126
+ .then((res) => {
127
+ setLoading(false)
128
+ refetchFn()
129
+ setOpen(false)
130
+ toast.success(successMessage ?? 'Successful')
131
+ setFile(null)
132
+ })
133
+ .catch((err) => {
134
+ console.log(err)
135
+ setLoading(false)
136
+ axiosErrorToast(err)
137
+ })
138
+ }
139
+
140
+ useEffect(() => {
141
+ return () => {
142
+ setFile(null)
143
+ inputRef.current = null
144
+ }
145
+ }, [])
146
+
147
+ return (
148
+ <>
149
+ <Button
150
+ onClick={() => {
151
+ setOpen(true)
152
+ }}
153
+ variant="outlined"
154
+ {...buttonProps}
155
+ >
156
+ {buttonText}
157
+ </Button>
158
+ <Dialog
159
+ open={open}
160
+ onClose={onClose}
161
+ maxWidth="sm"
162
+ fullWidth
163
+ {...dialogProps}
164
+ >
165
+ <StyledDialogHeader>
166
+ <Typography fontWeight={600}>{dialogTitle}</Typography>
167
+ <IconButton onClick={onClose}>
168
+ <Close />
169
+ </IconButton>
170
+ </StyledDialogHeader>
171
+ <StyledDialogContent>
172
+ <StyledImage src={animatedImage} alt="Upload Image" />
173
+ <Typography variant="h6">{dialogTitle}</Typography>
174
+ <Typography textAlign={'center'}>
175
+ Before importing, download Sample CSV File or Sample XLSX file and
176
+ compare it with your sheet or edit the sample sheet
177
+ </Typography>
178
+ <Box sx={{ minWidth: '400px', marginBottom: '20px' }}>
179
+ {!file ? (
180
+ <>
181
+ <input
182
+ onChange={handleImageChange}
183
+ hidden
184
+ type="file"
185
+ ref={inputRef}
186
+ />
187
+ <StyledChooseFileButton
188
+ variant="outlined"
189
+ fullWidth
190
+ onClick={triggerUpload}
191
+ >
192
+ <Box>
193
+ <Typography variant="h6" color="primary">
194
+ Choose File
195
+ </Typography>
196
+ <Add />
197
+ </Box>
198
+ </StyledChooseFileButton>
199
+ </>
200
+ ) : (
201
+ <StyledFileLabel>
202
+ <Typography variant="body2">{file?.name}</Typography>
203
+ <Box display={'flex'} gap="16px">
204
+ <EditButton
205
+ onClick={() => {
206
+ triggerUpload()
207
+ }}
208
+ />
209
+ <DeleteButton onClick={() => setFile(null)} />
210
+ </Box>
211
+ </StyledFileLabel>
212
+ )}
213
+ </Box>
214
+
215
+ <Button
216
+ fullWidth
217
+ sx={{ maxWidth: '255px' }}
218
+ onClick={handleOnUpload}
219
+ endIcon={
220
+ loading ? (
221
+ <CircularProgress size={20} sx={{ color: 'white' }} />
222
+ ) : null
223
+ }
224
+ >
225
+ Upload File
226
+ </Button>
227
+ {sampleFileUrl && (
228
+ <a href={sampleFileUrl} target="_blank" rel="noreferrer">
229
+ <Button fullWidth sx={{ maxWidth: '255px' }} variant="outlined">
230
+ Download Sample File
231
+ </Button>
232
+ </a>
233
+ )}
234
+ </StyledDialogContent>
235
+ </Dialog>
236
+ </>
237
+ )
238
+ }
@@ -0,0 +1 @@
1
+ export { default } from './UploadFileDialog'