@campxdev/shared 1.0.4 → 1.1.0

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 (220) hide show
  1. package/.eslintignore +3 -3
  2. package/.eslintrc.js +33 -33
  3. package/.prettierrc +10 -10
  4. package/antd.customize.less +73 -73
  5. package/exports.ts +17 -17
  6. package/package.json +82 -82
  7. package/publish.sh +1 -1
  8. package/src/assets/fonts/avenir/index.ts +2 -2
  9. package/src/assets/fonts/poppins/index.ts +7 -7
  10. package/src/assets/images/index.ts +17 -17
  11. package/src/assets/images/unauth.svg +92 -92
  12. package/src/components/ActionButton.tsx +28 -28
  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 +164 -164
  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.tsx +194 -194
  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/FloatingContainer.tsx +33 -33
  34. package/src/components/Form/Form.tsx +156 -156
  35. package/src/components/Form/RenderForm.tsx +188 -188
  36. package/src/components/FullCalendar/Actions.tsx +162 -162
  37. package/src/components/FullCalendar/FullCalendarWrapper.tsx +54 -54
  38. package/src/components/FullScreenLoader.tsx +19 -19
  39. package/src/components/HookForm/AutoCompleteSearch.tsx +113 -113
  40. package/src/components/HookForm/DatePicker.tsx +65 -65
  41. package/src/components/HookForm/DateTimePicker.tsx +70 -70
  42. package/src/components/HookForm/FormLabel.tsx +14 -14
  43. package/src/components/HookForm/MultiCheckbox.tsx +82 -82
  44. package/src/components/HookForm/MultiSelect.tsx +100 -100
  45. package/src/components/HookForm/RadioGroup.tsx +106 -106
  46. package/src/components/HookForm/SingleCheckbox.tsx +46 -46
  47. package/src/components/HookForm/SingleSelect.tsx +94 -94
  48. package/src/components/HookForm/TextField.tsx +74 -74
  49. package/src/components/HookForm/TimePicker.tsx +82 -82
  50. package/src/components/HookForm/index.ts +23 -23
  51. package/src/components/IconButtons/IconButtons.tsx +137 -137
  52. package/src/components/IconButtons/Icons.tsx +268 -268
  53. package/src/components/IconButtons/assets/edit.svg +4 -4
  54. package/src/components/IconButtons/assets/eye.svg +6 -6
  55. package/src/components/IconButtons/assets/trash.svg +7 -7
  56. package/src/components/IconButtons/index.tsx +8 -8
  57. package/src/components/IconLabel.tsx +37 -37
  58. package/src/components/Image/Image.tsx +43 -43
  59. package/src/components/Image/index.tsx +1 -1
  60. package/src/components/ImageUpload.tsx +98 -98
  61. package/src/components/Input/AutoCompleteSearch.tsx +113 -113
  62. package/src/components/Input/DatePicker.tsx +60 -60
  63. package/src/components/Input/DateRangePicker.tsx +131 -131
  64. package/src/components/Input/DateTimePicker.tsx +70 -70
  65. package/src/components/Input/FormLabel.tsx +14 -14
  66. package/src/components/Input/MultiCheckbox.tsx +79 -79
  67. package/src/components/Input/MultiSelect.tsx +52 -52
  68. package/src/components/Input/RadioGroup.tsx +61 -61
  69. package/src/components/Input/SingleCheckbox.tsx +23 -23
  70. package/src/components/Input/SingleSelect.tsx +126 -126
  71. package/src/components/Input/TextField.tsx +50 -50
  72. package/src/components/Input/TimePicker.tsx +82 -82
  73. package/src/components/Input/index.ts +26 -26
  74. package/src/components/JsonPreview/JsonPreview.tsx +7 -7
  75. package/src/components/JsonPreview/index.tsx +1 -1
  76. package/src/components/LabelValue/LabelValue.tsx +21 -21
  77. package/src/components/LabelValue/index.tsx +1 -1
  78. package/src/components/Layout/ChangePassword.tsx +49 -49
  79. package/src/components/Layout/Header/AppHeader.tsx +124 -124
  80. package/src/components/Layout/Header/AppsMenu.tsx +92 -92
  81. package/src/components/Layout/Header/CogWheelMenu.tsx +33 -33
  82. package/src/components/Layout/Header/HelpWidget/HelpWidget.tsx +298 -298
  83. package/src/components/Layout/Header/HelpWidget/styles.tsx +94 -92
  84. package/src/components/Layout/Header/Notification.tsx +13 -13
  85. package/src/components/Layout/Header/UserBox.tsx +90 -90
  86. package/src/components/Layout/Header/applications.ts +90 -90
  87. package/src/components/Layout/Header/assets/campx_square_small.svg +9 -9
  88. package/src/components/Layout/Header/assets/commutex.svg +14 -14
  89. package/src/components/Layout/Header/assets/commutexSmall.svg +11 -11
  90. package/src/components/Layout/Header/assets/enroll.svg +14 -14
  91. package/src/components/Layout/Header/assets/enrollx.svg +14 -14
  92. package/src/components/Layout/Header/assets/exams_small.svg +12 -12
  93. package/src/components/Layout/Header/assets/examsx.svg +14 -14
  94. package/src/components/Layout/Header/assets/hostel_small.svg +13 -13
  95. package/src/components/Layout/Header/assets/hostelx.svg +13 -13
  96. package/src/components/Layout/Header/assets/index.ts +33 -33
  97. package/src/components/Layout/Header/assets/libraryx.svg +12 -12
  98. package/src/components/Layout/Header/assets/pay_small.svg +16 -16
  99. package/src/components/Layout/Header/assets/payx.svg +19 -19
  100. package/src/components/Layout/Header/assets/people_small.svg +9 -9
  101. package/src/components/Layout/Header/assets/peoplex.svg +12 -12
  102. package/src/components/Layout/Header/assets/squarex.svg +12 -12
  103. package/src/components/Layout/Header/icons.tsx +57 -57
  104. package/src/components/Layout/Header/index.tsx +1 -1
  105. package/src/components/Layout/Header/styles.tsx +98 -98
  106. package/src/components/Layout/Tickets/MyTickets.tsx +74 -74
  107. package/src/components/Layout/Tickets/Services.tsx +6 -6
  108. package/src/components/Layout/Tickets/TicketDetails.tsx +66 -66
  109. package/src/components/Layout/Tickets/TimeLine.tsx +64 -64
  110. package/src/components/Layout/Tickets/index.tsx +1 -1
  111. package/src/components/Layout/Tickets/styles.tsx +136 -136
  112. package/src/components/LayoutWrapper.tsx +25 -25
  113. package/src/components/LinearProgress.tsx +19 -19
  114. package/src/components/ListItemButton.tsx +95 -95
  115. package/src/components/LoginForm.tsx +105 -103
  116. package/src/components/MediaRow/MediaRow.tsx +69 -69
  117. package/src/components/MediaRow/index.tsx +1 -1
  118. package/src/components/MenuButton.tsx +103 -103
  119. package/src/components/ModalButtons/DialogButton.tsx +88 -88
  120. package/src/components/ModalButtons/DrawerButton.tsx +89 -89
  121. package/src/components/ModalButtons/index.tsx +4 -4
  122. package/src/components/NoDataIllustration/NoDataIllustration.tsx +32 -32
  123. package/src/components/NoDataIllustration/index.tsx +1 -1
  124. package/src/components/PageContent.tsx +17 -17
  125. package/src/components/PageHeader.tsx +52 -52
  126. package/src/components/PageNotFound.tsx +26 -26
  127. package/src/components/PopupConfirm/ConfirmContextProvider.tsx +40 -40
  128. package/src/components/PopupConfirm/PopupConfirm.tsx +34 -34
  129. package/src/components/PopupConfirm/index.tsx +1 -1
  130. package/src/components/PopupConfirm/useConfirm.ts +47 -47
  131. package/src/components/Router.tsx +7 -7
  132. package/src/components/Row/Row.tsx +24 -24
  133. package/src/components/Row/index.tsx +1 -1
  134. package/src/components/SearchBar/SearchBar.tsx +53 -53
  135. package/src/components/SearchBar/index.tsx +1 -1
  136. package/src/components/SideMenuHeader.tsx +29 -29
  137. package/src/components/SideNav.tsx +168 -168
  138. package/src/components/Spinner.tsx +18 -18
  139. package/src/components/StepsHeader/StepsHeader.tsx +115 -115
  140. package/src/components/StepsHeader/index.tsx +1 -1
  141. package/src/components/StyledTableContainer.tsx +33 -33
  142. package/src/components/SwitchButton/SwitchButton.tsx +41 -41
  143. package/src/components/SwitchButton/index.tsx +1 -1
  144. package/src/components/Table.tsx +42 -42
  145. package/src/components/TableComponent/BatchActionsHeader.tsx +58 -58
  146. package/src/components/TableComponent/Icons/index.tsx +50 -50
  147. package/src/components/TableComponent/ReactTable.tsx +293 -293
  148. package/src/components/TableComponent/RenderTableBody.tsx +64 -64
  149. package/src/components/TableComponent/TableFooter/TableFooter.tsx +102 -102
  150. package/src/components/TableComponent/TableFooter/index.tsx +1 -1
  151. package/src/components/TableComponent/TableFooter/styles.tsx +28 -28
  152. package/src/components/TableComponent/index.tsx +226 -226
  153. package/src/components/TableComponent/react-table-config.d.ts +128 -128
  154. package/src/components/TableComponent/styles.tsx +173 -173
  155. package/src/components/TableComponent/types.ts +57 -57
  156. package/src/components/Tabs/Tabs.tsx +52 -52
  157. package/src/components/Tabs/TabsContainer.tsx +50 -50
  158. package/src/components/Tabs/index.tsx +1 -1
  159. package/src/components/Tabs/styles.tsx +55 -55
  160. package/src/components/ToastContainer/ToastContainer.tsx +42 -42
  161. package/src/components/ToastContainer/index.tsx +1 -1
  162. package/src/components/UploadButton/UploadButton.tsx +126 -126
  163. package/src/components/UploadButton/index.tsx +1 -1
  164. package/src/components/UploadButton/types.ts +19 -19
  165. package/src/components/UploadDocument/UploadDocument.tsx +108 -108
  166. package/src/components/UploadDocument/index.tsx +1 -1
  167. package/src/components/UploadFileDialog/UploadFileDialog.tsx +238 -238
  168. package/src/components/UploadFileDialog/index.tsx +1 -1
  169. package/src/components/index.ts +86 -86
  170. package/src/config/axios.ts +74 -74
  171. package/src/config/axiosXTenant.ts +57 -57
  172. package/src/constants/UIConstants.ts +97 -97
  173. package/src/constants/formValidations.ts +6 -6
  174. package/src/constants/index.ts +5 -5
  175. package/src/constants/isDevelopment.ts +3 -3
  176. package/src/constants/permissions.ts +67 -67
  177. package/src/constants/validateMessages.ts +12 -12
  178. package/src/contexts/LoginFormProvider.tsx +39 -39
  179. package/src/contexts/Providers.tsx +60 -59
  180. package/src/contexts/PublicProviders.tsx +30 -30
  181. package/src/contexts/QueryClientProvider.tsx +22 -22
  182. package/src/hooks/index.ts +3 -3
  183. package/src/hooks/useAppInit.ts +33 -33
  184. package/src/hooks/useAuth.ts +96 -92
  185. package/src/hooks/useFetch.ts +53 -53
  186. package/src/hooks/useRouter.ts +31 -31
  187. package/src/layouts/Components/DashBoardMenu.tsx +232 -232
  188. package/src/layouts/Components/icons/index.tsx +403 -403
  189. package/src/layouts/Components/styles.tsx +60 -60
  190. package/src/layouts/ComponentsLayout.tsx +3 -3
  191. package/src/permissions/PageWithPermission.tsx +18 -18
  192. package/src/permissions/PermissionDeniedPage.tsx +16 -16
  193. package/src/permissions/ValidateAccess.tsx +18 -18
  194. package/src/permissions/index.ts +2 -3
  195. package/src/react-app-env.d.ts +1 -1
  196. package/src/shared-state/AssetsStore.ts +15 -15
  197. package/src/{permissions → shared-state}/PermissionsStore.ts +352 -352
  198. package/src/shared-state/UserStore.ts +13 -13
  199. package/src/shared-state/index.ts +4 -3
  200. package/src/theme/App.less +3 -3
  201. package/src/theme/MuiThemeProvider.tsx +13 -13
  202. package/src/theme/customCssBaseline.ts +78 -78
  203. package/src/theme/index.css +75 -75
  204. package/src/theme/muiTheme.ts +490 -490
  205. package/src/theme/theme.d.ts +75 -75
  206. package/src/utils/alphabet.ts +23 -23
  207. package/src/utils/arrayPadEnd.ts +3 -3
  208. package/src/utils/formatCurrency.ts +9 -9
  209. package/src/utils/getUrlParams.ts +5 -5
  210. package/src/utils/index.ts +8 -8
  211. package/src/utils/logout.ts +24 -24
  212. package/src/utils/ordinalSuffixOf.ts +14 -14
  213. package/src/utils/romanize.ts +40 -40
  214. package/src/utils/withLocalization.tsx +11 -11
  215. package/src/utils/withRouteWrapper.tsx +25 -25
  216. package/src/utils/withSuspense.tsx +6 -6
  217. package/styled-components.tsx +60 -60
  218. package/todo.md +20 -20
  219. package/tsconfig.json +21 -21
  220. package/src/components/Layout/Header/assets/commuteX.png +0 -0
