@campxdev/shared 0.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 (253) hide show
  1. package/.eslintrc.js +34 -0
  2. package/.prettierrc +10 -0
  3. package/.storybook/main.js +16 -0
  4. package/.storybook/preview.js +9 -0
  5. package/antd.customize.less +73 -0
  6. package/exports.ts +20 -0
  7. package/package.json +78 -0
  8. package/public/dean.JPG +0 -0
  9. package/public/download.png +0 -0
  10. package/public/illustrations/bookmark.svg +19 -0
  11. package/public/illustrations/girl-writing.png +0 -0
  12. package/public/illustrations/whiteboard.svg +24 -0
  13. package/public/images/AnimatedUploadFile.gif +0 -0
  14. package/public/images/doc@2x.png +0 -0
  15. package/public/images/greenTick.png +0 -0
  16. package/public/images/jpg.png +0 -0
  17. package/public/images/paperclip@2x.png +0 -0
  18. package/public/images/pdf.png +0 -0
  19. package/public/images/ppt.png +0 -0
  20. package/public/images/profileImage.jpg +0 -0
  21. package/public/images/profileImage.png +0 -0
  22. package/public/index.html +50 -0
  23. package/public/logo.png +0 -0
  24. package/public/logo_campx_full.png +0 -0
  25. package/public/logo_square.svg +21 -0
  26. package/public/omr_sign.jpg +0 -0
  27. package/src/App.tsx +35 -0
  28. package/src/assets/fonts/avenir/Avenir.ttc +0 -0
  29. package/src/assets/fonts/avenir/index.ts +2 -0
  30. package/src/assets/fonts/poppins/Poppins-Bold.ttf +0 -0
  31. package/src/assets/fonts/poppins/Poppins-Italic.ttf +0 -0
  32. package/src/assets/fonts/poppins/Poppins-Light.ttf +0 -0
  33. package/src/assets/fonts/poppins/Poppins-LightItalic.ttf +0 -0
  34. package/src/assets/fonts/poppins/Poppins-Medium.ttf +0 -0
  35. package/src/assets/fonts/poppins/Poppins-MediumItalic.ttf +0 -0
  36. package/src/assets/fonts/poppins/Poppins-Regular.ttf +0 -0
  37. package/src/assets/fonts/poppins/Poppins-SemiBold.ttf +0 -0
  38. package/src/assets/fonts/poppins/Poppins-SemiBoldItalic.ttf +0 -0
  39. package/src/assets/fonts/poppins/index.ts +7 -0
  40. package/src/assets/images/File bundle-bro.svg +122 -0
  41. package/src/assets/images/Filebundle.png +0 -0
  42. package/src/assets/images/NoPart.png +0 -0
  43. package/src/assets/images/ResultProcess.png +0 -0
  44. package/src/assets/images/ResultProcess.svg +99 -0
  45. package/src/assets/images/attachment.svg +1 -0
  46. package/src/assets/images/avatar.png +0 -0
  47. package/src/assets/images/index.ts +19 -0
  48. package/src/assets/images/pdf.png +0 -0
  49. package/src/assets/images/taskAttachment.png +0 -0
  50. package/src/assets/images/welcomeimage.jpg +0 -0
  51. package/src/assets/static_files/External_Marks_Import .xlsx +0 -0
  52. package/src/assets/static_files/Leads_Sample.xlsx +0 -0
  53. package/src/assets/static_files/Subject_Topic_Import_Sheet.xlsx +0 -0
  54. package/src/assets/static_files/admissions_Sample.xlsx +0 -0
  55. package/src/assets/static_files/barcodes_template.xlsx +0 -0
  56. package/src/assets/static_files/hostel_rooms_import.xlsx +0 -0
  57. package/src/assets/static_files/index.ts +24 -0
  58. package/src/assets/static_files/sample_admissions.xlsx +0 -0
  59. package/src/assets/static_files/sample_admissions_report.xlsx +0 -0
  60. package/src/assets/static_files/sample_curriculum_subjects_template.xlsx +0 -0
  61. package/src/assets/static_files/sample_import_students_new.xlsx +0 -0
  62. package/src/assets/static_files/sample_internal_marks.xlsx +0 -0
  63. package/src/assets/static_files/sample_student_subjects_template.xlsx +0 -0
  64. package/src/components/ActionButton.tsx +28 -0
  65. package/src/components/Attachment.tsx +26 -0
  66. package/src/components/AutocompleteSearch/AutocompleteSearch.tsx +57 -0
  67. package/src/components/AutocompleteSearch/index.tsx +1 -0
  68. package/src/components/Breadcrumbs.tsx +73 -0
  69. package/src/components/Card.tsx +97 -0
  70. package/src/components/CardsGrid.tsx +28 -0
  71. package/src/components/Chips.tsx +77 -0
  72. package/src/components/Detail.tsx +15 -0
  73. package/src/components/DetailsGrid.tsx +52 -0
  74. package/src/components/DividerHeading.tsx +40 -0
  75. package/src/components/DrawerWrapper/DialogWrapper.tsx +63 -0
  76. package/src/components/DrawerWrapper/DrawerTemplate.tsx +53 -0
  77. package/src/components/DrawerWrapper/DrawerWrapper.tsx +53 -0
  78. package/src/components/DropDownButton.tsx +184 -0
  79. package/src/components/ErrorBoundary.js +45 -0
  80. package/src/components/ErrorBox.tsx +42 -0
  81. package/src/components/FloatingContainer.tsx +26 -0
  82. package/src/components/FullCalendar/Actions.tsx +162 -0
  83. package/src/components/FullCalendar/FullCalendarWrapper.tsx +54 -0
  84. package/src/components/HookForm/AutoCompleteSearch.tsx +143 -0
  85. package/src/components/HookForm/DatePicker.tsx +65 -0
  86. package/src/components/HookForm/DateTimePicker.tsx +70 -0
  87. package/src/components/HookForm/FormLabel.tsx +14 -0
  88. package/src/components/HookForm/MultiCheckbox.tsx +82 -0
  89. package/src/components/HookForm/MultiSelect.tsx +100 -0
  90. package/src/components/HookForm/RadioGroup.tsx +113 -0
  91. package/src/components/HookForm/SingleCheckbox.tsx +46 -0
  92. package/src/components/HookForm/SingleSelect.tsx +93 -0
  93. package/src/components/HookForm/TextField.tsx +74 -0
  94. package/src/components/HookForm/TimePicker.tsx +82 -0
  95. package/src/components/HookForm/index.ts +23 -0
  96. package/src/components/IconButtons/IconButtons.tsx +137 -0
  97. package/src/components/IconButtons/Icons.tsx +269 -0
  98. package/src/components/IconButtons/assets/edit.svg +4 -0
  99. package/src/components/IconButtons/assets/eye.svg +6 -0
  100. package/src/components/IconButtons/assets/trash.svg +7 -0
  101. package/src/components/IconButtons/index.tsx +8 -0
  102. package/src/components/IconLabel.tsx +37 -0
  103. package/src/components/Image/Image.tsx +43 -0
  104. package/src/components/Image/broken-image.png +0 -0
  105. package/src/components/Image/index.tsx +1 -0
  106. package/src/components/ImageUpload.tsx +98 -0
  107. package/src/components/Input/AutoCompleteSearch.tsx +143 -0
  108. package/src/components/Input/DatePicker.tsx +60 -0
  109. package/src/components/Input/DateRangePicker.tsx +131 -0
  110. package/src/components/Input/DateTimePicker.tsx +70 -0
  111. package/src/components/Input/FormLabel.tsx +14 -0
  112. package/src/components/Input/MultiCheckbox.tsx +79 -0
  113. package/src/components/Input/MultiSelect.tsx +52 -0
  114. package/src/components/Input/RadioGroup.tsx +55 -0
  115. package/src/components/Input/SingleCheckbox.tsx +23 -0
  116. package/src/components/Input/SingleSelect.tsx +139 -0
  117. package/src/components/Input/TextField.tsx +50 -0
  118. package/src/components/Input/TimePicker.tsx +82 -0
  119. package/src/components/Input/index.ts +26 -0
  120. package/src/components/JsonPreview/JsonPreview.tsx +7 -0
  121. package/src/components/JsonPreview/index.tsx +1 -0
  122. package/src/components/LabelValue/LabelValue.tsx +21 -0
  123. package/src/components/LabelValue/index.tsx +1 -0
  124. package/src/components/Layout/ChangePassword.tsx +49 -0
  125. package/src/components/Layout/Header/AppHeader.tsx +150 -0
  126. package/src/components/Layout/Header/CogWheelMenu.tsx +35 -0
  127. package/src/components/Layout/Header/FreshDeskHelpButton.tsx +19 -0
  128. package/src/components/Layout/Header/MainAppHeader.tsx +6 -0
  129. package/src/components/Layout/Header/Notification.tsx +13 -0
  130. package/src/components/Layout/Header/UserBox.tsx +51 -0
  131. package/src/components/Layout/Header/applications.tsx +39 -0
  132. package/src/components/Layout/Header/icons.tsx +57 -0
  133. package/src/components/Layout/Header/index.tsx +1 -0
  134. package/src/components/Layout/Header/styles.tsx +48 -0
  135. package/src/components/LinearProgress/LinearProgress.tsx +27 -0
  136. package/src/components/LinearProgress/index.tsx +1 -0
  137. package/src/components/MediaRow/MediaRow.tsx +69 -0
  138. package/src/components/MediaRow/index.tsx +1 -0
  139. package/src/components/MenuButton.tsx +105 -0
  140. package/src/components/ModalButtons/DialogButton.tsx +84 -0
  141. package/src/components/ModalButtons/DrawerButton.tsx +89 -0
  142. package/src/components/ModalButtons/index.tsx +4 -0
  143. package/src/components/NoDataIllustration/NoDataIllustration.tsx +32 -0
  144. package/src/components/NoDataIllustration/index.tsx +1 -0
  145. package/src/components/PageContent.tsx +14 -0
  146. package/src/components/PageHeader.tsx +52 -0
  147. package/src/components/PopupConfirm/ConfirmContextProvider.tsx +22 -0
  148. package/src/components/PopupConfirm/PopupConfirm.tsx +33 -0
  149. package/src/components/PopupConfirm/index.tsx +1 -0
  150. package/src/components/PopupConfirm/useConfirm.ts +47 -0
  151. package/src/components/Row/Row.tsx +24 -0
  152. package/src/components/Row/index.tsx +1 -0
  153. package/src/components/SearchBar/SearchBar.tsx +53 -0
  154. package/src/components/SearchBar/index.tsx +1 -0
  155. package/src/components/Spinner.tsx +18 -0
  156. package/src/components/StepsHeader/StepsHeader.tsx +115 -0
  157. package/src/components/StepsHeader/index.tsx +1 -0
  158. package/src/components/Styled/OutlinedIconButton.tsx +7 -0
  159. package/src/components/Styled/index.tsx +1 -0
  160. package/src/components/StyledTableContainer.tsx +33 -0
  161. package/src/components/Swiper/Swiper.tsx +39 -0
  162. package/src/components/Swiper/index.tsx +1 -0
  163. package/src/components/SwitchButton/SwitchButton.tsx +41 -0
  164. package/src/components/SwitchButton/index.tsx +1 -0
  165. package/src/components/TableComponent/BatchActionsHeader.tsx +58 -0
  166. package/src/components/TableComponent/Icons/index.tsx +50 -0
  167. package/src/components/TableComponent/ReactTable.tsx +293 -0
  168. package/src/components/TableComponent/RenderTableBody.tsx +65 -0
  169. package/src/components/TableComponent/TableFooter/TableFooter.tsx +102 -0
  170. package/src/components/TableComponent/TableFooter/index.tsx +1 -0
  171. package/src/components/TableComponent/TableFooter/styles.tsx +28 -0
  172. package/src/components/TableComponent/index.tsx +219 -0
  173. package/src/components/TableComponent/no-data-illu.svg +1 -0
  174. package/src/components/TableComponent/react-table-config.d.ts +129 -0
  175. package/src/components/TableComponent/styles.tsx +173 -0
  176. package/src/components/TableComponent/types.ts +57 -0
  177. package/src/components/Tabs/Tabs.tsx +52 -0
  178. package/src/components/Tabs/TabsContainer.tsx +50 -0
  179. package/src/components/Tabs/index.tsx +1 -0
  180. package/src/components/Tabs/styles.tsx +55 -0
  181. package/src/components/ToastContainer/ToastContainer.tsx +42 -0
  182. package/src/components/ToastContainer/index.tsx +1 -0
  183. package/src/components/UploadButton/UploadButton.tsx +98 -0
  184. package/src/components/UploadButton/index.tsx +1 -0
  185. package/src/components/UploadButton/types.ts +14 -0
  186. package/src/components/UploadDocument/UploadDocument.tsx +108 -0
  187. package/src/components/UploadDocument/index.tsx +1 -0
  188. package/src/components/UploadFileDialog/UploadFileDialog.tsx +240 -0
  189. package/src/components/UploadFileDialog/index.tsx +1 -0
  190. package/src/components/index.ts +59 -0
  191. package/src/config/axios.ts +138 -0
  192. package/src/constants/UIConstants.ts +97 -0
  193. package/src/constants/formValidations.ts +6 -0
  194. package/src/constants/index.ts +4 -0
  195. package/src/constants/permissions.ts +67 -0
  196. package/src/constants/validateMessages.ts +12 -0
  197. package/src/contexts/Providers.tsx +24 -0
  198. package/src/contexts/QueryClientProvider.tsx +22 -0
  199. package/src/hooks/index.ts +2 -0
  200. package/src/hooks/useFetch.ts +53 -0
  201. package/src/hooks/useRouter.ts +31 -0
  202. package/src/index.tsx +9 -0
  203. package/src/layouts/ComponentsLayout.tsx +3 -0
  204. package/src/pages/LoginPage/LoginPage.tsx +166 -0
  205. package/src/pages/LoginPage/index.ts +1 -0
  206. package/src/pages/LoginPage/styles.tsx +121 -0
  207. package/src/pages/index.ts +4 -0
  208. package/src/permissions/PageWithPermission.tsx +58 -0
  209. package/src/permissions/PermissionDeniedPage.tsx +23 -0
  210. package/src/permissions/PermissionsStore.ts +289 -0
  211. package/src/permissions/ValidateAccess.tsx +18 -0
  212. package/src/permissions/index.ts +3 -0
  213. package/src/react-app-env.d.ts +1 -0
  214. package/src/shared-state/AssetsStore.ts +15 -0
  215. package/src/shared-state/UserStore.ts +13 -0
  216. package/src/shared-state/index.ts +3 -0
  217. package/src/stories/Button.stories.tsx +41 -0
  218. package/src/stories/Button.tsx +48 -0
  219. package/src/stories/Header.stories.tsx +25 -0
  220. package/src/stories/Header.tsx +56 -0
  221. package/src/stories/Introduction.stories.mdx +211 -0
  222. package/src/stories/Page.stories.tsx +26 -0
  223. package/src/stories/Page.tsx +73 -0
  224. package/src/stories/TextField.stories.tsx +18 -0
  225. package/src/stories/TextField.tsx +49 -0
  226. package/src/stories/assets/code-brackets.svg +1 -0
  227. package/src/stories/assets/colors.svg +1 -0
  228. package/src/stories/assets/comments.svg +1 -0
  229. package/src/stories/assets/direction.svg +1 -0
  230. package/src/stories/assets/flow.svg +1 -0
  231. package/src/stories/assets/plugin.svg +1 -0
  232. package/src/stories/assets/repo.svg +1 -0
  233. package/src/stories/assets/stackalt.svg +1 -0
  234. package/src/stories/button.css +30 -0
  235. package/src/stories/header.css +32 -0
  236. package/src/stories/page.css +69 -0
  237. package/src/theme/App.less +3 -0
  238. package/src/theme/MuiThemeProvider.tsx +11 -0
  239. package/src/theme/customCssBaseline.ts +78 -0
  240. package/src/theme/index.css +75 -0
  241. package/src/theme/muiTheme.ts +516 -0
  242. package/src/theme/theme.d.ts +75 -0
  243. package/src/utils/alphabet.ts +23 -0
  244. package/src/utils/arrayPadEnd.ts +3 -0
  245. package/src/utils/formatCurrency.ts +9 -0
  246. package/src/utils/getUrlParams.ts +5 -0
  247. package/src/utils/index.ts +6 -0
  248. package/src/utils/ordinalSuffixOf.ts +14 -0
  249. package/src/utils/romanize.ts +40 -0
  250. package/src/utils/withRouteWrapper.tsx +25 -0
  251. package/src/utils/withSuspense.tsx +6 -0
  252. package/styled-components.tsx +60 -0
  253. package/tsconfig.json +21 -0
