@digitaldefiance/express-suite-react-components 2.8.5 → 2.9.2

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 (258) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +8 -0
  3. package/package.json +11 -7
  4. package/src/auth/Private.tsx +17 -0
  5. package/src/auth/PrivateRoute.tsx +28 -0
  6. package/src/auth/UnAuth.tsx +16 -0
  7. package/src/auth/UnAuthRoute.tsx +30 -0
  8. package/src/auth/{index.d.ts → index.ts} +1 -2
  9. package/src/components/ApiAccess.tsx +134 -0
  10. package/src/components/BackupCodeLoginForm.tsx +314 -0
  11. package/src/components/BackupCodesForm.tsx +198 -0
  12. package/src/components/ChangePasswordForm.tsx +182 -0
  13. package/src/components/ConfirmationDialog.tsx +48 -0
  14. package/src/components/CurrencyCodeSelector.tsx +60 -0
  15. package/src/components/CurrencyInput.tsx +80 -0
  16. package/src/components/DashboardPage.tsx +24 -0
  17. package/src/components/DropdownMenu.tsx +92 -0
  18. package/src/components/ExpirationSecondsSelector.tsx +65 -0
  19. package/src/components/Flag.tsx +53 -0
  20. package/src/components/ForgotPasswordForm.tsx +120 -0
  21. package/src/components/LoginForm.tsx +307 -0
  22. package/src/components/LogoutPage.tsx +21 -0
  23. package/src/components/RegisterForm.tsx +354 -0
  24. package/src/components/ResetPasswordForm.tsx +164 -0
  25. package/src/components/SideMenu.tsx +46 -0
  26. package/src/components/SideMenuListItem.tsx +74 -0
  27. package/src/components/TopMenu.tsx +134 -0
  28. package/src/components/TranslatedTitle.tsx +22 -0
  29. package/src/components/UserLanguageSelector.tsx +45 -0
  30. package/src/components/UserMenu.tsx +15 -0
  31. package/src/components/UserSettingsForm.tsx +328 -0
  32. package/src/components/VerifyEmailPage.tsx +133 -0
  33. package/src/components/{index.d.ts → index.ts} +1 -1
  34. package/src/contexts/AuthProvider.spec.tsx +1060 -0
  35. package/src/contexts/AuthProvider.tsx +741 -0
  36. package/src/contexts/I18nProvider.tsx +85 -0
  37. package/src/contexts/MenuContext.tsx +310 -0
  38. package/src/contexts/SuiteConfigProvider.tsx +93 -0
  39. package/src/contexts/ThemeProvider.tsx +67 -0
  40. package/src/contexts/{index.d.ts → index.ts} +0 -1
  41. package/src/hooks/{index.d.ts → index.ts} +0 -1
  42. package/src/hooks/useBackupCodes.ts +85 -0
  43. package/src/hooks/useEmailVerification.ts +39 -0
  44. package/src/hooks/useExpiringValue.ts +78 -0
  45. package/src/hooks/useLocalStorage.ts +18 -0
  46. package/src/hooks/useUserSettings.ts +216 -0
  47. package/src/{index.d.ts → index.ts} +1 -1
  48. package/src/interfaces/IAppConfig.ts +5 -0
  49. package/src/interfaces/IMenuConfig.ts +11 -0
  50. package/src/interfaces/IMenuOption.ts +55 -0
  51. package/src/interfaces/index.ts +3 -0
  52. package/src/services/__mocks__/authService.ts +14 -0
  53. package/src/services/api.ts +13 -0
  54. package/src/services/authService.ts +422 -0
  55. package/src/services/authenticatedApi.ts +17 -0
  56. package/src/services/index.ts +3 -0
  57. package/src/types/MenuType.ts +15 -0
  58. package/src/types/expirationSeconds.ts +18 -0
  59. package/src/types/index.ts +1 -0
  60. package/src/types/translation.ts +20 -0
  61. package/src/wrappers/BackupCodeLoginWrapper.tsx +35 -0
  62. package/src/wrappers/BackupCodesWrapper.tsx +28 -0
  63. package/src/wrappers/ChangePasswordFormWrapper.tsx +31 -0
  64. package/src/wrappers/LoginFormWrapper.tsx +59 -0
  65. package/src/wrappers/LogoutPageWrapper.tsx +30 -0
  66. package/src/wrappers/RegisterFormWrapper.tsx +48 -0
  67. package/src/wrappers/UserSettingsFormWrapper.tsx +39 -0
  68. package/src/wrappers/VerifyEmailPageWrapper.tsx +27 -0
  69. package/src/wrappers/{index.d.ts → index.tsx} +8 -1
  70. package/src/auth/Private.d.ts +0 -6
  71. package/src/auth/Private.d.ts.map +0 -1
  72. package/src/auth/Private.js +0 -14
  73. package/src/auth/PrivateRoute.d.ts +0 -8
  74. package/src/auth/PrivateRoute.d.ts.map +0 -1
  75. package/src/auth/PrivateRoute.js +0 -23
  76. package/src/auth/UnAuth.d.ts +0 -6
  77. package/src/auth/UnAuth.d.ts.map +0 -1
  78. package/src/auth/UnAuth.js +0 -14
  79. package/src/auth/UnAuthRoute.d.ts +0 -8
  80. package/src/auth/UnAuthRoute.d.ts.map +0 -1
  81. package/src/auth/UnAuthRoute.js +0 -22
  82. package/src/auth/index.d.ts.map +0 -1
  83. package/src/auth/index.js +0 -10
  84. package/src/components/ApiAccess.d.ts +0 -16
  85. package/src/components/ApiAccess.d.ts.map +0 -1
  86. package/src/components/ApiAccess.js +0 -70
  87. package/src/components/BackupCodeLoginForm.d.ts +0 -43
  88. package/src/components/BackupCodeLoginForm.d.ts.map +0 -1
  89. package/src/components/BackupCodeLoginForm.js +0 -106
  90. package/src/components/BackupCodesForm.d.ts +0 -26
  91. package/src/components/BackupCodesForm.d.ts.map +0 -1
  92. package/src/components/BackupCodesForm.js +0 -108
  93. package/src/components/ChangePasswordForm.d.ts +0 -26
  94. package/src/components/ChangePasswordForm.d.ts.map +0 -1
  95. package/src/components/ChangePasswordForm.js +0 -66
  96. package/src/components/ConfirmationDialog.d.ts +0 -13
  97. package/src/components/ConfirmationDialog.d.ts.map +0 -1
  98. package/src/components/ConfirmationDialog.js +0 -10
  99. package/src/components/CurrencyCodeSelector.d.ts +0 -9
  100. package/src/components/CurrencyCodeSelector.d.ts.map +0 -1
  101. package/src/components/CurrencyCodeSelector.js +0 -31
  102. package/src/components/CurrencyInput.d.ts +0 -13
  103. package/src/components/CurrencyInput.d.ts.map +0 -1
  104. package/src/components/CurrencyInput.js +0 -22
  105. package/src/components/DashboardPage.d.ts +0 -8
  106. package/src/components/DashboardPage.d.ts.map +0 -1
  107. package/src/components/DashboardPage.js +0 -10
  108. package/src/components/DropdownMenu.d.ts +0 -9
  109. package/src/components/DropdownMenu.d.ts.map +0 -1
  110. package/src/components/DropdownMenu.js +0 -56
  111. package/src/components/ExpirationSecondsSelector.d.ts +0 -13
  112. package/src/components/ExpirationSecondsSelector.d.ts.map +0 -1
  113. package/src/components/ExpirationSecondsSelector.js +0 -32
  114. package/src/components/Flag.d.ts +0 -20
  115. package/src/components/Flag.d.ts.map +0 -1
  116. package/src/components/Flag.js +0 -43
  117. package/src/components/ForgotPasswordForm.d.ts +0 -18
  118. package/src/components/ForgotPasswordForm.d.ts.map +0 -1
  119. package/src/components/ForgotPasswordForm.js +0 -54
  120. package/src/components/LoginForm.d.ts +0 -44
  121. package/src/components/LoginForm.d.ts.map +0 -1
  122. package/src/components/LoginForm.js +0 -99
  123. package/src/components/LogoutPage.d.ts +0 -8
  124. package/src/components/LogoutPage.d.ts.map +0 -1
  125. package/src/components/LogoutPage.js +0 -16
  126. package/src/components/RegisterForm.d.ts +0 -54
  127. package/src/components/RegisterForm.d.ts.map +0 -1
  128. package/src/components/RegisterForm.js +0 -105
  129. package/src/components/ResetPasswordForm.d.ts +0 -23
  130. package/src/components/ResetPasswordForm.d.ts.map +0 -1
  131. package/src/components/ResetPasswordForm.js +0 -68
  132. package/src/components/SideMenu.d.ts +0 -8
  133. package/src/components/SideMenu.d.ts.map +0 -1
  134. package/src/components/SideMenu.js +0 -25
  135. package/src/components/SideMenuListItem.d.ts +0 -13
  136. package/src/components/SideMenuListItem.d.ts.map +0 -1
  137. package/src/components/SideMenuListItem.js +0 -44
  138. package/src/components/TopMenu.d.ts +0 -24
  139. package/src/components/TopMenu.d.ts.map +0 -1
  140. package/src/components/TopMenu.js +0 -36
  141. package/src/components/TranslatedTitle.d.ts +0 -7
  142. package/src/components/TranslatedTitle.d.ts.map +0 -1
  143. package/src/components/TranslatedTitle.js +0 -15
  144. package/src/components/UserLanguageSelector.d.ts +0 -4
  145. package/src/components/UserLanguageSelector.d.ts.map +0 -1
  146. package/src/components/UserLanguageSelector.js +0 -31
  147. package/src/components/UserMenu.d.ts +0 -4
  148. package/src/components/UserMenu.d.ts.map +0 -1
  149. package/src/components/UserMenu.js +0 -12
  150. package/src/components/UserSettingsForm.d.ts +0 -56
  151. package/src/components/UserSettingsForm.d.ts.map +0 -1
  152. package/src/components/UserSettingsForm.js +0 -93
  153. package/src/components/VerifyEmailPage.d.ts +0 -23
  154. package/src/components/VerifyEmailPage.d.ts.map +0 -1
  155. package/src/components/VerifyEmailPage.js +0 -61
  156. package/src/components/index.d.ts.map +0 -1
  157. package/src/components/index.js +0 -28
  158. package/src/contexts/AuthProvider.d.ts +0 -152
  159. package/src/contexts/AuthProvider.d.ts.map +0 -1
  160. package/src/contexts/AuthProvider.js +0 -446
  161. package/src/contexts/I18nProvider.d.ts +0 -16
  162. package/src/contexts/I18nProvider.d.ts.map +0 -1
  163. package/src/contexts/I18nProvider.js +0 -46
  164. package/src/contexts/MenuContext.d.ts +0 -20
  165. package/src/contexts/MenuContext.d.ts.map +0 -1
  166. package/src/contexts/MenuContext.js +0 -244
  167. package/src/contexts/SuiteConfigProvider.d.ts +0 -44
  168. package/src/contexts/SuiteConfigProvider.d.ts.map +0 -1
  169. package/src/contexts/SuiteConfigProvider.js +0 -43
  170. package/src/contexts/ThemeProvider.d.ts +0 -15
  171. package/src/contexts/ThemeProvider.d.ts.map +0 -1
  172. package/src/contexts/ThemeProvider.js +0 -36
  173. package/src/contexts/index.d.ts.map +0 -1
  174. package/src/contexts/index.js +0 -8
  175. package/src/hooks/index.d.ts.map +0 -1
  176. package/src/hooks/index.js +0 -8
  177. package/src/hooks/useBackupCodes.d.ts +0 -15
  178. package/src/hooks/useBackupCodes.d.ts.map +0 -1
  179. package/src/hooks/useBackupCodes.js +0 -70
  180. package/src/hooks/useEmailVerification.d.ts +0 -10
  181. package/src/hooks/useEmailVerification.d.ts.map +0 -1
  182. package/src/hooks/useEmailVerification.js +0 -36
  183. package/src/hooks/useExpiringValue.d.ts +0 -14
  184. package/src/hooks/useExpiringValue.d.ts.map +0 -1
  185. package/src/hooks/useExpiringValue.js +0 -53
  186. package/src/hooks/useLocalStorage.d.ts +0 -2
  187. package/src/hooks/useLocalStorage.d.ts.map +0 -1
  188. package/src/hooks/useLocalStorage.js +0 -15
  189. package/src/hooks/useUserSettings.d.ts +0 -46
  190. package/src/hooks/useUserSettings.d.ts.map +0 -1
  191. package/src/hooks/useUserSettings.js +0 -152
  192. package/src/index.d.ts.map +0 -1
  193. package/src/index.js +0 -12
  194. package/src/interfaces/IAppConfig.d.ts +0 -6
  195. package/src/interfaces/IAppConfig.d.ts.map +0 -1
  196. package/src/interfaces/IAppConfig.js +0 -2
  197. package/src/interfaces/IMenuConfig.d.ts +0 -11
  198. package/src/interfaces/IMenuConfig.d.ts.map +0 -1
  199. package/src/interfaces/IMenuConfig.js +0 -2
  200. package/src/interfaces/IMenuOption.d.ts +0 -58
  201. package/src/interfaces/IMenuOption.d.ts.map +0 -1
  202. package/src/interfaces/IMenuOption.js +0 -2
  203. package/src/interfaces/index.d.ts +0 -4
  204. package/src/interfaces/index.d.ts.map +0 -1
  205. package/src/interfaces/index.js +0 -6
  206. package/src/services/__mocks__/authService.d.ts +0 -21
  207. package/src/services/__mocks__/authService.d.ts.map +0 -1
  208. package/src/services/__mocks__/authService.js +0 -15
  209. package/src/services/api.d.ts +0 -3
  210. package/src/services/api.d.ts.map +0 -1
  211. package/src/services/api.js +0 -14
  212. package/src/services/authService.d.ts +0 -72
  213. package/src/services/authService.d.ts.map +0 -1
  214. package/src/services/authService.js +0 -347
  215. package/src/services/authenticatedApi.d.ts +0 -3
  216. package/src/services/authenticatedApi.d.ts.map +0 -1
  217. package/src/services/authenticatedApi.js +0 -18
  218. package/src/services/index.d.ts +0 -4
  219. package/src/services/index.d.ts.map +0 -1
  220. package/src/services/index.js +0 -6
  221. package/src/types/MenuType.d.ts +0 -11
  222. package/src/types/MenuType.d.ts.map +0 -1
  223. package/src/types/MenuType.js +0 -12
  224. package/src/types/expirationSeconds.d.ts +0 -3
  225. package/src/types/expirationSeconds.d.ts.map +0 -1
  226. package/src/types/expirationSeconds.js +0 -17
  227. package/src/types/index.d.ts +0 -2
  228. package/src/types/index.d.ts.map +0 -1
  229. package/src/types/index.js +0 -4
  230. package/src/types/translation.d.ts +0 -10
  231. package/src/types/translation.d.ts.map +0 -1
  232. package/src/types/translation.js +0 -9
  233. package/src/wrappers/BackupCodeLoginWrapper.d.ts +0 -8
  234. package/src/wrappers/BackupCodeLoginWrapper.d.ts.map +0 -1
  235. package/src/wrappers/BackupCodeLoginWrapper.js +0 -21
  236. package/src/wrappers/BackupCodesWrapper.d.ts +0 -7
  237. package/src/wrappers/BackupCodesWrapper.d.ts.map +0 -1
  238. package/src/wrappers/BackupCodesWrapper.js +0 -17
  239. package/src/wrappers/ChangePasswordFormWrapper.d.ts +0 -8
  240. package/src/wrappers/ChangePasswordFormWrapper.d.ts.map +0 -1
  241. package/src/wrappers/ChangePasswordFormWrapper.js +0 -21
  242. package/src/wrappers/LoginFormWrapper.d.ts +0 -9
  243. package/src/wrappers/LoginFormWrapper.d.ts.map +0 -1
  244. package/src/wrappers/LoginFormWrapper.js +0 -43
  245. package/src/wrappers/LogoutPageWrapper.d.ts +0 -9
  246. package/src/wrappers/LogoutPageWrapper.d.ts.map +0 -1
  247. package/src/wrappers/LogoutPageWrapper.js +0 -21
  248. package/src/wrappers/RegisterFormWrapper.d.ts +0 -9
  249. package/src/wrappers/RegisterFormWrapper.d.ts.map +0 -1
  250. package/src/wrappers/RegisterFormWrapper.js +0 -26
  251. package/src/wrappers/UserSettingsFormWrapper.d.ts +0 -8
  252. package/src/wrappers/UserSettingsFormWrapper.d.ts.map +0 -1
  253. package/src/wrappers/UserSettingsFormWrapper.js +0 -24
  254. package/src/wrappers/VerifyEmailPageWrapper.d.ts +0 -8
  255. package/src/wrappers/VerifyEmailPageWrapper.d.ts.map +0 -1
  256. package/src/wrappers/VerifyEmailPageWrapper.js +0 -20
  257. package/src/wrappers/index.d.ts.map +0 -1
  258. package/src/wrappers/index.js +0 -20
