@campxdev/shared 1.10.17 → 1.10.18

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 (273) hide show
  1. package/antd.customize.less +73 -73
  2. package/exports.ts +19 -19
  3. package/package.json +87 -87
  4. package/src/assets/fonts/avenir/index.ts +13 -13
  5. package/src/assets/fonts/poppins/index.ts +18 -18
  6. package/src/assets/images/index.ts +17 -17
  7. package/src/assets/images/unauth.svg +92 -92
  8. package/src/components/ActionButton.tsx +20 -20
  9. package/src/components/ApplicationProfile/ApplicationProfile.tsx +378 -378
  10. package/src/components/ApplicationProfile/DepartmentFilter.tsx +77 -77
  11. package/src/components/ApplicationProfile/UserProfileRelation.tsx +130 -130
  12. package/src/components/ApplicationProfile/index.tsx +1 -1
  13. package/src/components/ApplicationProfile/services.ts +71 -71
  14. package/src/components/Attachment.tsx +26 -26
  15. package/src/components/AutocompleteSearch/AutocompleteSearch.tsx +57 -57
  16. package/src/components/AutocompleteSearch/index.tsx +1 -1
  17. package/src/components/Breadcrumbs.tsx +72 -72
  18. package/src/components/Card.tsx +98 -98
  19. package/src/components/CardsGrid.tsx +28 -28
  20. package/src/components/ChangePassword.tsx +123 -123
  21. package/src/components/Chips.tsx +81 -81
  22. package/src/components/Detail.tsx +15 -15
  23. package/src/components/DetailsGrid.tsx +52 -52
  24. package/src/components/DividerHeading.tsx +41 -41
  25. package/src/components/DrawerWrapper/DialogWrapper.tsx +67 -67
  26. package/src/components/DrawerWrapper/DrawerTemplate.tsx +53 -53
  27. package/src/components/DrawerWrapper/DrawerWrapper.tsx +53 -53
  28. package/src/components/DropDownButton/AnchorElement.tsx +44 -44
  29. package/src/components/DropDownButton/DropDownButton.tsx +184 -184
  30. package/src/components/DropDownButton/DropdownMenuItem.tsx +122 -122
  31. package/src/components/DropDownButton/index.tsx +1 -1
  32. package/src/components/DropDownButton/styles.tsx +59 -59
  33. package/src/components/ErrorBoundary/ErrorBoundary.tsx +33 -33
  34. package/src/components/ErrorBoundary/ErrorFallback.tsx +240 -240
  35. package/src/components/ErrorBoundary/GlobalNetworkLoadingIndicator.tsx +13 -13
  36. package/src/components/ErrorBoundary/index.tsx +1 -1
  37. package/src/components/ErrorBox.tsx +42 -42
  38. package/src/components/ExcelToJsonInput/ExcelJsonUpload.tsx +50 -50
  39. package/src/components/ExcelToJsonInput/ExcelToJsonInput.tsx +57 -57
  40. package/src/components/ExcelToJsonInput/index.tsx +1 -1
  41. package/src/components/FilterComponents/FilterButton.tsx +56 -56
  42. package/src/components/FilterComponents/SearchBar.tsx +45 -45
  43. package/src/components/FloatingContainer.tsx +33 -33
  44. package/src/components/Form/Form.tsx +147 -147
  45. package/src/components/Form/RenderForm.tsx +189 -189
  46. package/src/components/FullScreenLoader.tsx +19 -19
  47. package/src/components/HookForm/AutoCompleteSearch.tsx +113 -113
  48. package/src/components/HookForm/DatePicker.tsx +40 -40
  49. package/src/components/HookForm/DateTimePicker.tsx +47 -47
  50. package/src/components/HookForm/FormLabel.tsx +14 -14
  51. package/src/components/HookForm/MultiCheckbox.tsx +69 -69
  52. package/src/components/HookForm/MultiSelect.tsx +61 -61
  53. package/src/components/HookForm/RadioGroup.tsx +47 -47
  54. package/src/components/HookForm/SingleCheckbox.tsx +34 -34
  55. package/src/components/HookForm/SingleSelect.tsx +46 -46
  56. package/src/components/HookForm/TextField.tsx +40 -40
  57. package/src/components/HookForm/TimePicker.tsx +40 -40
  58. package/src/components/HookForm/index.ts +23 -23
  59. package/src/components/IconButtons/IconButtons.tsx +137 -137
  60. package/src/components/IconButtons/Icons.tsx +299 -299
  61. package/src/components/IconButtons/assets/edit.svg +4 -4
  62. package/src/components/IconButtons/assets/eye.svg +6 -6
  63. package/src/components/IconButtons/assets/trash.svg +7 -7
  64. package/src/components/IconButtons/index.tsx +8 -8
  65. package/src/components/IconLabel.tsx +37 -37
  66. package/src/components/Image/Image.tsx +45 -45
  67. package/src/components/Image/index.tsx +1 -1
  68. package/src/components/ImageUpload.tsx +98 -98
  69. package/src/components/Input/AsyncSearchSelect/AsyncSearchSelect.tsx +216 -216
  70. package/src/components/Input/AsyncSearchSelect/index.tsx +1 -1
  71. package/src/components/Input/AsyncSearchSelect/styles.tsx +105 -105
  72. package/src/components/Input/AutoCompleteSearch.tsx +121 -121
  73. package/src/components/Input/DatePicker.tsx +87 -87
  74. package/src/components/Input/DateRangePicker.tsx +105 -105
  75. package/src/components/Input/DateTimePicker.tsx +84 -84
  76. package/src/components/Input/FormLabel.tsx +21 -21
  77. package/src/components/Input/MultiCheckbox.tsx +64 -64
  78. package/src/components/Input/MultiSelect.tsx +161 -161
  79. package/src/components/Input/RadioGroup.tsx +104 -104
  80. package/src/components/Input/SingleCheckbox.tsx +78 -78
  81. package/src/components/Input/SingleSelect.tsx +104 -104
  82. package/src/components/Input/TextField.tsx +46 -46
  83. package/src/components/Input/TimePicker.tsx +77 -77
  84. package/src/components/Input/index.ts +26 -26
  85. package/src/components/Input/types.ts +3 -3
  86. package/src/components/Institutions/InsititutionsDialog.tsx +78 -78
  87. package/src/components/Institutions/InsititutionsNotAssignedDialog .tsx +12 -12
  88. package/src/components/Institutions/InstitutionsDropdown.tsx +33 -33
  89. package/src/components/Institutions/index.tsx +1 -1
  90. package/src/components/Institutions/services.ts +12 -12
  91. package/src/components/JsonPreview.tsx +7 -7
  92. package/src/components/LabelValue.tsx +21 -21
  93. package/src/components/Layout/ChangePassword.tsx +49 -49
  94. package/src/components/Layout/Header/AppHeader.tsx +109 -109
  95. package/src/components/Layout/Header/AppsMenu.tsx +132 -132
  96. package/src/components/Layout/Header/HeaderActions/CogWheelMenu.tsx +33 -33
  97. package/src/components/Layout/Header/HeaderActions/FreshChatButton.tsx +61 -61
  98. package/src/components/Layout/Header/HeaderActions/FreshDeskHelpButton.tsx +53 -53
  99. package/src/components/Layout/Header/HeaderActions/HeaderActions.tsx +22 -22
  100. package/src/components/Layout/Header/HeaderActions/UserBox.tsx +63 -63
  101. package/src/components/Layout/Header/Notification.tsx +13 -13
  102. package/src/components/Layout/Header/Search/SearchButton.tsx +69 -69
  103. package/src/components/Layout/Header/Search/SearchDialog.tsx +178 -178
  104. package/src/components/Layout/Header/applications.ts +98 -98
  105. package/src/components/Layout/Header/assets/campx_square_small.svg +8 -8
  106. package/src/components/Layout/Header/assets/commutex.svg +14 -14
  107. package/src/components/Layout/Header/assets/commutexSmall.svg +11 -11
  108. package/src/components/Layout/Header/assets/enroll.svg +14 -14
  109. package/src/components/Layout/Header/assets/enrollx.svg +14 -14
  110. package/src/components/Layout/Header/assets/exams_small.svg +11 -11
  111. package/src/components/Layout/Header/assets/examsx.svg +14 -14
  112. package/src/components/Layout/Header/assets/hostel_small.svg +13 -13
  113. package/src/components/Layout/Header/assets/hostelx.svg +13 -13
  114. package/src/components/Layout/Header/assets/index.ts +37 -37
  115. package/src/components/Layout/Header/assets/libraryx.svg +12 -12
  116. package/src/components/Layout/Header/assets/pay_small.svg +15 -15
  117. package/src/components/Layout/Header/assets/payx.svg +19 -19
  118. package/src/components/Layout/Header/assets/people_small.svg +9 -9
  119. package/src/components/Layout/Header/assets/peoplex.svg +12 -12
  120. package/src/components/Layout/Header/assets/squarex.svg +12 -12
  121. package/src/components/Layout/Header/icons.tsx +57 -57
  122. package/src/components/Layout/Header/index.tsx +1 -1
  123. package/src/components/Layout/Header/styles.tsx +133 -133
  124. package/src/components/Layout/Helmet.tsx +100 -100
  125. package/src/components/Layout/LayoutWrapper.tsx +28 -28
  126. package/src/components/Layout/SideMenuHeader.tsx +29 -29
  127. package/src/components/Layout/SideNav.tsx +168 -168
  128. package/src/components/Layout/Tickets/HelpWidget/HelpWidget.tsx +273 -273
  129. package/src/components/Layout/Tickets/HelpWidget/styles.tsx +94 -94
  130. package/src/components/Layout/Tickets/MyTickets.tsx +72 -72
  131. package/src/components/Layout/Tickets/TicketDetails.tsx +65 -65
  132. package/src/components/Layout/Tickets/TimeLine.tsx +64 -64
  133. package/src/components/Layout/Tickets/index.tsx +1 -1
  134. package/src/components/Layout/Tickets/services.ts +11 -11
  135. package/src/components/Layout/Tickets/styles.tsx +136 -136
  136. package/src/components/LinearProgress.tsx +19 -19
  137. package/src/components/ListItemButton.tsx +95 -95
  138. package/src/components/LoginForm.tsx +274 -274
  139. package/src/components/MediaRow/MediaRow.tsx +67 -67
  140. package/src/components/MediaRow/index.tsx +1 -1
  141. package/src/components/ModalButtons/DialogButton.tsx +130 -130
  142. package/src/components/ModalButtons/DrawerButton.tsx +115 -115
  143. package/src/components/ModalButtons/PopoverButton.tsx +99 -99
  144. package/src/components/ModalButtons/index.tsx +4 -4
  145. package/src/components/MyProfile/Education/Education.tsx +47 -47
  146. package/src/components/MyProfile/Education/EducationCard.tsx +62 -62
  147. package/src/components/MyProfile/Education/EducationForm.tsx +97 -97
  148. package/src/components/MyProfile/Education/Styles.tsx +27 -27
  149. package/src/components/MyProfile/Experience/Experience.tsx +47 -47
  150. package/src/components/MyProfile/Experience/ExperienceCard.tsx +63 -63
  151. package/src/components/MyProfile/Experience/ExperienceForm.tsx +107 -107
  152. package/src/components/MyProfile/Experience/Styles.tsx +27 -27
  153. package/src/components/MyProfile/FileUpload.tsx +69 -69
  154. package/src/components/MyProfile/MyProfile.tsx +166 -166
  155. package/src/components/MyProfile/NoDataSection.tsx +27 -27
  156. package/src/components/MyProfile/PaperPublication/Authors.tsx +88 -88
  157. package/src/components/MyProfile/PaperPublication/PaperPublications.tsx +52 -52
  158. package/src/components/MyProfile/PaperPublication/PublicationCard.tsx +80 -80
  159. package/src/components/MyProfile/PaperPublication/PublicationsForm.tsx +285 -285
  160. package/src/components/MyProfile/PaperPublication/Styles.tsx +51 -51
  161. package/src/components/MyProfile/StyledTabsContainer.tsx +53 -53
  162. package/src/components/MyProfile/Styles.tsx +115 -115
  163. package/src/components/MyProfile/Workshop/Styles.tsx +38 -38
  164. package/src/components/MyProfile/Workshop/Workshop.tsx +49 -49
  165. package/src/components/MyProfile/Workshop/WorkshopCard.tsx +64 -64
  166. package/src/components/MyProfile/Workshop/WorkshopData.tsx +36 -36
  167. package/src/components/MyProfile/Workshop/WorkshopForm.tsx +202 -202
  168. package/src/components/MyProfile/index.ts +1 -1
  169. package/src/components/MyProfile/service.ts +58 -58
  170. package/src/components/NoDataIllustration.tsx +35 -35
  171. package/src/components/PageContent.tsx +12 -12
  172. package/src/components/PageHeader.tsx +55 -55
  173. package/src/components/PageNotFound.tsx +26 -26
  174. package/src/components/PopupConfirm/ConfirmContextProvider.tsx +40 -40
  175. package/src/components/PopupConfirm/PopupConfirm.tsx +67 -67
  176. package/src/components/PopupConfirm/index.tsx +1 -1
  177. package/src/components/PopupConfirm/useConfirm.ts +47 -47
  178. package/src/components/ResetPassword.tsx +107 -107
  179. package/src/components/Row.tsx +24 -24
  180. package/src/components/Spinner.tsx +18 -18
  181. package/src/components/StepsHeader/StepsHeader.tsx +115 -115
  182. package/src/components/StepsHeader/index.tsx +1 -1
  183. package/src/components/StyledTableContainer.tsx +33 -33
  184. package/src/components/SwitchButton.tsx +41 -41
  185. package/src/components/Table.tsx +42 -42
  186. package/src/components/Tables/BasicTable/Table.tsx +198 -198
  187. package/src/components/Tables/BasicTable/TableFooter.tsx +86 -86
  188. package/src/components/Tables/BasicTable/index.tsx +1 -1
  189. package/src/components/Tables/ReactTable/BatchActionsHeader.tsx +58 -58
  190. package/src/components/Tables/ReactTable/ReactTable.tsx +295 -295
  191. package/src/components/Tables/ReactTable/RenderTableBody.tsx +49 -49
  192. package/src/components/Tables/ReactTable/index.tsx +1 -1
  193. package/src/components/Tables/ReactTable/react-table-config.d.ts +128 -128
  194. package/src/components/Tables/common/NoRecordsFound.tsx +31 -31
  195. package/src/components/Tables/common/TableStats.tsx +22 -22
  196. package/src/components/Tables/common/icons.tsx +50 -50
  197. package/src/components/Tables/common/no-data-illu.svg +23 -23
  198. package/src/components/Tables/common/styles.tsx +170 -170
  199. package/src/components/Tables/common/types.ts +57 -57
  200. package/src/components/Tabs/NavigationTabs.tsx +80 -80
  201. package/src/components/Tabs/Tabs.tsx +53 -53
  202. package/src/components/Tabs/TabsContainer.tsx +56 -56
  203. package/src/components/Tabs/index.tsx +1 -1
  204. package/src/components/Tabs/styles.tsx +55 -55
  205. package/src/components/ToastContainer/ToastContainer.tsx +57 -57
  206. package/src/components/ToastContainer/index.tsx +1 -1
  207. package/src/components/UploadButton/UploadButton.tsx +127 -127
  208. package/src/components/UploadButton/index.tsx +1 -1
  209. package/src/components/UploadButton/types.ts +20 -20
  210. package/src/components/UploadDocument.tsx +108 -108
  211. package/src/components/UploadFileDialog/UploadFileDialog.tsx +238 -238
  212. package/src/components/UploadFileDialog/index.tsx +1 -1
  213. package/src/components/index.ts +110 -110
  214. package/src/config/axios.ts +80 -80
  215. package/src/config/axiosEvaluator.ts +53 -53
  216. package/src/config/axiosXTenant.ts +57 -57
  217. package/src/constants/UIConstants.ts +124 -124
  218. package/src/constants/formValidations.ts +6 -6
  219. package/src/constants/index.ts +5 -5
  220. package/src/constants/isDevelopment.ts +4 -4
  221. package/src/constants/permissions.ts +67 -67
  222. package/src/constants/validateMessages.ts +12 -12
  223. package/src/contexts/LoginFormProvider.tsx +37 -37
  224. package/src/contexts/Providers.tsx +73 -73
  225. package/src/contexts/PublicProviders.tsx +30 -30
  226. package/src/contexts/QueryClientProvider.tsx +22 -22
  227. package/src/contexts/RootModal.tsx +76 -76
  228. package/src/hooks/index.ts +5 -5
  229. package/src/hooks/useAuth.ts +253 -253
  230. package/src/hooks/useExternalScript.ts +38 -38
  231. package/src/hooks/useFetch.ts +53 -53
  232. package/src/hooks/useFilters.ts +83 -83
  233. package/src/hooks/useRouter.ts +31 -31
  234. package/src/layouts/Components/DashBoardMenu.tsx +232 -232
  235. package/src/layouts/Components/icons/index.tsx +403 -403
  236. package/src/layouts/Components/styles.tsx +74 -74
  237. package/src/layouts/ComponentsLayout.tsx +3 -3
  238. package/src/permissions/PageWithPermission.tsx +18 -18
  239. package/src/permissions/PermissionDeniedPage.tsx +16 -16
  240. package/src/permissions/ValidateAccess.tsx +18 -18
  241. package/src/permissions/index.ts +2 -2
  242. package/src/react-app-env.d.ts +1 -1
  243. package/src/shared-state/AssetsStore.ts +15 -15
  244. package/src/shared-state/InstitutionsStore.ts +8 -8
  245. package/src/shared-state/PermissionsStore.ts +1243 -1243
  246. package/src/shared-state/UserStore.ts +14 -13
  247. package/src/shared-state/index.ts +4 -4
  248. package/src/sitemap/enrollx.ts +52 -52
  249. package/src/sitemap/exams_sitemap.ts +172 -172
  250. package/src/sitemap/payments.ts +128 -128
  251. package/src/sitemap/sitemap.ts +26 -26
  252. package/src/sitemap/square.ts +222 -222
  253. package/src/theme/App.less +3 -3
  254. package/src/theme/MuiThemeProvider.tsx +18 -18
  255. package/src/theme/customCssBaseline.ts +135 -135
  256. package/src/theme/index.css +28 -28
  257. package/src/theme/muiTheme.ts +597 -597
  258. package/src/theme/theme.d.ts +77 -77
  259. package/src/utils/adminAxios.ts +15 -15
  260. package/src/utils/alphabet.ts +23 -23
  261. package/src/utils/arrayPadEnd.ts +3 -3
  262. package/src/utils/buffertoCSV.ts +11 -11
  263. package/src/utils/formatCurrency.ts +9 -9
  264. package/src/utils/getUrlParams.ts +5 -5
  265. package/src/utils/index.ts +8 -8
  266. package/src/utils/logout.ts +25 -25
  267. package/src/utils/ordinalSuffixOf.ts +14 -14
  268. package/src/utils/romanize.ts +40 -40
  269. package/src/utils/withRouteWrapper.tsx +25 -25
  270. package/src/utils/withSuspense.tsx +6 -6
  271. package/styled-components.tsx +60 -60
  272. package/tsconfig.json +21 -21
  273. package/src/components/Layout/Header/assets/commuteX.png +0 -0
@@ -1,238 +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
- }
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
+ }
@@ -1 +1 @@
1
- export { default } from './UploadFileDialog'
1
+ export { default } from './UploadFileDialog'