@campxdev/shared 1.8.5-0.alpha-1 → 1.8.5-0.alpha-2

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 (232) 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 +342 -342
  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 +122 -122
  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 +113 -113
  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 +53 -53
  93. package/src/components/Layout/Header/HeaderActions/HeaderActions.tsx +20 -20
  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/SchoolSwitch/SchoolSwitch.tsx +33 -33
  97. package/src/components/Layout/Header/applications.ts +102 -102
  98. package/src/components/Layout/Header/assets/campx_square_small.svg +8 -8
  99. package/src/components/Layout/Header/assets/commuteX.png +0 -0
  100. package/src/components/Layout/Header/assets/commutex.svg +14 -14
  101. package/src/components/Layout/Header/assets/commutexSmall.svg +11 -11
  102. package/src/components/Layout/Header/assets/enroll.svg +14 -14
  103. package/src/components/Layout/Header/assets/enrollx.svg +14 -14
  104. package/src/components/Layout/Header/assets/exams_small.svg +11 -11
  105. package/src/components/Layout/Header/assets/examsx.svg +14 -14
  106. package/src/components/Layout/Header/assets/hostel_small.svg +13 -13
  107. package/src/components/Layout/Header/assets/hostelx.svg +13 -13
  108. package/src/components/Layout/Header/assets/index.ts +37 -37
  109. package/src/components/Layout/Header/assets/libraryx.svg +12 -12
  110. package/src/components/Layout/Header/assets/pay_small.svg +15 -15
  111. package/src/components/Layout/Header/assets/payx.svg +19 -19
  112. package/src/components/Layout/Header/assets/people_small.svg +9 -9
  113. package/src/components/Layout/Header/assets/peoplex.svg +12 -12
  114. package/src/components/Layout/Header/assets/squarex.svg +12 -12
  115. package/src/components/Layout/Header/icons.tsx +57 -57
  116. package/src/components/Layout/Header/index.tsx +1 -1
  117. package/src/components/Layout/Header/styles.tsx +133 -133
  118. package/src/components/Layout/Helmet.tsx +108 -108
  119. package/src/components/Layout/LayoutWrapper.tsx +28 -28
  120. package/src/components/Layout/SideMenuHeader.tsx +29 -29
  121. package/src/components/Layout/SideNav.tsx +168 -168
  122. package/src/components/Layout/Tickets/HelpWidget/HelpWidget.tsx +273 -273
  123. package/src/components/Layout/Tickets/HelpWidget/styles.tsx +94 -94
  124. package/src/components/Layout/Tickets/MyTickets.tsx +72 -72
  125. package/src/components/Layout/Tickets/TicketDetails.tsx +65 -65
  126. package/src/components/Layout/Tickets/TimeLine.tsx +64 -64
  127. package/src/components/Layout/Tickets/index.tsx +1 -1
  128. package/src/components/Layout/Tickets/services.ts +11 -11
  129. package/src/components/Layout/Tickets/styles.tsx +136 -136
  130. package/src/components/LinearProgress.tsx +19 -19
  131. package/src/components/ListItemButton.tsx +95 -95
  132. package/src/components/LoginForm.tsx +279 -279
  133. package/src/components/MediaRow/MediaRow.tsx +67 -67
  134. package/src/components/MediaRow/index.tsx +1 -1
  135. package/src/components/ModalButtons/DialogButton.tsx +126 -126
  136. package/src/components/ModalButtons/DrawerButton.tsx +115 -115
  137. package/src/components/ModalButtons/PopoverButton.tsx +99 -99
  138. package/src/components/ModalButtons/index.tsx +4 -4
  139. package/src/components/NoDataIllustration.tsx +32 -32
  140. package/src/components/PageContent.tsx +12 -12
  141. package/src/components/PageHeader.tsx +55 -55
  142. package/src/components/PageNotFound.tsx +26 -26
  143. package/src/components/PopupConfirm/ConfirmContextProvider.tsx +40 -40
  144. package/src/components/PopupConfirm/PopupConfirm.tsx +67 -67
  145. package/src/components/PopupConfirm/index.tsx +1 -1
  146. package/src/components/PopupConfirm/useConfirm.ts +47 -47
  147. package/src/components/ResetPassword.tsx +107 -107
  148. package/src/components/Row.tsx +24 -24
  149. package/src/components/Spinner.tsx +18 -18
  150. package/src/components/StepsHeader/StepsHeader.tsx +115 -115
  151. package/src/components/StepsHeader/index.tsx +1 -1
  152. package/src/components/StyledTableContainer.tsx +33 -33
  153. package/src/components/SwitchButton.tsx +41 -41
  154. package/src/components/Table.tsx +42 -42
  155. package/src/components/Tables/BasicTable/Table.tsx +198 -198
  156. package/src/components/Tables/BasicTable/TableFooter.tsx +86 -86
  157. package/src/components/Tables/BasicTable/index.tsx +1 -1
  158. package/src/components/Tables/ReactTable/BatchActionsHeader.tsx +58 -58
  159. package/src/components/Tables/ReactTable/ReactTable.tsx +295 -295
  160. package/src/components/Tables/ReactTable/RenderTableBody.tsx +49 -49
  161. package/src/components/Tables/ReactTable/index.tsx +1 -1
  162. package/src/components/Tables/ReactTable/react-table-config.d.ts +128 -128
  163. package/src/components/Tables/common/NoRecordsFound.tsx +27 -27
  164. package/src/components/Tables/common/TableStats.tsx +22 -22
  165. package/src/components/Tables/common/icons.tsx +50 -50
  166. package/src/components/Tables/common/styles.tsx +170 -170
  167. package/src/components/Tables/common/types.ts +57 -57
  168. package/src/components/Tabs/NavigationTabs.tsx +80 -80
  169. package/src/components/Tabs/Tabs.tsx +53 -53
  170. package/src/components/Tabs/TabsContainer.tsx +53 -53
  171. package/src/components/Tabs/index.tsx +1 -1
  172. package/src/components/Tabs/styles.tsx +55 -55
  173. package/src/components/ToastContainer/ToastContainer.tsx +57 -57
  174. package/src/components/ToastContainer/index.tsx +1 -1
  175. package/src/components/UploadButton/UploadButton.tsx +126 -126
  176. package/src/components/UploadButton/index.tsx +1 -1
  177. package/src/components/UploadButton/types.ts +19 -19
  178. package/src/components/UploadDocument.tsx +108 -108
  179. package/src/components/UploadFileDialog/UploadFileDialog.tsx +238 -238
  180. package/src/components/UploadFileDialog/index.tsx +1 -1
  181. package/src/components/index.ts +110 -110
  182. package/src/config/axios.ts +79 -79
  183. package/src/config/axiosEvaluator.ts +53 -53
  184. package/src/config/axiosXTenant.ts +57 -57
  185. package/src/constants/UIConstants.ts +124 -124
  186. package/src/constants/formValidations.ts +6 -6
  187. package/src/constants/index.ts +5 -5
  188. package/src/constants/isDevelopment.ts +4 -4
  189. package/src/constants/permissions.ts +67 -67
  190. package/src/constants/validateMessages.ts +12 -12
  191. package/src/contexts/LoginFormProvider.tsx +39 -39
  192. package/src/contexts/Providers.tsx +52 -52
  193. package/src/contexts/PublicProviders.tsx +30 -30
  194. package/src/contexts/QueryClientProvider.tsx +22 -22
  195. package/src/hooks/index.ts +5 -5
  196. package/src/hooks/useAuth.ts +152 -152
  197. package/src/hooks/useExternalScript.ts +38 -38
  198. package/src/hooks/useFetch.ts +53 -53
  199. package/src/hooks/useFilters.ts +83 -83
  200. package/src/hooks/useRouter.ts +31 -31
  201. package/src/layouts/Components/DashBoardMenu.tsx +232 -232
  202. package/src/layouts/Components/icons/index.tsx +403 -403
  203. package/src/layouts/Components/styles.tsx +74 -74
  204. package/src/layouts/ComponentsLayout.tsx +3 -3
  205. package/src/permissions/PageWithPermission.tsx +18 -18
  206. package/src/permissions/PermissionDeniedPage.tsx +16 -16
  207. package/src/permissions/ValidateAccess.tsx +18 -18
  208. package/src/permissions/index.ts +2 -2
  209. package/src/react-app-env.d.ts +1 -1
  210. package/src/shared-state/AssetsStore.ts +15 -15
  211. package/src/shared-state/PermissionsStore.ts +1163 -1159
  212. package/src/shared-state/UserStore.ts +13 -13
  213. package/src/shared-state/index.ts +4 -4
  214. package/src/theme/App.less +3 -3
  215. package/src/theme/MuiThemeProvider.tsx +18 -18
  216. package/src/theme/customCssBaseline.ts +135 -135
  217. package/src/theme/index.css +28 -28
  218. package/src/theme/muiTheme.ts +597 -597
  219. package/src/theme/theme.d.ts +77 -77
  220. package/src/utils/adminAxios.ts +15 -15
  221. package/src/utils/alphabet.ts +23 -23
  222. package/src/utils/arrayPadEnd.ts +3 -3
  223. package/src/utils/formatCurrency.ts +9 -9
  224. package/src/utils/getUrlParams.ts +5 -5
  225. package/src/utils/index.ts +7 -7
  226. package/src/utils/logout.ts +25 -25
  227. package/src/utils/ordinalSuffixOf.ts +14 -14
  228. package/src/utils/romanize.ts +40 -40
  229. package/src/utils/withRouteWrapper.tsx +25 -25
  230. package/src/utils/withSuspense.tsx +6 -6
  231. package/styled-components.tsx +60 -60
  232. package/tsconfig.json +21 -21