@@ -0,0 +1,48 @@
1
+ import { FC } from 'react';
2
+ import { useNavigate } from 'react-router-dom';
3
+ import { RegisterForm, RegisterFormValues, RegisterFormProps } from '../components/RegisterForm';
4
+ import { useAuth, useSuiteConfig } from '../contexts';
5
+
6
+ export interface RegisterFormWrapperProps {
7
+ onSuccess?: () => void;
8
+ redirectTo?: string;
9
+ componentProps?: Partial<Omit<RegisterFormProps, 'onSubmit' | 'timezones' | 'getInitialTimezone'>>;
10
+ }
11
+
12
+ export const RegisterFormWrapper: FC<RegisterFormWrapperProps> = ({
13
+ onSuccess,
14
+ redirectTo,
15
+ componentProps = {},
16
+ }) => {
17
+ const { register } = useAuth();
18
+ const navigate = useNavigate();
19
+ const { routes, timezones } = useSuiteConfig();
20
+
21
+ const handleSubmit = async (values: RegisterFormValues, usePassword: boolean) => {
22
+ const result = await register(
23
+ values.username,
24
+ values.email,
25
+ values.timezone || 'UTC',
26
+ values.password
27
+ );
28
+ if ('error' in result) {
29
+ throw new Error(result.error);
30
+ }
31
+ if (onSuccess) {
32
+ onSuccess();
33
+ }
34
+ navigate(redirectTo || routes.verifyEmail || '/verify-email');
35
+ return result;
36
+ };
37
+
38
+ const defaultTimezones = timezones || ['UTC', 'America/New_York', 'America/Los_Angeles', 'Europe/London'];
39
+
40
+ return (
41
+ <RegisterForm
42
+ onSubmit={handleSubmit}
43
+ timezones={defaultTimezones}
44
+ getInitialTimezone={() => Intl.DateTimeFormat().resolvedOptions().timeZone || 'UTC'}
45
+ {...componentProps}
46
+ />
47
+ );
48
+ };
@@ -0,0 +1,39 @@
1
+ import { FC } from 'react';
2
+ import { UserSettingsForm, UserSettingsFormValues, UserSettingsFormProps } from '../components/UserSettingsForm';
3
+ import { useSuiteConfig } from '../contexts';
4
+ import { useUserSettingsPublic } from '../hooks';
5
+ import { getSuiteCoreTranslation, SuiteCoreStringKey } from '@digitaldefiance/suite-core-lib';
6
+
7
+ export interface UserSettingsFormWrapperProps {
8
+ onSuccess?: () => void;
9
+ componentProps?: Partial<Omit<UserSettingsFormProps, 'initialValues' | 'onSubmit' | 'languages'>>;
10
+ }
11
+
12
+ export const UserSettingsFormWrapper: FC<UserSettingsFormWrapperProps> = ({
13
+ onSuccess,
14
+ componentProps = {},
15
+ }) => {
16
+ const { settings, isLoading, updateSettings } = useUserSettingsPublic();
17
+ const { languages } = useSuiteConfig();
18
+
19
+ const handleSubmit = async (values: UserSettingsFormValues) => {
20
+ const result = await updateSettings(values);
21
+ if ('success' in result && result.success && onSuccess) {
22
+ onSuccess();
23
+ }
24
+ return result;
25
+ };
26
+
27
+ if (isLoading || !settings) {
28
+ return <div>{getSuiteCoreTranslation(SuiteCoreStringKey.Common_Loading)}...</div>;
29
+ }
30
+
31
+ return (
32
+ <UserSettingsForm
33
+ initialValues={settings}
34
+ onSubmit={handleSubmit}
35
+ languages={languages}
36
+ {...componentProps}
37
+ />
38
+ );
39
+ };
@@ -0,0 +1,27 @@
1
+ import { FC } from 'react';
2
+ import { VerifyEmailPage } from '../components/VerifyEmailPage';
3
+ import { useEmailVerification } from '../hooks';
4
+
5
+ export interface VerifyEmailPageWrapperProps {
6
+ onSuccess?: () => void;
7
+ componentProps?: Partial<React.ComponentProps<typeof VerifyEmailPage>>;
8
+ }
9
+
10
+ export const VerifyEmailPageWrapper: FC<VerifyEmailPageWrapperProps> = ({
11
+ onSuccess,
12
+ componentProps = {},
13
+ }) => {
14
+ const searchParams = new URLSearchParams(window.location.search);
15
+ const token = searchParams.get('token');
16
+ const { verifyEmail } = useEmailVerification();
17
+
18
+ const handleVerify = async (verificationToken: string) => {
19
+ const result = await verifyEmail(verificationToken);
20
+ if (result.success && onSuccess) {
21
+ onSuccess();
22
+ }
23
+ return result;
24
+ };
25
+
26
+ return <VerifyEmailPage token={token} onVerify={handleVerify} {...componentProps} />;
27
+ };
@@ -1,17 +1,24 @@
1
+ // Re-export all wrapper components from their individual files
1
2
  export { BackupCodeLoginWrapper } from './BackupCodeLoginWrapper';