@@ -0,0 +1,131 @@
1
+ import { DateRangeIcon } from '../IconButtons'
2
+ import { Box, styled, TextField } from '@mui/material'
3
+ import { DatePicker, LocalizationProvider } from '@mui/x-date-pickers'
4
+ import { AdapterMoment } from '@mui/x-date-pickers/AdapterMoment'
5
+ import { useState } from 'react'
6
+ interface Props {
7
+ label?: string
8
+ name?: string
9
+ size?: 'small' | 'medium'
10
+ control?: any
11
+ minDate?: any
12
+ maxDate?: any
13
+ required?: boolean
14
+
15
+ onChangeFromDate: any
16
+ onChangeToDate: any
17
+ fromValue: any
18
+ toValue: any
19
+ }
20
+ export default function DateRangePicker(props: Props) {
21
+ const {
22
+ name,
23
+ size = 'small',
24
+ label = '',
25
+ minDate,
26
+ maxDate,
27
+ required = false,
28
+ fromValue,
29
+ toValue,
30
+ onChangeFromDate,
31
+ onChangeToDate,
32
+ } = props
33
+ const [fromOpen, setFromOpen] = useState(false)
34
+ const [toOpen, setToOpen] = useState(false)
35
+ return (
36
+ <LocalizationProvider dateAdapter={AdapterMoment}>
37
+ <Box
38
+ sx={{
39
+ display: 'flex',
40
+ justifyContent: 'space-between',
41
+ alignItems: 'center',
42
+ border: '1px solid #0000001A',
43
+ borderRadius: '10px',
44
+ padding: '5px',
45
+ }}
46
+ >
47
+ <StyledDatepicker
48
+ value={fromValue}
49
+ onChange={onChangeFromDate}
50
+ label={'start date'}
51
+ mask="__/__/____"
52
+ inputFormat="DD/MM/yyyy"
53
+ closeOnSelect={true}
54
+ OpenPickerButtonProps={{
55
+ onFocus: (e) => {
56
+ setFromOpen(true)
57
+ },
58
+ }}
59
+ onClose={() => {
60
+ setFromOpen(false)
61
+ }}
62
+ PopperProps={{
63
+ disablePortal: true,
64
+ }}
65
+ InputProps={{
66
+ onFocus: () => {
67
+ setFromOpen(true)
68
+ },
69
+ }}
70
+ open={fromOpen}
71
+ renderInput={(params) => (
72
+ <TextField sx={{ width: '200px' }} size={'small'} {...params} />
73
+ )}
74
+ />
75
+ <Box>
76
+ <DateRangeIcon />
77
+ </Box>
78
+ <StyledDatepicker
79
+ onChange={onChangeToDate}
80
+ value={toValue}
81
+ label={'end date'}
82
+ mask="__/__/____"
83
+ inputFormat="DD/MM/yyyy"
84
+ OpenPickerButtonProps={{
85
+ onFocus: (e) => {
86
+ setToOpen(true)
87
+ },
88
+ }}
89
+ onClose={() => {
90
+ setToOpen(false)
91
+ }}
92
+ PopperProps={{
93
+ disablePortal: true,
94
+ }}
95
+ InputProps={{
96
+ onFocus: () => {
97
+ setToOpen(true)
98
+ },
99
+ }}
100
+ open={toOpen}
101
+ renderInput={(params) => (
102
+ <TextField sx={{ width: '200px' }} size={'small'} {...params} />
103
+ )}
104
+ />
105
+ </Box>
106
+ {/* {error && (
107
+ <Typography
108
+ variant="caption"
109
+ component={'div'}
110
+ sx={{ pl: '2px' }}
111
+ color="rgb(211, 47, 47)"
112
+ >
113
+ {error.message}
114
+ </Typography>
115
+ )} */}
116
+ </LocalizationProvider>
117
+ )
118
+ }
119
+
120
+ const StyledDatepicker = styled(DatePicker)({
121
+ '& .MuiFormLabel-root .Mui-focused': {
122
+ display: 'none',
123
+ },
124
+ '& .MuiInputAdornment-root': {
125
+ display: 'none',
126
+ },
127
+
128
+ '& fieldset': {
129
+ display: 'none',
130
+ },
131
+ })
@@ -0,0 +1,70 @@
1
+ import { InputAdornment, TextField, Typography } from '@mui/material'
2
+ import { DateTimePicker, LocalizationProvider } from '@mui/x-date-pickers'
3
+ import { AdapterMoment } from '@mui/x-date-pickers/AdapterMoment'
4
+ import { Controller } from 'react-hook-form'
5
+ import DateRangeIcon from '@mui/icons-material/DateRange'
6
+ interface Props {
7
+ label?: string
8
+ name: string
9
+ size?: 'small' | 'medium'
10
+ control: any
11
+ required?: boolean
12
+ minDate?: any
13
+ }
14
+ export default function FormDateTimePicker(props: Props) {
15
+ const { name, size = 'small', control, label = '', required, minDate } = props
16
+ return (
17
+ <LocalizationProvider dateAdapter={AdapterMoment}>
18
+ <Controller
19
+ name={name}
20
+ control={control}
21
+ render={({ field, fieldState: { error } }) => (
22
+ <>
23
+ <DateTimePicker
24
+ label={
25
+ <>
26
+ {label}
27
+ {required && (
28
+ <Typography fontSize={14} component={'span'} color="error">
29
+ {' *'}
30
+ </Typography>
31
+ )}
32
+ </>
33
+ }
34
+ minDate={minDate && minDate}
35
+ mask="__/__/____ __:__ _M"
36
+ inputFormat="DD/MM/yyyy hh:mm a"
37
+ value={field.value || null}
38
+ onChange={field.onChange}
39
+ InputProps={{
40
+ endAdornment: (
41
+ <InputAdornment position="end">
42
+ <DateRangeIcon />
43
+ </InputAdornment>
44
+ ),
45
+ }}
46
+ renderInput={(params) => (
47
+ <TextField
48
+ fullWidth
49
+ size={size}
50
+ {...params}
51
+ error={Boolean(error)}
52
+ onBlur={field.onBlur}
53
+ />
54
+ )}
55
+ />
56
+ {error && (
57
+ <Typography
58
+ variant="caption"
59
+ sx={{ pl: '2px' }}
60
+ color="rgb(211, 47, 47)"
61
+ >
62
+ {error.message}
63
+ </Typography>
64
+ )}
65
+ </>
66
+ )}
67
+ />
68
+ </LocalizationProvider>
69
+ )
70
+ }
@@ -0,0 +1,14 @@
1
+ import { Typography } from '@mui/material'
2
+
3
+ export default function FormLabel({ label, required }) {
4
+ return (
5
+ <>
6
+ {label}
7
+ {required && (
8
+ <Typography fontSize={14} component={'span'} color="error">
9
+ {' *'}
10
+ </Typography>
11
+ )}
12
+ </>
13
+ )
14
+ }
@@ -0,0 +1,79 @@
1
+ import {
2
+ Checkbox,
3
+ FormControl,
4
+ FormControlLabel,
5
+ FormGroup,
6
+ Typography,
7
+ } from '@mui/material'
8
+ import { Controller } from 'react-hook-form'
9
+ import FormLabel from './FormLabel'
10
+
11
+ interface Props {
12
+ label?: string
13
+ name: string
14
+ size?: 'small' | 'medium'
15
+ control: any
16
+ options: Array<{ label: string; value: string }>
17
+ required?: boolean
18
+ row?: boolean
19
+ }
20
+
21
+ export default function MultiCheckbox(props: Props) {
22
+ const {
23
+ name,
24
+ size = 'small',
25
+ control,
26
+ label = '',
27
+ options = [],
28
+ required = false,
29
+ row = true,
30
+ } = props
31
+
32
+ return (
33
+ <Controller
34
+ name={name}
35
+ control={control}
36
+ render={({ field, fieldState: { error } }) => (
37
+ <>
38
+ <FormLabel label={label} required={required} />
39
+ <FormControl size={size} fullWidth>
40
+ <FormGroup row={row} sx={{ flexWrap: 'wrap' }}>
41
+ {options?.map((item, index) => (
42
+ <FormControlLabel
43
+ name={name}
44
+ key={index}
45
+ control={
46
+ <Checkbox
47
+ size="small"
48
+ checked={field?.value
49
+ ?.map((item: any) => item?.value)
50
+ ?.includes(item?.value)}
51
+ onChange={(e) => {
52
+ let value = field.value || []
53
+ if (e.target.checked) {
54
+ let newValue = [...value, item]
55
+ field.onChange(newValue)
56
+ } else {
57
+ let filteredValue = value.filter(
58
+ (opt: any) => opt?.value !== item.value,
59
+ )
60
+ field.onChange(filteredValue)
61
+ }
62
+ }}
63
+ />
64
+ }
65
+ label={item.label}
66
+ />
67
+ ))}
68
+ </FormGroup>
69
+ </FormControl>
70
+ {error && (
71
+ <Typography variant="caption" color="error" sx={{ pl: '2px' }}>
72
+ {error.message}
73
+ </Typography>
74
+ )}
75
+ </>
76
+ )}
77
+ />
78
+ )
79
+ }
@@ -0,0 +1,52 @@
1
+ import { Close } from '@mui/icons-material'
2
+ import { Autocomplete, TextField } from '@mui/material'
3
+ import { ReactNode } from 'react'
4
+ import FormLabel from './FormLabel'
5
+
6
+ interface MultiSelectProps {
7
+ label: string
8
+ name?: string
9
+ options: { label: string | ReactNode; value: any }[]
10
+ placeholder?: string
11
+ loading?: boolean
12
+ value: { label: string | ReactNode; value: any }[]
13
+ onChange: (value: any) => void
14
+ required?: boolean
15
+ }
16
+
17
+ export default function MultiSelect({
18
+ name,
19
+ options,
20
+ label,
21
+ loading,
22
+ value,
23
+ onChange,
24
+ required,
25
+ ...props
26
+ }: MultiSelectProps) {
27
+ return (
28
+ <Autocomplete
29
+ multiple
30
+ value={value}
31
+ loading={loading}
32
+ fullWidth
33
+ onChange={(e, value) => {
34
+ if (!onChange) return
35
+ onChange(value)
36
+ }}
37
+ options={options || []}
38
+ getOptionLabel={(option: any) => option?.value || ''}
39
+ renderInput={(params) => (
40
+ <TextField
41
+ {...params}
42
+ variant="outlined"
43
+ label={<FormLabel label={label} required={required} />}
44
+ />
45
+ )}
46
+ ChipProps={{
47
+ deleteIcon: <Close />,
48
+ }}
49
+ {...props}
50
+ />
51
+ )
52
+ }
@@ -0,0 +1,55 @@
1
+ import {
2
+ Checkbox,
3
+ FormControlLabel,
4
+ Radio,
5
+ Typography,
6
+ RadioGroup as MuiRadioGroup,
7
+ Box,
8
+ RadioGroupProps,
9
+ Stack,
10
+ } from '@mui/material'
11
+ import { ReactNode } from 'react'
12
+
13
+ interface Props extends RadioGroupProps {
14
+ label: string
15
+ name?: string
16
+ control?: any
17
+ sx?: any
18
+ row?: boolean
19
+ required?: boolean
20
+ options: { value: any; label: string | ReactNode }[]
21
+ }
22
+
23
+ export default function RadioGroup(props: Props) {
24
+ const {
25
+ name,
26
+ label,
27
+ options = [],
28
+ row = false,
29
+ required = false,
30
+ value,
31
+ onChange,
32
+ } = props
33
+ return (
34
+ <Box>
35
+ <Box sx={{ display: 'flex' }}>
36
+ <Typography variant="subtitle2">{label}</Typography>
37
+ {required && (
38
+ <Typography fontSize={14} component={'span'} color="error">
39
+ {' *'}
40
+ </Typography>
41
+ )}
42
+ </Box>
43
+ <MuiRadioGroup value={value} onChange={onChange} row={row} name={name}>
44
+ {options.map((item, index) => (
45
+ <FormControlLabel
46
+ key={index}
47
+ value={item.value}
48
+ control={<Radio />}
49
+ label={item.label}
50
+ />
51
+ ))}
52
+ </MuiRadioGroup>
53
+ </Box>
54
+ )
55
+ }
@@ -0,0 +1,23 @@
1
+ import { Checkbox, FormControlLabel, Typography } from '@mui/material'
2
+ import { Controller } from 'react-hook-form'
3
+
4
+ interface Props {
5
+ disabled?: boolean
6
+ label: string
7
+ name?: string
8
+ size?: 'small' | 'medium'
9
+ sx?: any
10
+ checked: boolean
11
+ onChange: (e) => void
12
+ }
13
+
14
+ export default function SingleCheckbox(props: Props) {
15
+ const { name, checked, size = 'medium', label = '', sx, onChange } = props
16
+ return (
17
+ <FormControlLabel
18
+ sx={{ width: '100%', ...sx }}
19
+ control={<Checkbox size={size} checked={checked} onChange={onChange} />}
20
+ label={label}
21
+ />
22
+ )
23
+ }
@@ -0,0 +1,139 @@
1
+ import {
2
+ FormControl,
3
+ InputLabel,
4
+ MenuItem,
5
+ Select,
6
+ SelectProps,
7
+ Typography,
8
+ } from '@mui/material'
9
+ import { ReactNode } from 'react'
10
+ import { Controller } from 'react-hook-form'
11
+ import FormLabel from './FormLabel'
12
+ interface Props extends SelectProps {
13
+ name?: string
14
+ control?: any
15
+ options: Array<{ label: ReactNode; value: any }>
16
+ label?: string
17
+ textColor?: string
18
+ onChange?: (value: any) => void
19
+ required?: boolean
20
+ hookForm?: boolean
21
+ firstItemEmpty?: boolean
22
+ }
23
+
24
+ export default function SingleSelect(props: Props) {
25
+ const {
26
+ name = 'select',
27
+ options,
28
+ control,
29
+ label,
30
+ textColor,
31
+ onChange,
32
+ required,
33
+ hookForm = true,
34
+ firstItemEmpty = false,
35
+ } = props
36
+
37
+ const inputOptions = firstItemEmpty
38
+ ? [{ label: 'All', value: '__empty__' }, ...options]
39
+ : options
40
+
41
+ if (!hookForm) {
42
+ return (
43
+ <>
44
+ <FormControl fullWidth sx={props.sx}>
45
+ <InputLabel id={name}>
46
+ <FormLabel required={required} label={label} />
47
+ </InputLabel>
48
+ <Select
49
+ variant="outlined"
50
+ id={name}
51
+ value={props.value}
52
+ displayEmpty={firstItemEmpty}
53
+ fullWidth
54
+ label={label}
55
+ MenuProps={{
56
+ PaperProps: {
57
+ sx: { maxHeight: 300 },
58
+ },
59
+ }}
60
+ onChange={props.onChange}
61
+ >
62
+ {inputOptions?.map((item, index) => (
63
+ <MenuItem key={index} value={item.value}>
64
+ {item.label}
65
+ </MenuItem>
66
+ ))}
67
+ </Select>
68
+ </FormControl>
69
+ </>
70
+ )
71
+ }
72
+
73
+ return (
74
+ <Controller
75
+ name={name}
76
+ control={control}
77
+ render={({ field, fieldState: { error } }) => (
78
+ <>
79
+ <FormControl fullWidth>
80
+ <InputLabel id={name}>
81
+ <FormLabel required={required} label={label} />
82
+ </InputLabel>
83
+ <Select
84
+ error={Boolean(error)}
85
+ variant="outlined"
86
+ sx={{ color: textColor }}
87
+ fullWidth
88
+ label={label}
89
+ displayEmpty={firstItemEmpty}
90
+ MenuProps={{
91
+ PaperProps: {
92
+ sx: { maxHeight: 300 },
93
+ },
94
+ }}
95
+ value={field.value}
96
+ onChange={(e) => {
97
+ if (onChange) onChange(e.target.value)
98
+ field.onChange(e.target.value)
99
+ }}
100
+ >
101
+ {inputOptions?.map((item, index) => (
102
+ <MenuItem key={index} value={item.value}>
103
+ {item.label}
104
+ </MenuItem>
105
+ ))}
106
+ </Select>
107
+ </FormControl>
108
+ {error && (
109
+ <Typography
110
+ fontSize={12}
111
+ sx={{
112
+ paddingLeft: '2px',
113
+ marginTop: '2px',
114
+ }}
115
+ color="error"
116
+ >
117
+ {error.message}
118
+ </Typography>
119
+ )}
120
+ </>
121
+ )}
122
+ />
123
+ )
124
+ }
125
+
126
+
127
+
128
+
129
+
130
+
131
+
132
+
133
+
134
+
135
+
136
+
137
+
138
+
139
+
@@ -0,0 +1,50 @@
1
+ import {
2
+ TextField as MuiTextField,
3
+ TextFieldProps as MuiTextFieldProps,
4
+ Typography,
5
+ } from '@mui/material'
6
+ import React from 'react'
7
+ import { Controller } from 'react-hook-form'
8
+ import FormLabel from './FormLabel'
9
+
10
+ type MyTextFieldProps = MuiTextFieldProps & {
11
+ control?: any
12
+ label?: string
13
+ name?: string
14
+ value?: any
15
+ hookForm?: boolean
16
+ required?: boolean
17
+ handleChange?: React.ChangeEventHandler<
18
+ HTMLTextAreaElement | HTMLInputElement
19
+ >
20
+ }
21
+
22
+ export default function TextField({
23
+ name,
24
+ control,
25
+ label,
26
+ value,
27
+ handleChange,
28
+ required = false,
29
+ hookForm = true,
30
+ ...rest
31
+ }: MyTextFieldProps) {
32
+ return (
33
+ <MuiTextField
34
+ label={
35
+ <>
36
+ {label}
37
+ {required && (
38
+ <Typography fontSize={14} component={'span'} color="error">
39
+ {' *'}
40
+ </Typography>
41
+ )}
42
+ </>
43
+ }
44
+ value={value}
45
+ name={name}
46
+ onChange={handleChange}
47
+ {...rest}
48
+ />
49
+ )
50
+ }
@@ -0,0 +1,82 @@
1
+ import DateRangeIcon from '@mui/icons-material/DateRange'
2
+ import { InputAdornment, TextField, Typography } from '@mui/material'
3
+ import {
4
+ LocalizationProvider,
5
+ TimePicker as MuiTimePicker,
6
+ } from '@mui/x-date-pickers'
7
+ import { AdapterMoment } from '@mui/x-date-pickers/AdapterMoment'
8
+ import { Controller } from 'react-hook-form'
9
+
10
+ interface Props {
11
+ label?: string
12
+ name: string
13
+ size?: 'small' | 'medium'
14
+ control: any
15
+ required?: boolean
16
+ hookForm?: boolean
17
+ }
18
+
19
+ export default function TimePicker(props: Props) {
20
+ const {
21
+ name,
22
+ size = 'small',
23
+ control,
24
+ label = '',
25
+ required,
26
+ hookForm = true,
27
+ } = props
28
+
29
+ return (
30
+ <LocalizationProvider dateAdapter={AdapterMoment}>
31
+ <Controller
32
+ name={name}
33
+ control={control}
34
+ render={({ field, fieldState: { error } }) => (
35
+ <>
36
+ <MuiTimePicker
37
+ label={
38
+ <>
39
+ {label}
40
+ {required && (
41
+ <Typography fontSize={14} component={'span'} color="error">
42
+ {' *'}
43
+ </Typography>
44
+ )}
45
+ </>
46
+ }
47
+ mask="__:__ _M"
48
+ inputFormat="hh:mm a"
49
+ value={field.value || null}
50
+ onChange={field.onChange}
51
+ InputProps={{
52
+ endAdornment: (
53
+ <InputAdornment position="end">
54
+ <DateRangeIcon />
55
+ </InputAdornment>
56
+ ),
57
+ }}
58
+ renderInput={(params) => (
59
+ <TextField
60
+ fullWidth
61
+ size={size}
62
+ {...params}
63
+ error={Boolean(error)}
64
+ onBlur={field.onBlur}
65
+ />
66
+ )}
67
+ />
68
+ {error && (
69
+ <Typography
70
+ variant="caption"
71
+ sx={{ pl: '2px' }}
72
+ color="rgb(211, 47, 47)"
73
+ >
74
+ {error.message}
75
+ </Typography>
76
+ )}
77
+ </>
78
+ )}
79
+ />
80
+ </LocalizationProvider>
81
+ )
82
+ }