@@ -1,30 +1,30 @@
1
- import { CssBaseline } from '@mui/material'
2
- import { BrowserRouter } from 'react-router-dom'
3
- import ConfirmContextProvider from '../components/PopupConfirm/ConfirmContextProvider'
4
- import MuiThemeProvider from '../theme/MuiThemeProvider'
5
- import QueryClientProvider from './QueryClientProvider'
6
-
7
- import { ReactNode } from 'react'
8
- import { ToastContainer } from '../components'
9
- import DialogProvider from '../components/DrawerWrapper/DrawerWrapper'
10
-
11
- // export const campxTenantKey = Cookies.get('campx_tenant')
12
- // export const urlTenantKey = window.location.pathname.split('/')[1]
13
-
14
- export default function PublicProviders({ children }: { children: ReactNode }) {
15
- return (
16
- <BrowserRouter>
17
- <QueryClientProvider>
18
- <MuiThemeProvider>
19
- <ConfirmContextProvider>
20
- <DialogProvider>
21
- {children}
22
- <CssBaseline />
23
- <ToastContainer />
24
- </DialogProvider>
25
- </ConfirmContextProvider>
26
- </MuiThemeProvider>
27
- </QueryClientProvider>
28
- </BrowserRouter>
29
- )
30
- }
1
+ import { CssBaseline } from '@mui/material'
2
+ import { BrowserRouter } from 'react-router-dom'
3
+ import ConfirmContextProvider from '../components/PopupConfirm/ConfirmContextProvider'
4
+ import MuiThemeProvider from '../theme/MuiThemeProvider'
5
+ import QueryClientProvider from './QueryClientProvider'
6
+
7
+ import { ReactNode } from 'react'
8
+ import { ToastContainer } from '../components'
9
+ import DialogProvider from '../components/DrawerWrapper/DrawerWrapper'
10
+
11
+ // export const campxTenantKey = Cookies.get('campx_tenant')
12
+ // export const urlTenantKey = window.location.pathname.split('/')[1]
13
+
14
+ export default function PublicProviders({ children }: { children: ReactNode }) {
15
+ return (
16
+ <BrowserRouter>
17
+ <QueryClientProvider>
18
+ <MuiThemeProvider>
19
+ <ConfirmContextProvider>
20
+ <DialogProvider>
21
+ {children}
22
+ <CssBaseline />
23
+ <ToastContainer />
24
+ </DialogProvider>
25
+ </ConfirmContextProvider>
26
+ </MuiThemeProvider>
27
+ </QueryClientProvider>
28
+ </BrowserRouter>
29
+ )
30
+ }
@@ -1,22 +1,22 @@
1
- import {
2
- QueryClient,
3
- QueryClientProvider as ReactQueryClientProvider,
4
- } from 'react-query'
5
-
6
- export const queryClient = new QueryClient({
7
- defaultOptions: {
8
- queries: {
9
- refetchOnWindowFocus: false,
10
- retry: false,
11
- useErrorBoundary: true,
12
- },
13
- },
14
- })
15
-
16
- export default function QueryClientProvider({ children }) {
17
- return (
18
- <ReactQueryClientProvider client={queryClient}>
19
- {children}
20
- </ReactQueryClientProvider>
21
- )
22
- }
1
+ import {
2
+ QueryClient,
3
+ QueryClientProvider as ReactQueryClientProvider,
4
+ } from 'react-query'
5
+
6
+ export const queryClient = new QueryClient({
7
+ defaultOptions: {
8
+ queries: {
9
+ refetchOnWindowFocus: false,
10
+ retry: false,
11
+ useErrorBoundary: true,
12
+ },
13
+ },
14
+ })
15
+
16
+ export default function QueryClientProvider({ children }) {
17
+ return (
18
+ <ReactQueryClientProvider client={queryClient}>
19
+ {children}
20
+ </ReactQueryClientProvider>
21
+ )
22
+ }
@@ -1,5 +1,5 @@
1
- export { default as useFetch } from './useFetch'
2
- export * from './useRouter'
3
- export { default as useAuth } from './useAuth'
4
- export { default as useFilter } from './useFilters'
5
- export { default as useExternalScript } from './useExternalScript'
1
+ export { default as useFetch } from './useFetch'
2
+ export * from './useRouter'
3
+ export { default as useAuth } from './useAuth'
4
+ export { default as useFilter } from './useFilters'
5
+ export { default as useExternalScript } from './useExternalScript'
@@ -1,152 +1,152 @@
1
- import { AxiosError } from 'axios'
2
- import { useEffect, useState } from 'react'
3
- import { toast } from 'react-toastify'
4
- import axios from '../config/axios'
5
- import { isDevelopment } from '../constants'
6
- import { useLoginForm } from '../contexts/LoginFormProvider'
7
- import { PermissionsStore, AssetsStore, UserStore } from '../shared-state'
8
-
9
- const url = window.location.origin
10
-
11
- type AuthParams = {
12
- permissionsEndpoint: string
13
- loginUrl?: string
14
- }
15
-
16
- type AuthResponse = {
17
- loading: boolean
18
- data: {
19
- user?: any
20
- roles?: any
21
- fullName?: any
22
- permissions?: any
23
- assets?: {
24
- logo: string
25
- logo_square: string
26
- }
27
- }
28
- }
29
-
30
- const ApplicationObj = {
31
- enroll: 'enroll_x',
32
- ums: 'square',
33
- payments: 'payments',
34
- exams: 'exams',
35
- }
36
-
37
- const checkIsAdmin = (user) => {
38
- let subDomain = window.location.host.split('.')?.slice(-3)[0]
39
- const localSubDomain = process.env.REACT_APP_SUBDOMAIN
40
-
41
- if (user?.isSuperuser) return 1
42
-
43
- if (process.env.NODE_ENV === 'development') {
44
- subDomain = localSubDomain
45
-
46
- if (!localSubDomain) {
47
- toast.warn('missing REACT_APP_SUBDOMAIN in .env')
48
- }
49
- }
50
-
51
- // eslint-disable-next-line no-console
52
- console.log(
53
- 'Current App ->',
54
- ApplicationObj[subDomain],
55
- '; subdomain env ->',
56
- subDomain,
57
- )
58
-
59
- const profile = user?.profiles?.find(
60
- (item) => item.application == ApplicationObj[subDomain],
61
- )
62
- return profile ? (profile.isAdmin == true ? 1 : 0) : 0
63
- }
64
-
65
- function useAuth({ permissionsEndpoint, loginUrl }: AuthParams): AuthResponse {
66
- const { openLoginForm } = useLoginForm()
67
- const [loading, setLoading] = useState<boolean>(false)
68
- const [data, setData] = useState(null)
69
-
70
- const appInit = async () => {
71
- setLoading(true)
72
- axios
73
- .get(permissionsEndpoint)
74
- .then((res) => {
75
- const origin = window.location.origin
76
- const originSubdomain =
77
- window.location.host.split('.')?.slice(-3)[0] ?? 'ums'
78
-
79
- const isStaging = origin.split('campx')[1] === '.dev'
80
-
81
- if (isDevelopment == false && isStaging == false) {
82
- if (
83
- !res.data.applications.includes(ApplicationObj[originSubdomain])
84
- ) {
85
- window.location.replace(
86
- `https://www.id.campx.in/apps?redirect_to=${url}`,
87
- )
88
- }
89
- }
90
-
91
- setLoading(false)
92
- setData(res.data)
93
- UserStore.update((s) => {
94
- s.username = res.data?.user?.username
95
- s.user = res.data?.user
96
- s.roles = res.data?.roles
97
- })
98
- const isAdmin = checkIsAdmin(res.data.user)
99
- // eslint-disable-next-line no-console
100
- console.log('Is Admin -> ', isAdmin)
101
-
102
- PermissionsStore.update((s) => {
103
- s.permissions = {
104
- ...res.data?.permissions,
105
- can_settings_view: 1,
106
- can_dashboard_view: 1,
107
- can_individual_pages_view: 1,
108
- can_analatics_view: isAdmin,
109
- can_admin_view: isAdmin,
110
- } as any
111
- s.applications = res.data?.applications ?? []
112
- })
113
- AssetsStore.update((s) => {
114
- s.logo = res.data?.assets.logo
115
- s.logo_square = res.data?.assets.logo_square
116
- })
117
- })
118
- .catch((err: AxiosError) => {
119
- setLoading(false)
120
- const origin = window.location.origin
121
- const isStaging = origin.split('campx')[1] === '.dev'
122
-
123
- if (isDevelopment || isStaging) {
124
- openLoginForm(loginUrl)
125
- return
126
- } else {
127
- window.location.replace(`https://www.id.campx.in/?redirect_to=${url}`)
128
- }
129
-
130
- if (err.response.status !== 401) {
131
- if (err.response.status > 400 && err.response.status < 500) {
132
- window.location.replace(
133
- `https://www.id.campx.in/?redirect_to=${url}`,
134
- )
135
- } else {
136
- toast.error('Server Error')
137
- }
138
- }
139
- })
140
- }
141
-
142
- useEffect(() => {
143
- appInit()
144
- }, [])
145
-
146
- return {
147
- loading: loading || !data?.permissions,
148
- data,
149
- }
150
- }
151
-
152
- export default useAuth
1
+ import { AxiosError } from 'axios'
2
+ import { useEffect, useState } from 'react'
3
+ import { toast } from 'react-toastify'
4
+ import axios from '../config/axios'
5
+ import { isDevelopment } from '../constants'
6
+ import { useLoginForm } from '../contexts/LoginFormProvider'
7
+ import { PermissionsStore, AssetsStore, UserStore } from '../shared-state'
8
+
9
+ const url = window.location.origin
10
+
11
+ type AuthParams = {
12
+ permissionsEndpoint: string
13
+ loginUrl?: string
14
+ }
15
+
16
+ type AuthResponse = {
17
+ loading: boolean
18
+ data: {
19
+ user?: any
20
+ roles?: any
21
+ fullName?: any
22
+ permissions?: any
23
+ assets?: {
24
+ logo: string
25
+ logo_square: string
26
+ }
27
+ }
28
+ }
29
+
30
+ const ApplicationObj = {
31
+ enroll: 'enroll_x',
32
+ ums: 'square',
33
+ payments: 'payments',
34
+ exams: 'exams',
35
+ }
36
+
37
+ const checkIsAdmin = (user) => {
38
+ let subDomain = window.location.host.split('.')?.slice(-3)[0]
39
+ const localSubDomain = process.env.REACT_APP_SUBDOMAIN
40
+
41
+ if (user?.isSuperuser) return 1
42
+
43
+ if (process.env.NODE_ENV === 'development') {
44
+ subDomain = localSubDomain
45
+
46
+ if (!localSubDomain) {
47
+ toast.warn('missing REACT_APP_SUBDOMAIN in .env')
48
+ }
49
+ }
50
+
51
+ // eslint-disable-next-line no-console
52
+ console.log(
53
+ 'Current App ->',
54
+ ApplicationObj[subDomain],
55
+ '; subdomain env ->',
56
+ subDomain,
57
+ )
58
+
59
+ const profile = user?.profiles?.find(
60
+ (item) => item.application == ApplicationObj[subDomain],
61
+ )
62
+ return profile ? (profile.isAdmin == true ? 1 : 0) : 0
63
+ }
64
+
65
+ function useAuth({ permissionsEndpoint, loginUrl }: AuthParams): AuthResponse {
66
+ const { openLoginForm } = useLoginForm()
67
+ const [loading, setLoading] = useState<boolean>(false)
68
+ const [data, setData] = useState(null)
69
+
70
+ const appInit = async () => {
71
+ setLoading(true)
72
+ axios
73
+ .get(permissionsEndpoint)
74
+ .then((res) => {
75
+ const origin = window.location.origin
76
+ const originSubdomain =
77
+ window.location.host.split('.')?.slice(-3)[0] ?? 'ums'
78
+
79
+ const isStaging = origin.split('campx')[1] === '.dev'
80
+
81
+ if (isDevelopment == false && isStaging == false) {
82
+ if (
83
+ !res.data.applications.includes(ApplicationObj[originSubdomain])
84
+ ) {
85
+ window.location.replace(
86
+ `https://www.id.campx.in/apps?redirect_to=${url}`,
87
+ )
88
+ }
89
+ }
90
+
91
+ setLoading(false)
92
+ setData(res.data)
93
+ UserStore.update((s) => {
94
+ s.username = res.data?.user?.username
95
+ s.user = res.data?.user
96
+ s.roles = res.data?.roles
97
+ })
98
+ const isAdmin = checkIsAdmin(res.data.user)
99
+ // eslint-disable-next-line no-console
100
+ console.log('Is Admin -> ', isAdmin)
101
+
102
+ PermissionsStore.update((s) => {
103
+ s.permissions = {
104
+ ...res.data?.permissions,
105
+ can_settings_view: 1,
106
+ can_dashboard_view: 1,
107
+ can_individual_pages_view: 1,
108
+ can_analatics_view: isAdmin,
109
+ can_admin_view: isAdmin,
110
+ } as any
111
+ s.applications = res.data?.applications ?? []
112
+ })
113
+ AssetsStore.update((s) => {
114
+ s.logo = res.data?.assets.logo
115
+ s.logo_square = res.data?.assets.logo_square
116
+ })
117
+ })
118
+ .catch((err: AxiosError) => {
119
+ setLoading(false)
120
+ const origin = window.location.origin
121
+ const isStaging = origin.split('campx')[1] === '.dev'
122
+
123
+ if (isDevelopment || isStaging) {
124
+ openLoginForm(loginUrl)
125
+ return
126
+ } else {
127
+ window.location.replace(`https://www.id.campx.in/?redirect_to=${url}`)
128
+ }
129
+
130
+ if (err.response.status !== 401) {
131
+ if (err.response.status > 400 && err.response.status < 500) {
132
+ window.location.replace(
133
+ `https://www.id.campx.in/?redirect_to=${url}`,
134
+ )
135
+ } else {
136
+ toast.error('Server Error')
137
+ }
138
+ }
139
+ })
140
+ }
141
+
142
+ useEffect(() => {
143
+ appInit()
144
+ }, [])
145
+
146
+ return {
147
+ loading: loading || !data?.permissions,
148
+ data,
149
+ }
150
+ }
151
+
152
+ export default useAuth
@@ -1,38 +1,38 @@
1
- import { useEffect, useState } from 'react'
2
- const useExternalScript = (url) => {
3
- let [state, setState] = useState(url ? 'loading' : 'idle')
4
-
5
- useEffect(() => {
6
- if (!url) {
7
- setState('idle')
8
- return
9
- }
10
- let script: any = document.querySelector(`script[src="${url}"]`)
11
-
12
- const handleScript = (e) => {
13
- setState(e.type === 'load' ? 'ready' : 'error')
14
- }
15
- if (!script) {
16
- script = document.createElement('script')
17
- script.type = 'application/javascript'
18
- script.src = url
19
- script.async = true
20
- document.body.appendChild(script)
21
- script.addEventListener('load', handleScript)
22
- script.addEventListener('error', handleScript)
23
- }
24
-
25
- script.addEventListener('load', handleScript)
26
- script.addEventListener('error', handleScript)
27
-
28
- return () => {
29
- script.removeEventListener('load', handleScript)
30
- script.removeEventListener('error', handleScript)
31
- document.body.removeChild(script)
32
- }
33
- }, [url])
34
-
35
- return state
36
- }
37
-
38
- export default useExternalScript
1
+ import { useEffect, useState } from 'react'
2
+ const useExternalScript = (url) => {
3
+ let [state, setState] = useState(url ? 'loading' : 'idle')
4
+
5
+ useEffect(() => {
6
+ if (!url) {
7
+ setState('idle')
8
+ return
9
+ }
10
+ let script: any = document.querySelector(`script[src="${url}"]`)
11
+
12
+ const handleScript = (e) => {
13
+ setState(e.type === 'load' ? 'ready' : 'error')
14
+ }
15
+ if (!script) {
16
+ script = document.createElement('script')
17
+ script.type = 'application/javascript'
18
+ script.src = url
19
+ script.async = true
20
+ document.body.appendChild(script)
21
+ script.addEventListener('load', handleScript)
22
+ script.addEventListener('error', handleScript)
23
+ }
24
+
25
+ script.addEventListener('load', handleScript)
26
+ script.addEventListener('error', handleScript)
27
+
28
+ return () => {
29
+ script.removeEventListener('load', handleScript)
30
+ script.removeEventListener('error', handleScript)
31
+ document.body.removeChild(script)
32
+ }
33
+ }, [url])
34
+
35
+ return state
36
+ }
37
+
38
+ export default useExternalScript
@@ -1,53 +1,53 @@
1
- import { useEffect, useState } from 'react'
2
- import axios from '../config/axios'
3
-
4
- export function useMockFetch(promiseFn: Function) {
5
- const [data, setData] = useState<any>()
6
- const [error, setError] = useState<any>(null)
7
- const [loading, setLoading] = useState(true)
8
-
9
- useEffect(() => {
10
- setLoading(true)
11
- promiseFn()
12
- .then((res) => {
13
- setData(res.data)
14
- setLoading(false)
15
- })
16
- .catch((err) => {
17
- setLoading(false)
18
- setError(null)
19
- })
20
- }, [])
21
-
22
- return {
23
- data,
24
- loading,
25
- }
26
- }
27
-
28
- export default function useFetch(url: string, skip?: boolean) {
29
- const [data, setData] = useState<any>()
30
- const [error, setError] = useState<any>(null)
31
- const [loading, setLoading] = useState(true)
32
-
33
- useEffect(() => {
34
- if (skip) return
35
- setLoading(true)
36
- axios
37
- .get(url)
38
- .then((res) => {
39
- setData(res.data)
40
- setLoading(false)
41
- })
42
- .catch((err) => {
43
- setError(err)
44
- setLoading(false)
45
- })
46
- }, [])
47
-
48
- return {
49
- data,
50
- loading,
51
- error,
52
- }
53
- }
1
+ import { useEffect, useState } from 'react'
2
+ import axios from '../config/axios'
3
+
4
+ export function useMockFetch(promiseFn: Function) {
5
+ const [data, setData] = useState<any>()
6
+ const [error, setError] = useState<any>(null)
7
+ const [loading, setLoading] = useState(true)
8
+
9
+ useEffect(() => {
10
+ setLoading(true)
11
+ promiseFn()
12
+ .then((res) => {
13
+ setData(res.data)
14
+ setLoading(false)
15
+ })
16
+ .catch((err) => {
17
+ setLoading(false)
18
+ setError(null)
19
+ })
20
+ }, [])
21
+
22
+ return {
23
+ data,
24
+ loading,
25
+ }
26
+ }
27
+
28
+ export default function useFetch(url: string, skip?: boolean) {
29
+ const [data, setData] = useState<any>()
30
+ const [error, setError] = useState<any>(null)
31
+ const [loading, setLoading] = useState(true)
32
+
33
+ useEffect(() => {
34
+ if (skip) return
35
+ setLoading(true)
36
+ axios
37
+ .get(url)
38
+ .then((res) => {
39
+ setData(res.data)
40
+ setLoading(false)
41
+ })
42
+ .catch((err) => {
43
+ setError(err)
44
+ setLoading(false)
45
+ })
46
+ }, [])
47
+
48
+ return {
49
+ data,
50
+ loading,
51
+ error,
52
+ }
53
+ }