2
3
  export type { BackupCodeLoginWrapperProps } from './BackupCodeLoginWrapper';
4
+
3
5
  export { BackupCodesWrapper } from './BackupCodesWrapper';
4
6
  export type { BackupCodesWrapperProps } from './BackupCodesWrapper';
7
+
5
8
  export { ChangePasswordFormWrapper } from './ChangePasswordFormWrapper';
6
9
  export type { ChangePasswordFormWrapperProps } from './ChangePasswordFormWrapper';
10
+
7
11
  export { LoginFormWrapper } from './LoginFormWrapper';
8
12
  export type { LoginFormWrapperProps } from './LoginFormWrapper';
13
+
9
14
  export { RegisterFormWrapper } from './RegisterFormWrapper';
10
15
  export type { RegisterFormWrapperProps } from './RegisterFormWrapper';
16
+
11
17
  export { LogoutPageWrapper } from './LogoutPageWrapper';
12
18
  export type { LogoutPageWrapperProps } from './LogoutPageWrapper';
19
+
13
20
  export { VerifyEmailPageWrapper } from './VerifyEmailPageWrapper';
14
21
  export type { VerifyEmailPageWrapperProps } from './VerifyEmailPageWrapper';
22
+
15
23
  export { UserSettingsFormWrapper } from './UserSettingsFormWrapper';
