@campxdev/shared 1.8.29 → 1.8.30

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 (230) hide show
  1. package/antd.customize.less +73 -73
  2. package/exports.ts +19 -19
  3. package/package.json +86 -86
  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 +336 -336
  10. package/src/components/ApplicationProfile/Service.ts +68 -68
  11. package/src/components/ApplicationProfile/UserProfileRelation.tsx +174 -174
  12. package/src/components/ApplicationProfile/index.tsx +1 -1
  13. package/src/components/Attachment.tsx +26 -26
  14. package/src/components/AutocompleteSearch/AutocompleteSearch.tsx +57 -57
  15. package/src/components/AutocompleteSearch/index.tsx +1 -1
  16. package/src/components/Breadcrumbs.tsx +72 -72
  17. package/src/components/Card.tsx +98 -98
  18. package/src/components/CardsGrid.tsx +28 -28
  19. package/src/components/ChangePassword.tsx +123 -123
  20. package/src/components/Chips.tsx +81 -81
  21. package/src/components/Detail.tsx +15 -15
  22. package/src/components/DetailsGrid.tsx +52 -52
  23. package/src/components/DividerHeading.tsx +41 -41
  24. package/src/components/DrawerWrapper/DialogWrapper.tsx +67 -67
  25. package/src/components/DrawerWrapper/DrawerTemplate.tsx +53 -53
  26. package/src/components/DrawerWrapper/DrawerWrapper.tsx +53 -53
  27. package/src/components/DropDownButton/AnchorElement.tsx +44 -44
  28. package/src/components/DropDownButton/DropDownButton.tsx +184 -184
  29. package/src/components/DropDownButton/DropdownMenuItem.tsx +110 -110
  30. package/src/components/DropDownButton/index.tsx +1 -1
  31. package/src/components/DropDownButton/styles.tsx +59 -59
  32. package/src/components/ErrorBoundary/ErrorBoundary.tsx +33 -33
  33. package/src/components/ErrorBoundary/ErrorFallback.tsx +241 -241
  34. package/src/components/ErrorBoundary/GlobalNetworkLoadingIndicator.tsx +13 -13
  35. package/src/components/ErrorBoundary/index.tsx +1 -1
  36. package/src/components/ErrorBox.tsx +42 -42
  37. package/src/components/ExcelToJsonInput/ExcelJsonUpload.tsx +50 -50
  38. package/src/components/ExcelToJsonInput/ExcelToJsonInput.tsx +57 -57
  39. package/src/components/ExcelToJsonInput/index.tsx +1 -1
  40. package/src/components/FilterComponents/FilterButton.tsx +56 -56
  41. package/src/components/FilterComponents/SearchBar.tsx +45 -45
  42. package/src/components/FloatingContainer.tsx +33 -33
  43. package/src/components/Form/Form.tsx +147 -147
  44. package/src/components/Form/RenderForm.tsx +189 -189
  45. package/src/components/FullScreenLoader.tsx +19 -19
  46. package/src/components/HookForm/AutoCompleteSearch.tsx +113 -113
  47. package/src/components/HookForm/DatePicker.tsx +40 -40
  48. package/src/components/HookForm/DateTimePicker.tsx +47 -47
  49. package/src/components/HookForm/FormLabel.tsx +14 -14
  50. package/src/components/HookForm/MultiCheckbox.tsx +69 -69
  51. package/src/components/HookForm/MultiSelect.tsx +61 -61
  52. package/src/components/HookForm/RadioGroup.tsx +47 -47
  53. package/src/components/HookForm/SingleCheckbox.tsx +34 -34
  54. package/src/components/HookForm/SingleSelect.tsx +46 -46
  55. package/src/components/HookForm/TextField.tsx +40 -40
  56. package/src/components/HookForm/TimePicker.tsx +40 -40
  57. package/src/components/HookForm/index.ts +23 -23
  58. package/src/components/IconButtons/IconButtons.tsx +137 -137
  59. package/src/components/IconButtons/Icons.tsx +268 -268
  60. package/src/components/IconButtons/assets/edit.svg +4 -4
  61. package/src/components/IconButtons/assets/eye.svg +6 -6
  62. package/src/components/IconButtons/assets/trash.svg +7 -7
  63. package/src/components/IconButtons/index.tsx +8 -8
  64. package/src/components/IconLabel.tsx +37 -37
  65. package/src/components/Image/Image.tsx +45 -45
  66. package/src/components/Image/index.tsx +1 -1
  67. package/src/components/ImageUpload.tsx +98 -98
  68. package/src/components/Input/AsyncSearchSelect/AsyncSearchSelect.tsx +216 -216
  69. package/src/components/Input/AsyncSearchSelect/index.tsx +1 -1
  70. package/src/components/Input/AsyncSearchSelect/styles.tsx +105 -105
  71. package/src/components/Input/AutoCompleteSearch.tsx +121 -121
  72. package/src/components/Input/DatePicker.tsx +87 -87
  73. package/src/components/Input/DateRangePicker.tsx +105 -105
  74. package/src/components/Input/DateTimePicker.tsx +84 -84
  75. package/src/components/Input/FormLabel.tsx +21 -21
  76. package/src/components/Input/MultiCheckbox.tsx +64 -64
  77. package/src/components/Input/MultiSelect.tsx +161 -161
  78. package/src/components/Input/RadioGroup.tsx +104 -104
  79. package/src/components/Input/SingleCheckbox.tsx +78 -78
  80. package/src/components/Input/SingleSelect.tsx +104 -104
  81. package/src/components/Input/TextField.tsx +46 -46
  82. package/src/components/Input/TimePicker.tsx +77 -77
  83. package/src/components/Input/index.ts +26 -26
  84. package/src/components/Input/types.ts +3 -3
  85. package/src/components/JsonPreview.tsx +7 -7
  86. package/src/components/LabelValue.tsx +21 -21
  87. package/src/components/Layout/ChangePassword.tsx +49 -49
  88. package/src/components/Layout/Header/AppHeader.tsx +112 -112
  89. package/src/components/Layout/Header/AppsMenu.tsx +133 -133
  90. package/src/components/Layout/Header/HeaderActions/CogWheelMenu.tsx +33 -33
  91. package/src/components/Layout/Header/HeaderActions/FreshChatButton.tsx +61 -61
  92. package/src/components/Layout/Header/HeaderActions/FreshDeskHelpButton.tsx +28 -28
  93. package/src/components/Layout/Header/HeaderActions/HeaderActions.tsx +18 -18
  94. package/src/components/Layout/Header/HeaderActions/UserBox.tsx +56 -56
  95. package/src/components/Layout/Header/Notification.tsx +13 -13
  96. package/src/components/Layout/Header/applications.ts +97 -97
  97. package/src/components/Layout/Header/assets/campx_square_small.svg +8 -8
  98. package/src/components/Layout/Header/assets/commuteX.png +0 -0
  99. package/src/components/Layout/Header/assets/commutex.svg +14 -14
  100. package/src/components/Layout/Header/assets/commutexSmall.svg +11 -11
  101. package/src/components/Layout/Header/assets/enroll.svg +14 -14
  102. package/src/components/Layout/Header/assets/enrollx.svg +14 -14
  103. package/src/components/Layout/Header/assets/exams_small.svg +11 -11
  104. package/src/components/Layout/Header/assets/examsx.svg +14 -14
  105. package/src/components/Layout/Header/assets/hostel_small.svg +13 -13
  106. package/src/components/Layout/Header/assets/hostelx.svg +13 -13
  107. package/src/components/Layout/Header/assets/index.ts +37 -37
  108. package/src/components/Layout/Header/assets/libraryx.svg +12 -12
  109. package/src/components/Layout/Header/assets/pay_small.svg +15 -15
  110. package/src/components/Layout/Header/assets/payx.svg +19 -19
  111. package/src/components/Layout/Header/assets/people_small.svg +9 -9
  112. package/src/components/Layout/Header/assets/peoplex.svg +12 -12
  113. package/src/components/Layout/Header/assets/squarex.svg +12 -12
  114. package/src/components/Layout/Header/icons.tsx +57 -57
  115. package/src/components/Layout/Header/index.tsx +1 -1
  116. package/src/components/Layout/Header/styles.tsx +133 -133
  117. package/src/components/Layout/Helmet.tsx +105 -105
  118. package/src/components/Layout/LayoutWrapper.tsx +28 -28
  119. package/src/components/Layout/SideMenuHeader.tsx +29 -29
  120. package/src/components/Layout/SideNav.tsx +168 -168
  121. package/src/components/Layout/Tickets/HelpWidget/HelpWidget.tsx +273 -273
  122. package/src/components/Layout/Tickets/HelpWidget/styles.tsx +94 -94
  123. package/src/components/Layout/Tickets/MyTickets.tsx +72 -72
  124. package/src/components/Layout/Tickets/TicketDetails.tsx +65 -65
  125. package/src/components/Layout/Tickets/TimeLine.tsx +64 -64
  126. package/src/components/Layout/Tickets/index.tsx +1 -1
  127. package/src/components/Layout/Tickets/services.ts +11 -11
  128. package/src/components/Layout/Tickets/styles.tsx +136 -136
  129. package/src/components/LinearProgress.tsx +19 -19
  130. package/src/components/ListItemButton.tsx +95 -95
  131. package/src/components/LoginForm.tsx +279 -279
  132. package/src/components/MediaRow/MediaRow.tsx +67 -67
  133. package/src/components/MediaRow/index.tsx +1 -1
  134. package/src/components/ModalButtons/DialogButton.tsx +126 -126
  135. package/src/components/ModalButtons/DrawerButton.tsx +115 -115
  136. package/src/components/ModalButtons/index.tsx +4 -4
  137. package/src/components/NoDataIllustration.tsx +32 -32
  138. package/src/components/PageContent.tsx +12 -12
  139. package/src/components/PageHeader.tsx +55 -55
  140. package/src/components/PageNotFound.tsx +26 -26
  141. package/src/components/PopupConfirm/ConfirmContextProvider.tsx +40 -40
  142. package/src/components/PopupConfirm/PopupConfirm.tsx +67 -67
  143. package/src/components/PopupConfirm/index.tsx +1 -1
  144. package/src/components/PopupConfirm/useConfirm.ts +47 -47
  145. package/src/components/ResetPassword.tsx +107 -107
  146. package/src/components/Row.tsx +24 -24
  147. package/src/components/Spinner.tsx +18 -18
  148. package/src/components/StepsHeader/StepsHeader.tsx +115 -115
  149. package/src/components/StepsHeader/index.tsx +1 -1
  150. package/src/components/StyledTableContainer.tsx +33 -33
  151. package/src/components/SwitchButton.tsx +41 -41
  152. package/src/components/Table.tsx +42 -42
  153. package/src/components/Tables/BasicTable/Table.tsx +198 -198
  154. package/src/components/Tables/BasicTable/TableFooter.tsx +86 -86
  155. package/src/components/Tables/BasicTable/index.tsx +1 -1
  156. package/src/components/Tables/ReactTable/BatchActionsHeader.tsx +58 -58
  157. package/src/components/Tables/ReactTable/ReactTable.tsx +295 -295
  158. package/src/components/Tables/ReactTable/RenderTableBody.tsx +49 -49
  159. package/src/components/Tables/ReactTable/index.tsx +1 -1
  160. package/src/components/Tables/ReactTable/react-table-config.d.ts +128 -128
  161. package/src/components/Tables/common/NoRecordsFound.tsx +27 -27
  162. package/src/components/Tables/common/TableStats.tsx +22 -22
  163. package/src/components/Tables/common/icons.tsx +50 -50
  164. package/src/components/Tables/common/styles.tsx +170 -170
  165. package/src/components/Tables/common/types.ts +57 -57
  166. package/src/components/Tabs/NavigationTabs.tsx +80 -80
  167. package/src/components/Tabs/Tabs.tsx +53 -53
  168. package/src/components/Tabs/TabsContainer.tsx +53 -53
  169. package/src/components/Tabs/index.tsx +1 -1
  170. package/src/components/Tabs/styles.tsx +55 -55
  171. package/src/components/ToastContainer/ToastContainer.tsx +57 -57
  172. package/src/components/ToastContainer/index.tsx +1 -1
  173. package/src/components/UploadButton/UploadButton.tsx +126 -126
  174. package/src/components/UploadButton/index.tsx +1 -1
  175. package/src/components/UploadButton/types.ts +19 -19
  176. package/src/components/UploadDocument.tsx +108 -108
  177. package/src/components/UploadFileDialog/UploadFileDialog.tsx +238 -238
  178. package/src/components/UploadFileDialog/index.tsx +1 -1
  179. package/src/components/index.ts +108 -108
  180. package/src/config/axios.ts +73 -73
  181. package/src/config/axiosEvaluator.ts +53 -53
  182. package/src/config/axiosXTenant.ts +57 -57
  183. package/src/constants/UIConstants.ts +124 -124
  184. package/src/constants/formValidations.ts +6 -6
  185. package/src/constants/index.ts +5 -5
  186. package/src/constants/isDevelopment.ts +4 -4
  187. package/src/constants/permissions.ts +67 -67
  188. package/src/constants/validateMessages.ts +12 -12
  189. package/src/contexts/LoginFormProvider.tsx +39 -39
  190. package/src/contexts/Providers.tsx +52 -52
  191. package/src/contexts/PublicProviders.tsx +30 -30
  192. package/src/contexts/QueryClientProvider.tsx +22 -22
  193. package/src/hooks/index.ts +5 -5
  194. package/src/hooks/useAuth.ts +111 -110
  195. package/src/hooks/useExternalScript.ts +38 -38
  196. package/src/hooks/useFetch.ts +53 -53
  197. package/src/hooks/useFilters.ts +83 -83
  198. package/src/hooks/useRouter.ts +31 -31
  199. package/src/layouts/Components/DashBoardMenu.tsx +232 -232
  200. package/src/layouts/Components/icons/index.tsx +403 -403
  201. package/src/layouts/Components/styles.tsx +74 -74
  202. package/src/layouts/ComponentsLayout.tsx +3 -3
  203. package/src/permissions/PageWithPermission.tsx +18 -18
  204. package/src/permissions/PermissionDeniedPage.tsx +16 -16
  205. package/src/permissions/ValidateAccess.tsx +18 -18
  206. package/src/permissions/index.ts +2 -2
  207. package/src/react-app-env.d.ts +1 -1
  208. package/src/shared-state/AssetsStore.ts +15 -15
  209. package/src/shared-state/PermissionsStore.ts +1053 -534
  210. package/src/shared-state/UserStore.ts +13 -13
  211. package/src/shared-state/index.ts +4 -4
  212. package/src/theme/App.less +3 -3
  213. package/src/theme/MuiThemeProvider.tsx +18 -18
  214. package/src/theme/customCssBaseline.ts +135 -135
  215. package/src/theme/index.css +28 -28
  216. package/src/theme/muiTheme.ts +597 -597
  217. package/src/theme/theme.d.ts +77 -77
  218. package/src/utils/adminAxios.ts +15 -15
  219. package/src/utils/alphabet.ts +23 -23
  220. package/src/utils/arrayPadEnd.ts +3 -3
  221. package/src/utils/formatCurrency.ts +9 -9
  222. package/src/utils/getUrlParams.ts +5 -5
  223. package/src/utils/index.ts +7 -7
  224. package/src/utils/logout.ts +25 -25
  225. package/src/utils/ordinalSuffixOf.ts +14 -14
  226. package/src/utils/romanize.ts +40 -40
  227. package/src/utils/withRouteWrapper.tsx +25 -25
  228. package/src/utils/withSuspense.tsx +6 -6
  229. package/styled-components.tsx +60 -60
  230. package/tsconfig.json +21 -21
