@digitaldefiance/express-suite-react-components 2.9.38 → 2.9.39

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 (257) hide show
  1. package/package.json +5 -4
  2. package/src/auth/Private.d.ts +6 -0
  3. package/src/auth/Private.d.ts.map +1 -0
  4. package/src/auth/Private.js +14 -0
  5. package/src/auth/PrivateRoute.d.ts +8 -0
  6. package/src/auth/PrivateRoute.d.ts.map +1 -0
  7. package/src/auth/PrivateRoute.js +23 -0
  8. package/src/auth/UnAuth.d.ts +6 -0
  9. package/src/auth/UnAuth.d.ts.map +1 -0
  10. package/src/auth/UnAuth.js +14 -0
  11. package/src/auth/UnAuthRoute.d.ts +8 -0
  12. package/src/auth/UnAuthRoute.d.ts.map +1 -0
  13. package/src/auth/UnAuthRoute.js +22 -0
  14. package/src/auth/{index.ts → index.d.ts} +2 -1
  15. package/src/auth/index.d.ts.map +1 -0
  16. package/src/auth/index.js +10 -0
  17. package/src/components/ApiAccess.d.ts +16 -0
  18. package/src/components/ApiAccess.d.ts.map +1 -0
  19. package/src/components/ApiAccess.js +77 -0
  20. package/src/components/BackupCodeLoginForm.d.ts +43 -0
  21. package/src/components/BackupCodeLoginForm.d.ts.map +1 -0
  22. package/src/components/BackupCodeLoginForm.js +139 -0
  23. package/src/components/BackupCodesForm.d.ts +26 -0
  24. package/src/components/BackupCodesForm.d.ts.map +1 -0
  25. package/src/components/BackupCodesForm.js +120 -0
  26. package/src/components/ChangePasswordForm.d.ts +26 -0
  27. package/src/components/ChangePasswordForm.d.ts.map +1 -0
  28. package/src/components/ChangePasswordForm.js +78 -0
  29. package/src/components/ConfirmationDialog.d.ts +13 -0
  30. package/src/components/ConfirmationDialog.d.ts.map +1 -0
  31. package/src/components/ConfirmationDialog.js +10 -0
  32. package/src/components/CurrencyCodeSelector.d.ts +9 -0
  33. package/src/components/CurrencyCodeSelector.d.ts.map +1 -0
  34. package/src/components/CurrencyCodeSelector.js +31 -0
  35. package/src/components/CurrencyInput.d.ts +13 -0
  36. package/src/components/CurrencyInput.d.ts.map +1 -0
  37. package/src/components/CurrencyInput.js +22 -0
  38. package/src/components/DashboardPage.d.ts +8 -0
  39. package/src/components/DashboardPage.d.ts.map +1 -0
  40. package/src/components/DashboardPage.js +10 -0
  41. package/src/components/DropdownMenu.d.ts +9 -0
  42. package/src/components/DropdownMenu.d.ts.map +1 -0
  43. package/src/components/DropdownMenu.js +56 -0
  44. package/src/components/ExpirationSecondsSelector.d.ts +13 -0
  45. package/src/components/ExpirationSecondsSelector.d.ts.map +1 -0
  46. package/src/components/ExpirationSecondsSelector.js +32 -0
  47. package/src/components/Flag.d.ts +20 -0
  48. package/src/components/Flag.d.ts.map +1 -0
  49. package/src/components/Flag.js +43 -0
  50. package/src/components/ForgotPasswordForm.d.ts +18 -0
  51. package/src/components/ForgotPasswordForm.d.ts.map +1 -0
  52. package/src/components/ForgotPasswordForm.js +61 -0
  53. package/src/components/LoginForm.d.ts +44 -0
  54. package/src/components/LoginForm.d.ts.map +1 -0
  55. package/src/components/LoginForm.js +122 -0
  56. package/src/components/LogoutPage.d.ts +8 -0
  57. package/src/components/LogoutPage.d.ts.map +1 -0
  58. package/src/components/LogoutPage.js +16 -0
  59. package/src/components/RegisterForm.d.ts +56 -0
  60. package/src/components/RegisterForm.d.ts.map +1 -0
  61. package/src/components/RegisterForm.js +140 -0
  62. package/src/components/ResetPasswordForm.d.ts +23 -0
  63. package/src/components/ResetPasswordForm.d.ts.map +1 -0
  64. package/src/components/ResetPasswordForm.js +78 -0
  65. package/src/components/SideMenu.d.ts +8 -0
  66. package/src/components/SideMenu.d.ts.map +1 -0
  67. package/src/components/SideMenu.js +25 -0
  68. package/src/components/SideMenuListItem.d.ts +13 -0
  69. package/src/components/SideMenuListItem.d.ts.map +1 -0
  70. package/src/components/SideMenuListItem.js +44 -0
  71. package/src/components/TopMenu.d.ts +24 -0
  72. package/src/components/TopMenu.d.ts.map +1 -0
  73. package/src/components/TopMenu.js +35 -0
  74. package/src/components/TranslatedTitle.d.ts +7 -0
  75. package/src/components/TranslatedTitle.d.ts.map +1 -0
  76. package/src/components/TranslatedTitle.js +15 -0
  77. package/src/components/UserLanguageSelector.d.ts +4 -0
  78. package/src/components/UserLanguageSelector.d.ts.map +1 -0
  79. package/src/components/UserLanguageSelector.js +31 -0
  80. package/src/components/UserMenu.d.ts +4 -0
  81. package/src/components/UserMenu.d.ts.map +1 -0
  82. package/src/components/UserMenu.js +12 -0
  83. package/src/components/UserSettingsForm.d.ts +57 -0
  84. package/src/components/UserSettingsForm.d.ts.map +1 -0
  85. package/src/components/UserSettingsForm.js +126 -0
  86. package/src/components/VerifyEmailPage.d.ts +23 -0
  87. package/src/components/VerifyEmailPage.d.ts.map +1 -0
  88. package/src/components/VerifyEmailPage.js +70 -0
  89. package/src/components/{index.ts → index.d.ts} +1 -1
  90. package/src/components/index.d.ts.map +1 -0
  91. package/src/components/index.js +28 -0
  92. package/src/contexts/AuthProvider.d.ts +152 -0
  93. package/src/contexts/AuthProvider.d.ts.map +1 -0
  94. package/src/contexts/AuthProvider.js +502 -0
  95. package/src/contexts/I18nProvider.d.ts +16 -0
  96. package/src/contexts/I18nProvider.d.ts.map +1 -0
  97. package/src/contexts/I18nProvider.js +46 -0
  98. package/src/contexts/MenuContext.d.ts +20 -0
  99. package/src/contexts/MenuContext.d.ts.map +1 -0
  100. package/src/contexts/MenuContext.js +273 -0
  101. package/src/contexts/SuiteConfigProvider.d.ts +44 -0
  102. package/src/contexts/SuiteConfigProvider.d.ts.map +1 -0
  103. package/src/contexts/SuiteConfigProvider.js +43 -0
  104. package/src/contexts/ThemeProvider.d.ts +15 -0
  105. package/src/contexts/ThemeProvider.d.ts.map +1 -0
  106. package/src/contexts/ThemeProvider.js +36 -0
  107. package/src/contexts/{index.ts → index.d.ts} +1 -0
  108. package/src/contexts/index.d.ts.map +1 -0
  109. package/src/contexts/index.js +8 -0
  110. package/src/hooks/{index.ts → index.d.ts} +1 -0
  111. package/src/hooks/index.d.ts.map +1 -0
  112. package/src/hooks/index.js +8 -0
  113. package/src/hooks/useBackupCodes.d.ts +15 -0
  114. package/src/hooks/useBackupCodes.d.ts.map +1 -0
  115. package/src/hooks/useBackupCodes.js +74 -0
  116. package/src/hooks/useEmailVerification.d.ts +10 -0
  117. package/src/hooks/useEmailVerification.d.ts.map +1 -0
  118. package/src/hooks/useEmailVerification.js +40 -0
  119. package/src/hooks/useExpiringValue.d.ts +14 -0
  120. package/src/hooks/useExpiringValue.d.ts.map +1 -0
  121. package/src/hooks/useExpiringValue.js +53 -0
  122. package/src/hooks/useLocalStorage.d.ts +2 -0
  123. package/src/hooks/useLocalStorage.d.ts.map +1 -0
  124. package/src/hooks/useLocalStorage.js +15 -0
  125. package/src/hooks/useUserSettings.d.ts +48 -0
  126. package/src/hooks/useUserSettings.d.ts.map +1 -0
  127. package/src/hooks/useUserSettings.js +169 -0
  128. package/src/{index.ts → index.d.ts} +1 -1
  129. package/src/index.d.ts.map +1 -0
  130. package/src/index.js +12 -0
  131. package/src/interfaces/IAppConfig.d.ts +6 -0
  132. package/src/interfaces/IAppConfig.d.ts.map +1 -0
  133. package/src/interfaces/IAppConfig.js +2 -0
  134. package/src/interfaces/IMenuConfig.d.ts +11 -0
  135. package/src/interfaces/IMenuConfig.d.ts.map +1 -0
  136. package/src/interfaces/IMenuConfig.js +2 -0
  137. package/src/interfaces/IMenuOption.d.ts +58 -0
  138. package/src/interfaces/IMenuOption.d.ts.map +1 -0
  139. package/src/interfaces/IMenuOption.js +2 -0
  140. package/src/interfaces/index.d.ts +4 -0
  141. package/src/interfaces/index.d.ts.map +1 -0
  142. package/src/interfaces/index.js +6 -0
  143. package/src/services/__mocks__/authService.d.ts +21 -0
  144. package/src/services/__mocks__/authService.d.ts.map +1 -0
  145. package/src/services/__mocks__/authService.js +15 -0
  146. package/src/services/api.d.ts +3 -0
  147. package/src/services/api.d.ts.map +1 -0
  148. package/src/services/api.js +14 -0
  149. package/src/services/authService.d.ts +72 -0
  150. package/src/services/authService.d.ts.map +1 -0
  151. package/src/services/authService.js +335 -0
  152. package/src/services/authenticatedApi.d.ts +3 -0
  153. package/src/services/authenticatedApi.d.ts.map +1 -0
  154. package/src/services/authenticatedApi.js +18 -0
  155. package/src/services/index.d.ts +4 -0
  156. package/src/services/index.d.ts.map +1 -0
  157. package/src/services/index.js +6 -0
  158. package/src/types/MenuType.d.ts +11 -0
  159. package/src/types/MenuType.d.ts.map +1 -0
  160. package/src/types/MenuType.js +12 -0
  161. package/src/types/expirationSeconds.d.ts +3 -0
  162. package/src/types/expirationSeconds.d.ts.map +1 -0
  163. package/src/types/expirationSeconds.js +17 -0
  164. package/src/types/index.d.ts +2 -0
  165. package/src/types/index.d.ts.map +1 -0
  166. package/src/types/index.js +4 -0
  167. package/src/types/translation.d.ts +10 -0
  168. package/src/types/translation.d.ts.map +1 -0
  169. package/src/types/translation.js +9 -0
  170. package/src/wrappers/BackupCodeLoginWrapper.d.ts +8 -0
  171. package/src/wrappers/BackupCodeLoginWrapper.d.ts.map +1 -0
  172. package/src/wrappers/BackupCodeLoginWrapper.js +20 -0
  173. package/src/wrappers/BackupCodesWrapper.d.ts +7 -0
  174. package/src/wrappers/BackupCodesWrapper.d.ts.map +1 -0
  175. package/src/wrappers/BackupCodesWrapper.js +17 -0
  176. package/src/wrappers/ChangePasswordFormWrapper.d.ts +8 -0
  177. package/src/wrappers/ChangePasswordFormWrapper.d.ts.map +1 -0
  178. package/src/wrappers/ChangePasswordFormWrapper.js +21 -0
  179. package/src/wrappers/LoginFormWrapper.d.ts +9 -0
  180. package/src/wrappers/LoginFormWrapper.d.ts.map +1 -0
  181. package/src/wrappers/LoginFormWrapper.js +43 -0
  182. package/src/wrappers/LogoutPageWrapper.d.ts +9 -0
  183. package/src/wrappers/LogoutPageWrapper.d.ts.map +1 -0
  184. package/src/wrappers/LogoutPageWrapper.js +21 -0
  185. package/src/wrappers/RegisterFormWrapper.d.ts +9 -0
  186. package/src/wrappers/RegisterFormWrapper.d.ts.map +1 -0
  187. package/src/wrappers/RegisterFormWrapper.js +31 -0
  188. package/src/wrappers/UserSettingsFormWrapper.d.ts +8 -0
  189. package/src/wrappers/UserSettingsFormWrapper.d.ts.map +1 -0
  190. package/src/wrappers/UserSettingsFormWrapper.js +24 -0
  191. package/src/wrappers/VerifyEmailPageWrapper.d.ts +8 -0
  192. package/src/wrappers/VerifyEmailPageWrapper.d.ts.map +1 -0
  193. package/src/wrappers/VerifyEmailPageWrapper.js +20 -0
  194. package/src/wrappers/{index.tsx → index.d.ts} +1 -8
  195. package/src/wrappers/index.d.ts.map +1 -0
  196. package/src/wrappers/index.js +20 -0
  197. package/LICENSE +0 -21
  198. package/src/auth/Private.tsx +0 -17
  199. package/src/auth/PrivateRoute.tsx +0 -28
  200. package/src/auth/UnAuth.tsx +0 -16
  201. package/src/auth/UnAuthRoute.tsx +0 -30
  202. package/src/components/ApiAccess.tsx +0 -174
  203. package/src/components/BackupCodeLoginForm.tsx +0 -488
  204. package/src/components/BackupCodesForm.tsx +0 -286
  205. package/src/components/ChangePasswordForm.tsx +0 -272
  206. package/src/components/ConfirmationDialog.tsx +0 -48
  207. package/src/components/CurrencyCodeSelector.tsx +0 -60
  208. package/src/components/CurrencyInput.tsx +0 -80
  209. package/src/components/DashboardPage.tsx +0 -24
  210. package/src/components/DropdownMenu.tsx +0 -92
  211. package/src/components/ExpirationSecondsSelector.tsx +0 -60
  212. package/src/components/Flag.tsx +0 -52
  213. package/src/components/ForgotPasswordForm.tsx +0 -173
  214. package/src/components/LoginForm.tsx +0 -455
  215. package/src/components/LogoutPage.tsx +0 -21
  216. package/src/components/RegisterForm.tsx +0 -602
  217. package/src/components/ResetPasswordForm.tsx +0 -246
  218. package/src/components/SideMenu.tsx +0 -46
  219. package/src/components/SideMenuListItem.tsx +0 -74
  220. package/src/components/TopMenu.tsx +0 -145
  221. package/src/components/TranslatedTitle.tsx +0 -29
  222. package/src/components/UserLanguageSelector.tsx +0 -45
  223. package/src/components/UserMenu.tsx +0 -15
  224. package/src/components/UserSettingsForm.tsx +0 -505
  225. package/src/components/VerifyEmailPage.tsx +0 -184
  226. package/src/contexts/AuthProvider.spec.tsx +0 -1195
  227. package/src/contexts/AuthProvider.tsx +0 -924
  228. package/src/contexts/I18nProvider.tsx +0 -114
  229. package/src/contexts/MenuContext.tsx +0 -398
  230. package/src/contexts/SuiteConfigProvider.tsx +0 -93
  231. package/src/contexts/ThemeProvider.tsx +0 -67
  232. package/src/hooks/useBackupCodes.ts +0 -105
  233. package/src/hooks/useEmailVerification.ts +0 -49
  234. package/src/hooks/useExpiringValue.ts +0 -78
  235. package/src/hooks/useLocalStorage.ts +0 -18
  236. package/src/hooks/useUserSettings.ts +0 -269
  237. package/src/interfaces/IAppConfig.ts +0 -5
  238. package/src/interfaces/IMenuConfig.ts +0 -11
  239. package/src/interfaces/IMenuOption.ts +0 -55
  240. package/src/interfaces/index.ts +0 -3
  241. package/src/services/__mocks__/authService.ts +0 -14
  242. package/src/services/api.ts +0 -13
  243. package/src/services/authService.ts +0 -500
  244. package/src/services/authenticatedApi.ts +0 -17
  245. package/src/services/index.ts +0 -3
  246. package/src/types/MenuType.ts +0 -15
  247. package/src/types/expirationSeconds.ts +0 -18
  248. package/src/types/index.ts +0 -1
  249. package/src/types/translation.ts +0 -20
  250. package/src/wrappers/BackupCodeLoginWrapper.tsx +0 -34
  251. package/src/wrappers/BackupCodesWrapper.tsx +0 -28
  252. package/src/wrappers/ChangePasswordFormWrapper.tsx +0 -34
  253. package/src/wrappers/LoginFormWrapper.tsx +0 -59
  254. package/src/wrappers/LogoutPageWrapper.tsx +0 -30
  255. package/src/wrappers/RegisterFormWrapper.tsx +0 -61
  256. package/src/wrappers/UserSettingsFormWrapper.tsx +0 -39
  257. package/src/wrappers/VerifyEmailPageWrapper.tsx +0 -27