@@ -1,490 +1,490 @@
1
- import { alpha, darken, lighten } from '@mui/material'
2
- import { red } from '@mui/material/colors'
3
- import { createTheme } from '@mui/material/styles'
4
- import { customCssBaseline } from './customCssBaseline'
5
-
6
- const borderRadius = {
7
- small: '5px',
8
- large: '10px',
9
- }
10
-
11
- const PRIMARY_FONT = 'Avenir'
12
- const SECONDARY_FONT = 'Poppins'
13
-
14
- const themeColors = {
15
- primary: '#1E19F5',
16
- secondary: '#121212',
17
- secondaryLight: '#1212121A',
18
- success: '#57CA22',
19
- warning: '#FFA319',
20
- error: '#BC2C3D',
21
- info: '#33C2FF',
22
- black: '#223354',
23
- white: '#ffffff',
24
- primaryAlt: '#000C57',
25
- yellow: '#FFAF20',
26
- green: '#99C15B',
27
- grayLight: '#F2F2F2',
28
- pureBlack: '#000000',
29
- pureWhite: '#ffffff',
30
- secondaryDark: '#EFEFEF',
31
- offsetBlue: '#149ECD',
32
- }
33
-
34
- const colors = {
35
- primary: {
36
- main: themeColors.primary,
37
- light: alpha(themeColors.primary, 0.5),
38
- lighter: alpha(themeColors.primary, 0.1),
39
- },
40
- secondary: {
41
- main: themeColors.secondary,
42
- light: themeColors.grayLight,
43
- lighter: themeColors.secondaryLight,
44
- dark: themeColors.secondaryDark,
45
- },
46
- common: {
47
- green: themeColors.green,
48
- yellow: themeColors.yellow,
49
- black: themeColors.pureBlack,
50
- white: themeColors.pureWhite,
51
- blue: themeColors.offsetBlue,
52
- },
53
- error: {
54
- lighter: alpha(themeColors.error, 0.1),
55
- light: lighten(themeColors.error, 0.3),
56
- main: themeColors.error,
57
- dark: darken(themeColors.error, 0.2),
58
- },
59
- }
60
-
61
- const borders = {
62
- primary: `1px solid ${themeColors.primary}`,
63
- grayLight: `1px solid ${themeColors.secondaryLight}`,
64
- }
65
-
66
- // A custom theme for this app
67
- const muiTheme = createTheme({
68
- typography: {
69
- fontFamily: ['Poppins', 'Avenir', 'sans-serif'].join(','),
70
- },
71
- borders: {
72
- ...borders,
73
- },
74
- palette: {
75
- primary: {
76
- dark: '#1E19F5',
77
- main: colors.primary.main,
78
- light: colors.primary.light,
79
- lighter: colors.primary.lighter,
80
- },
81
- secondary: {
82
- main: '#121212',
83
- light: colors.secondary.light,
84
- dark: themeColors.secondaryDark,
85
- lighter: themeColors.secondaryLight,
86
- },
87
- common: {
88
- green: themeColors.green,
89
- yellow: themeColors.yellow,
90
- blue: themeColors.offsetBlue,
91
- },
92
- error: {
93
- main: red.A400,
94
- },
95
- text: {
96
- primary: '#121212',
97
- secondary: '#959595',
98
- disabled: '#12121280',
99
- },
100
- },
101
- components: {
102
- MuiTypography: {
103
- styleOverrides: {
104
- root: {
105
- color: '#121212',
106
- fontSize: '14px',
107
- fontWeight: 500,
108
- fontFamily: PRIMARY_FONT,
109
- },
110
- h1: {
111
- fontSize: '18px',
112
- fontWeight: 600,
113
- fontFamily: SECONDARY_FONT,
114
- },
115
- h3: {
116
- fontSize: '16px',
117
- fontWeight: 600,
118
- fontFamily: SECONDARY_FONT,
119
- },
120
- h5: {
121
- fontSize: '14px',
122
- fontWeight: 500,
123
- fontFamily: SECONDARY_FONT,
124
- },
125
- h6: {
126
- fontSize: '15px',
127
- fontWeight: 600,
128
- fontFamily: SECONDARY_FONT,
129
- },
130
- paragraph: {
131
- fontSize: '16px',
132
- marginBottom: 0,
133
- },
134
- body2: {
135
- fontWeight: 600,
136
- },
137
- subtitle1: {
138
- fontSize: '12px',
139
- fontWeight: 400,
140
- color: '#959595',
141
- },
142
- subtitle2: {
143
- fontSize: '13px',
144
- fontWeight: 400,
145
- color: '#959595',
146
- },
147
- },
148
- },
149
- MuiButton: {
150
- defaultProps: {
151
- variant: 'contained',
152
- disableRipple: true,
153
- disableElevation: true,
154
- disableFocusRipple: true,
155
- disableTouchRipple: true,
156
- },
157
- styleOverrides: {
158
- root: {
159
- fontFamily: SECONDARY_FONT,
160
- height: '40px',
161
- padding: '10px 36px',
162
- textTransform: 'capitalize',
163
- fontWeight: 600,
164
- borderRadius: borderRadius.small,
165
- '&.MuiButton-sizeSmall': {
166
- padding: '6px 8px',
167
- height: '32px',
168
- fontSize: '13px',
169
- },
170
- },
171
- },
172
- },
173
- MuiButtonBase: {
174
- defaultProps: {
175
- disableRipple: true,
176
- },
177
- styleOverrides: {
178
- root: {
179
- fontFamily: SECONDARY_FONT,
180
- '&.MuiButton-textSizeSmall': {
181
- padding: '6px 8px',
182
- height: '32px',
183
- },
184
- },
185
- },
186
- },
187
- MuiOutlinedInput: {
188
- styleOverrides: {
189
- root: {
190
- fontSize: '14px',
191
- minHeight: '50px',
192
- borderRadius: borderRadius.large,
193
- '&.MuiInputBase-sizeSmall': {
194
- minHeight: '30px',
195
- },
196
- '& .MuiInputAdornment-positionEnd.MuiInputAdornment-outlined': {
197
- paddingRight: 2,
198
- },
199
- '& .MuiOutlinedInput-notchedOutline': {
200
- borderColor: alpha(colors.common.black, 0.15),
201
- '& legend': {
202
- '& > span': {
203
- paddingRight: 2,
204
- },
205
- },
206
- },
207
- '&:hover .MuiOutlinedInput-notchedOutline': {
208
- borderColor: alpha(colors.common.black, 0.3),
209
- },
210
- '&.Mui-focused .MuiOutlinedInput-notchedOutline': {
211
- borderColor: colors.primary.main,
212
- borderWidth: '0.5px',
213
- '& :hover': {
214
- borderColor: colors.primary.main,
215
- borderWidth: '0.5px',
216
- },
217
- },
218
- },
219
- },
220
- },
221
- MuiAutocomplete: {
222
- styleOverrides: {
223
- tag: {
224
- margin: 1,
225
- },
226
- root: {
227
- '.MuiAutocomplete-inputRoot.MuiOutlinedInput-root .MuiAutocomplete-endAdornment':
228
- {
229
- right: 14,
230
- },
231
- '& .MuiAutocomplete-tag': {
232
- border: '1px solid #D1D1D1',
233
- background: '#F8F8F8',
234
- borderRadius: '5px',
235
- height: '38px',
236
- '& .MuiSvgIcon-root': {
237
- fontSize: '15px',
238
- marginLeft: '5px',
239
- fontWeight: 700,
240
- color: colors.secondary.main,
241
- '&:hover': {
242
- color: alpha(colors.secondary.main, 0.8),
243
- },
244
- },
245
- },
246
- '& .MuiInputBase-root': {
247
- padding: '5px',
248
- },
249
- },
250
- clearIndicator: {
251
- background: colors.error.lighter,
252
- borderRadius: '5px',
253
- color: colors.error.main,
254
- marginRight: 8,
255
-
256
- '&:hover': {
257
- background: colors.error.lighter,
258
- color: colors.error.dark,
259
- },
260
- },
261
- popupIndicator: {
262
- color: alpha(colors.common.black, 0.5),
263
-
264
- '&:hover': {
265
- background: colors.primary.lighter,
266
- color: colors.primary.main,
267
- },
268
- },
269
- },
270
- },
271
- MuiSwitch: {
272
- styleOverrides: {
273
- root: {
274
- height: '20px',
275
- padding: 0,
276
- '& .MuiSwitch-switchBase': {
277
- padding: 0,
278
- transitionDuration: '300ms',
279
- '&.Mui-checked': {
280
- color: colors.common.green,
281
- '& .MuiSwitch-thumb': {
282
- marginLeft: '0px',
283
- },
284
- '& + .MuiSwitch-track': {
285
- opacity: '1',
286
- border: `0.5px solid ${colors.common.green}`,
287
- background: '#EDEDED 0% 0% no-repeat padding-box',
288
- },
289
- '&.Mui-disabled + .MuiSwitch-track': {
290
- opacity: 0.5,
291
- },
292
- },
293
- '&.Mui-disabled .MuiSwitch-thumb': {
294
- color: colors.common.green,
295
- opacity: '0.5',
296
- },
297
- },
298
- '& .MuiSwitch-thumb': {
299
- width: '18px',
300
- height: '16px',
301
- borderRadius: '5px',
302
- marginTop: '2px',
303
- boxShadow: 'none',
304
- marginLeft: '2px',
305
- },
306
- '& .MuiSwitch-track': {
307
- borderRadius: '5px',
308
- width: '40px',
309
- height: '20px',
310
- backgroundColor: '#EDEDED',
311
- paddingLeft: '12px',
312
- opacity: '1',
313
- },
314
- },
315
- },
316
- },
317
- MuiMenu: {
318
- styleOverrides: {
319
- paper: {
320
- '&::-webkit-scrollbar': {
321
- width: '0.5em',
322
- height: '0.5em',
323
- },
324
-
325
- '&::-webkit-scrollbar-thumb': {
326
- backgroundColor: 'rgba(0, 0, 0, 0.15)',
327
- borderRadius: '3px',
328
-
329
- '&:hover': {
330
- background: 'rgba(0, 0, 0, 0.2)',
331
- },
332
- },
333
- },
334
- },
335
- },
336
- MuiIconButton: {
337
- defaultProps: {
338
- disableRipple: true,
339
- disableFocusRipple: true,
340
- disableTouchRipple: true,
341
- size: 'small',
342
- },
343
- styleOverrides: {
344
- root: {
345
- borderRadius: '10px',
346
- },
347
- },
348
- },
349
- MuiFormLabel: {
350
- styleOverrides: {
351
- root: {
352
- fontSize: '14px',
353
- color: '#959595',
354
- },
355
- },
356
- },
357
- MuiTextField: {
358
- defaultProps: {
359
- variant: 'outlined',
360
- color: 'primary',
361
- fullWidth: true,
362
- },
363
- },
364
- MuiTable: {
365
- styleOverrides: {
366
- root: {
367
- border: borders.grayLight,
368
- fontFamily: PRIMARY_FONT,
369
- fontSize: '14px',
370
- fontWeight: 600,
371
- },
372
- },
373
- },
374
- MuiTableHead: {
375
- styleOverrides: {
376
- root: {
377
- backgroundColor: themeColors.grayLight,
378
- '& th': {
379
- lineHeight: '20px',
380
- fontSize: '14px',
381
- fontWeight: 600,
382
- fontFamily: SECONDARY_FONT,
383
- },
384
- },
385
- },
386
- },
387
- MuiTableCell: {
388
- styleOverrides: {
389
- root: {
390
- lineHeight: '20px',
391
- padding: '15px',
392
- fontWeight: 600,
393
- fontFamily: PRIMARY_FONT,
394
- fontSize: '14px',
395
- '& .MuiCheckbox-root': {
396
- padding: 0,
397
- },
398
- },
399
- },
400
- },
401
- MuiCard: {
402
- styleOverrides: {
403
- root: {
404
- border: borders.grayLight,
405
- boxShadow: 'none',
406
- borderRadius: '10px',
407
- '&.MuiPaper-root': {
408
- height: 'fit-content',
409
- },
410
- },
411
- },
412
- },
413
- MuiCardHeader: {
414
- styleOverrides: {
415
- root: {
416
- padding: '20px',
417
- '& .MuiCardHeader-title': {
418
- fontSize: '15px',
419
- fontFamily: SECONDARY_FONT,
420
- fontWeight: 500,
421
- },
422
- '& .MuiTypography-root.MuiCardHeader-subheader': {
423
- marginTop: '3px',
424
- fontSize: '13px',
425
- fontFamily: PRIMARY_FONT,
426
- fontWeight: 400,
427
- },
428
- },
429
- },
430
- },
431
- MuiCardContent: {
432
- styleOverrides: {
433
- root: {
434
- padding: '20px',
435
- paddingTop: 0,
436
- },
437
- },
438
- },
439
- MuiCardActions: {
440
- styleOverrides: {
441
- root: {
442
- padding: 0,
443
- },
444
- },
445
- },
446
- MuiFormHelperText: {
447
- styleOverrides: {
448
- root: {
449
- fontFamily: PRIMARY_FONT,
450
- fontSize: '12px',
451
- color: themeColors.error,
452
- marginLeft: '2px',
453
- marginRight: '2px',
454
- },
455
- },
456
- },
457
- MuiChip: {
458
- styleOverrides: {
459
- root: {
460
- fontFamily: SECONDARY_FONT,
461
- fontSize: '14px',
462
- },
463
- },
464
- },
465
- MuiListItemButton: {
466
- styleOverrides: {
467
- root: {
468
- fontFamily: SECONDARY_FONT,
469
- fontSize: '14px',
470
- '& .MuiListItemText-primary.MuiTypography-root': {
471
- fontFamily: SECONDARY_FONT,
472
- },
473
- },
474
- },
475
- },
476
- MuiRadio: {
477
- defaultProps: {
478
- size: 'small',
479
- },
480
- styleOverrides: {
481
- root: {},
482
- },
483
- },
484
- MuiCssBaseline: {
485
- styleOverrides: customCssBaseline,
486
- },
487
- },
488
- })
489
-
490
- export default muiTheme
1
+ import { alpha, darken, lighten } from '@mui/material'
2
+ import { red } from '@mui/material/colors'
3
+ import { createTheme } from '@mui/material/styles'
4
+ import { customCssBaseline } from './customCssBaseline'
5
+
6
+ const borderRadius = {
7
+ small: '5px',
8
+ large: '10px',
9
+ }
10
+
11
+ const PRIMARY_FONT = 'Avenir'
12
+ const SECONDARY_FONT = 'Poppins'
13
+
14
+ const themeColors = {
15
+ primary: '#1E19F5',
16
+ secondary: '#121212',
17
+ secondaryLight: '#1212121A',
18
+ success: '#57CA22',
19
+ warning: '#FFA319',
20
+ error: '#BC2C3D',
21
+ info: '#33C2FF',
22
+ black: '#223354',
23
+ white: '#ffffff',
24
+ primaryAlt: '#000C57',
25
+ yellow: '#FFAF20',
26
+ green: '#99C15B',
27
+ grayLight: '#F2F2F2',
28
+ pureBlack: '#000000',
29
+ pureWhite: '#ffffff',
30
+ secondaryDark: '#EFEFEF',
31
+ offsetBlue: '#149ECD',
32
+ }
33
+
34
+ const colors = {
35
+ primary: {
36
+ main: themeColors.primary,
37
+ light: alpha(themeColors.primary, 0.5),
38
+ lighter: alpha(themeColors.primary, 0.1),
39
+ },
40
+ secondary: {
41
+ main: themeColors.secondary,
42
+ light: themeColors.grayLight,
43
+ lighter: themeColors.secondaryLight,
44
+ dark: themeColors.secondaryDark,
45
+ },
46
+ common: {
47
+ green: themeColors.green,
48
+ yellow: themeColors.yellow,
49
+ black: themeColors.pureBlack,
50
+ white: themeColors.pureWhite,
51
+ blue: themeColors.offsetBlue,
52
+ },
53
+ error: {
54
+ lighter: alpha(themeColors.error, 0.1),
55
+ light: lighten(themeColors.error, 0.3),
56
+ main: themeColors.error,
57
+ dark: darken(themeColors.error, 0.2),
58
+ },
59
+ }
60
+
61
+ const borders = {
62
+ primary: `1px solid ${themeColors.primary}`,
63
+ grayLight: `1px solid ${themeColors.secondaryLight}`,
64
+ }
65
+
66
+ // A custom theme for this app
67
+ const muiTheme = createTheme({
68
+ typography: {
69
+ fontFamily: ['Poppins', 'Avenir', 'sans-serif'].join(','),
70
+ },
71
+ borders: {
72
+ ...borders,
73
+ },
74
+ palette: {
75
+ primary: {
76
+ dark: '#1E19F5',
77
+ main: colors.primary.main,
78
+ light: colors.primary.light,
79
+ lighter: colors.primary.lighter,
80
+ },
81
+ secondary: {
82
+ main: '#121212',
83
+ light: colors.secondary.light,
84
+ dark: themeColors.secondaryDark,
85
+ lighter: themeColors.secondaryLight,
86
+ },
87
+ common: {
88
+ green: themeColors.green,
89
+ yellow: themeColors.yellow,
90
+ blue: themeColors.offsetBlue,
91
+ },
92
+ error: {
93
+ main: red.A400,
94
+ },
95
+ text: {
96
+ primary: '#121212',
97
+ secondary: '#959595',
98
+ disabled: '#12121280',
99
+ },
100
+ },
101
+ components: {
102
+ MuiTypography: {
103
+ styleOverrides: {
104
+ root: {
105
+ color: '#121212',
106
+ fontSize: '14px',
107
+ fontWeight: 500,
108
+ fontFamily: PRIMARY_FONT,
109
+ },
110
+ h1: {
111
+ fontSize: '18px',
112
+ fontWeight: 600,
113
+ fontFamily: SECONDARY_FONT,
114
+ },
115
+ h3: {
116
+ fontSize: '16px',
117
+ fontWeight: 600,
118
+ fontFamily: SECONDARY_FONT,
119
+ },
120
+ h5: {
121
+ fontSize: '14px',
122
+ fontWeight: 500,
123
+ fontFamily: SECONDARY_FONT,
124
+ },
125
+ h6: {
126
+ fontSize: '15px',
127
+ fontWeight: 600,
128
+ fontFamily: SECONDARY_FONT,
129
+ },
130
+ paragraph: {
131
+ fontSize: '16px',
132
+ marginBottom: 0,
133
+ },
134
+ body2: {
135
+ fontWeight: 600,
136
+ },
137
+ subtitle1: {
138
+ fontSize: '12px',
139
+ fontWeight: 400,
140
+ color: '#959595',
141
+ },
142
+ subtitle2: {
143
+ fontSize: '13px',
144
+ fontWeight: 400,
145
+ color: '#959595',
146
+ },
147
+ },
148
+ },
149
+ MuiButton: {
150
+ defaultProps: {
151
+ variant: 'contained',
152
+ disableRipple: true,
153
+ disableElevation: true,
154
+ disableFocusRipple: true,
155
+ disableTouchRipple: true,
156
+ },
157
+ styleOverrides: {
158
+ root: {
159
+ fontFamily: SECONDARY_FONT,
160
+ height: '40px',
161
+ padding: '10px 36px',
162
+ textTransform: 'capitalize',
163
+ fontWeight: 600,
164
+ borderRadius: borderRadius.small,
165
+ '&.MuiButton-sizeSmall': {
166
+ padding: '6px 8px',
167
+ height: '32px',
168
+ fontSize: '13px',
169
+ },
170
+ },
171
+ },
172
+ },
173
+ MuiButtonBase: {
174
+ defaultProps: {
175
+ disableRipple: true,
176
+ },
177
+ styleOverrides: {
178
+ root: {
179
+ fontFamily: SECONDARY_FONT,
180
+ '&.MuiButton-textSizeSmall': {
181
+ padding: '6px 8px',
182
+ height: '32px',
183
+ },
184
+ },
185
+ },
186
+ },
187
+ MuiOutlinedInput: {
188
+ styleOverrides: {
189
+ root: {
190
+ fontSize: '14px',
191
+ minHeight: '50px',
192
+ borderRadius: borderRadius.large,
193
+ '&.MuiInputBase-sizeSmall': {
194
+ minHeight: '30px',
195
+ },
196
+ '& .MuiInputAdornment-positionEnd.MuiInputAdornment-outlined': {
197
+ paddingRight: 2,
198
+ },
199
+ '& .MuiOutlinedInput-notchedOutline': {
200
+ borderColor: alpha(colors.common.black, 0.15),
201
+ '& legend': {
202
+ '& > span': {
203
+ paddingRight: 2,
204
+ },
205
+ },
206
+ },
207
+ '&:hover .MuiOutlinedInput-notchedOutline': {
208
+ borderColor: alpha(colors.common.black, 0.3),
209
+ },
210
+ '&.Mui-focused .MuiOutlinedInput-notchedOutline': {
211
+ borderColor: colors.primary.main,
212
+ borderWidth: '0.5px',
213
+ '& :hover': {
214
+ borderColor: colors.primary.main,
215
+ borderWidth: '0.5px',
216
+ },
217
+ },
218
+ },
219
+ },
220
+ },
221
+ MuiAutocomplete: {
222
+ styleOverrides: {
223
+ tag: {
224
+ margin: 1,
225
+ },
226
+ root: {
227
+ '.MuiAutocomplete-inputRoot.MuiOutlinedInput-root .MuiAutocomplete-endAdornment':
228
+ {
229
+ right: 14,
230
+ },
231
+ '& .MuiAutocomplete-tag': {
232
+ border: '1px solid #D1D1D1',
233
+ background: '#F8F8F8',
234
+ borderRadius: '5px',
235
+ height: '38px',
236
+ '& .MuiSvgIcon-root': {
237
+ fontSize: '15px',
238
+ marginLeft: '5px',
239
+ fontWeight: 700,
240
+ color: colors.secondary.main,
241
+ '&:hover': {
242
+ color: alpha(colors.secondary.main, 0.8),
243
+ },
244
+ },
245
+ },
246
+ '& .MuiInputBase-root': {
247
+ padding: '5px',
248
+ },
249
+ },
250
+ clearIndicator: {
251
+ background: colors.error.lighter,
252
+ borderRadius: '5px',
253
+ color: colors.error.main,
254
+ marginRight: 8,
255
+
256
+ '&:hover': {
257
+ background: colors.error.lighter,
258
+ color: colors.error.dark,
259
+ },
260
+ },
261
+ popupIndicator: {
262
+ color: alpha(colors.common.black, 0.5),
263
+
264
+ '&:hover': {
265
+ background: colors.primary.lighter,
266
+ color: colors.primary.main,
267
+ },
268
+ },
269
+ },
270
+ },
271
+ MuiSwitch: {
272
+ styleOverrides: {
273
+ root: {
274
+ height: '20px',
275
+ padding: 0,
276
+ '& .MuiSwitch-switchBase': {
277
+ padding: 0,
278
+ transitionDuration: '300ms',
279
+ '&.Mui-checked': {
280
+ color: colors.common.green,
281
+ '& .MuiSwitch-thumb': {
282
+ marginLeft: '0px',
283
+ },
284
+ '& + .MuiSwitch-track': {
285
+ opacity: '1',
286
+ border: `0.5px solid ${colors.common.green}`,
287
+ background: '#EDEDED 0% 0% no-repeat padding-box',
288
+ },
289
+ '&.Mui-disabled + .MuiSwitch-track': {
290
+ opacity: 0.5,
291
+ },
292
+ },
293
+ '&.Mui-disabled .MuiSwitch-thumb': {
294
+ color: colors.common.green,
295
+ opacity: '0.5',
296
+ },
297
+ },
298
+ '& .MuiSwitch-thumb': {
299
+ width: '18px',
300
+ height: '16px',
301
+ borderRadius: '5px',
302
+ marginTop: '2px',
303
+ boxShadow: 'none',
304
+ marginLeft: '2px',
305
+ },
306
+ '& .MuiSwitch-track': {
307
+ borderRadius: '5px',
308
+ width: '40px',
309
+ height: '20px',
310
+ backgroundColor: '#EDEDED',
311
+ paddingLeft: '12px',
312
+ opacity: '1',
313
+ },
314
+ },
315
+ },
316
+ },
317
+ MuiMenu: {
318
+ styleOverrides: {
319
+ paper: {
320
+ '&::-webkit-scrollbar': {
321
+ width: '0.5em',
322
+ height: '0.5em',
323
+ },
324
+
325
+ '&::-webkit-scrollbar-thumb': {
326
+ backgroundColor: 'rgba(0, 0, 0, 0.15)',
327
+ borderRadius: '3px',
328
+
329
+ '&:hover': {
330
+ background: 'rgba(0, 0, 0, 0.2)',
331
+ },
332
+ },
333
+ },
334
+ },
335
+ },
336
+ MuiIconButton: {
337
+ defaultProps: {
338
+ disableRipple: true,
339
+ disableFocusRipple: true,
340
+ disableTouchRipple: true,
341
+ size: 'small',
342
+ },
343
+ styleOverrides: {
344
+ root: {
345
+ borderRadius: '10px',
346
+ },
347
+ },
348
+ },
349
+ MuiFormLabel: {
350
+ styleOverrides: {
351
+ root: {
352
+ fontSize: '14px',
353
+ color: '#959595',
354
+ },
355
+ },
356
+ },
357
+ MuiTextField: {
358
+ defaultProps: {
359
+ variant: 'outlined',
360
+ color: 'primary',
361
+ fullWidth: true,
362
+ },
363
+ },
364
+ MuiTable: {
365
+ styleOverrides: {
366
+ root: {
367
+ border: borders.grayLight,
368
+ fontFamily: PRIMARY_FONT,
369
+ fontSize: '14px',
370
+ fontWeight: 600,
371
+ },
372
+ },
373
+ },
374
+ MuiTableHead: {
375
+ styleOverrides: {
376
+ root: {
377
+ backgroundColor: themeColors.grayLight,
378
+ '& th': {
379
+ lineHeight: '20px',
380
+ fontSize: '14px',
381
+ fontWeight: 600,
382
+ fontFamily: SECONDARY_FONT,
383
+ },
384
+ },
385
+ },
386
+ },
387
+ MuiTableCell: {
388
+ styleOverrides: {
389
+ root: {
390
+ lineHeight: '20px',
391
+ padding: '15px',
392
+ fontWeight: 600,
393
+ fontFamily: PRIMARY_FONT,
394
+ fontSize: '14px',
395
+ '& .MuiCheckbox-root': {
396
+ padding: 0,
397
+ },
398
+ },
399
+ },
400
+ },
401
+ MuiCard: {
402
+ styleOverrides: {
403
+ root: {
404
+ border: borders.grayLight,
405
+ boxShadow: 'none',
406
+ borderRadius: '10px',
407
+ '&.MuiPaper-root': {
408
+ height: 'fit-content',
409
+ },
410
+ },
411
+ },
412
+ },
413
+ MuiCardHeader: {
414
+ styleOverrides: {
415
+ root: {
416
+ padding: '20px',
417
+ '& .MuiCardHeader-title': {
418
+ fontSize: '15px',
419
+ fontFamily: SECONDARY_FONT,
420
+ fontWeight: 500,
421
+ },
422
+ '& .MuiTypography-root.MuiCardHeader-subheader': {
423
+ marginTop: '3px',
424
+ fontSize: '13px',
425
+ fontFamily: PRIMARY_FONT,
426
+ fontWeight: 400,
427
+ },
428
+ },
429
+ },
430
+ },
431
+ MuiCardContent: {
432
+ styleOverrides: {
433
+ root: {
434
+ padding: '20px',
435
+ paddingTop: 0,
436
+ },
437
+ },
438
+ },
439
+ MuiCardActions: {
440
+ styleOverrides: {
441
+ root: {
442
+ padding: 0,
443
+ },
444
+ },
445
+ },
446
+ MuiFormHelperText: {
447
+ styleOverrides: {
448
+ root: {
449
+ fontFamily: PRIMARY_FONT,
450
+ fontSize: '12px',
451
+ color: themeColors.error,
452
+ marginLeft: '2px',
453
+ marginRight: '2px',
454
+ },
455
+ },
456
+ },
457
+ MuiChip: {
458
+ styleOverrides: {
459
+ root: {
460
+ fontFamily: SECONDARY_FONT,
461
+ fontSize: '14px',
462
+ },
463
+ },
464
+ },
465
+ MuiListItemButton: {
466
+ styleOverrides: {
467
+ root: {
468
+ fontFamily: SECONDARY_FONT,
469
+ fontSize: '14px',
470
+ '& .MuiListItemText-primary.MuiTypography-root': {
471
+ fontFamily: SECONDARY_FONT,
472
+ },
473
+ },
474
+ },
475
+ },
476
+ MuiRadio: {
477
+ defaultProps: {
478
+ size: 'small',
479
+ },
480
+ styleOverrides: {
481
+ root: {},
482
+ },
483
+ },
484
+ MuiCssBaseline: {
485
+ styleOverrides: customCssBaseline,
486
+ },
487
+ },
488
+ })
489
+
490
+ export default muiTheme