@@ -1,107 +1,107 @@
1
- import { VisibilityOff, Visibility } from '@mui/icons-material'
2
- import { Stack, InputAdornment, IconButton, Button, Alert } from '@mui/material'
3
- import React, { useState } from 'react'
4
- import { FormTextField } from './HookForm'
5
- import axios from '../config/axios'
6
- import { useForm } from 'react-hook-form'
7
- import { useNavigate } from 'react-router-dom'
8
- import { toast } from 'react-toastify'
9
-
10
- function ResetPassword() {
11
- const searchParams = new URLSearchParams(document.location.search)
12
- const { handleSubmit, control } = useForm()
13
- const navigate = useNavigate()
14
- const [error, setError] = useState('')
15
- const [showPassword, setShowPassword] = useState(false)
16
- const [showConfirmPassword, setShowConfirmPassword] = useState(false)
17
-
18
- async function handleResetPassword(values) {
19
- const token = searchParams.get('token')
20
- values.token = token
21
-
22
- if (values.newPassword == values.confirmNewPassword) {
23
- try {
24
- await axios
25
- .post(`https://api.campx.dev/auth-server/auth/reset-password`, values)
26
- .then((res) => {
27
- navigate('/login')
28
- toast.success('Password Changed Successfully')
29
- })
30
- } catch (err) {
31
- if (
32
- values.newPassword.length == 0 &&
33
- values.confirmNewPassword.length == 0
34
- ) {
35
- setError('Please enter valid password')
36
- } else if (token == null) {
37
- setError('Invalid token')
38
- } else {
39
- setError(err.response.data.message ?? 'Server Error')
40
- }
41
- }
42
- } else {
43
- setError("New Password and Confirm New password doesn't match")
44
- }
45
- }
46
-
47
- return (
48
- <>
49
- <form onSubmit={handleSubmit(handleResetPassword)}>
50
- <Stack gap={'30px'}>
51
- <FormTextField
52
- control={control}
53
- name="newPassword"
54
- label="New Password"
55
- type={showPassword ? 'text' : 'password'}
56
- required
57
- InputProps={{
58
- endAdornment: (
59
- <InputAdornment position="end">
60
- <IconButton
61
- size="small"
62
- aria-label="toggle password visibility"
63
- onClick={() => setShowPassword((prev) => !prev)}
64
- edge="end"
65
- >
66
- {showPassword ? <VisibilityOff /> : <Visibility />}
67
- </IconButton>
68
- </InputAdornment>
69
- ),
70
- }}
71
- />
72
-
73
- <FormTextField
74
- control={control}
75
- name="confirmNewPassword"
76
- label="Confirm Password"
77
- type={showConfirmPassword ? 'text' : 'password'}
78
- required
79
- InputProps={{
80
- endAdornment: (
81
- <InputAdornment position="end">
82
- <IconButton
83
- size="small"
84
- aria-label="toggle password visibility"
85
- onClick={() => setShowConfirmPassword((prev) => !prev)}
86
- edge="end"
87
- >
88
- {showPassword ? <VisibilityOff /> : <Visibility />}
89
- </IconButton>
90
- </InputAdornment>
91
- ),
92
- }}
93
- />
94
-
95
- <Button type="submit">Reset Password</Button>
96
- </Stack>
97
- </form>
98
- {error && (
99
- <Alert severity="error" sx={{ marginTop: '20px' }}>
100
- {error}
101
- </Alert>
102
- )}
103
- </>
104
- )
105
- }
106
-
107
- export default ResetPassword
1
+ import { VisibilityOff, Visibility } from '@mui/icons-material'
2
+ import { Stack, InputAdornment, IconButton, Button, Alert } from '@mui/material'
3
+ import React, { useState } from 'react'
4
+ import { FormTextField } from './HookForm'
5
+ import axios from '../config/axios'
6
+ import { useForm } from 'react-hook-form'
7
+ import { useNavigate } from 'react-router-dom'
8
+ import { toast } from 'react-toastify'
9
+
10
+ function ResetPassword() {
11
+ const searchParams = new URLSearchParams(document.location.search)
12
+ const { handleSubmit, control } = useForm()
13
+ const navigate = useNavigate()
14
+ const [error, setError] = useState('')
15
+ const [showPassword, setShowPassword] = useState(false)
16
+ const [showConfirmPassword, setShowConfirmPassword] = useState(false)
17
+
18
+ async function handleResetPassword(values) {
19
+ const token = searchParams.get('token')
20
+ values.token = token
21
+
22
+ if (values.newPassword == values.confirmNewPassword) {
23
+ try {
24
+ await axios
25
+ .post(`https://api.campx.dev/auth-server/auth/reset-password`, values)
26
+ .then((res) => {
27
+ navigate('/login')
28
+ toast.success('Password Changed Successfully')
29
+ })
30
+ } catch (err) {
31
+ if (
32
+ values.newPassword.length == 0 &&
33
+ values.confirmNewPassword.length == 0
34
+ ) {
35
+ setError('Please enter valid password')
36
+ } else if (token == null) {
37
+ setError('Invalid token')
38
+ } else {
39
+ setError(err.response.data.message ?? 'Server Error')
40
+ }
41
+ }
42
+ } else {
43
+ setError("New Password and Confirm New password doesn't match")
44
+ }
45
+ }
46
+
47
+ return (
48
+ <>
49
+ <form onSubmit={handleSubmit(handleResetPassword)}>
50
+ <Stack gap={'30px'}>
51
+ <FormTextField
52
+ control={control}
53
+ name="newPassword"
54
+ label="New Password"
55
+ type={showPassword ? 'text' : 'password'}
56
+ required
57
+ InputProps={{
58
+ endAdornment: (
59
+ <InputAdornment position="end">
60
+ <IconButton
61
+ size="small"
62
+ aria-label="toggle password visibility"
63
+ onClick={() => setShowPassword((prev) => !prev)}
64
+ edge="end"
65
+ >
66
+ {showPassword ? <VisibilityOff /> : <Visibility />}
67
+ </IconButton>
68
+ </InputAdornment>
69
+ ),
70
+ }}
71
+ />
72
+
73
+ <FormTextField
74
+ control={control}
75
+ name="confirmNewPassword"
76
+ label="Confirm Password"
77
+ type={showConfirmPassword ? 'text' : 'password'}
78
+ required
79
+ InputProps={{
80
+ endAdornment: (
81
+ <InputAdornment position="end">
82
+ <IconButton
83
+ size="small"
84
+ aria-label="toggle password visibility"
85
+ onClick={() => setShowConfirmPassword((prev) => !prev)}
86
+ edge="end"
87
+ >
88
+ {showPassword ? <VisibilityOff /> : <Visibility />}
89
+ </IconButton>
90
+ </InputAdornment>
91
+ ),
92
+ }}
93
+ />
94
+
95
+ <Button type="submit">Reset Password</Button>
96
+ </Stack>
97
+ </form>
98
+ {error && (
99
+ <Alert severity="error" sx={{ marginTop: '20px' }}>
100
+ {error}
101
+ </Alert>
102
+ )}
103
+ </>
104
+ )
105
+ }
106
+
107
+ export default ResetPassword
@@ -1,24 +1,24 @@
1
- import { Box, SxProps } from '@mui/material'
2
- import { ReactNode } from 'react'
3
-
4
- export default function Row({
5
- gap,
6
- children,
7
- sx,
8
- }: {
9
- gap: number
10
- children: ReactNode
11
- sx?: SxProps
12
- }) {
13
- return (
14
- <Box
15
- sx={{
16
- display: 'flex',
17
- gap: `${gap}px`,
18
- ...sx,
19
- }}
20
- >
21
- {children}
22
- </Box>
23
- )
24
- }
1
+ import { Box, SxProps } from '@mui/material'
2
+ import { ReactNode } from 'react'
3
+
4
+ export default function Row({
5
+ gap,
6
+ children,
7
+ sx,
8
+ }: {
9
+ gap: number
10
+ children: ReactNode
11
+ sx?: SxProps
12
+ }) {
13
+ return (
14
+ <Box
15
+ sx={{
16
+ display: 'flex',
17
+ gap: `${gap}px`,
18
+ ...sx,
19
+ }}
20
+ >
21
+ {children}
22
+ </Box>
23
+ )
24
+ }
@@ -1,18 +1,18 @@
1
- import { CircularProgress } from '@mui/material'
2
-
3
- function Spinner({ height = '200px' }: { height?: string | number }) {
4
- return (
5
- <div
6
- style={{
7
- justifyContent: 'center',
8
- alignItems: 'center',
9
- height,
10
- display: 'flex',
11
- }}
12
- >
13
- <CircularProgress />
14
- </div>
15
- )
16
- }
17
-
18
- export default Spinner
1
+ import { CircularProgress } from '@mui/material'
2
+
3
+ function Spinner({ height = '200px' }: { height?: string | number }) {
4
+ return (
5
+ <div
6
+ style={{
7
+ justifyContent: 'center',
8
+ alignItems: 'center',
9
+ height,
10
+ display: 'flex',
11
+ }}
12
+ >
13
+ <CircularProgress />
14
+ </div>
15
+ )
16
+ }
17
+
18
+ export default Spinner
@@ -1,115 +1,115 @@
1
- import { Done } from '@mui/icons-material'
2
- import { alpha, Box, styled, Typography } from '@mui/material'
3
- import { useEffect, useState } from 'react'
4
-
5
- export const StyledStepsContainer = styled(Box)(({ theme }) => ({
6
- padding: '10px 0',
7
- display: 'flex',
8
- justifyContent: 'center',
9
- gap: '10px',
10
- }))
11
-
12
- export const StyledStep = styled(Box, {
13
- shouldForwardProp: (prop) =>
14
- !['active', 'disableHover'].includes(prop as string),
15
- })<{ active: boolean; disableHover: boolean }>(
16
- ({ theme, active, disableHover }) => ({
17
- maxWidth: '130px',
18
- position: 'relative',
19
- display: 'grid',
20
- gridTemplateRows: '50px 1fr',
21
- placeItems: 'center',
22
- gap: '10px',
23
- cursor: disableHover ? 'default' : 'pointer',
24
- padding: '6px',
25
- borderRadius: '10px',
26
- transition: 'background 0.3s ease',
27
- '&:hover': {
28
- background: disableHover ? 'none' : theme.palette.secondary.light,
29
- },
30
- '& .MuiTypography-root': {
31
- color: alpha(theme.palette.secondary.main, active ? 1 : 0.6),
32
- fontWeight: 'bold',
33
- textAlign: 'center',
34
- },
35
- '& .connector': {
36
- position: 'absolute',
37
- top: '30%',
38
- left: '50%',
39
- width: '100%',
40
- borderBottom: `1px dashed #1212128A`,
41
- },
42
- '&:last-of-type': {
43
- '& .connector': {
44
- display: 'none',
45
- },
46
- },
47
- }),
48
- )
49
-
50
- export const StyledCircle = styled(Box, {
51
- shouldForwardProp: (prop) => prop !== 'active',
52
- })<{ active: boolean }>(({ theme, active }) => ({
53
- height: '50px',
54
- width: '50px',
55
- borderRadius: '50%',
56
- background: 'white',
57
- zIndex: 30,
58
- backgroundImage: `url("data:image/svg+xml,%3csvg width='100%25' height='100%25' xmlns='http://www.w3.org/2000/svg'%3e%3crect width='100%25' height='100%25' fill='none' rx='100' ry='100' stroke='gray' stroke-width='1.2' stroke-dasharray='8' stroke-dashoffset='0' stroke-linecap='square'/%3e%3c/svg%3e")`,
59
- display: 'flex',
60
- justifyContent: 'center',
61
- alignItems: 'center',
62
- ...(active && {
63
- border: `1px solid ${theme.palette.primary.main}`,
64
- backgroundImage: 'none',
65
- }),
66
- }))
67
-
68
- interface StepsHeaderProps {
69
- steps: { step: number; label: string }[]
70
- onChange: (step: number) => void
71
- activeStep?: number
72
- disableClick?: boolean
73
- }
74
-
75
- export default function StepsHeader({
76
- steps,
77
- onChange,
78
- activeStep: _activeStep = 0,
79
- disableClick = false,
80
- }: StepsHeaderProps) {
81
- const [activeStep, setActiveStep] = useState(0)
82
-
83
- const handleClick = (step) => {
84
- setActiveStep(step)
85
- onChange(step)
86
- }
87
-
88
- useEffect(() => {
89
- setActiveStep(_activeStep)
90
- }, [_activeStep])
91
-
92
- return (
93
- <StyledStepsContainer>
94
- {steps?.map((item) => (
95
- <StyledStep
96
- active={activeStep > item?.step - 1}
97
- disableHover={disableClick}
98
- onClick={() => {
99
- if (disableClick) return
100
- handleClick(item.step)
101
- }}
102
- key={item?.step}
103
- >
104
- <StyledCircle active={activeStep > item?.step - 1}>
105
- {activeStep > item?.step - 1 && <Done color="success" />}
106
- </StyledCircle>
107
- <Typography variant="body1" sx={{ fontSize: '13px' }}>
108
- {item?.label}
109
- </Typography>
110
- <Box className="connector"></Box>
111
- </StyledStep>
112
- ))}
113
- </StyledStepsContainer>
114
- )
115
- }
1
+ import { Done } from '@mui/icons-material'
2
+ import { alpha, Box, styled, Typography } from '@mui/material'
3
+ import { useEffect, useState } from 'react'
4
+
5
+ export const StyledStepsContainer = styled(Box)(({ theme }) => ({
6
+ padding: '10px 0',
7
+ display: 'flex',
8
+ justifyContent: 'center',
9
+ gap: '10px',
10
+ }))
11
+
12
+ export const StyledStep = styled(Box, {
13
+ shouldForwardProp: (prop) =>
14
+ !['active', 'disableHover'].includes(prop as string),
15
+ })<{ active: boolean; disableHover: boolean }>(
16
+ ({ theme, active, disableHover }) => ({
17
+ maxWidth: '130px',
18
+ position: 'relative',
19
+ display: 'grid',
20
+ gridTemplateRows: '50px 1fr',
21
+ placeItems: 'center',
22
+ gap: '10px',
23
+ cursor: disableHover ? 'default' : 'pointer',
24
+ padding: '6px',
25
+ borderRadius: '10px',
26
+ transition: 'background 0.3s ease',
27
+ '&:hover': {
28
+ background: disableHover ? 'none' : theme.palette.secondary.light,
29
+ },
30
+ '& .MuiTypography-root': {
31
+ color: alpha(theme.palette.secondary.main, active ? 1 : 0.6),
32
+ fontWeight: 'bold',
33
+ textAlign: 'center',
34
+ },
35
+ '& .connector': {
36
+ position: 'absolute',
37
+ top: '30%',
38
+ left: '50%',
39
+ width: '100%',
40
+ borderBottom: `1px dashed #1212128A`,
41
+ },
42
+ '&:last-of-type': {
43
+ '& .connector': {
44
+ display: 'none',
45
+ },
46
+ },
47
+ }),
48
+ )
49
+
50
+ export const StyledCircle = styled(Box, {
51
+ shouldForwardProp: (prop) => prop !== 'active',
52
+ })<{ active: boolean }>(({ theme, active }) => ({
53
+ height: '50px',
54
+ width: '50px',
55
+ borderRadius: '50%',
56
+ background: 'white',
57
+ zIndex: 30,
58
+ backgroundImage: `url("data:image/svg+xml,%3csvg width='100%25' height='100%25' xmlns='http://www.w3.org/2000/svg'%3e%3crect width='100%25' height='100%25' fill='none' rx='100' ry='100' stroke='gray' stroke-width='1.2' stroke-dasharray='8' stroke-dashoffset='0' stroke-linecap='square'/%3e%3c/svg%3e")`,
59
+ display: 'flex',
60
+ justifyContent: 'center',
61
+ alignItems: 'center',
62
+ ...(active && {
63
+ border: `1px solid ${theme.palette.primary.main}`,
64
+ backgroundImage: 'none',
65
+ }),
66
+ }))
67
+
68
+ interface StepsHeaderProps {
69
+ steps: { step: number; label: string }[]
70
+ onChange: (step: number) => void
71
+ activeStep?: number
72
+ disableClick?: boolean
73
+ }
74
+
75
+ export default function StepsHeader({
76
+ steps,
77
+ onChange,
78
+ activeStep: _activeStep = 0,
79
+ disableClick = false,
80
+ }: StepsHeaderProps) {
81
+ const [activeStep, setActiveStep] = useState(0)
82
+
83
+ const handleClick = (step) => {
84
+ setActiveStep(step)
85
+ onChange(step)
86
+ }
87
+
88
+ useEffect(() => {
89
+ setActiveStep(_activeStep)
90
+ }, [_activeStep])
91
+
92
+ return (
93
+ <StyledStepsContainer>
94
+ {steps?.map((item) => (
95
+ <StyledStep
96
+ active={activeStep > item?.step - 1}
97
+ disableHover={disableClick}
98
+ onClick={() => {
99
+ if (disableClick) return
100
+ handleClick(item.step)
101
+ }}
102
+ key={item?.step}
103
+ >
104
+ <StyledCircle active={activeStep > item?.step - 1}>
105
+ {activeStep > item?.step - 1 && <Done color="success" />}
106
+ </StyledCircle>
107
+ <Typography variant="body1" sx={{ fontSize: '13px' }}>
108
+ {item?.label}
109
+ </Typography>
110
+ <Box className="connector"></Box>
111
+ </StyledStep>
112
+ ))}
113
+ </StyledStepsContainer>
114
+ )
115
+ }
@@ -1 +1 @@
1
- export { default } from './StepsHeader'
1
+ export { default } from './StepsHeader'
@@ -1,33 +1,33 @@
1
- import styled from 'styled-components'
2
-
3
- export const StyledTableContainer = styled.div`
4
- /* background: white; */
5
- margin-top: 10px;
6
- border-radius: 16px;
7
-
8
- table thead tr {
9
- background-color: #efefef;
10
- }
11
-
12
- table,
13
- td,
14
- th {
15
- border: 1px solid #bebebe;
16
- padding: 8px;
17
- }
18
-
19
- table {
20
- background: white;
21
- width: 100%;
22
- border-collapse: collapse;
23
- }
24
-
25
- @media print {
26
- table,
27
- td,
28
- th {
29
- border: 1px solid black;
30
- padding: 8px;
31
- }
32
- }
33
- `
1
+ import styled from 'styled-components'
2
+
3
+ export const StyledTableContainer = styled.div`
4
+ /* background: white; */
5
+ margin-top: 10px;
6
+ border-radius: 16px;
7
+
8
+ table thead tr {
9
+ background-color: #efefef;
10
+ }
11
+
12
+ table,
13
+ td,
14
+ th {
15
+ border: 1px solid #bebebe;
16
+ padding: 8px;
17
+ }
18
+
19
+ table {
20
+ background: white;
21
+ width: 100%;
22
+ border-collapse: collapse;
23
+ }
24
+
25
+ @media print {
26
+ table,
27
+ td,
28
+ th {
29
+ border: 1px solid black;
30
+ padding: 8px;
31
+ }
32
+ }
33
+ `