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

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 (233) 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 -0
  10. package/src/components/ApplicationProfile/Service.ts +68 -0
  11. package/src/components/ApplicationProfile/UserProfileRelation.tsx +174 -0
  12. package/src/components/ApplicationProfile/index.tsx +1 -0
  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 -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 -28
  33. package/src/components/ErrorBoundary/ErrorFallback.tsx +241 -236
  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 -53
  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 -76
  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 -150
  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 -112
  89. package/src/components/Layout/Header/AppsMenu.tsx +133 -105
  90. package/src/components/Layout/Header/HeaderActions/CogWheelMenu.tsx +33 -33
  91. package/src/components/Layout/Header/HeaderActions/FreshChatButton.tsx +61 -0
  92. package/src/components/Layout/Header/HeaderActions/FreshDeskHelpButton.tsx +53 -24
  93. package/src/components/Layout/Header/HeaderActions/HeaderActions.tsx +20 -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/SchoolSwitch/SchoolSwitch.tsx +33 -0
  97. package/src/components/Layout/Header/applications.ts +102 -103
  98. package/src/components/Layout/Header/assets/campx_square_small.svg +8 -8
  99. package/src/components/Layout/Header/assets/chat_with_us.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 -35
  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 -49
  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 -274
  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 -0
  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 -50
  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 -106
  182. package/src/config/axios.ts +79 -73
  183. package/src/config/axiosEvaluator.ts +53 -53
  184. package/src/config/axiosXTenant.ts +57 -57
  185. package/src/constants/UIConstants.ts +124 -97
  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 -44
  192. package/src/contexts/Providers.tsx +52 -50
  193. package/src/contexts/PublicProviders.tsx +30 -30
  194. package/src/contexts/QueryClientProvider.tsx +22 -22
  195. package/src/hooks/index.ts +5 -4
  196. package/src/hooks/useAuth.ts +152 -96
  197. package/src/hooks/useExternalScript.ts +38 -0
  198. package/src/hooks/useFetch.ts +53 -53
  199. package/src/hooks/useFilters.ts +83 -80
  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 +1159 -356
  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 -595
  219. package/src/theme/theme.d.ts +77 -75
  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
  233. package/src/components/Layout/Header/assets/commuteX.png +0 -0