16
24
  export type { UserSettingsFormWrapperProps } from './UserSettingsFormWrapper';
17
- //# sourceMappingURL=index.d.ts.map
@@ -1,6 +0,0 @@
1
- import { FC, ReactNode } from 'react';
2
- export interface PrivateProps {
3
- children: ReactNode;
4
- }
5
- export declare const Private: FC<PrivateProps>;
6
- //# sourceMappingURL=Private.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Private.d.ts","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-express-suite-react-components/src/auth/Private.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,SAAS,EAAc,MAAM,OAAO,CAAC;AAElD,MAAM,WAAW,YAAY;IAC3B,QAAQ,EAAE,SAAS,CAAC;CACrB;AAED,eAAO,MAAM,OAAO,EAAE,EAAE,CAAC,YAAY,CAUpC,CAAC"}
@@ -1,14 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Private = void 0;
4
- const jsx_runtime_1 = require("react/jsx-runtime");
5
- const react_1 = require("react");
6
- const AuthProvider_1 = require("../contexts/AuthProvider");
7
- const Private = ({ children, }) => {
8
- const { isAuthenticated, isCheckingAuth } = (0, react_1.useContext)(AuthProvider_1.AuthContext);
9
- if (isCheckingAuth || !isAuthenticated) {
10
- return (0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, {});
11
- }
12
- return (0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, { children: children });
13
- };
14
- exports.Private = Private;
@@ -1,8 +0,0 @@
1
- import { FC, ReactNode } from 'react';
2
- interface PrivateRouteProps {
3
- children: ReactNode;
4
- redirectTo?: string;
5
- }
6
- export declare const PrivateRoute: FC<PrivateRouteProps>;
7
- export default PrivateRoute;
8
- //# sourceMappingURL=PrivateRoute.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"PrivateRoute.d.ts","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-express-suite-react-components/src/auth/PrivateRoute.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,SAAS,EAAc,MAAM,OAAO,CAAC;AAMlD,UAAU,iBAAiB;IACzB,QAAQ,EAAE,SAAS,CAAC;IACpB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED,eAAO,MAAM,YAAY,EAAE,EAAE,CAAC,iBAAiB,CAc9C,CAAC;AAEF,eAAe,YAAY,CAAC"}
@@ -1,23 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.PrivateRoute = void 0;
4
- const jsx_runtime_1 = require("react/jsx-runtime");
5
- const react_1 = require("react");
6
- const react_router_dom_1 = require("react-router-dom");
7
- const AuthProvider_1 = require("../contexts/AuthProvider");
8
- const contexts_1 = require("../contexts");
9
- const suite_core_lib_1 = require("@digitaldefiance/suite-core-lib");
10
- const PrivateRoute = ({ children, redirectTo }) => {
11
- const { tComponent } = (0, contexts_1.useI18n)();
12
- const { isAuthenticated, isCheckingAuth } = (0, react_1.useContext)(AuthProvider_1.AuthContext);
13
- const location = (0, react_router_dom_1.useLocation)();
14
- if (isCheckingAuth) {
15
- return (0, jsx_runtime_1.jsxs)("div", { children: [tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Common_CheckingAuthentication), "..."] });
16
- }
17
- if (!isAuthenticated) {
18
- return (0, jsx_runtime_1.jsx)(react_router_dom_1.Navigate, { to: redirectTo ?? "/login", state: { from: location }, replace: true });
19
- }
20
- return (0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, { children: children });
21
- };
22
- exports.PrivateRoute = PrivateRoute;
23
- exports.default = exports.PrivateRoute;
@@ -1,6 +0,0 @@
1
- import { FC, ReactNode } from 'react';
2
- export interface UnAuthProps {
3
- children: ReactNode;
4
- }
5
- export declare const UnAuth: FC<UnAuthProps>;
6
- //# sourceMappingURL=UnAuth.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"UnAuth.d.ts","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-express-suite-react-components/src/auth/UnAuth.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,SAAS,EAAc,MAAM,OAAO,CAAC;AAGlD,MAAM,WAAW,WAAW;IAC1B,QAAQ,EAAE,SAAS,CAAC;CACrB;AAED,eAAO,MAAM,MAAM,EAAE,EAAE,CAAC,WAAW,CAQlC,CAAC"}
@@ -1,14 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.UnAuth = void 0;
4
- const jsx_runtime_1 = require("react/jsx-runtime");
5
- const react_1 = require("react");
6
- const AuthProvider_1 = require("../contexts/AuthProvider");
7
- const UnAuth = ({ children }) => {
8
- const { isAuthenticated, isCheckingAuth } = (0, react_1.useContext)(AuthProvider_1.AuthContext);
9
- if (isCheckingAuth || isAuthenticated) {
10
- return null;
11
- }
12
- return (0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, { children: children });
13
- };
14
- exports.UnAuth = UnAuth;
@@ -1,8 +0,0 @@
1
- import { FC, ReactNode } from 'react';
2
- export interface UnAuthRouteProps {
3
- children: ReactNode;
4
- redirectTo?: string;
5
- }
6
- export declare const UnAuthRoute: FC<UnAuthRouteProps>;
7
- export default UnAuthRoute;
8
- //# sourceMappingURL=UnAuthRoute.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"UnAuthRoute.d.ts","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-express-suite-react-components/src/auth/UnAuthRoute.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,SAAS,EAAc,MAAM,OAAO,CAAC;AAKlD,MAAM,WAAW,gBAAgB;IAC/B,QAAQ,EAAE,SAAS,CAAC;IACpB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED,eAAO,MAAM,WAAW,EAAE,EAAE,CAAC,gBAAgB,CAiB5C,CAAC;AAEF,eAAe,WAAW,CAAC"}
@@ -1,22 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.UnAuthRoute = void 0;
4
- const jsx_runtime_1 = require("react/jsx-runtime");
5
- const react_1 = require("react");
6
- const react_router_dom_1 = require("react-router-dom");
7
- const contexts_1 = require("../contexts");
8
- const suite_core_lib_1 = require("@digitaldefiance/suite-core-lib");
9
- const UnAuthRoute = ({ children, redirectTo = '/dashboard', }) => {
10
- const { isAuthenticated, isCheckingAuth } = (0, react_1.useContext)(contexts_1.AuthContext);
11
- const { tComponent } = (0, contexts_1.useI18n)();
12
- const location = (0, react_router_dom_1.useLocation)();
13
- if (isCheckingAuth) {
14
- return (0, jsx_runtime_1.jsxs)("div", { children: [tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Common_CheckingAuthentication), "..."] });
15
- }
16
- if (isAuthenticated) {
17
- return (0, jsx_runtime_1.jsx)(react_router_dom_1.Navigate, { to: redirectTo ?? "/dashboard", state: { from: location }, replace: true });
18
- }
19
- return (0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, { children: children });
20
- };
21
- exports.UnAuthRoute = UnAuthRoute;
22
- exports.default = exports.UnAuthRoute;
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-express-suite-react-components/src/auth/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,YAAY,EAAE,MAAM,gBAAgB,CAAC;AACzD,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,eAAe,CAAC;AACvD,cAAc,WAAW,CAAC;AAC1B,cAAc,UAAU,CAAA"}
package/src/auth/index.js DELETED
@@ -1,10 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.UnAuthRoute = exports.PrivateRoute = void 0;
4
- const tslib_1 = require("tslib");
5
- var PrivateRoute_1 = require("./PrivateRoute");
6
- Object.defineProperty(exports, "PrivateRoute", { enumerable: true, get: function () { return tslib_1.__importDefault(PrivateRoute_1).default; } });
7
- var UnAuthRoute_1 = require("./UnAuthRoute");
8
- Object.defineProperty(exports, "UnAuthRoute", { enumerable: true, get: function () { return tslib_1.__importDefault(UnAuthRoute_1).default; } });
9
- tslib_1.__exportStar(require("./Private"), exports);
10
- tslib_1.__exportStar(require("./UnAuth"), exports);
@@ -1,16 +0,0 @@
1
- import { FC } from 'react';
2
- export interface ApiAccessProps {
3
- token?: string | null;
4
- labels?: {
5
- title?: string;
6
- tokenNotAvailable?: string;
7
- copyButton?: string;
8
- notificationTitle?: string;
9
- copied?: string;
10
- copyFailed?: string;
11
- ok?: string;
12
- };
13
- }
14
- export declare const ApiAccess: FC<ApiAccessProps>;
15
- export default ApiAccess;
16
- //# sourceMappingURL=ApiAccess.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ApiAccess.d.ts","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-express-suite-react-components/src/components/ApiAccess.tsx"],"names":[],"mappings":"AAYA,OAAO,EAAE,EAAE,EAAY,MAAM,OAAO,CAAC;AA4BrC,MAAM,WAAW,cAAc;IAC7B,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACtB,MAAM,CAAC,EAAE;QACP,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,iBAAiB,CAAC,EAAE,MAAM,CAAC;QAC3B,UAAU,CAAC,EAAE,MAAM,CAAC;QACpB,iBAAiB,CAAC,EAAE,MAAM,CAAC;QAC3B,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,UAAU,CAAC,EAAE,MAAM,CAAC;QACpB,EAAE,CAAC,EAAE,MAAM,CAAC;KACb,CAAC;CACH;AAED,eAAO,MAAM,SAAS,EAAE,EAAE,CAAC,cAAc,CA8ExC,CAAC;AAEF,eAAe,SAAS,CAAC"}
@@ -1,70 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.ApiAccess = void 0;
4
- const tslib_1 = require("tslib");
5
- const jsx_runtime_1 = require("react/jsx-runtime");
6
- const ContentCopy_1 = tslib_1.__importDefault(require("@mui/icons-material/ContentCopy"));
7
- const material_1 = require("@mui/material");
8
- const react_1 = require("react");
9
- const suite_core_lib_1 = require("@digitaldefiance/suite-core-lib");
10
- const contexts_1 = require("../contexts");
11
- const ApiAccessContainer = (0, material_1.styled)(material_1.Box)(({ theme }) => ({
12
- display: 'flex',
13
- flexDirection: 'column',
14
- alignItems: 'center',
15
- justifyContent: 'center',
16
- minHeight: '100vh',
17
- backgroundColor: theme.palette.background.default,
18
- padding: theme.spacing(3),
19
- }));
20
- const ApiAccessContent = (0, material_1.styled)(material_1.Box)(({ theme }) => ({
21
- maxWidth: '600px',
22
- width: '100%',
23
- backgroundColor: theme.palette.background.paper,
24
- borderRadius: theme.shape.borderRadius,
25
- padding: theme.spacing(4),
26
- boxShadow: theme.shadows[3],
27
- }));
28
- const ApiAccessTitle = (0, material_1.styled)(material_1.Typography)(({ theme }) => ({
29
- marginBottom: theme.spacing(3),
30
- color: theme.palette.primary.main,
31
- }));
32
- const ApiAccess = ({ token: tokenProp, labels = {}, }) => {
33
- const { token: authToken } = (0, contexts_1.useAuth)();
34
- const token = tokenProp !== undefined ? tokenProp : authToken;
35
- const { tComponent } = (0, contexts_1.useI18n)();
36
- const [dialogOpen, setDialogOpen] = (0, react_1.useState)(false);
37
- const [isError, setIsError] = (0, react_1.useState)(false);
38
- const translatedLabels = {
39
- title: labels.title || tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.ApiAccess_Title),
40
- tokenNotAvailable: labels.tokenNotAvailable || tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.ApiAccess_TokenNotAvailable),
41
- copyButton: labels.copyButton || tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Common_CopyToClipboard),
42
- notificationTitle: labels.notificationTitle || tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Common_Notification),
43
- copied: labels.copied || tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Common_CopiedToClipboard),
44
- copyFailed: labels.copyFailed || tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Error_FailedToCopy),
45
- ok: labels.ok || tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Common_OK),
46
- };
47
- const copyToClipboard = async () => {
48
- if (token) {
49
- try {
50
- await navigator.clipboard.writeText(token);
51
- setIsError(false);
52
- setDialogOpen(true);
53
- }
54
- catch (err) {
55
- setIsError(true);
56
- }
57
- }
58
- };
59
- const handleClose = () => {
60
- setDialogOpen(false);
61
- setIsError(false);
62
- };
63
- return ((0, jsx_runtime_1.jsxs)(ApiAccessContainer, { children: [(0, jsx_runtime_1.jsxs)(ApiAccessContent, { children: [(0, jsx_runtime_1.jsx)(ApiAccessTitle, { variant: "h4", align: "center", children: translatedLabels.title }), (0, jsx_runtime_1.jsx)(material_1.TextField, { fullWidth: true, multiline: true, rows: 4, value: token || translatedLabels.tokenNotAvailable, slotProps: {
64
- input: {
65
- readOnly: true,
66
- },
67
- }, variant: "outlined", margin: "normal" }), (0, jsx_runtime_1.jsx)(material_1.Button, { variant: "contained", color: "primary", startIcon: (0, jsx_runtime_1.jsx)(ContentCopy_1.default, {}), onClick: copyToClipboard, fullWidth: true, style: { marginTop: '16px' }, children: translatedLabels.copyButton })] }), (0, jsx_runtime_1.jsxs)(material_1.Dialog, { open: dialogOpen, onClose: handleClose, children: [(0, jsx_runtime_1.jsx)(material_1.DialogTitle, { children: translatedLabels.notificationTitle }), (0, jsx_runtime_1.jsx)(material_1.DialogContent, { children: isError ? translatedLabels.copyFailed : translatedLabels.copied }), (0, jsx_runtime_1.jsx)(material_1.DialogActions, { children: (0, jsx_runtime_1.jsx)(material_1.Button, { onClick: handleClose, color: "primary", children: translatedLabels.ok }) })] })] }));
68
- };
69
- exports.ApiAccess = ApiAccess;
70
- exports.default = exports.ApiAccess;
@@ -1,43 +0,0 @@
1
- import { FC } from 'react';
2
- import * as Yup from 'yup';
3
- export interface BackupCodeLoginFormValues {
4
- email: string;
5
- username: string;
6
- code: string;
7
- newPassword?: string;
8
- confirmNewPassword?: string;
9
- recoverMnemonic: boolean;
10
- }
11
- export interface BackupCodeLoginFormProps {
12
- onSubmit: (identifier: string, code: string, isEmail: boolean, recoverMnemonic: boolean, newPassword?: string) => Promise<{
13
- token: string;
14
- codeCount: number;
15
- mnemonic?: string;
16
- message?: string;
17
- } | {
18
- error: string;
19
- status?: number;
20
- }>;
21
- onNavigate?: (path: string, state?: any) => void;
22
- isAuthenticated?: boolean;
23
- validationSchema?: Yup.ObjectSchema<any>;
24
- labels?: {
25
- title?: string;
26
- email?: string;
27
- username?: string;
28
- code?: string;
29
- newPassword?: string;
30
- confirmPassword?: string;
31
- recoverMnemonic?: string;
32
- login?: string;
33
- useUsername?: string;
34
- useEmail?: string;
35
- dashboard?: string;
36
- generateNewCodes?: string;
37
- mnemonicLabel?: string;
38
- codesRemaining?: string;
39
- };
40
- }
41
- export declare const BackupCodeLoginForm: FC<BackupCodeLoginFormProps>;
42
- export default BackupCodeLoginForm;
43
- //# sourceMappingURL=BackupCodeLoginForm.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"BackupCodeLoginForm.d.ts","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-express-suite-react-components/src/components/BackupCodeLoginForm.tsx"],"names":[],"mappings":"AAUA,OAAO,EAAE,EAAE,EAAY,MAAM,OAAO,CAAC;AACrC,OAAO,KAAK,GAAG,MAAM,KAAK,CAAC;AAI3B,MAAM,WAAW,yBAAyB;IACxC,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,eAAe,EAAE,OAAO,CAAC;CAC1B;AAED,MAAM,WAAW,wBAAwB;IACvC,QAAQ,EAAE,CACR,UAAU,EAAE,MAAM,EAClB,IAAI,EAAE,MAAM,EACZ,OAAO,EAAE,OAAO,EAChB,eAAe,EAAE,OAAO,EACxB,WAAW,CAAC,EAAE,MAAM,KACjB,OAAO,CACR;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAC;QAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;QAAC,OAAO,CAAC,EAAE,MAAM,CAAA;KAAE,GACzE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,MAAM,CAAC,EAAE,MAAM,CAAA;KAAE,CACrC,CAAC;IACF,UAAU,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,GAAG,KAAK,IAAI,CAAC;IACjD,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,gBAAgB,CAAC,EAAE,GAAG,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;IACzC,MAAM,CAAC,EAAE;QACP,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,eAAe,CAAC,EAAE,MAAM,CAAC;QACzB,eAAe,CAAC,EAAE,MAAM,CAAC;QACzB,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,gBAAgB,CAAC,EAAE,MAAM,CAAC;QAC1B,aAAa,CAAC,EAAE,MAAM,CAAC;QACvB,cAAc,CAAC,EAAE,MAAM,CAAC;KACzB,CAAC;CACH;AAED,eAAO,MAAM,mBAAmB,EAAE,EAAE,CAAC,wBAAwB,CA+P5D,CAAC;AAEF,eAAe,mBAAmB,CAAC"}
@@ -1,106 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.BackupCodeLoginForm = void 0;
4
- const tslib_1 = require("tslib");
5
- const jsx_runtime_1 = require("react/jsx-runtime");
6
- const material_1 = require("@mui/material");
7
- const formik_1 = require("formik");
8
- const react_1 = require("react");
9
- const Yup = tslib_1.__importStar(require("yup"));
10
- const suite_core_lib_1 = require("@digitaldefiance/suite-core-lib");
11
- const contexts_1 = require("../contexts");
12
- const BackupCodeLoginForm = ({ onSubmit, onNavigate, isAuthenticated = false, validationSchema, labels = {}, }) => {
13
- const { tComponent } = (0, contexts_1.useI18n)();
14
- const [loginType, setLoginType] = (0, react_1.useState)('email');
15
- const [loginError, setLoginError] = (0, react_1.useState)(null);
16
- const [recoveredMnemonic, setRecoveredMnemonic] = (0, react_1.useState)(null);
17
- const [successMessage, setSuccessMessage] = (0, react_1.useState)(null);
18
- const [codesRemaining, setCodesRemaining] = (0, react_1.useState)(null);
19
- const translatedLabels = {
20
- title: labels.title || tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.BackupCodeRecovery_Title),
21
- email: labels.email || tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Common_Email),
22
- username: labels.username || tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Common_Username),
23
- code: labels.code || tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Common_BackupCode),
24
- newPassword: labels.newPassword || tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Common_NewPassword),
25
- confirmPassword: labels.confirmPassword || tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Common_ConfirmNewPassword),
26
- recoverMnemonic: labels.recoverMnemonic || tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.BackupCodeRecovery_RecoverMnemonic),
27
- login: labels.login || tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.BackupCodeRecovery_Login),
28
- useUsername: labels.useUsername || tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Login_UseUsername),
29
- useEmail: labels.useEmail || tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Login_UseEmailAddress),
30
- dashboard: labels.dashboard || tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Common_Dashboard),
31
- generateNewCodes: labels.generateNewCodes || tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.BackupCodeRecovery_GenerateNewCodes),
32
- mnemonicLabel: labels.mnemonicLabel || tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Common_Mnemonic),
33
- codesRemaining: labels.codesRemaining || tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.BackupCodeRecovery_CodesRemainingTemplate),
34
- unexpectedError: tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Common_UnexpectedError),
35
- };
36
- const yupFieldValidation = {
37
- email: Yup.string()
38
- .email(tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Validation_InvalidEmail))
39
- .required(tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Validation_Required)),
40
- username: Yup.string()
41
- .matches(suite_core_lib_1.Constants.UsernameRegex, tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Validation_UsernameRegexErrorTemplate))
42
- .required(tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Validation_Required)),
43
- code: Yup.string()
44
- .required(tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Validation_Required))
45
- .matches(suite_core_lib_1.Constants.BACKUP_CODES.DisplayRegex, tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Validation_InvalidBackupCode)),
46
- password: Yup.string()
47
- .matches(suite_core_lib_1.Constants.PasswordRegex, tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Validation_PasswordRegexErrorTemplate)),
48
- confirmPassword: Yup.string()
49
- .oneOf([Yup.ref('newPassword')], tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Validation_PasswordMatch)),
50
- };
51
- const formik = (0, formik_1.useFormik)({
52
- initialValues: {
53
- email: '',
54
- username: '',
55
- code: '',
56
- newPassword: '',
57
- confirmNewPassword: '',
58
- recoverMnemonic: false,
59
- },
60
- validationSchema: validationSchema ?? Yup.object({
61
- [loginType]: loginType === 'email' ? yupFieldValidation.email : yupFieldValidation.username,
62
- code: yupFieldValidation.code,
63
- newPassword: yupFieldValidation.password,
64
- confirmNewPassword: yupFieldValidation.confirmPassword,
65
- }),
66
- enableReinitialize: true,
67
- onSubmit: async (values, { setSubmitting }) => {
68
- try {
69
- const loginResult = await onSubmit(loginType === 'email' ? values.email : values.username, values.code, loginType === 'email', values.recoverMnemonic, values.newPassword && values.newPassword.length > 0 ? values.newPassword : undefined);
70
- if ('error' in loginResult) {
71
- setLoginError(loginResult.error);
72
- setCodesRemaining(null);
73
- setRecoveredMnemonic(null);
74
- return;
75
- }
76
- setLoginError(null);
77
- if (loginResult.codeCount) {
78
- setCodesRemaining(loginResult.codeCount);
79
- }
80
- if (loginResult.mnemonic) {
81
- setRecoveredMnemonic(loginResult.mnemonic);
82
- }
83
- if (loginResult.message) {
84
- setSuccessMessage(loginResult.message);
85
- }
86
- }
87
- catch {
88
- setLoginError(translatedLabels.unexpectedError);
89
- }
90
- finally {
91
- setSubmitting(false);
92
- }
93
- },
94
- });
95
- if (isAuthenticated && recoveredMnemonic === null && codesRemaining === null) {
96
- onNavigate?.('/dashboard');
97
- return null;
98
- }
99
- return ((0, jsx_runtime_1.jsx)(material_1.Container, { component: "main", maxWidth: "xs", children: (0, jsx_runtime_1.jsxs)(material_1.Box, { sx: { marginTop: 8, display: 'flex', flexDirection: 'column', alignItems: 'center' }, children: [(0, jsx_runtime_1.jsx)(material_1.Typography, { component: "h1", variant: "h5", children: translatedLabels.title }), (0, jsx_runtime_1.jsxs)(material_1.Box, { component: "form", onSubmit: formik.handleSubmit, sx: { mt: 1, width: '100%' }, children: [!isAuthenticated && ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(material_1.TextField, { margin: "normal", fullWidth: true, id: loginType, label: loginType === 'email' ? translatedLabels.email : translatedLabels.username, name: loginType, autoComplete: loginType === 'email' ? 'email' : 'username', autoFocus: true, value: loginType === 'email' ? formik.values.email : formik.values.username, onChange: formik.handleChange, onBlur: formik.handleBlur, error: formik.touched[loginType] && Boolean(formik.errors[loginType]), helperText: formik.touched[loginType] && formik.errors[loginType], disabled: isAuthenticated }), (0, jsx_runtime_1.jsx)(material_1.TextField, { margin: "normal", required: true, fullWidth: true, name: "code", label: translatedLabels.code, id: "code", value: formik.values.code, onChange: formik.handleChange, onBlur: formik.handleBlur, error: formik.touched.code && Boolean(formik.errors.code), helperText: formik.touched.code && formik.errors.code, disabled: isAuthenticated }), (0, jsx_runtime_1.jsx)(material_1.TextField, { margin: "normal", fullWidth: true, name: "newPassword", label: translatedLabels.newPassword, type: "password", id: "newPassword", value: formik.values.newPassword, onChange: formik.handleChange, onBlur: formik.handleBlur, error: formik.touched.newPassword && Boolean(formik.errors.newPassword), helperText: formik.touched.newPassword && formik.errors.newPassword, disabled: isAuthenticated }), (0, jsx_runtime_1.jsx)(material_1.TextField, { margin: "normal", fullWidth: true, name: "confirmNewPassword", label: translatedLabels.confirmPassword, type: "password", id: "confirmNewPassword", value: formik.values.confirmNewPassword, onChange: formik.handleChange, onBlur: formik.handleBlur, error: formik.touched.confirmNewPassword && Boolean(formik.errors.confirmNewPassword), helperText: formik.touched.confirmNewPassword && formik.errors.confirmNewPassword, disabled: isAuthenticated }), (0, jsx_runtime_1.jsx)(material_1.FormControlLabel, { control: (0, jsx_runtime_1.jsx)(material_1.Checkbox, { checked: formik.values.recoverMnemonic, onChange: formik.handleChange, onBlur: formik.handleBlur, name: "recoverMnemonic" }), label: translatedLabels.recoverMnemonic, disabled: isAuthenticated })] })), successMessage && ((0, jsx_runtime_1.jsx)(material_1.Typography, { color: "success.main", variant: "body2", sx: { mt: 1 }, children: successMessage })), recoveredMnemonic && ((0, jsx_runtime_1.jsxs)(material_1.Box, { sx: { mt: 2, p: 2, bgcolor: 'grey.100', borderRadius: 1 }, children: [(0, jsx_runtime_1.jsxs)(material_1.Typography, { variant: "subtitle2", gutterBottom: true, children: [translatedLabels.mnemonicLabel, ":"] }), (0, jsx_runtime_1.jsx)(material_1.Typography, { variant: "body2", sx: { fontFamily: 'monospace' }, children: recoveredMnemonic }), (0, jsx_runtime_1.jsx)(material_1.Button, { fullWidth: true, variant: "contained", sx: { mt: 2 }, onClick: () => onNavigate?.('/dashboard'), children: translatedLabels.dashboard })] })), codesRemaining !== null && ((0, jsx_runtime_1.jsxs)(material_1.Box, { sx: { mt: 2 }, children: [(0, jsx_runtime_1.jsx)(material_1.Typography, { variant: "body2", children: translatedLabels.codesRemaining.replace('{count}', String(codesRemaining)) }), (0, jsx_runtime_1.jsx)(material_1.Button, { fullWidth: true, variant: "contained", sx: { mt: 2 }, onClick: () => onNavigate?.('/backup-codes', { codeCount: codesRemaining }), children: translatedLabels.generateNewCodes })] })), loginError && ((0, jsx_runtime_1.jsx)(material_1.Typography, { color: "error", variant: "body2", sx: { mt: 1 }, children: loginError })), !isAuthenticated && ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(material_1.Button, { type: "submit", fullWidth: true, variant: "contained", sx: { mt: 3, mb: 2 }, disabled: formik.isSubmitting, children: translatedLabels.login }), (0, jsx_runtime_1.jsx)(material_1.Box, { sx: { display: 'flex', justifyContent: 'center' }, children: (0, jsx_runtime_1.jsx)(material_1.Button, { fullWidth: true, variant: "text", onClick: () => {
100
- const newType = loginType === 'email' ? 'username' : 'email';
101
- formik.setFieldValue(loginType, '');
102
- setLoginType(newType);
103
- }, children: loginType === 'email' ? translatedLabels.useUsername : translatedLabels.useEmail }) })] }))] })] }) }));
104
- };
105
- exports.BackupCodeLoginForm = BackupCodeLoginForm;
106
- exports.default = exports.BackupCodeLoginForm;
@@ -1,26 +0,0 @@
1
- import { FC } from 'react';
2
- import * as Yup from 'yup';
3
- export interface BackupCodesFormValues {
4
- password?: string;
5
- mnemonic?: string;
6
- }
7
- export interface BackupCodesFormProps {
8
- onSubmit: (values: BackupCodesFormValues) => Promise<{
9
- message: string;
10
- backupCodes: string[];
11
- }>;
12
- backupCodesRemaining?: number | null;
13
- mnemonicValidation?: Yup.StringSchema;
14
- passwordValidation?: Yup.StringSchema;
15
- labels?: {
16
- title?: string;
17
- codesRemaining?: string;
18
- mnemonic?: string;
19
- password?: string;
20
- generateButton?: string;
21
- successTitle?: string;
22
- };
23
- }
24
- export declare const BackupCodesForm: FC<BackupCodesFormProps>;
25
- export default BackupCodesForm;
26
- //# sourceMappingURL=BackupCodesForm.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"BackupCodesForm.d.ts","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-express-suite-react-components/src/components/BackupCodesForm.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,EAAE,EAAY,MAAM,OAAO,CAAC;AACrC,OAAO,KAAK,GAAG,MAAM,KAAK,CAAC;AAI3B,MAAM,WAAW,qBAAqB;IACpC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,oBAAoB;IACnC,QAAQ,EAAE,CAAC,MAAM,EAAE,qBAAqB,KAAK,OAAO,CAAC;QACnD,OAAO,EAAE,MAAM,CAAC;QAChB,WAAW,EAAE,MAAM,EAAE,CAAC;KACvB,CAAC,CAAC;IACH,oBAAoB,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACrC,kBAAkB,CAAC,EAAE,GAAG,CAAC,YAAY,CAAC;IACtC,kBAAkB,CAAC,EAAE,GAAG,CAAC,YAAY,CAAC;IACtC,MAAM,CAAC,EAAE;QACP,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,cAAc,CAAC,EAAE,MAAM,CAAC;QACxB,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,cAAc,CAAC,EAAE,MAAM,CAAC;QACxB,YAAY,CAAC,EAAE,MAAM,CAAC;KACvB,CAAC;CACH;AAED,eAAO,MAAM,eAAe,EAAE,EAAE,CAAC,oBAAoB,CAqKpD,CAAC;AAEF,eAAe,eAAe,CAAC"}