@@ -1,80 +0,0 @@
1
- import { TextField } from '@mui/material';
2
- import { NumericFormat } from 'react-number-format';
3
- import { getCurrencyFormat } from '@digitaldefiance/i18n-lib';
4
-
5
- export interface CurrencyInputProps {
6
- value: number;
7
- onChange: (value: number) => void;
8
- currencyCode?: string;
9
- locale?: string;
10
- label: string;
11
- error?: boolean;
12
- helperText?: string;
13
- name: string;
14
- }
15
-
16
- export const CurrencyInput: React.FC<CurrencyInputProps> = ({
17
- value,
18
- onChange,
19
- currencyCode = 'USD',
20
- locale = 'en-US',
21
- label,
22
- error,
23
- helperText,
24
- name,
25
- }) => {
26
- const format = getCurrencyFormat(locale, currencyCode);
27
-
28
- if (format.position === 'infix') {
29
- const [whole, decimal] = value.toString().split('.');
30
- const displayValue = `${whole}${format.symbol}${format.decimalSeparator}${
31
- decimal || '00'
32
- }`;
33
-
34
- return (
35
- <NumericFormat
36
- customInput={TextField}
37
- fullWidth
38
- margin="normal"
39
- label={label}
40
- value={displayValue}
41
- thousandSeparator={format.groupSeparator}
42
- decimalSeparator={format.decimalSeparator}
43
- decimalScale={2}
44
- fixedDecimalScale
45
- valueIsNumericString
46
- onValueChange={(values) => {
47
- onChange(values.floatValue || 0);
48
- }}
49
- error={error}
50
- helperText={helperText}
51
- name={name}
52
- />
53
- );
54
- }
55
-
56
- return (
57
- <NumericFormat
58
- customInput={TextField}
59
- fullWidth
60
- margin="normal"
61
- label={label}
62
- value={value}
63
- thousandSeparator={format.groupSeparator}
64
- decimalSeparator={format.decimalSeparator}
65
- decimalScale={2}
66
- fixedDecimalScale
67
- prefix={format.position === 'prefix' ? format.symbol + ' ' : undefined}
68
- suffix={format.position === 'postfix' ? ' ' + format.symbol : undefined}
69
- valueIsNumericString
70
- onValueChange={(values) => {
71
- onChange(values.floatValue || 0);
72
- }}
73
- error={error}
74
- helperText={helperText}
75
- name={name}
76
- />
77
- );
78
- };
79
-
80
- export default CurrencyInput;
@@ -1,24 +0,0 @@
1
- import { Box, Container, Typography } from '@mui/material';
2
- import { FC, ReactNode } from 'react';
3
-
4
- export interface DashboardPageProps {
5
- title?: string;
6
- children?: ReactNode;
7
- }
8
-
9
- export const DashboardPage: FC<DashboardPageProps> = ({ title = 'Dashboard', children }) => {
10
- return (
11
- <Container maxWidth="md">
12
- <Box my={4}>
13
- <Typography variant="h4" component="h1" gutterBottom align="center">
14
- {title}
15
- </Typography>
16
- <Box display="flex" justifyContent="center" mt={3}>
17
- {children}
18
- </Box>
19
- </Box>
20
- </Container>
21
- );
22
- };
23
-
24
- export default DashboardPage;
@@ -1,92 +0,0 @@
1
- import { Box, Fade, IconButton, Menu, MenuItem } from '@mui/material';
2
- import { FC, MouseEvent, ReactElement, useCallback, useState } from 'react';
3
- import { useNavigate } from 'react-router-dom';
4
- import { MenuType } from '../types/MenuType';
5
- import { IMenuOption } from '../interfaces/IMenuOption';
6
- import { useMenu } from '../contexts/MenuContext';
7
-
8
- interface DropdownMenuProps {
9
- menuType: MenuType;
10
- menuIcon: ReactElement;
11
- }
12
-
13
- export const DropdownMenu: FC<DropdownMenuProps> = ({ menuType, menuIcon }) => {
14
- const { getMenuOptions } = useMenu();
15
- const [anchorEl, setAnchorEl] = useState<null | HTMLElement>(null);
16
- const navigate = useNavigate();
17
- const handleClose = useCallback(() => {
18
- setAnchorEl(null);
19
- }, []);
20
- const handleMenuItemClick = useCallback(
21
- (option: IMenuOption) => (event: React.MouseEvent<HTMLElement>) => {
22
- event.stopPropagation();
23
- if (option.action) {
24
- option.action();
25
- } else if (option.link !== undefined) {
26
- if (
27
- typeof option.link === 'object' &&
28
- 'pathname' in option.link &&
29
- 'state' in option.link
30
- ) {
31
- navigate(option.link.pathname, { state: option.link.state });
32
- } else {
33
- navigate(option.link);
34
- }
35
- }
36
- handleClose(); // Call handleClose after handling the click
37
- },
38
- [navigate, handleClose], // Add handleClose to the dependency array
39
- );
40
-
41
- const handleClick = useCallback((event: MouseEvent<HTMLElement>) => {
42
- setAnchorEl(event.currentTarget);
43
- }, []);
44
-
45
- const menuItems = getMenuOptions(menuType, false);
46
-
47
- if (menuItems.length === 0) {
48
- return null;
49
- }
50
-
51
- return (
52
- <Box>
53
- <IconButton color="inherit" onClick={handleClick}>
54
- {menuIcon}
55
- </IconButton>
56
- <Menu
57
- anchorEl={anchorEl}
58
- open={Boolean(anchorEl)}
59
- onClose={handleClose}
60
- TransitionComponent={Fade}
61
- sx={{
62
- '& .MuiPopover-paper': {
63
- opacity: 0.5,
64
- overflow: 'visible',
65
- },
66
- }}
67
- >
68
- {menuItems.map((option) => (
69
- <MenuItem
70
- key={option.id}
71
- component="li"
72
- onClick={handleMenuItemClick(option)}
73
- sx={{
74
- display: 'flex',
75
- alignItems: 'center',
76
- '& > svg': {
77
- marginRight: 2,
78
- width: 24,
79
- height: 24,
80
- },
81
- }}
82
- >
83
- {option.icon}
84
- {option.label}
85
- </MenuItem>
86
- ))}
87
- </Menu>
88
- </Box>
89
- );
90
- };
91
-
92
- export default DropdownMenu;
@@ -1,60 +0,0 @@
1
- import { MenuItem, TextField } from '@mui/material';
2
- import { FormikProps } from 'formik';
3
- import { ChangeEvent, FC } from 'react';
4
-
5
- export interface ExpirationSecondsSelectorProps<T = Record<string, unknown>> {
6
- name: string;
7
- label: string;
8
- formik: FormikProps<T>;
9
- optionValues: number[];
10
- optionNames: string[];
11
- onChange?: (value: number) => void;
12
- }
13
-
14
- export const ExpirationSecondsSelector: FC<
15
- ExpirationSecondsSelectorProps<Record<string, unknown>>
16
- > = ({ name, label, formik, optionValues, optionNames, onChange }) => {
17
- return (
18
- <TextField
19
- select
20
- fullWidth
21
- label={label}
22
- name={name}
23
- value={formik.values[name] ?? ''}
24
- onChange={(event: ChangeEvent<HTMLInputElement>) => {
25
- const selectedValue = event.target.value;
26
- formik.setFieldValue(name, selectedValue);
27
- if (onChange) {
28
- onChange(parseInt(selectedValue));
29
- }
30
- }}
31
- error={formik.touched[name] && Boolean(formik.errors[name])}
32
- helperText={formik.touched[name] && (formik.errors[name] as string)}
33
- sx={{
34
- mt: 1,
35
- '& .MuiSelect-select': {
36
- paddingRight: '32px',
37
- },
38
- '& .MuiOutlinedInput-root': {
39
- '& fieldset': {
40
- borderColor: 'rgba(0, 0, 0, 0.23)',
41
- },
42
- '&:hover fieldset': {
43
- borderColor: 'rgba(0, 0, 0, 0.87)',
44
- },
45
- '&.Mui-focused fieldset': {
46
- borderColor: 'primary.main',
47
- },
48
- },
49
- }}
50
- >
51
- {optionNames.map((name: string, index: number) => (
52
- <MenuItem key={name} value={optionValues[index]}>
53
- {name}
54
- </MenuItem>
55
- ))}
56
- </TextField>
57
- );
58
- };
59
-
60
- export default ExpirationSecondsSelector;
@@ -1,52 +0,0 @@
1
- import { getFlagCode } from '@digitaldefiance/suite-core-lib';
2
- import { Box, SxProps, Theme } from '@mui/material';
3
- import { FC } from 'react';
4
-
5
- export interface FlagProps {
6
- language: string;
7
- sx?: SxProps<Theme>;
8
- }
9
-
10
- /**
11
- * A simple component to display a flag icon for a given language.
12
- *
13
- * Props:
14
- * language: The language to display a flag for, as a StringLanguages enum value.
15
- * sx: Optional styles to apply to the component.
16
- *
17
- * Returns a Box component with an SVG flag icon from flagcdn.com as a ::before pseudo-element.
18
- * The flag is sized to 1.5rem by default, but can be overridden by passing a custom sx prop.
19
- * The component also includes an aria-label for accessibility, set to `Flag for <language>`.
20
- */
21
- export const Flag: FC<FlagProps> = ({ language, sx }) => {
22
- const flagContent = getFlagCode(language);
23
- if (!flagContent) {
24
- return null;
25
- }
26
- return (
27
- <Box
28
- component="span"
29
- aria-label={`Flag for ${language}`}
30
- sx={{
31
- fontSize: '1.5rem',
32
- lineHeight: 1,
33
- verticalAlign: 'middle',
34
- '&::before': {
35
- content: `" "`,
36
- display: 'inline-block',
37
- width: '1em',
38
- height: '1em',
39
- backgroundImage: `url(https://flagcdn.com/${flagContent.toLowerCase()}.svg)`,
40
- backgroundSize: 'contain',
41
- backgroundRepeat: 'no-repeat',
42
- backgroundPosition: 'center',
43
- border: '1px solid rgba(0, 0, 0, 0.1)',
44
- borderRadius: '2px',
45
- },
46
- ...sx,
47
- }}
48
- />
49
- );
50
- };
51
-
52
- export default Flag;
@@ -1,173 +0,0 @@
1
- import {
2
- SuiteCoreComponentId,
3
- SuiteCoreStringKey,
4
- } from '@digitaldefiance/suite-core-lib';
5
- import {
6
- Alert,
7
- Box,
8
- Button,
9
- Container,
10
- TextField,
11
- Typography,
12
- } from '@mui/material';
13
- import { useFormik } from 'formik';
14
- import { FC, useState } from 'react';
15
- import * as Yup from 'yup';
16
- import { useI18n } from '../contexts';
17
-
18
- export interface ForgotPasswordFormValues {
19
- email: string;
20
- }
21
-
22
- export interface ForgotPasswordFormProps {
23
- onSubmit: (values: ForgotPasswordFormValues) => Promise<void>;
24
- emailValidation?: Yup.StringSchema;
25
- labels?: {
26
- title?: string;
27
- email?: string;
28
- sendResetLink?: string;
29
- successMessage?: string;
30
- };
31
- }
32
-
33
- export const ForgotPasswordForm: FC<ForgotPasswordFormProps> = ({
34
- onSubmit,
35
- emailValidation,
36
- labels = {},
37
- }) => {
38
- const { tComponent } = useI18n();
39
- const [success, setSuccess] = useState(false);
40
- const [apiError, setApiError] = useState<string>('');
41
-
42
- const validation = {
43
- email:
44
- emailValidation ||
45
- Yup.string()
46
- .email(
47
- tComponent<SuiteCoreStringKey>(
48
- SuiteCoreComponentId,
49
- SuiteCoreStringKey.Validation_InvalidEmail
50
- )
51
- )
52
- .required(
53
- tComponent<SuiteCoreStringKey>(
54
- SuiteCoreComponentId,
55
- SuiteCoreStringKey.Validation_Required
56
- )
57
- ),
58
- };
59
-
60
- const translatedLabels = {
61
- title:
62
- labels.title ||
63
- tComponent<SuiteCoreStringKey>(
64
- SuiteCoreComponentId,
65
- SuiteCoreStringKey.ForgotPassword_Title
66
- ),
67
- email:
68
- labels.email ||
69
- tComponent<SuiteCoreStringKey>(
70
- SuiteCoreComponentId,
71
- SuiteCoreStringKey.Common_Email
72
- ),
73
- sendResetLink:
74
- labels.sendResetLink ||
75
- tComponent<SuiteCoreStringKey>(
76
- SuiteCoreComponentId,
77
- SuiteCoreStringKey.ForgotPassword_SendResetLink
78
- ),
79
- successMessage:
80
- labels.successMessage ||
81
- tComponent<SuiteCoreStringKey>(
82
- SuiteCoreComponentId,
83
- SuiteCoreStringKey.PasswordReset_Success
84
- ),
85
- };
86
-
87
- const formik = useFormik<ForgotPasswordFormValues>({
88
- initialValues: {
89
- email: '',
90
- },
91
- validationSchema: Yup.object({
92
- email: validation.email,
93
- }),
94
- onSubmit: async (values) => {
95
- try {
96
- await onSubmit(values);
97
- setSuccess(true);
98
- setApiError('');
99
- } catch (error: unknown) {
100
- const err = error as { response?: { data?: { message?: string } } };
101
- setApiError(
102
- err.response?.data?.message ||
103
- tComponent<SuiteCoreStringKey>(
104
- SuiteCoreComponentId,
105
- SuiteCoreStringKey.ForgotPassword_Error
106
- )
107
- );
108
- setSuccess(false);
109
- }
110
- },
111
- });
112
-
113
- return (
114
- <Container maxWidth="sm">
115
- <Box
116
- sx={{
117
- mt: 8,
118
- display: 'flex',
119
- flexDirection: 'column',
120
- alignItems: 'center',
121
- }}
122
- >
123
- <Typography variant="h4" component="h1" gutterBottom>
124
- {translatedLabels.title}
125
- </Typography>
126
-
127
- <Box
128
- component="form"
129
- onSubmit={formik.handleSubmit}
130
- sx={{ mt: 1, width: '100%' }}
131
- >
132
- <TextField
133
- fullWidth
134
- id="email"
135
- name="email"
136
- label={translatedLabels.email}
137
- value={formik.values.email}
138
- onChange={formik.handleChange}
139
- onBlur={formik.handleBlur}
140
- error={Boolean(formik.touched.email && formik.errors.email)}
141
- helperText={formik.touched.email && formik.errors.email}
142
- margin="normal"
143
- />
144
-
145
- {apiError && (
146
- <Alert severity="error" sx={{ mt: 2, mb: 2 }}>
147
- {apiError}
148
- </Alert>
149
- )}
150
-
151
- {success && (
152
- <Alert severity="success" sx={{ mt: 2, mb: 2 }}>
153
- {translatedLabels.successMessage}
154
- </Alert>
155
- )}
156
-
157
- <Button
158
- type="submit"
159
- fullWidth
160
- variant="contained"
161
- color="primary"
162
- sx={{ mt: 3, mb: 2 }}
163
- disabled={formik.isSubmitting}
164
- >
165
- {translatedLabels.sendResetLink}
166
- </Button>
167
- </Box>
168
- </Box>
169
- </Container>
170
- );
171
- };
172
-
173
- export default ForgotPasswordForm;