@@ -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,4 +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'
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,96 +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 { campxTenantKey, urlTenantKey } from '../contexts/Providers'
8
- import { PermissionsStore, AssetsStore, UserStore } from '../shared-state'
9
-
10
- const url = window.location.origin
11
-
12
- type AuthParams = {
13
- permissionsEndpoint: string
14
- loginUrl?: string
15
- }
16
-
17
- type AuthResponse = {
18
- loading: boolean
19
- data: {
20
- user?: any
21
- roles?: any
22
- fullName?: any
23
- permissions?: any
24
- assets?: {
25
- logo: string
26
- logo_square: string
27
- }
28
- }
29
- }
30
-
31
- function useAuth({ permissionsEndpoint, loginUrl }: AuthParams): AuthResponse {
32
- const { openLoginForm } = useLoginForm()
33
- const [loading, setLoading] = useState<boolean>(false)
34
- const [data, setData] = useState(null)
35
-
36
- const appInit = async () => {
37
- setLoading(true)
38
- axios
39
- .get(permissionsEndpoint)
40
- .then((res) => {
41
- setLoading(false)
42
- setData(res.data)
43
- UserStore.update((s) => {
44
- s.username = res.data?.username
45
- s.user = res.data?.user
46
- s.roles = res.data?.roles
47
- })
48
-
49
- PermissionsStore.update((s) => {
50
- s.permissions = {
51
- ...res.data?.permissions,
52
- can_settings_view: 1,
53
- can_dashboard_view: 1,
54
- can_individual_pages_view: 1,
55
- } as any
56
- })
57
- AssetsStore.update((s) => {
58
- s.logo = res.data?.assets.logo
59
- s.logo_square = res.data?.assets.logo_square
60
- })
61
- })
62
- .catch((err: AxiosError) => {
63
- setLoading(false)
64
- const origin = window.location.origin
65
- const isStaging = origin.split('campx')[1] === '.dev'
66
-
67
- if (isDevelopment || isStaging) {
68
- openLoginForm(loginUrl)
69
- return
70
- } else {
71
- window.location.replace(`https://www.id.campx.in/?redirect_to=${url}`)
72
- }
73
-
74
- if (err.response.status !== 401) {
75
- if (err.response.status > 400 && err.response.status < 500) {
76
- window.location.replace(
77
- `https://www.id.campx.in/?redirect_to=${url}`,
78
- )
79
- } else {
80
- toast.error('Server Error')
81
- }
82
- }
83
- })
84
- }
85
-
86
- useEffect(() => {
87
- appInit()
88
- }, [])
89
-
90
- return {
91
- loading: loading || !data?.permissions,
92
- data,
93
- }
94
- }
95
-
96
- 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
@@ -0,0 +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,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
+ }
@@ -1,80 +1,83 @@
1
- import React, { useEffect, useState } from 'react'
2
-
3
- export default function useFilters(initialState, key?: any) {
4
- const [filters, setFilters] = useState(initialState)
5
- const [filtersApplied, setFiltersApplied] = useState(false)
6
-
7
- useEffect(() => {
8
- const prevFilters = getSessionFilters()
9
- setFilters({
10
- ...filters,
11
- ...prevFilters,
12
- })
13
- }, [])
14
-
15
- function onFilterChange(modified) {
16
- setFilters({
17
- ...filters,
18
- ...modified,
19
- })
20
-
21
- const filterData = {
22
- ...filters,
23
- ...modified,
24
- }
25
-
26
- const sessionData = Object.keys(filterData).map((item, key) => {
27
- if (filtersCheck(item, filterData)) {
28
- return { key: item, value: filterData[item] }
29
- }
30
- })
31
-
32
- const filteredSessionArray = sessionData.filter(
33
- (value) => value !== undefined,
34
- )
35
-
36
- if (filteredSessionArray?.length > 0) {
37
- sessionStorage.setItem(key, JSON.stringify(filteredSessionArray))
38
- setFiltersApplied(true)
39
- }
40
- }
41
-
42
- function filtersCheck(item: any, filterData: any) {
43
- switch (true) {
44
- case !!filterData[item] &&
45
- item !== 'limit' &&
46
- item !== 'offset' &&
47
- item !== 'page':
48
- return true
49
- default:
50
- return false
51
- }
52
- }
53
-
54
- function clearFilters() {
55
- setFilters(initialState)
56
- setFiltersApplied(false)
57
- sessionStorage.removeItem(key)
58
- }
59
-
60
- const getSessionFilters = () => {
61
- try {
62
- if (sessionStorage.getItem(key)) {
63
- setFiltersApplied(true)
64
- const parsed = JSON.parse(sessionStorage.getItem(key))
65
- const filters = parsed?.reduce(
66
- (acc, curr) => ({ ...acc, [curr.key]: curr.value }),
67
- {},
68
- )
69
- return filters
70
- }
71
- } catch (error) {}
72
- }
73
-
74
- return {
75
- filters,
76
- onFilterChange,
77
- clearFilters,
78
- filtersApplied,
79
- }
80
- }
1
+ import React, { useEffect, useState } from 'react'
2
+
3
+ export default function useFilters(initialState, key?: any) {
4
+ const [filters, setFilters] = useState(initialState)
5
+ const [filtersApplied, setFiltersApplied] = useState(false)
6
+
7
+ useEffect(() => {
8
+ const prevFilters = getSessionFilters()
9
+ setFilters({
10
+ ...filters,
11
+ ...prevFilters,
12
+ })
13
+ }, [])
14
+
15
+ function onFilterChange(modified) {
16
+ setFilters((prev) => ({
17
+ ...prev,
18
+ ...modified,
19
+ }))
20
+
21
+ const filterData = {
22
+ ...filters,
23
+ ...modified,
24
+ }
25
+
26
+ const sessionData = Object.keys(filterData).map((item, key) => {
27
+ if (filtersCheck(item, filterData)) {
28
+ return { key: item, value: filterData[item] }
29
+ }
30
+ })
31
+
32
+ const filteredSessionArray = sessionData.filter(
33
+ (value) => value !== undefined,
34
+ )
35
+
36
+ if (filteredSessionArray?.length > 0) {
37
+ sessionStorage.setItem(key, JSON.stringify(filteredSessionArray))
38
+ setFiltersApplied(true)
39
+ } else {
40
+ sessionStorage.removeItem(key)
41
+ setFiltersApplied(false)
42
+ }
43
+ }
44
+
45
+ function filtersCheck(item: any, filterData: any) {
46
+ switch (true) {
47
+ case !!filterData[item] &&
48
+ item !== 'limit' &&
49
+ item !== 'offset' &&
50
+ item !== 'page':
51
+ return true
52
+ default:
53
+ return false
54
+ }
55
+ }
56
+
57
+ function clearFilters() {
58
+ setFilters(initialState)
59
+ setFiltersApplied(false)
60
+ sessionStorage.removeItem(key)
61
+ }
62
+
63
+ const getSessionFilters = () => {
64
+ try {
65
+ if (sessionStorage.getItem(key)) {
66
+ setFiltersApplied(true)
67
+ const parsed = JSON.parse(sessionStorage.getItem(key))
68
+ const filters = parsed?.reduce(
69
+ (acc, curr) => ({ ...acc, [curr.key]: curr.value }),
70
+ {},
71
+ )
72
+ return filters
73
+ }
74
+ } catch (error) {}
75
+ }
76
+
77
+ return {
78
+ filters,
79
+ onFilterChange,
80
+ clearFilters,
81
+ filtersApplied,
82
+ }
83
+ }
@@ -1,31 +1,31 @@
1
- import { useLocation, useMatch, useNavigate, useParams } from 'react-router-dom'
2
-
3
- const useHistory = () => {
4
- const navigate = useNavigate()
5
- const { pathname, search } = useLocation()
6
-
7
- return {
8
- push: navigate,
9
- location: {
10
- pathname: pathname,
11
- search: search,
12
- },
13
- }
14
- }
15
- const useRouteMatch = (path?) => {
16
- const { pathname } = useLocation()
17
- const params = useParams()
18
- const match = useMatch({ path, end: false })
19
- // console.log({
20
- // match,
21
- // params,
22
- // pathname,
23
- // })
24
- return {
25
- params: params,
26
- path: match?.pattern?.path,
27
- url: pathname,
28
- }
29
- }
30
-
31
- export { useHistory, useRouteMatch }
1
+ import { useLocation, useMatch, useNavigate, useParams } from 'react-router-dom'
2
+
3
+ const useHistory = () => {
4
+ const navigate = useNavigate()
5
+ const { pathname, search } = useLocation()
6
+
7
+ return {
8
+ push: navigate,
9
+ location: {
10
+ pathname: pathname,
11
+ search: search,
12
+ },
13
+ }
14
+ }
15
+ const useRouteMatch = (path?) => {
16
+ const { pathname } = useLocation()
17
+ const params = useParams()
18
+ const match = useMatch({ path, end: false })
19
+ // console.log({
20
+ // match,
21
+ // params,
22
+ // pathname,
23
+ // })
24
+ return {
25
+ params: params,
26
+ path: match?.pattern?.path,
27
+ url: pathname,
28
+ }
29
+ }
30
+
31
+ export { useHistory, useRouteMatch }