@campxdev/shared 1.8.5 → 1.8.6

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 (225) 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/Attachment.tsx +26 -26
  10. package/src/components/AutocompleteSearch/AutocompleteSearch.tsx +57 -57
  11. package/src/components/AutocompleteSearch/index.tsx +1 -1
  12. package/src/components/Breadcrumbs.tsx +72 -72
  13. package/src/components/Card.tsx +98 -98
  14. package/src/components/CardsGrid.tsx +28 -28
  15. package/src/components/ChangePassword.tsx +123 -123
  16. package/src/components/Chips.tsx +81 -81
  17. package/src/components/Detail.tsx +15 -15
  18. package/src/components/DetailsGrid.tsx +52 -52
  19. package/src/components/DividerHeading.tsx +41 -41
  20. package/src/components/DrawerWrapper/DialogWrapper.tsx +67 -67
  21. package/src/components/DrawerWrapper/DrawerTemplate.tsx +53 -53
  22. package/src/components/DrawerWrapper/DrawerWrapper.tsx +53 -53
  23. package/src/components/DropDownButton/AnchorElement.tsx +44 -44
  24. package/src/components/DropDownButton/DropDownButton.tsx +184 -184
  25. package/src/components/DropDownButton/DropdownMenuItem.tsx +110 -110
  26. package/src/components/DropDownButton/index.tsx +1 -1
  27. package/src/components/DropDownButton/styles.tsx +59 -59
  28. package/src/components/ErrorBoundary/ErrorBoundary.tsx +28 -28
  29. package/src/components/ErrorBoundary/ErrorFallback.tsx +236 -236
  30. package/src/components/ErrorBoundary/GlobalNetworkLoadingIndicator.tsx +13 -13
  31. package/src/components/ErrorBoundary/index.tsx +1 -1
  32. package/src/components/ErrorBox.tsx +42 -42
  33. package/src/components/ExcelToJsonInput/ExcelJsonUpload.tsx +50 -50
  34. package/src/components/ExcelToJsonInput/ExcelToJsonInput.tsx +57 -57
  35. package/src/components/ExcelToJsonInput/index.tsx +1 -1
  36. package/src/components/FilterComponents/FilterButton.tsx +56 -56
  37. package/src/components/FilterComponents/SearchBar.tsx +45 -45
  38. package/src/components/FloatingContainer.tsx +33 -33
  39. package/src/components/Form/Form.tsx +147 -147
  40. package/src/components/Form/RenderForm.tsx +189 -189
  41. package/src/components/FullScreenLoader.tsx +19 -19
  42. package/src/components/HookForm/AutoCompleteSearch.tsx +113 -113
  43. package/src/components/HookForm/DatePicker.tsx +40 -40
  44. package/src/components/HookForm/DateTimePicker.tsx +47 -47
  45. package/src/components/HookForm/FormLabel.tsx +14 -14
  46. package/src/components/HookForm/MultiCheckbox.tsx +69 -69
  47. package/src/components/HookForm/MultiSelect.tsx +53 -53
  48. package/src/components/HookForm/RadioGroup.tsx +47 -47
  49. package/src/components/HookForm/SingleCheckbox.tsx +34 -34
  50. package/src/components/HookForm/SingleSelect.tsx +46 -46
  51. package/src/components/HookForm/TextField.tsx +40 -40
  52. package/src/components/HookForm/TimePicker.tsx +40 -40
  53. package/src/components/HookForm/index.ts +23 -23
  54. package/src/components/IconButtons/IconButtons.tsx +137 -137
  55. package/src/components/IconButtons/Icons.tsx +268 -268
  56. package/src/components/IconButtons/assets/edit.svg +4 -4
  57. package/src/components/IconButtons/assets/eye.svg +6 -6
  58. package/src/components/IconButtons/assets/trash.svg +7 -7
  59. package/src/components/IconButtons/index.tsx +8 -8
  60. package/src/components/IconLabel.tsx +37 -37
  61. package/src/components/Image/Image.tsx +45 -45
  62. package/src/components/Image/index.tsx +1 -1
  63. package/src/components/ImageUpload.tsx +98 -98
  64. package/src/components/Input/AsyncSearchSelect/AsyncSearchSelect.tsx +216 -216
  65. package/src/components/Input/AsyncSearchSelect/index.tsx +1 -1
  66. package/src/components/Input/AsyncSearchSelect/styles.tsx +105 -105
  67. package/src/components/Input/AutoCompleteSearch.tsx +121 -121
  68. package/src/components/Input/DatePicker.tsx +76 -76
  69. package/src/components/Input/DateRangePicker.tsx +105 -105
  70. package/src/components/Input/DateTimePicker.tsx +84 -84
  71. package/src/components/Input/FormLabel.tsx +21 -21
  72. package/src/components/Input/MultiCheckbox.tsx +64 -64
  73. package/src/components/Input/MultiSelect.tsx +150 -150
  74. package/src/components/Input/RadioGroup.tsx +104 -104
  75. package/src/components/Input/SingleCheckbox.tsx +78 -78
  76. package/src/components/Input/SingleSelect.tsx +104 -104
  77. package/src/components/Input/TextField.tsx +46 -46
  78. package/src/components/Input/TimePicker.tsx +77 -77
  79. package/src/components/Input/index.ts +26 -26
  80. package/src/components/Input/types.ts +3 -3
  81. package/src/components/JsonPreview.tsx +7 -7
  82. package/src/components/LabelValue.tsx +21 -21
  83. package/src/components/Layout/ChangePassword.tsx +49 -49
  84. package/src/components/Layout/Header/AppHeader.tsx +112 -112
  85. package/src/components/Layout/Header/AppsMenu.tsx +105 -105
  86. package/src/components/Layout/Header/HeaderActions/CogWheelMenu.tsx +33 -33
  87. package/src/components/Layout/Header/HeaderActions/FreshDeskHelpButton.tsx +24 -24
  88. package/src/components/Layout/Header/HeaderActions/HeaderActions.tsx +18 -18
  89. package/src/components/Layout/Header/HeaderActions/UserBox.tsx +56 -56
  90. package/src/components/Layout/Header/Notification.tsx +13 -13
  91. package/src/components/Layout/Header/applications.ts +103 -103
  92. package/src/components/Layout/Header/assets/campx_square_small.svg +8 -8
  93. package/src/components/Layout/Header/assets/commutex.svg +14 -14
  94. package/src/components/Layout/Header/assets/commutexSmall.svg +11 -11
  95. package/src/components/Layout/Header/assets/enroll.svg +14 -14
  96. package/src/components/Layout/Header/assets/enrollx.svg +14 -14
  97. package/src/components/Layout/Header/assets/exams_small.svg +11 -11
  98. package/src/components/Layout/Header/assets/examsx.svg +14 -14
  99. package/src/components/Layout/Header/assets/hostel_small.svg +13 -13
  100. package/src/components/Layout/Header/assets/hostelx.svg +13 -13
  101. package/src/components/Layout/Header/assets/index.ts +35 -35
  102. package/src/components/Layout/Header/assets/libraryx.svg +12 -12
  103. package/src/components/Layout/Header/assets/pay_small.svg +15 -15
  104. package/src/components/Layout/Header/assets/payx.svg +19 -19
  105. package/src/components/Layout/Header/assets/people_small.svg +9 -9
  106. package/src/components/Layout/Header/assets/peoplex.svg +12 -12
  107. package/src/components/Layout/Header/assets/squarex.svg +12 -12
  108. package/src/components/Layout/Header/icons.tsx +57 -57
  109. package/src/components/Layout/Header/index.tsx +1 -1
  110. package/src/components/Layout/Header/styles.tsx +133 -133
  111. package/src/components/Layout/Helmet.tsx +49 -49
  112. package/src/components/Layout/LayoutWrapper.tsx +28 -28
  113. package/src/components/Layout/SideMenuHeader.tsx +29 -29
  114. package/src/components/Layout/SideNav.tsx +168 -168
  115. package/src/components/Layout/Tickets/HelpWidget/HelpWidget.tsx +273 -273
  116. package/src/components/Layout/Tickets/HelpWidget/styles.tsx +94 -94
  117. package/src/components/Layout/Tickets/MyTickets.tsx +72 -72
  118. package/src/components/Layout/Tickets/TicketDetails.tsx +65 -65
  119. package/src/components/Layout/Tickets/TimeLine.tsx +64 -64
  120. package/src/components/Layout/Tickets/index.tsx +1 -1
  121. package/src/components/Layout/Tickets/services.ts +11 -11
  122. package/src/components/Layout/Tickets/styles.tsx +136 -136
  123. package/src/components/LinearProgress.tsx +19 -19
  124. package/src/components/ListItemButton.tsx +95 -95
  125. package/src/components/LoginForm.tsx +279 -279
  126. package/src/components/MediaRow/MediaRow.tsx +67 -67
  127. package/src/components/MediaRow/index.tsx +1 -1
  128. package/src/components/ModalButtons/DialogButton.tsx +126 -126
  129. package/src/components/ModalButtons/DrawerButton.tsx +115 -115
  130. package/src/components/ModalButtons/index.tsx +4 -4
  131. package/src/components/NoDataIllustration.tsx +32 -32
  132. package/src/components/PageContent.tsx +12 -12
  133. package/src/components/PageHeader.tsx +55 -55
  134. package/src/components/PageNotFound.tsx +26 -26
  135. package/src/components/PopupConfirm/ConfirmContextProvider.tsx +40 -40
  136. package/src/components/PopupConfirm/PopupConfirm.tsx +67 -67
  137. package/src/components/PopupConfirm/index.tsx +1 -1
  138. package/src/components/PopupConfirm/useConfirm.ts +47 -47
  139. package/src/components/ResetPassword.tsx +107 -107
  140. package/src/components/Row.tsx +24 -24
  141. package/src/components/Spinner.tsx +18 -18
  142. package/src/components/StepsHeader/StepsHeader.tsx +115 -115
  143. package/src/components/StepsHeader/index.tsx +1 -1
  144. package/src/components/StyledTableContainer.tsx +33 -33
  145. package/src/components/SwitchButton.tsx +41 -41
  146. package/src/components/Table.tsx +42 -42
  147. package/src/components/Tables/BasicTable/Table.tsx +198 -198
  148. package/src/components/Tables/BasicTable/TableFooter.tsx +86 -86
  149. package/src/components/Tables/BasicTable/index.tsx +1 -1
  150. package/src/components/Tables/ReactTable/BatchActionsHeader.tsx +58 -58
  151. package/src/components/Tables/ReactTable/ReactTable.tsx +295 -295
  152. package/src/components/Tables/ReactTable/RenderTableBody.tsx +49 -49
  153. package/src/components/Tables/ReactTable/index.tsx +1 -1
  154. package/src/components/Tables/ReactTable/react-table-config.d.ts +128 -128
  155. package/src/components/Tables/common/NoRecordsFound.tsx +27 -27
  156. package/src/components/Tables/common/TableStats.tsx +22 -22
  157. package/src/components/Tables/common/icons.tsx +50 -50
  158. package/src/components/Tables/common/styles.tsx +170 -170
  159. package/src/components/Tables/common/types.ts +57 -57
  160. package/src/components/Tabs/NavigationTabs.tsx +80 -80
  161. package/src/components/Tabs/Tabs.tsx +53 -53
  162. package/src/components/Tabs/TabsContainer.tsx +50 -50
  163. package/src/components/Tabs/index.tsx +1 -1
  164. package/src/components/Tabs/styles.tsx +55 -55
  165. package/src/components/ToastContainer/ToastContainer.tsx +57 -57
  166. package/src/components/ToastContainer/index.tsx +1 -1
  167. package/src/components/UploadButton/UploadButton.tsx +126 -126
  168. package/src/components/UploadButton/index.tsx +1 -1
  169. package/src/components/UploadButton/types.ts +19 -19
  170. package/src/components/UploadDocument.tsx +108 -108
  171. package/src/components/UploadFileDialog/UploadFileDialog.tsx +238 -238
  172. package/src/components/UploadFileDialog/index.tsx +1 -1
  173. package/src/components/index.ts +106 -106
  174. package/src/config/axios.ts +73 -73
  175. package/src/config/axiosEvaluator.ts +53 -53
  176. package/src/config/axiosXTenant.ts +57 -57
  177. package/src/constants/UIConstants.ts +97 -97
  178. package/src/constants/formValidations.ts +6 -6
  179. package/src/constants/index.ts +5 -5
  180. package/src/constants/isDevelopment.ts +4 -4
  181. package/src/constants/permissions.ts +67 -67
  182. package/src/constants/validateMessages.ts +12 -12
  183. package/src/contexts/LoginFormProvider.tsx +44 -44
  184. package/src/contexts/Providers.tsx +50 -50
  185. package/src/contexts/PublicProviders.tsx +30 -30
  186. package/src/contexts/QueryClientProvider.tsx +22 -22
  187. package/src/hooks/index.ts +4 -4
  188. package/src/hooks/useAuth.ts +96 -96
  189. package/src/hooks/useFetch.ts +53 -53
  190. package/src/hooks/useFilters.ts +83 -80
  191. package/src/hooks/useRouter.ts +31 -31
  192. package/src/layouts/Components/DashBoardMenu.tsx +232 -232
  193. package/src/layouts/Components/icons/index.tsx +403 -403
  194. package/src/layouts/Components/styles.tsx +74 -74
  195. package/src/layouts/ComponentsLayout.tsx +3 -3
  196. package/src/permissions/PageWithPermission.tsx +18 -18
  197. package/src/permissions/PermissionDeniedPage.tsx +16 -16
  198. package/src/permissions/ValidateAccess.tsx +18 -18
  199. package/src/permissions/index.ts +2 -2
  200. package/src/react-app-env.d.ts +1 -1
  201. package/src/shared-state/AssetsStore.ts +15 -15
  202. package/src/shared-state/PermissionsStore.ts +356 -356
  203. package/src/shared-state/UserStore.ts +13 -13
  204. package/src/shared-state/index.ts +4 -4
  205. package/src/theme/App.less +3 -3
  206. package/src/theme/MuiThemeProvider.tsx +18 -18
  207. package/src/theme/customCssBaseline.ts +135 -135
  208. package/src/theme/index.css +28 -28
  209. package/src/theme/muiTheme.ts +595 -595
  210. package/src/theme/theme.d.ts +75 -75
  211. package/src/utils/adminAxios.ts +15 -15
  212. package/src/utils/alphabet.ts +23 -23
  213. package/src/utils/arrayPadEnd.ts +3 -3
  214. package/src/utils/formatCurrency.ts +9 -9
  215. package/src/utils/getUrlParams.ts +5 -5
  216. package/src/utils/index.ts +7 -7
  217. package/src/utils/logout.ts +25 -25
  218. package/src/utils/ordinalSuffixOf.ts +14 -14
  219. package/src/utils/romanize.ts +40 -40
  220. package/src/utils/withRouteWrapper.tsx +25 -25
  221. package/src/utils/withSuspense.tsx +6 -6
  222. package/styled-components.tsx +60 -60
  223. package/tsconfig.json +21 -21
  224. package/yarn-error.log +109 -0
  225. 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,4 @@
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'
@@ -1,96 +1,96 @@
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 { 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,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({
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
+ } 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 }